harperdb 4.0.1 → 4.0.2
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 +2 -2
- package/launchServiceScripts/launchCustomFunctions.js +2 -2
- package/launchServiceScripts/launchHarperDB.js +2 -2
- package/launchServiceScripts/launchInstallNATSServer.js +1 -1
- package/launchServiceScripts/launchNatsIngestService.js +2 -2
- package/launchServiceScripts/launchNatsReplyService.js +2 -2
- package/package.json +3 -3
- package/server/ipc/hdbIpcServer.js +1 -1
- package/server/jobs/jobProcess.js +2 -2
- package/utility/scripts/restartHdb.js +2 -2
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";var Tb=Object.defineProperty;var a=(e,t)=>Tb(e,"name",{value:t,configurable:!0});var S=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var is=S((M1,mb)=>{mb.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_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]}}});var T=S((P1,sh)=>{"use strict";var $e=require("path"),Rb=require("fs");function Ab(){let e=__dirname;for(;!Rb.existsSync($e.join(e,"package.json"));){let t=$e.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(Ab,"getHDBPackageRoot");var Gt=Ab(),Yd="js",xn=Yd,Ob="harperdb-config.yaml",pb="defaultConfig.yaml",Nb="hdb",Kd=`hdbServer.${xn}`,Qd=`customFunctionsServer.${xn}`,Wd=`hdbIpcServer.${xn}`,gb=`restartHdb.${xn}`,X_="HarperDB",da="Custom Functions",ha="Clustering Hub",Sa="Clustering Leaf",z_="Clustering Ingest Service",j_="Clustering Reply Service",Ib="foreground.pid",Z_={HDB:X_,IPC:"IPC",CLUSTERING_HUB:ha,CLUSTERING_LEAF:Sa,CLUSTERING_INGEST_SERVICE:z_,CLUSTERING_REPLY_SERVICE:j_,CUSTOM_FUNCTIONS:da,RESTART_HDB:"Restart HDB",INSTALL:"Install",RUN:"Run",STOP:"Stop",UPGRADE:"Upgrade",REGISTER:"Register",JOB:"Job",PM2_LOGROTATE:"pm2-logrotate",CLUSTERING_UPGRADE_4_0_0:"Upgrade-4-0-0"},bb={HDB:"hdb.log",IPC:"ipc.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log",CLUSTERING_INGEST_SERVICE:"clustering_ingest_service.log",CLUSTERING_REPLY_SERVICE:"clustering_reply_service.log",CUSTOM_FUNCTIONS:"custom_functions.log",INSTALL:"install.log",CLI:"cli.log",PM2:"pm2.log",CLUSTERING_UPGRADE:"clustering_upgrade.log",JOBS:"jobs.log"},Cb={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},wb={harperdb:X_,ipc:"IPC","clustering hub":ha,"clustering leaf":Sa,"clustering ingest service":z_,"clustering reply service":j_,"custom functions":da,custom_functions:da,"pm2-logrotate":Z_.PM2_LOGROTATE,logrotate:Z_.PM2_LOGROTATE,clustering:"clustering","clustering config":"clustering config"},Lb={CLUSTERING_HUB_PROC_DESCRIPTOR:ha,CLUSTERING_LEAF_PROC_DESCRIPTOR:Sa,CLUSTERING_INGEST_PROC_DESCRIPTOR:z_,CLUSTERING_REPLY_SERVICE_DESCRIPTOR:j_},Ea={HDB:$e.join(Gt,"server/harperdb"),IPC:$e.join(Gt,"server/ipc"),CUSTOM_FUNCTIONS:$e.join(Gt,"server/customFunctions"),CLUSTERING_HUB:$e.join(Gt,"server/nats"),CLUSTERING_LEAF:$e.join(Gt,"server/nats")},Ub={HDB:$e.join(Ea.HDB,Kd),IPC:$e.join(Ea.IPC,Wd),CUSTOM_FUNCTIONS:$e.join(Ea.CUSTOM_FUNCTIONS,Qd)},yb={HDB:$e.join(Gt,"launchServiceScripts/launchHarperDB.js"),CUSTOM_FUNCTIONS:$e.join(Gt,"launchServiceScripts/launchCustomFunctions.js"),NATS_INGEST_SERVICE:$e.join(Gt,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:$e.join(Gt,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:$e.resolve(Gt,"launchServiceScripts/launchUpdateNodes4-0-0.js")},Db={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},Jd="support@harperdb.io",Mb="customer-success@harperdb.io",Zd=1,Pb=4141,Xd="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",Bb="https://www.harperdb.io/product",vb=`For support, please submit a request at ${Xd} or contact ${Jd}`,zd=`For license support, please contact ${Mb}`,Hb="None of the specified records were found.",Gb="hash attribute not found",qb=`Your current license only supports ${Zd} role. ${zd}`,Fb="Your current license only supports 3 connections to a node.",Vb="127.0.0.1",kb=1,xb=/^\.$/,$b=/^\.\.$/,Yb="U+002E",Kb=/\//g,Qb="U+002F",Wb=/U\+002F/g,Jb=/^U\+002E$/,Zb=/^U\+002EU\+002E$/,Xb="d",zb=999999,jb="*",eC="--max-old-space-size=",tC="system",rC="__hdb_hash",sC=".harperdb",nC=".hdb",iC="keys",aC="hdb_boot_properties.file",oC=".updateConfig.json",cC="SIGTSTP",_C=24,uC=6e4,lC=448,EC="blob",dC="trash",hC="schema",SC="transactions",fC=".count",TC="id",mC="install_log.log",RC="run_log.log",AC="PROCESS_NAME",OC={SETTINGS_PATH_KEY:"settings_path"},jd=require("lodash"),pC={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",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},NC={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},gC={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},IC={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"},bC={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"},ht="hdb_internal:",CC={CREATE_SCHEMA:ht+"create_schema",CREATE_TABLE:ht+"create_table",CREATE_ATTRIBUTE:ht+"create_attribute",ADD_USER:ht+"add_user",ALTER_USER:ht+"alter_user",DROP_USER:ht+"drop_user",HDB_NODES:ht+"hdb_nodes",HDB_USERS:ht+"hdb_users",HDB_WORKERS:ht+"hdb_workers",CATCHUP:ht+"catchup",SCHEMA_CATCHUP:ht+"schema_catchup",WORKER_ROOM:ht+"cluster_workers"},wC={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"},LC="060493.ks",UC=".license",yC={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},g={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",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_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",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",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",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",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",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",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"},DC={CSV:".csv",JSON:".json"},MC={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key"},PC={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Dr={};Dr[g.CREATE_SCHEMA]=g.CREATE_SCHEMA;Dr[g.CREATE_TABLE]=g.CREATE_TABLE;Dr[g.CREATE_ATTRIBUTE]=g.CREATE_ATTRIBUTE;Dr[g.INSERT]=g.INSERT;Dr[g.UPDATE]=g.UPDATE;Dr[g.UPSERT]=g.UPSERT;Dr[g.DELETE]=g.DELETE;var J=Object.create(null);J[g.DESCRIBE_ALL]=g.DESCRIBE_ALL;J[g.DESCRIBE_TABLE]=g.DESCRIBE_TABLE;J[g.DESCRIBE_SCHEMA]=g.DESCRIBE_SCHEMA;J[g.READ_LOG]=g.READ_LOG;J[g.ADD_NODE]=g.ADD_NODE;J[g.LIST_USERS]=g.LIST_USERS;J[g.LIST_ROLES]=g.LIST_ROLES;J[g.USER_INFO]=g.USER_INFO;J[g.SQL]=g.SQL;J[g.GET_JOB]=g.GET_JOB;J[g.SEARCH_JOBS_BY_START_DATE]=g.SEARCH_JOBS_BY_START_DATE;J[g.DELETE_FILES_BEFORE]=g.DELETE_FILES_BEFORE;J[g.EXPORT_LOCAL]=g.EXPORT_LOCAL;J[g.EXPORT_TO_S3]=g.EXPORT_TO_S3;J[g.CLUSTER_STATUS]=g.CLUSTER_STATUS;J[g.REMOVE_NODE]=g.REMOVE_NODE;J[g.RESTART]=g.RESTART;J[g.CUSTOM_FUNCTIONS_STATUS]=g.CUSTOM_FUNCTIONS_STATUS;J[g.GET_CUSTOM_FUNCTIONS]=g.GET_CUSTOM_FUNCTIONS;J[g.GET_CUSTOM_FUNCTION]=g.GET_CUSTOM_FUNCTION;J[g.SET_CUSTOM_FUNCTION]=g.SET_CUSTOM_FUNCTION;J[g.DROP_CUSTOM_FUNCTION]=g.DROP_CUSTOM_FUNCTION;J[g.ADD_CUSTOM_FUNCTION_PROJECT]=g.ADD_CUSTOM_FUNCTION_PROJECT;J[g.DROP_CUSTOM_FUNCTION_PROJECT]=g.DROP_CUSTOM_FUNCTION_PROJECT;J[g.PACKAGE_CUSTOM_FUNCTION_PROJECT]=g.PACKAGE_CUSTOM_FUNCTION_PROJECT;J[g.DEPLOY_CUSTOM_FUNCTION_PROJECT]=g.DEPLOY_CUSTOM_FUNCTION_PROJECT;var BC={RUN:"run",INSTALL:"install",REGISTER:"register",STOP:"stop",RESTART:"restart",VERSION:"version",UPGRADE:"upgrade"},vC={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},eh={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",IPC_SERVER_PORT:"IPC_SERVER_PORT",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"},HC=jd.invert(eh),f={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_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",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",HTTP_THREADS:"http_threads",IPC_NETWORK_PORT:"ipc_network_port",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_DATEFORMAT:"logging_rotation_dateFormat",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",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",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",OPERATIONSAPI_AUTHENTICATION_OPERATIONTOKENTIMEOUT:"operationsApi_authentication_operationTokenTimeout",OPERATIONSAPI_AUTHENTICATION_REFRESHTOKENTIMEOUT:"operationsApi_authentication_refreshTokenTimeout",OPERATIONSAPI_FOREGROUND:"operationsApi_foreground",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",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_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERT_AUTH:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_NODEENV:"operationsApi_nodeEnv",ROOTPATH:"rootPath",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync"},GC={hdb_root_key:f.ROOTPATH,hdb_root:f.ROOTPATH,server_port_key:f.OPERATIONSAPI_NETWORK_PORT,server_port:f.OPERATIONSAPI_NETWORK_PORT,cert_key:f.OPERATIONSAPI_TLS_CERTIFICATE,certificate:f.OPERATIONSAPI_TLS_CERTIFICATE,private_key_key:f.OPERATIONSAPI_TLS_PRIVATEKEY,private_key:f.OPERATIONSAPI_TLS_PRIVATEKEY,http_secure_enabled_key:f.OPERATIONSAPI_NETWORK_HTTPS,https_on:f.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:f.OPERATIONSAPI_NETWORK_CORS,cors_on:f.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:f.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:f.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:f.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:f.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:f.LOGGING_LEVEL,log_level:f.LOGGING_LEVEL,log_path_key:f.LOGGING_ROOT,log_path:f.LOGGING_ROOT,log_daily_rotate:f.LOGGING_ROTATION_ROTATE,log_rotate:f.LOGGING_ROTATION_ROTATE,log_rotate_max_size:f.LOGGING_ROTATION_MAXSIZE,log_rotate_retain:f.LOGGING_ROTATION_RETAIN,log_rotate_compress:f.LOGGING_ROTATION_COMPRESS,log_rotate_date_format:f.LOGGING_ROTATION_DATEFORMAT,log_rotate_rotate_module:f.LOGGING_ROTATION_ROTATEMODULE,log_rotate_worker_interval:f.LOGGING_ROTATION_WORKERINTERVAL,log_rotate_rotate_interval:f.LOGGING_ROTATION_ROTATEINTERVAL,log_rotate_timezone:f.LOGGING_ROTATION_TIMEZONE,props_env_key:f.OPERATIONSAPI_NODEENV,node_env:f.OPERATIONSAPI_NODEENV,clustering_node_name_key:f.CLUSTERING_NODENAME,node_name:f.CLUSTERING_NODENAME,clustering_enabled_key:f.CLUSTERING_ENABLED,clustering:f.CLUSTERING_ENABLED,max_http_threads:f.HTTP_THREADS,max_hdb_processes:f.HTTP_THREADS,server_timeout_key:f.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:f.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:f.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:f.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:f.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:f.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:f.LOGGING_AUDITLOG,disable_transaction_log:f.LOGGING_AUDITLOG,operation_token_timeout_key:f.OPERATIONSAPI_AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:f.OPERATIONSAPI_AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:f.OPERATIONSAPI_AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:f.OPERATIONSAPI_AUTHENTICATION_REFRESHTOKENTIMEOUT,ipc_server_port:f.IPC_NETWORK_PORT,custom_functions_enabled_key:f.CUSTOMFUNCTIONS_ENABLED,custom_functions:f.CUSTOMFUNCTIONS_ENABLED,custom_functions_port_key:f.CUSTOMFUNCTIONS_NETWORK_PORT,custom_functions_port:f.CUSTOMFUNCTIONS_NETWORK_PORT,custom_functions_directory_key:f.CUSTOMFUNCTIONS_ROOT,custom_functions_directory:f.CUSTOMFUNCTIONS_ROOT,max_custom_function_processes:f.HTTP_THREADS,log_to_file:f.LOGGING_FILE,log_to_stdstreams:f.LOGGING_STDSTREAMS,run_in_foreground:f.OPERATIONSAPI_FOREGROUND,local_studio_on:f.LOCALSTUDIO_ENABLED,clustering_port:f.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:f.CLUSTERING_USER,clustering_enabled:f.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:f.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:f.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:f.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:f.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:f.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:f.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:f.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_nodename:f.CLUSTERING_NODENAME,clustering_tls_certificate:f.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:f.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:f.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:f.CLUSTERING_TLS_INSECURE,customfunctions_enabled:f.CUSTOMFUNCTIONS_ENABLED,customfunctions_network_port:f.CUSTOMFUNCTIONS_NETWORK_PORT,customfunctions_tls_certificate:f.CUSTOMFUNCTIONS_TLS_CERTIFICATE,customfunctions_network_cors:f.CUSTOMFUNCTIONS_NETWORK_CORS,customfunctions_network_corsaccesslist:f.CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST,customfunctions_network_headerstimeout:f.CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT,customfunctions_network_https:f.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:f.CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:f.CUSTOMFUNCTIONS_TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:f.CUSTOMFUNCTIONS_TLS_CERT_AUTH,customfunctions_network_timeout:f.CUSTOMFUNCTIONS_NETWORK_TIMEOUT,customfunctions_nodeenv:f.CUSTOMFUNCTIONS_NODEENV,http_threads:f.HTTP_THREADS,customfunctions_processes:f.HTTP_THREADS,customfunctions_root:f.CUSTOMFUNCTIONS_ROOT,ipc_network_port:f.IPC_NETWORK_PORT,localstudio_enabled:f.LOCALSTUDIO_ENABLED,logging_file:f.LOGGING_FILE,logging_level:f.LOGGING_LEVEL,logging_root:f.LOGGING_ROOT,logging_rotation_compress:f.LOGGING_ROTATION_COMPRESS,logging_rotation_dateformat:f.LOGGING_ROTATION_DATEFORMAT,logging_rotation_maxsize:f.LOGGING_ROTATION_MAXSIZE,logging_rotation_retain:f.LOGGING_ROTATION_RETAIN,logging_rotation_rotate:f.LOGGING_ROTATION_ROTATE,logging_rotation_rotateinterval:f.LOGGING_ROTATION_ROTATEINTERVAL,logging_rotation_rotatemodule:f.LOGGING_ROTATION_ROTATEMODULE,logging_rotation_timezone:f.LOGGING_ROTATION_TIMEZONE,logging_rotation_workerinterval:f.LOGGING_ROTATION_WORKERINTERVAL,logging_stdstreams:f.LOGGING_STDSTREAMS,logging_auditlog:f.LOGGING_AUDITLOG,operationsapi_authentication_operationtokentimeout:f.OPERATIONSAPI_AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:f.OPERATIONSAPI_AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_foreground:f.OPERATIONSAPI_FOREGROUND,operationsapi_tls_certificate:f.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_network_cors:f.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:f.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:f.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:f.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:f.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:f.OPERATIONSAPI_NETWORK_PORT,operationsapi_tls_privatekey:f.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_network_timeout:f.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_nodeenv:f.OPERATIONSAPI_NODEENV,operationsapi_root:f.ROOTPATH,rootpath:f.ROOTPATH,storage_writeasync:f.STORAGE_WRITEASYNC,storage_overlappingsync:f.STORAGE_OVERLAPPINGSYNC},qC={csv_file_load:"csv_file_load",csv_data_load:g.CSV_DATA_LOAD,csv_url_load:g.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"},FC={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"},VC={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},kC={FILE_SYSTEM:"fs",LMDB:"lmdb"},xC={API_CALL_DEFAULT:1e4,VERSION_DEFAULT:"2.2.0"},$C={DEVELOPMENT:8192,DEFAULT:512},YC={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"},KC={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"},QC={ENOENT:"ENOENT",EACCES:"EACCES"},th={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},WC="__clustering__",JC=Object.values(th),ZC=15984864e5,rh={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},XC=jd.invert(rh),zC={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"},jC=111,ew=`\r
|
|
2
2
|
`,tw={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},rw=["*","%"],sw="unauthorized_access",nw="func_val",iw={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},aw={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},ow="hdb_ipc_server",cw="hdb_ipc_client_",_w={RESTART:"restart",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",SCHEMA:"schema",USER:"user",CLUSTER_STATUS_RESPONSE:"cluster_status_response",CLUSTER_STATUS_REQUEST:"cluster_status_request"},uw={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},lw={STOPPED:"stopped",ONLINE:"online"},Ew="3.x.x";sh.exports={LOCAL_HARPERDB_OPERATIONS:J,HDB_SUPPORT_ADDRESS:Jd,HDB_SUPPORT_URL:Xd,HDB_PRICING_URL:Bb,SUPPORT_HELP_MSG:vb,LICENSE_HELP_MSG:zd,HDB_PROC_NAME:Kd,HDB_PROC_DESCRIPTOR:X_,CLUSTERING_LEAF_PROC_DESCRIPTOR:Sa,CLUSTERING_HUB_PROC_DESCRIPTOR:ha,SYSTEM_SCHEMA_NAME:tC,HASH_FOLDER_NAME:rC,HDB_HOME_DIR_NAME:sC,UPDATE_FILE_NAME:oC,LICENSE_KEY_DIR_NAME:iC,BOOT_PROPS_FILE_NAME:aC,JOB_TYPE_ENUM:qC,JOB_STATUS_ENUM:yC,SYSTEM_TABLE_NAMES:IC,SYSTEM_TABLE_HASH_ATTRIBUTES:bC,OPERATIONS_ENUM:g,VALID_S3_FILE_TYPES:DC,S3_BUCKET_AUTH_KEYS:MC,VALID_SQL_OPS_ENUM:PC,GEO_CONVERSION_ENUM:vC,HDB_SETTINGS_NAMES:eh,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:HC,SERVICE_ACTIONS_ENUM:BC,CLUSTER_MESSAGE_TYPE_ENUM:FC,CLUSTER_CONNECTION_DIRECTION_ENUM:VC,CLUSTER_EVENTS_DEFS_ENUM:YC,PERIOD_REGEX:xb,DOUBLE_PERIOD_REGEX:$b,UNICODE_PERIOD:Yb,FORWARD_SLASH_REGEX:Kb,UNICODE_FORWARD_SLASH:Qb,ESCAPED_FORWARD_SLASH_REGEX:Wb,ESCAPED_PERIOD_REGEX:Jb,ESCAPED_DOUBLE_PERIOD_REGEX:Zb,REG_KEY_FILE_NAME:LC,RESTART_TIMEOUT_MS:uC,HDB_FILE_PERMISSIONS:lC,SCHEMA_DIR_NAME:hC,TRANSACTIONS_DIR_NAME:SC,LIMIT_COUNT_NAME:fC,ID_ATTRIBUTE_STRING:TC,INSERT_MODULE_ENUM:NC,UPGRADE_JSON_FIELD_NAMES_ENUM:gC,RESTART_CODE:cC,RESTART_CODE_NUM:_C,CLUSTER_OPERATIONS:Dr,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:wC,HDB_INTERNAL_SC_CHANNEL_PREFIX:ht,INTERNAL_SC_CHANNELS:CC,CLUSTERING_MESSAGE_TYPES:zC,HDB_FILE_SUFFIX:nC,BLOB_FOLDER_NAME:EC,HDB_TRASH_DIR:dC,ORIGINATOR_SET_VALUE:jC,LICENSE_VALUES:xC,RAM_ALLOCATION_ENUM:$C,STORAGE_TYPES_ENUM:kC,TIME_STAMP_NAMES_ENUM:th,TIME_STAMP_NAMES:JC,PERMS_UPDATE_RELEASE_TIMESTAMP:ZC,SEARCH_NOT_FOUND_MESSAGE:Hb,SEARCH_ATTRIBUTE_NOT_FOUND:Gb,LICENSE_ROLE_DENIED_RESPONSE:qb,LICENSE_MAX_CONNS_REACHED:Fb,BASIC_LICENSE_MAX_NON_CU_ROLES:Zd,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:Pb,VALUE_SEARCH_COMPARATORS:rh,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:XC,LICENSE_FILE_NAME:UC,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:KC,NEW_LINE:ew,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:kb,MOMENT_DAYS_TAG:Xb,API_TURNOVER_SEC:zb,LOOPBACK:Vb,CODE_EXTENSION:xn,WILDCARD_SEARCH_VALUE:jb,NODE_ERROR_CODES:QC,JAVASCRIPT_EXTENSION:Yd,PERMS_CRUD_ENUM:tw,UNAUTHORIZED_PERMISSION_NAME:sw,SEARCH_WILDCARDS:rw,FUNC_VAL:nw,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:iw,JWT_ENUM:aw,CLUSTERING_FLAG:WC,RUN_LOG:RC,INSTALL_LOG:mC,IPC_SERVER_MODULE:Wd,HDB_IPC_SERVER:ow,IPC_EVENT_TYPES:_w,HDB_IPC_CLIENT_PREFIX:cw,CUSTOM_FUNCTION_PROC_NAME:Qd,CUSTOM_FUNCTION_PROC_DESCRIPTOR:da,SERVICES:uw,MEM_SETTING_KEY:eC,HDB_RESTART_SCRIPT:gb,PROCESS_DESCRIPTORS:Z_,SERVICE_SERVERS:Ub,SERVICE_SERVERS_CWD:Ea,PROCESS_DESCRIPTORS_VALIDATE:wb,LAUNCH_SERVICE_SCRIPTS:yb,LOG_LEVELS:Cb,PROCESS_NAME_ENV_PROP:AC,PROCESS_LOG_NAMES:bb,PM2_PROCESS_STATUSES:lw,CONFIG_PARAM_MAP:GC,CONFIG_PARAMS:f,HDB_CONFIG_FILE:Ob,HDB_DEFAULT_CONFIG_FILE:pb,ROLE_TYPES_ENUM:Db,BOOT_PROP_PARAMS:OC,INSTALL_PROMPTS:pC,HDB_ROOT_DIR_NAME:Nb,CLUSTERING_PROCESSES:Lb,FOREGROUND_PID_FILE:Ib,PACKAGE_ROOT:Gt,PRE_4_0_0_VERSION:Ew}});var eu=S((B1,ah)=>{"use strict";var nh=require("minimist");ah.exports=dw;function dw(e=[],t=!1){if(!Array.isArray(e))return{};let r,s;t?(r=ih(process.env),s=ih(nh(process.argv))):(r=process.env,s=nh(process.argv));let n={};for(let i=0,o=e.length;i<o;i++){let c=e[i];s[c]!==void 0?n[c]=s[c].toString().trim():r[c]!==void 0&&(n[c]=r[c].toString().trim())}return n}a(dw,"assignCMDENVVariables");function ih(e){let t,r=Object.keys(e),s=r.length,n={};for(;s--;)t=r[s],n[t.toLowerCase()]=e[t];return n}a(ih,"objKeysToLowerCase")});var I=S((v1,dh)=>{"use strict";var as=require("fs-extra"),os=require("path"),ch=require("yaml"),_h=require("properties-reader"),me=T(),hw=eu(),Sw=require("os"),{PACKAGE_ROOT:su}=T(),rt={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},fa=os.join(su,"logs"),Mr=process.env.pm_id===void 0,fw=os.join(su,"config/yaml/",me.HDB_DEFAULT_CONFIG_FILE),nu=process.env.PROCESS_NAME===void 0?me.PROCESS_DESCRIPTORS.INSTALL:process.env.PROCESS_NAME,Ys,Zt,lr,tt,tu,Ks;Ks===void 0&&uh();dh.exports={createLogFile:Tw,notify:Aw,fatal:Ow,error:ru,warn:pw,info:mw,debug:Rw,trace:Eh,setLogLevel:gw,log_level:tt};function uh(){try{if(Ks===void 0){let e=Nw();Ks=_h(e),{level:tt,config_log_path:tu,to_file:Zt,to_stream:lr}=Iw(Ks.get("settings_path"))}}catch(e){if(Ks=void 0,e.code===me.NODE_ERROR_CODES.ENOENT){let t=hw(Object.keys(me.CONFIG_PARAM_MAP),!0);for(let i in t){let o=me.CONFIG_PARAM_MAP[i];o&&o.toLowerCase();let c=t[i];if(o===me.CONFIG_PARAMS.LOGGING_LEVEL){tt=c;continue}if(o===me.CONFIG_PARAMS.LOGGING_STDSTREAMS){lr=c;continue}o===me.CONFIG_PARAMS.LOGGING_FILE&&(Zt=o)}let{default_level:r,default_to_file:s,default_to_stream:n}=bw();Zt=Zt===void 0?s:Zt,Zt=oh(Zt),lr=lr===void 0?n:lr,lr=oh(lr),tt=tt===void 0?r:tt,tu=fa;return}throw ru("Error initializing log settings"),ru(e),e}}a(uh,"initLogSettings");function Tw(e,t){if(!Mr){Eh("createLogFile should only be used if the process is not being managed by pm2");return}Ks===void 0&&uh(),nu=t;let r;e===me.PROCESS_LOG_NAMES.INSTALL?r=fa:r=tu,Zt&&(Ys=os.join(r,e),as.ensureFileSync(Ys))}a(Tw,"createLogFile");function cs(e,t){let r=new Date(Date.now()).toISOString(),s="",n=t.length,i=n-1;for(let o=0;o<n;o++){let c=t[o];c instanceof Error&&c.stack?s+=c.stack:typeof c=="object"?s+=JSON.stringify(c):s+=c,o<i&&(s+=" ")}return`{"process_name": "${nu}", "level": "${e}", "timestamp": "${r}", "message": "${s}"}
|
|
3
3
|
`}a(cs,"createLogRecord");function lh(e){Ys===void 0&&(nu=me.PROCESS_DESCRIPTORS.INSTALL,as.ensureDirSync(fa),Ys=os.join(fa,me.PROCESS_LOG_NAMES.INSTALL),as.ensureFileSync(Ys)),as.appendFileSync(Ys,e)}a(lh,"writeToLogFile");function Ta(e){Zt&&lh(e),lr&&process.stdout.write(e)}a(Ta,"nonPm2LogStdOut");function iu(e){Zt&&lh(e),lr&&process.stderr.write(e)}a(iu,"nonPm2LogStdErr");function mw(...e){if(rt[tt]<=rt.info){let t=cs("info",e);if(Mr){Ta(t);return}process.stdout.write(t)}}a(mw,"info");function Eh(...e){if(rt[tt]<=rt.trace){let t=cs("trace",e);if(Mr){Ta(t);return}process.stdout.write(t)}}a(Eh,"trace");function ru(...e){if(rt[tt]<=rt.error){let t=cs("error",e);if(Mr){iu(t);return}process.stderr.write(t)}}a(ru,"error");function Rw(...e){if(rt[tt]<=rt.debug){let t=cs("debug",e);if(Mr){Ta(t);return}process.stdout.write(t)}}a(Rw,"debug");function Aw(...e){if(rt[tt]<=rt.notify){let t=cs("notify",e);if(Mr){Ta(t);return}process.stdout.write(t)}}a(Aw,"notify");function Ow(...e){if(rt[tt]<=rt.fatal){let t=cs("fatal",e);if(Mr){iu(t);return}process.stderr.write(t)}}a(Ow,"fatal");function pw(...e){if(rt[tt]<=rt.warn){let t=cs("warn",e);if(Mr){iu(t);return}process.stderr.write(t)}}a(pw,"warn");function Nw(){let e;try{e=Sw.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=os.join(e,me.HDB_HOME_DIR_NAME,me.BOOT_PROPS_FILE_NAME);return as.existsSync(t)||(t=os.join(su,"utility/hdb_boot_properties.file")),t}a(Nw,"getPropsFilePath");function gw(e){tt=e}a(gw,"setLogLevel");function oh(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(oh,"autoCastBoolean");function Iw(e){try{if(e.includes("config/settings.js")){let o=_h(e);return{level:o.get(me.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:os.dirname(o.get(me.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(me.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(me.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=ch.parseDocument(as.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),s=t.getIn(["logging","root"]),n=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:s,to_file:n,to_stream:i}}catch(t){if(t.code===me.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(Iw,"getLogConfig");function bw(){try{let e=ch.parseDocument(as.readFileSync(fw,"utf8")),t=e.getIn(["logging","level"]),r=e.getIn(["logging","file"]),s=e.getIn(["logging","stdStreams"]);return{default_level:t,default_to_file:r,default_to_stream:s}}catch(e){console.error("Error accessing default config file for logging"),console.error(e)}}a(bw,"getDefaultConfig")});var Sh=S((H1,hh)=>{"use strict";var Cw=require("util"),ww=require("path"),Lw=require("child_process"),Uw=Cw.promisify(Lw.execFile),yw=1e3*1e3*10;hh.exports={findPs:Dw};async function Dw(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:s}=await Uw("ps",["wwxo",`pid,${r}`],{maxBuffer:yw});for(let n of s.trim().split(`
|
|
4
|
-
`).slice(1)){n=n.trim();let[i]=n.split(" ",1),o=n.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,s])=>({pid:Number.parseInt(r,10),name:ww.basename(s.comm),cmd:s.args,ppid:Number.parseInt(s.ppid,10),uid:Number.parseInt(s.uid,10),cpu:Number.parseFloat(s["%cpu"]),memory:Number.parseFloat(s["%mem"])}))}a(Dw,"findPs")});var Ye=S((G1,Th)=>{"use strict";var Mw="__dbis__",Pw="__environment_name__",Bw="__dbi_defintion__",vw={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"},Hw=["__createdtime__","__updatedtime__"],Gw="\uFFFF",fh={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},qw=Object.values(fh);Th.exports={INTERNAL_DBIS_NAME:Mw,DBI_DEFINITION_NAME:Bw,SEARCH_TYPES:vw,TIMESTAMP_NAMES:Hw,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:Pw,TRANSACTIONS_DBI_NAMES_ENUM:fh,TRANSACTIONS_DBIS:qw,OVERFLOW_MARKER:Gw}});var Ke=S((q1,bh)=>{"use strict";var mh=T(),Rh=Ye(),Ah={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},Oh=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),ph={500:Oh("There was an error processing your request."),400:"Invalid request"},Fw=ph[Ah.INTERNAL_SERVER_ERROR],Vw={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.`},kw={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},xw={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"},$w={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_ARRAY:"ids must be an array",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 ${Rh.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${Rh.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"},Yw={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${mh.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 ${mh.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"},Nh={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"},Kw={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid schema 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' schema, tables and records are used internally by HarperDB and cannot be updated or removed."},Qw={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 schema metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view schema.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`},Ww={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=>`Schema '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`Schema '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in schema '${e}'`,SCHEMA_REQUIRED_ERR:"schema is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},Jw={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},Zw={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`},gh={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.`},Ih={INVALID_IPC_DATA_TYPE:"Invalid IPC event data type, must be an object",MISSING_TYPE:"IPC event missing 'type'",MISSING_MSG:"IPC event missing 'message'",MISSING_ORIGIN:"IPC event message missing 'originator' property",INVALID_EVENT:e=>`IPC server received invalid event type: ${e}`},Xw={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 customFunctions enabled to true in hdb/harperdb-config.yaml file."},zw={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},jw={...Nh,...xw,...Vw,...Kw,...Qw,...Ww,...Jw,...Zw,...Yw,...gh,...Ih,...Xw,...zw,...kw};bh.exports={CHECK_LOGS_WRAPPER:Oh,HDB_ERROR_MSGS:jw,DEFAULT_ERROR_MSGS:ph,DEFAULT_ERROR_RESP:Fw,HTTP_STATUS_CODES:Ah,LMDB_ERRORS_ENUM:$w,AUTHENTICATION_ERROR_MSGS:Nh,VALIDATION_ERROR_MSGS:gh,IPC_ERRORS:Ih}});var D=S((F1,Lh)=>{"use strict";var Qs=Ke(),eL=I(),tL=T(),$n=class extends Error{constructor(t,r,s,n,i){super(),Error.captureStackTrace(this,Ch),this.http_resp_code=s||Qs.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Qs.DEFAULT_ERROR_MSGS[s]?Qs.DEFAULT_ERROR_MSGS[s]:Qs.DEFAULT_ERROR_MSGS[Qs.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,typeof this.message!="string"&&(this.stack=t.stack),i&&eL[n](i)}};a($n,"HdbError");function Ch(e,t,r,s=tL.LOG_LEVELS.ERROR,n=null,i=!1){if(wh(e))return e;let o=new $n(e,t,r,s,n);return i&&delete o.stack,o}a(Ch,"handleHDBError");function wh(e){return e.__proto__.constructor.name===$n.name}a(wh,"isHDBError");Lh.exports={isHDBError:wh,handleHDBError:Ch,hdb_errors:Qs}});var b=S((k1,$h)=>{"use strict";var au=require("path"),rL=require("fs-extra"),Ie=I(),Uh=require("fs-extra"),sL=require("truncate-utf8-bytes"),Yn=require("os"),nL=require("net"),iL=require("recursive-iterator"),Ue=T(),Bh=Sh(),yh=require("papaparse"),ma=require("moment"),{inspect:aL}=require("util"),Dh=require("is-number"),V1=require("lodash"),{hdb_errors:Ra}=D(),vh=require("util").promisify(setTimeout),oL=100,cL=5,_L="",uL=4,Mh=255,Ph={true:!0,false:!1,undefined:null,null:null,NaN:NaN};$h.exports={isEmpty:St,isEmptyOrZeroLength:Xt,arrayHasEmptyValues:dL,arrayHasEmptyOrZeroLengthValues:hL,buildFolderPath:SL,isBoolean:Hh,errorizeMessage:lL,stripFileExtension:TL,autoCast:mL,autoCastJSONDeep:ou,removeDir:AL,compareVersions:OL,isCompatibleDataVersion:pL,escapeRawValue:qh,unescapeValue:NL,stringifyProps:gL,valueConverter:IL,timeoutPromise:CL,isClusterOperation:LL,getClusterUser:DL,sendTransactionToSocketCluster:UL,checkGlobalSchemaTable:yL,getHomeDir:Fh,getPropsFilePath:bL,promisifyPapaParse:ML,removeBOM:Vh,createEventPromise:PL,checkProcessRunning:BL,checkSchemaTableExist:vL,checkSchemaExists:kh,checkTableExists:xh,getStartOfTomorrowInSeconds:HL,getLimitKey:GL,isObject:fL,isNotEmptyAndHasValue:EL,autoCasterIsNumberCheck:Gh,backtickASTSchemaItems:qL,isPortTaken:wL,stopProcess:FL,createForkArgs:VL,autoCastBoolean:kL,async_set_timeout:vh,getTableHashAttribute:xL,doesSchemaExist:$L,doesTableExist:YL,stringifyObj:KL,ms_to_time:QL,PACKAGE_ROOT:Ue.PACKAGE_ROOT};function lL(e){return e instanceof Error?e:new Error(e)}a(lL,"errorizeMessage");function St(e){return e==null}a(St,"isEmpty");function EL(e){return!St(e)&&(e||e===0||e===""||Hh(e))}a(EL,"isNotEmptyAndHasValue");function Xt(e){return St(e)||e.length===0||e.size===0}a(Xt,"isEmptyOrZeroLength");function dL(e){if(St(e))return!0;for(let t=0;t<e.length;t++)if(St(e[t]))return!0;return!1}a(dL,"arrayHasEmptyValues");function hL(e){if(Xt(e))return!0;for(let t=0;t<e.length;t++)if(Xt(e[t]))return!0;return!1}a(hL,"arrayHasEmptyOrZeroLengthValues");function SL(...e){try{return e.join(au.sep)}catch{console.error(e)}}a(SL,"buildFolderPath");function Hh(e){return St(e)?!1:e===!0||e===!1}a(Hh,"isBoolean");function fL(e){return St(e)?!1:typeof e=="object"}a(fL,"isObject");function TL(e){return Xt(e)?_L:e.slice(0,-uL)}a(TL,"stripFileExtension");function mL(e){return St(e)||e===""||typeof e!="string"?e:Ph[e]!==void 0?Ph[e]:Gh(e)===!0?Number(e):e}a(mL,"autoCast");function RL(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(RL,"autoCastJSON");function ou(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let s=e[t],n=ou(s);n!==s&&(e[t]=n)}else for(let t in e){let r=e[t],s=ou(r);s!==r&&(e[t]=s)}return e}else return RL(e)}a(ou,"autoCastJSONDeep");function Gh(e){if(e.startsWith("0.")&&Dh(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&Dh(e))}a(Gh,"autoCasterIsNumberCheck");async function AL(e){if(Xt(e))throw new Error(`Directory path: ${e} does not exist`);try{await Uh.emptyDir(e),await Uh.remove(e)}catch(t){throw Ie.error(`Error removing files in ${e} -- ${t}`),t}}a(AL,"removeDir");function OL(e,t){if(Xt(e)){Ie.info("Invalid current version sent as parameter.");return}if(Xt(t)){Ie.info("Invalid upgrade version sent as parameter.");return}let r,s=/(\.0+)+$/,n=e.version?e.version:e,i=t.version?t.version:t,o=n.replace(s,"").split("."),c=i.replace(s,"").split("."),_=Math.min(o.length,c.length);for(let u=0;u<_;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(OL,"compareVersions");function pL(e,t,r=!1){let s=e.toString().split("."),n=t.toString().split(".");return s[0]===n[0]&&(!r||s[1]===n[1])}a(pL,"isCompatibleDataVersion");function qh(e){if(St(e))return e;let t=String(e);return t==="."?Ue.UNICODE_PERIOD:t===".."?Ue.UNICODE_PERIOD+Ue.UNICODE_PERIOD:t.replace(Ue.FORWARD_SLASH_REGEX,Ue.UNICODE_FORWARD_SLASH)}a(qh,"escapeRawValue");function NL(e){if(St(e))return e;let t=String(e);return t===Ue.UNICODE_PERIOD?".":t===Ue.UNICODE_PERIOD+Ue.UNICODE_PERIOD?"..":String(e).replace(Ue.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(NL,"unescapeValue");function gL(e,t){if(St(e))return Ie.info("Properties object is null"),"";let r="";return e.each(function(s,n){try{if(t&&t[s]){let i=t[s];for(let o of i)r+=";"+o+Yn.EOL}!Xt(s)&&s[0]===";"?r+=" "+s+n+Yn.EOL:Xt(s)||(r+=s+"="+n+Yn.EOL)}catch{Ie.error(`Found bad property during upgrade with key ${s} and value: ${n}`)}}),r}a(gL,"stringifyProps");function IL(e){let t;try{t=typeof e=="object"?JSON.stringify(e):e}catch(n){Ie.error(n),t=e}let r=String(qh(t)),s=Buffer.byteLength(r)>Mh?sL(r,Mh)+"/blob":r;return{value:t,value_stripped:r,value_path:s}}a(IL,"valueConverter");function Fh(){let e;try{e=Yn.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(Fh,"getHomeDir");function bL(){let e=au.join(Fh(),Ue.HDB_HOME_DIR_NAME,Ue.BOOT_PROPS_FILE_NAME);return rL.existsSync(e)||(e=au.join(__dirname,"../","hdb_boot_properties.file")),e}a(bL,"getPropsFilePath");function CL(e,t){let r,s;return s=new Promise(function(n){r=setTimeout(function(){n(t)},e)}),{promise:s,cancel:function(){clearTimeout(r)}}}a(CL,"timeoutPromise");async function wL(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let s=nL.createServer().once("error",n=>{n.code==="EADDRINUSE"?t(!0):r(n)}).once("listening",()=>s.once("close",()=>t(!1)).close()).listen(e)})}a(wL,"isPortTaken");function LL(e){try{return Ue.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Ie.error(`Error checking operation against cluster ops ${t}`)}return!1}a(LL,"isClusterOperation");function UL(e,t,r){if(global.hdb_socket_client!==void 0){Ie.trace(`Sending transaction to channel: ${e}`);let{hdb_user:s,hdb_auth_header:n,...i}=t;i.__originator||(i.__originator={}),i.__transacted=!0,r&&(i.__originator[r]=Ue.ORIGINATOR_SET_VALUE),global.hdb_socket_client.publish(e,i)}}a(UL,"sendTransactionToSocketCluster");function yL(e,t){if(!global.hdb_schema[e])return Ra.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!global.hdb_schema[e]||!global.hdb_schema[e][t])return Ra.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(yL,"checkGlobalSchemaTable");function DL(e,t){if(St(t)){Ie.warn("No CLUSTERING_USER defined, clustering disabled");return}if(St(e)||Xt(e)){Ie.warn("No users to search.");return}let r;try{let s=e.get(t);s&&s.role.permission.cluster_user===!0&&s.active===!0&&(r=s)}catch(s){Ie.error(`unable to find cluster_user due to: ${s.message}`);return}if(r===void 0){Ie.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(DL,"getClusterUser");function ML(){yh.parsePromise=function(e,t){return new Promise(function(r,s){yh.parse(e,{header:!0,transformHeader:Vh,chunk:t.bind(null,s),skipEmptyLines:!0,dynamicTyping:!0,error:s,complete:r})})}}a(ML,"promisifyPapaParse");function Vh(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(Vh,"removeBOM");function PL(e,t,r){return new Promise(s=>{t.once(e,n=>{let i=r;Ie.info(`Got cluster status event response: ${aL(n)}`);try{i.cancel()}catch{Ie.error("Error trying to cancel timeout.")}s(n)})})}a(PL,"createEventPromise");async function BL(e){let t=!0,r=0;do await vh(oL*r++),(await Bh.findPs(e)).length>0&&(t=!1);while(t&&r<cL);if(t)throw new Error(`process ${e} was not started`)}a(BL,"checkProcessRunning");function vL(e,t){let r=kh(e);if(r)return r;let s=xh(e,t);if(s)return s}a(vL,"checkSchemaTableExist");function kh(e){if(!global.hdb_schema[e])return Ra.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(kh,"checkSchemaExists");function xh(e,t){if(!global.hdb_schema[e][t])return Ra.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(xh,"checkTableExists");function HL(){let e=ma().utc().add(1,Ue.MOMENT_DAYS_TAG).startOf(Ue.MOMENT_DAYS_TAG).unix(),t=ma().utc().unix();return e-t}a(HL,"getStartOfTomorrowInSeconds");function GL(){return ma().utc().format("DD-MM-YYYY")}a(GL,"getLimitKey");function qL(e){try{let t=new iL(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){Ie.error("Got an error back ticking items."),Ie.error(t)}}a(qL,"backtickASTSchemaItems");async function FL(e){let t=Yn.userInfo();(await Bh.findPs(e)).forEach(s=>{(t.uid==0||s.uid==t.uid)&&(process.kill(s.pid),Ie.trace(`Following process was killed by stopProcess: ${s.cmd}`))})}a(FL,"stopProcess");function VL(e){return[e]}a(VL,"createForkArgs");function kL(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(kL,"autoCastBoolean");function xL(e,t){return global.hdb_schema?.[e]?.[t]?.hash_attribute}a(xL,"getTableHashAttribute");function $L(e){return global?.hdb_schema?.[e]!==void 0}a($L,"doesSchemaExist");function YL(e,t){return global?.hdb_schema?.[e]?.[t]!==void 0}a(YL,"doesTableExist");function KL(e){try{return JSON.stringify(e)}catch{return e}}a(KL,"stringifyObj");function QL(e){let t=ma.duration(e),r=t.seconds()>0?t.seconds()+"s":"",s=t.minutes()>0?t.minutes()+"m ":"",n=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+n+s+r}a(QL,"ms_to_time")});var sS=S(($1,rS)=>{"use strict";var cu=require("recursive-iterator"),WL=require("alasql"),_u=require("clone"),Yh=b(),{handleHDBError:Kh,hdb_errors:JL}=D(),{HDB_ERROR_MSGS:Qh,HTTP_STATUS_CODES:Wh}=JL,ZL=["DISTINCT_ARRAY"],Jh=Symbol("validateTables"),uu=Symbol("validateTable"),x1=Symbol("getAllColumns"),Zh=Symbol("validateAllColumns"),Aa=Symbol("findColumn"),Xh=Symbol("validateOrderBy"),Kn=Symbol("validateSegment"),lu=Symbol("validateColumn"),zh=Symbol("setColumnsForTable"),jh=Symbol("checkColumnsForAsterisk"),eS=Symbol("validateGroupBy"),tS=Symbol("hasColumns"),Oa=class{constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[Jh](),this[jh](),this[Zh]()}[Jh](){if(this[tS]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[uu](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[uu](t.table)})}}[tS](){let t=!1,r=new cu(this.statement);for(let{node:s,path:n}of r)if(s&&s.columnid){t=!0;break}return t}[uu](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;if(!global.hdb_schema[t.databaseid])throw Kh(new Error,Qh.SCHEMA_NOT_FOUND(t.databaseid),Wh.NOT_FOUND);if(!global.hdb_schema[t.databaseid][t.tableid])throw Kh(new Error,Qh.TABLE_NOT_FOUND(t.databaseid,t.tableid),Wh.NOT_FOUND);global.hdb_schema[t.databaseid][t.tableid].attributes.forEach(s=>{let n=_u(s);n.table=_u(t),this.attributes.push(n)})}[Aa](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)}[jh](){let t=new cu(this.statement.columns);for(let{node:r,path:s}of t)r&&r.columnid==="*"&&s.indexOf("expression")<0&&this[zh](r.tableid)}[zh](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&this.statement.columns.push(new WL.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Zh](){this[Kn](this.statement.columns,!1),this[Kn](this.statement.joins,!1),this[Kn](this.statement.where,!1),this[eS](this.statement.group,!1),this[Kn](this.statement.order,!0)}[Kn](t,r){if(!t)return;let s=new cu(t),n=[];for(let{node:i,path:o}of s)!Yh.isEmpty(i)&&!Yh.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Xh](i):n.push(this[lu](i)));return n}[eS](t){if(!t)return;let r=[];if(this.statement.columns.forEach(s=>{if(!(s.funcid&&ZL.indexOf(s.funcid.toUpperCase())>=0)){if(!s.aggregatorid&&!s.columnid){let n=_u(s);delete n.as,r.push(n)}else if(s.columnid){let n=this[Aa](s)[0];n&&r.push(n)}}}),this.statement.group.forEach(s=>{let n=null;if(!s.columnid)r.forEach((i,o)=>{if(i.toString()===s.toString()){n=i,r.splice(o,1);return}});else{let i=this[Aa](s);if(!i||i.length===0)throw`unknown column '${s.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${s.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){n=o,r.splice(c,1);return}})}if(!n)throw`group by column '${s.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`}[Xh](t){let r=this.statement.columns.filter(s=>s.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[lu](t)}[lu](t){let r=this[Aa](t),s=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${s}`;if(r.length>1)throw`ambiguous column reference ${s}`;return r[0]}};a(Oa,"SelectValidator");rS.exports=Oa});var Eu=S((Y1,nS)=>{"use strict";var pa=class{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")}};a(pa,"BridgeMethods");nS.exports=pa});var _s=S((W1,cS)=>{"use strict";var iS=Ke().LMDB_ERRORS_ENUM,K1=require("lmdb"),XL=Ye(),Q1=require("buffer").Buffer,zL=require("microtime"),{OVERFLOW_MARKER:aS,MAX_SEARCH_KEY_LENGTH:Na}=XL,oS=["number","string","symbol","boolean","bigint"];function jL(e){if(!e)throw new Error(iS.ENV_REQUIRED);if(e.constructor.name!=="LMDBStore")throw new Error(iS.INVALID_ENVIRONMENT)}a(jL,"validateEnv");function eU(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(eU,"stringifyData");function tU(e){return e instanceof Date?e.valueOf():e}a(tU,"convertKeyValueToWrite");function rU(e){if(e==null)return;if(oS.includes(typeof e))return e.length>Na?[e.slice(0,Na)+aS]:[e];let t;if(Array.isArray(e)){t=[];for(let r=0,s=e.length;r<s;r++){let n=e[r];oS.includes(typeof n)&&(n.length>Na?t.push(n.slice(0,Na)+aS):t.push(n))}}return t}a(rU,"getIndexedValues");function sU(){let e=zL.now().toString(),t=e.length-3;return Number(e.slice(0,t)+"."+e.slice(t))}a(sU,"getMicroTime");cS.exports={validateEnv:jL,stringifyData:eU,convertKeyValueToWrite:tU,getMicroTime:sU,getIndexedValues:rU}});var uS=S((J1,_S)=>{"use strict";var ga=class{constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};a(ga,"DBIDefinition");_S.exports=ga});var ES=S((Z1,lS)=>{"use strict";var Ia=class{constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache={validated:!0},this.randomAccessStructure=!0,this.freezeData=!0)}};a(Ia,"OpenDBIObject");lS.exports=Ia});var hS=S((X1,dS)=>{"use strict";var ba=class{constructor(t,r,s,n,i=!1,o=!1,c=void 0){this.path=t,this.mapSize=r,this.maxDbs=s,this.maxReaders=n,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=i,this.trackMetrics=!0,this.noSync=o,c!==void 0&&(this.overlappingSync=c)}};a(ba,"OpenEnvironmentObject");dS.exports=ba});var fS=S((z1,SS)=>{"use strict";var nU={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,String.fromCharCode(13,10)),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,String.fromCharCode(13,10))},iU="certificate.pem",aU="privateKey.pem",oU="ca.pem";SS.exports={CERTIFICATE_VALUES:nU,CERTIFICATE_PEM_NAME:iU,PRIVATEKEY_PEM_NAME:aU,CA_PEM_NAME:oU}});var de=S((j1,TS)=>{"use strict";var st=require("validate.js");st.validators.type=function(e,t,r,s){return e===null||typeof e>"u"||st.validators.type.checks[t](e)?null:` must be a '${t}' value`};st.validators.type.checks={Object:function(e){return st.isObject(e)&&!st.isArray(e)},Array:st.isArray,Integer:st.isInteger,Number:st.isNumber,String:st.isString,Date:st.isDate,Boolean:function(e){return typeof e=="boolean"}};st.validators.hasValidFileExt=function(e,t){return!st.isString(e)||e===""||t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`};TS.exports={validateObject:cU,validateObjectAsync:_U,validateBySchema:uU};function cU(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=st(e,t,{format:"flat"});return r?new Error(r):null}a(cU,"validateObject");async function _U(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await st.async(e,t,{format:"flat"})}catch(r){let s=r.join(",");return new Error(s)}return null}a(_U,"validateObjectAsync");function uU(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(uU,"validateBySchema")});var hu=S((eJ,RS)=>{"use strict";var lU=require("fs-extra"),F=require("joi"),EU=require("os"),{boolean:ye,string:dr,number:zt,array:du}=F.types(),qt=require("path"),dU=I(),Ca=b(),hr=fS(),hU=de(),Er="keys",SU=hr.CERTIFICATE_PEM_NAME,fU=hr.PRIVATEKEY_PEM_NAME,TU=hr.CA_PEM_NAME,mU=hr.CERTIFICATE_PEM_NAME,RU=hr.PRIVATEKEY_PEM_NAME,AU=hr.CA_PEM_NAME,OU=hr.CERTIFICATE_PEM_NAME,pU=hr.PRIVATEKEY_PEM_NAME,NU=hr.CA_PEM_NAME,gU="log",IU="custom_functions",bU="Invalid logging.rotation.maxSize unit. Available units are G, M or K",CU="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",wU="rootPath config parameter is undefined",LU="clustering.enabled config parameter is undefined",Pr=zt.min(0).required(),wa=du.items({host:dr.required(),port:Pr}).empty(null),nt;RS.exports={configValidator:UU,routesValidator:BU,route_constraints:wa};function UU(e){if(nt=e.rootPath,Ca.isEmpty(nt))throw wU;let t=ye.required(),r=F.valid("production","development").required(),s=zt.min(1).max(1e3).empty(null).default(PU),n=dr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(mS),i=F.custom(DU).messages({"any.custom":"{:#label} {:#error}"}).empty(null).default(mS),o=dr.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),c=e.clustering?.enabled;if(Ca.isEmpty(c))throw LU;let _;return c===!0?_=F.object({enabled:t,hubServer:F.object({cluster:F.object({name:F.required().empty(null),network:F.object({port:Pr,routes:wa}).required()}).required(),leafNodes:F.object({network:F.object({port:Pr}).required()}).required(),network:F.object({port:Pr}).required()}).required(),leafServer:F.object({network:F.object({port:Pr,routes:wa}).required()}).required(),nodeName:o,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:ye.required()}),user:F.string().required()}).required():_=F.object({enabled:t,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:ye.required()})}).required(),F.object({clustering:_,customFunctions:F.object({enabled:t,network:F.object({cors:ye.required(),corsAccessList:du.required(),headersTimeout:zt.min(1).required(),https:ye.required(),keepAliveTimeout:zt.min(1).required(),port:Pr,timeout:zt.min(1).required()}),nodeEnv:r,root:n,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i})}).required(),ipc:F.object({network:F.object({port:Pr})}).required(),localStudio:F.object({enabled:t}).required(),logging:F.object({file:ye.required(),level:F.valid("notify","fatal","error","warn","info","debug","trace"),rotation:F.object({compress:ye.required(),dateFormat:dr.required(),maxSize:dr.custom(MU).required(),retain:zt.min(0).required(),rotate:ye.required(),rotateInterval:dr.required(),rotateModule:ye.required(),timezone:dr.required(),workerInterval:zt.min(1).required()}).required(),root:n,stdStreams:ye.required(),auditLog:ye.required()}).required(),operationsApi:F.object({authentication:F.object({operationTokenTimeout:F.required(),refreshTokenTimeout:F.required()}).required(),foreground:ye.required(),network:F.object({cors:ye.required(),corsAccessList:du.required(),headersTimeout:zt.min(1).required(),https:ye.required(),keepAliveTimeout:zt.min(1).required(),port:Pr,timeout:zt.min(1).required()}).required(),nodeEnv:r,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i})}).required(),rootPath:dr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),http:F.object({threads:s}).required(),storage:F.object({writeAsync:ye.required(),overlappingSync:ye.optional()}).required()}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(UU,"configValidator");function yU(e){return lU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(yU,"doesPathExist");function DU(e,t){F.assert(e,dr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+\.pem+$/).messages({"string.pattern.base":"must be a valid directory path and specify a .pem file"}));let r=yU(e);if(r)return t.message(r)}a(DU,"validatePemFile");function MU(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(bU);let s=e.slice(0,-1);if(isNaN(parseInt(s)))return t.message(CU)}a(MU,"validateRotationMaxSize");function PU(e,t){let r=t.state.path.join("."),s=EU.cpus().length,n=s-1;return n===1&&s===2&&(n=s),dU.info(`Detected ${s} cores on this machine, defaulting ${r} to ${n}`),n}a(PU,"setDefaultThreads");function mS(e,t){if(!Ca.isEmpty(t.original))return t.original;let r=t.state.path.join(".");if(Ca.isEmpty(nt))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"customFunctions.root":return qt.join(nt,IU);case"logging.root":return qt.join(nt,gU);case"operationsApi.tls.certificate":return qt.join(nt,Er,SU);case"operationsApi.tls.privateKey":return qt.join(nt,Er,fU);case"operationsApi.tls.certificateAuthority":return qt.join(nt,Er,TU);case"customFunctions.tls.certificate":return qt.join(nt,Er,mU);case"customFunctions.tls.privateKey":return qt.join(nt,Er,RU);case"customFunctions.tls.certificateAuthority":return qt.join(nt,Er,AU);case"clustering.tls.certificate":return qt.join(nt,Er,OU);case"clustering.tls.privateKey":return qt.join(nt,Er,pU);case"clustering.tls.certificateAuthority":return qt.join(nt,Er,NU);default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(mS,"setDefaultRoot");function BU(e){let t=F.object({routes:wa});return hU.validateBySchema({routes:e},t)}a(BU,"routesValidator")});var Sr=S((tJ,bS)=>{"use strict";var re=T(),It=b(),Qe=I(),{configValidator:vU,routesValidator:AS}=hu(),Ft=require("fs-extra"),HU=require("yaml"),Ws=require("path"),GU=require("is-number"),ya=require("properties-reader"),qU=require("lodash"),{handleHDBError:FU}=D(),{HTTP_STATUS_CODES:VU,HDB_ERROR_MSGS:La}=Ke(),{PACKAGE_ROOT:kU}=T(),xU="Unable to get config value because config is uninitialized",$U="Config successfully initialized",YU="Error backing up config file",KU="Empty parameter sent to getConfigValue",OS=Ws.join(kU,"config","yaml",re.HDB_DEFAULT_CONFIG_FILE),QU="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",Ua,it;bS.exports={createConfigFile:WU,getDefaultConfig:JU,getConfigValue:pS,initConfig:NS,flattenConfig:us,updateConfigValue:gS,updateConfigObject:ZU,getConfiguration:XU,setConfiguration:zU,readConfigFile:Tu,getClusteringRoutes:jU,initOldConfig:IS,getConfigFromFile:ey};function WU(e){let t=Js(OS);Ua=us(t.toJSON());for(let i in e){let o=re.CONFIG_PARAM_MAP[i.toLowerCase()];if(o!==void 0){let c=o.split("_"),_=Su(o,e[i]);try{t.setIn([...c],_)}catch(u){Qe.error(u)}}}fu(t);let r=t.toJSON();it=us(r);let s=t.getIn(["rootPath"]),n=Ws.join(s,re.HDB_CONFIG_FILE);Ft.createFileSync(n),Ft.writeFileSync(n,String(t)),Qe.trace(`Config file written to ${n}`)}a(WU,"createConfigFile");function JU(e){if(Ua===void 0){let r=Js(OS);Ua=us(r.toJSON())}let t=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(t!==void 0)return Ua[t.toLowerCase()]}a(JU,"getDefaultConfig");function pS(e){if(It.isEmpty(e)){Qe.error(KU);return}if(it===void 0){Qe.trace(xU);return}let t=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(t!==void 0)return it[t.toLowerCase()]}a(pS,"getConfigValue");function NS(e=!1){if(it===void 0||e){let t=It.getPropsFilePath();try{Ft.accessSync(t,Ft.constants.F_OK|Ft.constants.R_OK)}catch(o){throw Qe.error(o),new Error(`HarperDB properties file at path ${t} does not exist`)}let s=ya(t).get(re.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),n;if(s.includes("config/settings.js"))try{IS(s);return}catch(o){if(o.code!==re.NODE_ERROR_CODES.ENOENT)throw o}try{n=Js(s)}catch(o){if(o.code===re.NODE_ERROR_CODES.ENOENT){Qe.trace(`HarperDB config file not found at ${s}.
|
|
5
|
-
This can occur during early stages of install where the config file has not yet been created`);return}else throw Qe.error(o),new Error(`Error reading HarperDB config file at ${s}`)}fu(n);let i=n.toJSON();it=us(i),Qe.trace($U)}}a(NS,"initConfig");function fu(e){let t=e.toJSON(),r=vU(t);if(r.error)throw La.CONFIG_VALIDATION(r.error.message);e.setIn(["http","threads"],r.value.http.threads),e.setIn(["customFunctions","root"],r.value.customFunctions.root),e.setIn(["logging","root"],r.value.logging.root),e.setIn(["operationsApi","tls","certificate"],r.value.operationsApi.tls.certificate),e.setIn(["operationsApi","tls","privateKey"],r.value.operationsApi.tls.privateKey),e.setIn(["operationsApi","tls","certificateAuthority"],r.value.operationsApi.tls.certificateAuthority),e.setIn(["customFunctions","tls","certificate"],r.value.customFunctions.tls.certificate),e.setIn(["customFunctions","tls","privateKey"],r.value.customFunctions.tls.privateKey),e.setIn(["customFunctions","tls","certificateAuthority"],r.value.customFunctions.tls.certificateAuthority),e.setIn(["clustering","tls","certificate"],r.value.clustering.tls.certificate),e.setIn(["clustering","tls","privateKey"],r.value.clustering.tls.privateKey),e.setIn(["clustering","tls","certificateAuthority"],r.value.clustering.tls.certificateAuthority)}a(fu,"validateConfig");function ZU(e,t){it===void 0&&(it={});let r=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(r===void 0){Qe.trace(`Unable to update config object because config param '${e}' does not exist`);return}it[r.toLowerCase()]=t}a(ZU,"updateConfigObject");function gS(e,t,r=void 0,s=!1,n=!1){it===void 0&&NS();let i=pS(re.CONFIG_PARAM_MAP.hdb_root),o=Ws.join(i,re.HDB_CONFIG_FILE),c=Js(o);if(r===void 0){let l=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(l===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let E=l.split("_"),d=Su(l,t);c.setIn([...E],d)}else for(let l in r){let E=re.CONFIG_PARAM_MAP[l.toLowerCase()];if(E!==void 0){let d=E.split("_"),h=Su(E,r[l]);try{c.setIn([...d],h)}catch(m){Qe.error(m)}}}fu(c);let _=c.getIn(["rootPath"]),u=Ws.join(_,re.HDB_CONFIG_FILE);if(s===!0)try{let l=Ws.join(_,"backup",`${re.HDB_CONFIG_FILE}.bak`);Ft.copySync(o,l),Qe.trace(`Config file: ${o} backed up to: ${l}`)}catch(l){Qe.error(YU),Qe.error(l)}Ft.writeFileSync(u,String(c)),n&&(it=us(c.toJSON())),Qe.trace(`Config parameter: ${e} updated with value: ${t}`)}a(gS,"updateConfigValue");function us(e){let t={};for(let r in e)if(!!e.hasOwnProperty(r))if(typeof e[r]=="object"&&e[r]!==null&&!Array.isArray(e[r])){let s=us(e[r]);for(let n in s)!s.hasOwnProperty(n)||(t[r.toLowerCase()+"_"+n]=s[n])}else t[r.toLowerCase()]=e[r];return t}a(us,"flattenConfig");function Su(e,t){if(e===re.CONFIG_PARAMS.CLUSTERING_NODENAME||e===re.CONFIG_PARAMS.CLUSTERING_USER){if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(GU(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||It.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 It.autoCast(t)}a(Su,"castConfigValue");function XU(){let e=It.getPropsFilePath(),r=ya(e).get(re.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);return Js(r).toJSON()}a(XU,"getConfiguration");async function zU(e){let{operation:t,hdb_user:r,hdb_auth_header:s,...n}=e;try{return gS(void 0,void 0,n,!0),QU}catch(i){throw typeof i=="string"||i instanceof String?FU(i,i,VU.BAD_REQUEST,void 0,void 0,!0):i}}a(zU,"setConfiguration");function Tu(){let e=It.getPropsFilePath();try{Ft.accessSync(e,Ft.constants.F_OK|Ft.constants.R_OK)}catch(n){throw Qe.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let r=ya(e).get(re.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);return Js(r).toJSON()}a(Tu,"readConfigFile");function Js(e){return HU.parseDocument(Ft.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Js,"parseYamlDoc");function jU(){let e=Tu(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=It.isEmptyOrZeroLength(t)?[]:t;let r=AS(t);if(r)throw La.CONFIG_VALIDATION(r.message);let s=e?.clustering?.leafServer?.network?.routes;s=It.isEmptyOrZeroLength(s)?[]:s;let n=AS(s);if(n)throw La.CONFIG_VALIDATION(n.message);if(!It.isEmptyOrZeroLength(s)&&!It.isEmptyOrZeroLength(t)){let i=t.filter(o=>s.some(c=>c.host===o.host&&c.port===o.port));if(!It.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw La.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:s}}a(jU,"getClusteringRoutes");function IS(e){let t=ya(e);it={};for(let r in re.CONFIG_PARAM_MAP){let s=t.get(r.toUpperCase());if(It.isEmpty(s)||typeof s=="string"&&s.trim().length===0)continue;let n=re.CONFIG_PARAM_MAP[r].toLowerCase();n===re.CONFIG_PARAMS.LOGGING_ROOT?it[n]=Ws.dirname(s):it[n]=s}return it}a(IS,"initOldConfig");function ey(e){let t=Tu();return qU.get(t,e.replaceAll("_","."))}a(ey,"getConfigFromFile")});var Y=S((rJ,wS)=>{"use strict";var mu=require("fs-extra"),jt=require("path"),ty=require("os"),ry=require("properties-reader"),Qn=I(),Zs=b(),M=T(),Da=Sr(),sy="Error initializing environment manager",Ma="BOOT_PROPS_FILE_PATH",CS=!1,ny={[M.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},fr={};wS.exports={BOOT_PROPS_FILE_PATH:Ma,getHdbBasePath:iy,setHdbBasePath:ay,get:oy,initSync:_y,setProperty:$,initTestEnvironment:uy};function iy(){return fr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(iy,"getHdbBasePath");function ay(e){fr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(ay,"setHdbBasePath");function oy(e){let t=Da.getConfigValue(e);return t===void 0?fr[e]:t}a(oy,"get");function $(e,t){ny[e]&&(fr[e]=t),Da.updateConfigObject(e,t)}a($,"setProperty");function cy(){let e;try{e=Zs.getPropsFilePath(),mu.accessSync(e,mu.constants.F_OK|mu.constants.R_OK),CS=!0;let t=ry(e);return fr[M.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(M.HDB_SETTINGS_NAMES.INSTALL_USER),fr[M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),fr[Ma]=e,!0}catch{return Qn.trace(`Environment manager found no properties file at ${e}`),!1}}a(cy,"doesPropFileExist");function _y(e=!1){try{(CS||cy())&&(Da.initConfig(e),fr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=Da.getConfigValue(M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Qn.error(sy),Qn.error(t),console.error(t),process.exit(1)}}a(_y,"initSync");function uy(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:s,https_enabled:n,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,_=jt.join(__dirname,"../../","unitTests");fr[Ma]=jt.join(_,"hdb_boot_properties.file"),$(M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,jt.join(_,"settings.test")),$(M.HDB_SETTINGS_NAMES.INSTALL_USER,ty.userInfo().username),$(M.HDB_SETTINGS_NAMES.PRIVATE_KEY_KEY,jt.join(_,"envDir","utility","keys","privateKey.pem")),$(M.HDB_SETTINGS_NAMES.CERT_KEY,jt.join(_,"envDir","utility","keys","certificate.pem")),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_TLS_PRIVATEKEY,jt.join(_,"envDir","utility","keys","privateKey.pem")),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_TLS_CERTIFICATE,jt.join(_,"envDir","utility","keys","certificate.pem")),$(M.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),$(M.HDB_SETTINGS_NAMES.LOG_PATH_KEY,jt.join(_,"envDir","log")),$(M.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),$(M.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),$(M.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),$(M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,jt.join(_,"envDir")),$(M.HDB_SETTINGS_NAMES.HTTP_SECURE_ENABLED_KEY,Zs.isEmpty(n)?!0:n),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,Zs.isEmpty(n)?!0:n),$(M.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),$(M.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Zs.isEmpty(i)?!1:i),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_CORS,Zs.isEmpty(i)?!1:i),$(M.HDB_SETTINGS_NAMES.IPC_SERVER_PORT,9383),$(M.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),$(M.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),$(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),$(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),$(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,jt.resolve(__dirname,"../../unitTests/server/customFunctions/custom_functions")),$(M.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Zs.isEmpty(c)?!1:c),o&&($("CORS_ACCESSLIST",o),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST,o)),s&&($(M.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,s),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_TIMEOUT,s)),t&&($(M.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT,t)),r&&($(M.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${Ma}. Please check your boot props and settings files`;Qn.fatal(r),Qn.error(t)}}a(uy,"initTestEnvironment")});var Z=S((nJ,FS)=>{"use strict";var Ru=require("lmdb"),bt=require("fs-extra"),Vt=require("path"),Ba=_s(),LS=I(),De=Ke().LMDB_ERRORS_ENUM,va=uS(),Au=ES(),US=hS(),Br=Ye(),sJ=T(),Wn=Y();Wn.initSync();var yS=Wn.get("STORAGE_WRITEASYNC")===!0||Wn.get("STORAGE_WRITEASYNC")==="true"||Wn.get("STORAGE_WRITEASYNC")==="TRUE",DS=Wn.get("STORAGE_OVERLAPPINGSYNC"),MS=1024*1024*1024,PS=1e4,BS=1e3,kt=Br.INTERNAL_DBIS_NAME,vS=Br.DBI_DEFINITION_NAME,ly="data.mdb",Ey="lock.mdb",Jn=".mdb",dy="-lock",Pa=class{constructor(t,r,s=!1){this.dbi=Ct(t,r),this.key_type=this.dbi[Br.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Br.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:s===!1}),this.cursor=new Ru.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};a(Pa,"TransactionCursor");function Ou(e,t){if(e===void 0)throw new Error(De.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(De.ENV_NAME_REQUIRED)}a(Ou,"pathEnvNameValidation");async function pu(e,t,r=!0){try{await bt.access(e)}catch(s){throw s.code==="ENOENT"?new Error(De.INVALID_BASE_PATH):s}try{let s=Vt.join(e,t+Jn);return await bt.access(s,bt.constants.R_OK|bt.constants.F_OK),s}catch(s){if(s.code==="ENOENT")if(r)try{return await bt.access(Vt.join(e,t,ly),bt.constants.R_OK|bt.constants.F_OK),Vt.join(e,t)}catch(n){if(n.code==="ENOENT")throw new Error(De.INVALID_ENVIRONMENT)}else throw new Error(De.INVALID_ENVIRONMENT);throw s}}a(pu,"validateEnvironmentPath");function Ha(e,t){if(Ba.validateEnv(e),t===void 0)throw new Error(De.DBI_NAME_REQUIRED)}a(Ha,"validateEnvDBIName");async function hy(e,t,r=!1,s=!1){Ou(e,t),t=t.toString();try{return await pu(e,t,s),Nu(e,t,r)}catch(n){if(n.message===De.INVALID_ENVIRONMENT){let i=Vt.join(e,t);await bt.mkdirp(s?i:e);let o=new US(s?i:i+Jn,MS,PS,BS,!1,yS,DS),c=Ru.open(o);c.dbis=Object.create(null);let _=new Au(!1);c.openDB(kt,_),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let u=gu(e,t,r);return c[Br.ENVIRONMENT_NAME_KEY]=u,global.lmdb_map[u]=c,c}throw n}}a(hy,"createEnvironment");async function Sy(e,t,r,s=!0){let n=await Nu(e,t);if(r===void 0)throw new Error(De.DESTINATION_PATH_REQUIRED);try{await bt.access(Vt.dirname(r))}catch(i){throw i.code==="ENOENT"?new Error(De.INVALID_DESTINATION_PATH):i}await n.backup(r,s)}a(Sy,"copyEnvironment");async function Nu(e,t,r=!1){Ou(e,t),t=t.toString();let s=gu(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[s]!==void 0)return global.lmdb_map[s];let n=await pu(e,t),i=Vt.join(e,t+Jn),o=n!=i,c=new US(n,MS,PS,BS,o,yS,DS),_=Ru.open(c);_.dbis=Object.create(null);let u=GS(_);for(let l=0;l<u.length;l++)Ct(_,u[l]);return _[Br.ENVIRONMENT_NAME_KEY]=s,global.lmdb_map[s]=_,_}a(Nu,"openEnvironment");async function fy(e,t,r=!1){Ou(e,t),t=t.toString();let s=Vt.join(e,t+Jn),n=await pu(e,t);if(global.lmdb_map!==void 0){let i=gu(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await HS(o),delete global.lmdb_map[i]}}await bt.remove(n),await bt.remove(n===s?n+dy:Vt.join(Vt.dirname(n),Ey))}a(fy,"deleteEnvironment");async function HS(e){Ba.validateEnv(e);let t=e[Br.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(HS,"closeEnvironment");function gu(e,t,r=!1){let n=`${Vt.basename(e)}.${t}`;return r===!0&&(n=`txn.${n}`),n}a(gu,"getCachedEnvironmentName");function Ty(e){Ba.validateEnv(e);let t=Object.create(null),r=Ct(e,kt);for(let{key:s,value:n}of r.getRange({start:!1}))if(s!==kt)try{t[s]=Object.assign(new va,n)}catch{LS.warn(`an internal error occurred: unable to parse DBI Definition for ${s}`)}return t}a(Ty,"listDBIDefinitions");function GS(e){Ba.validateEnv(e);let t=[],r=Ct(e,kt);for(let{key:s}of r.getRange({start:!1}))s!==kt&&t.push(s);return t}a(GS,"listDBIs");function my(e,t){let s=Ct(e,kt).getEntry(t),n=new va;if(s!==void 0){try{n=Object.assign(n,s.value)}catch{LS.warn(`an internal error occurred: unable to parse DBI Definition for ${s}`)}return n}}a(my,"getDBIDefinition");function qS(e,t,r,s=!1){if(Ha(e,t),t=t.toString(),t===kt)throw new Error(De.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Ct(e,t)}catch(n){if(n.message===De.DBI_DOES_NOT_EXIST){let i=new Au(r,s===!0),o=e.openDB(t,i),c=new va(r===!0,s);return o[vS]=c,Ct(e,kt).putSync(t,c),e.dbis[t]=o,o}throw n}}a(qS,"createDBI");function Ct(e,t){if(Ha(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==kt?r=my(e,t):r=new va,r===void 0)throw new Error(De.DBI_DOES_NOT_EXIST);let s;try{let n=new Au(r.dup_sort,r.useVersions);if(s=e.openDB(t,n),s.db===void 0)throw new Error("MDB_NOTFOUND")}catch(n){throw n.message.includes("MDB_NOTFOUND")===!0?new Error(De.DBI_DOES_NOT_EXIST):n}return s[vS]=r,e.dbis[t]=s,s}a(Ct,"openDBI");function Ry(e,t){Ha(e,t),t=t.toString();let r=Ct(e,t),s=r.getStats();return r[Br.DBI_DEFINITION_NAME].is_hash_attribute&&s.entryCount>0&&s.entryCount--,s}a(Ry,"statDBI");async function Ay(e,t){try{let r=Vt.join(e,t+Jn);return(await bt.stat(r)).size}catch{throw new Error(De.INVALID_ENVIRONMENT)}}a(Ay,"environmentDataSize");function Oy(e,t){if(Ha(e,t),t=t.toString(),t===kt)throw new Error(De.CANNOT_DROP_INTERNAL_DBIS_NAME);Ct(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Ct(e,kt).removeSync(t)}a(Oy,"dropDBI");function py(e,t,r){for(let s=0;s<r.length;s++){let n=r[s];if(!e.dbis[n])try{Ct(e,n)}catch(i){if(i.message===De.DBI_DOES_NOT_EXIST)qS(e,n,n!==t,n===t);else throw i}}}a(py,"initializeDBIs");FS.exports={openDBI:Ct,openEnvironment:Nu,createEnvironment:hy,listDBIs:GS,listDBIDefinitions:Ty,createDBI:qS,dropDBI:Oy,statDBI:Ry,deleteEnvironment:fy,initializeDBIs:py,TransactionCursor:Pa,environmentDataSize:Ay,copyEnvironment:Sy,closeEnvironment:HS}});var kS=S((iJ,VS)=>{"use strict";var Ga=class{constructor(t=[],r=[],s=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=s}};a(Ga,"InsertRecordsResponseObject");VS.exports=Ga});var $S=S((aJ,xS)=>{"use strict";var qa=class{constructor(t=[],r=[],s=void 0,n=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=s,this.original_records=n}};a(qa,"UpdateRecordsResponseObject");xS.exports=qa});var KS=S((oJ,YS)=>{"use strict";var Fa=class{constructor(t=[],r=void 0,s=[]){this.written_hashes=t,this.txn_time=r,this.original_records=s}};a(Fa,"UpsertRecordsResponseObject");YS.exports=Fa});var Xs=S((lJ,WS)=>{"use strict";var Ny=Z(),gy=kS(),Iy=$S(),by=KS(),Xn=_s(),Zn=Ke().LMDB_ERRORS_ENUM,Cy=Ye(),vr=T(),wy=b(),Ly=require("uuid"),cJ=require("lmdb"),{handleHDBError:Uy,hdb_errors:yy}=D(),{OVERFLOW_MARKER:_J,MAX_SEARCH_KEY_LENGTH:uJ}=Cy,Iu=vr.TIME_STAMP_NAMES_ENUM.CREATED_TIME,ls=vr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function Dy(e,t,r,s,n=!0){Lu(e,t,r,s),bu(e,t,r);let i=new gy,o=[],c=[];for(let _=0;_<s.length;_++){let u=s[_];QS(u,!0,n);let l=My(e,t,r,u),E=u[t];o.push(l),c.push(E)}return Cu(o,c,s,i)}a(Dy,"insertRecords");function My(e,t,r,s){let n=s[t];return e.dbis[t].ifNoExists(n,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||s.hasOwnProperty(o)===!1)continue;let c=s[o];if(typeof c=="function"){let u=c([[{}]]);Array.isArray(u)&&(c=u[0][vr.FUNC_VAL],s[o]=c)}let _=Xn.getIndexedValues(c);if(_)for(let u=0,l=_.length;u<l;u++)e.dbis[o].put(_[u],n)}e.dbis[t].put(n,s,s[ls])})}a(My,"insertRecord");function Py(e,t=[]){let r=0;for(let s=0;s<t.length;s++){let n=t[s];e.splice(n-r,1),r++}}a(Py,"removeSkippedRecords");function QS(e,t,r=!0){let s=Date.now();(r===!0||!Number.isInteger(e[ls]))&&(e[ls]=s),t===!0?(r===!0||!Number.isInteger(e[Iu]))&&(e[Iu]=s):delete e[Iu]}a(QS,"setTimestamps");function bu(e,t,r){r.indexOf(vr.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(vr.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(vr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(vr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),Ny.initializeDBIs(e,t,r)}a(bu,"initializeTransaction");async function By(e,t,r,s,n=!0){Lu(e,t,r,s),bu(e,t,r);let i=new Iy,o=[],c=[],_=[];for(let u=0;u<s.length;u++){let l=s[u],E=l[t],d;try{d=wu(e,t,l,E,i,!0,n)}catch{i.skipped_hashes.push(E),o.push(u);continue}c.push(d),_.push(E)}return Cu(c,_,s,i,o)}a(By,"updateRecords");async function vy(e,t,r,s,n=!0){try{Lu(e,t,r,s)}catch(_){throw Uy(_,_.message,yy.HTTP_STATUS_CODES.BAD_REQUEST)}bu(e,t,r);let i=new by,o=[],c=[];for(let _=0;_<s.length;_++){let u=s[_],l;wy.isEmpty(u[t])?(l=Ly.v4(),u[t]=l):l=u[t];let E=wu(e,t,u,l,i,!1,n);o.push(E),c.push(l)}return Cu(o,c,s,i)}a(vy,"upsertRecords");async function Cu(e,t,r,s,n=[]){let i=await Promise.all(e);for(let o=0,c=i.length;o<c;o++)i[o]===!0?s.written_hashes.push(t[o]):(s.skipped_hashes.push(t[o]),n.push(o));return s.txn_time=Xn.getMicroTime(),Py(r,n),s}a(Cu,"finalizeWrite");function wu(e,t,r,s,n,i=!1,o=!0){let c=e.dbis[t],_=c.getEntry(s),u=_?.value,l=u;if(!u){if(i)return!1;u={}}if(QS(r,!l,o),Number.isInteger(r[ls])&&u[ls]>r[ls])return!1;l&&n.original_records.push(u);let E,d=a(()=>{for(let m in r){if(!r.hasOwnProperty(m)||m===t)continue;let R=r[m],w=e.dbis[m];if(w===void 0)continue;let L=u[m];if(typeof R=="function"){let z=R([[u]]);Array.isArray(z)&&(R=z[0][vr.FUNC_VAL],r[m]=R)}if(R===L)continue;let B=Xn.getIndexedValues(L);if(B)for(let z=0,V=B.length;z<V;z++)w.remove(B[z],s);if(B=Xn.getIndexedValues(R),B)for(let z=0,V=B.length;z<V;z++)w.put(B[z],s)}let h=Object.assign({},u,r);c.put(s,h,h[ls])},"do_put");return _?E=c.ifVersion(s,_.version,d):E=c.ifNoExists(s,d),E.then(h=>h?!0:wu(e,t,r,s,n,i,o))}a(wu,"updateUpsertRecord");function Hy(e,t,r){if(Xn.validateEnv(e),t===void 0)throw new Error(Zn.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Zn.WRITE_ATTRIBUTES_REQUIRED):new Error(Zn.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(Hy,"validateBasic");function Lu(e,t,r,s){if(Hy(e,t,r),!Array.isArray(s))throw s===void 0?new Error(Zn.RECORDS_REQUIRED):new Error(Zn.RECORDS_MUST_BE_ARRAY)}a(Lu,"validateWrite");WS.exports={insertRecords:Dy,updateRecords:By,upsertRecords:vy}});var te=S((EJ,ZS)=>{"use strict";var Uu=T(),zs=Y(),yu=require("path");zs.initSync();var Va,ka,xa;function JS(){if(Va!==void 0)return Va;if(zs.getHdbBasePath()!==void 0)return Va=yu.join(zs.getHdbBasePath(),Uu.SCHEMA_DIR_NAME),Va}a(JS,"getBaseSchemaPath");function Gy(){if(ka!==void 0)return ka;if(zs.getHdbBasePath()!==void 0)return ka=yu.join(JS(),Uu.SYSTEM_SCHEMA_NAME),ka}a(Gy,"getSystemSchemaPath");function qy(){if(xa!==void 0)return xa;if(zs.getHdbBasePath()!==void 0)return xa=yu.join(zs.getHdbBasePath(),Uu.TRANSACTIONS_DIR_NAME),xa}a(qy,"getTransactionAuditStorePath");ZS.exports={getBaseSchemaPath:JS,getSystemSchemaPath:Gy,getTransactionAuditStorePath:qy}});var Tr=S((dJ,jS)=>{"use strict";var zS=b(),XS=T(),Ya=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Du=require("joi"),$a={schema_format:{pattern:Ya,message:"names cannot include backticks or forward slashes"},schema_length:{maximum:250,tooLong:"cannot exceed 250 characters"}},Fy=Du.alternatives(Du.string().min(1).max($a.schema_length.maximum).pattern(Ya).messages({"string.pattern.base":"{:#label} "+$a.schema_format.message}),Du.number()).required();function Vy(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>$a.schema_length.maximum?`'${e}' maximum of 250 characters`:Ya.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(Vy,"checkValidTable");function ky(e,t){return zS.doesSchemaExist(e)?e:t.message(`Schema '${e}' does not exist`)}a(ky,"validateSchemaExists");function xy(e,t){let r=t.state.ancestors[0].schema;return zS.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(xy,"validateTableExists");function $y(e,t){return e.toLowerCase()===XS.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid schema name, '${XS.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a($y,"validateSchemaName");jS.exports={common_validators:$a,schema_regex:Ya,hdb_schema_table:Fy,validateSchemaExists:ky,validateTableExists:xy,validateSchemaName:$y,checkValidTable:Vy}});var Ka=S((hJ,ef)=>{var{common_validators:Hr}=Tr(),zn=de(),xt="is required",X={schema:{presence:!0,format:Hr.schema_format,length:Hr.schema_length},table:{presence:!0,format:Hr.schema_format,length:Hr.schema_length},attribute:{presence:!0,format:Hr.schema_format,length:Hr.schema_length},hash_attribute:{presence:!0,format:Hr.schema_format,length:Hr.schema_length}};function jn(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(jn,"makeAttributesStrings");function Yy(e){return e=jn(e),X.schema.presence={message:xt},X.table.presence=!1,X.attribute.presence=!1,X.hash_attribute.presence=!1,zn.validateObject(e,X)}a(Yy,"schema_object");function Ky(e){return e=jn(e),X.schema.presence={message:xt},X.table.presence={message:xt},X.attribute.presence=!1,X.hash_attribute.presence=!1,zn.validateObject(e,X)}a(Ky,"table_object");function Qy(e){return e=jn(e),X.schema.presence={message:xt},X.table.presence={message:xt},X.attribute.presence=!1,X.hash_attribute.presence={message:xt},zn.validateObject(e,X)}a(Qy,"create_table_object");function Wy(e){return e=jn(e),X.schema.presence={message:xt},X.table.presence={message:xt},X.attribute.presence={message:xt},X.hash_attribute.presence=!1,zn.validateObject(e,X)}a(Wy,"attribute_object");function Jy(e){return e=jn(e),X.schema.presence={message:xt},X.table.presence={message:xt},X.attribute.presence=!1,X.hash_attribute.presence=!1,zn.validateObject(e,X)}a(Jy,"describe_table");function Zy(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(Zy,"validateTableResidence");ef.exports={schema_object:Yy,create_table_object:Qy,table_object:Ky,attribute_object:Wy,describe_table:Jy,validateTableResidence:Zy}});var rf=S((SJ,tf)=>{"use strict";var Xy=require("uuid"),Qa=class{constructor(t,r,s,n){this.schema=t,this.table=r,this.attribute=s,this.id=n||Xy.v4(),this.schema_table=`${this.schema}.${this.table}`}};a(Qa,"CreateAttributeObject");tf.exports=Qa});var Ja=S((fJ,sf)=>{"use strict";var zy=rf(),Wa=class extends zy{constructor(t,r,s,n,i=!0,o=!1){super(t,r,s,n),this.dup_sort=i,this.is_hash_attribute=o}};a(Wa,"LMDBCreateAttributeObject");sf.exports=Wa});var af=S((TJ,nf)=>{"use strict";nf.exports=eD;var jy="inserted";function eD(e,t,r,s){let n={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:s};return e===jy?(n.inserted_hashes=t,n):(n.update_hashes=t,n)}a(eD,"returnObject")});var Za=S((mJ,cf)=>{"use strict";var tD=T(),Mu=Z(),rD=Xs(),{getSystemSchemaPath:sD,getBaseSchemaPath:nD}=te(),iD=require("path"),aD=is(),oD=Ka(),cD=Ja(),_D=af(),{handleHDBError:uD,hdb_errors:lD}=D(),ED=b(),Pu=aD.hdb_attribute,of=[];for(let e=0;e<Pu.attributes.length;e++)of.push(Pu.attributes[e].attribute);var dD="inserted";cf.exports=hD;async function hD(e){let t=oD.attribute_object(e);if(t)throw uD(new Error,t.message,lD.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=ED.isEmpty(e.dup_sort)||e.dup_sort=="true";let r=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(r=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(r)&&r.length>0){for(let n of r)if(n.attribute===e.attribute)throw new Error(`attribute '${n.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new cD(e.schema,e.table,e.attribute,e.id);try{let n=await Mu.openEnvironment(iD.join(nD(),e.schema.toString()),e.table);if(n.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);Mu.createDBI(n,e.attribute,e.dup_sort,e.is_hash_attribute);let i=await Mu.openEnvironment(sD(),tD.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:o,skipped_hashes:c}=await rD.insertRecords(i,Pu.hash_attribute,of,[s]);return _D(dD,o,{records:[s]},c)}catch(n){throw n}}a(hD,"lmdbCreateAttribute")});var vu=S((RJ,uf)=>{var{hdb_schema_table:_f}=Tr(),SD=de(),Bu=require("joi"),fD={undefined:"undefined",null:"null"},TD=a((e,t)=>{let r=Object.keys(e),s=r.length,n;for(let i=0;i<s;i++){let o=r[i];(!o||o.length===0||fD[o]!==void 0)&&(n===void 0?n=`Invalid attribute name: '${o}'`:n+=`. Invalid attribute name: '${o}'`)}return n?t.message(n):e},"custom_records_val"),mD=Bu.object({schema:_f,table:_f,records:Bu.array().items(Bu.object().custom(TD)).required()});uf.exports=function(e){return SD.validateBySchema(e,mD)}});var Xa=S((OJ,Ef)=>{"use strict";var mr=b(),lf=I(),AJ=vu();Ef.exports=RD;function RD(e){if(mr.isEmpty(e))throw new Error("invalid update parameters defined.");if(mr.isEmptyOrZeroLength(e.schema))throw new Error("invalid schema specified.");if(mr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");if(!Array.isArray(e.records))throw new Error("records must be an array");let t=global.hdb_schema[e.schema][e.table];if(mr.isEmpty(t))throw new Error(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.hash_attribute,s=new Set,n={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&mr.isEmptyOrZeroLength(o[r]))throw lf.error("a valid hash attribute must be provided with update record:",o),new Error("a valid hash attribute must be provided with update record, check log for more info");if(!mr.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw lf.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Error(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!mr.isEmpty(o[r])&&o[r]!==""&&s.has(mr.autoCast(o[r]))&&(o.skip=!0),s.add(mr.autoCast(o[r]));for(let c in o)n[c]=1}),n[r]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(n)}}a(RD,"insertUpdateValidate")});var ei=S((pJ,df)=>{"use strict";var AD=T().OPERATIONS_ENUM,za=class{constructor(t,r,s,n,i=void 0){this.operation=AD.INSERT,this.schema=t,this.table=r,this.hash_attribute=s,this.records=n,this.__origin=i}};a(za,"InsertObject");df.exports=za});var eo=S((gJ,hf)=>{"use strict";var NJ=ei(),ja=T(),Gu=b(),Hu=I(),OD=require("uuid"),{handleHDBError:ti,hdb_errors:pD}=D(),{HDB_ERROR_MSGS:ri,HTTP_STATUS_CODES:si}=pD;hf.exports=ND;function ND(e,t,r){for(let n=0;n<t.length;n++)gD(t[n]);let{records:s}=e;for(let n=0;n<s.length;n++){let i=s[n];ID(i,r,e.operation)}}a(ND,"processRows");function gD(e){if(Buffer.byteLength(String(e))>ja.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw ti(new Error,ri.ATTR_NAME_LENGTH_ERR(e),si.BAD_REQUEST,void 0,void 0,!0);if(Gu.isEmptyOrZeroLength(e)||Gu.isEmpty(e.trim()))throw ti(new Error,ri.ATTR_NAME_NULLISH_ERR,si.BAD_REQUEST,void 0,void 0,!0)}a(gD,"validateAttribute");function ID(e,t,r){if(!e.hasOwnProperty(t)||Gu.isEmptyOrZeroLength(e[t])){if(r===ja.OPERATIONS_ENUM.INSERT||r===ja.OPERATIONS_ENUM.UPSERT){e[t]=OD.v4();return}throw Hu.error("Update transaction aborted due to record with no hash value:",e),ti(new Error,ri.RECORD_MISSING_HASH_ERR,si.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>ja.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Hu.error(e),ti(new Error,ri.HASH_VAL_LENGTH_ERR,si.BAD_REQUEST,void 0,void 0,!0);if(isNaN(e[t])&&e[t].includes("/"))throw Hu.error(e),ti(new Error,ri.INVALID_FORWARD_SLASH_IN_HASH_ERR,si.BAD_REQUEST,void 0,void 0,!0)}a(ID,"validateHash")});var ff=S((IJ,Sf)=>{"use strict";var to=class{constructor(t,r){this.type=t,this.message=r}};a(to,"IPCEventObject");Sf.exports=to});var Gr=S((bJ,Tf)=>{"use strict";var bD=I(),qu=b(),CD=T(),{IPC_ERRORS:ni}=Ke();Tf.exports={sendIpcEvent:wD,validateEvent:LD,SchemaEventMsg:UD,UserEventMsg:yD};function wD(e){global.hdb_ipc?global.hdb_ipc.emitToServer(e):bD.warn("Tried to send event:",e,"to HDB IPC client but it does not exist")}a(wD,"sendIpcEvent");function LD(e){if(typeof e!="object")return ni.INVALID_IPC_DATA_TYPE;if(!e.hasOwnProperty("type")||qu.isEmpty(e.type))return ni.MISSING_TYPE;if(!e.hasOwnProperty("message")||qu.isEmpty(e.message))return ni.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||qu.isEmpty(e.message.originator))return ni.MISSING_ORIGIN;if(CD.IPC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return ni.INVALID_EVENT(e.type)}a(LD,"validateEvent");function UD(e,t,r,s=void 0,n=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=s,this.attribute=n}a(UD,"SchemaEventMsg");function yD(e){this.originator=e}a(yD,"UserEventMsg")});var js=S((wJ,Of)=>{"use strict";var mf=T(),CJ=b(),ro=I(),Rf=ff(),{sendIpcEvent:Af}=Gr();function DD(e){try{ro.trace("signalSchemaChange called with message:",e);let t=new Rf(mf.IPC_EVENT_TYPES.SCHEMA,e);Af(t)}catch(t){ro.error(t)}}a(DD,"signalSchemaChange");function MD(e){try{ro.trace("signalUserChange called with message:",e);let t=new Rf(mf.IPC_EVENT_TYPES.USER,e);Af(t)}catch(t){ro.error(t)}}a(MD,"signalUserChange");Of.exports={signalSchemaChange:DD,signalUserChange:MD}});var so=S((LJ,Nf)=>{"use strict";var pf=b(),PD=T(),BD=I(),vD=Za(),HD=Ja(),GD=js(),{SchemaEventMsg:qD}=Gr(),FD="already exists in";Nf.exports=VD;async function VD(e,t,r){try{if(pf.isEmptyOrZeroLength(r))return r;let s=[];pf.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{s.push(i.attribute)});let n=r.filter(i=>s.indexOf(i)<0);return n.length===0||await Promise.all(n.map(async i=>{await kD(e,t.schema,t.name,i)})),n}catch(s){throw s}}a(VD,"lmdbCheckForNewAttributes");async function kD(e,t,r,s){let n=new HD(t,r,s,void 0,!0);e&&(n.hdb_auth_header=e);try{await xD(n)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(FD))BD.warn(`attribute ${t}.${r}.${s} already exists`);else throw i}}a(kD,"createNewAttribute");async function xD(e){let t;try{return t=await vD(e),GD.signalSchemaChange(new qD(process.pid,PD.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}catch(r){throw r}}a(xD,"createAttribute")});var en=S((UJ,gf)=>{"use strict";var no=class{constructor(t,r,s,n,i=void 0){this.operation=t,this.user_name=r,this.timestamp=s,this.hash_values=n,this.origin=i}};a(no,"LMDBTransactionObject");gf.exports=no});var bf=S((yJ,If)=>{"use strict";var $D=en(),YD=T().OPERATIONS_ENUM,io=class extends $D{constructor(t,r,s,n,i=void 0){super(YD.INSERT,r,s,n,i),this.records=t}};a(io,"LMDBInsertTransactionObject");If.exports=io});var wf=S((DJ,Cf)=>{"use strict";var KD=en(),QD=T().OPERATIONS_ENUM,ao=class extends KD{constructor(t,r,s,n,i,o=void 0){super(QD.UPDATE,s,n,i,o),this.records=t,this.original_records=r}};a(ao,"LMDBUpdateTransactionObject");Cf.exports=ao});var Uf=S((MJ,Lf)=>{"use strict";var WD=en(),JD=T().OPERATIONS_ENUM,oo=class extends WD{constructor(t,r,s,n,i,o=void 0){super(JD.UPSERT,s,n,i,o),this.records=t,this.original_records=r}};a(oo,"LMDBUpsertTransactionObject");Lf.exports=oo});var Df=S((PJ,yf)=>{"use strict";var ZD=en(),XD=T().OPERATIONS_ENUM,co=class extends ZD{constructor(t,r,s,n,i=void 0){super(XD.DELETE,s,n,t,i),this.original_records=r}};a(co,"LMDBDeleteTransactionObject");yf.exports=co});var ii=S((BJ,vf)=>{"use strict";var zD=require("path"),Mf=Z(),jD=bf(),eM=wf(),tM=Uf(),rM=Df(),tn=Ye(),Pf=b(),{CONFIG_PARAMS:sM}=T(),Bf=Y();Bf.initSync();var _o=T().OPERATIONS_ENUM,{getTransactionAuditStorePath:nM}=te();vf.exports=iM;async function iM(e,t){if(Bf.get(sM.LOGGING_AUDITLOG)===!1)return;let r=zD.join(nM(),e.schema.toString()),s=await Mf.openEnvironment(r,e.table,!0),n=aM(e,t);if(!(n===void 0||n.hash_values.length===0)&&s!==void 0){Mf.initializeDBIs(s,tn.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,tn.TRANSACTIONS_DBIS);try{let i=n.timestamp;return await s.dbis[tn.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{s.dbis[tn.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,n),Pf.isEmpty(n.user_name)||s.dbis[tn.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(n.user_name,i);for(let o=0;o<n.hash_values.length;o++)s.dbis[tn.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n.hash_values[o],i)})}catch(i){throw i}}}a(iM,"writeTransaction");function aM(e,t){let r=Pf.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===_o.INSERT)return new jD(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===_o.UPDATE)return new eM(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===_o.UPSERT)return new tM(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===_o.DELETE)return new rM(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(aM,"createTransactionObject")});var Fu=S((HJ,Hf)=>{"use strict";var oM=Xa(),vJ=ei(),rn=T(),cM=eo(),_M=Xs().insertRecords,uM=Z(),lM=require("path"),EM=I(),dM=so(),{getBaseSchemaPath:hM}=te(),SM=ii();Hf.exports=fM;async function fM(e){try{let{schema_table:t,attributes:r}=oM(e);cM(e,r,t.hash_attribute),e.schema!==rn.SYSTEM_SCHEMA_NAME&&(r.includes(rn.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(rn.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(rn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(rn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await dM(e.hdb_auth_header,t,r),n=lM.join(hM(),e.schema.toString()),i=await uM.openEnvironment(n,e.table),o=await _M(i,t.hash_attribute,r,e.records,e[rn.CLUSTERING_FLAG]!==!0);try{await SM(e,o)}catch(c){EM.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:s,txn_time:o.txn_time}}catch(t){throw t}}a(fM,"lmdbCreateRecords")});var Ff=S((GJ,qf)=>{"use strict";var Gf=T(),TM=Fu(),mM=ei(),RM=require("fs-extra"),AM=require("path"),{getBaseSchemaPath:OM}=te();qf.exports=pM;async function pM(e){let t=[{name:e.schema,createddate:Date.now()}],r=new mM(Gf.SYSTEM_SCHEMA_NAME,Gf.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await TM(r),await RM.mkdirp(AM.join(OM(),e.schema.toString()))}a(pM,"lmdbCreateSchema")});var kf=S((qJ,Vf)=>{"use strict";var uo=class{constructor(t=[],r=[],s=void 0,n=[]){this.deleted=t,this.skipped=r,this.txn_time=s,this.original_records=n}};a(uo,"DeleteRecordsResponseObject");Vf.exports=uo});var xu=S((xJ,Yf)=>{"use strict";var xf=Z(),Vu=_s(),ku=Ke().LMDB_ERRORS_ENUM,NM=Ye(),$f=I(),FJ=b(),gM=require("lmdb"),IM=kf(),{OVERFLOW_MARKER:VJ,MAX_SEARCH_KEY_LENGTH:kJ}=NM;async function bM(e,t,r){if(Vu.validateEnv(e),t===void 0)throw new Error(ku.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(ku.IDS_REQUIRED):new Error(ku.IDS_MUST_BE_ARRAY);try{let s=xf.listDBIs(e);xf.initializeDBIs(e,t,s);let n=new IM,i,o=[],c=[];for(let E=0,d=r.length;E<d;E++)try{i=r[E];let h=e.dbis[t].get(i);if(!h){n.skipped.push(i);continue}let m=e.dbis[t].ifVersion(i,gM.IF_EXISTS,()=>{e.dbis[t].remove(i);for(let R=0;R<s.length;R++){let w=s[R];if(!h.hasOwnProperty(w)||w===t)continue;let L=e.dbis[w],B=h[w];if(B!=null)try{let z=Vu.getIndexedValues(B);if(z)for(let V=0,W=z.length;V<W;V++)L.remove(z[V],i)}catch{$f.warn(`cannot delete from attribute: ${w}, ${B}:${i}`)}}});o.push(m),c.push(i),n.original_records.push(h)}catch(h){$f.warn(h),n.skipped.push(i)}let _=[],u=await Promise.all(o);for(let E=0,d=u.length;E<d;E++)u[E]===!0?n.deleted.push(c[E]):(n.skipped.push(c[E]),_.push(E));let l=0;for(let E=0;E<_.length;E++){let d=_[E];n.original_records.splice(d-l,1),l++}return n.txn_time=Vu.getMicroTime(),n}catch(s){throw s}}a(bM,"deleteRecords");Yf.exports={deleteRecords:bM}});var ai=S(($J,Qf)=>{"use strict";var sn=b(),CM=xu(),wM=Z(),LM=require("path"),{getBaseSchemaPath:UM}=te(),yM=ii(),DM=I();Qf.exports=MM;async function MM(e,t=!0){let s=global.hdb_schema[e.schema][e.table].hash_attribute;if(sn.isEmpty(s))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(sn.isEmptyOrZeroLength(e.hash_values)&&!sn.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let _=e.records[c][s];sn.isEmpty(_)||e.hash_values.push(_)}}if(sn.isEmptyOrZeroLength(e.hash_values))return Kf([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(sn.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[s]:e.hash_values[c]}}let n=LM.join(UM(),e.schema.toString()),i=await wM.openEnvironment(n,e.table),o=await CM.deleteRecords(i,s,e.hash_values);try{t===!0&&await yM(e,o)}catch(c){DM.error(`unable to write transaction due to ${c.message}`)}return Kf(o.deleted,o.skipped,o.txn_time)}catch(n){throw n}}a(MM,"lmdbDeleteRecords");function Kf(e,t,r){let s=e.length+t.length,n=s===1?"record":"records";return{message:`${e.length} of ${s} ${n} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(Kf,"createDeleteResponse")});var Yu=S((KJ,Wf)=>{"use strict";var PM=T(),YJ=_s();function $u(e,t){let r=Object.create(null);if(t.length===1&&PM.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let s=0;s<t.length;s++){let n=t[s],i=e[n];r[n]=i===void 0?null:i}return r}a($u,"parseRow");function BM(e,t,r,s){let n=$u(r,e);s.push(n)}a(BM,"searchAll");function vM(e,t,r,s){let n=$u(r,e);s[t]=n}a(vM,"searchAllToMap");function HM(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(HM,"iterateDBI");function Es(e,t,r,s,n){let i=Object.create(null);i[n]=e;let o;s===n?o=e:(o=t,s!==void 0&&(i[s]=o)),r[0].push(o),r[1].push(i)}a(Es,"pushResults");function GM(e,t,r,s,n,i){t.toString().endsWith(e)&&Es(t,r,s,n,i)}a(GM,"endsWith");function qM(e,t,r,s,n,i){t.toString().includes(e)&&Es(t,r,s,n,i)}a(qM,"contains");function FM(e,t,r,s,n,i){t>e&&Es(t,r,s,n,i)}a(FM,"greaterThanCompare");function VM(e,t,r,s,n,i){t>=e&&Es(t,r,s,n,i)}a(VM,"greaterThanEqualCompare");function kM(e,t,r,s,n,i){t<e&&Es(t,r,s,n,i)}a(kM,"lessThanCompare");function xM(e,t,r,s,n,i){t<=e&&Es(t,r,s,n,i)}a(xM,"lessThanEqualCompare");Wf.exports={parseRow:$u,searchAll:BM,searchAllToMap:vM,iterateDBI:HM,endsWith:GM,contains:qM,greaterThanCompare:FM,greaterThanEqualCompare:VM,lessThanCompare:kM,lessThanEqualCompare:xM,pushResults:Es}});var nn=S((JJ,eT)=>{"use strict";var wt=Z(),$M=I(),ft=_s(),qr=Ye(),ce=Ke().LMDB_ERRORS_ENUM,QJ=b(),YM=T(),$t=Yu(),WJ=require("lmdb"),{OVERFLOW_MARKER:Jf,MAX_SEARCH_KEY_LENGTH:KM}=qr,oi={lazy:!0};function Zf(e,t,r,s,n=!1,i=void 0,o=void 0){let c=Object.create(null),_=wt.openDBI(e,r);_[qr.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let u=Ku(e,t,r);for(let{key:l,value:E}of _.getRange({start:n?void 0:!1,end:n?!1:void 0,limit:i,offset:o,reverse:n}))s(u(l,E),E,c,t,r);return c}a(Zf,"iterateFullIndex");function ci(e,t,r,s,n,i=!1,o=void 0,c=void 0,_=!1,u=!1){let l=[[],[]],E=wt.openDBI(e,r),d=Ku(e,t,r);E[qr.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let h=i===!0?s:n,m=i===!0?n:s,R=i===!0?!_:!u,w=i===!0?u:_;for(let{key:L,value:B}of E.getRange({start:m,end:h,reverse:i,limit:o,offset:c,inclusiveEnd:R,exclusiveStart:w}))$t.pushResults(d(L,B),B,l,t,r);return l}a(ci,"iterateRangeBetween");function Ku(e,t,r){let s;return function(n,i){if(typeof n=="string"&&n.endsWith(Jf)){if(!s)if(t)s=wt.openDBI(e,t);else{let c=wt.listDBIs(e);for(let _=0,u=c.length;_<u&&(s=wt.openDBI(e,c[_]),!s[qr.DBI_DEFINITION_NAME].is_hash_attribute);_++);}n=s.get(i,oi)[r]}return n}}a(Ku,"getOverflowCheck");function QM(e,t,r,s=!1,n=void 0,i=void 0){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);lo(r),r=_i(e,r);let o=[],c=wt.openDBI(e,t);for(let{key:_,value:u}of c.getRange({start:s?void 0:!1,end:s?!1:void 0,limit:n,offset:i,reverse:s}))$t.searchAll(r,_,u,o);return o}a(QM,"searchAll");function WM(e,t,r,s=!1,n=void 0,i=void 0){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);return lo(r),r=_i(e,r),Zf(e,t,t,$t.searchAllToMap.bind(null,r),s,n,i)}a(WM,"searchAllToMap");function JM(e,t,r=!1,s=void 0,n=void 0){if(ft.validateEnv(e),t===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);return Zf(e,void 0,t,$t.iterateDBI,r,s,n)}a(JM,"iterateDBI");function ZM(e,t){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);return wt.statDBI(e,t).entryCount}a(ZM,"countAll");function XM(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=wt.openDBI(e,r);s=ft.convertKeyValueToWrite(s);let _=[[],[]];if(c[qr.DBI_DEFINITION_NAME].is_hash_attribute){t=r;let u=c.get(s,oi);u!==void 0&&$t.pushResults(s,u,_,t,r)}else for(let u of c.getValues(s,{reverse:n,limit:i,offset:o}))$t.pushResults(s,u,_,t,r);return _}a(XM,"equals");function zM(e,t,r){return Fr(e,t,r),wt.openDBI(e,t).getValuesCount(r)}a(zM,"count");function jM(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=[[],[]],_=wt.openDBI(e,r);_[qr.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r),s=ft.convertKeyValueToWrite(s);let u=!0;if(typeof s=="number"&&(u=!1),n===!0){let l;for(let E of _.getKeys({start:s}))if(!E.startsWith(s)){l=E;break}l!==void 0&&(Number.isInteger(o)?o++:i++);for(let{key:E,value:d}of _.getRange({start:l,end:void 0,reverse:n,limit:i,offset:o}))if(E!==l){if(E.toString().startsWith(s))$t.pushResults(E,d,c,t,r);else if(u===!0)break}}else for(let{key:l,value:E}of _.getRange({start:s,reverse:n,limit:i,offset:o}))if(l.toString().startsWith(s))$t.pushResults(l,E,c,t,r);else if(u===!0)break;return c}a(jM,"startsWith");function eP(e,t,r,s,n=!1,i=void 0,o=void 0){return Xf(e,t,r,s,n,i,o,!0)}a(eP,"endsWith");function Xf(e,t,r,s,n=!1,i=void 0,o=void 0,c=!1){Fr(e,r,s);let _=[[],[]],u=wt.openDBI(e,r);u[qr.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let l=Ku(e,t,r);o=Number.isInteger(o)?o:0;for(let d of u.getKeys({end:n?!1:void 0,reverse:n})){if(i===0)break;let h=d.toString();if(h.endsWith(Jf))for(let m of u.getValues(d)){let R=l(d,m);(c?R.endsWith(s):R.includes(s))&&E(R,m)}else if(c?h.endsWith(s):h.includes(s))if(u[qr.DBI_DEFINITION_NAME].is_hash_attribute)E(d,d);else for(let m of u.getValues(d))E(d,m)}function E(d,h){if(o>0){o--;return}i!==0&&($t.pushResults(d,h,_,t,r),i--)}return a(E,"found_match"),_}a(Xf,"contains");function tP(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=typeof s,_;return c==="string"?_="\uFFFF":c==="number"?_=1/0:c==="boolean"&&(_=!0),ci(e,t,r,s,_,n,i,o,!0,!1)}a(tP,"greaterThan");function rP(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=typeof s,_;return c==="string"?_="\uFFFF":c==="number"?_=1/0:c==="boolean"&&(_=!0),ci(e,t,r,s,_,n,i,o,!1,!1)}a(rP,"greaterThanEqual");function sP(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=typeof s,_;return c==="string"?_="\0":c==="number"?_=-1/0:c==="boolean"&&(_=!1),ci(e,t,r,_,s,n,i,o,!1,!0)}a(sP,"lessThan");function nP(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=typeof s,_;return c==="string"?_="\0":c==="number"?_=-1/0:c==="boolean"&&(_=!1),ci(e,t,r,_,s,n,i,o,!1,!1)}a(nP,"lessThanEqual");function iP(e,t,r,s,n,i=!1,o=void 0,c=void 0){if(ft.validateEnv(e),r===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);if(s===void 0)throw new Error(ce.START_VALUE_REQUIRED);if(n===void 0)throw new Error(ce.END_VALUE_REQUIRED);if(s=ft.convertKeyValueToWrite(s),n=ft.convertKeyValueToWrite(n),s>n)throw new Error(ce.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return ci(e,t,r,s,n,i,o,c)}a(iP,"between");function aP(e,t,r,s){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(lo(r),r=_i(e,r),s===void 0)throw new Error(ce.ID_REQUIRED);let n=null,i=e.dbis[t].get(s,r.length<3?oi:void 0);return i&&(n=$t.parseRow(i,r)),n}a(aP,"searchByHash");function oP(e,t,r){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ce.ID_REQUIRED);let s=!0;return e.dbis[t].get(r,oi)===void 0&&(s=!1),s}a(oP,"checkHashExists");function cP(e,t,r,s,n=[]){jf(e,t,r,s,n);let i=zf(e,t,r,s,n);return Object.values(i)}a(cP,"batchSearchByHash");function _P(e,t,r,s,n=[]){return jf(e,t,r,s,n),zf(e,t,r,s,n)}a(_P,"batchSearchByHashToMap");function zf(e,t,r,s,n=[]){r=_i(e,r);let i=Object.create(null),o=r.length<3?oi:void 0;for(let c=0;c<s.length;c++){let _=s[c];try{let u=e.dbis[t].get(_,o);if(u){let l=$t.parseRow(u,r);i[_]=l}else n.push(_)}catch(u){throw $M.warn(u),u}}return i}a(zf,"batchHashSearch");function jf(e,t,r,s,n){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(lo(r),!Array.isArray(s))throw s===void 0?new Error(ce.IDS_REQUIRED):new Error(ce.IDS_MUST_BE_ARRAY);Array.isArray(n)||(n=[])}a(jf,"initializeBatchSearchByHash");function lo(e){if(!Array.isArray(e))throw e===void 0?new Error(ce.FETCH_ATTRIBUTES_REQUIRED):new Error(ce.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(lo,"validateFetchAttributes");function Fr(e,t,r){if(ft.validateEnv(e),t===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ce.SEARCH_VALUE_REQUIRED);if(r?.length>KM)throw new Error(ce.SEARCH_VALUE_TOO_LARGE)}a(Fr,"validateComparisonFunctions");function _i(e,t){return t.length===1&&YM.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wt.listDBIs(e)),t}a(_i,"setGetWholeRowAttributes");eT.exports={searchAll:QM,searchAllToMap:WM,count:zM,countAll:ZM,equals:XM,startsWith:jM,endsWith:eP,contains:Xf,searchByHash:aP,setGetWholeRowAttributes:_i,batchSearchByHash:cP,batchSearchByHashToMap:_P,checkHashExists:oP,iterateDBI:JM,greaterThan:tP,greaterThanEqual:rP,lessThan:sP,lessThanEqual:nP,between:iP}});var ui=S((XJ,nT)=>{var tT=require("lodash"),rT=de(),Q=require("joi"),uP=b(),{hdb_schema_table:Yt,checkValidTable:sT}=Tr(),{handleHDBError:lP,hdb_errors:EP}=D(),{HTTP_STATUS_CODES:dP}=EP,ZJ=Q.object({schema:Yt,table:Yt,hash_values:Q.array().min(1).items(Q.alternatives(Q.string(),Q.number())).required(),get_attributes:Q.array().min(1).items(Yt).required()}),hP=Q.object({schema:Yt,table:Yt,search_attribute:Yt,search_value:Q.any().required(),get_attributes:Q.array().min(1).items(Yt).required(),desc:Q.bool(),limit:Q.number().integer().min(1),offset:Q.number().integer().min(0)}),SP=Q.object({schema:Yt,table:Yt,operator:Q.string().valid("and","or").default("and").lowercase(),offset:Q.number().integer().min(0),limit:Q.number().integer().min(1),get_attributes:Q.array().min(1).items(Yt).required(),conditions:Q.array().min(1).items(Q.object({search_attribute:Yt,search_type:Q.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between").required(),search_value:Q.when("search_type",{switch:[{is:"equals",then:Q.any()},{is:"between",then:Q.array().items(Q.alternatives([Q.string(),Q.number()])).length(2)}],otherwise:Q.alternatives(Q.string(),Q.number())}).required()})).required()});nT.exports=function(e,t){let r=null;switch(t){case"value":r=rT.validateBySchema(e,hP);break;case"hashes":let i=function(o){n?n+=". "+o:n=o};var s=i;a(i,"addError");let n;i(sT("schema",e.schema)),i(sT("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"),n&&(r=new Error(n.trim()));break;case"conditions":r=rT.validateBySchema(e,SP);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let n=uP.checkGlobalSchemaTable(e.schema,e.table);if(n)return lP(new Error,n,dP.NOT_FOUND);let o=global.hdb_schema[e.schema][e.table].attributes,c=[...e.get_attributes];if(t==="value"&&c.push(e.search_attribute),t==="conditions")for(let u=0,l=e.conditions.length;u<l;u++){let E=e.conditions[u];c.push(E.search_attribute)}let _=tT.filter(c,u=>u!=="*"&&u.attribute!=="*"&&!tT.some(o,l=>l===u||l.attribute===u||l.attribute===u.attribute));if(_&&_.length>0){let u=_.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var Qu=S((zJ,iT)=>{"use strict";var fP=Z(),TP=ui(),mP=require("path"),{getBaseSchemaPath:RP}=te();iT.exports=AP;function AP(e){let t=TP(e,"hashes");if(t)throw t;let r=mP.join(RP(),e.schema.toString());return fP.openEnvironment(r,e.table)}a(AP,"initialize")});var Wu=S((jJ,aT)=>{"use strict";var OP=nn(),pP=Qu();aT.exports=NP;async function NP(e){try{let t=await pP(e),r=global.hdb_schema[e.schema][e.table];return OP.batchSearchByHashToMap(t,r.hash_attribute,e.get_attributes,e.hash_values)}catch(t){throw t}}a(NP,"lmdbGetDataByHash")});var ds=S((eZ,oT)=>{"use strict";var Eo=class{constructor(t,r,s,n){this.schema=t,this.table=r,this.hash_values=s,this.get_attributes=n}};a(Eo,"SearchByHashObject");oT.exports=Eo});var _T=S((rZ,cT)=>{"use strict";var tZ=ds(),gP=nn(),IP=Qu();cT.exports=bP;async function bP(e){try{let t=await IP(e),r=global.hdb_schema[e.schema][e.table];return gP.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}catch(t){throw t}}a(bP,"lmdbSearchByHash")});var Kt=S((sZ,uT)=>{"use strict";var ho=class{constructor(t,r,s,n,i,o,c,_=!1,u=void 0,l=void 0){this.schema=t,this.table=r,this.search_attribute=s,this.search_value=n,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=_,this.limit=u,this.offset=l}};a(ho,"SearchObject");uT.exports=ho});var So=S((nZ,ST)=>{"use strict";var We=nn(),CP=Z(),wP=require("path"),LP=b(),U=Ye(),hs=T(),{getBaseSchemaPath:UP}=te(),yP=is(),lT=Ke().LMDB_ERRORS_ENUM,{compareKeys:an}=require("ordered-binary"),Rr=hs.SEARCH_WILDCARDS;async function DP(e,t,r){let s;e.schema===hs.SYSTEM_SCHEMA_NAME?s=yP[e.table]:s=global.hdb_schema[e.schema][e.table];let n=hT(e,s.hash_attribute,r,t);return ET(e,n,s.hash_attribute,r)}a(DP,"prepSearch");async function ET(e,t,r,s){let n=wP.join(UP(),e.schema.toString()),i=await CP.openEnvironment(n,e.table),o=dT(i,e,t,r);if([U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,U.SEARCH_TYPES.SEARCH_ALL,U.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(BP(e,r)===!1)return s===!0?PP(o):o[1];let _=o[0];return s===!0?We.batchSearchByHashToMap(i,r,e.get_attributes,_):We.batchSearchByHash(i,r,e.get_attributes,_)}a(ET,"executeSearch");function dT(e,t,r,s){let n,i=s;t.get_attributes.indexOf(s)<0&&(i=void 0);let{reverse:o,limit:c,offset:_}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,_=Number.isInteger(_)?_:void 0,r){case U.SEARCH_TYPES.EQUALS:n=We.equals(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.CONTAINS:n=We.contains(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.ENDS_WITH:case U.SEARCH_TYPES._ENDS_WITH:n=We.endsWith(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.STARTS_WITH:case U.SEARCH_TYPES._STARTS_WITH:n=We.startsWith(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return We.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return We.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case U.SEARCH_TYPES.SEARCH_ALL:return We.searchAll(e,s,t.get_attributes,o,c,_);case U.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return We.searchAllToMap(e,s,t.get_attributes,o,c,_);case U.SEARCH_TYPES.BETWEEN:n=We.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,_);break;case U.SEARCH_TYPES.GREATER_THAN:case U.SEARCH_TYPES._GREATER_THAN:n=We.greaterThan(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.GREATER_THAN_EQUAL:case U.SEARCH_TYPES._GREATER_THAN_EQUAL:n=We.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.LESS_THAN:case U.SEARCH_TYPES._LESS_THAN:n=We.lessThan(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.LESS_THAN_EQUAL:case U.SEARCH_TYPES._LESS_THAN_EQUAL:n=We.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,_);break;default:return Object.create(null)}return n}a(dT,"searchByType");function MP(e){let t=e.search_type,r=e.search_attribute,s=e.search_value;switch(t){case U.SEARCH_TYPES.EQUALS:return n=>n[r]===s;case U.SEARCH_TYPES.CONTAINS:return n=>typeof n[r]=="string"&&n[r].includes(s);case U.SEARCH_TYPES.ENDS_WITH:case U.SEARCH_TYPES._ENDS_WITH:return n=>typeof n[r]=="string"&&n[r].endsWith(s);case U.SEARCH_TYPES.STARTS_WITH:case U.SEARCH_TYPES._STARTS_WITH:return n=>typeof n[r]=="string"&&n[r].startsWith(s);case U.SEARCH_TYPES.BETWEEN:return n=>{let i=n[r];return an(i,s[0])>=0&&an(i,s[1])<=0};case U.SEARCH_TYPES.GREATER_THAN:case U.SEARCH_TYPES._GREATER_THAN:return n=>an(n[r],s)>0;case U.SEARCH_TYPES.GREATER_THAN_EQUAL:case U.SEARCH_TYPES._GREATER_THAN_EQUAL:return n=>an(n[r],s)>=0;case U.SEARCH_TYPES.LESS_THAN:case U.SEARCH_TYPES._LESS_THAN:return n=>an(n[r],s)<0;case U.SEARCH_TYPES.LESS_THAN_EQUAL:case U.SEARCH_TYPES._LESS_THAN_EQUAL:return n=>an(n[r],s)<=0;default:return Object.create(null)}}a(MP,"filterByType");function PP(e){let t=Object.create(null);for(let r=0,s=e[0].length;r<s;r++)t[e[0][r]]=e[1][r];return t}a(PP,"createMapFromArrays");function BP(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 s=!1;for(let n=0;n<e.get_attributes.length;n++)if(r.indexOf(e.get_attributes[n])<0){s=!0;break}return s}a(BP,"checkToFetchMore");function hT(e,t,r,s){if(LP.isEmpty(s)){let n=e.search_value;typeof n=="object"?n=JSON.stringify(n):n=n.toString();let i=n.charAt(0),o=n.charAt(n.length-1),c=!1;if(e.search_attribute===t&&(c=!0),Rr.indexOf(n)>-1)return r===!0?U.SEARCH_TYPES.SEARCH_ALL_TO_MAP:U.SEARCH_TYPES.SEARCH_ALL;if(n.indexOf(Rr[0])<0&&n.indexOf(Rr[1])<0)return c===!0?r===!0?U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:U.SEARCH_TYPES.EQUALS;if(Rr.indexOf(i)>=0&&Rr.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),U.SEARCH_TYPES.CONTAINS;if(Rr.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),U.SEARCH_TYPES.ENDS_WITH;if(Rr.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),U.SEARCH_TYPES.STARTS_WITH;if(n.includes(Rr[0])||n.includes(Rr[1]))return U.SEARCH_TYPES.EQUALS;throw new Error(lT.UNKNOWN_SEARCH_TYPE)}else switch(s){case hs.VALUE_SEARCH_COMPARATORS.BETWEEN:return U.SEARCH_TYPES.BETWEEN;case hs.VALUE_SEARCH_COMPARATORS.GREATER:return U.SEARCH_TYPES.GREATER_THAN;case hs.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return U.SEARCH_TYPES.GREATER_THAN_EQUAL;case hs.VALUE_SEARCH_COMPARATORS.LESS:return U.SEARCH_TYPES.LESS_THAN;case hs.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return U.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(lT.UNKNOWN_SEARCH_TYPE)}}a(hT,"createSearchTypeFromSearchObject");ST.exports={executeSearch:ET,createSearchTypeFromSearchObject:hT,prepSearch:DP,searchByType:dT,filterByType:MP}});var TT=S((aZ,fT)=>{"use strict";var iZ=Kt(),vP=ui(),HP=b(),GP=T(),qP=So();fT.exports=FP;async function FP(e,t){if(!HP.isEmpty(t)&&GP.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let s=vP(e,"value");if(s)throw s;let n=!0;try{return await qP.prepSearch(e,t,n)}catch(i){throw i}}a(FP,"lmdbGetDataByValue")});var on=S((cZ,mT)=>{"use strict";var oZ=Kt(),VP=ui(),kP=b(),xP=T(),$P=So();mT.exports=YP;async function YP(e,t){if(!kP.isEmpty(t)&&xP.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let s=VP(e,"value");if(s)throw s;let n=!1;try{return await $P.prepSearch(e,t,n)}catch(i){throw i}}a(YP,"lmdbSearchByValue")});var AT=S((uZ,RT)=>{"use strict";var _Z=Ye(),fo=class{constructor(t,r,s,n,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=s,this.limit=i,this.offset=o,this.conditions=n,this.operator=c}};a(fo,"SearchByConditionsObject");var To=class{constructor(t,r,s){this.search_attribute=t,this.search_type=r,this.search_value=s}};a(To,"SearchCondition");var mo=class{constructor(t,r){this.attribute=t,this.desc=r}};a(mo,"SortAttribute");RT.exports={SearchByConditionsObject:fo,SearchCondition:To,SortAttribute:mo}});var bT=S((EZ,IT)=>{"use strict";var lZ=AT().SearchByConditionsObject,KP=Kt(),QP=ui(),Ju=nn(),Ro=Ye(),gT=So(),WP=Yu(),OT=require("lodash"),{getBaseSchemaPath:JP}=te(),ZP=require("path"),XP=Z(),{handleHDBError:pT,hdb_errors:zP}=D(),{HTTP_STATUS_CODES:jP}=zP,eB=1e8,tB={lazy:!0};IT.exports=rB;async function rB(e){try{let t=QP(e,"conditions");if(t)throw pT(t,t.message,jP.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=ZP.join(JP(),e.schema.toString()),s=await XP.openEnvironment(r,e.table),n=global.hdb_schema[e.schema][e.table],i=OT.sortBy(e.conditions,o=>{if(o.estimated_count===void 0){let c=o.search_type;c===Ro.SEARCH_TYPES.EQUALS?o.estimated_count=Ju.count(s,o.search_attribute,o.search_value):c===Ro.SEARCH_TYPES.CONTAINS||c===Ro.SEARCH_TYPES.ENDS_WITH?o.estimated_count=1/0:o.estimated_count=eB}return o.estimated_count});if(!e.operator||e.operator.toLowerCase()==="and"){let[o]=await NT(s,e,i[0],n.hash_attribute),c=s.dbis[n.hash_attribute],_=i.slice(1).map(gT.filterByType),u=_.length,l=[],E=Ju.setGetWholeRowAttributes(s,e.get_attributes),d=e.offset>-1?e.offset:0,h=e.limit>-1?e.limit:1/0;e:for(let m of o){let R=c.get(m,tB);for(let w=0;w<u;w++)if(!_[w](R))continue e;if(d>0){d--;continue}if(h<=0)break;h--,l.push(WP.parseRow(R,E))}return l}else{let o=[],c=[];for(let _ of i){let[u]=await NT(s,e,_,n.hash_attribute);c.push(u)}if(o=OT.union(...c),e.limit>0||e.offset>0){let _=Number.isInteger(e.limit)?e.limit:o.length;o=o.splice(e.offset,_)}return Ju.batchSearchByHash(s,n.hash_attribute,e.get_attributes,o)}}catch(t){throw pT(t)}}a(rB,"lmdbSearchByConditions");async function NT(e,t,r,s){let n=new KP(t.schema,t.table,void 0,void 0,s,t.get_attributes),i=r.search_type;return n.search_attribute=r.search_attribute,i===Ro.SEARCH_TYPES.BETWEEN?(n.search_value=r.search_value[0],n.end_value=r.search_value[1]):n.search_value=r.search_value,gT.searchByType(e,n,i,s)}a(NT,"executeConditionSearch")});var li=S((dZ,CT)=>{"use strict";var sB=T().OPERATIONS_ENUM,Ao=class{constructor(t,r,s,n=void 0){this.operation=sB.DELETE,this.schema=t,this.table=r,this.hash_values=s,this.__origin=n}};a(Ao,"DeleteObject");CT.exports=Ao});var Zu=S((hZ,wT)=>{"use strict";var Oo=class{constructor(t,r,s){this.schema=t,this.table=r,this.attribute=s}};a(Oo,"DropAttributeObject");wT.exports=Oo});var zu=S((fZ,LT)=>{"use strict";var nB=Kt(),iB=li(),SZ=Zu(),er=T(),aB=b(),Xu=Z(),oB=is(),cB=on(),_B=ai(),{getBaseSchemaPath:uB}=te(),lB=require("path");LT.exports=EB;async function EB(e,t=!0){let r;e.schema===er.SYSTEM_SCHEMA_NAME?r=oB[e.table]:r=global.hdb_schema[e.schema][e.table];let s=await hB(e),n=lB.join(uB(),e.schema.toString()),i=await Xu.openEnvironment(n,e.table);return t===!0&&await dB(e,i,r.hash_attribute),Xu.dropDBI(i,e.attribute),s}a(EB,"lmdbDropAttribute");async function dB(e,t,r){let s=Xu.openDBI(t,r),n,i=e.attribute;for(let{key:o,value:c,version:_}of s.getRange({start:!1,versions:!0})){let u={};for(let l in c)l!==i&&(u[l]=c[l]);n=t.dbis[r].put(o,u,_)}await n}a(dB,"removeAttributeFromAllObjects");async function hB(e){let t=new nB(er.SYSTEM_SCHEMA_NAME,er.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,er.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[er.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,er.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),s=(await cB(t)).filter(o=>o[er.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(aB.isEmptyOrZeroLength(s))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let n=s.map(o=>o[er.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new iB(er.SYSTEM_SCHEMA_NAME,er.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);return _B(i)}a(hB,"dropAttributeFromSystem")});var MT=S((TZ,DT)=>{"use strict";var SB=zu(),fB=Zu(),UT=b(),yT=I(),TB=Ke().LMDB_ERRORS_ENUM;DT.exports=mB;async function mB(e){if(UT.isEmpty(global.hdb_schema[e.schema])||UT.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);let t=global.hdb_schema[e.schema][e.table],r;try{for(let s=0;s<t.attributes.length;s++){r=t.attributes[s].attribute;let n=new fB(e.schema,e.table,r);try{await SB(n,!1)}catch(i){i.message!==TB.DBI_DOES_NOT_EXIST&&yT.error(`unable to drop attribute ${e.schema}.${e.table}.${r}:`+i)}}}catch(s){throw yT.error(`Error dropping attribute ${r}`),s}}a(mB,"lmdbDropAllAttributes")});var ju=S((RZ,kT)=>{"use strict";var GT=Kt(),qT=li(),FT=on(),VT=ai(),mZ=MT(),at=T(),PT=b(),BT=Z(),{getBaseSchemaPath:RB,getTransactionAuditStorePath:AB}=te(),vT=require("path"),HT=I();kT.exports=OB;async function OB(e){try{if(PT.isEmpty(global.hdb_schema[e.schema])||PT.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await pB(e),await NB(e);let t=vT.join(RB(),e.schema.toString());try{await BT.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")HT.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=vT.join(AB(),e.schema.toString());await BT.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")HT.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(OB,"lmdbDropTable");async function pB(e){let t=new GT(at.SYSTEM_SCHEMA_NAME,at.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=await FT(t),s=[];for(let i=0;i<r.length;i++){let o=r[i];s.push(o.id)}if(s.length===0)return;let n=new qT(at.SYSTEM_SCHEMA_NAME,at.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);await VT(n)}a(pB,"deleteAttributesFromSystem");async function NB(e){let t=new GT(at.SYSTEM_SCHEMA_NAME,at.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,s;try{r=await FT(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&&(s=o)}if(!s)throw new Error(`${e.schema}.${e.table} was not found`);let n=new qT(at.SYSTEM_SCHEMA_NAME,at.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[s.id]);try{await VT(n)}catch(i){throw i}}a(NB,"dropTableFromSystem")});var $T=S((OZ,xT)=>{"use strict";var gB=require("fs-extra"),IB=Kt(),bB=ds(),CB=li(),wB=ju(),LB=ai(),UB=Wu(),yB=on(),Ar=T(),AZ=b(),DB=require("path"),{getBaseSchemaPath:MB}=te(),{handleHDBError:PB,hdb_errors:BB}=D(),{HDB_ERROR_MSGS:vB,HTTP_STATUS_CODES:HB}=BB;xT.exports=GB;async function GB(e){let t;try{t=await qB(e.schema);let r=new IB(Ar.SYSTEM_SCHEMA_NAME,Ar.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),s=await yB(r);for(let o=0;o<s.length;o++){let c={schema:t,table:s[o].name};try{await wB(c)}catch(_){if(_.message!=="invalid environment")throw _}}let n=new CB(Ar.SYSTEM_SCHEMA_NAME,Ar.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await LB(n);let i=DB.join(MB(),t.toString());await gB.remove(i)}catch(r){throw r}}a(GB,"lmdbDropSchema");async function qB(e){let t=new bB(Ar.SYSTEM_SCHEMA_NAME,Ar.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,s;try{r=await UB(t)}catch(n){throw n}for(let n in r)r[n].name===e&&(s=e);if(!s)throw PB(new Error,vB.SCHEMA_NOT_FOUND(e),HB.NOT_FOUND,void 0,void 0,!0);return s}a(qB,"validateDropSchema")});var el=S((pZ,YT)=>{"use strict";var po=class{constructor(t,r,s){this.schema=t,this.table=r,this.hash_attribute=s}};a(po,"CreateTableObject");YT.exports=po});var QT=S((gZ,KT)=>{"use strict";var FB=require("path"),VB=require("fs-extra"),No=Z(),{getTransactionAuditStorePath:kB}=te(),tl=Ye(),NZ=el();KT.exports=xB;async function xB(e){let t;try{let r=FB.join(kB(),e.schema.toString());await VB.mkdirp(r),t=await No.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{No.createDBI(t,tl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),No.createDBI(t,tl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),No.createDBI(t,tl.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(xB,"createTransactionsAuditEnvironment")});var XT=S((IZ,ZT)=>{"use strict";var rl=T(),WT=Z(),$B=Xs(),YB=require("path"),{getSystemSchemaPath:KB,getBaseSchemaPath:QB}=te(),WB=is(),JB=Za(),sl=Ja(),ZB=I(),XB=QT(),il=WB.hdb_table,JT=[];for(let e=0;e<il.attributes.length;e++)JT.push(il.attributes[e].attribute);ZT.exports=zB;async function zB(e,t){let r=YB.join(QB(),t.schema.toString()),s=new sl(t.schema,t.table,rl.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),n=new sl(t.schema,t.table,rl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new sl(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await WT.createEnvironment(r,t.table),e!==void 0){let o=await WT.openEnvironment(KB(),rl.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await $B.insertRecords(o,il.hash_attribute,JT,[e]),await nl(s),await nl(n),await nl(i)}await XB(t)}catch(o){throw o}}a(zB,"lmdbCreateTable");async function nl(e){try{await JB(e)}catch(t){ZB.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(nl,"createAttribute")});var jT=S((bZ,zT)=>{"use strict";var jB=Xa(),ev=eo(),tv=so(),cn=T(),rv=Xs().updateRecords,sv=Z(),nv=require("path"),{getBaseSchemaPath:iv}=te(),av=ii(),ov=I();zT.exports=cv;async function cv(e){try{let{schema_table:t,attributes:r}=jB(e);ev(e,r,t.hash_attribute),e.schema!==cn.SYSTEM_SCHEMA_NAME&&(r.includes(cn.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(cn.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(cn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(cn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await tv(e.hdb_auth_header,t,r),n=nv.join(iv(),e.schema.toString()),i=await sv.openEnvironment(n,e.table),o=await rv(i,t.hash_attribute,r,e.records,e[cn.CLUSTERING_FLAG]!==!0);try{await av(e,o)}catch(c){ov.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:s,txn_time:o.txn_time}}catch(t){throw t}}a(cv,"lmdbUpdateRecords")});var tm=S((CZ,em)=>{"use strict";var _v=T().OPERATIONS_ENUM,go=class{constructor(t,r,s,n=void 0){this.operation=_v.UPSERT,this.schema=t,this.table=r,this.records=s,this.__origin=n}};a(go,"UpsertObject");em.exports=go});var sm=S((LZ,rm)=>{"use strict";var wZ=tm(),uv=Xa(),lv=eo(),Ev=so(),_n=T(),dv=Xs().upsertRecords,hv=Z(),Sv=require("path"),{getBaseSchemaPath:fv}=te(),Tv=ii(),mv=I(),{handleHDBError:Rv,hdb_errors:Av}=D();rm.exports=Ov;async function Ov(e){let t;try{t=uv(e)}catch(_){throw Rv(_,_.message,Av.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:s}=t;lv(e,s,r.hash_attribute),e.schema!==_n.SYSTEM_SCHEMA_NAME&&(s.includes(_n.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||s.push(_n.TIME_STAMP_NAMES_ENUM.CREATED_TIME),s.includes(_n.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||s.push(_n.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Ev(e.hdb_auth_header,r,s),i=Sv.join(fv(),e.schema.toString()),o=await hv.openEnvironment(i,e.table),c=await dv(o,r.hash_attribute,s,e.records,e[_n.CLUSTERING_FLAG]!==!0);try{await Tv(e,c)}catch(_){mv.error(`unable to write transaction due to ${_.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:n,txn_time:c.txn_time}}a(Ov,"lmdbUpsertRecords")});var _m=S((UZ,cm)=>{"use strict";var pv=Kt(),nm=b(),im=I(),Nv=on(),am=T(),gv=xu().deleteRecords,Iv=Z(),bv=require("path"),{getBaseSchemaPath:Cv}=te(),{promisify:wv}=require("util"),Lv=wv(setTimeout),om=1e4,Uv=10;cm.exports=yv;async function yv(e){let t=global.hdb_schema[e.schema][e.table].hash_attribute;if(nm.isEmptyOrZeroLength(t))throw new Error(`Could not retrieve hash attribute for schema: ${e.schema} table: ${e.table}`);let r=Date.parse(e.date),s;try{let n=new pv(e.schema,e.table,am.TIME_STAMP_NAMES_ENUM.CREATED_TIME,r,void 0,[t]);s=await Nv(n,am.VALUE_SEARCH_COMPARATORS.LESS)}catch(n){throw im.error(`Error searching for date: ${e.date} in schema: ${e.schema} table: ${e.table}`),n}return nm.isEmptyOrZeroLength(s)?(im.trace("No records found to delete"),{message:"No records found to delete"}):await Dv(e,s,t)}a(yv,"lmdbDeleteRecordsBefore");async function Dv(e,t,r){let s=bv.join(Cv(),e.schema.toString()),n=await Iv.openEnvironment(s,e.table),i={message:"",deleted_hashes:[],skipped_hashes:[]};for(let o=0,c=t.length;o<c;o+=om){let _=t.slice(o,o+om),u=[];for(let l=0,E=_.length;l<E;l++)u.push(_[l][r]);try{let l=await gv(n,r,u);i.deleted_hashes=i.deleted_hashes.concat(l.deleted),i.skipped_hashes=i.skipped_hashes.concat(l.skipped)}catch(l){throw l}await Lv(Uv)}return i.message=`${i.deleted_hashes.length} of ${i.deleted_hashes.length+i.skipped_hashes.length} records successfully deleted`,i}a(Dv,"chunkDeletes")});var lm=S((yZ,um)=>{"use strict";var Io=class{constructor(t,r,s){this.schema=t,this.table=r,this.timestamp=s}};a(Io,"DeleteBeforeObject");um.exports=Io});var dm=S((DZ,Em)=>{"use strict";var bo=class{constructor(t=void 0,r=void 0,s=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=s}};a(bo,"DeleteAuditLogsBeforeResults");Em.exports=bo});var fm=S((PZ,Sm)=>{"use strict";var al=Z(),{getTransactionAuditStorePath:Mv}=te(),MZ=lm(),Pv=require("path"),Ei=Ye(),Bv=b(),hm=dm(),vv=require("util").promisify,Hv=vv(setTimeout),Gv=1e4,qv=100;Sm.exports=Fv;async function Fv(e){let t=Pv.join(Mv(),e.schema),r=await al.openEnvironment(t,e.table,!0),s=al.listDBIs(r);al.initializeDBIs(r,Ei.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,s);let n,i=new hm;do n=await Vv(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=n.start_timestamp),n.end_timestamp!==void 0&&(i.end_timestamp=n.end_timestamp),i.transactions_deleted+=n.transactions_deleted,await Hv(qv);while(n.transactions_deleted>0);return i}a(Fv,"deleteAuditLogsBefore");async function Vv(e,t){let r=new hm;try{let s=e.dbis[Ei.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let{key:i,value:o}of s.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),n=s.remove(i);let c=o[Ei.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Bv.isEmpty(c)||(n=e.dbis[Ei.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let _=0;_<o.hash_values.length;_++)n=e.dbis[Ei.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[_],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Gv)break}return await n,r}catch(s){throw s}}a(Vv,"deleteTransactions")});var Nm=S((BZ,pm)=>{"use strict";var ol=Z(),un=Ye(),Tm=_s(),cl=T(),mm=b(),{getTransactionAuditStorePath:kv}=te(),xv=require("path"),$v=nn(),Co=en(),Yv=I();pm.exports=Kv;async function Kv(e){let t=xv.join(kv(),e.schema),r=await ol.openEnvironment(t,e.table,!0),s=ol.listDBIs(r);ol.initializeDBIs(r,un.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,s);let n;switch(e.search_type){case cl.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Rm(r,e.search_values);case cl.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return n=global.hdb_schema[e.schema][e.table].hash_attribute,Wv(r,e.search_values,n);case cl.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return Qv(r,e.search_values);default:return Rm(r)}}a(Kv,"readAuditLog");function Rm(e,t=[0,Tm.getMicroTime()]){mm.isEmpty(t[0])&&(t[0]=0),mm.isEmpty(t[1])&&(t[1]=Tm.getMicroTime());let r=[];try{let s=e.dbis[un.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let i of s.getKeys({start:t[1]}))if(i!==t[1]){n=i;break}for(let{value:i}of s.getRange({start:t[0],end:n})){let o=Object.assign(new Co,i);r.push(o)}return r}catch(s){throw s}}a(Rm,"searchTransactionsByTimestamp");function Qv(e,t=[]){let r=new Map;for(let s=0;s<t.length;s++){let n=t[s],i=[];for(let o of e.dbis[un.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(n))i.push(o);r.set(n,Om(e,i))}return Object.fromEntries(r)}a(Qv,"searchTransactionsByUsername");function Wv(e,t,r){let s=new Map;for(let c=0,_=t.length;c<_;c++){let u=t[c],l=$v.equals(e,un.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,un.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let E=0,d=l[0].length;E<d;E++){let h=l[0][E],m=Number(h);s.has(m)?s.get(m).push(u.toString()):s.set(m,[u.toString()])}}let n=Array.from(s.keys()),i=Om(e,n),o=new Map;for(let c=0;c<i.length;c++){let _=i[c],u=_.timestamp,l=s.get(u);Am(_,"records",r,l,o),Am(_,"original_records",r,l,o)}return Object.fromEntries(o)}a(Wv,"searchTransactionsByHashValues");function Am(e,t,r,s,n){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],_=c[r].toString();if(s.indexOf(_)>=0)if(n.has(_)){let u=n.get(_),l=u[u.length-1];if(l.timestamp===i)l[t]=[c];else{let E=new Co(e.operation,e.user_name,i,void 0);E[t]=[c],u.push(E)}}else{let u=new Co(e.operation,e.user_name,i,void 0);u[t]=[c],n.set(_,[u])}}}a(Am,"loopRecords");function Om(e,t){let r=[];try{let s=e.dbis[un.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let n=0;n<t.length;n++)try{let i=s.get(t[n]);if(i){let o=Object.assign(new Co,i);r.push(o)}}catch(i){Yv.warn(i)}return r}catch(s){throw s}}a(Om,"batchSearchTransactions")});var Im=S((vZ,gm)=>{"use strict";var Jv=require("path"),{getBaseSchemaPath:Zv}=te(),Xv=Z();gm.exports={writeTransaction:zv};async function zv(e,t,r){let s=Jv.join(Zv(),e);return(await Xv.openEnvironment(s,t)).transaction(r)}a(zv,"writeTransaction")});var Cm=S((HZ,bm)=>{"use strict";var jv=require("path"),{getBaseSchemaPath:eH}=te(),tH=Z();bm.exports={flush:rH};async function rH(e,t){let r=jv.join(eH(),e.toString());return(await tH.openEnvironment(r,t.toString())).flushed}a(rH,"flush")});var Lm=S((GZ,wm)=>{"use strict";var Re=I(),{handleHDBError:sH}=D(),nH=Eu(),iH=Za(),aH=Fu(),oH=Ff(),cH=ai(),_H=Wu(),uH=_T(),lH=TT(),EH=on(),dH=bT(),hH=$T(),SH=XT(),fH=jT(),TH=sm(),mH=_m(),RH=fm(),AH=ju(),OH=zu(),pH=Nm(),NH=Im(),gH=Cm(),wo=class extends nH{async searchByConditions(t){try{return dH(t)}catch(r){throw Re.error(r),r}}async getDataByHash(t){try{return await _H(t)}catch(r){throw Re.error(r),r}}async searchByHash(t){try{return await uH(t)}catch(r){throw Re.error(r),r}}async getDataByValue(t,r){try{return await lH(t,r)}catch(s){throw Re.error(s),s}}async searchByValue(t){try{return await EH(t)}catch(r){throw Re.error(r),r}}async createSchema(t){try{return await oH(t)}catch(r){throw Re.error(r),r}}async dropSchema(t){try{return await hH(t)}catch(r){throw Re.error(r),r}}async createTable(t,r){try{return await SH(t,r)}catch(s){throw Re.error(s),s}}async dropTable(t){try{return await AH(t)}catch(r){throw Re.error(r),r}}async createAttribute(t){try{return await iH(t)}catch(r){throw Re.error(r),r}}async createRecords(t){try{return await aH(t)}catch(r){throw Re.error(r),r}}async updateRecords(t){try{return await fH(t)}catch(r){throw Re.error(r),r}}async upsertRecords(t){try{return await TH(t)}catch(r){throw sH(r,null,null,Re.ERR,r)}}async deleteRecords(t){try{return await cH(t)}catch(r){throw Re.error(r),r}}async deleteRecordsBefore(t){try{return await mH(t)}catch(r){throw Re.error(r),r}}async dropAttribute(t){try{return await OH(t)}catch(r){throw Re.error(r),r}}async deleteAuditLogsBefore(t){try{return await RH(t)}catch(r){throw Re.error(r),r}}async readAuditLog(t){try{return await pH(t)}catch(r){throw Re.error(r),r}}writeTransaction(t,r,s){return NH.writeTransaction(t,r,s)}flush(t,r){return gH.flush(t,r)}};a(wo,"LMDBBridge");wm.exports=wo});var Or=S((qZ,ym)=>{"use strict";var IH=Lm(),bH=Eu(),CH=Y();CH.initSync();var Um;function wH(){return Um instanceof bH?Um:new IH}a(wH,"getBridge");ym.exports=wH()});var Bm=S((FZ,Pm)=>{"use strict";var Dm=require("lodash"),di=require("mathjs"),LH=require("jsonata"),Mm=b();Pm.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?Dm.uniqWith(e,Dm.isEqual):e,searchJSON:UH,mad:hi.bind(null,di.mad),mean:hi.bind(null,di.mean),mode:hi.bind(null,di.mode),prod:hi.bind(null,di.prod),median:hi.bind(null,di.median)};function hi(e,t,r,s){return s===1?t==null?[]:[t]:s===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(hi,"aggregateFunction");function UH(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(Mm.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Mm.isEmpty(this.__ala__.res[r])){let s=LH(e);this.__ala__.res[r]=s}return this.__ala__.res[r].evaluate(t)}a(UH,"searchJSON")});var Hm=S((VZ,vm)=>{"use strict";var he=require("moment"),_l="YYYY-MM-DDTHH:mm:ss.SSSZZ";he.suppressDeprecationWarnings=!0;vm.exports={current_date:()=>he().utc().format("YYYY-MM-DD"),current_time:()=>he().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return he(e).utc().format("YYYY");case"month":return he(e).utc().format("MM");case"day":return he(e).utc().format("DD");case"hour":return he(e).utc().format("HH");case"minute":return he(e).utc().format("mm");case"second":return he(e).utc().format("ss");case"millisecond":return he(e).utc().format("SSS");default:break}},date:e=>he(e).utc().format(_l),date_format:(e,t)=>he(e).utc().format(t),date_add:(e,t,r)=>he(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>he(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let s=he(e).utc(),n=he(t).utc();return r?s.diff(n,r,!0):s.diff(n)},now:()=>he().utc().valueOf(),get_server_time:()=>he().format(_l),offset_utc:(e,t)=>he(e).utc().utcOffset(t).format(_l)}});var Vm=S((kZ,Fm)=>{"use strict";var yH=require("@turf/area"),DH=require("@turf/length"),MH=require("@turf/circle"),PH=require("@turf/difference"),BH=require("@turf/distance"),vH=require("@turf/boolean-contains"),HH=require("@turf/boolean-equal"),GH=require("@turf/boolean-disjoint"),qH=require("@turf/helpers"),Gm=T(),k=b();Fm.exports={geoArea:FH,geoLength:VH,geoCircle:kH,geoDifference:xH,geoDistance:qm,geoNear:$H,geoContains:YH,geoEqual:KH,geoCrosses:QH,geoConvert:WH};var ul="geo1 is required",ll="geo2 is required";function FH(e){if(k.isEmpty(e))throw new Error("geoJSON is required");return typeof e=="string"&&(e=k.autoCast(e)),yH.default(e)}a(FH,"geoArea");function VH(e,t){if(k.isEmpty(e))throw new Error("geoJSON is required");return typeof e=="string"&&(e=k.autoCast(e)),DH.default(e,{units:t||"kilometers"})}a(VH,"geoLength");function kH(e,t,r){if(k.isEmpty(e))throw new Error("point is required");if(k.isEmpty(t))throw new Error("radius is required");return typeof e=="string"&&(e=k.autoCast(e)),MH.default(e,t,{units:r||"kilometers"})}a(kH,"geoCircle");function xH(e,t){if(k.isEmpty(e))throw new Error("poly1 is required");if(k.isEmpty(t))throw new Error("poly2 is required");return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),PH(e,t)}a(xH,"geoDifference");function qm(e,t,r){if(k.isEmpty(e))throw new Error("point1 is required");if(k.isEmpty(t))throw new Error("point2 is required");return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),BH.default(e,t,{units:r||"kilometers"})}a(qm,"geoDistance");function $H(e,t,r,s){if(k.isEmpty(e))throw new Error("point1 is required");if(k.isEmpty(t))throw new Error("point2 is required");if(k.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),isNaN(r))throw new Error("distance must be a number");return qm(e,t,s)<=r}a($H,"geoNear");function YH(e,t){if(k.isEmpty(e))throw new Error(ul);if(k.isEmpty(e))throw new Error(ll);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),vH.default(e,t)}a(YH,"geoContains");function KH(e,t){if(k.isEmpty(e))throw new Error(ul);if(k.isEmpty(e))throw new Error(ll);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),HH.default(e,t)}a(KH,"geoEqual");function QH(e,t){if(k.isEmpty(e))throw new Error(ul);if(k.isEmpty(e))throw new Error(ll);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),!GH.default(e,t)}a(QH,"geoCrosses");function WH(e,t,r){if(k.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(k.isEmpty(t))throw new Error("geo_type is required");if(k.isEmpty(Gm.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Gm.GEO_CONVERSION_ENUM).join(",")}`);return qH[t](e,r)}a(WH,"geoConvert")});var Lo=S((xZ,km)=>{var Ss=Bm(),Tt=Hm(),tr=Vm();km.exports=e=>{e.aggr.mad=e.aggr.MAD=Ss.mad,e.aggr.mean=e.aggr.MEAN=Ss.mean,e.aggr.mode=e.aggr.MODE=Ss.mode,e.aggr.prod=e.aggr.PROD=Ss.prod,e.aggr.median=e.aggr.MEDIAN=Ss.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Ss.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Ss.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Tt.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Tt.current_time,e.fn.extract=e.fn.EXTRACT=Tt.extract,e.fn.date=e.fn.DATE=Tt.date,e.fn.date_format=e.fn.DATE_FORMAT=Tt.date_format,e.fn.date_add=e.fn.DATE_ADD=Tt.date_add,e.fn.date_sub=e.fn.DATE_SUB=Tt.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Tt.date_diff,e.fn.now=e.fn.NOW=Tt.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Tt.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Tt.get_server_time,e.fn.getdate=e.fn.GETDATE=Tt.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Tt.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=tr.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=tr.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=tr.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=tr.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=tr.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=tr.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=tr.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=tr.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=tr.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=tr.geoNear}});var Ym=S(($Z,$m)=>{"use strict";var Si=require("lodash"),Me=require("alasql");Me.options.cache=!1;var JH=Lo(),xm=require("clone"),Uo=require("recursive-iterator"),v=I(),G=b(),ln=Or(),ZH=T(),{hdb_errors:XH}=D(),zH="IS NULL",fi="There was a problem performing this search. Please check the logs and try again.";JH(Me);var yo=class{constructor(t,r){if(G.isEmpty(t))throw v.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(),G.backtickASTSchemaItems(this.statement)}async search(){let t;try{let s=await this._checkEmptySQL();if(!G.isEmptyOrZeroLength(s))return v.trace("No results returned from checkEmptySQL SQLSearch method."),s}catch(s){throw v.error("Error thrown from checkEmptySQL in SQLSearch class method search."),v.error(s),new Error(fi)}try{let s=await this._getFetchAttributeValues();if(s)return s}catch(s){throw v.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),v.error(s),new Error(fi)}if(Object.keys(this.data).length===0)return v.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(s){throw v.error("Error thrown from processJoins in SQLSearch class method search."),v.error(s),new Error(fi)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(s){throw v.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),v.error(s),new Error(fi)}try{return t=await this._finalSQL(),t}catch(s){throw v.error("Error thrown from finalSQL in SQLSearch class method search."),v.error(s),new Error(fi)}}_getColumns(){let t=new Uo(this.statement);for(let{node:r,path:s}of t)r&&r.columnid&&(this.columns[s[0]]||(this.columns[s[0]]=[]),this.columns[s[0]].push(xm(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Si.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let s=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[s]={},this.data[s].__hash_name=global.hdb_schema[r.databaseid][r.tableid].hash_attribute,this.data[s].__merged_data={},this.data[s].__merged_attributes=[],this.data[s].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(G.isEmpty(this.statement.where)){v.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new Uo(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!G.isEmpty(r)&&r.right)if(G.isNotEmptyAndHasValue(r.right.value)){let s=G.autoCast(r.right.value);[!0,!1].indexOf(s)>=0?r.right=new Me.yy.LogicValue({value:s}):r.right instanceof Me.yy.StringValue&&!G.isEmpty(s)&&G.autoCasterIsNumberCheck(s.toString())&&(r.right=new Me.yy.NumValue({value:s}))}else Array.isArray(r.right)&&r.right.forEach((s,n)=>{let i=G.autoCast(s.value);[!0,!1].indexOf(i)>=0?r.right[n]=new Me.yy.LogicValue({value:i}):s instanceof Me.yy.StringValue&&G.autoCasterIsNumberCheck(i.toString())&&(r.right[n]=new Me.yy.NumValue({value:i}))});if(t){v.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new Uo(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let s=new Set,n=r.left.columnid?r.left:r.right,i=this._findColumn(n);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!G.isEmpty(ZH.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(G.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(G.isEmptyOrZeroLength(r.left.columnid)||G.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(G.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"=":!G.isEmpty(r.right.value)||!G.isEmpty(r.left.value)?s.add(G.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let _=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<_.length;u++)if(_[u].value)s.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,...s])}}}_setAliasesForColumns(){if(G.isEmptyOrZeroLength(this.all_table_attributes)&&G.isEmptyOrZeroLength(this.statement.from)&&G.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((s,n)=>{if(s.columnid==="*"){t.push(n);return}if(s.aggregatorid&&(this.has_aggregator=!0),!s.aggregatorid&&!s.funcid)if(s.as_orig=s.as?s.as:s.columnid,this.statement.joins)if(r[s.as_orig]>=0){let i=r[s.as_orig]+1;s.as=`[${s.as_orig+i}]`,r[s.as_orig]=i}else s.as=`[${s.as_orig}]`,r[s.as_orig]=0;else s.as=`[${s.as_orig}]`;!s.aggregatorid&&s.funcid&&s.args&&(s.as_orig=s.as?s.as:s.toString().replace(/'/g,'"'),s.as=`[${s.as_orig}]`),s.aggregatorid&&s.expression.columnid!=="*"&&(s.as_orig=s.as?s.as:s.expression.tableid?`${s.aggregatorid}(${s.expression.tableid}.${s.expression.columnid})`:`${s.aggregatorid}(${s.expression.columnid})`,s.as=`[${s.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&Si.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(s=>{if(t.columnid_orig&&t.tableid_orig)return(s.table.as===t.tableid_orig||s.table.tableid===t.tableid_orig)&&s.attribute===t.columnid_orig;if(t.tableid)return(s.table.as===t.tableid||s.table.tableid===t.tableid)&&s.attribute===t.columnid;let n=t.columnid_orig?t.columnid_orig:t.columnid;return s.attribute===n});if(G.isEmptyOrZeroLength(r)){let s=this.columns.columns.filter(n=>n.as?t.columnid===n.as:!1);G.isEmptyOrZeroLength(s)||(r=this.all_table_attributes.filter(n=>n.attribute===s[0].columnid&&s[0].tableid&&s[0].tableid===(n.table.as?n.table.as:n.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(G.isEmptyOrZeroLength(this.all_table_attributes)&&!G.isEmptyOrZeroLength(this.columns.columns))return t;if(G.isEmptyOrZeroLength(this.all_table_attributes)&&G.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Me.promise(r)}catch(r){throw v.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),v.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let s=this._findColumn(r);s&&this.fetch_attributes.push(xm(s))})}_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,s,n){let i=this.data[t].__merged_attr_map[s];this.data[t].__merged_data[r].splice(i,1,n)}async _getFetchAttributeValues(){if(G.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(zH)>-1&&this.tables.forEach(n=>{let i={columnid:global.hdb_schema[n.databaseid][n.tableid].hash_attribute,tableid:n.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Si.uniqBy(this.fetch_attributes,n=>[n.table.databaseid,n.table.as?n.table.as:n.table.tableid,n.attribute].join()),r)return await this._simpleSQLQuery();let s=this.fetch_attributes.reduce((n,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return n[o]||(n[o]=[],n[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(n[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),n},{});for(let n of this.fetch_attributes){let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,o=this.data[i].__hash_name,c={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]},_=!1,u=[n.table.databaseid,n.table.tableid,n.attribute].join("/");if(n.attribute===o&&(_=!0),!G.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!G.isEmptyOrZeroLength(this.exact_search_values[u].values))if(_)try{c.hash_values=Array.from(this.exact_search_values[u].values);let l=await ln.getDataByHash(c);for(let E of c.hash_values)E in l&&!this.data[i].__merged_data[E]&&(this.data[i].__merged_data[E]=[...s[i]],this._setMergedHashAttribute(i,E))}catch(l){v.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),v.error(l)}else try{c.search_attribute=n.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async l=>{let E=Object.assign({},c);E.search_value=l;let d=await ln.getDataByValue(E);for(let h in d)this.data[i].__merged_data[h]?this._updateMergedAttribute(i,h,n.attribute,d[h][n.attribute]):(this.data[i].__merged_data[h]=[...s[i]],this._updateMergedAttribute(i,h,n.attribute,d[h][n.attribute]),this._setMergedHashAttribute(i,G.autoCast(h)))}))}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),v.error(l)}else if(!G.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!G.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let l=this.comparator_search_values[u].comparators;for(let E=0,d=l.length;E<d;E++){let h=l[E];c.search_attribute=h.attribute,c.search_value=h.search_value;let m=await ln.getDataByValue(c,h.operation);if(_)for(let R in m)this.data[i].__merged_data[R]||(this.data[i].__merged_data[R]=[...s[i]],this._setMergedHashAttribute(i,G.autoCast(R)));else for(let R in m)this.data[i].__merged_data[R]?this._updateMergedAttribute(i,R,n.attribute,m[R][n.attribute]):(this.data[i].__merged_data[R]=[...s[i]],this._updateMergedAttribute(i,R,n.attribute,m[R][n.attribute]),this._setMergedHashAttribute(i,G.autoCast(R)))}}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),v.error(l)}else try{c.search_attribute=n.attribute,c.search_value="*";let l=await ln.getDataByValue(c);if(_)for(let E in l)this.data[i].__merged_data[E]||(this.data[i].__merged_data[E]=[...s[i]],this._setMergedHashAttribute(i,G.autoCast(E)));else for(let E in l)this.data[i].__merged_data[E]?this._updateMergedAttribute(i,E,n.attribute,l[E][n.attribute]):(this.data[i].__merged_data[E]=[...s[i]],this._updateMergedAttribute(i,E,n.attribute,l[E][n.attribute]),this._setMergedHashAttribute(i,G.autoCast(E)))}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),v.error(l)}}}_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 Me.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(n=>{let i=n.aggregatorid?n.expression:n,o=n.aggregatorid?n.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 s=r[0];if(t.is_func=!!s.funcid,t.is_aggregator=!!s.aggregatorid,s.as)if(s.as&&!t.expression.tableid)t.expression.columnid=s.as,t.expression.columnid_orig=s.as_orig;else{let n=new Me.yy.Column;n.columnid=s.as,n.columnid_orig=s.as_orig,t.expression=n}else{t.initial_select_column=Object.assign(new Me.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 n=t.is_func?new Me.yy.FuncValue:new Me.yy.Column;t.initial_select_column=Object.assign(n,s)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(s=>!s.is_aggregator&&!s.is_ordinal).map(s=>s.is_func?{columnid:s.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:s.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],s=this.statement.from[0],n=[s],i=["? "+(s.as?" AS "+s.as:s.tableid)];t.push(Object.values(this.data[`${s.databaseid_orig}_${s.as?s.as_orig:s.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),n.push(h.table);let m=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(m+=" ON "+h.on.toString()),i.push(m),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__merged_data))});let o=[],c={};n.forEach(h=>{let m=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hash_name,R=h.as?h.as_orig:h.tableid_orig;o.push({key:`'${R}.${m}'`,schema:h.databaseid_orig,table:h.as?h.as_orig:h.tableid_orig,keys:new Set}),r.push(`${h.as?h.as:h.tableid}.\`${m}\` AS "${R}.${m}"`),c[h.as?h.as_orig:h.tableid_orig]=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__merged_attributes});let _=this.statement.where?"WHERE "+this.statement.where:"",u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(h=>{h.is_func?r.push(h.initial_select_column.toString()):h.initial_select_column.tableid?r.push(`${h.initial_select_column.tableid}.${h.initial_select_column.columnid} AS ${h.expression.columnid}`):r.push(`${h.initial_select_column.columnid} AS ${h.expression.columnid}`)}));let l="",E="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",E=this.statement.offset?"OFFSET "+this.statement.offset:"");let d=[];try{let h=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${_} ${u} ${l} ${E}`,m=this._convertColumnsToIndexes(h,n);d=await Me.promise(m,t),t=null}catch(h){throw v.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),v.error(h),new Error("There was a problem processing the data.")}if(d&&d.length>0){for(let h=0,m=d.length;h<m;h++){let R=d[h];o.forEach(w=>{R[w.key]!==null&&R[w.key]!==void 0&&w.keys.add(R[w.key])})}o.forEach(h=>{let m=Object.keys(this.data[`${h.schema}_${h.table}`].__merged_data),R=Si.difference(m,[...h.keys].map(w=>w.toString()));for(let w=0,L=R.length;w<L;w++){let B=R[w];delete this.data[`${h.schema}_${h.table}`].__merged_data[B]}})}return{existing_attributes:c,joined_length:d?d.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let s=[],n=new Uo(this.columns);for(let{node:i}of n)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)&&s.push(o)}}s=Si.uniqBy(s,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(s)}catch(i){v.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),v.error(i)}}async _getData(t){try{let r=t.reduce((s,n)=>{let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`;return s[i]?s[i].columns.push(n.attribute):s[i]={schema:n.table.databaseid,table:n.table.tableid,columns:[n.attribute]},s},{});for(let s in r){let n=r[s],i=this.data[s].__merged_data,o=[];for(let l in i)o.push(i[l][0]);this.data[s].__merged_attributes.push(...n.columns);let c={schema:n.schema,table:n.table,hash_values:o,get_attributes:n.columns},_=await ln.getDataByHash(c),u=n.columns.length;for(let l=0,E=o.length;l<E;l++){let d=o[l],h=_[d];for(let m=0;m<u;m++){let R=n.columns[m],w=h[R]===void 0?null:h[R];this.data[s].__merged_data[d].push(w)}}}}catch(r){throw v.error("Error thrown from getDataByHash function in SQLSearch class method getData."),v.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(n=>{n.as=n.as?n.as:n.table.tableid,t.push(Object.values(this.data[`${n.table.databaseid_orig}_${n.table.as?n.table.as_orig:n.table.tableid_orig}`].__merged_data)),n.table.databaseid="",n.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(n=>{if(n.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,_=o.aggregatorid?o.as_orig:c.as_orig;return n.expression.tableid?c.columnid_orig===n.expression.columnid_orig&&c.tableid_orig===n.expression.tableid_orig:c.columnid_orig===n.expression.columnid_orig||n.expression.columnid_orig===_}).length===0&&(n.expression.columnid=n.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&(this.statement.limit&&delete this.statement.limit,this.statement.offset&&delete this.statement.offset);let s;try{let n=this._buildSQL();v.trace(`Final SQL: ${n}`),s=await Me.promise(n,t),this.has_outer_join&&(s=this._translateUndefinedValues(s)),v.trace(`Final AlaSQL results data included ${s.length} rows`)}catch(n){throw v.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),v.error(n),new Error("There was a problem running the generated sql.")}return s}_translateUndefinedValues(t){try{let r=[];for(let s of t){let n=Object.create(null);Object.keys(s).forEach(i=>{s[i]===void 0?n[i]=null:n[i]=s[i]}),r.push(n)}return r}catch(r){return v.error(XH.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),v.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return this.statement.columns.forEach(s=>{if(s.funcid&&s.as){let n=s.toString().replace(" AS "+s.as,"");r=r.replace(s.toString(),n)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let s=t,n={};r.forEach(i=>{i.databaseid_orig?n[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:n[`${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 _=n[i],u=new RegExp(`${_}.\`${o}\``,"g"),l=`${_}.[${c}]`;s=s.replace(u,l)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let _=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;s=s.replace(_,u)});return s}async _simpleSQLQuery(){let t=this.statement.columns.reduce((s,n)=>(n.as_orig&&n.as_orig!=n.columnid_orig?s[n.columnid_orig]=n.as_orig:s[n.columnid_orig]||(s[n.columnid_orig]=n.columnid_orig),s),{}),r=this.fetch_attributes.reduce((s,n)=>{let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`;return s[i]||(s[i]={}),s[i][t[n.attribute]]=null,s},{});for(let s of this.fetch_attributes){let n=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,i={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]};try{i.search_attribute=s.attribute,i.search_value="*";let o=await ln.getDataByValue(i);for(let c in o)this.data[n].__merged_data[c]||(this.data[n].__merged_data[c]=Object.assign({},r[n])),this.data[n].__merged_data[c][t[s.attribute]]=o[c][s.attribute]}catch(o){v.error("There was an error when processing this SQL operation. Check your logs"),v.error(o)}}return Object.values(Object.values(this.data)[0].__merged_data)}};a(yo,"SQLSearch");$m.exports=yo});var mt=S((YZ,Qm)=>{"use strict";var jH=sS();Qm.exports={searchByConditions:sG,searchByHash:nG,searchByValue:iG,search:aG};var El=Or(),Km=require("util"),eG=Km.callbackify(El.searchByHash),tG=Km.callbackify(El.searchByValue),rG=Ym();async function sG(e){return El.searchByConditions(e)}a(sG,"searchByConditions");function nG(e,t){try{eG(e,(r,s)=>{if(r){t(r);return}t(null,s)})}catch(r){return t(r)}}a(nG,"searchByHash");function iG(e,t){try{e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc),tG(e,(r,s)=>{if(r){t(r);return}t(null,s)})}catch(r){return t(r)}}a(iG,"searchByValue");function aG(e,t){try{let r=new jH(e);r.validate(),new rG(r.statement,r.attributes).search().then(n=>{t(null,n)}).catch(n=>{t(n,null)})}catch(r){return t(r)}}a(aG,"search")});var Vr=S((KZ,Xm)=>{"use strict";var Ti=require("crypto"),Jm="aes-256-cbc",oG=32,cG=16,dl=64,Zm=32,_G=dl+Zm,Wm=new Map;Xm.exports={encrypt:uG,decrypt:lG,createNatsTableStreamName:EG};function uG(e){let t=Ti.randomBytes(oG),r=Ti.randomBytes(cG),s=Ti.createCipheriv(Jm,Buffer.from(t),r),n=s.update(e);n=Buffer.concat([n,s.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=n.toString("hex");return i+o+c}a(uG,"encrypt");function lG(e){let t=e.substr(0,dl),r=e.substr(dl,Zm),s=e.substr(_G,e.length),n=Buffer.from(r,"hex"),i=Buffer.from(s,"hex"),o=Ti.createDecipheriv(Jm,Buffer.from(t,"hex"),n),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(lG,"decrypt");function EG(e,t){let r=`${e}.${t}`,s=Wm.get(r);return s||(s=Ti.createHash("md5").update(`${e}.${t}`).digest("hex"),Wm.set(r,s)),s}a(EG,"createNatsTableStreamName")});var fs=S((QZ,nR)=>{"use strict";var jm=mt(),kr=I(),eR=Ka(),dG=require("lodash"),hG=require("path"),SG=Vr(),hl=b(),{promisify:tR}=require("util"),j=T(),{handleHDBError:Do,hdb_errors:fG}=D(),{HDB_ERROR_MSGS:Mo,HTTP_STATUS_CODES:rR}=fG,TG=Y();TG.initSync();var zm=Z(),mG=te(),mi=tR(jm.searchByValue),RG=tR(jm.searchByHash),En="name",sR="hash_attribute",Sl="schema",AG="schema_table",OG="attribute";nR.exports={describeAll:pG,describeTable:Po,describeSchema:gG};async function pG(e){try{let t=hl.isEmptyOrZeroLength(e),r,s;t||(r=e.hdb_user.role.permission,s=r.super_user||r.cluster_user);let n={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,search_attribute:En,search_value:j.WILDCARD_SEARCH_VALUE,get_attributes:[En]},i=await mi(n);if(hl.isEmptyOrZeroLength(i))return{};let o={},c={};for(let d in i)o[i[d].name]=!0,!t&&!s&&(c[i[d].name]=r[i[d].name].describe);let _={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,search_attribute:j.ID_ATTRIBUTE_STRING,search_value:j.WILDCARD_SEARCH_VALUE,get_attributes:[sR,j.ID_ATTRIBUTE_STRING,En,Sl]},u=await mi(_),l=[];for(let d of u)try{let h;if(t||s)h=await Po({schema:d.schema,table:d.name});else if(r&&r[d.schema].describe&&r[d.schema].tables[d.name].describe){let m=r[d.schema].tables[d.name].attribute_permissions;h=await Po({schema:d.schema,table:d.name},m)}h&&l.push(h)}catch(h){kr.error(h)}let E={};for(let d in l)t||s?(E[l[d].schema]==null&&(E[l[d].schema]={}),E[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(E[l[d].schema]==null&&(E[l[d].schema]={}),E[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s?E[d]={}:c[d]&&(E[d]={});return E}catch(t){return kr.error("Got an error in describeAll"),kr.error(t),Do(new Error,Mo.DESCRIBE_ALL_ERR)}}a(pG,"describeAll");async function Po(e,t){let{schema:r,table:s}=e;r=r.toString(),s=s.toString();let n=t;e.hdb_user&&!e.hdb_user.role.permission.super_user&&(n=e.hdb_user.role.permission[r].tables[s].attribute_permissions);let i={},o=eR.describe_table(e);if(o)throw o;if(r===j.SYSTEM_SCHEMA_NAME)return global.hdb_schema[j.SYSTEM_SCHEMA_NAME][s];let c={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.TABLE_TABLE_HASH_ATTRIBUTE,search_attribute:En,search_value:s,hash_values:[],get_attributes:[j.WILDCARD_SEARCH_VALUE]},_=await mi(c);if(!_||_.length===0)throw Do(new Error,Mo.TABLE_NOT_FOUND(e.schema,e.table),rR.NOT_FOUND);for await(let u of _)try{if(u.schema!==r)continue;if(i=u,!i.hash_attribute)throw Do(new Error,Mo.INVALID_TABLE_ERR(i));let l={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.ATTRIBUTE_TABLE_HASH_ATTRIBUTE,search_attribute:AG,search_value:r+"."+s,get_attributes:[OG]},E=await mi(l);E=dG.uniqBy(E,d=>d.attribute),n&&n.length>0&&(E=NG(n)),i.attributes=E,i.clustering_stream_name=SG.createNatsTableStreamName(u.schema,u.name);try{let d=hG.join(mG.getBaseSchemaPath(),i.schema.toString()),h=await zm.openEnvironment(d,i.name),m=zm.statDBI(h,i.hash_attribute);i.record_count=m.entryCount}catch(d){kr.warn(`unable to stat table dbi due to ${d}`)}}catch(l){kr.error(`There was an error getting attributes for table '${u.name}'`),kr.error(l)}return i}a(Po,"descTable");function NG(e){return e.reduce((t,r)=>(r.describe&&t.push({attribute:r.attribute_name}),t),[])}a(NG,"getAttrsByPerms");async function gG(e){let t=eR.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 s=e.schema.toString(),n={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.TABLE_TABLE_HASH_ATTRIBUTE,search_attribute:Sl,search_value:s,hash_values:[],get_attributes:[sR,j.ID_ATTRIBUTE_STRING,En,Sl]},i=await mi(n);if(i&&i.length<1){let o={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.SCHEMA_TABLE_HASH_ATTRIBUTE,hash_values:[s],get_attributes:[En]},c=await RG(o);if(c&&c.length<1)throw Do(new Error,Mo.SCHEMA_NOT_FOUND(e.schema),rR.NOT_FOUND);return{}}else{let o={};return await Promise.all(i.map(async c=>{try{let _;if(r&&r.tables[c.name]&&(_=r.tables[c.name]),hl.isEmpty(_)||_.describe){let u=await Po({schema:e.schema,table:c.name},_?_.attribute_permissions:null);u&&(o[u.name]=u)}}catch(_){kr.error(`Error describing schema table '${e.schema}.${c}'`),kr.error(_)}})),o}}a(gG,"describeSchema")});var xr=S((ZZ,_R)=>{var WZ=require("async"),dn=is(),JZ=I(),{callbackify:oR,promisify:IG}=require("util");_R.exports={setSchemaDataToGlobal:iR,getTableSchema:wG,getSystemSchema:UG,setSchemaDataToGlobalAsync:IG(iR)};var cR=fs(),bG=oR(cR.describeAll),CG=oR(cR.describeTable);function iR(e){bG(null,(t,r)=>{if(t){e(t);return}r.system||(r.system=dn),global.hdb_schema=r,e(null,null)})}a(iR,"setSchemaDataToGlobal");function aR(e,t){return e==="system"?dn[t]:global.hdb_schema[e][t]}a(aR,"returnSchema");function wG(e,t,r){!global.hdb_schema||!global.hdb_schema[e]||!global.hdb_schema[e][t]?LG(e,t,s=>{if(s)return r(s);if(!global.hdb_schema[e])return r(`schema ${e} does not exist`);if(!global.hdb_schema[e]||!global.hdb_schema[e][t])return r(`table ${e}.${t} does not exist`);r(null,aR(e,t))}):r(null,aR(e,t))}a(wG,"getTableSchema");function LG(e,t,r){let s={table:t,schema:e};if(e==="system"){global.hdb_schema?global.hdb_schema.system=dn:global.hdb_schema={system:dn},r();return}CG(s,(n,i)=>{if(n){r(n);return}if(!i.schema&&!i.name){r();return}global.hdb_schema||(global.hdb_schema={system:dn}),global.hdb_schema[e]||(global.hdb_schema[e]={}),global.hdb_schema[e][t]=i,r()})}a(LG,"setTableDataToGlobal");function UG(){return dn}a(UG,"getSystemSchema")});var ER=S((XZ,lR)=>{"use strict";var fl=Z(),yG=I(),uR=Ke().LMDB_ERRORS_ENUM;lR.exports=DG;async function DG(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 fl.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==uR.ENV_REQUIRED)throw c}}break;case"drop_table":let s=`${e.schema}.${e.table}`,n=`txn.${s}`;try{await fl.closeEnvironment(global.lmdb_map[s]),await fl.closeEnvironment(global.lmdb_map[n])}catch(i){if(i.message!==uR.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){yG.error(t)}}a(DG,"cleanLMDBMap")});var Ut=S((zZ,SR)=>{"use strict";var vo=vu(),Lt=b(),MG=require("util"),Ho=Or(),PG=xr(),Tl=I(),{handleHDBError:$r,hdb_errors:BG}=D(),{HTTP_STATUS_CODES:Ts}=BG,vG=MG.promisify(PG.getTableSchema),HG="updated",dR="inserted",hR="upserted";SR.exports={insert:qG,update:FG,upsert:VG,validation:GG,flush:kG};async function GG(e){if(Lt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Lt.isEmptyOrZeroLength(e.schema))throw new Error("invalid schema specified.");if(Lt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await vG(e.schema,e.table),r=vo(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let s=t.hash_attribute,n=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Lt.isEmptyOrZeroLength(c[s]))throw Tl.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(!Lt.isEmptyOrZeroLength(c[s])&&(c[s]==="null"||c[s]==="undefined"))throw Tl.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[s]}" is not a valid hash attribute value`);!Lt.isEmpty(c[s])&&c[s]!==""&&n.has(Lt.autoCast(c[s]))&&(c.skip=!0),n.add(Lt.autoCast(c[s]));for(let _ in c)i[_]=1}),i[s]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(i)}}a(GG,"validation");async function qG(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=vo(e);if(t)throw $r(new Error,t.message,Ts.BAD_REQUEST);let r=Lt.checkSchemaTableExist(e.schema,e.table);if(r)throw $r(new Error,r,Ts.BAD_REQUEST);try{let s=await Ho.createRecords(e);return Bo(dR,s.written_hashes,e,s.skipped_hashes,s.new_attributes,s.txn_time)}catch(s){throw s}}a(qG,"insertData");async function FG(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=vo(e);if(t)throw $r(new Error,t.message,Ts.BAD_REQUEST);let r=Lt.checkSchemaTableExist(e.schema,e.table);if(r)throw $r(new Error,r,Ts.BAD_REQUEST);try{let s=await Ho.updateRecords(e);return Lt.isEmpty(s.existing_rows)?Bo(HG,s.written_hashes,e,s.skipped_hashes,s.new_attributes,s.txn_time):Bo(s.update_action,[],e,s.hashes,void 0,s.txn_time)}catch(s){throw s}}a(FG,"updateData");async function VG(e){if(e.operation!=="upsert")throw $r(new Error,"invalid operation, must be upsert",Ts.INTERNAL_SERVER_ERROR);let t=vo(e);if(t)throw $r(new Error,t.message,Ts.BAD_REQUEST);let r=Lt.checkSchemaTableExist(e.schema,e.table);if(r)throw $r(new Error,r,Ts.BAD_REQUEST);try{let s=await Ho.upsertRecords(e);return Bo(hR,s.written_hashes,e,[],s.new_attributes,s.txn_time)}catch(s){let n=`There was an error during an upsert op: ${s}`;throw $r(s,null,null,Tl.ERR,n)}}a(VG,"upsertData");function Bo(e,t,r,s,n,i){let o={message:`${e} ${t.length} of ${t.length+s.length} records`,new_attributes:n,txn_time:i};return e===dR?(o.inserted_hashes=t,o.skipped_hashes=s,o):e===hR?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=s,o)}a(Bo,"returnObject");function kG(e){return Ho.flush(e.schema,e.table)}a(kG,"flush")});var Rl=S((jZ,mR)=>{var xG=de(),ml=require("joi"),{hdb_schema_table:fR}=Tr(),TR={schema:fR,table:fR},$G={date:ml.date().iso().required()},YG={timestamp:ml.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};mR.exports=function(e,t){let r=t==="timestamp"?{...TR,...YG}:{...TR,...$G},s=ml.object(r);return xG.validateBySchema(e,s)}});var pR=S((eX,OR)=>{var KG=de(),RR=require("joi"),{hdb_schema_table:AR}=Tr(),QG=RR.object({schema:AR,table:AR,hash_values:RR.array().required()});OR.exports=function(e){return KG.validateBySchema(e,QG)}});var gR=S((tX,NR)=>{"use strict";var Go=class{constructor(t,r,s,n,i){this.operation=t,this.schema=r,this.table=s,this.hash_attribute=n,this.records=i}};a(Go,"InsertObject");var qo=class{constructor(t,r,s,n,i,o){this.schema=t,this.table=r,this.search_attribute=s,this.hash_attribute=n,this.get_attributes=i,this.search_value=o}};a(qo,"NoSQLSeachObject");var Fo=class{constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};a(Fo,"DeleteResponseObject");NR.exports={InsertObject:Go,NoSQLSeachObject:qo,DeleteResponseObject:Fo}});var Rs=S((rX,LR)=>{"use strict";var bR=Rl(),WG=pR(),Vo=b(),IR=require("moment"),CR=I(),{promisify:JG,callbackify:ZG}=require("util"),ms=T(),XG=xr(),Al=JG(XG.getTableSchema),Ol=Or(),{DeleteResponseObject:zG}=gR(),{handleHDBError:Yr,hdb_errors:jG}=D(),{HDB_ERROR_MSGS:ko,HTTP_STATUS_CODES:Kr}=jG,eq="records successfully deleted",tq=ZG(wR);LR.exports={delete:tq,deleteRecord:wR,deleteFilesBefore:rq,deleteAuditLogsBefore:sq};async function rq(e){let t=bR(e,"date");if(t)throw Yr(t,t.message,Kr.BAD_REQUEST,void 0,void 0,!0);if(!IR(e.date,IR.ISO_8601).isValid())throw Yr(new Error,ko.INVALID_DATE,Kr.BAD_REQUEST,ms.LOG_LEVELS.ERROR,ko.INVALID_DATE,!0);let s=Vo.checkSchemaTableExist(e.schema,e.table);if(s)throw Yr(new Error,s,Kr.NOT_FOUND,ms.LOG_LEVELS.ERROR,s,!0);try{let n=await Ol.deleteRecordsBefore(e);if(await Al(e.schema,e.table),CR.info(`Finished deleting files before ${e.date}`),n&&n.message)return n.message}catch(n){throw n}}a(rq,"deleteFilesBefore");async function sq(e){let t=bR(e,"timestamp");if(t)throw Yr(t,t.message,Kr.BAD_REQUEST,void 0,void 0,!0);if(isNaN(e.timestamp))throw Yr(new Error,ko.INVALID_VALUE("Timestamp"),Kr.BAD_REQUEST,ms.LOG_LEVELS.ERROR,ko.INVALID_VALUE("Timestamp"),!0);let r=Vo.checkSchemaTableExist(e.schema,e.table);if(r)throw Yr(new Error,r,Kr.NOT_FOUND,ms.LOG_LEVELS.ERROR,r,!0);try{let s=await Ol.deleteAuditLogsBefore(e);return await Al(e.schema,e.table),CR.info(`Finished deleting audit logs before ${e.timestamp}`),s}catch(s){throw s}}a(sq,"deleteAuditLogsBefore");async function wR(e){let t=WG(e);if(t)throw Yr(t,t.message,Kr.BAD_REQUEST,void 0,void 0,!0);let r=Vo.checkSchemaTableExist(e.schema,e.table);if(r)throw Yr(new Error,r,Kr.NOT_FOUND,ms.LOG_LEVELS.ERROR,r,!0);try{await Al(e.schema,e.table);let s=await Ol.deleteRecords(e);return Vo.isEmptyOrZeroLength(s.message)&&(s.message=`${s.deleted_hashes.length} of ${e.hash_values.length} ${eq}`),s}catch(s){if(s.message===ms.SEARCH_NOT_FOUND_MESSAGE){let n=new zG;return n.message=ms.SEARCH_NOT_FOUND_MESSAGE,n.skipped_hashes=e.hash_values.length,n.deleted_hashes=0,n}throw s}}a(wR,"deleteRecord")});var xo=S((sX,DR)=>{var nq=require("crypto"),UR=9;function iq(e){let t=oq(UR),r=yR(e+t);return t+r}a(iq,"createHash");function aq(e,t){let r=e.substr(0,UR),s=r+yR(t+r);return e===s}a(aq,"validateHash");function oq(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,s="";for(let n=0;n<e;n++){let i=Math.floor(Math.random()*r);s+=t[i]}return s}a(oq,"generateSalt");function yR(e){return nq.createHash("md5").update(e).digest("hex")}a(yR,"md5");DR.exports={hash:iq,validate:aq}});var PR=S((nX,MR)=>{var pl=de(),Je={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 cq(e){return Je.password.presence=!0,Je.username.presence=!0,Je.role.presence=!0,Je.active.presence=!0,pl.validateObject(e,Je)}a(cq,"addUserValidation");function _q(e){return Je.password.presence=!1,Je.username.presence=!0,Je.role.presence=!1,Je.active.presence=!1,pl.validateObject(e,Je)}a(_q,"alterUserValidation");function uq(e){return Je.password.presence=!1,Je.username.presence=!0,Je.role.presence=!1,Je.active.presence=!1,pl.validateObject(e,Je)}a(uq,"dropUserValidation");MR.exports={addUserValidation:cq,alterUserValidation:_q,dropUserValidation:uq}});var _e=S((aX,vR)=>{"use strict";var{platform:iX}=require("os"),lq="nats-server.zip",Nl="nats-server",Eq=process.platform==="win32"?`${Nl}.exe`:Nl,gl="HDB",dq=/^[^\s.,*>]+$/,BR="__request__",hq=a(e=>`${e}.${BR}`,"REQUEST_SUBJECT"),Sq={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},fq={HUB:"hub.pid",LEAF:"leaf.pid"},Tq={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},mq={stream_name:"__HARPERDB_WORK_QUEUE__",durable_name:"HDB_WORK_QUEUE",deliver_group:gl,deliver_subject:"__HDB__.WORKQUEUE"},Rq={stream_name:"__HARPERDB_SCHEMA_QUEUE__",durable_name:"HDB_SCHEMA_QUEUE",deliver_group:gl,deliver_subject:"HDB.SCHEMAQUEUE"},Aq={stream_name:"__HARPERDB_USER_QUEUE__",durable_name:"HDB_USER_QUEUE",deliver_group:gl,deliver_subject:"HDB.USERQUEUE"},Oq={SUCCESS:"success",ERROR:"error"},pq={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},Nq={TXN:"txn",MSGID:"msgid"};vR.exports={NATS_SERVER_ZIP:lq,NATS_SERVER_NAME:Nl,NATS_BINARY_NAME:Eq,PID_FILES:fq,NATS_CONFIG_FILES:Sq,SERVER_SUFFIX:Tq,WORK_QUEUE_CONSUMER_NAMES:mq,SCHEMA_QUEUE_CONSUMER_NAMES:Rq,USER_QUEUE_CONSUMER_NAMES:Aq,NATS_TERM_CONSTRAINTS_RX:dq,REQUEST_SUFFIX:BR,UPDATE_REMOTE_RESPONSE_STATUSES:Oq,CLUSTER_STATUS_STATUSES:pq,REQUEST_SUBJECT:hq,SUBJECT_PREFIXES:Nq}});var GR=S((oX,HR)=>{"use strict";var Qr=T(),Ri=class{constructor(t=0,r=Qr.STORAGE_TYPES_ENUM.LMDB,s=Qr.LICENSE_VALUES.API_CALL_DEFAULT,n=Qr.RAM_ALLOCATION_ENUM.DEFAULT,i=Qr.LICENSE_VALUES.VERSION_DEFAULT,o){this.exp_date=t,this.storage_type=r,this.api_call=s,this.ram_allocation=n,this.version=i,this.fingerprint=o}};a(Ri,"BaseLicense");var $o=class extends Ri{constructor(t=0,r=Qr.STORAGE_TYPES_ENUM.LMDB,s=Qr.LICENSE_VALUES.API_CALL_DEFAULT,n=Qr.RAM_ALLOCATION_ENUM.DEFAULT,i=Qr.LICENSE_VALUES.VERSION_DEFAULT,o,c=!1){super(t,r,s,n,i,o),this.enterprise=c}};a($o,"ExtendedLicense");HR.exports={BaseLicense:Ri,ExtendedLicense:$o}});var Ai=S((cX,$R)=>{"use strict";var Sn=require("fs-extra"),qR=xo(),FR=require("crypto"),gq=require("moment"),Iq=require("uuid").v4,Ze=I(),bl=require("path"),bq=b(),Rt=T(),Cq=GR().ExtendedLicense,hn="invalid license key format",wq="061183",Lq="mofi25",Uq="aes-256-cbc",yq=16,Dq=32,VR=Y();VR.initSync();var Il;$R.exports={validateLicense:kR,generateFingerPrint:Pq,licenseSearch:xR,getLicense:Hq};function Cl(){return bl.join(VR.getHdbBasePath(),Rt.LICENSE_KEY_DIR_NAME,Rt.LICENSE_FILE_NAME)}a(Cl,"getLicenseDirPath");function Mq(){let e=Cl();return bl.join(e,Rt.LICENSE_FILE_NAME)}a(Mq,"getLicenseFilePath");function wl(){let e=Cl();return bl.join(e,Rt.REG_KEY_FILE_NAME)}a(wl,"getFingerPrintFilePath");async function Pq(){let e=wl();try{return await Sn.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Bq();throw Ze.error(`Error writing fingerprint file to ${e}`),Ze.error(t),new Error("There was an error generating the fingerprint")}}a(Pq,"generateFingerPrint");async function Bq(){let e=Iq(),t=qR.hash(e),r=wl();try{await Sn.mkdirp(Cl()),await Sn.writeFile(r,t)}catch(s){if(s.code==="EEXIST")return t;throw Ze.error(`Error writing fingerprint file to ${r}`),Ze.error(s),new Error("There was an error generating the fingerprint")}return t}a(Bq,"writeFingerprint");function kR(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,storage_type:Rt.STORAGE_TYPES_ENUM.LMDB,api_call:Rt.LICENSE_VALUES.API_CALL_DEFAULT,ram_allocation:Rt.RAM_ALLOCATION_ENUM.DEFAULT,version:Rt.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Ze.error("empty license key passed to validate."),r;let s=wl(),n=!1;try{n=Sn.statSync(s)}catch(i){Ze.error(i)}if(n){let i;try{i=Sn.readFileSync(s,"utf8")}catch{Ze.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(Lq),c=o[1];c=Buffer.concat([Buffer.from(c)],yq);let _=Buffer.concat([Buffer.from(i)],Dq),u=FR.createDecipheriv(Uq,_,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=u.update(o[0],"hex","utf8"),l.trim(),l+=u.final("utf8")}catch{let h=vq(o[0],i);if(h)l=h;else throw r.valid_license=!1,r.valid_machine=!1,console.error(hn),Ze.error(hn),new Error(hn)}let E;if(isNaN(l))try{E=JSON.parse(l),r.api_call=E.api_call,r.version=E.version,r.storage_type=E.storage_type,r.exp_date=E.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),E.ram_allocation&&(r.ram_allocation=E.ram_allocation)}catch{throw console.error(hn),Ze.error(hn),new Error(hn)}else r.exp_date=l;r.exp_date<gq().valueOf()&&(r.valid_date=!1),qR.validate(o[1],`${wq}${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||Ze.error("Invalid licence"),r}a(kR,"validateLicense");function vq(e,t){try{let r=FR.createDecipher("aes192",t),s=r.update(e,"hex","utf8");return s.trim(),s+=r.final("utf8"),s}catch{Ze.warn("Check old license failed")}}a(vq,"checkOldLicense");function xR(){let e=new Cq;e.api_call=0;let t=[];try{t=Sn.readFileSync(Mq(),"utf-8").split(Rt.NEW_LINE)}catch(r){r.code==="ENOENT"?Ze.info("no license file found"):Ze.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let s=t[r];try{if(bq.isEmptyOrZeroLength(s))continue;let n=JSON.parse(s),i=kR(n.license_key,n.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.api_call+=i.api_call,e.ram_allocation=i.ram_allocation,e.storage_type=i.storage_type,e.enterprise=!0)}catch(n){Ze.error("There was an error parsing the license string."),Ze.error(n),e.api_call=Rt.LICENSE_VALUES.API_CALL_DEFAULT,e.ram_allocation=Rt.RAM_ALLOCATION_ENUM.DEFAULT,e.storage_type=Rt.STORAGE_TYPES_ENUM.LMDB,e.enterprise=!1}}return e.api_call===0&&(e.api_call=Rt.LICENSE_VALUES.API_CALL_DEFAULT),Il=e,e}a(xR,"licenseSearch");async function Hq(){return Il||await xR(),Il}a(Hq,"getLicense")});var Wr=S((_X,nA)=>{"use strict";var WR="username is required",JR="nothing to update, must supply active, role or password to update",ZR="password cannot be an empty string",XR="If role is specified, it cannot be empty.",zR="active must be true or false";nA.exports={addUser:Yq,alterUser:Kq,dropUser:Wq,userInfo:Jq,listUsers:Ko,listUsersExternal:Zq,setUsersToGlobal:Oi,findAndValidateUser:jq,getClusterUser:eF,USERNAME_REQUIRED:WR,ALTERUSER_NOTHING_TO_UPDATE:JR,EMPTY_PASSWORD:ZR,EMPTY_ROLE:XR,ACTIVE_BOOLEAN:zR};var jR=Ut(),Gq=Rs(),Ul=xo(),eA=PR(),tA=mt(),yl=js(),be=b(),rA=require("validate.js"),H=I(),{promisify:Dl}=require("util"),Ml=Vr(),As=T(),YR=_e(),qq=Sr(),Pl=Y(),Fq=Ai(),Vq=is(),{handleHDBError:rr,hdb_errors:kq}=D(),{HTTP_STATUS_CODES:sr,AUTHENTICATION_ERROR_MSGS:Ll,HDB_ERROR_MSGS:fn}=kq,{UserEventMsg:Bl}=Gr(),KR=require("lodash"),sA={username:!0,active:!0,role:!0,password:!0},QR=new Map,Yo=Dl(tA.searchByValue),xq=Dl(tA.searchByHash),$q=Dl(Gq.delete);async function Yq(e){let t=rA.cleanAttributes(e,sA),r=eA.addUserValidation(t);if(r)throw rr(new Error,r.message,sr.BAD_REQUEST,void 0,void 0,!0);let s={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},n;try{n=await Yo(s)}catch(u){throw H.error("There was an error searching for a role in add user"),H.error(u),u}if(!n||n.length<1)throw rr(new Error,fn.ROLE_NAME_NOT_FOUND(t.role),sr.NOT_FOUND,void 0,void 0,!0);if(n.length>1)throw rr(new Error,fn.DUP_ROLES_FOUND(t.role),sr.CONFLICT,void 0,void 0,!0);n[0].permission.cluster_user===!0&&(t.hash=Ml.encrypt(t.password)),t.password=Ul.hash(t.password),t.role=n[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await jR.insert(i)}catch(u){throw H.error("There was an error searching for a user."),H.error(u),u}H.debug(o);try{await Oi()}catch(u){throw H.error("Got an error setting users to global"),H.error(u),u}if(o.skipped_hashes.length===1)throw rr(new Error,fn.USER_ALREADY_EXISTS(t.username),sr.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);c.role=n[0];let _={user:null};return _.user=c,be.sendTransactionToSocketCluster(As.INTERNAL_SC_CHANNELS.ADD_USER,_,Pl.get(As.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),yl.signalUserChange(new Bl(process.pid)),`${c.username} successfully added`}a(Yq,"addUser");async function Kq(e){let t=rA.cleanAttributes(e,sA);if(be.isEmptyOrZeroLength(t.username))throw new Error(WR);if(be.isEmptyOrZeroLength(t.password)&&be.isEmptyOrZeroLength(t.role)&&be.isEmptyOrZeroLength(t.active))throw new Error(JR);if(!be.isEmpty(t.password)&&be.isEmptyOrZeroLength(t.password.trim()))throw new Error(ZR);if(!be.isEmpty(t.active)&&!be.isBoolean(t.active))throw new Error(zR);let r=Qq(t.username);if(!be.isEmpty(t.password)&&!be.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=Ml.encrypt(t.password)),t.password=Ul.hash(t.password)),t.role==="")throw new Error(XR);if(t.role){let o={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},c;try{c=await Yo(o)}catch(_){throw H.error("Got an error searching for a role."),H.error(_),_}if(!c||c.length===0){let _=fn.ALTER_USER_ROLE_NOT_FOUND(t.role);throw H.error(_),rr(new Error,_,sr.NOT_FOUND,void 0,void 0,!0)}if(c.length>1){let _=fn.ALTER_USER_DUP_ROLES(t.role);throw H.error(_),rr(new Error,_,sr.CONFLICT,void 0,void 0,!0)}t.role=c[0].id}let s={operation:"update",schema:"system",table:"hdb_user",records:[t]},n;try{n=await jR.update(s)}catch(o){throw H.error("Error during update."),H.error(o),o}try{await Oi()}catch(o){throw H.error("Got an error setting users to global"),H.error(o),o}let i={user:null};return i.user=t,be.sendTransactionToSocketCluster(As.INTERNAL_SC_CHANNELS.ALTER_USER,i,Pl.get(As.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),yl.signalUserChange(new Bl(process.pid)),n}a(Kq,"alterUser");function Qq(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(Qq,"isClusterUser");async function Wq(e){try{let t=eA.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(be.isEmpty(global.hdb_users.get(e.username)))throw rr(new Error,fn.USER_NOT_EXIST(e.username),sr.NOT_FOUND,void 0,void 0,!0);let s;try{s=await $q(r)}catch(i){throw H.error("Got an error deleting a user."),H.error(i),i}H.debug(s);try{await Oi()}catch(i){throw H.error("Got an error setting users to global."),H.error(i),i}let n={user:null};return n.user=e,be.sendTransactionToSocketCluster(As.INTERNAL_SC_CHANNELS.DROP_USER,n,Pl.get(As.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),yl.signalUserChange(new Bl(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(Wq,"dropUser");async function Jq(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=e.hdb_user;let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},s;try{s=await xq(r)}catch(n){throw H.error("Got an error searching for a role."),H.error(n),n}t.role=s[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw H.error(r),r}return t}a(Jq,"userInfo");async function Zq(){let e;try{e=await Ko()}catch(t){throw H.error("Got an error listing users."),H.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(Zq,"listUsersExternal");async function Ko(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=KR.cloneDeep(await Yo(e))}catch(r){throw H.error("Got an error searching for roles."),H.error(r),r}if(!be.isEmptyOrZeroLength(t)){let r={};for(let o in t)r[t[o].id]=t[o];let s={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},n;try{n=KR.cloneDeep(await Yo(s))}catch(o){throw H.error("Got an error searching for users."),H.error(o),o}let i=new Map;for(let o in n){let c=n[o];c.role=r[n[o].role],Xq(c.role),i.set(c.username,c)}return(await Fq.getLicense()).enterprise?i:zq(i)}}catch(e){throw H.error("got an error listing users"),H.error(e),be.errorizeMessage(e)}return null}a(Ko,"listUsers");function Xq(e){try{if(!e){H.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(Vq)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){H.error("Got an error trying to set system permissions."),H.error(t)}}a(Xq,"appendSystemTablesToRole");function zq(e){try{if(H.info("No enterprise license found. System is limited to 1 clustering role and 1 user role"),!e)return new Map;let t=Object.create(null),r=new Map;e.forEach((n,i)=>{n.role.permission.cluster_user===void 0||n.role.permission.cluster_user===!1?n.role.permission.super_user===!0&&(t[n.role.id]||(t[n.role.id]=new Map),t[n.role.id].set(i,n)):r.set(i,n)});let s={role:void 0,count:0};return Object.keys(t).forEach(n=>{let i=t[n];i.size>=s.count&&(s.role=n,s.count=i.size)}),s.role===void 0?(H.error("No roles found with active users. This is bad."),new Map):(r=new Map([...r,...t[s.role]]),r)}catch(t){return H.error("error filtering users."),H.error(t),new Map}}a(zq,"nonEnterpriseFilter");async function Oi(){try{let e=await Ko();global.hdb_users=e}catch(e){throw H.error(e),e}}a(Oi,"setUsersToGlobal");async function jq(e,t,r=!0){global.hdb_users||await Oi();let s=global.hdb_users.get(e);if(!s)throw rr(new Error,Ll.GENERIC_AUTH_FAIL,sr.UNAUTHORIZED,void 0,void 0,!0);if(s&&!s.active)throw rr(new Error,Ll.USER_INACTIVE,sr.UNAUTHORIZED,void 0,void 0,!0);let n={active:s.active,username:s.username};if(s.refresh_token&&(n.refresh_token=s.refresh_token),s.role&&(n.role=s.role),r===!0){if(QR.get(t)===s.password)return n;if(Ul.validate(s.password,t))QR.set(t,s.password);else throw rr(new Error,Ll.GENERIC_AUTH_FAIL,sr.UNAUTHORIZED,void 0,void 0,!0)}return n}a(jq,"findAndValidateUser");async function eF(){let e=await Ko(),t=qq.getConfigFromFile(As.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!be.isEmpty(r))return r.decrypt_hash=Ml.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+YR.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+YR.SERVER_SUFFIX.ADMIN,r}a(eF,"getClusterUser")});var _A=S((uX,cA)=>{"use strict";var Os=I(),Qo=T(),tF=ER(),iA=xr(),rF=fs(),sF=Wr(),{validateEvent:oA}=Gr(),nF={[Qo.IPC_EVENT_TYPES.SCHEMA]:iF,[Qo.IPC_EVENT_TYPES.USER]:oF};async function iF(e){let t=oA(e);if(t){Os.error(t);return}Os.trace(`IPC schemaHandler ${Qo.HDB_IPC_CLIENT_PREFIX}${process.pid} received schema event:`,e),await tF(e.message),await aF(e.message)}a(iF,"schemaHandler");async function aF(e){try{if(global.hdb_schema!==void 0&&typeof global.hdb_schema=="object"&&e.operation!==void 0)switch(e.operation){case"drop_schema":delete global.hdb_schema[e.schema];break;case"drop_table":global.hdb_schema[e.schema]!==void 0&&delete global.hdb_schema[e.schema][e.table];break;case"create_schema":global.hdb_schema[e.schema]===void 0&&(global.hdb_schema[e.schema]={});break;case"create_table":case"create_attribute":global.hdb_schema[e.schema]===void 0&&(global.hdb_schema[e.schema]={}),global.hdb_schema[e.schema][e.table]=await rF.describeTable({schema:e.schema,table:e.table});break;default:iA.setSchemaDataToGlobal(aA);break}else iA.setSchemaDataToGlobal(aA)}catch(t){Os.error(t)}}a(aF,"syncSchemaMetadata");function aA(e){e&&Os.error(e)}a(aA,"handleErrorCallback");async function oF(e){try{let t=oA(e);if(t){Os.error(t);return}Os.trace(`IPC userHandler ${Qo.HDB_IPC_CLIENT_PREFIX}${process.pid} received user event:`,e),await sF.setUsersToGlobal()}catch(t){Os.error(t)}}a(oF,"userHandler");cA.exports=nF});var Wo=S((lX,uA)=>{"use strict";var cF=Or();uA.exports={writeTransaction:_F};function _F(e,t,r){return cF.writeTransaction(e,t,r)}a(_F,"writeTransaction")});var vl=S((EX,uF)=>{uF.exports={name:"harperdb",version:"4.0.1",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:{node:">=14.0.0","preferred-node":"18.13.0","go-lang":"1.19.3","nats-server":"2.9.8"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"See License in ./license/Community+Edition+and+Evaluation+End+User+License+Agreement.pdf",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ data_layer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ data_layer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",test:"rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license --storage_type=lmdb && npm run cover:upgrade && npm run cover:nats && npm run cover:cfserver && npm run cover:lmdbbridge && npm run cover:lmdbutility && npm run cover:hdbserver && npm run cover:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license --storage_type=lmdb","cover:main":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","cover:lmdbbridge":"cd bin/ && nyc --no-clean --reporter=lcovonly --retries 3 ../node_modules/mocha/bin/_mocha '../unitTests/data_layer/harperBridge/lmdbBridge/**/*.js' --parallel --config '../unitTests/.mocharc.json'","cover:lmdbutility":"cd bin/ && nyc --no-clean --reporter=lcovonly --retries 3 ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --config '../unitTests/.mocharc.json'","cover:hdbserver":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --config '../unitTests/.mocharc.json'","cover:cfserver":"npm run submodules && cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","cover:nats":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","cover:upgrade":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.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/data_layer/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:{"@fastify/accepts-serializer":"5.1.0","@fastify/autoload":"5.4.0","@fastify/compress":"6.1.1","@fastify/cors":"8.1.0","@fastify/static":"6.5.0","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"1.7.4",async:"3.2.3","aws-sdk":"2.1096.0",chalk:"4.1.2","cli-progress":"3.10.0",clone:"2.1.2",esbuild:"^0.14.49","fast-glob":"3.2.11",fastify:"4.8.1","fastify-plugin":"4.2.1","fill-range":"7.0.1","fs-extra":"10.0.1","human-readable-ids":"1.0.4",inquirer:"8.2.2","is-number":"7.0.0",joi:"17.6.0",json2csv:"5.0.7",jsonata:"1.8.6",jsonwebtoken:"8.5.1",lmdb:"2.7.3",lodash:"4.17.21",mathjs:"10.4.0",microtime:"3.1.1",minimist:"1.2.6",mkcert:"1.5.0",moment:"2.29.4",msgpackr:"1.7.0",nats:"2.9.2",needle:"3.1.0","node-ipc":"9.1.4","node-stream-zip":"1.15.0","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.3.0",papaparse:"5.3.2",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.3.1",pm2:"5.2.0",prompt:"1.2.2","properties-reader":"2.2.0","recursive-iterator":"3.3.0",semver:"7.3.5","stream-chain":"2.2.5","stream-json":"1.7.4",systeminformation:"5.12.4","tar-fs":"2.1.1","truncate-utf8-bytes":"1.0.2",ulidx:"0.3.0",uuid:"9.0.0","validate.js":"0.11.1",yaml:"1.10.2"},devDependencies:{axios:"0.27.2",chai:"4.3.4","chai-integer":"0.1.0",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1","hook-std":"2.0.0","intercept-stdout":"0.1.2",mocha:"8.3.2","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",newman:"5.2.3","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"1.21.0","newman-reporter-teamcity":"0.1.11","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.3.2",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},"newman-reporter-html":{newman:"5.2.3"}}}});var ot=S((NX,UA)=>{"use strict";var nr=Y();nr.initSync();var lF=require("fs-extra"),EF=require("semver"),bi=require("path"),{monotonicFactory:dF}=require("ulidx"),hF=dF(),EA=require("util"),dA=require("child_process"),SF=EA.promisify(dA.exec),fF=dA.spawn,ee=_e(),se=T(),kl=b(),pr=I(),Jo=Vr(),TF=Wo(),pi=Sr(),{encode:ql,decode:hA}=require("msgpackr"),{isEmpty:ps}=kl,SA=Wr(),dX=ds(),mF=mt(),hX=EA.promisify(mF.searchByHash),{connect:RF,StorageType:fA,RetentionPolicy:TA,AckPolicy:mA,DeliverPolicy:Fl,NatsConnection:SX,JetStreamManager:fX,JetStreamClient:TX,StringCodec:mX,JSONCodec:AF,createInbox:xl,StreamSource:RX,headers:OF,toJsMsg:pF,nuid:AX,JetStreamOptions:OX,ErrorCode:lA,nanos:pX}=require("nats"),{PACKAGE_ROOT:NF}=T(),gF=vl(),RA=AF(),IF="clustering",bF=gF.engines[ee.NATS_SERVER_NAME],CF=bi.join(NF,"dependencies"),Vl=bi.join(CF,`${process.platform}-${process.arch}`,ee.NATS_BINARY_NAME),Hl,Gl,Ni,gi,Ii,Qt;UA.exports={runCommand:AA,checkNATSServerInstalled:wF,createConnection:$l,getConnection:Zo,getJetStreamManager:Tn,getJetStream:OA,getNATSReferences:yt,getServerList:UF,createLocalStream:Yl,listStreams:pA,deleteLocalStream:yF,getServerConfig:Ci,listRemoteStreams:DF,viewStream:MF,publishToStream:PF,createWorkQueueStream:BF,addSourceToWorkStream:NA,request:vF,removeSourceFromWorkStream:IA,reloadNATS:Kl,reloadNATSHub:HF,reloadNATSLeaf:GF,extractServerName:gA,requestErrorHandler:qF,updateWorkStream:FF,createLocalTableStream:CA,createTableStreams:VF,purgeTableStream:wA,purgeSchemaTableStreams:kF,getStreamInfo:xF,updateNodeNameLocalStreams:$F,closeConnection:LF};async function AA(e,t=void 0){let{stdout:r,stderr:s}=await SF(e,{cwd:t});if(s)throw new Error(s.replace(`
|
|
4
|
+
`).slice(1)){n=n.trim();let[i]=n.split(" ",1),o=n.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,s])=>({pid:Number.parseInt(r,10),name:ww.basename(s.comm),cmd:s.args,ppid:Number.parseInt(s.ppid,10),uid:Number.parseInt(s.uid,10),cpu:Number.parseFloat(s["%cpu"]),memory:Number.parseFloat(s["%mem"])}))}a(Dw,"findPs")});var Ye=S((G1,Th)=>{"use strict";var Mw="__dbis__",Pw="__environment_name__",Bw="__dbi_defintion__",vw={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"},Hw=["__createdtime__","__updatedtime__"],Gw="\uFFFF",fh={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},qw=Object.values(fh);Th.exports={INTERNAL_DBIS_NAME:Mw,DBI_DEFINITION_NAME:Bw,SEARCH_TYPES:vw,TIMESTAMP_NAMES:Hw,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:Pw,TRANSACTIONS_DBI_NAMES_ENUM:fh,TRANSACTIONS_DBIS:qw,OVERFLOW_MARKER:Gw}});var Ke=S((q1,bh)=>{"use strict";var mh=T(),Rh=Ye(),Ah={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},Oh=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),ph={500:Oh("There was an error processing your request."),400:"Invalid request"},Fw=ph[Ah.INTERNAL_SERVER_ERROR],Vw={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.`},kw={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},xw={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"},$w={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_ARRAY:"ids must be an array",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 ${Rh.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${Rh.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"},Yw={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${mh.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 ${mh.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"},Nh={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"},Kw={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid schema 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' schema, tables and records are used internally by HarperDB and cannot be updated or removed."},Qw={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 schema metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view schema.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`},Ww={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=>`Schema '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`Schema '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in schema '${e}'`,SCHEMA_REQUIRED_ERR:"schema is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},Jw={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},Zw={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`},gh={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.`},Ih={INVALID_IPC_DATA_TYPE:"Invalid IPC event data type, must be an object",MISSING_TYPE:"IPC event missing 'type'",MISSING_MSG:"IPC event missing 'message'",MISSING_ORIGIN:"IPC event message missing 'originator' property",INVALID_EVENT:e=>`IPC server received invalid event type: ${e}`},Xw={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 customFunctions enabled to true in hdb/harperdb-config.yaml file."},zw={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},jw={...Nh,...xw,...Vw,...Kw,...Qw,...Ww,...Jw,...Zw,...Yw,...gh,...Ih,...Xw,...zw,...kw};bh.exports={CHECK_LOGS_WRAPPER:Oh,HDB_ERROR_MSGS:jw,DEFAULT_ERROR_MSGS:ph,DEFAULT_ERROR_RESP:Fw,HTTP_STATUS_CODES:Ah,LMDB_ERRORS_ENUM:$w,AUTHENTICATION_ERROR_MSGS:Nh,VALIDATION_ERROR_MSGS:gh,IPC_ERRORS:Ih}});var D=S((F1,Lh)=>{"use strict";var Qs=Ke(),eL=I(),tL=T(),$n=class extends Error{constructor(t,r,s,n,i){super(),Error.captureStackTrace(this,Ch),this.http_resp_code=s||Qs.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Qs.DEFAULT_ERROR_MSGS[s]?Qs.DEFAULT_ERROR_MSGS[s]:Qs.DEFAULT_ERROR_MSGS[Qs.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,typeof this.message!="string"&&(this.stack=t.stack),i&&eL[n](i)}};a($n,"HdbError");function Ch(e,t,r,s=tL.LOG_LEVELS.ERROR,n=null,i=!1){if(wh(e))return e;let o=new $n(e,t,r,s,n);return i&&delete o.stack,o}a(Ch,"handleHDBError");function wh(e){return e.__proto__.constructor.name===$n.name}a(wh,"isHDBError");Lh.exports={isHDBError:wh,handleHDBError:Ch,hdb_errors:Qs}});var b=S((k1,$h)=>{"use strict";var au=require("path"),rL=require("fs-extra"),Ie=I(),Uh=require("fs-extra"),sL=require("truncate-utf8-bytes"),Yn=require("os"),nL=require("net"),iL=require("recursive-iterator"),Ue=T(),Bh=Sh(),yh=require("papaparse"),ma=require("moment"),{inspect:aL}=require("util"),Dh=require("is-number"),V1=require("lodash"),{hdb_errors:Ra}=D(),vh=require("util").promisify(setTimeout),oL=100,cL=5,_L="",uL=4,Mh=255,Ph={true:!0,false:!1,undefined:null,null:null,NaN:NaN};$h.exports={isEmpty:St,isEmptyOrZeroLength:Xt,arrayHasEmptyValues:dL,arrayHasEmptyOrZeroLengthValues:hL,buildFolderPath:SL,isBoolean:Hh,errorizeMessage:lL,stripFileExtension:TL,autoCast:mL,autoCastJSONDeep:ou,removeDir:AL,compareVersions:OL,isCompatibleDataVersion:pL,escapeRawValue:qh,unescapeValue:NL,stringifyProps:gL,valueConverter:IL,timeoutPromise:CL,isClusterOperation:LL,getClusterUser:DL,sendTransactionToSocketCluster:UL,checkGlobalSchemaTable:yL,getHomeDir:Fh,getPropsFilePath:bL,promisifyPapaParse:ML,removeBOM:Vh,createEventPromise:PL,checkProcessRunning:BL,checkSchemaTableExist:vL,checkSchemaExists:kh,checkTableExists:xh,getStartOfTomorrowInSeconds:HL,getLimitKey:GL,isObject:fL,isNotEmptyAndHasValue:EL,autoCasterIsNumberCheck:Gh,backtickASTSchemaItems:qL,isPortTaken:wL,stopProcess:FL,createForkArgs:VL,autoCastBoolean:kL,async_set_timeout:vh,getTableHashAttribute:xL,doesSchemaExist:$L,doesTableExist:YL,stringifyObj:KL,ms_to_time:QL,PACKAGE_ROOT:Ue.PACKAGE_ROOT};function lL(e){return e instanceof Error?e:new Error(e)}a(lL,"errorizeMessage");function St(e){return e==null}a(St,"isEmpty");function EL(e){return!St(e)&&(e||e===0||e===""||Hh(e))}a(EL,"isNotEmptyAndHasValue");function Xt(e){return St(e)||e.length===0||e.size===0}a(Xt,"isEmptyOrZeroLength");function dL(e){if(St(e))return!0;for(let t=0;t<e.length;t++)if(St(e[t]))return!0;return!1}a(dL,"arrayHasEmptyValues");function hL(e){if(Xt(e))return!0;for(let t=0;t<e.length;t++)if(Xt(e[t]))return!0;return!1}a(hL,"arrayHasEmptyOrZeroLengthValues");function SL(...e){try{return e.join(au.sep)}catch{console.error(e)}}a(SL,"buildFolderPath");function Hh(e){return St(e)?!1:e===!0||e===!1}a(Hh,"isBoolean");function fL(e){return St(e)?!1:typeof e=="object"}a(fL,"isObject");function TL(e){return Xt(e)?_L:e.slice(0,-uL)}a(TL,"stripFileExtension");function mL(e){return St(e)||e===""||typeof e!="string"?e:Ph[e]!==void 0?Ph[e]:Gh(e)===!0?Number(e):e}a(mL,"autoCast");function RL(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(RL,"autoCastJSON");function ou(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let s=e[t],n=ou(s);n!==s&&(e[t]=n)}else for(let t in e){let r=e[t],s=ou(r);s!==r&&(e[t]=s)}return e}else return RL(e)}a(ou,"autoCastJSONDeep");function Gh(e){if(e.startsWith("0.")&&Dh(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&Dh(e))}a(Gh,"autoCasterIsNumberCheck");async function AL(e){if(Xt(e))throw new Error(`Directory path: ${e} does not exist`);try{await Uh.emptyDir(e),await Uh.remove(e)}catch(t){throw Ie.error(`Error removing files in ${e} -- ${t}`),t}}a(AL,"removeDir");function OL(e,t){if(Xt(e)){Ie.info("Invalid current version sent as parameter.");return}if(Xt(t)){Ie.info("Invalid upgrade version sent as parameter.");return}let r,s=/(\.0+)+$/,n=e.version?e.version:e,i=t.version?t.version:t,o=n.replace(s,"").split("."),c=i.replace(s,"").split("."),_=Math.min(o.length,c.length);for(let u=0;u<_;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(OL,"compareVersions");function pL(e,t,r=!1){let s=e.toString().split("."),n=t.toString().split(".");return s[0]===n[0]&&(!r||s[1]===n[1])}a(pL,"isCompatibleDataVersion");function qh(e){if(St(e))return e;let t=String(e);return t==="."?Ue.UNICODE_PERIOD:t===".."?Ue.UNICODE_PERIOD+Ue.UNICODE_PERIOD:t.replace(Ue.FORWARD_SLASH_REGEX,Ue.UNICODE_FORWARD_SLASH)}a(qh,"escapeRawValue");function NL(e){if(St(e))return e;let t=String(e);return t===Ue.UNICODE_PERIOD?".":t===Ue.UNICODE_PERIOD+Ue.UNICODE_PERIOD?"..":String(e).replace(Ue.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(NL,"unescapeValue");function gL(e,t){if(St(e))return Ie.info("Properties object is null"),"";let r="";return e.each(function(s,n){try{if(t&&t[s]){let i=t[s];for(let o of i)r+=";"+o+Yn.EOL}!Xt(s)&&s[0]===";"?r+=" "+s+n+Yn.EOL:Xt(s)||(r+=s+"="+n+Yn.EOL)}catch{Ie.error(`Found bad property during upgrade with key ${s} and value: ${n}`)}}),r}a(gL,"stringifyProps");function IL(e){let t;try{t=typeof e=="object"?JSON.stringify(e):e}catch(n){Ie.error(n),t=e}let r=String(qh(t)),s=Buffer.byteLength(r)>Mh?sL(r,Mh)+"/blob":r;return{value:t,value_stripped:r,value_path:s}}a(IL,"valueConverter");function Fh(){let e;try{e=Yn.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(Fh,"getHomeDir");function bL(){let e=au.join(Fh(),Ue.HDB_HOME_DIR_NAME,Ue.BOOT_PROPS_FILE_NAME);return rL.existsSync(e)||(e=au.join(__dirname,"../","hdb_boot_properties.file")),e}a(bL,"getPropsFilePath");function CL(e,t){let r,s;return s=new Promise(function(n){r=setTimeout(function(){n(t)},e)}),{promise:s,cancel:function(){clearTimeout(r)}}}a(CL,"timeoutPromise");async function wL(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let s=nL.createServer().once("error",n=>{n.code==="EADDRINUSE"?t(!0):r(n)}).once("listening",()=>s.once("close",()=>t(!1)).close()).listen(e)})}a(wL,"isPortTaken");function LL(e){try{return Ue.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Ie.error(`Error checking operation against cluster ops ${t}`)}return!1}a(LL,"isClusterOperation");function UL(e,t,r){if(global.hdb_socket_client!==void 0){Ie.trace(`Sending transaction to channel: ${e}`);let{hdb_user:s,hdb_auth_header:n,...i}=t;i.__originator||(i.__originator={}),i.__transacted=!0,r&&(i.__originator[r]=Ue.ORIGINATOR_SET_VALUE),global.hdb_socket_client.publish(e,i)}}a(UL,"sendTransactionToSocketCluster");function yL(e,t){if(!global.hdb_schema[e])return Ra.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!global.hdb_schema[e]||!global.hdb_schema[e][t])return Ra.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(yL,"checkGlobalSchemaTable");function DL(e,t){if(St(t)){Ie.warn("No CLUSTERING_USER defined, clustering disabled");return}if(St(e)||Xt(e)){Ie.warn("No users to search.");return}let r;try{let s=e.get(t);s&&s.role.permission.cluster_user===!0&&s.active===!0&&(r=s)}catch(s){Ie.error(`unable to find cluster_user due to: ${s.message}`);return}if(r===void 0){Ie.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(DL,"getClusterUser");function ML(){yh.parsePromise=function(e,t){return new Promise(function(r,s){yh.parse(e,{header:!0,transformHeader:Vh,chunk:t.bind(null,s),skipEmptyLines:!0,dynamicTyping:!0,error:s,complete:r})})}}a(ML,"promisifyPapaParse");function Vh(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(Vh,"removeBOM");function PL(e,t,r){return new Promise(s=>{t.once(e,n=>{let i=r;Ie.info(`Got cluster status event response: ${aL(n)}`);try{i.cancel()}catch{Ie.error("Error trying to cancel timeout.")}s(n)})})}a(PL,"createEventPromise");async function BL(e){let t=!0,r=0;do await vh(oL*r++),(await Bh.findPs(e)).length>0&&(t=!1);while(t&&r<cL);if(t)throw new Error(`process ${e} was not started`)}a(BL,"checkProcessRunning");function vL(e,t){let r=kh(e);if(r)return r;let s=xh(e,t);if(s)return s}a(vL,"checkSchemaTableExist");function kh(e){if(!global.hdb_schema[e])return Ra.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(kh,"checkSchemaExists");function xh(e,t){if(!global.hdb_schema[e][t])return Ra.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(xh,"checkTableExists");function HL(){let e=ma().utc().add(1,Ue.MOMENT_DAYS_TAG).startOf(Ue.MOMENT_DAYS_TAG).unix(),t=ma().utc().unix();return e-t}a(HL,"getStartOfTomorrowInSeconds");function GL(){return ma().utc().format("DD-MM-YYYY")}a(GL,"getLimitKey");function qL(e){try{let t=new iL(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){Ie.error("Got an error back ticking items."),Ie.error(t)}}a(qL,"backtickASTSchemaItems");async function FL(e){let t=Yn.userInfo();(await Bh.findPs(e)).forEach(s=>{(t.uid==0||s.uid==t.uid)&&(process.kill(s.pid),Ie.trace(`Following process was killed by stopProcess: ${s.cmd}`))})}a(FL,"stopProcess");function VL(e){return[e]}a(VL,"createForkArgs");function kL(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(kL,"autoCastBoolean");function xL(e,t){return global.hdb_schema?.[e]?.[t]?.hash_attribute}a(xL,"getTableHashAttribute");function $L(e){return global?.hdb_schema?.[e]!==void 0}a($L,"doesSchemaExist");function YL(e,t){return global?.hdb_schema?.[e]?.[t]!==void 0}a(YL,"doesTableExist");function KL(e){try{return JSON.stringify(e)}catch{return e}}a(KL,"stringifyObj");function QL(e){let t=ma.duration(e),r=t.seconds()>0?t.seconds()+"s":"",s=t.minutes()>0?t.minutes()+"m ":"",n=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+n+s+r}a(QL,"ms_to_time")});var sS=S(($1,rS)=>{"use strict";var cu=require("recursive-iterator"),WL=require("alasql"),_u=require("clone"),Yh=b(),{handleHDBError:Kh,hdb_errors:JL}=D(),{HDB_ERROR_MSGS:Qh,HTTP_STATUS_CODES:Wh}=JL,ZL=["DISTINCT_ARRAY"],Jh=Symbol("validateTables"),uu=Symbol("validateTable"),x1=Symbol("getAllColumns"),Zh=Symbol("validateAllColumns"),Aa=Symbol("findColumn"),Xh=Symbol("validateOrderBy"),Kn=Symbol("validateSegment"),lu=Symbol("validateColumn"),zh=Symbol("setColumnsForTable"),jh=Symbol("checkColumnsForAsterisk"),eS=Symbol("validateGroupBy"),tS=Symbol("hasColumns"),Oa=class{constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[Jh](),this[jh](),this[Zh]()}[Jh](){if(this[tS]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[uu](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[uu](t.table)})}}[tS](){let t=!1,r=new cu(this.statement);for(let{node:s,path:n}of r)if(s&&s.columnid){t=!0;break}return t}[uu](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;if(!global.hdb_schema[t.databaseid])throw Kh(new Error,Qh.SCHEMA_NOT_FOUND(t.databaseid),Wh.NOT_FOUND);if(!global.hdb_schema[t.databaseid][t.tableid])throw Kh(new Error,Qh.TABLE_NOT_FOUND(t.databaseid,t.tableid),Wh.NOT_FOUND);global.hdb_schema[t.databaseid][t.tableid].attributes.forEach(s=>{let n=_u(s);n.table=_u(t),this.attributes.push(n)})}[Aa](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)}[jh](){let t=new cu(this.statement.columns);for(let{node:r,path:s}of t)r&&r.columnid==="*"&&s.indexOf("expression")<0&&this[zh](r.tableid)}[zh](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&this.statement.columns.push(new WL.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Zh](){this[Kn](this.statement.columns,!1),this[Kn](this.statement.joins,!1),this[Kn](this.statement.where,!1),this[eS](this.statement.group,!1),this[Kn](this.statement.order,!0)}[Kn](t,r){if(!t)return;let s=new cu(t),n=[];for(let{node:i,path:o}of s)!Yh.isEmpty(i)&&!Yh.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Xh](i):n.push(this[lu](i)));return n}[eS](t){if(!t)return;let r=[];if(this.statement.columns.forEach(s=>{if(!(s.funcid&&ZL.indexOf(s.funcid.toUpperCase())>=0)){if(!s.aggregatorid&&!s.columnid){let n=_u(s);delete n.as,r.push(n)}else if(s.columnid){let n=this[Aa](s)[0];n&&r.push(n)}}}),this.statement.group.forEach(s=>{let n=null;if(!s.columnid)r.forEach((i,o)=>{if(i.toString()===s.toString()){n=i,r.splice(o,1);return}});else{let i=this[Aa](s);if(!i||i.length===0)throw`unknown column '${s.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${s.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){n=o,r.splice(c,1);return}})}if(!n)throw`group by column '${s.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`}[Xh](t){let r=this.statement.columns.filter(s=>s.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[lu](t)}[lu](t){let r=this[Aa](t),s=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${s}`;if(r.length>1)throw`ambiguous column reference ${s}`;return r[0]}};a(Oa,"SelectValidator");rS.exports=Oa});var Eu=S((Y1,nS)=>{"use strict";var pa=class{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")}};a(pa,"BridgeMethods");nS.exports=pa});var _s=S((W1,cS)=>{"use strict";var iS=Ke().LMDB_ERRORS_ENUM,K1=require("lmdb"),XL=Ye(),Q1=require("buffer").Buffer,zL=require("microtime"),{OVERFLOW_MARKER:aS,MAX_SEARCH_KEY_LENGTH:Na}=XL,oS=["number","string","symbol","boolean","bigint"];function jL(e){if(!e)throw new Error(iS.ENV_REQUIRED);if(e.constructor.name!=="LMDBStore")throw new Error(iS.INVALID_ENVIRONMENT)}a(jL,"validateEnv");function eU(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(eU,"stringifyData");function tU(e){return e instanceof Date?e.valueOf():e}a(tU,"convertKeyValueToWrite");function rU(e){if(e==null)return;if(oS.includes(typeof e))return e.length>Na?[e.slice(0,Na)+aS]:[e];let t;if(Array.isArray(e)){t=[];for(let r=0,s=e.length;r<s;r++){let n=e[r];oS.includes(typeof n)&&(n.length>Na?t.push(n.slice(0,Na)+aS):t.push(n))}}return t}a(rU,"getIndexedValues");function sU(){let e=zL.now().toString(),t=e.length-3;return Number(e.slice(0,t)+"."+e.slice(t))}a(sU,"getMicroTime");cS.exports={validateEnv:jL,stringifyData:eU,convertKeyValueToWrite:tU,getMicroTime:sU,getIndexedValues:rU}});var uS=S((J1,_S)=>{"use strict";var ga=class{constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};a(ga,"DBIDefinition");_S.exports=ga});var ES=S((Z1,lS)=>{"use strict";var Ia=class{constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache={validated:!0},this.randomAccessStructure=!0,this.freezeData=!0)}};a(Ia,"OpenDBIObject");lS.exports=Ia});var hS=S((X1,dS)=>{"use strict";var ba=class{constructor(t,r,s,n,i=!1,o=!1,c=void 0){this.path=t,this.mapSize=r,this.maxDbs=s,this.maxReaders=n,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=i,this.trackMetrics=!0,this.noSync=o,c!==void 0&&(this.overlappingSync=c)}};a(ba,"OpenEnvironmentObject");dS.exports=ba});var fS=S((z1,SS)=>{"use strict";var nU={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,String.fromCharCode(13,10)),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,String.fromCharCode(13,10))},iU="certificate.pem",aU="privateKey.pem",oU="ca.pem";SS.exports={CERTIFICATE_VALUES:nU,CERTIFICATE_PEM_NAME:iU,PRIVATEKEY_PEM_NAME:aU,CA_PEM_NAME:oU}});var de=S((j1,TS)=>{"use strict";var st=require("validate.js");st.validators.type=function(e,t,r,s){return e===null||typeof e>"u"||st.validators.type.checks[t](e)?null:` must be a '${t}' value`};st.validators.type.checks={Object:function(e){return st.isObject(e)&&!st.isArray(e)},Array:st.isArray,Integer:st.isInteger,Number:st.isNumber,String:st.isString,Date:st.isDate,Boolean:function(e){return typeof e=="boolean"}};st.validators.hasValidFileExt=function(e,t){return!st.isString(e)||e===""||t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`};TS.exports={validateObject:cU,validateObjectAsync:_U,validateBySchema:uU};function cU(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=st(e,t,{format:"flat"});return r?new Error(r):null}a(cU,"validateObject");async function _U(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await st.async(e,t,{format:"flat"})}catch(r){let s=r.join(",");return new Error(s)}return null}a(_U,"validateObjectAsync");function uU(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(uU,"validateBySchema")});var hu=S((eJ,RS)=>{"use strict";var lU=require("fs-extra"),F=require("joi"),EU=require("os"),{boolean:ye,string:dr,number:zt,array:du}=F.types(),qt=require("path"),dU=I(),Ca=b(),hr=fS(),hU=de(),Er="keys",SU=hr.CERTIFICATE_PEM_NAME,fU=hr.PRIVATEKEY_PEM_NAME,TU=hr.CA_PEM_NAME,mU=hr.CERTIFICATE_PEM_NAME,RU=hr.PRIVATEKEY_PEM_NAME,AU=hr.CA_PEM_NAME,OU=hr.CERTIFICATE_PEM_NAME,pU=hr.PRIVATEKEY_PEM_NAME,NU=hr.CA_PEM_NAME,gU="log",IU="custom_functions",bU="Invalid logging.rotation.maxSize unit. Available units are G, M or K",CU="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",wU="rootPath config parameter is undefined",LU="clustering.enabled config parameter is undefined",Pr=zt.min(0).required(),wa=du.items({host:dr.required(),port:Pr}).empty(null),nt;RS.exports={configValidator:UU,routesValidator:BU,route_constraints:wa};function UU(e){if(nt=e.rootPath,Ca.isEmpty(nt))throw wU;let t=ye.required(),r=F.valid("production","development").required(),s=zt.min(1).max(1e3).empty(null).default(PU),n=dr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(mS),i=F.custom(DU).messages({"any.custom":"{:#label} {:#error}"}).empty(null).default(mS),o=dr.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),c=e.clustering?.enabled;if(Ca.isEmpty(c))throw LU;let _;return c===!0?_=F.object({enabled:t,hubServer:F.object({cluster:F.object({name:F.required().empty(null),network:F.object({port:Pr,routes:wa}).required()}).required(),leafNodes:F.object({network:F.object({port:Pr}).required()}).required(),network:F.object({port:Pr}).required()}).required(),leafServer:F.object({network:F.object({port:Pr,routes:wa}).required()}).required(),nodeName:o,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:ye.required()}),user:F.string().required()}).required():_=F.object({enabled:t,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:ye.required()})}).required(),F.object({clustering:_,customFunctions:F.object({enabled:t,network:F.object({cors:ye.required(),corsAccessList:du.required(),headersTimeout:zt.min(1).required(),https:ye.required(),keepAliveTimeout:zt.min(1).required(),port:Pr,timeout:zt.min(1).required()}),nodeEnv:r,root:n,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i})}).required(),ipc:F.object({network:F.object({port:Pr})}).required(),localStudio:F.object({enabled:t}).required(),logging:F.object({file:ye.required(),level:F.valid("notify","fatal","error","warn","info","debug","trace"),rotation:F.object({compress:ye.required(),dateFormat:dr.required(),maxSize:dr.custom(MU).required(),retain:zt.min(0).required(),rotate:ye.required(),rotateInterval:dr.required(),rotateModule:ye.required(),timezone:dr.required(),workerInterval:zt.min(1).required()}).required(),root:n,stdStreams:ye.required(),auditLog:ye.required()}).required(),operationsApi:F.object({authentication:F.object({operationTokenTimeout:F.required(),refreshTokenTimeout:F.required()}).required(),foreground:ye.required(),network:F.object({cors:ye.required(),corsAccessList:du.required(),headersTimeout:zt.min(1).required(),https:ye.required(),keepAliveTimeout:zt.min(1).required(),port:Pr,timeout:zt.min(1).required()}).required(),nodeEnv:r,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i})}).required(),rootPath:dr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),http:F.object({threads:s}).required(),storage:F.object({writeAsync:ye.required(),overlappingSync:ye.optional()}).required()}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(UU,"configValidator");function yU(e){return lU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(yU,"doesPathExist");function DU(e,t){F.assert(e,dr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+\.pem+$/).messages({"string.pattern.base":"must be a valid directory path and specify a .pem file"}));let r=yU(e);if(r)return t.message(r)}a(DU,"validatePemFile");function MU(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(bU);let s=e.slice(0,-1);if(isNaN(parseInt(s)))return t.message(CU)}a(MU,"validateRotationMaxSize");function PU(e,t){let r=t.state.path.join("."),s=EU.cpus().length,n=s-1;return n<=2&&(n=2),dU.info(`Detected ${s} cores on this machine, defaulting ${r} to ${n}`),n}a(PU,"setDefaultThreads");function mS(e,t){if(!Ca.isEmpty(t.original))return t.original;let r=t.state.path.join(".");if(Ca.isEmpty(nt))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"customFunctions.root":return qt.join(nt,IU);case"logging.root":return qt.join(nt,gU);case"operationsApi.tls.certificate":return qt.join(nt,Er,SU);case"operationsApi.tls.privateKey":return qt.join(nt,Er,fU);case"operationsApi.tls.certificateAuthority":return qt.join(nt,Er,TU);case"customFunctions.tls.certificate":return qt.join(nt,Er,mU);case"customFunctions.tls.privateKey":return qt.join(nt,Er,RU);case"customFunctions.tls.certificateAuthority":return qt.join(nt,Er,AU);case"clustering.tls.certificate":return qt.join(nt,Er,OU);case"clustering.tls.privateKey":return qt.join(nt,Er,pU);case"clustering.tls.certificateAuthority":return qt.join(nt,Er,NU);default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(mS,"setDefaultRoot");function BU(e){let t=F.object({routes:wa});return hU.validateBySchema({routes:e},t)}a(BU,"routesValidator")});var Sr=S((tJ,bS)=>{"use strict";var re=T(),It=b(),Qe=I(),{configValidator:vU,routesValidator:AS}=hu(),Ft=require("fs-extra"),HU=require("yaml"),Ws=require("path"),GU=require("is-number"),ya=require("properties-reader"),qU=require("lodash"),{handleHDBError:FU}=D(),{HTTP_STATUS_CODES:VU,HDB_ERROR_MSGS:La}=Ke(),{PACKAGE_ROOT:kU}=T(),xU="Unable to get config value because config is uninitialized",$U="Config successfully initialized",YU="Error backing up config file",KU="Empty parameter sent to getConfigValue",OS=Ws.join(kU,"config","yaml",re.HDB_DEFAULT_CONFIG_FILE),QU="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",Ua,it;bS.exports={createConfigFile:WU,getDefaultConfig:JU,getConfigValue:pS,initConfig:NS,flattenConfig:us,updateConfigValue:gS,updateConfigObject:ZU,getConfiguration:XU,setConfiguration:zU,readConfigFile:Tu,getClusteringRoutes:jU,initOldConfig:IS,getConfigFromFile:ey};function WU(e){let t=Js(OS);Ua=us(t.toJSON());for(let i in e){let o=re.CONFIG_PARAM_MAP[i.toLowerCase()];if(o!==void 0){let c=o.split("_"),_=Su(o,e[i]);try{t.setIn([...c],_)}catch(u){Qe.error(u)}}}fu(t);let r=t.toJSON();it=us(r);let s=t.getIn(["rootPath"]),n=Ws.join(s,re.HDB_CONFIG_FILE);Ft.createFileSync(n),Ft.writeFileSync(n,String(t)),Qe.trace(`Config file written to ${n}`)}a(WU,"createConfigFile");function JU(e){if(Ua===void 0){let r=Js(OS);Ua=us(r.toJSON())}let t=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(t!==void 0)return Ua[t.toLowerCase()]}a(JU,"getDefaultConfig");function pS(e){if(It.isEmpty(e)){Qe.error(KU);return}if(it===void 0){Qe.trace(xU);return}let t=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(t!==void 0)return it[t.toLowerCase()]}a(pS,"getConfigValue");function NS(e=!1){if(it===void 0||e){let t=It.getPropsFilePath();try{Ft.accessSync(t,Ft.constants.F_OK|Ft.constants.R_OK)}catch(o){throw Qe.error(o),new Error(`HarperDB properties file at path ${t} does not exist`)}let s=ya(t).get(re.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),n;if(s.includes("config/settings.js"))try{IS(s);return}catch(o){if(o.code!==re.NODE_ERROR_CODES.ENOENT)throw o}try{n=Js(s)}catch(o){if(o.code===re.NODE_ERROR_CODES.ENOENT){Qe.trace(`HarperDB config file not found at ${s}.
|
|
5
|
+
This can occur during early stages of install where the config file has not yet been created`);return}else throw Qe.error(o),new Error(`Error reading HarperDB config file at ${s}`)}fu(n);let i=n.toJSON();it=us(i),Qe.trace($U)}}a(NS,"initConfig");function fu(e){let t=e.toJSON(),r=vU(t);if(r.error)throw La.CONFIG_VALIDATION(r.error.message);e.setIn(["http","threads"],r.value.http.threads),e.setIn(["customFunctions","root"],r.value.customFunctions.root),e.setIn(["logging","root"],r.value.logging.root),e.setIn(["operationsApi","tls","certificate"],r.value.operationsApi.tls.certificate),e.setIn(["operationsApi","tls","privateKey"],r.value.operationsApi.tls.privateKey),e.setIn(["operationsApi","tls","certificateAuthority"],r.value.operationsApi.tls.certificateAuthority),e.setIn(["customFunctions","tls","certificate"],r.value.customFunctions.tls.certificate),e.setIn(["customFunctions","tls","privateKey"],r.value.customFunctions.tls.privateKey),e.setIn(["customFunctions","tls","certificateAuthority"],r.value.customFunctions.tls.certificateAuthority),e.setIn(["clustering","tls","certificate"],r.value.clustering.tls.certificate),e.setIn(["clustering","tls","privateKey"],r.value.clustering.tls.privateKey),e.setIn(["clustering","tls","certificateAuthority"],r.value.clustering.tls.certificateAuthority)}a(fu,"validateConfig");function ZU(e,t){it===void 0&&(it={});let r=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(r===void 0){Qe.trace(`Unable to update config object because config param '${e}' does not exist`);return}it[r.toLowerCase()]=t}a(ZU,"updateConfigObject");function gS(e,t,r=void 0,s=!1,n=!1){it===void 0&&NS();let i=pS(re.CONFIG_PARAM_MAP.hdb_root),o=Ws.join(i,re.HDB_CONFIG_FILE),c=Js(o);if(r===void 0){let l=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(l===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let E=l.split("_"),d=Su(l,t);c.setIn([...E],d)}else for(let l in r){let E=re.CONFIG_PARAM_MAP[l.toLowerCase()];if(E!==void 0){let d=E.split("_"),h=Su(E,r[l]);try{c.setIn([...d],h)}catch(m){Qe.error(m)}}}fu(c);let _=c.getIn(["rootPath"]),u=Ws.join(_,re.HDB_CONFIG_FILE);if(s===!0)try{let l=Ws.join(_,"backup",`${re.HDB_CONFIG_FILE}.bak`);Ft.copySync(o,l),Qe.trace(`Config file: ${o} backed up to: ${l}`)}catch(l){Qe.error(YU),Qe.error(l)}Ft.writeFileSync(u,String(c)),n&&(it=us(c.toJSON())),Qe.trace(`Config parameter: ${e} updated with value: ${t}`)}a(gS,"updateConfigValue");function us(e){let t={};for(let r in e)if(!!e.hasOwnProperty(r))if(typeof e[r]=="object"&&e[r]!==null&&!Array.isArray(e[r])){let s=us(e[r]);for(let n in s)!s.hasOwnProperty(n)||(t[r.toLowerCase()+"_"+n]=s[n])}else t[r.toLowerCase()]=e[r];return t}a(us,"flattenConfig");function Su(e,t){if(e===re.CONFIG_PARAMS.CLUSTERING_NODENAME||e===re.CONFIG_PARAMS.CLUSTERING_USER){if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(GU(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||It.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 It.autoCast(t)}a(Su,"castConfigValue");function XU(){let e=It.getPropsFilePath(),r=ya(e).get(re.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);return Js(r).toJSON()}a(XU,"getConfiguration");async function zU(e){let{operation:t,hdb_user:r,hdb_auth_header:s,...n}=e;try{return gS(void 0,void 0,n,!0),QU}catch(i){throw typeof i=="string"||i instanceof String?FU(i,i,VU.BAD_REQUEST,void 0,void 0,!0):i}}a(zU,"setConfiguration");function Tu(){let e=It.getPropsFilePath();try{Ft.accessSync(e,Ft.constants.F_OK|Ft.constants.R_OK)}catch(n){throw Qe.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let r=ya(e).get(re.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);return Js(r).toJSON()}a(Tu,"readConfigFile");function Js(e){return HU.parseDocument(Ft.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Js,"parseYamlDoc");function jU(){let e=Tu(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=It.isEmptyOrZeroLength(t)?[]:t;let r=AS(t);if(r)throw La.CONFIG_VALIDATION(r.message);let s=e?.clustering?.leafServer?.network?.routes;s=It.isEmptyOrZeroLength(s)?[]:s;let n=AS(s);if(n)throw La.CONFIG_VALIDATION(n.message);if(!It.isEmptyOrZeroLength(s)&&!It.isEmptyOrZeroLength(t)){let i=t.filter(o=>s.some(c=>c.host===o.host&&c.port===o.port));if(!It.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw La.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:s}}a(jU,"getClusteringRoutes");function IS(e){let t=ya(e);it={};for(let r in re.CONFIG_PARAM_MAP){let s=t.get(r.toUpperCase());if(It.isEmpty(s)||typeof s=="string"&&s.trim().length===0)continue;let n=re.CONFIG_PARAM_MAP[r].toLowerCase();n===re.CONFIG_PARAMS.LOGGING_ROOT?it[n]=Ws.dirname(s):it[n]=s}return it}a(IS,"initOldConfig");function ey(e){let t=Tu();return qU.get(t,e.replaceAll("_","."))}a(ey,"getConfigFromFile")});var Y=S((rJ,wS)=>{"use strict";var mu=require("fs-extra"),jt=require("path"),ty=require("os"),ry=require("properties-reader"),Qn=I(),Zs=b(),M=T(),Da=Sr(),sy="Error initializing environment manager",Ma="BOOT_PROPS_FILE_PATH",CS=!1,ny={[M.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},fr={};wS.exports={BOOT_PROPS_FILE_PATH:Ma,getHdbBasePath:iy,setHdbBasePath:ay,get:oy,initSync:_y,setProperty:$,initTestEnvironment:uy};function iy(){return fr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(iy,"getHdbBasePath");function ay(e){fr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(ay,"setHdbBasePath");function oy(e){let t=Da.getConfigValue(e);return t===void 0?fr[e]:t}a(oy,"get");function $(e,t){ny[e]&&(fr[e]=t),Da.updateConfigObject(e,t)}a($,"setProperty");function cy(){let e;try{e=Zs.getPropsFilePath(),mu.accessSync(e,mu.constants.F_OK|mu.constants.R_OK),CS=!0;let t=ry(e);return fr[M.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(M.HDB_SETTINGS_NAMES.INSTALL_USER),fr[M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),fr[Ma]=e,!0}catch{return Qn.trace(`Environment manager found no properties file at ${e}`),!1}}a(cy,"doesPropFileExist");function _y(e=!1){try{(CS||cy())&&(Da.initConfig(e),fr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=Da.getConfigValue(M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Qn.error(sy),Qn.error(t),console.error(t),process.exit(1)}}a(_y,"initSync");function uy(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:s,https_enabled:n,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,_=jt.join(__dirname,"../../","unitTests");fr[Ma]=jt.join(_,"hdb_boot_properties.file"),$(M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,jt.join(_,"settings.test")),$(M.HDB_SETTINGS_NAMES.INSTALL_USER,ty.userInfo().username),$(M.HDB_SETTINGS_NAMES.PRIVATE_KEY_KEY,jt.join(_,"envDir","utility","keys","privateKey.pem")),$(M.HDB_SETTINGS_NAMES.CERT_KEY,jt.join(_,"envDir","utility","keys","certificate.pem")),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_TLS_PRIVATEKEY,jt.join(_,"envDir","utility","keys","privateKey.pem")),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_TLS_CERTIFICATE,jt.join(_,"envDir","utility","keys","certificate.pem")),$(M.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),$(M.HDB_SETTINGS_NAMES.LOG_PATH_KEY,jt.join(_,"envDir","log")),$(M.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),$(M.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),$(M.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),$(M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,jt.join(_,"envDir")),$(M.HDB_SETTINGS_NAMES.HTTP_SECURE_ENABLED_KEY,Zs.isEmpty(n)?!0:n),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,Zs.isEmpty(n)?!0:n),$(M.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),$(M.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Zs.isEmpty(i)?!1:i),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_CORS,Zs.isEmpty(i)?!1:i),$(M.HDB_SETTINGS_NAMES.IPC_SERVER_PORT,9383),$(M.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),$(M.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),$(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),$(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),$(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,jt.resolve(__dirname,"../../unitTests/server/customFunctions/custom_functions")),$(M.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Zs.isEmpty(c)?!1:c),o&&($("CORS_ACCESSLIST",o),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST,o)),s&&($(M.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,s),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_TIMEOUT,s)),t&&($(M.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT,t)),r&&($(M.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),$(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${Ma}. Please check your boot props and settings files`;Qn.fatal(r),Qn.error(t)}}a(uy,"initTestEnvironment")});var Z=S((nJ,FS)=>{"use strict";var Ru=require("lmdb"),bt=require("fs-extra"),Vt=require("path"),Ba=_s(),LS=I(),De=Ke().LMDB_ERRORS_ENUM,va=uS(),Au=ES(),US=hS(),Br=Ye(),sJ=T(),Wn=Y();Wn.initSync();var yS=Wn.get("STORAGE_WRITEASYNC")===!0||Wn.get("STORAGE_WRITEASYNC")==="true"||Wn.get("STORAGE_WRITEASYNC")==="TRUE",DS=Wn.get("STORAGE_OVERLAPPINGSYNC"),MS=1024*1024*1024,PS=1e4,BS=1e3,kt=Br.INTERNAL_DBIS_NAME,vS=Br.DBI_DEFINITION_NAME,ly="data.mdb",Ey="lock.mdb",Jn=".mdb",dy="-lock",Pa=class{constructor(t,r,s=!1){this.dbi=Ct(t,r),this.key_type=this.dbi[Br.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Br.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:s===!1}),this.cursor=new Ru.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};a(Pa,"TransactionCursor");function Ou(e,t){if(e===void 0)throw new Error(De.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(De.ENV_NAME_REQUIRED)}a(Ou,"pathEnvNameValidation");async function pu(e,t,r=!0){try{await bt.access(e)}catch(s){throw s.code==="ENOENT"?new Error(De.INVALID_BASE_PATH):s}try{let s=Vt.join(e,t+Jn);return await bt.access(s,bt.constants.R_OK|bt.constants.F_OK),s}catch(s){if(s.code==="ENOENT")if(r)try{return await bt.access(Vt.join(e,t,ly),bt.constants.R_OK|bt.constants.F_OK),Vt.join(e,t)}catch(n){if(n.code==="ENOENT")throw new Error(De.INVALID_ENVIRONMENT)}else throw new Error(De.INVALID_ENVIRONMENT);throw s}}a(pu,"validateEnvironmentPath");function Ha(e,t){if(Ba.validateEnv(e),t===void 0)throw new Error(De.DBI_NAME_REQUIRED)}a(Ha,"validateEnvDBIName");async function hy(e,t,r=!1,s=!1){Ou(e,t),t=t.toString();try{return await pu(e,t,s),Nu(e,t,r)}catch(n){if(n.message===De.INVALID_ENVIRONMENT){let i=Vt.join(e,t);await bt.mkdirp(s?i:e);let o=new US(s?i:i+Jn,MS,PS,BS,!1,yS,DS),c=Ru.open(o);c.dbis=Object.create(null);let _=new Au(!1);c.openDB(kt,_),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let u=gu(e,t,r);return c[Br.ENVIRONMENT_NAME_KEY]=u,global.lmdb_map[u]=c,c}throw n}}a(hy,"createEnvironment");async function Sy(e,t,r,s=!0){let n=await Nu(e,t);if(r===void 0)throw new Error(De.DESTINATION_PATH_REQUIRED);try{await bt.access(Vt.dirname(r))}catch(i){throw i.code==="ENOENT"?new Error(De.INVALID_DESTINATION_PATH):i}await n.backup(r,s)}a(Sy,"copyEnvironment");async function Nu(e,t,r=!1){Ou(e,t),t=t.toString();let s=gu(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[s]!==void 0)return global.lmdb_map[s];let n=await pu(e,t),i=Vt.join(e,t+Jn),o=n!=i,c=new US(n,MS,PS,BS,o,yS,DS),_=Ru.open(c);_.dbis=Object.create(null);let u=GS(_);for(let l=0;l<u.length;l++)Ct(_,u[l]);return _[Br.ENVIRONMENT_NAME_KEY]=s,global.lmdb_map[s]=_,_}a(Nu,"openEnvironment");async function fy(e,t,r=!1){Ou(e,t),t=t.toString();let s=Vt.join(e,t+Jn),n=await pu(e,t);if(global.lmdb_map!==void 0){let i=gu(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await HS(o),delete global.lmdb_map[i]}}await bt.remove(n),await bt.remove(n===s?n+dy:Vt.join(Vt.dirname(n),Ey))}a(fy,"deleteEnvironment");async function HS(e){Ba.validateEnv(e);let t=e[Br.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(HS,"closeEnvironment");function gu(e,t,r=!1){let n=`${Vt.basename(e)}.${t}`;return r===!0&&(n=`txn.${n}`),n}a(gu,"getCachedEnvironmentName");function Ty(e){Ba.validateEnv(e);let t=Object.create(null),r=Ct(e,kt);for(let{key:s,value:n}of r.getRange({start:!1}))if(s!==kt)try{t[s]=Object.assign(new va,n)}catch{LS.warn(`an internal error occurred: unable to parse DBI Definition for ${s}`)}return t}a(Ty,"listDBIDefinitions");function GS(e){Ba.validateEnv(e);let t=[],r=Ct(e,kt);for(let{key:s}of r.getRange({start:!1}))s!==kt&&t.push(s);return t}a(GS,"listDBIs");function my(e,t){let s=Ct(e,kt).getEntry(t),n=new va;if(s!==void 0){try{n=Object.assign(n,s.value)}catch{LS.warn(`an internal error occurred: unable to parse DBI Definition for ${s}`)}return n}}a(my,"getDBIDefinition");function qS(e,t,r,s=!1){if(Ha(e,t),t=t.toString(),t===kt)throw new Error(De.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Ct(e,t)}catch(n){if(n.message===De.DBI_DOES_NOT_EXIST){let i=new Au(r,s===!0),o=e.openDB(t,i),c=new va(r===!0,s);return o[vS]=c,Ct(e,kt).putSync(t,c),e.dbis[t]=o,o}throw n}}a(qS,"createDBI");function Ct(e,t){if(Ha(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==kt?r=my(e,t):r=new va,r===void 0)throw new Error(De.DBI_DOES_NOT_EXIST);let s;try{let n=new Au(r.dup_sort,r.useVersions);if(s=e.openDB(t,n),s.db===void 0)throw new Error("MDB_NOTFOUND")}catch(n){throw n.message.includes("MDB_NOTFOUND")===!0?new Error(De.DBI_DOES_NOT_EXIST):n}return s[vS]=r,e.dbis[t]=s,s}a(Ct,"openDBI");function Ry(e,t){Ha(e,t),t=t.toString();let r=Ct(e,t),s=r.getStats();return r[Br.DBI_DEFINITION_NAME].is_hash_attribute&&s.entryCount>0&&s.entryCount--,s}a(Ry,"statDBI");async function Ay(e,t){try{let r=Vt.join(e,t+Jn);return(await bt.stat(r)).size}catch{throw new Error(De.INVALID_ENVIRONMENT)}}a(Ay,"environmentDataSize");function Oy(e,t){if(Ha(e,t),t=t.toString(),t===kt)throw new Error(De.CANNOT_DROP_INTERNAL_DBIS_NAME);Ct(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Ct(e,kt).removeSync(t)}a(Oy,"dropDBI");function py(e,t,r){for(let s=0;s<r.length;s++){let n=r[s];if(!e.dbis[n])try{Ct(e,n)}catch(i){if(i.message===De.DBI_DOES_NOT_EXIST)qS(e,n,n!==t,n===t);else throw i}}}a(py,"initializeDBIs");FS.exports={openDBI:Ct,openEnvironment:Nu,createEnvironment:hy,listDBIs:GS,listDBIDefinitions:Ty,createDBI:qS,dropDBI:Oy,statDBI:Ry,deleteEnvironment:fy,initializeDBIs:py,TransactionCursor:Pa,environmentDataSize:Ay,copyEnvironment:Sy,closeEnvironment:HS}});var kS=S((iJ,VS)=>{"use strict";var Ga=class{constructor(t=[],r=[],s=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=s}};a(Ga,"InsertRecordsResponseObject");VS.exports=Ga});var $S=S((aJ,xS)=>{"use strict";var qa=class{constructor(t=[],r=[],s=void 0,n=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=s,this.original_records=n}};a(qa,"UpdateRecordsResponseObject");xS.exports=qa});var KS=S((oJ,YS)=>{"use strict";var Fa=class{constructor(t=[],r=void 0,s=[]){this.written_hashes=t,this.txn_time=r,this.original_records=s}};a(Fa,"UpsertRecordsResponseObject");YS.exports=Fa});var Xs=S((lJ,WS)=>{"use strict";var Ny=Z(),gy=kS(),Iy=$S(),by=KS(),Xn=_s(),Zn=Ke().LMDB_ERRORS_ENUM,Cy=Ye(),vr=T(),wy=b(),Ly=require("uuid"),cJ=require("lmdb"),{handleHDBError:Uy,hdb_errors:yy}=D(),{OVERFLOW_MARKER:_J,MAX_SEARCH_KEY_LENGTH:uJ}=Cy,Iu=vr.TIME_STAMP_NAMES_ENUM.CREATED_TIME,ls=vr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function Dy(e,t,r,s,n=!0){Lu(e,t,r,s),bu(e,t,r);let i=new gy,o=[],c=[];for(let _=0;_<s.length;_++){let u=s[_];QS(u,!0,n);let l=My(e,t,r,u),E=u[t];o.push(l),c.push(E)}return Cu(o,c,s,i)}a(Dy,"insertRecords");function My(e,t,r,s){let n=s[t];return e.dbis[t].ifNoExists(n,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||s.hasOwnProperty(o)===!1)continue;let c=s[o];if(typeof c=="function"){let u=c([[{}]]);Array.isArray(u)&&(c=u[0][vr.FUNC_VAL],s[o]=c)}let _=Xn.getIndexedValues(c);if(_)for(let u=0,l=_.length;u<l;u++)e.dbis[o].put(_[u],n)}e.dbis[t].put(n,s,s[ls])})}a(My,"insertRecord");function Py(e,t=[]){let r=0;for(let s=0;s<t.length;s++){let n=t[s];e.splice(n-r,1),r++}}a(Py,"removeSkippedRecords");function QS(e,t,r=!0){let s=Date.now();(r===!0||!Number.isInteger(e[ls]))&&(e[ls]=s),t===!0?(r===!0||!Number.isInteger(e[Iu]))&&(e[Iu]=s):delete e[Iu]}a(QS,"setTimestamps");function bu(e,t,r){r.indexOf(vr.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(vr.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(vr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(vr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),Ny.initializeDBIs(e,t,r)}a(bu,"initializeTransaction");async function By(e,t,r,s,n=!0){Lu(e,t,r,s),bu(e,t,r);let i=new Iy,o=[],c=[],_=[];for(let u=0;u<s.length;u++){let l=s[u],E=l[t],d;try{d=wu(e,t,l,E,i,!0,n)}catch{i.skipped_hashes.push(E),o.push(u);continue}c.push(d),_.push(E)}return Cu(c,_,s,i,o)}a(By,"updateRecords");async function vy(e,t,r,s,n=!0){try{Lu(e,t,r,s)}catch(_){throw Uy(_,_.message,yy.HTTP_STATUS_CODES.BAD_REQUEST)}bu(e,t,r);let i=new by,o=[],c=[];for(let _=0;_<s.length;_++){let u=s[_],l;wy.isEmpty(u[t])?(l=Ly.v4(),u[t]=l):l=u[t];let E=wu(e,t,u,l,i,!1,n);o.push(E),c.push(l)}return Cu(o,c,s,i)}a(vy,"upsertRecords");async function Cu(e,t,r,s,n=[]){let i=await Promise.all(e);for(let o=0,c=i.length;o<c;o++)i[o]===!0?s.written_hashes.push(t[o]):(s.skipped_hashes.push(t[o]),n.push(o));return s.txn_time=Xn.getMicroTime(),Py(r,n),s}a(Cu,"finalizeWrite");function wu(e,t,r,s,n,i=!1,o=!0){let c=e.dbis[t],_=c.getEntry(s),u=_?.value,l=u;if(!u){if(i)return!1;u={}}if(QS(r,!l,o),Number.isInteger(r[ls])&&u[ls]>r[ls])return!1;l&&n.original_records.push(u);let E,d=a(()=>{for(let m in r){if(!r.hasOwnProperty(m)||m===t)continue;let R=r[m],w=e.dbis[m];if(w===void 0)continue;let L=u[m];if(typeof R=="function"){let z=R([[u]]);Array.isArray(z)&&(R=z[0][vr.FUNC_VAL],r[m]=R)}if(R===L)continue;let B=Xn.getIndexedValues(L);if(B)for(let z=0,V=B.length;z<V;z++)w.remove(B[z],s);if(B=Xn.getIndexedValues(R),B)for(let z=0,V=B.length;z<V;z++)w.put(B[z],s)}let h=Object.assign({},u,r);c.put(s,h,h[ls])},"do_put");return _?E=c.ifVersion(s,_.version,d):E=c.ifNoExists(s,d),E.then(h=>h?!0:wu(e,t,r,s,n,i,o))}a(wu,"updateUpsertRecord");function Hy(e,t,r){if(Xn.validateEnv(e),t===void 0)throw new Error(Zn.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Zn.WRITE_ATTRIBUTES_REQUIRED):new Error(Zn.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(Hy,"validateBasic");function Lu(e,t,r,s){if(Hy(e,t,r),!Array.isArray(s))throw s===void 0?new Error(Zn.RECORDS_REQUIRED):new Error(Zn.RECORDS_MUST_BE_ARRAY)}a(Lu,"validateWrite");WS.exports={insertRecords:Dy,updateRecords:By,upsertRecords:vy}});var te=S((EJ,ZS)=>{"use strict";var Uu=T(),zs=Y(),yu=require("path");zs.initSync();var Va,ka,xa;function JS(){if(Va!==void 0)return Va;if(zs.getHdbBasePath()!==void 0)return Va=yu.join(zs.getHdbBasePath(),Uu.SCHEMA_DIR_NAME),Va}a(JS,"getBaseSchemaPath");function Gy(){if(ka!==void 0)return ka;if(zs.getHdbBasePath()!==void 0)return ka=yu.join(JS(),Uu.SYSTEM_SCHEMA_NAME),ka}a(Gy,"getSystemSchemaPath");function qy(){if(xa!==void 0)return xa;if(zs.getHdbBasePath()!==void 0)return xa=yu.join(zs.getHdbBasePath(),Uu.TRANSACTIONS_DIR_NAME),xa}a(qy,"getTransactionAuditStorePath");ZS.exports={getBaseSchemaPath:JS,getSystemSchemaPath:Gy,getTransactionAuditStorePath:qy}});var Tr=S((dJ,jS)=>{"use strict";var zS=b(),XS=T(),Ya=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Du=require("joi"),$a={schema_format:{pattern:Ya,message:"names cannot include backticks or forward slashes"},schema_length:{maximum:250,tooLong:"cannot exceed 250 characters"}},Fy=Du.alternatives(Du.string().min(1).max($a.schema_length.maximum).pattern(Ya).messages({"string.pattern.base":"{:#label} "+$a.schema_format.message}),Du.number()).required();function Vy(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>$a.schema_length.maximum?`'${e}' maximum of 250 characters`:Ya.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(Vy,"checkValidTable");function ky(e,t){return zS.doesSchemaExist(e)?e:t.message(`Schema '${e}' does not exist`)}a(ky,"validateSchemaExists");function xy(e,t){let r=t.state.ancestors[0].schema;return zS.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(xy,"validateTableExists");function $y(e,t){return e.toLowerCase()===XS.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid schema name, '${XS.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a($y,"validateSchemaName");jS.exports={common_validators:$a,schema_regex:Ya,hdb_schema_table:Fy,validateSchemaExists:ky,validateTableExists:xy,validateSchemaName:$y,checkValidTable:Vy}});var Ka=S((hJ,ef)=>{var{common_validators:Hr}=Tr(),zn=de(),xt="is required",X={schema:{presence:!0,format:Hr.schema_format,length:Hr.schema_length},table:{presence:!0,format:Hr.schema_format,length:Hr.schema_length},attribute:{presence:!0,format:Hr.schema_format,length:Hr.schema_length},hash_attribute:{presence:!0,format:Hr.schema_format,length:Hr.schema_length}};function jn(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(jn,"makeAttributesStrings");function Yy(e){return e=jn(e),X.schema.presence={message:xt},X.table.presence=!1,X.attribute.presence=!1,X.hash_attribute.presence=!1,zn.validateObject(e,X)}a(Yy,"schema_object");function Ky(e){return e=jn(e),X.schema.presence={message:xt},X.table.presence={message:xt},X.attribute.presence=!1,X.hash_attribute.presence=!1,zn.validateObject(e,X)}a(Ky,"table_object");function Qy(e){return e=jn(e),X.schema.presence={message:xt},X.table.presence={message:xt},X.attribute.presence=!1,X.hash_attribute.presence={message:xt},zn.validateObject(e,X)}a(Qy,"create_table_object");function Wy(e){return e=jn(e),X.schema.presence={message:xt},X.table.presence={message:xt},X.attribute.presence={message:xt},X.hash_attribute.presence=!1,zn.validateObject(e,X)}a(Wy,"attribute_object");function Jy(e){return e=jn(e),X.schema.presence={message:xt},X.table.presence={message:xt},X.attribute.presence=!1,X.hash_attribute.presence=!1,zn.validateObject(e,X)}a(Jy,"describe_table");function Zy(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(Zy,"validateTableResidence");ef.exports={schema_object:Yy,create_table_object:Qy,table_object:Ky,attribute_object:Wy,describe_table:Jy,validateTableResidence:Zy}});var rf=S((SJ,tf)=>{"use strict";var Xy=require("uuid"),Qa=class{constructor(t,r,s,n){this.schema=t,this.table=r,this.attribute=s,this.id=n||Xy.v4(),this.schema_table=`${this.schema}.${this.table}`}};a(Qa,"CreateAttributeObject");tf.exports=Qa});var Ja=S((fJ,sf)=>{"use strict";var zy=rf(),Wa=class extends zy{constructor(t,r,s,n,i=!0,o=!1){super(t,r,s,n),this.dup_sort=i,this.is_hash_attribute=o}};a(Wa,"LMDBCreateAttributeObject");sf.exports=Wa});var af=S((TJ,nf)=>{"use strict";nf.exports=eD;var jy="inserted";function eD(e,t,r,s){let n={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:s};return e===jy?(n.inserted_hashes=t,n):(n.update_hashes=t,n)}a(eD,"returnObject")});var Za=S((mJ,cf)=>{"use strict";var tD=T(),Mu=Z(),rD=Xs(),{getSystemSchemaPath:sD,getBaseSchemaPath:nD}=te(),iD=require("path"),aD=is(),oD=Ka(),cD=Ja(),_D=af(),{handleHDBError:uD,hdb_errors:lD}=D(),ED=b(),Pu=aD.hdb_attribute,of=[];for(let e=0;e<Pu.attributes.length;e++)of.push(Pu.attributes[e].attribute);var dD="inserted";cf.exports=hD;async function hD(e){let t=oD.attribute_object(e);if(t)throw uD(new Error,t.message,lD.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=ED.isEmpty(e.dup_sort)||e.dup_sort=="true";let r=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(r=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(r)&&r.length>0){for(let n of r)if(n.attribute===e.attribute)throw new Error(`attribute '${n.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new cD(e.schema,e.table,e.attribute,e.id);try{let n=await Mu.openEnvironment(iD.join(nD(),e.schema.toString()),e.table);if(n.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);Mu.createDBI(n,e.attribute,e.dup_sort,e.is_hash_attribute);let i=await Mu.openEnvironment(sD(),tD.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:o,skipped_hashes:c}=await rD.insertRecords(i,Pu.hash_attribute,of,[s]);return _D(dD,o,{records:[s]},c)}catch(n){throw n}}a(hD,"lmdbCreateAttribute")});var vu=S((RJ,uf)=>{var{hdb_schema_table:_f}=Tr(),SD=de(),Bu=require("joi"),fD={undefined:"undefined",null:"null"},TD=a((e,t)=>{let r=Object.keys(e),s=r.length,n;for(let i=0;i<s;i++){let o=r[i];(!o||o.length===0||fD[o]!==void 0)&&(n===void 0?n=`Invalid attribute name: '${o}'`:n+=`. Invalid attribute name: '${o}'`)}return n?t.message(n):e},"custom_records_val"),mD=Bu.object({schema:_f,table:_f,records:Bu.array().items(Bu.object().custom(TD)).required()});uf.exports=function(e){return SD.validateBySchema(e,mD)}});var Xa=S((OJ,Ef)=>{"use strict";var mr=b(),lf=I(),AJ=vu();Ef.exports=RD;function RD(e){if(mr.isEmpty(e))throw new Error("invalid update parameters defined.");if(mr.isEmptyOrZeroLength(e.schema))throw new Error("invalid schema specified.");if(mr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");if(!Array.isArray(e.records))throw new Error("records must be an array");let t=global.hdb_schema[e.schema][e.table];if(mr.isEmpty(t))throw new Error(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.hash_attribute,s=new Set,n={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&mr.isEmptyOrZeroLength(o[r]))throw lf.error("a valid hash attribute must be provided with update record:",o),new Error("a valid hash attribute must be provided with update record, check log for more info");if(!mr.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw lf.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Error(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!mr.isEmpty(o[r])&&o[r]!==""&&s.has(mr.autoCast(o[r]))&&(o.skip=!0),s.add(mr.autoCast(o[r]));for(let c in o)n[c]=1}),n[r]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(n)}}a(RD,"insertUpdateValidate")});var ei=S((pJ,df)=>{"use strict";var AD=T().OPERATIONS_ENUM,za=class{constructor(t,r,s,n,i=void 0){this.operation=AD.INSERT,this.schema=t,this.table=r,this.hash_attribute=s,this.records=n,this.__origin=i}};a(za,"InsertObject");df.exports=za});var eo=S((gJ,hf)=>{"use strict";var NJ=ei(),ja=T(),Gu=b(),Hu=I(),OD=require("uuid"),{handleHDBError:ti,hdb_errors:pD}=D(),{HDB_ERROR_MSGS:ri,HTTP_STATUS_CODES:si}=pD;hf.exports=ND;function ND(e,t,r){for(let n=0;n<t.length;n++)gD(t[n]);let{records:s}=e;for(let n=0;n<s.length;n++){let i=s[n];ID(i,r,e.operation)}}a(ND,"processRows");function gD(e){if(Buffer.byteLength(String(e))>ja.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw ti(new Error,ri.ATTR_NAME_LENGTH_ERR(e),si.BAD_REQUEST,void 0,void 0,!0);if(Gu.isEmptyOrZeroLength(e)||Gu.isEmpty(e.trim()))throw ti(new Error,ri.ATTR_NAME_NULLISH_ERR,si.BAD_REQUEST,void 0,void 0,!0)}a(gD,"validateAttribute");function ID(e,t,r){if(!e.hasOwnProperty(t)||Gu.isEmptyOrZeroLength(e[t])){if(r===ja.OPERATIONS_ENUM.INSERT||r===ja.OPERATIONS_ENUM.UPSERT){e[t]=OD.v4();return}throw Hu.error("Update transaction aborted due to record with no hash value:",e),ti(new Error,ri.RECORD_MISSING_HASH_ERR,si.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>ja.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Hu.error(e),ti(new Error,ri.HASH_VAL_LENGTH_ERR,si.BAD_REQUEST,void 0,void 0,!0);if(isNaN(e[t])&&e[t].includes("/"))throw Hu.error(e),ti(new Error,ri.INVALID_FORWARD_SLASH_IN_HASH_ERR,si.BAD_REQUEST,void 0,void 0,!0)}a(ID,"validateHash")});var ff=S((IJ,Sf)=>{"use strict";var to=class{constructor(t,r){this.type=t,this.message=r}};a(to,"IPCEventObject");Sf.exports=to});var Gr=S((bJ,Tf)=>{"use strict";var bD=I(),qu=b(),CD=T(),{IPC_ERRORS:ni}=Ke();Tf.exports={sendIpcEvent:wD,validateEvent:LD,SchemaEventMsg:UD,UserEventMsg:yD};function wD(e){global.hdb_ipc?global.hdb_ipc.emitToServer(e):bD.warn("Tried to send event:",e,"to HDB IPC client but it does not exist")}a(wD,"sendIpcEvent");function LD(e){if(typeof e!="object")return ni.INVALID_IPC_DATA_TYPE;if(!e.hasOwnProperty("type")||qu.isEmpty(e.type))return ni.MISSING_TYPE;if(!e.hasOwnProperty("message")||qu.isEmpty(e.message))return ni.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||qu.isEmpty(e.message.originator))return ni.MISSING_ORIGIN;if(CD.IPC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return ni.INVALID_EVENT(e.type)}a(LD,"validateEvent");function UD(e,t,r,s=void 0,n=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=s,this.attribute=n}a(UD,"SchemaEventMsg");function yD(e){this.originator=e}a(yD,"UserEventMsg")});var js=S((wJ,Of)=>{"use strict";var mf=T(),CJ=b(),ro=I(),Rf=ff(),{sendIpcEvent:Af}=Gr();function DD(e){try{ro.trace("signalSchemaChange called with message:",e);let t=new Rf(mf.IPC_EVENT_TYPES.SCHEMA,e);Af(t)}catch(t){ro.error(t)}}a(DD,"signalSchemaChange");function MD(e){try{ro.trace("signalUserChange called with message:",e);let t=new Rf(mf.IPC_EVENT_TYPES.USER,e);Af(t)}catch(t){ro.error(t)}}a(MD,"signalUserChange");Of.exports={signalSchemaChange:DD,signalUserChange:MD}});var so=S((LJ,Nf)=>{"use strict";var pf=b(),PD=T(),BD=I(),vD=Za(),HD=Ja(),GD=js(),{SchemaEventMsg:qD}=Gr(),FD="already exists in";Nf.exports=VD;async function VD(e,t,r){try{if(pf.isEmptyOrZeroLength(r))return r;let s=[];pf.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{s.push(i.attribute)});let n=r.filter(i=>s.indexOf(i)<0);return n.length===0||await Promise.all(n.map(async i=>{await kD(e,t.schema,t.name,i)})),n}catch(s){throw s}}a(VD,"lmdbCheckForNewAttributes");async function kD(e,t,r,s){let n=new HD(t,r,s,void 0,!0);e&&(n.hdb_auth_header=e);try{await xD(n)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(FD))BD.warn(`attribute ${t}.${r}.${s} already exists`);else throw i}}a(kD,"createNewAttribute");async function xD(e){let t;try{return t=await vD(e),GD.signalSchemaChange(new qD(process.pid,PD.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}catch(r){throw r}}a(xD,"createAttribute")});var en=S((UJ,gf)=>{"use strict";var no=class{constructor(t,r,s,n,i=void 0){this.operation=t,this.user_name=r,this.timestamp=s,this.hash_values=n,this.origin=i}};a(no,"LMDBTransactionObject");gf.exports=no});var bf=S((yJ,If)=>{"use strict";var $D=en(),YD=T().OPERATIONS_ENUM,io=class extends $D{constructor(t,r,s,n,i=void 0){super(YD.INSERT,r,s,n,i),this.records=t}};a(io,"LMDBInsertTransactionObject");If.exports=io});var wf=S((DJ,Cf)=>{"use strict";var KD=en(),QD=T().OPERATIONS_ENUM,ao=class extends KD{constructor(t,r,s,n,i,o=void 0){super(QD.UPDATE,s,n,i,o),this.records=t,this.original_records=r}};a(ao,"LMDBUpdateTransactionObject");Cf.exports=ao});var Uf=S((MJ,Lf)=>{"use strict";var WD=en(),JD=T().OPERATIONS_ENUM,oo=class extends WD{constructor(t,r,s,n,i,o=void 0){super(JD.UPSERT,s,n,i,o),this.records=t,this.original_records=r}};a(oo,"LMDBUpsertTransactionObject");Lf.exports=oo});var Df=S((PJ,yf)=>{"use strict";var ZD=en(),XD=T().OPERATIONS_ENUM,co=class extends ZD{constructor(t,r,s,n,i=void 0){super(XD.DELETE,s,n,t,i),this.original_records=r}};a(co,"LMDBDeleteTransactionObject");yf.exports=co});var ii=S((BJ,vf)=>{"use strict";var zD=require("path"),Mf=Z(),jD=bf(),eM=wf(),tM=Uf(),rM=Df(),tn=Ye(),Pf=b(),{CONFIG_PARAMS:sM}=T(),Bf=Y();Bf.initSync();var _o=T().OPERATIONS_ENUM,{getTransactionAuditStorePath:nM}=te();vf.exports=iM;async function iM(e,t){if(Bf.get(sM.LOGGING_AUDITLOG)===!1)return;let r=zD.join(nM(),e.schema.toString()),s=await Mf.openEnvironment(r,e.table,!0),n=aM(e,t);if(!(n===void 0||n.hash_values.length===0)&&s!==void 0){Mf.initializeDBIs(s,tn.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,tn.TRANSACTIONS_DBIS);try{let i=n.timestamp;return await s.dbis[tn.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{s.dbis[tn.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,n),Pf.isEmpty(n.user_name)||s.dbis[tn.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(n.user_name,i);for(let o=0;o<n.hash_values.length;o++)s.dbis[tn.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n.hash_values[o],i)})}catch(i){throw i}}}a(iM,"writeTransaction");function aM(e,t){let r=Pf.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===_o.INSERT)return new jD(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===_o.UPDATE)return new eM(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===_o.UPSERT)return new tM(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===_o.DELETE)return new rM(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(aM,"createTransactionObject")});var Fu=S((HJ,Hf)=>{"use strict";var oM=Xa(),vJ=ei(),rn=T(),cM=eo(),_M=Xs().insertRecords,uM=Z(),lM=require("path"),EM=I(),dM=so(),{getBaseSchemaPath:hM}=te(),SM=ii();Hf.exports=fM;async function fM(e){try{let{schema_table:t,attributes:r}=oM(e);cM(e,r,t.hash_attribute),e.schema!==rn.SYSTEM_SCHEMA_NAME&&(r.includes(rn.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(rn.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(rn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(rn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await dM(e.hdb_auth_header,t,r),n=lM.join(hM(),e.schema.toString()),i=await uM.openEnvironment(n,e.table),o=await _M(i,t.hash_attribute,r,e.records,e[rn.CLUSTERING_FLAG]!==!0);try{await SM(e,o)}catch(c){EM.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:s,txn_time:o.txn_time}}catch(t){throw t}}a(fM,"lmdbCreateRecords")});var Ff=S((GJ,qf)=>{"use strict";var Gf=T(),TM=Fu(),mM=ei(),RM=require("fs-extra"),AM=require("path"),{getBaseSchemaPath:OM}=te();qf.exports=pM;async function pM(e){let t=[{name:e.schema,createddate:Date.now()}],r=new mM(Gf.SYSTEM_SCHEMA_NAME,Gf.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await TM(r),await RM.mkdirp(AM.join(OM(),e.schema.toString()))}a(pM,"lmdbCreateSchema")});var kf=S((qJ,Vf)=>{"use strict";var uo=class{constructor(t=[],r=[],s=void 0,n=[]){this.deleted=t,this.skipped=r,this.txn_time=s,this.original_records=n}};a(uo,"DeleteRecordsResponseObject");Vf.exports=uo});var xu=S((xJ,Yf)=>{"use strict";var xf=Z(),Vu=_s(),ku=Ke().LMDB_ERRORS_ENUM,NM=Ye(),$f=I(),FJ=b(),gM=require("lmdb"),IM=kf(),{OVERFLOW_MARKER:VJ,MAX_SEARCH_KEY_LENGTH:kJ}=NM;async function bM(e,t,r){if(Vu.validateEnv(e),t===void 0)throw new Error(ku.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(ku.IDS_REQUIRED):new Error(ku.IDS_MUST_BE_ARRAY);try{let s=xf.listDBIs(e);xf.initializeDBIs(e,t,s);let n=new IM,i,o=[],c=[];for(let E=0,d=r.length;E<d;E++)try{i=r[E];let h=e.dbis[t].get(i);if(!h){n.skipped.push(i);continue}let m=e.dbis[t].ifVersion(i,gM.IF_EXISTS,()=>{e.dbis[t].remove(i);for(let R=0;R<s.length;R++){let w=s[R];if(!h.hasOwnProperty(w)||w===t)continue;let L=e.dbis[w],B=h[w];if(B!=null)try{let z=Vu.getIndexedValues(B);if(z)for(let V=0,W=z.length;V<W;V++)L.remove(z[V],i)}catch{$f.warn(`cannot delete from attribute: ${w}, ${B}:${i}`)}}});o.push(m),c.push(i),n.original_records.push(h)}catch(h){$f.warn(h),n.skipped.push(i)}let _=[],u=await Promise.all(o);for(let E=0,d=u.length;E<d;E++)u[E]===!0?n.deleted.push(c[E]):(n.skipped.push(c[E]),_.push(E));let l=0;for(let E=0;E<_.length;E++){let d=_[E];n.original_records.splice(d-l,1),l++}return n.txn_time=Vu.getMicroTime(),n}catch(s){throw s}}a(bM,"deleteRecords");Yf.exports={deleteRecords:bM}});var ai=S(($J,Qf)=>{"use strict";var sn=b(),CM=xu(),wM=Z(),LM=require("path"),{getBaseSchemaPath:UM}=te(),yM=ii(),DM=I();Qf.exports=MM;async function MM(e,t=!0){let s=global.hdb_schema[e.schema][e.table].hash_attribute;if(sn.isEmpty(s))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(sn.isEmptyOrZeroLength(e.hash_values)&&!sn.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let _=e.records[c][s];sn.isEmpty(_)||e.hash_values.push(_)}}if(sn.isEmptyOrZeroLength(e.hash_values))return Kf([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(sn.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[s]:e.hash_values[c]}}let n=LM.join(UM(),e.schema.toString()),i=await wM.openEnvironment(n,e.table),o=await CM.deleteRecords(i,s,e.hash_values);try{t===!0&&await yM(e,o)}catch(c){DM.error(`unable to write transaction due to ${c.message}`)}return Kf(o.deleted,o.skipped,o.txn_time)}catch(n){throw n}}a(MM,"lmdbDeleteRecords");function Kf(e,t,r){let s=e.length+t.length,n=s===1?"record":"records";return{message:`${e.length} of ${s} ${n} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(Kf,"createDeleteResponse")});var Yu=S((KJ,Wf)=>{"use strict";var PM=T(),YJ=_s();function $u(e,t){let r=Object.create(null);if(t.length===1&&PM.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let s=0;s<t.length;s++){let n=t[s],i=e[n];r[n]=i===void 0?null:i}return r}a($u,"parseRow");function BM(e,t,r,s){let n=$u(r,e);s.push(n)}a(BM,"searchAll");function vM(e,t,r,s){let n=$u(r,e);s[t]=n}a(vM,"searchAllToMap");function HM(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(HM,"iterateDBI");function Es(e,t,r,s,n){let i=Object.create(null);i[n]=e;let o;s===n?o=e:(o=t,s!==void 0&&(i[s]=o)),r[0].push(o),r[1].push(i)}a(Es,"pushResults");function GM(e,t,r,s,n,i){t.toString().endsWith(e)&&Es(t,r,s,n,i)}a(GM,"endsWith");function qM(e,t,r,s,n,i){t.toString().includes(e)&&Es(t,r,s,n,i)}a(qM,"contains");function FM(e,t,r,s,n,i){t>e&&Es(t,r,s,n,i)}a(FM,"greaterThanCompare");function VM(e,t,r,s,n,i){t>=e&&Es(t,r,s,n,i)}a(VM,"greaterThanEqualCompare");function kM(e,t,r,s,n,i){t<e&&Es(t,r,s,n,i)}a(kM,"lessThanCompare");function xM(e,t,r,s,n,i){t<=e&&Es(t,r,s,n,i)}a(xM,"lessThanEqualCompare");Wf.exports={parseRow:$u,searchAll:BM,searchAllToMap:vM,iterateDBI:HM,endsWith:GM,contains:qM,greaterThanCompare:FM,greaterThanEqualCompare:VM,lessThanCompare:kM,lessThanEqualCompare:xM,pushResults:Es}});var nn=S((JJ,eT)=>{"use strict";var wt=Z(),$M=I(),ft=_s(),qr=Ye(),ce=Ke().LMDB_ERRORS_ENUM,QJ=b(),YM=T(),$t=Yu(),WJ=require("lmdb"),{OVERFLOW_MARKER:Jf,MAX_SEARCH_KEY_LENGTH:KM}=qr,oi={lazy:!0};function Zf(e,t,r,s,n=!1,i=void 0,o=void 0){let c=Object.create(null),_=wt.openDBI(e,r);_[qr.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let u=Ku(e,t,r);for(let{key:l,value:E}of _.getRange({start:n?void 0:!1,end:n?!1:void 0,limit:i,offset:o,reverse:n}))s(u(l,E),E,c,t,r);return c}a(Zf,"iterateFullIndex");function ci(e,t,r,s,n,i=!1,o=void 0,c=void 0,_=!1,u=!1){let l=[[],[]],E=wt.openDBI(e,r),d=Ku(e,t,r);E[qr.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let h=i===!0?s:n,m=i===!0?n:s,R=i===!0?!_:!u,w=i===!0?u:_;for(let{key:L,value:B}of E.getRange({start:m,end:h,reverse:i,limit:o,offset:c,inclusiveEnd:R,exclusiveStart:w}))$t.pushResults(d(L,B),B,l,t,r);return l}a(ci,"iterateRangeBetween");function Ku(e,t,r){let s;return function(n,i){if(typeof n=="string"&&n.endsWith(Jf)){if(!s)if(t)s=wt.openDBI(e,t);else{let c=wt.listDBIs(e);for(let _=0,u=c.length;_<u&&(s=wt.openDBI(e,c[_]),!s[qr.DBI_DEFINITION_NAME].is_hash_attribute);_++);}n=s.get(i,oi)[r]}return n}}a(Ku,"getOverflowCheck");function QM(e,t,r,s=!1,n=void 0,i=void 0){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);lo(r),r=_i(e,r);let o=[],c=wt.openDBI(e,t);for(let{key:_,value:u}of c.getRange({start:s?void 0:!1,end:s?!1:void 0,limit:n,offset:i,reverse:s}))$t.searchAll(r,_,u,o);return o}a(QM,"searchAll");function WM(e,t,r,s=!1,n=void 0,i=void 0){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);return lo(r),r=_i(e,r),Zf(e,t,t,$t.searchAllToMap.bind(null,r),s,n,i)}a(WM,"searchAllToMap");function JM(e,t,r=!1,s=void 0,n=void 0){if(ft.validateEnv(e),t===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);return Zf(e,void 0,t,$t.iterateDBI,r,s,n)}a(JM,"iterateDBI");function ZM(e,t){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);return wt.statDBI(e,t).entryCount}a(ZM,"countAll");function XM(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=wt.openDBI(e,r);s=ft.convertKeyValueToWrite(s);let _=[[],[]];if(c[qr.DBI_DEFINITION_NAME].is_hash_attribute){t=r;let u=c.get(s,oi);u!==void 0&&$t.pushResults(s,u,_,t,r)}else for(let u of c.getValues(s,{reverse:n,limit:i,offset:o}))$t.pushResults(s,u,_,t,r);return _}a(XM,"equals");function zM(e,t,r){return Fr(e,t,r),wt.openDBI(e,t).getValuesCount(r)}a(zM,"count");function jM(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=[[],[]],_=wt.openDBI(e,r);_[qr.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r),s=ft.convertKeyValueToWrite(s);let u=!0;if(typeof s=="number"&&(u=!1),n===!0){let l;for(let E of _.getKeys({start:s}))if(!E.startsWith(s)){l=E;break}l!==void 0&&(Number.isInteger(o)?o++:i++);for(let{key:E,value:d}of _.getRange({start:l,end:void 0,reverse:n,limit:i,offset:o}))if(E!==l){if(E.toString().startsWith(s))$t.pushResults(E,d,c,t,r);else if(u===!0)break}}else for(let{key:l,value:E}of _.getRange({start:s,reverse:n,limit:i,offset:o}))if(l.toString().startsWith(s))$t.pushResults(l,E,c,t,r);else if(u===!0)break;return c}a(jM,"startsWith");function eP(e,t,r,s,n=!1,i=void 0,o=void 0){return Xf(e,t,r,s,n,i,o,!0)}a(eP,"endsWith");function Xf(e,t,r,s,n=!1,i=void 0,o=void 0,c=!1){Fr(e,r,s);let _=[[],[]],u=wt.openDBI(e,r);u[qr.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let l=Ku(e,t,r);o=Number.isInteger(o)?o:0;for(let d of u.getKeys({end:n?!1:void 0,reverse:n})){if(i===0)break;let h=d.toString();if(h.endsWith(Jf))for(let m of u.getValues(d)){let R=l(d,m);(c?R.endsWith(s):R.includes(s))&&E(R,m)}else if(c?h.endsWith(s):h.includes(s))if(u[qr.DBI_DEFINITION_NAME].is_hash_attribute)E(d,d);else for(let m of u.getValues(d))E(d,m)}function E(d,h){if(o>0){o--;return}i!==0&&($t.pushResults(d,h,_,t,r),i--)}return a(E,"found_match"),_}a(Xf,"contains");function tP(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=typeof s,_;return c==="string"?_="\uFFFF":c==="number"?_=1/0:c==="boolean"&&(_=!0),ci(e,t,r,s,_,n,i,o,!0,!1)}a(tP,"greaterThan");function rP(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=typeof s,_;return c==="string"?_="\uFFFF":c==="number"?_=1/0:c==="boolean"&&(_=!0),ci(e,t,r,s,_,n,i,o,!1,!1)}a(rP,"greaterThanEqual");function sP(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=typeof s,_;return c==="string"?_="\0":c==="number"?_=-1/0:c==="boolean"&&(_=!1),ci(e,t,r,_,s,n,i,o,!1,!0)}a(sP,"lessThan");function nP(e,t,r,s,n=!1,i=void 0,o=void 0){Fr(e,r,s);let c=typeof s,_;return c==="string"?_="\0":c==="number"?_=-1/0:c==="boolean"&&(_=!1),ci(e,t,r,_,s,n,i,o,!1,!1)}a(nP,"lessThanEqual");function iP(e,t,r,s,n,i=!1,o=void 0,c=void 0){if(ft.validateEnv(e),r===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);if(s===void 0)throw new Error(ce.START_VALUE_REQUIRED);if(n===void 0)throw new Error(ce.END_VALUE_REQUIRED);if(s=ft.convertKeyValueToWrite(s),n=ft.convertKeyValueToWrite(n),s>n)throw new Error(ce.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return ci(e,t,r,s,n,i,o,c)}a(iP,"between");function aP(e,t,r,s){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(lo(r),r=_i(e,r),s===void 0)throw new Error(ce.ID_REQUIRED);let n=null,i=e.dbis[t].get(s,r.length<3?oi:void 0);return i&&(n=$t.parseRow(i,r)),n}a(aP,"searchByHash");function oP(e,t,r){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ce.ID_REQUIRED);let s=!0;return e.dbis[t].get(r,oi)===void 0&&(s=!1),s}a(oP,"checkHashExists");function cP(e,t,r,s,n=[]){jf(e,t,r,s,n);let i=zf(e,t,r,s,n);return Object.values(i)}a(cP,"batchSearchByHash");function _P(e,t,r,s,n=[]){return jf(e,t,r,s,n),zf(e,t,r,s,n)}a(_P,"batchSearchByHashToMap");function zf(e,t,r,s,n=[]){r=_i(e,r);let i=Object.create(null),o=r.length<3?oi:void 0;for(let c=0;c<s.length;c++){let _=s[c];try{let u=e.dbis[t].get(_,o);if(u){let l=$t.parseRow(u,r);i[_]=l}else n.push(_)}catch(u){throw $M.warn(u),u}}return i}a(zf,"batchHashSearch");function jf(e,t,r,s,n){if(ft.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(lo(r),!Array.isArray(s))throw s===void 0?new Error(ce.IDS_REQUIRED):new Error(ce.IDS_MUST_BE_ARRAY);Array.isArray(n)||(n=[])}a(jf,"initializeBatchSearchByHash");function lo(e){if(!Array.isArray(e))throw e===void 0?new Error(ce.FETCH_ATTRIBUTES_REQUIRED):new Error(ce.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(lo,"validateFetchAttributes");function Fr(e,t,r){if(ft.validateEnv(e),t===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ce.SEARCH_VALUE_REQUIRED);if(r?.length>KM)throw new Error(ce.SEARCH_VALUE_TOO_LARGE)}a(Fr,"validateComparisonFunctions");function _i(e,t){return t.length===1&&YM.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wt.listDBIs(e)),t}a(_i,"setGetWholeRowAttributes");eT.exports={searchAll:QM,searchAllToMap:WM,count:zM,countAll:ZM,equals:XM,startsWith:jM,endsWith:eP,contains:Xf,searchByHash:aP,setGetWholeRowAttributes:_i,batchSearchByHash:cP,batchSearchByHashToMap:_P,checkHashExists:oP,iterateDBI:JM,greaterThan:tP,greaterThanEqual:rP,lessThan:sP,lessThanEqual:nP,between:iP}});var ui=S((XJ,nT)=>{var tT=require("lodash"),rT=de(),Q=require("joi"),uP=b(),{hdb_schema_table:Yt,checkValidTable:sT}=Tr(),{handleHDBError:lP,hdb_errors:EP}=D(),{HTTP_STATUS_CODES:dP}=EP,ZJ=Q.object({schema:Yt,table:Yt,hash_values:Q.array().min(1).items(Q.alternatives(Q.string(),Q.number())).required(),get_attributes:Q.array().min(1).items(Yt).required()}),hP=Q.object({schema:Yt,table:Yt,search_attribute:Yt,search_value:Q.any().required(),get_attributes:Q.array().min(1).items(Yt).required(),desc:Q.bool(),limit:Q.number().integer().min(1),offset:Q.number().integer().min(0)}),SP=Q.object({schema:Yt,table:Yt,operator:Q.string().valid("and","or").default("and").lowercase(),offset:Q.number().integer().min(0),limit:Q.number().integer().min(1),get_attributes:Q.array().min(1).items(Yt).required(),conditions:Q.array().min(1).items(Q.object({search_attribute:Yt,search_type:Q.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between").required(),search_value:Q.when("search_type",{switch:[{is:"equals",then:Q.any()},{is:"between",then:Q.array().items(Q.alternatives([Q.string(),Q.number()])).length(2)}],otherwise:Q.alternatives(Q.string(),Q.number())}).required()})).required()});nT.exports=function(e,t){let r=null;switch(t){case"value":r=rT.validateBySchema(e,hP);break;case"hashes":let i=function(o){n?n+=". "+o:n=o};var s=i;a(i,"addError");let n;i(sT("schema",e.schema)),i(sT("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"),n&&(r=new Error(n.trim()));break;case"conditions":r=rT.validateBySchema(e,SP);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let n=uP.checkGlobalSchemaTable(e.schema,e.table);if(n)return lP(new Error,n,dP.NOT_FOUND);let o=global.hdb_schema[e.schema][e.table].attributes,c=[...e.get_attributes];if(t==="value"&&c.push(e.search_attribute),t==="conditions")for(let u=0,l=e.conditions.length;u<l;u++){let E=e.conditions[u];c.push(E.search_attribute)}let _=tT.filter(c,u=>u!=="*"&&u.attribute!=="*"&&!tT.some(o,l=>l===u||l.attribute===u||l.attribute===u.attribute));if(_&&_.length>0){let u=_.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var Qu=S((zJ,iT)=>{"use strict";var fP=Z(),TP=ui(),mP=require("path"),{getBaseSchemaPath:RP}=te();iT.exports=AP;function AP(e){let t=TP(e,"hashes");if(t)throw t;let r=mP.join(RP(),e.schema.toString());return fP.openEnvironment(r,e.table)}a(AP,"initialize")});var Wu=S((jJ,aT)=>{"use strict";var OP=nn(),pP=Qu();aT.exports=NP;async function NP(e){try{let t=await pP(e),r=global.hdb_schema[e.schema][e.table];return OP.batchSearchByHashToMap(t,r.hash_attribute,e.get_attributes,e.hash_values)}catch(t){throw t}}a(NP,"lmdbGetDataByHash")});var ds=S((eZ,oT)=>{"use strict";var Eo=class{constructor(t,r,s,n){this.schema=t,this.table=r,this.hash_values=s,this.get_attributes=n}};a(Eo,"SearchByHashObject");oT.exports=Eo});var _T=S((rZ,cT)=>{"use strict";var tZ=ds(),gP=nn(),IP=Qu();cT.exports=bP;async function bP(e){try{let t=await IP(e),r=global.hdb_schema[e.schema][e.table];return gP.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}catch(t){throw t}}a(bP,"lmdbSearchByHash")});var Kt=S((sZ,uT)=>{"use strict";var ho=class{constructor(t,r,s,n,i,o,c,_=!1,u=void 0,l=void 0){this.schema=t,this.table=r,this.search_attribute=s,this.search_value=n,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=_,this.limit=u,this.offset=l}};a(ho,"SearchObject");uT.exports=ho});var So=S((nZ,ST)=>{"use strict";var We=nn(),CP=Z(),wP=require("path"),LP=b(),U=Ye(),hs=T(),{getBaseSchemaPath:UP}=te(),yP=is(),lT=Ke().LMDB_ERRORS_ENUM,{compareKeys:an}=require("ordered-binary"),Rr=hs.SEARCH_WILDCARDS;async function DP(e,t,r){let s;e.schema===hs.SYSTEM_SCHEMA_NAME?s=yP[e.table]:s=global.hdb_schema[e.schema][e.table];let n=hT(e,s.hash_attribute,r,t);return ET(e,n,s.hash_attribute,r)}a(DP,"prepSearch");async function ET(e,t,r,s){let n=wP.join(UP(),e.schema.toString()),i=await CP.openEnvironment(n,e.table),o=dT(i,e,t,r);if([U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,U.SEARCH_TYPES.SEARCH_ALL,U.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(BP(e,r)===!1)return s===!0?PP(o):o[1];let _=o[0];return s===!0?We.batchSearchByHashToMap(i,r,e.get_attributes,_):We.batchSearchByHash(i,r,e.get_attributes,_)}a(ET,"executeSearch");function dT(e,t,r,s){let n,i=s;t.get_attributes.indexOf(s)<0&&(i=void 0);let{reverse:o,limit:c,offset:_}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,_=Number.isInteger(_)?_:void 0,r){case U.SEARCH_TYPES.EQUALS:n=We.equals(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.CONTAINS:n=We.contains(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.ENDS_WITH:case U.SEARCH_TYPES._ENDS_WITH:n=We.endsWith(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.STARTS_WITH:case U.SEARCH_TYPES._STARTS_WITH:n=We.startsWith(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return We.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return We.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case U.SEARCH_TYPES.SEARCH_ALL:return We.searchAll(e,s,t.get_attributes,o,c,_);case U.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return We.searchAllToMap(e,s,t.get_attributes,o,c,_);case U.SEARCH_TYPES.BETWEEN:n=We.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,_);break;case U.SEARCH_TYPES.GREATER_THAN:case U.SEARCH_TYPES._GREATER_THAN:n=We.greaterThan(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.GREATER_THAN_EQUAL:case U.SEARCH_TYPES._GREATER_THAN_EQUAL:n=We.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.LESS_THAN:case U.SEARCH_TYPES._LESS_THAN:n=We.lessThan(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.LESS_THAN_EQUAL:case U.SEARCH_TYPES._LESS_THAN_EQUAL:n=We.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,_);break;default:return Object.create(null)}return n}a(dT,"searchByType");function MP(e){let t=e.search_type,r=e.search_attribute,s=e.search_value;switch(t){case U.SEARCH_TYPES.EQUALS:return n=>n[r]===s;case U.SEARCH_TYPES.CONTAINS:return n=>typeof n[r]=="string"&&n[r].includes(s);case U.SEARCH_TYPES.ENDS_WITH:case U.SEARCH_TYPES._ENDS_WITH:return n=>typeof n[r]=="string"&&n[r].endsWith(s);case U.SEARCH_TYPES.STARTS_WITH:case U.SEARCH_TYPES._STARTS_WITH:return n=>typeof n[r]=="string"&&n[r].startsWith(s);case U.SEARCH_TYPES.BETWEEN:return n=>{let i=n[r];return an(i,s[0])>=0&&an(i,s[1])<=0};case U.SEARCH_TYPES.GREATER_THAN:case U.SEARCH_TYPES._GREATER_THAN:return n=>an(n[r],s)>0;case U.SEARCH_TYPES.GREATER_THAN_EQUAL:case U.SEARCH_TYPES._GREATER_THAN_EQUAL:return n=>an(n[r],s)>=0;case U.SEARCH_TYPES.LESS_THAN:case U.SEARCH_TYPES._LESS_THAN:return n=>an(n[r],s)<0;case U.SEARCH_TYPES.LESS_THAN_EQUAL:case U.SEARCH_TYPES._LESS_THAN_EQUAL:return n=>an(n[r],s)<=0;default:return Object.create(null)}}a(MP,"filterByType");function PP(e){let t=Object.create(null);for(let r=0,s=e[0].length;r<s;r++)t[e[0][r]]=e[1][r];return t}a(PP,"createMapFromArrays");function BP(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 s=!1;for(let n=0;n<e.get_attributes.length;n++)if(r.indexOf(e.get_attributes[n])<0){s=!0;break}return s}a(BP,"checkToFetchMore");function hT(e,t,r,s){if(LP.isEmpty(s)){let n=e.search_value;typeof n=="object"?n=JSON.stringify(n):n=n.toString();let i=n.charAt(0),o=n.charAt(n.length-1),c=!1;if(e.search_attribute===t&&(c=!0),Rr.indexOf(n)>-1)return r===!0?U.SEARCH_TYPES.SEARCH_ALL_TO_MAP:U.SEARCH_TYPES.SEARCH_ALL;if(n.indexOf(Rr[0])<0&&n.indexOf(Rr[1])<0)return c===!0?r===!0?U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:U.SEARCH_TYPES.EQUALS;if(Rr.indexOf(i)>=0&&Rr.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),U.SEARCH_TYPES.CONTAINS;if(Rr.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),U.SEARCH_TYPES.ENDS_WITH;if(Rr.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),U.SEARCH_TYPES.STARTS_WITH;if(n.includes(Rr[0])||n.includes(Rr[1]))return U.SEARCH_TYPES.EQUALS;throw new Error(lT.UNKNOWN_SEARCH_TYPE)}else switch(s){case hs.VALUE_SEARCH_COMPARATORS.BETWEEN:return U.SEARCH_TYPES.BETWEEN;case hs.VALUE_SEARCH_COMPARATORS.GREATER:return U.SEARCH_TYPES.GREATER_THAN;case hs.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return U.SEARCH_TYPES.GREATER_THAN_EQUAL;case hs.VALUE_SEARCH_COMPARATORS.LESS:return U.SEARCH_TYPES.LESS_THAN;case hs.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return U.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(lT.UNKNOWN_SEARCH_TYPE)}}a(hT,"createSearchTypeFromSearchObject");ST.exports={executeSearch:ET,createSearchTypeFromSearchObject:hT,prepSearch:DP,searchByType:dT,filterByType:MP}});var TT=S((aZ,fT)=>{"use strict";var iZ=Kt(),vP=ui(),HP=b(),GP=T(),qP=So();fT.exports=FP;async function FP(e,t){if(!HP.isEmpty(t)&&GP.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let s=vP(e,"value");if(s)throw s;let n=!0;try{return await qP.prepSearch(e,t,n)}catch(i){throw i}}a(FP,"lmdbGetDataByValue")});var on=S((cZ,mT)=>{"use strict";var oZ=Kt(),VP=ui(),kP=b(),xP=T(),$P=So();mT.exports=YP;async function YP(e,t){if(!kP.isEmpty(t)&&xP.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let s=VP(e,"value");if(s)throw s;let n=!1;try{return await $P.prepSearch(e,t,n)}catch(i){throw i}}a(YP,"lmdbSearchByValue")});var AT=S((uZ,RT)=>{"use strict";var _Z=Ye(),fo=class{constructor(t,r,s,n,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=s,this.limit=i,this.offset=o,this.conditions=n,this.operator=c}};a(fo,"SearchByConditionsObject");var To=class{constructor(t,r,s){this.search_attribute=t,this.search_type=r,this.search_value=s}};a(To,"SearchCondition");var mo=class{constructor(t,r){this.attribute=t,this.desc=r}};a(mo,"SortAttribute");RT.exports={SearchByConditionsObject:fo,SearchCondition:To,SortAttribute:mo}});var bT=S((EZ,IT)=>{"use strict";var lZ=AT().SearchByConditionsObject,KP=Kt(),QP=ui(),Ju=nn(),Ro=Ye(),gT=So(),WP=Yu(),OT=require("lodash"),{getBaseSchemaPath:JP}=te(),ZP=require("path"),XP=Z(),{handleHDBError:pT,hdb_errors:zP}=D(),{HTTP_STATUS_CODES:jP}=zP,eB=1e8,tB={lazy:!0};IT.exports=rB;async function rB(e){try{let t=QP(e,"conditions");if(t)throw pT(t,t.message,jP.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=ZP.join(JP(),e.schema.toString()),s=await XP.openEnvironment(r,e.table),n=global.hdb_schema[e.schema][e.table],i=OT.sortBy(e.conditions,o=>{if(o.estimated_count===void 0){let c=o.search_type;c===Ro.SEARCH_TYPES.EQUALS?o.estimated_count=Ju.count(s,o.search_attribute,o.search_value):c===Ro.SEARCH_TYPES.CONTAINS||c===Ro.SEARCH_TYPES.ENDS_WITH?o.estimated_count=1/0:o.estimated_count=eB}return o.estimated_count});if(!e.operator||e.operator.toLowerCase()==="and"){let[o]=await NT(s,e,i[0],n.hash_attribute),c=s.dbis[n.hash_attribute],_=i.slice(1).map(gT.filterByType),u=_.length,l=[],E=Ju.setGetWholeRowAttributes(s,e.get_attributes),d=e.offset>-1?e.offset:0,h=e.limit>-1?e.limit:1/0;e:for(let m of o){let R=c.get(m,tB);for(let w=0;w<u;w++)if(!_[w](R))continue e;if(d>0){d--;continue}if(h<=0)break;h--,l.push(WP.parseRow(R,E))}return l}else{let o=[],c=[];for(let _ of i){let[u]=await NT(s,e,_,n.hash_attribute);c.push(u)}if(o=OT.union(...c),e.limit>0||e.offset>0){let _=Number.isInteger(e.limit)?e.limit:o.length;o=o.splice(e.offset,_)}return Ju.batchSearchByHash(s,n.hash_attribute,e.get_attributes,o)}}catch(t){throw pT(t)}}a(rB,"lmdbSearchByConditions");async function NT(e,t,r,s){let n=new KP(t.schema,t.table,void 0,void 0,s,t.get_attributes),i=r.search_type;return n.search_attribute=r.search_attribute,i===Ro.SEARCH_TYPES.BETWEEN?(n.search_value=r.search_value[0],n.end_value=r.search_value[1]):n.search_value=r.search_value,gT.searchByType(e,n,i,s)}a(NT,"executeConditionSearch")});var li=S((dZ,CT)=>{"use strict";var sB=T().OPERATIONS_ENUM,Ao=class{constructor(t,r,s,n=void 0){this.operation=sB.DELETE,this.schema=t,this.table=r,this.hash_values=s,this.__origin=n}};a(Ao,"DeleteObject");CT.exports=Ao});var Zu=S((hZ,wT)=>{"use strict";var Oo=class{constructor(t,r,s){this.schema=t,this.table=r,this.attribute=s}};a(Oo,"DropAttributeObject");wT.exports=Oo});var zu=S((fZ,LT)=>{"use strict";var nB=Kt(),iB=li(),SZ=Zu(),er=T(),aB=b(),Xu=Z(),oB=is(),cB=on(),_B=ai(),{getBaseSchemaPath:uB}=te(),lB=require("path");LT.exports=EB;async function EB(e,t=!0){let r;e.schema===er.SYSTEM_SCHEMA_NAME?r=oB[e.table]:r=global.hdb_schema[e.schema][e.table];let s=await hB(e),n=lB.join(uB(),e.schema.toString()),i=await Xu.openEnvironment(n,e.table);return t===!0&&await dB(e,i,r.hash_attribute),Xu.dropDBI(i,e.attribute),s}a(EB,"lmdbDropAttribute");async function dB(e,t,r){let s=Xu.openDBI(t,r),n,i=e.attribute;for(let{key:o,value:c,version:_}of s.getRange({start:!1,versions:!0})){let u={};for(let l in c)l!==i&&(u[l]=c[l]);n=t.dbis[r].put(o,u,_)}await n}a(dB,"removeAttributeFromAllObjects");async function hB(e){let t=new nB(er.SYSTEM_SCHEMA_NAME,er.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,er.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[er.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,er.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),s=(await cB(t)).filter(o=>o[er.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(aB.isEmptyOrZeroLength(s))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let n=s.map(o=>o[er.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new iB(er.SYSTEM_SCHEMA_NAME,er.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);return _B(i)}a(hB,"dropAttributeFromSystem")});var MT=S((TZ,DT)=>{"use strict";var SB=zu(),fB=Zu(),UT=b(),yT=I(),TB=Ke().LMDB_ERRORS_ENUM;DT.exports=mB;async function mB(e){if(UT.isEmpty(global.hdb_schema[e.schema])||UT.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);let t=global.hdb_schema[e.schema][e.table],r;try{for(let s=0;s<t.attributes.length;s++){r=t.attributes[s].attribute;let n=new fB(e.schema,e.table,r);try{await SB(n,!1)}catch(i){i.message!==TB.DBI_DOES_NOT_EXIST&&yT.error(`unable to drop attribute ${e.schema}.${e.table}.${r}:`+i)}}}catch(s){throw yT.error(`Error dropping attribute ${r}`),s}}a(mB,"lmdbDropAllAttributes")});var ju=S((RZ,kT)=>{"use strict";var GT=Kt(),qT=li(),FT=on(),VT=ai(),mZ=MT(),at=T(),PT=b(),BT=Z(),{getBaseSchemaPath:RB,getTransactionAuditStorePath:AB}=te(),vT=require("path"),HT=I();kT.exports=OB;async function OB(e){try{if(PT.isEmpty(global.hdb_schema[e.schema])||PT.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await pB(e),await NB(e);let t=vT.join(RB(),e.schema.toString());try{await BT.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")HT.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=vT.join(AB(),e.schema.toString());await BT.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")HT.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(OB,"lmdbDropTable");async function pB(e){let t=new GT(at.SYSTEM_SCHEMA_NAME,at.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=await FT(t),s=[];for(let i=0;i<r.length;i++){let o=r[i];s.push(o.id)}if(s.length===0)return;let n=new qT(at.SYSTEM_SCHEMA_NAME,at.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);await VT(n)}a(pB,"deleteAttributesFromSystem");async function NB(e){let t=new GT(at.SYSTEM_SCHEMA_NAME,at.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,at.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,s;try{r=await FT(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&&(s=o)}if(!s)throw new Error(`${e.schema}.${e.table} was not found`);let n=new qT(at.SYSTEM_SCHEMA_NAME,at.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[s.id]);try{await VT(n)}catch(i){throw i}}a(NB,"dropTableFromSystem")});var $T=S((OZ,xT)=>{"use strict";var gB=require("fs-extra"),IB=Kt(),bB=ds(),CB=li(),wB=ju(),LB=ai(),UB=Wu(),yB=on(),Ar=T(),AZ=b(),DB=require("path"),{getBaseSchemaPath:MB}=te(),{handleHDBError:PB,hdb_errors:BB}=D(),{HDB_ERROR_MSGS:vB,HTTP_STATUS_CODES:HB}=BB;xT.exports=GB;async function GB(e){let t;try{t=await qB(e.schema);let r=new IB(Ar.SYSTEM_SCHEMA_NAME,Ar.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),s=await yB(r);for(let o=0;o<s.length;o++){let c={schema:t,table:s[o].name};try{await wB(c)}catch(_){if(_.message!=="invalid environment")throw _}}let n=new CB(Ar.SYSTEM_SCHEMA_NAME,Ar.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await LB(n);let i=DB.join(MB(),t.toString());await gB.remove(i)}catch(r){throw r}}a(GB,"lmdbDropSchema");async function qB(e){let t=new bB(Ar.SYSTEM_SCHEMA_NAME,Ar.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ar.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,s;try{r=await UB(t)}catch(n){throw n}for(let n in r)r[n].name===e&&(s=e);if(!s)throw PB(new Error,vB.SCHEMA_NOT_FOUND(e),HB.NOT_FOUND,void 0,void 0,!0);return s}a(qB,"validateDropSchema")});var el=S((pZ,YT)=>{"use strict";var po=class{constructor(t,r,s){this.schema=t,this.table=r,this.hash_attribute=s}};a(po,"CreateTableObject");YT.exports=po});var QT=S((gZ,KT)=>{"use strict";var FB=require("path"),VB=require("fs-extra"),No=Z(),{getTransactionAuditStorePath:kB}=te(),tl=Ye(),NZ=el();KT.exports=xB;async function xB(e){let t;try{let r=FB.join(kB(),e.schema.toString());await VB.mkdirp(r),t=await No.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{No.createDBI(t,tl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),No.createDBI(t,tl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),No.createDBI(t,tl.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(xB,"createTransactionsAuditEnvironment")});var XT=S((IZ,ZT)=>{"use strict";var rl=T(),WT=Z(),$B=Xs(),YB=require("path"),{getSystemSchemaPath:KB,getBaseSchemaPath:QB}=te(),WB=is(),JB=Za(),sl=Ja(),ZB=I(),XB=QT(),il=WB.hdb_table,JT=[];for(let e=0;e<il.attributes.length;e++)JT.push(il.attributes[e].attribute);ZT.exports=zB;async function zB(e,t){let r=YB.join(QB(),t.schema.toString()),s=new sl(t.schema,t.table,rl.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),n=new sl(t.schema,t.table,rl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new sl(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await WT.createEnvironment(r,t.table),e!==void 0){let o=await WT.openEnvironment(KB(),rl.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await $B.insertRecords(o,il.hash_attribute,JT,[e]),await nl(s),await nl(n),await nl(i)}await XB(t)}catch(o){throw o}}a(zB,"lmdbCreateTable");async function nl(e){try{await JB(e)}catch(t){ZB.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(nl,"createAttribute")});var jT=S((bZ,zT)=>{"use strict";var jB=Xa(),ev=eo(),tv=so(),cn=T(),rv=Xs().updateRecords,sv=Z(),nv=require("path"),{getBaseSchemaPath:iv}=te(),av=ii(),ov=I();zT.exports=cv;async function cv(e){try{let{schema_table:t,attributes:r}=jB(e);ev(e,r,t.hash_attribute),e.schema!==cn.SYSTEM_SCHEMA_NAME&&(r.includes(cn.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(cn.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(cn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(cn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await tv(e.hdb_auth_header,t,r),n=nv.join(iv(),e.schema.toString()),i=await sv.openEnvironment(n,e.table),o=await rv(i,t.hash_attribute,r,e.records,e[cn.CLUSTERING_FLAG]!==!0);try{await av(e,o)}catch(c){ov.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:s,txn_time:o.txn_time}}catch(t){throw t}}a(cv,"lmdbUpdateRecords")});var tm=S((CZ,em)=>{"use strict";var _v=T().OPERATIONS_ENUM,go=class{constructor(t,r,s,n=void 0){this.operation=_v.UPSERT,this.schema=t,this.table=r,this.records=s,this.__origin=n}};a(go,"UpsertObject");em.exports=go});var sm=S((LZ,rm)=>{"use strict";var wZ=tm(),uv=Xa(),lv=eo(),Ev=so(),_n=T(),dv=Xs().upsertRecords,hv=Z(),Sv=require("path"),{getBaseSchemaPath:fv}=te(),Tv=ii(),mv=I(),{handleHDBError:Rv,hdb_errors:Av}=D();rm.exports=Ov;async function Ov(e){let t;try{t=uv(e)}catch(_){throw Rv(_,_.message,Av.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:s}=t;lv(e,s,r.hash_attribute),e.schema!==_n.SYSTEM_SCHEMA_NAME&&(s.includes(_n.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||s.push(_n.TIME_STAMP_NAMES_ENUM.CREATED_TIME),s.includes(_n.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||s.push(_n.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Ev(e.hdb_auth_header,r,s),i=Sv.join(fv(),e.schema.toString()),o=await hv.openEnvironment(i,e.table),c=await dv(o,r.hash_attribute,s,e.records,e[_n.CLUSTERING_FLAG]!==!0);try{await Tv(e,c)}catch(_){mv.error(`unable to write transaction due to ${_.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:n,txn_time:c.txn_time}}a(Ov,"lmdbUpsertRecords")});var _m=S((UZ,cm)=>{"use strict";var pv=Kt(),nm=b(),im=I(),Nv=on(),am=T(),gv=xu().deleteRecords,Iv=Z(),bv=require("path"),{getBaseSchemaPath:Cv}=te(),{promisify:wv}=require("util"),Lv=wv(setTimeout),om=1e4,Uv=10;cm.exports=yv;async function yv(e){let t=global.hdb_schema[e.schema][e.table].hash_attribute;if(nm.isEmptyOrZeroLength(t))throw new Error(`Could not retrieve hash attribute for schema: ${e.schema} table: ${e.table}`);let r=Date.parse(e.date),s;try{let n=new pv(e.schema,e.table,am.TIME_STAMP_NAMES_ENUM.CREATED_TIME,r,void 0,[t]);s=await Nv(n,am.VALUE_SEARCH_COMPARATORS.LESS)}catch(n){throw im.error(`Error searching for date: ${e.date} in schema: ${e.schema} table: ${e.table}`),n}return nm.isEmptyOrZeroLength(s)?(im.trace("No records found to delete"),{message:"No records found to delete"}):await Dv(e,s,t)}a(yv,"lmdbDeleteRecordsBefore");async function Dv(e,t,r){let s=bv.join(Cv(),e.schema.toString()),n=await Iv.openEnvironment(s,e.table),i={message:"",deleted_hashes:[],skipped_hashes:[]};for(let o=0,c=t.length;o<c;o+=om){let _=t.slice(o,o+om),u=[];for(let l=0,E=_.length;l<E;l++)u.push(_[l][r]);try{let l=await gv(n,r,u);i.deleted_hashes=i.deleted_hashes.concat(l.deleted),i.skipped_hashes=i.skipped_hashes.concat(l.skipped)}catch(l){throw l}await Lv(Uv)}return i.message=`${i.deleted_hashes.length} of ${i.deleted_hashes.length+i.skipped_hashes.length} records successfully deleted`,i}a(Dv,"chunkDeletes")});var lm=S((yZ,um)=>{"use strict";var Io=class{constructor(t,r,s){this.schema=t,this.table=r,this.timestamp=s}};a(Io,"DeleteBeforeObject");um.exports=Io});var dm=S((DZ,Em)=>{"use strict";var bo=class{constructor(t=void 0,r=void 0,s=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=s}};a(bo,"DeleteAuditLogsBeforeResults");Em.exports=bo});var fm=S((PZ,Sm)=>{"use strict";var al=Z(),{getTransactionAuditStorePath:Mv}=te(),MZ=lm(),Pv=require("path"),Ei=Ye(),Bv=b(),hm=dm(),vv=require("util").promisify,Hv=vv(setTimeout),Gv=1e4,qv=100;Sm.exports=Fv;async function Fv(e){let t=Pv.join(Mv(),e.schema),r=await al.openEnvironment(t,e.table,!0),s=al.listDBIs(r);al.initializeDBIs(r,Ei.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,s);let n,i=new hm;do n=await Vv(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=n.start_timestamp),n.end_timestamp!==void 0&&(i.end_timestamp=n.end_timestamp),i.transactions_deleted+=n.transactions_deleted,await Hv(qv);while(n.transactions_deleted>0);return i}a(Fv,"deleteAuditLogsBefore");async function Vv(e,t){let r=new hm;try{let s=e.dbis[Ei.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let{key:i,value:o}of s.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),n=s.remove(i);let c=o[Ei.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Bv.isEmpty(c)||(n=e.dbis[Ei.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let _=0;_<o.hash_values.length;_++)n=e.dbis[Ei.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[_],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Gv)break}return await n,r}catch(s){throw s}}a(Vv,"deleteTransactions")});var Nm=S((BZ,pm)=>{"use strict";var ol=Z(),un=Ye(),Tm=_s(),cl=T(),mm=b(),{getTransactionAuditStorePath:kv}=te(),xv=require("path"),$v=nn(),Co=en(),Yv=I();pm.exports=Kv;async function Kv(e){let t=xv.join(kv(),e.schema),r=await ol.openEnvironment(t,e.table,!0),s=ol.listDBIs(r);ol.initializeDBIs(r,un.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,s);let n;switch(e.search_type){case cl.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Rm(r,e.search_values);case cl.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return n=global.hdb_schema[e.schema][e.table].hash_attribute,Wv(r,e.search_values,n);case cl.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return Qv(r,e.search_values);default:return Rm(r)}}a(Kv,"readAuditLog");function Rm(e,t=[0,Tm.getMicroTime()]){mm.isEmpty(t[0])&&(t[0]=0),mm.isEmpty(t[1])&&(t[1]=Tm.getMicroTime());let r=[];try{let s=e.dbis[un.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let i of s.getKeys({start:t[1]}))if(i!==t[1]){n=i;break}for(let{value:i}of s.getRange({start:t[0],end:n})){let o=Object.assign(new Co,i);r.push(o)}return r}catch(s){throw s}}a(Rm,"searchTransactionsByTimestamp");function Qv(e,t=[]){let r=new Map;for(let s=0;s<t.length;s++){let n=t[s],i=[];for(let o of e.dbis[un.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(n))i.push(o);r.set(n,Om(e,i))}return Object.fromEntries(r)}a(Qv,"searchTransactionsByUsername");function Wv(e,t,r){let s=new Map;for(let c=0,_=t.length;c<_;c++){let u=t[c],l=$v.equals(e,un.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,un.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let E=0,d=l[0].length;E<d;E++){let h=l[0][E],m=Number(h);s.has(m)?s.get(m).push(u.toString()):s.set(m,[u.toString()])}}let n=Array.from(s.keys()),i=Om(e,n),o=new Map;for(let c=0;c<i.length;c++){let _=i[c],u=_.timestamp,l=s.get(u);Am(_,"records",r,l,o),Am(_,"original_records",r,l,o)}return Object.fromEntries(o)}a(Wv,"searchTransactionsByHashValues");function Am(e,t,r,s,n){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],_=c[r].toString();if(s.indexOf(_)>=0)if(n.has(_)){let u=n.get(_),l=u[u.length-1];if(l.timestamp===i)l[t]=[c];else{let E=new Co(e.operation,e.user_name,i,void 0);E[t]=[c],u.push(E)}}else{let u=new Co(e.operation,e.user_name,i,void 0);u[t]=[c],n.set(_,[u])}}}a(Am,"loopRecords");function Om(e,t){let r=[];try{let s=e.dbis[un.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let n=0;n<t.length;n++)try{let i=s.get(t[n]);if(i){let o=Object.assign(new Co,i);r.push(o)}}catch(i){Yv.warn(i)}return r}catch(s){throw s}}a(Om,"batchSearchTransactions")});var Im=S((vZ,gm)=>{"use strict";var Jv=require("path"),{getBaseSchemaPath:Zv}=te(),Xv=Z();gm.exports={writeTransaction:zv};async function zv(e,t,r){let s=Jv.join(Zv(),e);return(await Xv.openEnvironment(s,t)).transaction(r)}a(zv,"writeTransaction")});var Cm=S((HZ,bm)=>{"use strict";var jv=require("path"),{getBaseSchemaPath:eH}=te(),tH=Z();bm.exports={flush:rH};async function rH(e,t){let r=jv.join(eH(),e.toString());return(await tH.openEnvironment(r,t.toString())).flushed}a(rH,"flush")});var Lm=S((GZ,wm)=>{"use strict";var Re=I(),{handleHDBError:sH}=D(),nH=Eu(),iH=Za(),aH=Fu(),oH=Ff(),cH=ai(),_H=Wu(),uH=_T(),lH=TT(),EH=on(),dH=bT(),hH=$T(),SH=XT(),fH=jT(),TH=sm(),mH=_m(),RH=fm(),AH=ju(),OH=zu(),pH=Nm(),NH=Im(),gH=Cm(),wo=class extends nH{async searchByConditions(t){try{return dH(t)}catch(r){throw Re.error(r),r}}async getDataByHash(t){try{return await _H(t)}catch(r){throw Re.error(r),r}}async searchByHash(t){try{return await uH(t)}catch(r){throw Re.error(r),r}}async getDataByValue(t,r){try{return await lH(t,r)}catch(s){throw Re.error(s),s}}async searchByValue(t){try{return await EH(t)}catch(r){throw Re.error(r),r}}async createSchema(t){try{return await oH(t)}catch(r){throw Re.error(r),r}}async dropSchema(t){try{return await hH(t)}catch(r){throw Re.error(r),r}}async createTable(t,r){try{return await SH(t,r)}catch(s){throw Re.error(s),s}}async dropTable(t){try{return await AH(t)}catch(r){throw Re.error(r),r}}async createAttribute(t){try{return await iH(t)}catch(r){throw Re.error(r),r}}async createRecords(t){try{return await aH(t)}catch(r){throw Re.error(r),r}}async updateRecords(t){try{return await fH(t)}catch(r){throw Re.error(r),r}}async upsertRecords(t){try{return await TH(t)}catch(r){throw sH(r,null,null,Re.ERR,r)}}async deleteRecords(t){try{return await cH(t)}catch(r){throw Re.error(r),r}}async deleteRecordsBefore(t){try{return await mH(t)}catch(r){throw Re.error(r),r}}async dropAttribute(t){try{return await OH(t)}catch(r){throw Re.error(r),r}}async deleteAuditLogsBefore(t){try{return await RH(t)}catch(r){throw Re.error(r),r}}async readAuditLog(t){try{return await pH(t)}catch(r){throw Re.error(r),r}}writeTransaction(t,r,s){return NH.writeTransaction(t,r,s)}flush(t,r){return gH.flush(t,r)}};a(wo,"LMDBBridge");wm.exports=wo});var Or=S((qZ,ym)=>{"use strict";var IH=Lm(),bH=Eu(),CH=Y();CH.initSync();var Um;function wH(){return Um instanceof bH?Um:new IH}a(wH,"getBridge");ym.exports=wH()});var Bm=S((FZ,Pm)=>{"use strict";var Dm=require("lodash"),di=require("mathjs"),LH=require("jsonata"),Mm=b();Pm.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?Dm.uniqWith(e,Dm.isEqual):e,searchJSON:UH,mad:hi.bind(null,di.mad),mean:hi.bind(null,di.mean),mode:hi.bind(null,di.mode),prod:hi.bind(null,di.prod),median:hi.bind(null,di.median)};function hi(e,t,r,s){return s===1?t==null?[]:[t]:s===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(hi,"aggregateFunction");function UH(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(Mm.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Mm.isEmpty(this.__ala__.res[r])){let s=LH(e);this.__ala__.res[r]=s}return this.__ala__.res[r].evaluate(t)}a(UH,"searchJSON")});var Hm=S((VZ,vm)=>{"use strict";var he=require("moment"),_l="YYYY-MM-DDTHH:mm:ss.SSSZZ";he.suppressDeprecationWarnings=!0;vm.exports={current_date:()=>he().utc().format("YYYY-MM-DD"),current_time:()=>he().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return he(e).utc().format("YYYY");case"month":return he(e).utc().format("MM");case"day":return he(e).utc().format("DD");case"hour":return he(e).utc().format("HH");case"minute":return he(e).utc().format("mm");case"second":return he(e).utc().format("ss");case"millisecond":return he(e).utc().format("SSS");default:break}},date:e=>he(e).utc().format(_l),date_format:(e,t)=>he(e).utc().format(t),date_add:(e,t,r)=>he(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>he(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let s=he(e).utc(),n=he(t).utc();return r?s.diff(n,r,!0):s.diff(n)},now:()=>he().utc().valueOf(),get_server_time:()=>he().format(_l),offset_utc:(e,t)=>he(e).utc().utcOffset(t).format(_l)}});var Vm=S((kZ,Fm)=>{"use strict";var yH=require("@turf/area"),DH=require("@turf/length"),MH=require("@turf/circle"),PH=require("@turf/difference"),BH=require("@turf/distance"),vH=require("@turf/boolean-contains"),HH=require("@turf/boolean-equal"),GH=require("@turf/boolean-disjoint"),qH=require("@turf/helpers"),Gm=T(),k=b();Fm.exports={geoArea:FH,geoLength:VH,geoCircle:kH,geoDifference:xH,geoDistance:qm,geoNear:$H,geoContains:YH,geoEqual:KH,geoCrosses:QH,geoConvert:WH};var ul="geo1 is required",ll="geo2 is required";function FH(e){if(k.isEmpty(e))throw new Error("geoJSON is required");return typeof e=="string"&&(e=k.autoCast(e)),yH.default(e)}a(FH,"geoArea");function VH(e,t){if(k.isEmpty(e))throw new Error("geoJSON is required");return typeof e=="string"&&(e=k.autoCast(e)),DH.default(e,{units:t||"kilometers"})}a(VH,"geoLength");function kH(e,t,r){if(k.isEmpty(e))throw new Error("point is required");if(k.isEmpty(t))throw new Error("radius is required");return typeof e=="string"&&(e=k.autoCast(e)),MH.default(e,t,{units:r||"kilometers"})}a(kH,"geoCircle");function xH(e,t){if(k.isEmpty(e))throw new Error("poly1 is required");if(k.isEmpty(t))throw new Error("poly2 is required");return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),PH(e,t)}a(xH,"geoDifference");function qm(e,t,r){if(k.isEmpty(e))throw new Error("point1 is required");if(k.isEmpty(t))throw new Error("point2 is required");return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),BH.default(e,t,{units:r||"kilometers"})}a(qm,"geoDistance");function $H(e,t,r,s){if(k.isEmpty(e))throw new Error("point1 is required");if(k.isEmpty(t))throw new Error("point2 is required");if(k.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),isNaN(r))throw new Error("distance must be a number");return qm(e,t,s)<=r}a($H,"geoNear");function YH(e,t){if(k.isEmpty(e))throw new Error(ul);if(k.isEmpty(e))throw new Error(ll);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),vH.default(e,t)}a(YH,"geoContains");function KH(e,t){if(k.isEmpty(e))throw new Error(ul);if(k.isEmpty(e))throw new Error(ll);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),HH.default(e,t)}a(KH,"geoEqual");function QH(e,t){if(k.isEmpty(e))throw new Error(ul);if(k.isEmpty(e))throw new Error(ll);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),!GH.default(e,t)}a(QH,"geoCrosses");function WH(e,t,r){if(k.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(k.isEmpty(t))throw new Error("geo_type is required");if(k.isEmpty(Gm.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Gm.GEO_CONVERSION_ENUM).join(",")}`);return qH[t](e,r)}a(WH,"geoConvert")});var Lo=S((xZ,km)=>{var Ss=Bm(),Tt=Hm(),tr=Vm();km.exports=e=>{e.aggr.mad=e.aggr.MAD=Ss.mad,e.aggr.mean=e.aggr.MEAN=Ss.mean,e.aggr.mode=e.aggr.MODE=Ss.mode,e.aggr.prod=e.aggr.PROD=Ss.prod,e.aggr.median=e.aggr.MEDIAN=Ss.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Ss.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Ss.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Tt.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Tt.current_time,e.fn.extract=e.fn.EXTRACT=Tt.extract,e.fn.date=e.fn.DATE=Tt.date,e.fn.date_format=e.fn.DATE_FORMAT=Tt.date_format,e.fn.date_add=e.fn.DATE_ADD=Tt.date_add,e.fn.date_sub=e.fn.DATE_SUB=Tt.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Tt.date_diff,e.fn.now=e.fn.NOW=Tt.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Tt.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Tt.get_server_time,e.fn.getdate=e.fn.GETDATE=Tt.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Tt.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=tr.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=tr.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=tr.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=tr.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=tr.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=tr.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=tr.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=tr.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=tr.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=tr.geoNear}});var Ym=S(($Z,$m)=>{"use strict";var Si=require("lodash"),Me=require("alasql");Me.options.cache=!1;var JH=Lo(),xm=require("clone"),Uo=require("recursive-iterator"),v=I(),G=b(),ln=Or(),ZH=T(),{hdb_errors:XH}=D(),zH="IS NULL",fi="There was a problem performing this search. Please check the logs and try again.";JH(Me);var yo=class{constructor(t,r){if(G.isEmpty(t))throw v.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(),G.backtickASTSchemaItems(this.statement)}async search(){let t;try{let s=await this._checkEmptySQL();if(!G.isEmptyOrZeroLength(s))return v.trace("No results returned from checkEmptySQL SQLSearch method."),s}catch(s){throw v.error("Error thrown from checkEmptySQL in SQLSearch class method search."),v.error(s),new Error(fi)}try{let s=await this._getFetchAttributeValues();if(s)return s}catch(s){throw v.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),v.error(s),new Error(fi)}if(Object.keys(this.data).length===0)return v.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(s){throw v.error("Error thrown from processJoins in SQLSearch class method search."),v.error(s),new Error(fi)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(s){throw v.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),v.error(s),new Error(fi)}try{return t=await this._finalSQL(),t}catch(s){throw v.error("Error thrown from finalSQL in SQLSearch class method search."),v.error(s),new Error(fi)}}_getColumns(){let t=new Uo(this.statement);for(let{node:r,path:s}of t)r&&r.columnid&&(this.columns[s[0]]||(this.columns[s[0]]=[]),this.columns[s[0]].push(xm(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Si.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let s=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[s]={},this.data[s].__hash_name=global.hdb_schema[r.databaseid][r.tableid].hash_attribute,this.data[s].__merged_data={},this.data[s].__merged_attributes=[],this.data[s].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(G.isEmpty(this.statement.where)){v.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new Uo(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!G.isEmpty(r)&&r.right)if(G.isNotEmptyAndHasValue(r.right.value)){let s=G.autoCast(r.right.value);[!0,!1].indexOf(s)>=0?r.right=new Me.yy.LogicValue({value:s}):r.right instanceof Me.yy.StringValue&&!G.isEmpty(s)&&G.autoCasterIsNumberCheck(s.toString())&&(r.right=new Me.yy.NumValue({value:s}))}else Array.isArray(r.right)&&r.right.forEach((s,n)=>{let i=G.autoCast(s.value);[!0,!1].indexOf(i)>=0?r.right[n]=new Me.yy.LogicValue({value:i}):s instanceof Me.yy.StringValue&&G.autoCasterIsNumberCheck(i.toString())&&(r.right[n]=new Me.yy.NumValue({value:i}))});if(t){v.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new Uo(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let s=new Set,n=r.left.columnid?r.left:r.right,i=this._findColumn(n);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!G.isEmpty(ZH.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(G.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(G.isEmptyOrZeroLength(r.left.columnid)||G.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(G.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"=":!G.isEmpty(r.right.value)||!G.isEmpty(r.left.value)?s.add(G.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let _=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<_.length;u++)if(_[u].value)s.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,...s])}}}_setAliasesForColumns(){if(G.isEmptyOrZeroLength(this.all_table_attributes)&&G.isEmptyOrZeroLength(this.statement.from)&&G.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((s,n)=>{if(s.columnid==="*"){t.push(n);return}if(s.aggregatorid&&(this.has_aggregator=!0),!s.aggregatorid&&!s.funcid)if(s.as_orig=s.as?s.as:s.columnid,this.statement.joins)if(r[s.as_orig]>=0){let i=r[s.as_orig]+1;s.as=`[${s.as_orig+i}]`,r[s.as_orig]=i}else s.as=`[${s.as_orig}]`,r[s.as_orig]=0;else s.as=`[${s.as_orig}]`;!s.aggregatorid&&s.funcid&&s.args&&(s.as_orig=s.as?s.as:s.toString().replace(/'/g,'"'),s.as=`[${s.as_orig}]`),s.aggregatorid&&s.expression.columnid!=="*"&&(s.as_orig=s.as?s.as:s.expression.tableid?`${s.aggregatorid}(${s.expression.tableid}.${s.expression.columnid})`:`${s.aggregatorid}(${s.expression.columnid})`,s.as=`[${s.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&Si.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(s=>{if(t.columnid_orig&&t.tableid_orig)return(s.table.as===t.tableid_orig||s.table.tableid===t.tableid_orig)&&s.attribute===t.columnid_orig;if(t.tableid)return(s.table.as===t.tableid||s.table.tableid===t.tableid)&&s.attribute===t.columnid;let n=t.columnid_orig?t.columnid_orig:t.columnid;return s.attribute===n});if(G.isEmptyOrZeroLength(r)){let s=this.columns.columns.filter(n=>n.as?t.columnid===n.as:!1);G.isEmptyOrZeroLength(s)||(r=this.all_table_attributes.filter(n=>n.attribute===s[0].columnid&&s[0].tableid&&s[0].tableid===(n.table.as?n.table.as:n.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(G.isEmptyOrZeroLength(this.all_table_attributes)&&!G.isEmptyOrZeroLength(this.columns.columns))return t;if(G.isEmptyOrZeroLength(this.all_table_attributes)&&G.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Me.promise(r)}catch(r){throw v.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),v.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let s=this._findColumn(r);s&&this.fetch_attributes.push(xm(s))})}_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,s,n){let i=this.data[t].__merged_attr_map[s];this.data[t].__merged_data[r].splice(i,1,n)}async _getFetchAttributeValues(){if(G.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(zH)>-1&&this.tables.forEach(n=>{let i={columnid:global.hdb_schema[n.databaseid][n.tableid].hash_attribute,tableid:n.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Si.uniqBy(this.fetch_attributes,n=>[n.table.databaseid,n.table.as?n.table.as:n.table.tableid,n.attribute].join()),r)return await this._simpleSQLQuery();let s=this.fetch_attributes.reduce((n,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return n[o]||(n[o]=[],n[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(n[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),n},{});for(let n of this.fetch_attributes){let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,o=this.data[i].__hash_name,c={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]},_=!1,u=[n.table.databaseid,n.table.tableid,n.attribute].join("/");if(n.attribute===o&&(_=!0),!G.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!G.isEmptyOrZeroLength(this.exact_search_values[u].values))if(_)try{c.hash_values=Array.from(this.exact_search_values[u].values);let l=await ln.getDataByHash(c);for(let E of c.hash_values)E in l&&!this.data[i].__merged_data[E]&&(this.data[i].__merged_data[E]=[...s[i]],this._setMergedHashAttribute(i,E))}catch(l){v.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),v.error(l)}else try{c.search_attribute=n.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async l=>{let E=Object.assign({},c);E.search_value=l;let d=await ln.getDataByValue(E);for(let h in d)this.data[i].__merged_data[h]?this._updateMergedAttribute(i,h,n.attribute,d[h][n.attribute]):(this.data[i].__merged_data[h]=[...s[i]],this._updateMergedAttribute(i,h,n.attribute,d[h][n.attribute]),this._setMergedHashAttribute(i,G.autoCast(h)))}))}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),v.error(l)}else if(!G.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!G.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let l=this.comparator_search_values[u].comparators;for(let E=0,d=l.length;E<d;E++){let h=l[E];c.search_attribute=h.attribute,c.search_value=h.search_value;let m=await ln.getDataByValue(c,h.operation);if(_)for(let R in m)this.data[i].__merged_data[R]||(this.data[i].__merged_data[R]=[...s[i]],this._setMergedHashAttribute(i,G.autoCast(R)));else for(let R in m)this.data[i].__merged_data[R]?this._updateMergedAttribute(i,R,n.attribute,m[R][n.attribute]):(this.data[i].__merged_data[R]=[...s[i]],this._updateMergedAttribute(i,R,n.attribute,m[R][n.attribute]),this._setMergedHashAttribute(i,G.autoCast(R)))}}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),v.error(l)}else try{c.search_attribute=n.attribute,c.search_value="*";let l=await ln.getDataByValue(c);if(_)for(let E in l)this.data[i].__merged_data[E]||(this.data[i].__merged_data[E]=[...s[i]],this._setMergedHashAttribute(i,G.autoCast(E)));else for(let E in l)this.data[i].__merged_data[E]?this._updateMergedAttribute(i,E,n.attribute,l[E][n.attribute]):(this.data[i].__merged_data[E]=[...s[i]],this._updateMergedAttribute(i,E,n.attribute,l[E][n.attribute]),this._setMergedHashAttribute(i,G.autoCast(E)))}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),v.error(l)}}}_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 Me.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(n=>{let i=n.aggregatorid?n.expression:n,o=n.aggregatorid?n.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 s=r[0];if(t.is_func=!!s.funcid,t.is_aggregator=!!s.aggregatorid,s.as)if(s.as&&!t.expression.tableid)t.expression.columnid=s.as,t.expression.columnid_orig=s.as_orig;else{let n=new Me.yy.Column;n.columnid=s.as,n.columnid_orig=s.as_orig,t.expression=n}else{t.initial_select_column=Object.assign(new Me.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 n=t.is_func?new Me.yy.FuncValue:new Me.yy.Column;t.initial_select_column=Object.assign(n,s)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(s=>!s.is_aggregator&&!s.is_ordinal).map(s=>s.is_func?{columnid:s.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:s.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],s=this.statement.from[0],n=[s],i=["? "+(s.as?" AS "+s.as:s.tableid)];t.push(Object.values(this.data[`${s.databaseid_orig}_${s.as?s.as_orig:s.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),n.push(h.table);let m=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(m+=" ON "+h.on.toString()),i.push(m),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__merged_data))});let o=[],c={};n.forEach(h=>{let m=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hash_name,R=h.as?h.as_orig:h.tableid_orig;o.push({key:`'${R}.${m}'`,schema:h.databaseid_orig,table:h.as?h.as_orig:h.tableid_orig,keys:new Set}),r.push(`${h.as?h.as:h.tableid}.\`${m}\` AS "${R}.${m}"`),c[h.as?h.as_orig:h.tableid_orig]=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__merged_attributes});let _=this.statement.where?"WHERE "+this.statement.where:"",u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(h=>{h.is_func?r.push(h.initial_select_column.toString()):h.initial_select_column.tableid?r.push(`${h.initial_select_column.tableid}.${h.initial_select_column.columnid} AS ${h.expression.columnid}`):r.push(`${h.initial_select_column.columnid} AS ${h.expression.columnid}`)}));let l="",E="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",E=this.statement.offset?"OFFSET "+this.statement.offset:"");let d=[];try{let h=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${_} ${u} ${l} ${E}`,m=this._convertColumnsToIndexes(h,n);d=await Me.promise(m,t),t=null}catch(h){throw v.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),v.error(h),new Error("There was a problem processing the data.")}if(d&&d.length>0){for(let h=0,m=d.length;h<m;h++){let R=d[h];o.forEach(w=>{R[w.key]!==null&&R[w.key]!==void 0&&w.keys.add(R[w.key])})}o.forEach(h=>{let m=Object.keys(this.data[`${h.schema}_${h.table}`].__merged_data),R=Si.difference(m,[...h.keys].map(w=>w.toString()));for(let w=0,L=R.length;w<L;w++){let B=R[w];delete this.data[`${h.schema}_${h.table}`].__merged_data[B]}})}return{existing_attributes:c,joined_length:d?d.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let s=[],n=new Uo(this.columns);for(let{node:i}of n)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)&&s.push(o)}}s=Si.uniqBy(s,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(s)}catch(i){v.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),v.error(i)}}async _getData(t){try{let r=t.reduce((s,n)=>{let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`;return s[i]?s[i].columns.push(n.attribute):s[i]={schema:n.table.databaseid,table:n.table.tableid,columns:[n.attribute]},s},{});for(let s in r){let n=r[s],i=this.data[s].__merged_data,o=[];for(let l in i)o.push(i[l][0]);this.data[s].__merged_attributes.push(...n.columns);let c={schema:n.schema,table:n.table,hash_values:o,get_attributes:n.columns},_=await ln.getDataByHash(c),u=n.columns.length;for(let l=0,E=o.length;l<E;l++){let d=o[l],h=_[d];for(let m=0;m<u;m++){let R=n.columns[m],w=h[R]===void 0?null:h[R];this.data[s].__merged_data[d].push(w)}}}}catch(r){throw v.error("Error thrown from getDataByHash function in SQLSearch class method getData."),v.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(n=>{n.as=n.as?n.as:n.table.tableid,t.push(Object.values(this.data[`${n.table.databaseid_orig}_${n.table.as?n.table.as_orig:n.table.tableid_orig}`].__merged_data)),n.table.databaseid="",n.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(n=>{if(n.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,_=o.aggregatorid?o.as_orig:c.as_orig;return n.expression.tableid?c.columnid_orig===n.expression.columnid_orig&&c.tableid_orig===n.expression.tableid_orig:c.columnid_orig===n.expression.columnid_orig||n.expression.columnid_orig===_}).length===0&&(n.expression.columnid=n.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&(this.statement.limit&&delete this.statement.limit,this.statement.offset&&delete this.statement.offset);let s;try{let n=this._buildSQL();v.trace(`Final SQL: ${n}`),s=await Me.promise(n,t),this.has_outer_join&&(s=this._translateUndefinedValues(s)),v.trace(`Final AlaSQL results data included ${s.length} rows`)}catch(n){throw v.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),v.error(n),new Error("There was a problem running the generated sql.")}return s}_translateUndefinedValues(t){try{let r=[];for(let s of t){let n=Object.create(null);Object.keys(s).forEach(i=>{s[i]===void 0?n[i]=null:n[i]=s[i]}),r.push(n)}return r}catch(r){return v.error(XH.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),v.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return this.statement.columns.forEach(s=>{if(s.funcid&&s.as){let n=s.toString().replace(" AS "+s.as,"");r=r.replace(s.toString(),n)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let s=t,n={};r.forEach(i=>{i.databaseid_orig?n[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:n[`${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 _=n[i],u=new RegExp(`${_}.\`${o}\``,"g"),l=`${_}.[${c}]`;s=s.replace(u,l)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let _=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;s=s.replace(_,u)});return s}async _simpleSQLQuery(){let t=this.statement.columns.reduce((s,n)=>(n.as_orig&&n.as_orig!=n.columnid_orig?s[n.columnid_orig]=n.as_orig:s[n.columnid_orig]||(s[n.columnid_orig]=n.columnid_orig),s),{}),r=this.fetch_attributes.reduce((s,n)=>{let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`;return s[i]||(s[i]={}),s[i][t[n.attribute]]=null,s},{});for(let s of this.fetch_attributes){let n=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,i={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]};try{i.search_attribute=s.attribute,i.search_value="*";let o=await ln.getDataByValue(i);for(let c in o)this.data[n].__merged_data[c]||(this.data[n].__merged_data[c]=Object.assign({},r[n])),this.data[n].__merged_data[c][t[s.attribute]]=o[c][s.attribute]}catch(o){v.error("There was an error when processing this SQL operation. Check your logs"),v.error(o)}}return Object.values(Object.values(this.data)[0].__merged_data)}};a(yo,"SQLSearch");$m.exports=yo});var mt=S((YZ,Qm)=>{"use strict";var jH=sS();Qm.exports={searchByConditions:sG,searchByHash:nG,searchByValue:iG,search:aG};var El=Or(),Km=require("util"),eG=Km.callbackify(El.searchByHash),tG=Km.callbackify(El.searchByValue),rG=Ym();async function sG(e){return El.searchByConditions(e)}a(sG,"searchByConditions");function nG(e,t){try{eG(e,(r,s)=>{if(r){t(r);return}t(null,s)})}catch(r){return t(r)}}a(nG,"searchByHash");function iG(e,t){try{e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc),tG(e,(r,s)=>{if(r){t(r);return}t(null,s)})}catch(r){return t(r)}}a(iG,"searchByValue");function aG(e,t){try{let r=new jH(e);r.validate(),new rG(r.statement,r.attributes).search().then(n=>{t(null,n)}).catch(n=>{t(n,null)})}catch(r){return t(r)}}a(aG,"search")});var Vr=S((KZ,Xm)=>{"use strict";var Ti=require("crypto"),Jm="aes-256-cbc",oG=32,cG=16,dl=64,Zm=32,_G=dl+Zm,Wm=new Map;Xm.exports={encrypt:uG,decrypt:lG,createNatsTableStreamName:EG};function uG(e){let t=Ti.randomBytes(oG),r=Ti.randomBytes(cG),s=Ti.createCipheriv(Jm,Buffer.from(t),r),n=s.update(e);n=Buffer.concat([n,s.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=n.toString("hex");return i+o+c}a(uG,"encrypt");function lG(e){let t=e.substr(0,dl),r=e.substr(dl,Zm),s=e.substr(_G,e.length),n=Buffer.from(r,"hex"),i=Buffer.from(s,"hex"),o=Ti.createDecipheriv(Jm,Buffer.from(t,"hex"),n),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(lG,"decrypt");function EG(e,t){let r=`${e}.${t}`,s=Wm.get(r);return s||(s=Ti.createHash("md5").update(`${e}.${t}`).digest("hex"),Wm.set(r,s)),s}a(EG,"createNatsTableStreamName")});var fs=S((QZ,nR)=>{"use strict";var jm=mt(),kr=I(),eR=Ka(),dG=require("lodash"),hG=require("path"),SG=Vr(),hl=b(),{promisify:tR}=require("util"),j=T(),{handleHDBError:Do,hdb_errors:fG}=D(),{HDB_ERROR_MSGS:Mo,HTTP_STATUS_CODES:rR}=fG,TG=Y();TG.initSync();var zm=Z(),mG=te(),mi=tR(jm.searchByValue),RG=tR(jm.searchByHash),En="name",sR="hash_attribute",Sl="schema",AG="schema_table",OG="attribute";nR.exports={describeAll:pG,describeTable:Po,describeSchema:gG};async function pG(e){try{let t=hl.isEmptyOrZeroLength(e),r,s;t||(r=e.hdb_user.role.permission,s=r.super_user||r.cluster_user);let n={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,search_attribute:En,search_value:j.WILDCARD_SEARCH_VALUE,get_attributes:[En]},i=await mi(n);if(hl.isEmptyOrZeroLength(i))return{};let o={},c={};for(let d in i)o[i[d].name]=!0,!t&&!s&&(c[i[d].name]=r[i[d].name].describe);let _={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,search_attribute:j.ID_ATTRIBUTE_STRING,search_value:j.WILDCARD_SEARCH_VALUE,get_attributes:[sR,j.ID_ATTRIBUTE_STRING,En,Sl]},u=await mi(_),l=[];for(let d of u)try{let h;if(t||s)h=await Po({schema:d.schema,table:d.name});else if(r&&r[d.schema].describe&&r[d.schema].tables[d.name].describe){let m=r[d.schema].tables[d.name].attribute_permissions;h=await Po({schema:d.schema,table:d.name},m)}h&&l.push(h)}catch(h){kr.error(h)}let E={};for(let d in l)t||s?(E[l[d].schema]==null&&(E[l[d].schema]={}),E[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(E[l[d].schema]==null&&(E[l[d].schema]={}),E[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s?E[d]={}:c[d]&&(E[d]={});return E}catch(t){return kr.error("Got an error in describeAll"),kr.error(t),Do(new Error,Mo.DESCRIBE_ALL_ERR)}}a(pG,"describeAll");async function Po(e,t){let{schema:r,table:s}=e;r=r.toString(),s=s.toString();let n=t;e.hdb_user&&!e.hdb_user.role.permission.super_user&&(n=e.hdb_user.role.permission[r].tables[s].attribute_permissions);let i={},o=eR.describe_table(e);if(o)throw o;if(r===j.SYSTEM_SCHEMA_NAME)return global.hdb_schema[j.SYSTEM_SCHEMA_NAME][s];let c={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.TABLE_TABLE_HASH_ATTRIBUTE,search_attribute:En,search_value:s,hash_values:[],get_attributes:[j.WILDCARD_SEARCH_VALUE]},_=await mi(c);if(!_||_.length===0)throw Do(new Error,Mo.TABLE_NOT_FOUND(e.schema,e.table),rR.NOT_FOUND);for await(let u of _)try{if(u.schema!==r)continue;if(i=u,!i.hash_attribute)throw Do(new Error,Mo.INVALID_TABLE_ERR(i));let l={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.ATTRIBUTE_TABLE_HASH_ATTRIBUTE,search_attribute:AG,search_value:r+"."+s,get_attributes:[OG]},E=await mi(l);E=dG.uniqBy(E,d=>d.attribute),n&&n.length>0&&(E=NG(n)),i.attributes=E,i.clustering_stream_name=SG.createNatsTableStreamName(u.schema,u.name);try{let d=hG.join(mG.getBaseSchemaPath(),i.schema.toString()),h=await zm.openEnvironment(d,i.name),m=zm.statDBI(h,i.hash_attribute);i.record_count=m.entryCount}catch(d){kr.warn(`unable to stat table dbi due to ${d}`)}}catch(l){kr.error(`There was an error getting attributes for table '${u.name}'`),kr.error(l)}return i}a(Po,"descTable");function NG(e){return e.reduce((t,r)=>(r.describe&&t.push({attribute:r.attribute_name}),t),[])}a(NG,"getAttrsByPerms");async function gG(e){let t=eR.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 s=e.schema.toString(),n={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.TABLE_TABLE_HASH_ATTRIBUTE,search_attribute:Sl,search_value:s,hash_values:[],get_attributes:[sR,j.ID_ATTRIBUTE_STRING,En,Sl]},i=await mi(n);if(i&&i.length<1){let o={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.SCHEMA_TABLE_HASH_ATTRIBUTE,hash_values:[s],get_attributes:[En]},c=await RG(o);if(c&&c.length<1)throw Do(new Error,Mo.SCHEMA_NOT_FOUND(e.schema),rR.NOT_FOUND);return{}}else{let o={};return await Promise.all(i.map(async c=>{try{let _;if(r&&r.tables[c.name]&&(_=r.tables[c.name]),hl.isEmpty(_)||_.describe){let u=await Po({schema:e.schema,table:c.name},_?_.attribute_permissions:null);u&&(o[u.name]=u)}}catch(_){kr.error(`Error describing schema table '${e.schema}.${c}'`),kr.error(_)}})),o}}a(gG,"describeSchema")});var xr=S((ZZ,_R)=>{var WZ=require("async"),dn=is(),JZ=I(),{callbackify:oR,promisify:IG}=require("util");_R.exports={setSchemaDataToGlobal:iR,getTableSchema:wG,getSystemSchema:UG,setSchemaDataToGlobalAsync:IG(iR)};var cR=fs(),bG=oR(cR.describeAll),CG=oR(cR.describeTable);function iR(e){bG(null,(t,r)=>{if(t){e(t);return}r.system||(r.system=dn),global.hdb_schema=r,e(null,null)})}a(iR,"setSchemaDataToGlobal");function aR(e,t){return e==="system"?dn[t]:global.hdb_schema[e][t]}a(aR,"returnSchema");function wG(e,t,r){!global.hdb_schema||!global.hdb_schema[e]||!global.hdb_schema[e][t]?LG(e,t,s=>{if(s)return r(s);if(!global.hdb_schema[e])return r(`schema ${e} does not exist`);if(!global.hdb_schema[e]||!global.hdb_schema[e][t])return r(`table ${e}.${t} does not exist`);r(null,aR(e,t))}):r(null,aR(e,t))}a(wG,"getTableSchema");function LG(e,t,r){let s={table:t,schema:e};if(e==="system"){global.hdb_schema?global.hdb_schema.system=dn:global.hdb_schema={system:dn},r();return}CG(s,(n,i)=>{if(n){r(n);return}if(!i.schema&&!i.name){r();return}global.hdb_schema||(global.hdb_schema={system:dn}),global.hdb_schema[e]||(global.hdb_schema[e]={}),global.hdb_schema[e][t]=i,r()})}a(LG,"setTableDataToGlobal");function UG(){return dn}a(UG,"getSystemSchema")});var ER=S((XZ,lR)=>{"use strict";var fl=Z(),yG=I(),uR=Ke().LMDB_ERRORS_ENUM;lR.exports=DG;async function DG(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 fl.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==uR.ENV_REQUIRED)throw c}}break;case"drop_table":let s=`${e.schema}.${e.table}`,n=`txn.${s}`;try{await fl.closeEnvironment(global.lmdb_map[s]),await fl.closeEnvironment(global.lmdb_map[n])}catch(i){if(i.message!==uR.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){yG.error(t)}}a(DG,"cleanLMDBMap")});var Ut=S((zZ,SR)=>{"use strict";var vo=vu(),Lt=b(),MG=require("util"),Ho=Or(),PG=xr(),Tl=I(),{handleHDBError:$r,hdb_errors:BG}=D(),{HTTP_STATUS_CODES:Ts}=BG,vG=MG.promisify(PG.getTableSchema),HG="updated",dR="inserted",hR="upserted";SR.exports={insert:qG,update:FG,upsert:VG,validation:GG,flush:kG};async function GG(e){if(Lt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Lt.isEmptyOrZeroLength(e.schema))throw new Error("invalid schema specified.");if(Lt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await vG(e.schema,e.table),r=vo(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let s=t.hash_attribute,n=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Lt.isEmptyOrZeroLength(c[s]))throw Tl.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(!Lt.isEmptyOrZeroLength(c[s])&&(c[s]==="null"||c[s]==="undefined"))throw Tl.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[s]}" is not a valid hash attribute value`);!Lt.isEmpty(c[s])&&c[s]!==""&&n.has(Lt.autoCast(c[s]))&&(c.skip=!0),n.add(Lt.autoCast(c[s]));for(let _ in c)i[_]=1}),i[s]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(i)}}a(GG,"validation");async function qG(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=vo(e);if(t)throw $r(new Error,t.message,Ts.BAD_REQUEST);let r=Lt.checkSchemaTableExist(e.schema,e.table);if(r)throw $r(new Error,r,Ts.BAD_REQUEST);try{let s=await Ho.createRecords(e);return Bo(dR,s.written_hashes,e,s.skipped_hashes,s.new_attributes,s.txn_time)}catch(s){throw s}}a(qG,"insertData");async function FG(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=vo(e);if(t)throw $r(new Error,t.message,Ts.BAD_REQUEST);let r=Lt.checkSchemaTableExist(e.schema,e.table);if(r)throw $r(new Error,r,Ts.BAD_REQUEST);try{let s=await Ho.updateRecords(e);return Lt.isEmpty(s.existing_rows)?Bo(HG,s.written_hashes,e,s.skipped_hashes,s.new_attributes,s.txn_time):Bo(s.update_action,[],e,s.hashes,void 0,s.txn_time)}catch(s){throw s}}a(FG,"updateData");async function VG(e){if(e.operation!=="upsert")throw $r(new Error,"invalid operation, must be upsert",Ts.INTERNAL_SERVER_ERROR);let t=vo(e);if(t)throw $r(new Error,t.message,Ts.BAD_REQUEST);let r=Lt.checkSchemaTableExist(e.schema,e.table);if(r)throw $r(new Error,r,Ts.BAD_REQUEST);try{let s=await Ho.upsertRecords(e);return Bo(hR,s.written_hashes,e,[],s.new_attributes,s.txn_time)}catch(s){let n=`There was an error during an upsert op: ${s}`;throw $r(s,null,null,Tl.ERR,n)}}a(VG,"upsertData");function Bo(e,t,r,s,n,i){let o={message:`${e} ${t.length} of ${t.length+s.length} records`,new_attributes:n,txn_time:i};return e===dR?(o.inserted_hashes=t,o.skipped_hashes=s,o):e===hR?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=s,o)}a(Bo,"returnObject");function kG(e){return Ho.flush(e.schema,e.table)}a(kG,"flush")});var Rl=S((jZ,mR)=>{var xG=de(),ml=require("joi"),{hdb_schema_table:fR}=Tr(),TR={schema:fR,table:fR},$G={date:ml.date().iso().required()},YG={timestamp:ml.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};mR.exports=function(e,t){let r=t==="timestamp"?{...TR,...YG}:{...TR,...$G},s=ml.object(r);return xG.validateBySchema(e,s)}});var pR=S((eX,OR)=>{var KG=de(),RR=require("joi"),{hdb_schema_table:AR}=Tr(),QG=RR.object({schema:AR,table:AR,hash_values:RR.array().required()});OR.exports=function(e){return KG.validateBySchema(e,QG)}});var gR=S((tX,NR)=>{"use strict";var Go=class{constructor(t,r,s,n,i){this.operation=t,this.schema=r,this.table=s,this.hash_attribute=n,this.records=i}};a(Go,"InsertObject");var qo=class{constructor(t,r,s,n,i,o){this.schema=t,this.table=r,this.search_attribute=s,this.hash_attribute=n,this.get_attributes=i,this.search_value=o}};a(qo,"NoSQLSeachObject");var Fo=class{constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};a(Fo,"DeleteResponseObject");NR.exports={InsertObject:Go,NoSQLSeachObject:qo,DeleteResponseObject:Fo}});var Rs=S((rX,LR)=>{"use strict";var bR=Rl(),WG=pR(),Vo=b(),IR=require("moment"),CR=I(),{promisify:JG,callbackify:ZG}=require("util"),ms=T(),XG=xr(),Al=JG(XG.getTableSchema),Ol=Or(),{DeleteResponseObject:zG}=gR(),{handleHDBError:Yr,hdb_errors:jG}=D(),{HDB_ERROR_MSGS:ko,HTTP_STATUS_CODES:Kr}=jG,eq="records successfully deleted",tq=ZG(wR);LR.exports={delete:tq,deleteRecord:wR,deleteFilesBefore:rq,deleteAuditLogsBefore:sq};async function rq(e){let t=bR(e,"date");if(t)throw Yr(t,t.message,Kr.BAD_REQUEST,void 0,void 0,!0);if(!IR(e.date,IR.ISO_8601).isValid())throw Yr(new Error,ko.INVALID_DATE,Kr.BAD_REQUEST,ms.LOG_LEVELS.ERROR,ko.INVALID_DATE,!0);let s=Vo.checkSchemaTableExist(e.schema,e.table);if(s)throw Yr(new Error,s,Kr.NOT_FOUND,ms.LOG_LEVELS.ERROR,s,!0);try{let n=await Ol.deleteRecordsBefore(e);if(await Al(e.schema,e.table),CR.info(`Finished deleting files before ${e.date}`),n&&n.message)return n.message}catch(n){throw n}}a(rq,"deleteFilesBefore");async function sq(e){let t=bR(e,"timestamp");if(t)throw Yr(t,t.message,Kr.BAD_REQUEST,void 0,void 0,!0);if(isNaN(e.timestamp))throw Yr(new Error,ko.INVALID_VALUE("Timestamp"),Kr.BAD_REQUEST,ms.LOG_LEVELS.ERROR,ko.INVALID_VALUE("Timestamp"),!0);let r=Vo.checkSchemaTableExist(e.schema,e.table);if(r)throw Yr(new Error,r,Kr.NOT_FOUND,ms.LOG_LEVELS.ERROR,r,!0);try{let s=await Ol.deleteAuditLogsBefore(e);return await Al(e.schema,e.table),CR.info(`Finished deleting audit logs before ${e.timestamp}`),s}catch(s){throw s}}a(sq,"deleteAuditLogsBefore");async function wR(e){let t=WG(e);if(t)throw Yr(t,t.message,Kr.BAD_REQUEST,void 0,void 0,!0);let r=Vo.checkSchemaTableExist(e.schema,e.table);if(r)throw Yr(new Error,r,Kr.NOT_FOUND,ms.LOG_LEVELS.ERROR,r,!0);try{await Al(e.schema,e.table);let s=await Ol.deleteRecords(e);return Vo.isEmptyOrZeroLength(s.message)&&(s.message=`${s.deleted_hashes.length} of ${e.hash_values.length} ${eq}`),s}catch(s){if(s.message===ms.SEARCH_NOT_FOUND_MESSAGE){let n=new zG;return n.message=ms.SEARCH_NOT_FOUND_MESSAGE,n.skipped_hashes=e.hash_values.length,n.deleted_hashes=0,n}throw s}}a(wR,"deleteRecord")});var xo=S((sX,DR)=>{var nq=require("crypto"),UR=9;function iq(e){let t=oq(UR),r=yR(e+t);return t+r}a(iq,"createHash");function aq(e,t){let r=e.substr(0,UR),s=r+yR(t+r);return e===s}a(aq,"validateHash");function oq(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,s="";for(let n=0;n<e;n++){let i=Math.floor(Math.random()*r);s+=t[i]}return s}a(oq,"generateSalt");function yR(e){return nq.createHash("md5").update(e).digest("hex")}a(yR,"md5");DR.exports={hash:iq,validate:aq}});var PR=S((nX,MR)=>{var pl=de(),Je={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 cq(e){return Je.password.presence=!0,Je.username.presence=!0,Je.role.presence=!0,Je.active.presence=!0,pl.validateObject(e,Je)}a(cq,"addUserValidation");function _q(e){return Je.password.presence=!1,Je.username.presence=!0,Je.role.presence=!1,Je.active.presence=!1,pl.validateObject(e,Je)}a(_q,"alterUserValidation");function uq(e){return Je.password.presence=!1,Je.username.presence=!0,Je.role.presence=!1,Je.active.presence=!1,pl.validateObject(e,Je)}a(uq,"dropUserValidation");MR.exports={addUserValidation:cq,alterUserValidation:_q,dropUserValidation:uq}});var _e=S((aX,vR)=>{"use strict";var{platform:iX}=require("os"),lq="nats-server.zip",Nl="nats-server",Eq=process.platform==="win32"?`${Nl}.exe`:Nl,gl="HDB",dq=/^[^\s.,*>]+$/,BR="__request__",hq=a(e=>`${e}.${BR}`,"REQUEST_SUBJECT"),Sq={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},fq={HUB:"hub.pid",LEAF:"leaf.pid"},Tq={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},mq={stream_name:"__HARPERDB_WORK_QUEUE__",durable_name:"HDB_WORK_QUEUE",deliver_group:gl,deliver_subject:"__HDB__.WORKQUEUE"},Rq={stream_name:"__HARPERDB_SCHEMA_QUEUE__",durable_name:"HDB_SCHEMA_QUEUE",deliver_group:gl,deliver_subject:"HDB.SCHEMAQUEUE"},Aq={stream_name:"__HARPERDB_USER_QUEUE__",durable_name:"HDB_USER_QUEUE",deliver_group:gl,deliver_subject:"HDB.USERQUEUE"},Oq={SUCCESS:"success",ERROR:"error"},pq={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},Nq={TXN:"txn",MSGID:"msgid"};vR.exports={NATS_SERVER_ZIP:lq,NATS_SERVER_NAME:Nl,NATS_BINARY_NAME:Eq,PID_FILES:fq,NATS_CONFIG_FILES:Sq,SERVER_SUFFIX:Tq,WORK_QUEUE_CONSUMER_NAMES:mq,SCHEMA_QUEUE_CONSUMER_NAMES:Rq,USER_QUEUE_CONSUMER_NAMES:Aq,NATS_TERM_CONSTRAINTS_RX:dq,REQUEST_SUFFIX:BR,UPDATE_REMOTE_RESPONSE_STATUSES:Oq,CLUSTER_STATUS_STATUSES:pq,REQUEST_SUBJECT:hq,SUBJECT_PREFIXES:Nq}});var GR=S((oX,HR)=>{"use strict";var Qr=T(),Ri=class{constructor(t=0,r=Qr.STORAGE_TYPES_ENUM.LMDB,s=Qr.LICENSE_VALUES.API_CALL_DEFAULT,n=Qr.RAM_ALLOCATION_ENUM.DEFAULT,i=Qr.LICENSE_VALUES.VERSION_DEFAULT,o){this.exp_date=t,this.storage_type=r,this.api_call=s,this.ram_allocation=n,this.version=i,this.fingerprint=o}};a(Ri,"BaseLicense");var $o=class extends Ri{constructor(t=0,r=Qr.STORAGE_TYPES_ENUM.LMDB,s=Qr.LICENSE_VALUES.API_CALL_DEFAULT,n=Qr.RAM_ALLOCATION_ENUM.DEFAULT,i=Qr.LICENSE_VALUES.VERSION_DEFAULT,o,c=!1){super(t,r,s,n,i,o),this.enterprise=c}};a($o,"ExtendedLicense");HR.exports={BaseLicense:Ri,ExtendedLicense:$o}});var Ai=S((cX,$R)=>{"use strict";var Sn=require("fs-extra"),qR=xo(),FR=require("crypto"),gq=require("moment"),Iq=require("uuid").v4,Ze=I(),bl=require("path"),bq=b(),Rt=T(),Cq=GR().ExtendedLicense,hn="invalid license key format",wq="061183",Lq="mofi25",Uq="aes-256-cbc",yq=16,Dq=32,VR=Y();VR.initSync();var Il;$R.exports={validateLicense:kR,generateFingerPrint:Pq,licenseSearch:xR,getLicense:Hq};function Cl(){return bl.join(VR.getHdbBasePath(),Rt.LICENSE_KEY_DIR_NAME,Rt.LICENSE_FILE_NAME)}a(Cl,"getLicenseDirPath");function Mq(){let e=Cl();return bl.join(e,Rt.LICENSE_FILE_NAME)}a(Mq,"getLicenseFilePath");function wl(){let e=Cl();return bl.join(e,Rt.REG_KEY_FILE_NAME)}a(wl,"getFingerPrintFilePath");async function Pq(){let e=wl();try{return await Sn.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Bq();throw Ze.error(`Error writing fingerprint file to ${e}`),Ze.error(t),new Error("There was an error generating the fingerprint")}}a(Pq,"generateFingerPrint");async function Bq(){let e=Iq(),t=qR.hash(e),r=wl();try{await Sn.mkdirp(Cl()),await Sn.writeFile(r,t)}catch(s){if(s.code==="EEXIST")return t;throw Ze.error(`Error writing fingerprint file to ${r}`),Ze.error(s),new Error("There was an error generating the fingerprint")}return t}a(Bq,"writeFingerprint");function kR(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,storage_type:Rt.STORAGE_TYPES_ENUM.LMDB,api_call:Rt.LICENSE_VALUES.API_CALL_DEFAULT,ram_allocation:Rt.RAM_ALLOCATION_ENUM.DEFAULT,version:Rt.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Ze.error("empty license key passed to validate."),r;let s=wl(),n=!1;try{n=Sn.statSync(s)}catch(i){Ze.error(i)}if(n){let i;try{i=Sn.readFileSync(s,"utf8")}catch{Ze.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(Lq),c=o[1];c=Buffer.concat([Buffer.from(c)],yq);let _=Buffer.concat([Buffer.from(i)],Dq),u=FR.createDecipheriv(Uq,_,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=u.update(o[0],"hex","utf8"),l.trim(),l+=u.final("utf8")}catch{let h=vq(o[0],i);if(h)l=h;else throw r.valid_license=!1,r.valid_machine=!1,console.error(hn),Ze.error(hn),new Error(hn)}let E;if(isNaN(l))try{E=JSON.parse(l),r.api_call=E.api_call,r.version=E.version,r.storage_type=E.storage_type,r.exp_date=E.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),E.ram_allocation&&(r.ram_allocation=E.ram_allocation)}catch{throw console.error(hn),Ze.error(hn),new Error(hn)}else r.exp_date=l;r.exp_date<gq().valueOf()&&(r.valid_date=!1),qR.validate(o[1],`${wq}${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||Ze.error("Invalid licence"),r}a(kR,"validateLicense");function vq(e,t){try{let r=FR.createDecipher("aes192",t),s=r.update(e,"hex","utf8");return s.trim(),s+=r.final("utf8"),s}catch{Ze.warn("Check old license failed")}}a(vq,"checkOldLicense");function xR(){let e=new Cq;e.api_call=0;let t=[];try{t=Sn.readFileSync(Mq(),"utf-8").split(Rt.NEW_LINE)}catch(r){r.code==="ENOENT"?Ze.info("no license file found"):Ze.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let s=t[r];try{if(bq.isEmptyOrZeroLength(s))continue;let n=JSON.parse(s),i=kR(n.license_key,n.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.api_call+=i.api_call,e.ram_allocation=i.ram_allocation,e.storage_type=i.storage_type,e.enterprise=!0)}catch(n){Ze.error("There was an error parsing the license string."),Ze.error(n),e.api_call=Rt.LICENSE_VALUES.API_CALL_DEFAULT,e.ram_allocation=Rt.RAM_ALLOCATION_ENUM.DEFAULT,e.storage_type=Rt.STORAGE_TYPES_ENUM.LMDB,e.enterprise=!1}}return e.api_call===0&&(e.api_call=Rt.LICENSE_VALUES.API_CALL_DEFAULT),Il=e,e}a(xR,"licenseSearch");async function Hq(){return Il||await xR(),Il}a(Hq,"getLicense")});var Wr=S((_X,nA)=>{"use strict";var WR="username is required",JR="nothing to update, must supply active, role or password to update",ZR="password cannot be an empty string",XR="If role is specified, it cannot be empty.",zR="active must be true or false";nA.exports={addUser:Yq,alterUser:Kq,dropUser:Wq,userInfo:Jq,listUsers:Ko,listUsersExternal:Zq,setUsersToGlobal:Oi,findAndValidateUser:jq,getClusterUser:eF,USERNAME_REQUIRED:WR,ALTERUSER_NOTHING_TO_UPDATE:JR,EMPTY_PASSWORD:ZR,EMPTY_ROLE:XR,ACTIVE_BOOLEAN:zR};var jR=Ut(),Gq=Rs(),Ul=xo(),eA=PR(),tA=mt(),yl=js(),be=b(),rA=require("validate.js"),H=I(),{promisify:Dl}=require("util"),Ml=Vr(),As=T(),YR=_e(),qq=Sr(),Pl=Y(),Fq=Ai(),Vq=is(),{handleHDBError:rr,hdb_errors:kq}=D(),{HTTP_STATUS_CODES:sr,AUTHENTICATION_ERROR_MSGS:Ll,HDB_ERROR_MSGS:fn}=kq,{UserEventMsg:Bl}=Gr(),KR=require("lodash"),sA={username:!0,active:!0,role:!0,password:!0},QR=new Map,Yo=Dl(tA.searchByValue),xq=Dl(tA.searchByHash),$q=Dl(Gq.delete);async function Yq(e){let t=rA.cleanAttributes(e,sA),r=eA.addUserValidation(t);if(r)throw rr(new Error,r.message,sr.BAD_REQUEST,void 0,void 0,!0);let s={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},n;try{n=await Yo(s)}catch(u){throw H.error("There was an error searching for a role in add user"),H.error(u),u}if(!n||n.length<1)throw rr(new Error,fn.ROLE_NAME_NOT_FOUND(t.role),sr.NOT_FOUND,void 0,void 0,!0);if(n.length>1)throw rr(new Error,fn.DUP_ROLES_FOUND(t.role),sr.CONFLICT,void 0,void 0,!0);n[0].permission.cluster_user===!0&&(t.hash=Ml.encrypt(t.password)),t.password=Ul.hash(t.password),t.role=n[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await jR.insert(i)}catch(u){throw H.error("There was an error searching for a user."),H.error(u),u}H.debug(o);try{await Oi()}catch(u){throw H.error("Got an error setting users to global"),H.error(u),u}if(o.skipped_hashes.length===1)throw rr(new Error,fn.USER_ALREADY_EXISTS(t.username),sr.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);c.role=n[0];let _={user:null};return _.user=c,be.sendTransactionToSocketCluster(As.INTERNAL_SC_CHANNELS.ADD_USER,_,Pl.get(As.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),yl.signalUserChange(new Bl(process.pid)),`${c.username} successfully added`}a(Yq,"addUser");async function Kq(e){let t=rA.cleanAttributes(e,sA);if(be.isEmptyOrZeroLength(t.username))throw new Error(WR);if(be.isEmptyOrZeroLength(t.password)&&be.isEmptyOrZeroLength(t.role)&&be.isEmptyOrZeroLength(t.active))throw new Error(JR);if(!be.isEmpty(t.password)&&be.isEmptyOrZeroLength(t.password.trim()))throw new Error(ZR);if(!be.isEmpty(t.active)&&!be.isBoolean(t.active))throw new Error(zR);let r=Qq(t.username);if(!be.isEmpty(t.password)&&!be.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=Ml.encrypt(t.password)),t.password=Ul.hash(t.password)),t.role==="")throw new Error(XR);if(t.role){let o={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},c;try{c=await Yo(o)}catch(_){throw H.error("Got an error searching for a role."),H.error(_),_}if(!c||c.length===0){let _=fn.ALTER_USER_ROLE_NOT_FOUND(t.role);throw H.error(_),rr(new Error,_,sr.NOT_FOUND,void 0,void 0,!0)}if(c.length>1){let _=fn.ALTER_USER_DUP_ROLES(t.role);throw H.error(_),rr(new Error,_,sr.CONFLICT,void 0,void 0,!0)}t.role=c[0].id}let s={operation:"update",schema:"system",table:"hdb_user",records:[t]},n;try{n=await jR.update(s)}catch(o){throw H.error("Error during update."),H.error(o),o}try{await Oi()}catch(o){throw H.error("Got an error setting users to global"),H.error(o),o}let i={user:null};return i.user=t,be.sendTransactionToSocketCluster(As.INTERNAL_SC_CHANNELS.ALTER_USER,i,Pl.get(As.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),yl.signalUserChange(new Bl(process.pid)),n}a(Kq,"alterUser");function Qq(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(Qq,"isClusterUser");async function Wq(e){try{let t=eA.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(be.isEmpty(global.hdb_users.get(e.username)))throw rr(new Error,fn.USER_NOT_EXIST(e.username),sr.NOT_FOUND,void 0,void 0,!0);let s;try{s=await $q(r)}catch(i){throw H.error("Got an error deleting a user."),H.error(i),i}H.debug(s);try{await Oi()}catch(i){throw H.error("Got an error setting users to global."),H.error(i),i}let n={user:null};return n.user=e,be.sendTransactionToSocketCluster(As.INTERNAL_SC_CHANNELS.DROP_USER,n,Pl.get(As.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),yl.signalUserChange(new Bl(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(Wq,"dropUser");async function Jq(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=e.hdb_user;let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},s;try{s=await xq(r)}catch(n){throw H.error("Got an error searching for a role."),H.error(n),n}t.role=s[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw H.error(r),r}return t}a(Jq,"userInfo");async function Zq(){let e;try{e=await Ko()}catch(t){throw H.error("Got an error listing users."),H.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(Zq,"listUsersExternal");async function Ko(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=KR.cloneDeep(await Yo(e))}catch(r){throw H.error("Got an error searching for roles."),H.error(r),r}if(!be.isEmptyOrZeroLength(t)){let r={};for(let o in t)r[t[o].id]=t[o];let s={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},n;try{n=KR.cloneDeep(await Yo(s))}catch(o){throw H.error("Got an error searching for users."),H.error(o),o}let i=new Map;for(let o in n){let c=n[o];c.role=r[n[o].role],Xq(c.role),i.set(c.username,c)}return(await Fq.getLicense()).enterprise?i:zq(i)}}catch(e){throw H.error("got an error listing users"),H.error(e),be.errorizeMessage(e)}return null}a(Ko,"listUsers");function Xq(e){try{if(!e){H.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(Vq)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){H.error("Got an error trying to set system permissions."),H.error(t)}}a(Xq,"appendSystemTablesToRole");function zq(e){try{if(H.info("No enterprise license found. System is limited to 1 clustering role and 1 user role"),!e)return new Map;let t=Object.create(null),r=new Map;e.forEach((n,i)=>{n.role.permission.cluster_user===void 0||n.role.permission.cluster_user===!1?n.role.permission.super_user===!0&&(t[n.role.id]||(t[n.role.id]=new Map),t[n.role.id].set(i,n)):r.set(i,n)});let s={role:void 0,count:0};return Object.keys(t).forEach(n=>{let i=t[n];i.size>=s.count&&(s.role=n,s.count=i.size)}),s.role===void 0?(H.error("No roles found with active users. This is bad."),new Map):(r=new Map([...r,...t[s.role]]),r)}catch(t){return H.error("error filtering users."),H.error(t),new Map}}a(zq,"nonEnterpriseFilter");async function Oi(){try{let e=await Ko();global.hdb_users=e}catch(e){throw H.error(e),e}}a(Oi,"setUsersToGlobal");async function jq(e,t,r=!0){global.hdb_users||await Oi();let s=global.hdb_users.get(e);if(!s)throw rr(new Error,Ll.GENERIC_AUTH_FAIL,sr.UNAUTHORIZED,void 0,void 0,!0);if(s&&!s.active)throw rr(new Error,Ll.USER_INACTIVE,sr.UNAUTHORIZED,void 0,void 0,!0);let n={active:s.active,username:s.username};if(s.refresh_token&&(n.refresh_token=s.refresh_token),s.role&&(n.role=s.role),r===!0){if(QR.get(t)===s.password)return n;if(Ul.validate(s.password,t))QR.set(t,s.password);else throw rr(new Error,Ll.GENERIC_AUTH_FAIL,sr.UNAUTHORIZED,void 0,void 0,!0)}return n}a(jq,"findAndValidateUser");async function eF(){let e=await Ko(),t=qq.getConfigFromFile(As.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!be.isEmpty(r))return r.decrypt_hash=Ml.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+YR.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+YR.SERVER_SUFFIX.ADMIN,r}a(eF,"getClusterUser")});var _A=S((uX,cA)=>{"use strict";var Os=I(),Qo=T(),tF=ER(),iA=xr(),rF=fs(),sF=Wr(),{validateEvent:oA}=Gr(),nF={[Qo.IPC_EVENT_TYPES.SCHEMA]:iF,[Qo.IPC_EVENT_TYPES.USER]:oF};async function iF(e){let t=oA(e);if(t){Os.error(t);return}Os.trace(`IPC schemaHandler ${Qo.HDB_IPC_CLIENT_PREFIX}${process.pid} received schema event:`,e),await tF(e.message),await aF(e.message)}a(iF,"schemaHandler");async function aF(e){try{if(global.hdb_schema!==void 0&&typeof global.hdb_schema=="object"&&e.operation!==void 0)switch(e.operation){case"drop_schema":delete global.hdb_schema[e.schema];break;case"drop_table":global.hdb_schema[e.schema]!==void 0&&delete global.hdb_schema[e.schema][e.table];break;case"create_schema":global.hdb_schema[e.schema]===void 0&&(global.hdb_schema[e.schema]={});break;case"create_table":case"create_attribute":global.hdb_schema[e.schema]===void 0&&(global.hdb_schema[e.schema]={}),global.hdb_schema[e.schema][e.table]=await rF.describeTable({schema:e.schema,table:e.table});break;default:iA.setSchemaDataToGlobal(aA);break}else iA.setSchemaDataToGlobal(aA)}catch(t){Os.error(t)}}a(aF,"syncSchemaMetadata");function aA(e){e&&Os.error(e)}a(aA,"handleErrorCallback");async function oF(e){try{let t=oA(e);if(t){Os.error(t);return}Os.trace(`IPC userHandler ${Qo.HDB_IPC_CLIENT_PREFIX}${process.pid} received user event:`,e),await sF.setUsersToGlobal()}catch(t){Os.error(t)}}a(oF,"userHandler");cA.exports=nF});var Wo=S((lX,uA)=>{"use strict";var cF=Or();uA.exports={writeTransaction:_F};function _F(e,t,r){return cF.writeTransaction(e,t,r)}a(_F,"writeTransaction")});var vl=S((EX,uF)=>{uF.exports={name:"harperdb",version:"4.0.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:{node:">=14.0.0","preferred-node":"18.13.0","go-lang":"1.19.3","nats-server":"2.9.8"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"See License in ./license/Community+Edition+and+Evaluation+End+User+License+Agreement.pdf",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ data_layer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ data_layer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",test:"rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license --storage_type=lmdb && npm run cover:upgrade && npm run cover:nats && npm run cover:cfserver && npm run cover:lmdbbridge && npm run cover:lmdbutility && npm run cover:hdbserver && npm run cover:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license --storage_type=lmdb","cover:main":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","cover:lmdbbridge":"cd bin/ && nyc --no-clean --reporter=lcovonly --retries 3 ../node_modules/mocha/bin/_mocha '../unitTests/data_layer/harperBridge/lmdbBridge/**/*.js' --parallel --config '../unitTests/.mocharc.json'","cover:lmdbutility":"cd bin/ && nyc --no-clean --reporter=lcovonly --retries 3 ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --config '../unitTests/.mocharc.json'","cover:hdbserver":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --config '../unitTests/.mocharc.json'","cover:cfserver":"npm run submodules && cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","cover:nats":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","cover:upgrade":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.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/data_layer/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:{"@fastify/accepts-serializer":"5.1.0","@fastify/autoload":"5.4.0","@fastify/compress":"6.1.1","@fastify/cors":"8.1.0","@fastify/static":"6.5.0","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"1.7.4",async:"3.2.3","aws-sdk":"2.1096.0",chalk:"4.1.2","cli-progress":"3.10.0",clone:"2.1.2",esbuild:"^0.14.49","fast-glob":"3.2.11",fastify:"4.8.1","fastify-plugin":"4.2.1","fill-range":"7.0.1","fs-extra":"10.0.1","human-readable-ids":"1.0.4",inquirer:"8.2.2","is-number":"7.0.0",joi:"17.6.0",json2csv:"5.0.7",jsonata:"1.8.6",jsonwebtoken:"8.5.1",lmdb:"2.7.6",lodash:"4.17.21",mathjs:"10.4.0",microtime:"3.1.1",minimist:"1.2.6",mkcert:"1.5.0",moment:"2.29.4",msgpackr:"1.8.2",nats:"2.9.2",needle:"3.1.0","node-ipc":"9.1.4","node-stream-zip":"1.15.0","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.3.0",papaparse:"5.3.2",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.3.1",pm2:"5.2.0",prompt:"1.2.2","properties-reader":"2.2.0","recursive-iterator":"3.3.0",semver:"7.3.5","stream-chain":"2.2.5","stream-json":"1.7.4",systeminformation:"5.12.4","tar-fs":"2.1.1","truncate-utf8-bytes":"1.0.2",ulidx:"0.3.0",uuid:"9.0.0","validate.js":"0.11.1",yaml:"1.10.2"},devDependencies:{axios:"0.27.2",chai:"4.3.4","chai-integer":"0.1.0",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1","hook-std":"2.0.0","intercept-stdout":"0.1.2",mocha:"8.3.2","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",newman:"5.2.3","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"1.21.0","newman-reporter-teamcity":"0.1.11","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.3.2",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},"newman-reporter-html":{newman:"5.2.3"}}}});var ot=S((NX,UA)=>{"use strict";var nr=Y();nr.initSync();var lF=require("fs-extra"),EF=require("semver"),bi=require("path"),{monotonicFactory:dF}=require("ulidx"),hF=dF(),EA=require("util"),dA=require("child_process"),SF=EA.promisify(dA.exec),fF=dA.spawn,ee=_e(),se=T(),kl=b(),pr=I(),Jo=Vr(),TF=Wo(),pi=Sr(),{encode:ql,decode:hA}=require("msgpackr"),{isEmpty:ps}=kl,SA=Wr(),dX=ds(),mF=mt(),hX=EA.promisify(mF.searchByHash),{connect:RF,StorageType:fA,RetentionPolicy:TA,AckPolicy:mA,DeliverPolicy:Fl,NatsConnection:SX,JetStreamManager:fX,JetStreamClient:TX,StringCodec:mX,JSONCodec:AF,createInbox:xl,StreamSource:RX,headers:OF,toJsMsg:pF,nuid:AX,JetStreamOptions:OX,ErrorCode:lA,nanos:pX}=require("nats"),{PACKAGE_ROOT:NF}=T(),gF=vl(),RA=AF(),IF="clustering",bF=gF.engines[ee.NATS_SERVER_NAME],CF=bi.join(NF,"dependencies"),Vl=bi.join(CF,`${process.platform}-${process.arch}`,ee.NATS_BINARY_NAME),Hl,Gl,Ni,gi,Ii,Qt;UA.exports={runCommand:AA,checkNATSServerInstalled:wF,createConnection:$l,getConnection:Zo,getJetStreamManager:Tn,getJetStream:OA,getNATSReferences:yt,getServerList:UF,createLocalStream:Yl,listStreams:pA,deleteLocalStream:yF,getServerConfig:Ci,listRemoteStreams:DF,viewStream:MF,publishToStream:PF,createWorkQueueStream:BF,addSourceToWorkStream:NA,request:vF,removeSourceFromWorkStream:IA,reloadNATS:Kl,reloadNATSHub:HF,reloadNATSLeaf:GF,extractServerName:gA,requestErrorHandler:qF,updateWorkStream:FF,createLocalTableStream:CA,createTableStreams:VF,purgeTableStream:wA,purgeSchemaTableStreams:kF,getStreamInfo:xF,updateNodeNameLocalStreams:$F,closeConnection:LF};async function AA(e,t=void 0){let{stdout:r,stderr:s}=await SF(e,{cwd:t});if(s)throw new Error(s.replace(`
|
|
6
6
|
`,""));return r.replace(`
|
|
7
7
|
`,"")}a(AA,"runCommand");async function wF(){try{await lF.access(Vl)}catch{return!1}let e=await AA(`${Vl} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return EF.eq(t,bF)}a(wF,"checkNATSServerInstalled");async function $l(e,t,r,s=!0,n="127.0.0.1"){return RF({name:n,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:s,tls:{keyFile:nr.get(se.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:nr.get(se.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:nr.get(se.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),insecure:nr.get(se.CONFIG_PARAMS.CLUSTERING_TLS_INSECURE)}})}a($l,"createConnection");async function LF(){Qt&&(await Qt.close(),Qt=void 0)}a(LF,"closeConnection");async function Zo(){if(!Qt){let e=await SA.getClusterUser();if(ps(e))throw new Error("Unable to get nats connection. Cluster user is undefined.");let t=nr.get(se.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT);Qt=await $l(t,e.username,e.decrypt_hash)}return Qt}a(Zo,"getConnection");async function Tn(){if(gi)return gi;ps(Qt)&&await Zo();let{domain:e}=Ci(se.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ps(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return gi=await Qt.jetstreamManager({domain:e}),gi}a(Tn,"getJetStreamManager");async function OA(){if(Ii)return Ii;ps(Qt)&&await Zo();let{domain:e}=Ci(se.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ps(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ii=Qt.jetstream({domain:e}),Ii}a(OA,"getJetStream");async function yt(){let e=Qt||await Zo(),t=gi||await Tn(),r=Ii||await OA();return{connection:e,jsm:t,js:r}}a(yt,"getNATSReferences");async function UF(){let e=nr.get(se.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),{sys_name:t,decrypt_hash:r}=await SA.getClusterUser(),s=await $l(e,t,r),n=xl(),i=s.subscribe(n),o=[],c=(async()=>{for await(let _ of i)o.push(RA.decode(_.data))})();return await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:n}),await s.flush(),await kl.async_set_timeout(50),await i.drain(),await s.close(),await c,o}a(UF,"getServerList");async function Yl(e,t){let{jsm:r}=await yt();await r.streams.add({name:e,storage:fA.File,retention:TA.Limits,subjects:t})}a(Yl,"createLocalStream");async function pA(){let{jsm:e}=await yt(),t=await e.streams.list().next(),r=[];return t.forEach(s=>{r.push(s)}),r}a(pA,"listStreams");async function yF(e){let{jsm:t}=await yt();await t.streams.delete(e)}a(yF,"deleteLocalStream");async function DF(e){let{connection:t}=await yt(),r=[],s=xl(),n=t.subscribe(s),i=(async()=>{for await(let o of n)r.push(RA.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:s}),await t.flush(),await n.drain(),await i,r}a(DF,"listRemoteStreams");async function MF(e,t=void 0,r=void 0){let{jsm:s,connection:n}=await yt(),i=hF(),o=[],c={ack_policy:mA.None,durable_name:i,deliver_subject:i,deliver_policy:Fl.All};t&&(c.deliver_policy=Fl.StartTime,c.opt_start_time=new Date(t).toISOString());try{await s.consumers.add(e,c);let _={timeout:2e3};r&&(_.max=r);let u=await n.subscribe(i,_);for await(let l of u){let E=pF(l),d=hA(E.data),h={nats_timestamp:E.info.timestampNanos,nats_sequence:E.info.streamSequence,entry:d,originators:[]},m=[];if(E.headers){let R=E.headers.get("originators");R&&(m=R.split(","),h.originators=m)}o.push(h),u.getPending()===1&&E.info.pending===0&&u.stop()}return await s.consumers.delete(e,i),o}catch(_){if(await s.consumers.delete(e,i),_.code==="TIMEOUT")return o;throw _}}a(MF,"viewStream");async function PF(e,t,r=[],s=[]){pr.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,r,"originators:",s);let{connection:n,js:i}=await yt(),o=await Xo(),c=`${e}.${o}`,_=OF();s.push(o),_.append("originators",s.join());for(let u=0,l=r.length;u<l;u++)try{pr.trace(`publishToStream publishing to subject: ${c}, data:`,r[u]),await i.publish(c,ql(r[u]),{headers:_})}catch(E){if(E.code&&E.code.toString()==="503")pr.trace(`publishToStream creating stream: ${t}`),await Yl(t,[c]),await i.publish(c,ql(r[u]),{headers:_});else throw E}}a(PF,"publishToStream");function Ci(e){e=e.toLowerCase();let t=bi.join(nr.get(se.CONFIG_PARAMS.ROOTPATH),IF);if(e===se.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return ps(Gl)&&(Gl={port:pi.getConfigFromFile(se.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:pi.getConfigFromFile(se.CONFIG_PARAMS.CLUSTERING_NODENAME)+ee.SERVER_SUFFIX.HUB,config_file:ee.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:bi.join(t,ee.PID_FILES.HUB),hdb_nats_path:t}),Gl;if(e===se.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return ps(Hl)&&(Hl={port:pi.getConfigFromFile(se.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:pi.getConfigFromFile(se.CONFIG_PARAMS.CLUSTERING_NODENAME)+ee.SERVER_SUFFIX.LEAF,config_file:ee.NATS_CONFIG_FILES.LEAF_SERVER,domain:pi.getConfigFromFile(se.CONFIG_PARAMS.CLUSTERING_NODENAME)+ee.SERVER_SUFFIX.LEAF,pid_file_path:bi.join(t,ee.PID_FILES.LEAF),hdb_nats_path:t}),Hl;pr.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Ci,"getServerConfig");async function BF(e){let{jsm:t}=await yt(),r=await Xo();try{await t.streams.add({name:e.stream_name,storage:fA.File,retention:TA.Workqueue,subjects:[`${ee.SUBJECT_PREFIXES.MSGID}.${r}`,`${ee.SUBJECT_PREFIXES.TXN}.${e.stream_name}.${r}`]})}catch(s){if(s.code!=="400")throw s}try{await t.consumers.info(e.stream_name,e.durable_name)}catch(s){if(s.code.toString()==="404")await t.consumers.add(e.stream_name,{ack_policy:mA.Explicit,deliver_subject:`${e.deliver_subject}.${r}`,durable_name:e.durable_name,deliver_policy:Fl.All,max_ack_pending:1e4,deliver_group:e.deliver_group,filter_subject:`${ee.SUBJECT_PREFIXES.TXN}.>`});else throw s}}a(BF,"createWorkQueueStream");async function NA(e,t,r){let{jsm:s}=await yt(),n=await s.streams.info(t),i=gA(s.prefix),o=r.start_time?r.start_time:new Date(Date.now()).toISOString(),{schema:c,table:_}=r,u=Jo.createNatsTableStreamName(c,_),l=i===e,E,d,h=!1;if(!Array.isArray(n.config.sources)||n.config.sources.length===0)n.config.sources=[];else for(let R=0,w=n.config.sources.length;R<w;R++)if(E=n.config.sources[R],d=R,l&&E.name===u||!l&&E.name===u&&E.external&&E.external.api===`$JS.${e}.API`){h=!0;break}if(h===!0){if(E.opt_start_time===o)return;await bA(c,_,E,t),n.config.sources.splice(d,1),await s.streams.update(t,n.config)}let m={name:u,opt_start_time:o,filter_subject:`${ee.SUBJECT_PREFIXES.TXN}.>`};l||(m.external={api:`$JS.${e}.API`,deliver:""}),n.config.sources.push(m),await s.streams.update(t,n.config)}a(NA,"addSourceToWorkStream");function gA(e){return e.split(".")[1]}a(gA,"extractServerName");async function IA(e,t,r){let{schema:s,table:n}=r,i=Jo.createNatsTableStreamName(s,n),{jsm:o}=await yt(),c=await o.streams.info(t);if(!Array.isArray(c.config.sources)||c.config.sources.length===0)return;let _=c.config.sources.length,u;for(;_--;)if(u=c.config.sources[_],u.name===i&&u.external.api===`$JS.${e}.API`){c.config.sources.splice(_,1);break}await o.streams.update(t,c.config),await bA(s,n,u,t)}a(IA,"removeSourceFromWorkStream");async function bA(e,t,r,s){let n=await Tn(),i;try{i=LA(e,t,r.external.api.split(".")[1]),await n.streams.purge(s,{filter:i})}catch{pr.error("Error purging source subject",i,"from work stream",s)}}a(bA,"purgeSourceFromWorkStream");async function vF(e,t,r=2e3,s=xl()){if(!kl.isObject(t))throw new Error("data param must be an object");let n=ql(t),{connection:i}=await yt(),o={timeout:r};s&&(o.reply=s,o.noMux=!0);let c=await i.request(e,n,o);return hA(c.data)}a(vF,"request");function Kl(e){return new Promise(async(t,r)=>{let s=fF(Vl,["--signal",`reload=${e}`],{cwd:__dirname}),n,i;s.on("error",o=>{r(o)}),s.stdout.on("data",o=>{i+=o.toString()}),s.stderr.on("data",o=>{n+=o.toString()}),s.stderr.on("close",o=>{n&&r(n),t(i)})})}a(Kl,"reloadNATS");async function HF(){let{pid_file_path:e}=Ci(se.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await Kl(e)}a(HF,"reloadNATSHub");async function GF(){let{pid_file_path:e}=Ci(se.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await Kl(e)}a(GF,"reloadNATSLeaf");function qF(e,t,r){let s;switch(e.code){case lA.NoResponders:s=`Unable to ${t}, node '${r}' is not listening.`;break;case lA.Timeout:s=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:s=e.message;break}return s}a(qF,"requestErrorHandler");async function FF(e,t){let r=t+ee.SERVER_SUFFIX.LEAF;await TF.writeTransaction(se.SYSTEM_SCHEMA_NAME,se.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,async()=>{e.subscribe===!0?await NA(r,ee.WORK_QUEUE_CONSUMER_NAMES.stream_name,e):await IA(r,ee.WORK_QUEUE_CONSUMER_NAMES.stream_name,e)})}a(FF,"updateWorkStream");async function CA(e,t){let r=Jo.createNatsTableStreamName(e,t),s=await Xo(),n=LA(e,t,s);await Yl(r,[n])}a(CA,"createLocalTableStream");async function VF(e){for(let t=0,r=e.length;t<r;t++){let s=e[t].schema,n=e[t].table;await CA(s,n)}}a(VF,"createTableStreams");async function wA(e,t){if(nr.get(se.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let r=Jo.createNatsTableStreamName(e,t),{jsm:s}=await yt();await s.streams.purge(r)}catch(r){if(r.message==="stream not found")pr.warn(r);else throw r}}a(wA,"purgeTableStream");async function kF(e,t){if(nr.get(se.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,s=t.length;r<s;r++)await wA(e,t[r])}a(kF,"purgeSchemaTableStreams");async function xF(e){return(await Tn()).streams.info(e)}a(xF,"getStreamInfo");function LA(e,t,r){return`${ee.SUBJECT_PREFIXES.TXN}.${e}.${t}.${r}`}a(LA,"createSubjectName");async function Xo(){if(Ni)return Ni;if(Ni=(await Tn())?.nc?.info?.server_name,Ni===void 0)throw new Error("Unable to get jetstream manager server name");return Ni}a(Xo,"getJsmServerName");async function $F(){let e=await Tn(),t=await Xo(),r=await pA();for(let s of r){let n=s.config,i=n.subjects[0];if(!i)continue;let o=i.split(".");if(o[o.length-1]!==t){if(n.name===ee.SCHEMA_QUEUE_CONSUMER_NAMES.stream_name){let _=`${ee.SCHEMA_QUEUE_CONSUMER_NAMES.deliver_subject}.${t}`;pr.trace(`Updating stream subject name from: ${i} to: ${_}`),n.subjects[0]=_}else if(n.name===ee.WORK_QUEUE_CONSUMER_NAMES.stream_name){let _=`${ee.WORK_QUEUE_CONSUMER_NAMES.stream_name}.${t}`;pr.trace(`Updating stream subject name from: ${i} to: ${_}`),n.subjects[0]=_,await e.consumers.update(ee.WORK_QUEUE_CONSUMER_NAMES.stream_name,ee.WORK_QUEUE_CONSUMER_NAMES.durable_name,{deliver_subject:`${ee.WORK_QUEUE_CONSUMER_NAMES.deliver_subject}.${t}`})}else{let _=i.split(".");_[_.length-1]=t;let u=_.join(".");pr.trace(`Updating stream subject name from: ${i} to: ${u}`),n.subjects[0]=u}await e.streams.update(n.name,n)}}}a($F,"updateNodeNameLocalStreams")});var Ql=S((gX,yA)=>{"use strict";var zo=class{constructor(t,r,s){this.timestamp=t,this.user=r,this.node_name=s}};a(zo,"ClusteringOriginObject");yA.exports=zo});var Ns=S((IX,PA)=>{"use strict";var DA=b(),Li=Y(),ue=T(),Wl=_e(),mn=ot(),Se=I(),MA=Ql(),YF=Vr();Li.initSync();var Rn=Wl.SCHEMA_QUEUE_CONSUMER_NAMES.stream_name,wi=Wl.SCHEMA_QUEUE_CONSUMER_NAMES.deliver_subject;PA.exports={sendAttributeTransaction:ec,postOperationHandler:QF};async function ec(e,t,r=[]){if(!!Li.get(ue.CONFIG_PARAMS.CLUSTERING_ENABLED)&&!DA.isEmptyOrZeroLength(e.new_attributes)&&t.schema!==ue.SYSTEM_SCHEMA_NAME){let s=t.hdb_user?.username,n=Li.get(ue.CONFIG_PARAMS.CLUSTERING_NODENAME);for(let i of e.new_attributes){let o={operation:ue.OPERATIONS_ENUM.CREATE_ATTRIBUTE,schema:t.schema,table:t.table,attribute:i,__origin:new MA(e.txn_time,s,n)};Se.trace(`sendAttributeTransaction publishing ${Rn}`,o),await mn.publishToStream(wi,Rn,[o],r)}}}a(ec,"sendAttributeTransaction");async function jo(e,t,r,s=[]){if(e.schema===ue.SYSTEM_SCHEMA_NAME)return;let n=KF(e,t,r);n&&(Se.trace(`sendOperationTransaction publishing to schema ${e.schema} table ${e.table} following transaction:`,n),await mn.publishToStream(`${Wl.SUBJECT_PREFIXES.TXN}.${e.schema}.${e.table}`,YF.createNatsTableStreamName(e.schema,e.table),[n],s))}a(jo,"sendOperationTransaction");function KF(e,t,r){if(DA.isEmptyOrZeroLength(t))return null;let s={operation:e.operation,schema:e.schema,table:e.table,__origin:r};return e.operation===ue.OPERATIONS_ENUM.DELETE?s.hash_values=t:s.records=e.records,s}a(KF,"convertCRUDOperationToTransaction");async function QF(e,t,r=[]){if(!Li.get(ue.CONFIG_PARAMS.CLUSTERING_ENABLED))return;Se.trace(`postOperationHandler called for operation ${e.operation} on schema.table: ${e.schema}.${e.table}`);let s=e.hdb_user?.username,n=Li.get(ue.CONFIG_PARAMS.CLUSTERING_NODENAME),i=new MA(t.txn_time,s,n);switch(e.operation){case ue.OPERATIONS_ENUM.INSERT:try{await jo(e,t.inserted_hashes,i,r),await ec(t,e,r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for insert."),Se.error(o)}break;case ue.OPERATIONS_ENUM.DELETE:try{await jo(e,t.deleted_hashes,i,r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for delete."),Se.error(o)}break;case ue.OPERATIONS_ENUM.UPDATE:try{await jo(e,t.update_hashes,i,r),await ec(t,e,r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for update."),Se.error(o)}break;case ue.OPERATIONS_ENUM.UPSERT:try{await jo(e,t.upserted_hashes,i,r),await ec(t,e,r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for upsert."),Se.error(o)}break;case ue.OPERATIONS_ENUM.CREATE_SCHEMA:try{let o={operation:ue.OPERATIONS_ENUM.CREATE_SCHEMA,schema:e.schema,__origin:i};await mn.publishToStream(wi,Rn,[o],r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for create_schema."),Se.error(o)}break;case ue.OPERATIONS_ENUM.CREATE_TABLE:try{let o={operation:ue.OPERATIONS_ENUM.CREATE_TABLE,schema:e.schema,table:e.table,hash_attribute:e.hash_attribute,__origin:i};await mn.publishToStream(wi,Rn,[o],r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for create_table."),Se.error(o)}break;case ue.OPERATIONS_ENUM.CREATE_ATTRIBUTE:try{let o={operation:ue.OPERATIONS_ENUM.CREATE_ATTRIBUTE,schema:e.schema,table:e.table,attribute:e.attribute,__origin:i};await mn.publishToStream(wi,Rn,[o],r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for create_attribute."),Se.error(o)}break;case ue.OPERATIONS_ENUM.CSV_DATA_LOAD:try{let o={operation:ue.OPERATIONS_ENUM.CSV_DATA_LOAD,schema:e.schema,table:e.table,attribute:e.attribute};await mn.publishToStream(wi,Rn,[o],r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for csv_data_load."),Se.error(o)}break;default:break}return t}a(QF,"postOperationHandler")});var qA=S((bX,GA)=>{"use strict";var WF=mt(),JF=xr(),BA=I(),vA=Ut(),ZF=Wo(),XF=require("clone"),Zl=require("alasql"),zF=Lo(),HA=require("util"),jF=HA.promisify(JF.getTableSchema),e0=HA.promisify(WF.search),t0=T(),Jl=b(),r0=Ns();zF(Zl);GA.exports={update:n0};var s0="There was a problem performing this update. Please check the logs and try again.";async function n0({statement:e,hdb_user:t}){let r=await jF(e.table.databaseid,e.table.tableid),s=i0(e.columns);Jl.backtickASTSchemaItems(e);let{table:n,where:i}=e,o=XF(n),c=Jl.isEmpty(i)?"":` WHERE ${i.toString()}`,_=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${c}`,u=Zl.parse(_).statements[0],l=await ZF.writeTransaction(r.schema,r.name,async()=>{let E=await e0(u),d=a0(s,E);return o0(o,d,t)});return await vA.flush({schema:r.schema,table:r.name}),l}a(n0,"update");function i0(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value:t[r.column.columnid]=Zl.compile(`SELECT ${r.expression.toString()} AS [${t0.FUNC_VAL}] FROM ?`)}),t}catch(t){throw BA.error(t),new Error(s0)}}a(i0,"createUpdateRecord");function a0(e,t){return Jl.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(a0,"buildUpdateRecords");async function o0(e,t,r){let s={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r};try{let n=await vA.update(s);await r0.postOperationHandler(s,n);try{delete n.new_attributes,delete n.txn_time}catch(i){BA.error(`Error delete new_attributes from update response: ${i}`)}return n}catch(n){throw n}}a(o0,"updateRecords")});var VA=S((CX,FA)=>{var c0=require("alasql"),_0=mt(),u0=I(),l0=Or(),zl=require("util"),Xl=b(),E0=T(),d0=xr(),h0=Wo(),S0=Ns(),f0=Ut(),T0="record",m0="successfully deleted",R0=zl.callbackify(N0),A0=zl.promisify(_0.search),O0=zl.promisify(d0.getTableSchema);FA.exports={convertDelete:R0};function p0(e){return`${e.deleted_hashes.length} ${T0}${e.deleted_hashes.length===1?"":"s"} ${m0}`}a(p0,"generateReturnMessage");async function N0({statement:e,hdb_user:t}){let r=await O0(e.table.databaseid,e.table.tableid);Xl.backtickASTSchemaItems(e);let{table:s,where:n}=e,i=Xl.isEmpty(n)?"":` WHERE ${n.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${i}`,c=c0.parse(o).statements[0],_={operation:E0.OPERATIONS_ENUM.DELETE,schema:s.databaseid_orig,table:s.tableid_orig,hdb_user:t};try{let u=await h0.writeTransaction(r.schema,r.name,async()=>(_.records=await A0(c),l0.deleteRecords(_)));return await f0.flush({schema:r.schema,table:r.name}),u.deleted_hashes.length>0&&await S0.postOperationHandler(_,u),Xl.isEmptyOrZeroLength(u.message)&&(u.message=p0(u)),delete u.txn_time,u}catch(u){throw u0.error(u),u.hdb_code?u.message:u}}a(N0,"convertDelete")});var $A=S((wX,xA)=>{"use strict";var eE=fs(),{hdb_errors:jl}=D();xA.exports={checkSchemaExists:kA,checkSchemaTableExists:g0,schema_describe:eE};async function kA(e){if(!global.hdb_schema[e])try{let t=await eE.describeSchema({schema:e});global.hdb_schema[e]=t}catch{return jl.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}}a(kA,"checkSchemaExists");async function g0(e,t){let r=await kA(e);if(r)return r;if(!global.hdb_schema[e][t])try{let s=await eE.describeTable({schema:e,table:t});if(!s||Object.keys(s).length===0)return jl.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t);global.hdb_schema[e][t]=s}catch{return jl.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}}a(g0,"checkSchemaTableExists")});var tc=S((UX,JA)=>{"use strict";var An=Ka(),gs=$A(),YA=I(),I0=require("uuid").v4,LX=require("clone"),pn=js(),Is=T(),b0=require("util"),bs=Or(),{handleHDBError:Pe,hdb_errors:C0}=D(),{HDB_ERROR_MSGS:On,HTTP_STATUS_CODES:Be}=C0,{SchemaEventMsg:Nn}=Gr(),KA=ot();JA.exports={createSchema:w0,createSchemaStructure:QA,createTable:L0,createTableStructure:WA,createAttribute:P0,dropSchema:U0,dropTable:y0,dropAttribute:D0};async function w0(e){try{let t=await QA(e);return pn.signalSchemaChange(new Nn(process.pid,e.operation,e.schema)),t}catch(t){throw t}}a(w0,"createSchema");async function QA(e){let t=An.schema_object(e);if(t)throw Pe(t,t.message,Be.BAD_REQUEST,void 0,void 0,!0);if(!await gs.checkSchemaExists(e.schema))throw Pe(new Error,On.SCHEMA_EXISTS_ERR(e.schema),Be.BAD_REQUEST,Is.LOG_LEVELS.ERROR,On.SCHEMA_EXISTS_ERR(e.schema),!0);try{return await bs.createSchema(e),`schema '${e.schema}' successfully created`}catch(r){throw r}}a(QA,"createSchemaStructure");async function L0(e){try{let t=await WA(e);return pn.signalSchemaChange(new Nn(process.pid,e.operation,e.schema,e.table)),t}catch(t){throw t}}a(L0,"createTable");async function WA(e){let t=An.create_table_object(e);if(t)throw Pe(t,t.message,Be.BAD_REQUEST,void 0,void 0,!0);An.validateTableResidence(e.residence);let r=await gs.checkSchemaExists(e.schema);if(r)throw Pe(new Error,r,Be.NOT_FOUND,Is.LOG_LEVELS.ERROR,r,!0);if(!await gs.checkSchemaTableExists(e.schema,e.table))throw Pe(new Error,On.TABLE_EXISTS_ERR(e.schema,e.table),Be.BAD_REQUEST,Is.LOG_LEVELS.ERROR,On.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:I0(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await bs.createTable(n,e);else throw Pe(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Be.BAD_REQUEST);else await bs.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(i){throw i}}a(WA,"createTableStructure");async function U0(e){let t=An.schema_object(e);if(t)throw Pe(t,t.message,Be.BAD_REQUEST,void 0,void 0,!0);let r=await gs.checkSchemaExists(e.schema);if(r)throw Pe(new Error,r,Be.NOT_FOUND,Is.LOG_LEVELS.ERROR,r,!0);let s=await gs.schema_describe.describeSchema({schema:e.schema});global.hdb_schema[e.schema]=s;let n=Object.keys(global.hdb_schema[e.schema]);return await bs.dropSchema(e),pn.signalSchemaChange(new Nn(process.pid,e.operation,e.schema)),delete global.hdb_schema[e.schema],await KA.purgeSchemaTableStreams(e.schema,n),`successfully deleted schema '${e.schema}'`}a(U0,"dropSchema");async function y0(e){let t=An.table_object(e);if(t)throw Pe(t,t.message,Be.BAD_REQUEST,void 0,void 0,!0);let r=await gs.checkSchemaTableExists(e.schema,e.table);if(r)throw Pe(new Error,r,Be.NOT_FOUND,Is.LOG_LEVELS.ERROR,r,!0);return await bs.dropTable(e),pn.signalSchemaChange(new Nn(process.pid,e.operation,e.schema,e.table)),await KA.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(y0,"dropTable");async function D0(e){let t=An.attribute_object(e);if(t)throw Pe(t,t.message,Be.BAD_REQUEST,void 0,void 0,!0);let r=await gs.checkSchemaTableExists(e.schema,e.table);if(r)throw Pe(new Error,r,Be.NOT_FOUND,Is.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Pe(new Error,"You cannot drop a hash attribute",Be.BAD_REQUEST,void 0,void 0,!0);if(Is.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Pe(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Be.BAD_REQUEST,void 0,void 0,!0);try{return await bs.dropAttribute(e),M0(e),pn.signalSchemaChange(new Nn(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(s){throw YA.error(`Got an error deleting attribute ${b0.inspect(e)}.`),s}}a(D0,"dropAttribute");function M0(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(M0,"dropAttributeFromGlobal");async function P0(e){if(!global.hdb_schema[e.schema])throw Pe(new Error,On.SCHEMA_NOT_FOUND(e.schema),Be.NOT_FOUND,void 0,void 0,!0);if(!global.hdb_schema[e.schema][e.table])throw Pe(new Error,On.TABLE_NOT_FOUND(e.schema,e.table),Be.NOT_FOUND,void 0,void 0,!0);try{return await bs.createAttribute(e),pn.signalSchemaChange(new Nn(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}catch(t){throw YA.error(t),t}}a(P0,"createAttribute")});var XA=S((yX,ZA)=>{"use strict";var{OPERATIONS_ENUM:B0}=T(),rc=class{constructor(t,r,s=void 0,n=void 0){this.operation=B0.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=s,this.search_values=n}};a(rc,"ReadAuditLogObject");ZA.exports=rc});var tE=S((MX,rO)=>{"use strict";var v0=Or(),DX=XA(),sc=b(),nc=T(),H0=Y(),{handleHDBError:zA,hdb_errors:G0}=D(),{HDB_ERROR_MSGS:jA,HTTP_STATUS_CODES:eO}=G0,q0=Object.values(nc.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),tO="To use this operation audit log must be enabled in harperdb-config.yaml";rO.exports=F0;async function F0(e){if(sc.isEmpty(e.schema))throw new Error(jA.SCHEMA_REQUIRED_ERR);if(sc.isEmpty(e.table))throw new Error(jA.TABLE_REQUIRED_ERR);if(!H0.get(nc.CONFIG_PARAMS.LOGGING_AUDITLOG))throw zA(new Error,tO,eO.BAD_REQUEST,nc.LOG_LEVELS.ERROR,tO,!0);let t=sc.checkSchemaTableExist(e.schema,e.table);if(t)throw zA(new Error,t,eO.NOT_FOUND,nc.LOG_LEVELS.ERROR,t,!0);if(!sc.isEmpty(e.search_type)&&q0.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await v0.readAuditLog(e)}a(F0,"readAuditLog")});var cO=S((PX,oO)=>{var Jr=require("validate.js"),nO=de(),gn=T(),{handleHDBError:V0,hdb_errors:k0}=D(),{HDB_ERROR_MSGS:le,HTTP_STATUS_CODES:x0}=k0,rE=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),$0={STRUCTURE_USER:"structure_user"},sO=Object.values(gn.ROLE_TYPES_ENUM),Y0="attribute_permissions",K0="attribute_name",{PERMS_CRUD_ENUM:In}=gn,Q0=[Y0,...Object.values(In)],iO=[In.READ,In.INSERT,In.UPDATE],W0=[K0,...iO];function J0(e){let t=rE();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,aO(e,t)}a(J0,"addRoleValidation");function Z0(e){let t=rE();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,aO(e,t)}a(Z0,"alterRoleValidation");function X0(e){let t=rE();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,nO.validateObject(e,t)}a(X0,"dropRoleValidation");var z0=["operation","role","id","permission","hdb_user","hdb_auth_header"];function aO(e,t){let r={main_permissions:[],schema_permissions:{}},s=Object.keys(e),n=[];for(let o=0,c=s.length;o<c;o++)z0.includes(s[o])||n.push(s[o]);n.length>0&&fe(le.INVALID_ROLE_JSON_KEYS(n),r);let i=nO.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{fe(o,r)}),e.permission){let o=j0(e);o&&fe(o,r),sO.forEach(c=>{e.permission[c]&&!Jr.isBoolean(e.permission[c])&&fe(le.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(sO.indexOf(o)<0){if(o===$0.STRUCTURE_USER){let _=e.permission[o];if(typeof _=="boolean")continue;if(Array.isArray(_)){for(let u=0,l=_.length;u<l;u++){let E=_[u];global.hdb_schema[E]||fe(le.SCHEMA_NOT_FOUND(E),r)}continue}fe(le.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){fe(le.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let _ in c.tables){let u=c.tables[_];if(!_||!global.hdb_schema[o][_]){fe(le.TABLE_NOT_FOUND(o,_),r);continue}if(Object.keys(u).forEach(l=>{Q0.includes(l)||fe(le.INVALID_PERM_KEY(l),r,o,_)}),Object.values(In).forEach(l=>{Jr.isDefined(u[l])?Jr.isBoolean(u[l])||fe(le.TABLE_PERM_NOT_BOOLEAN(l),r,o,_):fe(le.TABLE_PERM_MISSING(l),r,o,_)}),Jr.isDefined(u.attribute_permissions)){if(!Jr.isArray(u.attribute_permissions)){fe(le.ATTR_PERMS_NOT_ARRAY,r,o,_);continue}}else{fe(le.ATTR_PERMS_ARRAY_MISSING,r,o,_);continue}if(u.attribute_permissions){let l=global.hdb_schema[o][_].attributes.map(({attribute:d})=>d),E={read:!1,insert:!1,update:!1};for(let d in u.attribute_permissions){let h=u.attribute_permissions[d];if(Object.keys(h).forEach(R=>{!W0.includes(R)&&R!==In.DELETE&&fe(le.INVALID_ATTR_PERM_KEY(R),r,o,_)}),!Jr.isDefined(h.attribute_name)){fe(le.ATTR_PERM_MISSING_NAME,r,o,_);continue}let m=h.attribute_name;if(!l.includes(m)){fe(le.INVALID_ATTRIBUTE_IN_PERMS(m),r,o,_);continue}iO.forEach(R=>{Jr.isDefined(h[R])?Jr.isBoolean(h[R])||fe(le.ATTR_PERM_NOT_BOOLEAN(R,m),r,o,_):fe(le.ATTR_PERM_MISSING(R,m),r,o,_)}),!E.read&&h.read===!0&&(E.read=!0),!E.insert&&h.insert===!0&&(E.insert=!0),!E.update&&h.update===!0&&(E.update=!0)}if(u.read===!1&&E.read===!0||u.insert===!1&&E.insert===!0||u.update===!1&&E.update===!0){let d=`${o}.${_}`;fe(le.MISMATCHED_TABLE_ATTR_PERMS(d),r,o,_)}}}}return eV(r)}a(aO,"customValidate");oO.exports={addRoleValidation:J0,alterRoleValidation:Z0,dropRoleValidation:X0};function j0(e){let{operation:t,permission:r}=e;if(t===gn.OPERATIONS_ENUM.ADD_ROLE||t===gn.OPERATIONS_ENUM.ALTER_ROLE){let s=r.super_user===!0,n=r.cluster_user===!0;if(Object.keys(r).length>1&&(s||n)){if(n&&s)return le.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?gn.ROLE_TYPES_ENUM.SUPER_USER:gn.ROLE_TYPES_ENUM.CLUSTER_USER;return le.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(j0,"validateNoSUPerms");function eV(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let s={error:le.ROLE_PERMS_ERROR,...e};return V0(new Error,s,x0.BAD_REQUEST)}else return null}a(eV,"generateRolePermResponse");function fe(e,t,r,s){if(!r)t.main_permissions.push(e);else{let n=s?r+"_"+s:r;t.schema_permissions[n]?t.schema_permissions[n].push(e):t.schema_permissions[n]=[e]}}a(fe,"addPermError")});var uE=S((BX,hO)=>{"use strict";var _O=Ut(),uO=mt(),tV=Rs(),iE=cO(),aE=js(),rV=require("uuid").v4,oE=require("util"),sV=Ai(),Nr=T(),lO=b(),cE=oE.promisify(uO.searchByValue),nV=oE.promisify(uO.searchByHash),iV=oE.promisify(tV.delete),aV=Kt(),oV=ds(),{hdb_errors:cV,handleHDBError:Ui}=D(),{HDB_ERROR_MSGS:EO,HTTP_STATUS_CODES:sE}=cV,{UserEventMsg:_E}=Gr();hO.exports={addRole:_V,alterRole:lV,dropRole:EV,listRoles:dO};function nE(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(nE,"scrubRoleDetails");async function _V(e){let t=iE.addRoleValidation(e);if(t)throw t;if(!(await sV.getLicense()).enterprise){let o=await dO();if(uV(e,o))throw new Error(`Your current license only supports ${Nr.BASIC_LICENSE_MAX_CLUSTER_USER_ROLES} cluster_user role. ${Nr.SUPPORT_HELP_MSG}`);if(o.length>=2)throw new Error(`Your current license only supports ${Nr.BASIC_LICENSE_MAX_NON_CU_ROLES+Nr.BASIC_LICENSE_MAX_CLUSTER_USER_ROLES} roles. ${Nr.SUPPORT_HELP_MSG}`)}e=nE(e);let s={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=await cE(s)}catch(o){throw Ui(o)}if(n&&n.length>0)throw Ui(new Error,EO.ROLE_ALREADY_EXISTS(e.role),sE.CONFLICT,void 0,void 0,!0);e.id||(e.id=rV());let i={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await _O.insert(i),aE.signalUserChange(new _E(process.pid)),e=nE(e),e}a(_V,"addRole");function uV(e,t){let r=!1;if(e.permission.cluster_user===!0)for(let s=0;s<t.length;s++){let i=t[s].permission;if(!lO.isEmpty(i)&&i.cluster_user===!0)return!0}return r}a(uV,"checkClusterUserRole");async function lV(e){let t=iE.alterRoleValidation(e);if(t)throw t;e=nE(e);let r={operation:"update",schema:"system",table:"hdb_role",hash_attribute:"rolename",records:[e]};try{await _O.update(r)}catch(s){throw Ui(s)}return aE.signalUserChange(new _E(process.pid)),e}a(lV,"alterRole");async function EV(e){let t=iE.dropRoleValidation(e);if(t)throw Ui(new Error,t,sE.BAD_REQUEST,void 0,void 0,!0);let r=new oV(Nr.SYSTEM_SCHEMA_NAME,Nr.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),s=await nV(r);if(s.length===0)throw Ui(new Error,EO.ROLE_NOT_FOUND,sE.NOT_FOUND,void 0,void 0,!0);let n=new aV(Nr.SYSTEM_SCHEMA_NAME,Nr.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=await cE(n),o=!1;if(lO.isEmptyOrZeroLength(i)===!1){for(let _=0;_<i.length;_++)if(i[_].active===!0){o=!0;break}}if(o===!0)throw new Error(`Cannot drop role ${s[0].role} as it has active user(s) tied to this role`);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await iV(c),aE.signalUserChange(new _E(process.pid)),`${s[0].role} successfully deleted`}a(EV,"dropRole");async function dO(){return cE({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(dO,"listRoles")});var mO=S((vX,TO)=>{"use strict";var dV=Y(),Zr=require("joi"),hV=de(),SO=require("moment"),SV=require("fs-extra"),lE=require("path"),fV=require("lodash"),yi=T(),{LOG_LEVELS:Cs}=T(),TV="YYYY-MM-DD hh:mm:ss",mV=lE.resolve(__dirname,"../logs");TO.exports=function(e){return hV.validateBySchema(e,RV)};var RV=Zr.object({from:Zr.custom(fO),until:Zr.custom(fO),level:Zr.valid(Cs.NOTIFY,Cs.FATAL,Cs.ERROR,Cs.WARN,Cs.INFO,Cs.DEBUG,Cs.TRACE),order:Zr.valid("asc","desc"),limit:Zr.number().min(1),start:Zr.number().min(0),log_name:Zr.custom(AV)});function fO(e,t){if(SO(e,SO.ISO_8601).format(TV)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(fO,"validateDatetime");function AV(e,t){if(fV.invert(yi.PROCESS_LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let s=dV.get(yi.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e===void 0?yi.PROCESS_LOG_NAMES.HDB:e,i=n===yi.PROCESS_LOG_NAMES.INSTALL?lE.join(mV,yi.PROCESS_LOG_NAMES.INSTALL):lE.join(s,n);return SV.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(AV,"validateReadLogPath")});var dE=S((HX,AO)=>{"use strict";var ic=T(),RO=I(),OV=Y(),pV=mO(),EE=require("path"),NV=require("fs-extra"),gV=require("readline"),{once:IV}=require("events"),{handleHDBError:bV,hdb_errors:CV}=D(),{PACKAGE_ROOT:wV}=T(),LV=EE.join(wV,"logs"),UV=1e3;AO.exports=yV;async function yV(e){let t=pV(e);if(t)throw bV(t,t.message,CV.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=OV.get(ic.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e.log_name===void 0?ic.PROCESS_LOG_NAMES.HDB:e.log_name,n=s===ic.PROCESS_LOG_NAMES.INSTALL?EE.join(LV,ic.PROCESS_LOG_NAMES.INSTALL):EE.join(r,s),i=NV.createReadStream(n);i.on("error",z=>{RO.error(z)});let o=gV.createInterface({input:i,crlfDelay:1/0}),c=e.level!==void 0,_=c?e.level:void 0,u=e.from!==void 0,l=u?new Date(e.from):void 0,E=e.until!==void 0,d=E?new Date(e.until):void 0,h=e.limit===void 0?UV:e.limit,m=e.order===void 0?void 0:e.order,R=e.start===void 0?0:e.start,w=R+h,L=0,B=[];return o.on("line",z=>{let V,W,ke,xe;try{V=JSON.parse(z)}catch(ua){RO.warn(ua.message);return}switch(!0){case(c&&u&&E):W=new Date(V.timestamp),ke=new Date(l),xe=new Date(d),V.level===_&&W>=ke&&W<=xe&&L<R?L++:V.level===_&&W>=ke&&W<=xe&&(zr(V,m,B),L++,L===w&&Xr(o));break;case(c&&u):W=new Date(V.timestamp),ke=new Date(l),V.level===_&&W>=ke&&L<R?L++:V.level===_&&W>=ke&&(zr(V,m,B),L++,L===w&&Xr(o));break;case(c&&E):W=new Date(V.timestamp),xe=new Date(d),V.level===_&&W<=xe&&L<R?L++:V.level===_&&W<=xe&&(zr(V,m,B),L++,L===w&&Xr(o));break;case(u&&E):W=new Date(V.timestamp),ke=new Date(l),xe=new Date(d),W>=ke&&W<=xe&&L<R?L++:W>=ke&&W<=xe&&(zr(V,m,B),L++,L===w&&Xr(o));break;case c:V.level===_&&L<R?L++:V.level===_&&(zr(V,m,B),L++,L===w&&Xr(o));break;case u:W=new Date(V.timestamp),ke=new Date(l),W>=ke&&L<R?L++:W>=ke&&L>=R&&(zr(V,m,B),L++,L===w&&Xr(o));break;case E:W=new Date(V.timestamp),xe=new Date(d),W<=xe&&L<R?L++:W<=xe&&L>=R&&(zr(V,m,B),L++,L===w&&Xr(o));break;default:L<R?L++:(zr(V,m,B),L++,L===w&&Xr(o))}}),await IV(o,"close"),B}a(yV,"readLog");function Xr(e){e.close(),e.removeAllListeners()}a(Xr,"endReadLine");function zr(e,t,r){t==="desc"?DV(e,r):t==="asc"?MV(e,r):r.push(e)}a(zr,"pushLineToResult");function DV(e,t){let r=new Date(e.timestamp),s=0,n=t.length;for(;s<n;){let i=s+n>>>1;new Date(t[i].timestamp)>r?s=i+1:n=i}t.splice(s,0,e)}a(DV,"insertDescending");function MV(e,t){let r=new Date(e.timestamp),s=0,n=t.length;for(;s<n;){let i=s+n>>>1;new Date(t[i].timestamp)<r?s=i+1:n=i}t.splice(s,0,e)}a(MV,"insertAscending")});var oc=S((FX,NO)=>{"use strict";var hE=require("joi"),{string:ac,boolean:OO,date:PV}=hE.types(),BV=de(),{validateSchemaExists:GX,validateTableExists:qX,validateSchemaName:vV}=Tr(),HV=T(),GV=_e(),qV=Y(),FV=ac.invalid(qV.get(HV.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(GV.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(),pO={operation:ac.valid("add_node","update_node"),node_name:FV,subscriptions:hE.array().items({table:ac.required(),schema:ac.custom(vV).required(),subscribe:OO.required(),publish:OO.required().custom(kV),start_time:PV.iso()}).min(1).required()};function VV(e){return BV.validateBySchema(e,hE.object(pO))}a(VV,"addUpdateNodeValidator");function kV(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(kV,"checkForFalsy");NO.exports={addUpdateNodeValidator:VV,validation_schema:pO}});var IO=S((VX,gO)=>{var xV=de(),$V={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};gO.exports=function(e){return xV.validateObject(e,$V)}});var SE=S((kX,bO)=>{"use strict";var YV=T().OPERATIONS_ENUM,cc=class{constructor(t,r,s,n=void 0){this.operation=YV.UPDATE,this.schema=t,this.table=r,this.records=s,this.__origin=n}};a(cc,"UpdateObject");bO.exports=cc});var wO=S((xX,CO)=>{"use strict";var KV={OPERATION:"operation",REFRESH:"refresh"},_c=class{constructor(t,r){this.operation_token=t,this.refresh_token=r}};a(_c,"JWTTokens");var uc=class{constructor(t,r,s){this.public_key=t,this.private_key=r,this.passphrase=s}};a(uc,"JWTRSAKeys");CO.exports={JWTTokens:_c,TOKEN_TYPE_ENUM:KV,JWTRSAKeys:uc}});var hc=S(($X,DO)=>{"use strict";var Mi=require("jsonwebtoken"),fE=require("fs-extra"),TE=b(),Dt=T(),{handleHDBError:ct,hdb_errors:QV}=D(),{HTTP_STATUS_CODES:_t,AUTHENTICATION_ERROR_MSGS:ut}=QV,Di=I(),LO=xo(),AE=Wr(),WV=Ut().update,JV=SE(),ZV=js(),{UserEventMsg:XV}=Gr(),jr=Y();jr.initSync();var mE=require("path"),{JWTTokens:zV,JWTRSAKeys:jV,TOKEN_TYPE_ENUM:lc}=wO(),ek=jr.get(Dt.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?jr.get(Dt.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",tk=jr.get(Dt.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?jr.get(Dt.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",Ec="RS256",RE;DO.exports={createTokens:rk,validateOperationToken:nk,refreshOperationToken:sk,validateRefreshToken:yO};async function rk(e){if(TE.isEmpty(e)||typeof e!="object")throw ct(new Error,ut.INVALID_AUTH_OBJECT,_t.BAD_REQUEST,void 0,void 0,!0);if(TE.isEmpty(e.username))throw ct(new Error,ut.USERNAME_REQUIRED,_t.BAD_REQUEST,void 0,void 0,!0);if(TE.isEmpty(e.password))throw ct(new Error,ut.PASSWORD_REQUIRED,_t.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await AE.findAndValidateUser(e.username,e.password),!t)throw ct(new Error,ut.INVALID_CREDENTIALS,_t.UNAUTHORIZED,void 0,void 0,!0)}catch(d){throw Di.error(d),ct(new Error,ut.INVALID_CREDENTIALS,_t.UNAUTHORIZED,void 0,void 0,!0)}let r=await dc(),s=!1,n=!1;t.role&&t.role.permission&&(s=t.role.permission.super_user===!0,n=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:s,cluster_user:n},o=await UO(i,r.private_key,r.passphrase),c=await Mi.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:tk,algorithm:Ec,subject:lc.REFRESH}),_=LO.hash(c),u=new JV(Dt.SYSTEM_SCHEMA_NAME,Dt.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:_}]),l,E;try{l=await WV(u)}catch(d){Di.error(d),E=d}if(E!==void 0||l.skipped_hashes.length>0)throw ct(new Error,ut.REFRESH_TOKEN_SAVE_FAILED,_t.INTERNAL_SERVER_ERROR);return ZV.signalUserChange(new XV(process.pid)),new zV(o,c)}a(rk,"createTokens");async function UO(e,t,r){return await Mi.sign(e,{key:t,passphrase:r},{expiresIn:ek,algorithm:Ec,subject:lc.OPERATION})}a(UO,"signOperationToken");async function dc(){if(RE===void 0)try{let e=mE.join(jr.getHdbBasePath(),Dt.LICENSE_KEY_DIR_NAME,Dt.JWT_ENUM.JWT_PASSPHRASE_NAME),t=mE.join(jr.getHdbBasePath(),Dt.LICENSE_KEY_DIR_NAME,Dt.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=mE.join(jr.getHdbBasePath(),Dt.LICENSE_KEY_DIR_NAME,Dt.JWT_ENUM.JWT_PUBLIC_KEY_NAME),s=(await fE.readFile(e)).toString(),n=(await fE.readFile(t)).toString(),i=(await fE.readFile(r)).toString();RE=new jV(i,n,s)}catch(e){throw Di.error(e),ct(new Error,ut.NO_ENCRYPTION_KEYS,_t.INTERNAL_SERVER_ERROR)}return RE}a(dc,"getJWTRSAKeys");async function sk(e){if(!e)throw ct(new Error,ut.INVALID_BODY,_t.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw ct(new Error,ut.REFRESH_TOKEN_REQUIRED,_t.BAD_REQUEST,void 0,void 0,!0);await yO(e.refresh_token);let t=await dc(),r=await Mi.decode(e.refresh_token);return{operation_token:await UO({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(sk,"refreshOperationToken");async function nk(e){try{let t=await dc(),r=await Mi.verify(e,t.public_key,{algorithms:Ec,subject:lc.OPERATION});return await AE.findAndValidateUser(r.username,void 0,!1)}catch(t){throw Di.warn(t),t.name&&t.name==="TokenExpiredError"?ct(new Error,ut.TOKEN_EXPIRED,_t.FORBIDDEN):ct(new Error,ut.INVALID_TOKEN,_t.UNAUTHORIZED)}}a(nk,"validateOperationToken");async function yO(e){let t;try{let r=await dc(),s=await Mi.verify(e,r.public_key,{algorithms:Ec,subject:lc.REFRESH});t=await AE.findAndValidateUser(s.username,void 0,!1)}catch(r){throw Di.warn(r),r.name&&r.name==="TokenExpiredError"?ct(new Error,ut.TOKEN_EXPIRED,_t.FORBIDDEN):ct(new Error,ut.INVALID_TOKEN,_t.UNAUTHORIZED)}if(!LO.validate(t.refresh_token,e))throw ct(new Error,ut.INVALID_TOKEN,_t.UNAUTHORIZED);return t}a(yO,"validateRefreshToken")});var vO=S((KX,BO)=>{"use strict";var ik=IO(),bn=require("passport"),ak=require("passport-local").Strategy,ok=require("passport-http").BasicStrategy,ck=require("util"),_k=Wr(),PO=ck.callbackify(_k.findAndValidateUser),YX=Ke(),uk=T(),MO=hc();bn.use(new ak(function(e,t,r){PO(e,t,r)}));bn.use(new ok(function(e,t,r){PO(e,t,r)}));bn.serializeUser(function(e,t){t(null,e)});bn.deserializeUser(function(e,t){t(null,e)});function lk(e,t,r){let s,n;if(e.headers&&e.headers.authorization){let o=e.headers.authorization.split(" ");s=o[0],n=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("User not found")}switch(a(i,"handleResponse"),s){case"Basic":bn.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body&&e.body.operation&&e.body.operation===uk.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?MO.validateRefreshToken(n).then(o=>{e.body.refresh_token=n,r(null,o)}).catch(o=>{r(o)}):MO.validateOperationToken(n).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:bn.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(lk,"authorize");function Ek(e,t){let r=ik(e);if(r){t(r);return}let s={authorized:!0,messages:[]},n=e.user.role;if(!n||!n.permission)return t("Invalid role");let i=JSON.parse(n.permission);if(i.super_user)return t(null,s);if(!i[e.schema])return s.authorized=!1,s.messages.push(`Not authorized to access ${e.schema} schema`),t(null,s);if(!i[e.schema].tables[e.table])return s.authorized=!1,s.messages.push(`Not authorized to access ${e.table} table`),t(null,s);if(!i[e.schema].tables[e.table][e.operation])return s.authorized=!1,s.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,s);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return s.authorized=!1,s.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,s);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]&&(s.authorized=!1,s.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,s)}a(Ek,"checkPermissions");BO.exports={authorize:lk,checkPermissions:Ek}});var Cn=S((QX,HO)=>{"use strict";var Sc=class{constructor(t,r,s){this.name=t,this.subscriptions=r,this.system_info=s}};a(Sc,"Node");var fc=class{constructor(t,r,s,n){this.schema=t,this.table=r,this.publish=s,this.subscribe=n}};a(fc,"NodeSubscription");HO.exports={Node:Sc,NodeSubscription:fc}});var qO=S((WX,GO)=>{"use strict";var dk=T().OPERATIONS_ENUM,Tc=class{constructor(t,r,s,n=void 0){this.operation=dk.UPSERT,this.schema=t,this.table=r,this.records=s,this.__origin=n}};a(Tc,"UpsertObject");GO.exports=Tc});var Pi=S((JX,FO)=>{"use strict";var mc=class{constructor(t,r,s,n){this.operation=t,this.node_name=r,this.subscriptions=s,this.system_info=n}};a(mc,"RemotePayloadObject");var Rc=class{constructor(t,r,s,n,i,o){this.schema=t,this.table=r,this.hash_attribute=s,this.publish=n,this.subscribe=i,this.start_time=o}};a(Rc,"RemotePayloadSubscription");FO.exports={RemotePayloadObject:mc,RemotePayloadSubscription:Rc}});var kO=S((ZX,VO)=>{"use strict";var Ac=class{constructor(t,r,s=0,n=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=s,this.record_count=n,this.transaction_log_size=i,this.transaction_log_record_count=o}};a(Ac,"TableSizeObject");VO.exports=Ac});var KO=S((XX,YO)=>{"use strict";var hk=kO(),xO=require("path"),$O=te(),Sk=Ye(),wn=Z(),fk=I();YO.exports=Tk;async function Tk(e){let t=new hk;try{let r=xO.join($O.getBaseSchemaPath(),e.schema.toString()),s=await wn.openEnvironment(r,e.name),n=wn.statDBI(s,e.hash_attribute),i=xO.join($O.getTransactionAuditStorePath(),e.schema.toString()),o=await wn.openEnvironment(i,e.name,!0),c=wn.statDBI(o,Sk.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP),_=await wn.environmentDataSize(r,e.name),u=await wn.environmentDataSize(i,e.name);t.schema=e.schema,t.table=e.name,t.table_size=_,t.record_count=n.entryCount,t.transaction_log_size=u,t.transaction_log_record_count=c.entryCount}catch(r){fk.warn(`unable to stat table dbi due to ${r}`)}return t}a(Tk,"lmdbGetTableSize")});var WO=S((zX,QO)=>{"use strict";var mk=T(),Oc=class{constructor(t){this.operator=mk.OPERATIONS_ENUM.SYSTEM_INFORMATION,this.attributes=t}};a(Oc,"SystemInformationOperation");QO.exports=Oc});var ZO=S((jX,JO)=>{"use strict";var pc=class{constructor(t,r,s,n,i,o,c){this.system=t,this.time=r,this.cpu=s,this.memory=n,this.disk=i,this.network=o,this.harperdb_processes=c}};a(pc,"SystemInformationObject");JO.exports=pc});var gc=S((t3,XO)=>{"use strict";var ve=require("systeminformation"),Ln=I(),Rk=T(),Ak=KO(),Ok=fs(),pk=Y();pk.initSync();var e3=WO(),Nk=ZO(),Nc;XO.exports={getHDBProcessInfo:gE,getNetworkInfo:bE,getDiskInfo:IE,getMemoryInfo:NE,getCPUInfo:pE,getTimeInfo:OE,getSystemInformation:CE,systemInformation:gk,getTableSize:wE};function OE(){return ve.time()}a(OE,"getTimeInfo");async function pE(){try{let{family:e,model:t,stepping:r,revision:s,voltage:n,speedmin:i,speedmax:o,governor:c,socket:_,cache:u,...l}=await ve.cpu();l.cpu_speed=await ve.cpuCurrentSpeed();let{raw_currentload:E,raw_currentload_idle:d,raw_currentload_irq:h,raw_currentload_nice:m,raw_currentload_system:R,raw_currentload_user:w,cpus:L,...B}=await ve.currentLoad();return B.cpus=[],L.forEach(z=>{let{raw_load:V,raw_load_idle:W,raw_load_irq:ke,raw_load_nice:xe,raw_load_system:ua,raw_load_user:la,...yr}=z;B.cpus.push(yr)}),l.current_load=B,l}catch(e){return Ln.error(`error in getCPUInfo: ${e}`),{}}}a(pE,"getCPUInfo");async function NE(){try{let{buffers:e,cached:t,slab:r,buffcache:s,...n}=await ve.mem();return n}catch(e){return Ln.error(`error in getMemoryInfo: ${e}`),{}}}a(NE,"getMemoryInfo");async function gE(){let e={core:[],clustering:[]};try{return(await ve.processes()).list.forEach(r=>{r.params.includes(Rk.HDB_PROC_NAME)?e.core.push(r):r.params.includes("socketcluster")&&e.clustering.push(r)}),e}catch(t){return Ln.error(`error in getHDBProcessInfo: ${t}`),e}}a(gE,"getHDBProcessInfo");async function IE(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:s,ms:n,...i}=await ve.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:_,...u}=await ve.fsStats();return e.read_write=u,e.size=await ve.fsSize(),e}catch(t){return Ln.error(`error in getDiskInfo: ${t}`),e}}a(IE,"getDiskInfo");async function bE(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await ve.networkInterfaceDefault(),e.latency=await ve.inetChecksite("google.com"),(await ve.networkInterfaces()).forEach(s=>{let{internal:n,virtual:i,mtu:o,dhcp:c,dnsSuffix:_,ieee8021xAuth:u,ieee8021xState:l,carrier_changes:E,...d}=s;e.interfaces.push(d)}),(await ve.networkStats()).forEach(s=>{let{rx_sec:n,tx_sec:i,ms:o,...c}=s;e.stats.push(c)}),e.connections=await ve.networkConnections(),e}catch(t){return Ln.error(`error in getNetworkInfo: ${t}`),e}}a(bE,"getNetworkInfo");async function CE(){if(Nc!==void 0)return Nc;let e={};try{let{codepage:t,logofile:r,serial:s,build:n,servicepack:i,uefi:o,...c}=await ve.osInfo();e=c;let _=await ve.versions("node, npm");return e.node_version=_.node,e.npm_version=_.npm,Nc=e,Nc}catch(t){return Ln.error(`error in getSystemInformation: ${t}`),e}}a(CE,"getSystemInformation");async function wE(){let e=[],t=await Ok.describeAll();for(let r of Object.values(t))for(let s of Object.values(r))e.push(await Ak(s));return e}a(wE,"getTableSize");async function gk(e){let t=new Nk;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await CE(),t.time=OE(),t.cpu=await pE(),t.memory=await NE(),t.disk=await IE(),t.network=await bE(),t.harperdb_processes=await gE(),t.table_size=await wE(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await CE();break;case"time":t.time=OE();break;case"cpu":t.cpu=await pE();break;case"memory":t.memory=await NE();break;case"disk":t.disk=await IE();break;case"network":t.network=await bE();break;case"harperdb_processes":t.harperdb_processes=await gE();break;case"table_size":t.table_size=await wE();break;default:break}return t}a(gk,"systemInformation")});var LE=S((n3,zO)=>{"use strict";var r3=require("fs-extra"),s3=I();zO.exports={version:Ik,printVersion:Ck,nodeVersion:bk};var es=vl();function Ik(){if(es)return es.version}a(Ik,"version");function bk(){if(es&&es.engines&&es.engines["preferred-node"])return es.engines["preferred-node"]}a(bk,"nodeVersion");function Ck(){es&&console.log(`HarperDB Version ${es.version}`)}a(Ck,"printVersion")});var Ls=S((o3,rp)=>{"use strict";var wk=Ut(),UE=b(),yE=require("util"),ws=T(),jO=Y();jO.initSync();var Lk=vO(),ep=mt(),{Node:i3,NodeSubscription:a3}=Cn(),Uk=ds(),yk=qO(),{RemotePayloadObject:Dk,RemotePayloadSubscription:Mk}=Pi(),{handleHDBError:Pk,hdb_errors:Bk}=D(),{HTTP_STATUS_CODES:vk,HDB_ERROR_MSGS:Hk}=Bk,Gk=Kt(),qk=gc(),Fk=LE(),Vk=yE.promisify(Lk.authorize),kk=yE.promisify(ep.searchByHash),xk=yE.promisify(ep.searchByValue);rp.exports={authHeaderToUser:$k,isEmpty:Yk,getNodeRecord:Kk,upsertNodeRecord:Qk,buildNodePayloads:Wk,checkClusteringEnabled:Jk,getAllNodeRecords:Zk,getSystemInfo:Xk,reverseSubscription:tp};async function $k(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Vk(t,null),e}a($k,"authHeaderToUser");function Yk(e){return e==null}a(Yk,"isEmpty");async function Kk(e){let t=new Uk(ws.SYSTEM_SCHEMA_NAME,ws.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return kk(t)}a(Kk,"getNodeRecord");async function Qk(e){let t=new yk(ws.SYSTEM_SCHEMA_NAME,ws.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return wk.upsert(t)}a(Qk,"upsertNodeRecord");function tp(e){if(UE.isEmpty(e.subscribe)||UE.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:s}=e,n={schema:t,table:r,hash_attribute:s};return e.subscribe===!0&&e.publish===!1?(n.subscribe=!1,n.publish=!0):e.subscribe===!1&&e.publish===!0?(n.subscribe=!0,n.publish=!1):(n.subscribe=e.subscribe,n.publish=e.publish),n}a(tp,"reverseSubscription");function Wk(e,t,r,s){let n=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:_,table:u}=c,l=UE.getTableHashAttribute(_,u),{subscribe:E,publish:d}=tp(c),h=new Mk(_,u,l,d,E,c.start_time);n.push(h)}return new Dk(r,t,n,s)}a(Wk,"buildNodePayloads");function Jk(){if(!jO.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Pk(new Error,Hk.CLUSTERING_NOT_ENABLED,vk.BAD_REQUEST,void 0,void 0,!0)}a(Jk,"checkClusteringEnabled");async function Zk(){let e=new Gk(ws.SYSTEM_SCHEMA_NAME,ws.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return xk(e)}a(Zk,"getAllNodeRecords");async function Xk(){let e=await qk.getSystemInformation();return{hdb_version:Fk.version(),node_version:e.node_version,platform:e.platform}}a(Xk,"getSystemInfo")});var ME=S((c3,cp)=>{"use strict";var DE=ot(),sp=b(),np=_e(),zk=T(),Ic=I(),ip=tc(),jk=el(),{RemotePayloadObject:ex}=Pi(),{handleHDBError:ap,hdb_errors:tx}=D(),{HTTP_STATUS_CODES:op}=tx,{NodeSubscription:rx}=Cn();cp.exports=sx;async function sx(e,t){let r;try{r=await DE.request(`${t}.${np.REQUEST_SUFFIX}`,new ex(zk.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Ic.trace("Response from remote describe all request:",r)}catch(o){Ic.error(`addNode received error from describe all request to remote node: ${o}`);let c=DE.requestErrorHandler(o,"add_node",t);throw ap(new Error,c,op.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===np.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw ap(new Error,o,op.INTERNAL_SERVER_ERROR,"error",o)}let s=r.message,n=[],i=[];for(let o of e){let{schema:c,table:_}=o,u=sp.doesSchemaExist(c),l=s[c]!==void 0,E=sp.doesTableExist(c,_),d=s?.[c]?.[_]!==void 0;if(!u&&!l||!E&&!d){n.push(o);continue}if(!u&&l&&(Ic.trace(`addNode creating schema: ${c}`),await ip.createSchema({operation:"create_schema",schema:c})),!E&&d){Ic.trace(`addNode creating table: ${_} in schema: ${c}`);let m=new jk(c,_,s[c][_].hash_attribute);await ip.createTable(m)}await DE.createLocalTableStream(c,_);let h=new rx(c,_,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h)}return{added:i,skipped:n}}a(sx,"reviewSubscriptions")});var wc=S((_3,lp)=>{"use strict";var{handleHDBError:bc,hdb_errors:nx}=D(),{HTTP_STATUS_CODES:Cc}=nx,{addUpdateNodeValidator:ix}=oc(),Bi=I(),up=T(),_p=_e(),ax=b(),PE=ot(),vi=Ls(),ox=Y(),cx=ME(),{Node:_x,NodeSubscription:ux}=Cn(),lx="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Ex="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",dx=ox.get(up.CONFIG_PARAMS.CLUSTERING_NODENAME);lp.exports=hx;async function hx(e,t=!1){Bi.trace("addNode called with:",e),vi.checkClusteringEnabled();let r=ix(e);if(r)throw bc(r,r.message,Cc.BAD_REQUEST,void 0,void 0,!0);let s=e.node_name;if(!t){let E=await vi.getNodeRecord(s);if(!ax.isEmptyOrZeroLength(E))throw bc(new Error,`Node '${s}' has already been added, perform update_node to proceed.`,Cc.BAD_REQUEST,void 0,void 0,!0)}let{added:n,skipped:i}=await cx(e.subscriptions,s),o={message:void 0,added:n,skipped:i};if(n.length===0)return o.message=lx,o;let c=vi.buildNodePayloads(n,dx,up.OPERATIONS_ENUM.ADD_NODE,await vi.getSystemInfo());Bi.trace("addNode sending remote payload:",c);let _;try{_=await PE.request(`${s}.${_p.REQUEST_SUFFIX}`,c)}catch(E){Bi.error(`addNode received error from request: ${E}`);let d=PE.requestErrorHandler(E,"add_node",s);throw bc(new Error,d,Cc.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===_p.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let E=`Error returned from remote node ${s}: ${_.message}`;throw bc(new Error,E,Cc.INTERNAL_SERVER_ERROR,"error",E)}Bi.trace(_);let u=[];for(let E=0,d=n.length;E<d;E++){let h=n[E];Bi.trace("Add node updating work stream for node:",s,"subscriptions:",h),await PE.updateWorkStream(h,s),n[E].start_time===void 0&&delete n[E].start_time,u.push(new ux(h.schema,h.table,h.publish,h.subscribe))}let l=new _x(s,u,_.system_info);return await vi.upsertNodeRecord(l),i.length>0?o.message=Ex:o.message=`Successfully added '${s}' to manifest`,o}a(hx,"addNode")});var vE=S((u3,hp)=>{"use strict";var{handleHDBError:Lc,hdb_errors:Sx}=D(),{HTTP_STATUS_CODES:Uc}=Sx,{addUpdateNodeValidator:fx}=oc(),Hi=I(),dp=T(),Ep=_e(),Tx=b(),BE=ot(),Gi=Ls(),mx=Y(),{cloneDeep:Rx}=require("lodash"),Ax=ME(),{NodeSubscription:Ox}=Cn(),px="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",Nx="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",gx=mx.get(dp.CONFIG_PARAMS.CLUSTERING_NODENAME);hp.exports=Ix;async function Ix(e){Hi.trace("updateNode called with:",e),Gi.checkClusteringEnabled();let t=fx(e);if(t)throw Lc(t,t.message,Uc.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,s=Rx(await Gi.getNodeRecord(r));if(Tx.isEmptyOrZeroLength(s))throw Lc(new Error,`Node '${r}' has not been added, perform add_node to proceed.`,Uc.BAD_REQUEST,void 0,void 0,!0);let{added:n,skipped:i}=await Ax(e.subscriptions,r),o={message:void 0,updated:n,skipped:i};if(n.length===0)return o.message=px,o;let c=Gi.buildNodePayloads(n,gx,dp.OPERATIONS_ENUM.UPDATE_NODE,await Gi.getSystemInfo());Hi.trace("updateNode sending remote payload:",c);let _;try{_=await BE.request(`${r}.${Ep.REQUEST_SUFFIX}`,c)}catch(u){Hi.error(`updateNode received error from request: ${u}`);let l=BE.requestErrorHandler(u,"update_node",r);throw Lc(new Error,l,Uc.INTERNAL_SERVER_ERROR,"error",l)}if(_.status===Ep.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${_.message}`;throw Lc(new Error,u,Uc.INTERNAL_SERVER_ERROR,"error",u)}Hi.trace(_);for(let u=0,l=n.length;u<l;u++){let E=n[u];Hi.trace(`updateNode updating work stream for node: ${r} subscription:`,E),await BE.updateWorkStream(E,r),n[u].start_time===void 0&&delete n[u].start_time}return await bx(s[0],n,_.system_info),i.length>0?o.message=Nx:o.message=`Successfully updated '${r}'`,o}a(Ix,"updateNode");async function bx(e,t,r){let s=e;for(let n=0,i=t.length;n<i;n++){let o=t[n],c=!1;for(let _=0,u=e.subscriptions.length;_<u;_++){let l=s.subscriptions[_];if(l.schema===o.schema&&l.table===o.table){l.publish=o.publish,l.subscribe=o.subscribe,c=!0;break}}c||s.subscriptions.push(new Ox(o.schema,o.table,o.publish,o.subscribe))}s.system_info=r,await Gi.upsertNodeRecord(s)}a(bx,"updateNodeTable")});var Rp=S((l3,mp)=>{"use strict";var Tp=require("joi"),{string:Sp}=Tp.types(),Cx=de(),fp=T(),wx=Y(),Lx=_e();mp.exports=Ux;function Ux(e){let t=Sp.invalid(wx.get(fp.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Lx.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=Tp.object({operation:Sp.valid(fp.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return Cx.validateBySchema(e,r)}a(Ux,"removeNodeValidator")});var Dc=S((E3,Ip)=>{"use strict";var{handleHDBError:Ap,hdb_errors:yx}=D(),{HTTP_STATUS_CODES:Op}=yx,Dx=Rp(),qi=I(),pp=Ls(),Mx=b(),yc=T(),Np=_e(),gp=ot(),Px=Y(),{RemotePayloadObject:Bx}=Pi(),{NodeSubscription:vx}=Cn(),Hx=li(),Gx=Rs(),qx=Px.get(yc.CONFIG_PARAMS.CLUSTERING_NODENAME);Ip.exports=Fx;async function Fx(e){qi.trace("removeNode called with:",e),pp.checkClusteringEnabled();let t=Dx(e);if(t)throw Ap(t,t.message,Op.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,s=await pp.getNodeRecord(r);if(Mx.isEmptyOrZeroLength(s))throw Ap(new Error,`Node '${r}' was not found.`,Op.BAD_REQUEST,void 0,void 0,!0);s=s[0];let n=new Bx(yc.OPERATIONS_ENUM.REMOVE_NODE,qx,[]),i,o=!1;try{i=await gp.request(`${r}.${Np.REQUEST_SUFFIX}`,n),qi.trace("Remove node reply from remote node:",r,i)}catch(_){qi.error("removeNode received error from request:",_),o=!0}for(let _=0,u=s.subscriptions.length;_<u;_++){let l=s.subscriptions[_];qi.trace(`Remove node removing subscription: ${l.schema}.${l.table} for node: ${r}`);let E=new vx(l.schema,l.table,!1,!1);await gp.updateWorkStream(E,r)}let c=new Hx(yc.SYSTEM_SCHEMA_NAME,yc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Gx.deleteRecord(c),i?.status===Np.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(qi.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(Fx,"removeNode")});var wp=S((d3,Cp)=>{"use strict";var bp=require("joi"),{string:Vx,array:kx}=bp.types(),xx=de(),$x=oc();Cp.exports=Yx;function Yx(e){let t=bp.object({operation:Vx.valid("configure_cluster").required(),connections:kx.items($x.validation_schema).required()});return xx.validateBySchema(e,t)}a(Yx,"configureClusterValidator")});var HE=S((h3,Mp)=>{"use strict";var Kx=T(),Mc=I(),Qx=b(),Wx=Dc(),Jx=wc(),Lp=Ls(),Zx=wp(),{handleHDBError:Up,hdb_errors:Xx}=D(),{HTTP_STATUS_CODES:yp}=Xx,zx="Configure cluster complete.",jx="Failed to configure the cluster. Check the logs for more details.",e$="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";Mp.exports=t$;async function t$(e){Mc.trace("configure cluster called with:",e),Lp.checkClusteringEnabled();let t=Zx(e);if(t)throw Up(t,t.message,yp.BAD_REQUEST,void 0,void 0,!0);let r=await Lp.getAllNodeRecords(),s=[];for(let d=0,h=r.length;d<h;d++)s.push(Dp(Wx,{operation:Kx.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[d].name},r[d].name));let n=await Promise.allSettled(s);Mc.trace("All results from configure_cluster remove node:",n);let i=[],o=e.connections.length;for(let d=0;d<o;d++){let h=e.connections[d];i.push(Dp(Jx,h,h.node_name))}let c=await Promise.allSettled(i);Mc.trace("All results from configure_cluster add node:",c);let _=[],u=[],l=!1,E=n.concat(c);for(let d=0,h=E.length;d<h;d++){let m=E[d];m.status==="rejected"&&(Mc.error(m.reason),_.includes(m.reason.node_name)||_.push(m.reason.node_name)),m.status==="fulfilled"&&(l=!0);let R=m?.value?.result;typeof R=="string"&&R.includes("Successfully removed")||m.status==="rejected"||u.push({node_name:m?.value?.node_name,subscriptions:m?.value?.result})}if(Qx.isEmptyOrZeroLength(_))return{message:zx,connections:u};if(l)return{message:e$,failed_nodes:_,connections:u};throw Up(new Error,jx,yp.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(t$,"configureCluster");async function Dp(e,t,r){try{return{node_name:r,result:await e(t)}}catch(s){throw{node_name:r,error:s}}}a(Dp,"functionWrapper")});var FE=S((S3,qp)=>{"use strict";var qE=Ls(),r$=ot(),vp=Y(),Pc=T(),Us=_e(),s$=b(),GE=I(),{RemotePayloadObject:n$}=Pi(),{ErrorCode:Pp}=require("nats"),Bp=vp.get(Pc.CONFIG_PARAMS.CLUSTERING_ENABLED),Hp=vp.get(Pc.CONFIG_PARAMS.CLUSTERING_NODENAME);qp.exports={clusterStatus:i$,buildNodeStatus:Gp};async function i$(){let e={node_name:Hp,is_enabled:Bp,connections:[]};if(!Bp)return e;let t=await qE.getAllNodeRecords();if(s$.isEmptyOrZeroLength(t))return e;let r=[];for(let s=0,n=t.length;s<n;s++)r.push(Gp(t[s],e.connections));return await Promise.allSettled(r),e}a(i$,"clusterStatus");async function Gp(e,t){let r=e.name,s=new n$(Pc.OPERATIONS_ENUM.CLUSTER_STATUS,Hp,void 0,await qE.getSystemInfo()),n,i,o=Us.CLUSTER_STATUS_STATUSES.OPEN;try{let _=Date.now();n=await r$.request(Us.REQUEST_SUBJECT(r),s),i=Date.now()-_,n.status===Us.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Us.CLUSTER_STATUS_STATUSES.CLOSED,GE.error(`Error getting node status from ${r} `,n))}catch(_){GE.warn(`Error getting node status from ${r}`,_),_.code===Pp.NoResponders?o=Us.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:_.code===Pp.Timeout?o=Us.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Us.CLUSTER_STATUS_STATUSES.CLOSED}let c=new a$(r,o,n?.message?.ports?.clustering,n?.message?.ports?.operations_api,i,n?.message?.uptime,e.subscriptions,n?.message?.system_info);try{let _={name:r,system_info:n?.message?.system_info};e.system_info?.hdb_version!==Pc.PRE_4_0_0_VERSION&&await qE.upsertNodeRecord(_)}catch(_){GE.error("Cluster status encountered an error updating system info for node:",r,_)}t.push(c)}a(Gp,"buildNodeStatus");function a$(e,t,r,s,n,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:s},this.latency_ms=n,this.uptime=i,this.subscriptions=o,this.system_info=c}a(a$,"NodeStatusObject")});var xp=S((f3,kp)=>{"use strict";var VE=require("joi"),Fp=de(),{route_constraints:Vp}=hu();kp.exports={setRoutesValidator:o$,deleteRoutesValidator:c$};function o$(e){let t=VE.object({server:VE.valid("hub","leaf").required(),routes:Vp.required()});return Fp.validateBySchema(e,t)}a(o$,"setRoutesValidator");function c$(e){let t=VE.object({routes:Vp.required()});return Fp.validateBySchema(e,t)}a(c$,"deleteRoutesValidator")});var xE=S((T3,Qp)=>{"use strict";var ys=Sr(),kE=b(),Bc=T(),$p=xp(),{handleHDBError:Yp,hdb_errors:_$}=D(),{HTTP_STATUS_CODES:Kp}=_$,u$="cluster routes successfully set",l$="cluster routes successfully deleted";Qp.exports={setRoutes:E$,getRoutes:d$,deleteRoutes:h$};function E$(e){let t=$p.setRoutesValidator(e);if(t)throw Yp(t,t.message,Kp.BAD_REQUEST,void 0,void 0,!0);let r=ys.getClusteringRoutes(),s=e.server==="hub"?r.hub_routes:r.leaf_routes,n=e.server==="hub"?r.leaf_routes:r.hub_routes,i=[],o=[];for(let c=0,_=e.routes.length;c<_;c++){let u=e.routes[c];u.port=kE.autoCast(u.port);let l=s.some(d=>d.host===u.host&&d.port===u.port),E=n.some(d=>d.host===u.host&&d.port===u.port);l||E?i.push(u):(s.push(u),o.push(u))}return e.server==="hub"?ys.updateConfigValue(Bc.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,s):ys.updateConfigValue(Bc.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s),{message:u$,set:o,skipped:i}}a(E$,"setRoutes");function d$(){let e=ys.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(d$,"getRoutes");function h$(e){let t=$p.deleteRoutesValidator(e);if(t)throw Yp(t,t.message,Kp.BAD_REQUEST,void 0,void 0,!0);let r=ys.getClusteringRoutes(),s=r.hub_routes,n=r.leaf_routes,i=[],o=[],c=!1,_=!1;for(let u=0,l=e.routes.length;u<l;u++){let E=e.routes[u],d=!1;for(let h=0,m=s.length;h<m;h++){let R=s[h];if(E.host===R.host&&E.port===R.port){s.splice(h,1),d=!0,c=!0,i.push(E);break}}if(!d){let h=!0;for(let m=0,R=n.length;m<R;m++){let w=n[m];if(E.host===w.host&&E.port===w.port){n.splice(m,1),_=!0,h=!1,i.push(E);break}}h&&o.push(E)}}return c&&(s=kE.isEmptyOrZeroLength(s)?null:s,ys.updateConfigValue(Bc.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,s)),_&&(n=kE.isEmptyOrZeroLength(n)?null:n,ys.updateConfigValue(Bc.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:l$,deleted:i,skipped:o}}a(h$,"deleteRoutes")});var Jp=S((m3,Wp)=>{"use strict";var Fi=require("alasql"),Ds=require("recursive-iterator"),Wt=I(),S$=b(),Vi=T(),vc=class{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,T$(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(n=>Vi.SEARCH_WILDCARDS.includes(n.columnid));if(r.length===0)return this.ast;let s=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(n=>!Vi.SEARCH_WILDCARDS.includes(n.columnid)),r.forEach(n=>{let i=this.table_to_schema_lookup.has(n.tableid)?this.table_to_schema_lookup.get(n.tableid):s,o=this.table_lookup.has(n.tableid)?this.table_lookup.get(n.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][Vi.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=f$(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let _=this.affected_attributes.get(i).get(o).filter(u=>!Vi.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let l=new Fi.yy.Column({columnid:u});n.tableid&&(l.tableid=n.tableid),this.ast.columns.push(l),_.includes(u)||_.push(u)}),this.affected_attributes.get(i).set(o,_)}}),this.ast}};a(vc,"sql_statement_bucket");function f$(e){return e.filter(t=>t[Vi.PERMS_CRUD_ENUM.READ])}a(f$,"filterReadRestrictedAttrs");function T$(e,t,r,s,n){m$(e,t,r,s,n)}a(T$,"interpretAST");function ki(e,t,r,s,n){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),s&&!s.has(e.as)&&s.set(e.as,e.databaseid)),n)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),n.set(o,i)}}a(ki,"addSchemaTableToMap");function m$(e,t,r,s,n){if(!e){Wt.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Fi.yy.Insert?p$(e,t,r):e instanceof Fi.yy.Select?R$(e,t,r,s,n):e instanceof Fi.yy.Update?A$(e,t,r):e instanceof Fi.yy.Delete?O$(e,t,r):Wt.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(m$,"getRecordAttributesAST");function R$(e,t,r,s,n){if(!e){Wt.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(S$.isEmptyOrZeroLength(i)){Wt.error("No schema specified");return}e.from.forEach(c=>{ki(c,t,r,s,n)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),ki(c.table,t,r,s,n)});let o=new Ds(e.columns);for(let{node:c}of o)if(c&&c.columnid){let _=c.tableid,u=s.has(_)?s.get(_):i;if(_||(_=e.from[0].tableid),!t.get(u).has(_))if(r.has(_))_=r.get(_);else{Wt.info(`table specified as ${_} not found.`);return}t.get(u).get(_).indexOf(c.columnid)<0&&t.get(u).get(_).push(c.columnid)}if(e.where){let c=new Ds(e.where),_=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let l=u.tableid?u.tableid:_;if(!t.get(i).has(l))if(r.has(l))l=r.get(l);else{Wt.info(`table specified as ${l} not found.`);continue}t.get(i).get(l).indexOf(u.columnid)<0&&t.get(i).get(l).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let _=new Ds(c.on);for(let{node:u}of _)if(u&&u.columnid){let l=u.tableid,E=n.get(l);if(!t.get(E).has(l))if(r.has(l))l=r.get(l);else{Wt.info(`table specified as ${l} not found.`);continue}t.get(E).get(l).indexOf(u.columnid)<0&&t.get(E).get(l).push(u.columnid)}}),e.order){let c=new Ds(e.order);for(let{node:_}of c)if(_&&_.columnid){let u=_.tableid,l=s.has(u)?s.get(u):i;if(u||(u=e.from[0].tableid),!t.get(l).has(u))if(r.has(u))u=r.get(u);else{Wt.info(`table specified as ${u} not found.`);return}t.get(l).get(u).indexOf(_.columnid)<0&&t.get(l).get(u).push(_.columnid)}}}a(R$,"getSelectAttributes");function A$(e,t,r){if(!e){Wt.info("getUpdateAttributes: invalid SQL syntax tree");return}let s=new Ds(e.columns),n=e.table.databaseid;ki(e.table,t,r);for(let{node:i}of s)i&&i.columnid&&$E(e.table.tableid,n,i.columnid,t,r)}a(A$,"getUpdateAttributes");function O$(e,t,r){if(!e){Wt.info("getDeleteAttributes: invalid SQL syntax tree");return}let s=new Ds(e.where),n=e.table.databaseid;ki(e.table,t,r);for(let{node:i}of s)i&&i.columnid&&$E(e.table.tableid,n,i.columnid,t,r)}a(O$,"getDeleteAttributes");function p$(e,t,r){if(!e){Wt.info("getInsertAttributes: invalid SQL syntax tree");return}let s=new Ds(e.columns),n=e.into.databaseid;ki(e.into,t,r);for(let{node:i}of s)i&&i.columnid&&$E(e.into.tableid,n,i.columnid,t,r)}a(p$,"getInsertAttributes");function $E(e,t,r,s,n){if(!s.get(t))return;let i=e;s.get(t).has(i)||(i=n.get(i)),s.get(t).get(i).push(r)}a($E,"pushAttribute");Wp.exports=vc});var zp=S((R3,Xp)=>{var N$=require("os"),Zp=Y();Xp.exports={checkPermission:g$};function g$(){if(N$.userInfo().username!==Zp.get("install_user"))throw new Error(`Error: Must execute as ${Zp.get("install_user")}`)}a(g$,"checkPermission")});var KE=S((A3,sN)=>{var Gc=Ai(),jp=require("chalk"),ir=I(),eN=zp(),tN=require("prompt"),{promisify:I$}=require("util"),Hc=T(),b$=require("fs-extra"),C$=require("path"),w$=b(),L$=LE(),rN=Y();rN.initSync();var U$=require("moment"),y$=I$(tN.get),D$=C$.join(rN.getHdbBasePath(),Hc.LICENSE_KEY_DIR_NAME,Hc.LICENSE_FILE_NAME,Hc.LICENSE_FILE_NAME);sN.exports={getFingerprint:P$,setLicense:M$,parseLicense:YE,register:B$,getRegistrationInfo:H$};async function M$(e){if(e&&e.key&&e.company){try{ir.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await YE(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ir.error(r),ir.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(M$,"setLicense");async function P$(){try{eN.checkPermission()}catch(t){throw ir.error(t),new Error("You do not have permission to generate a fingerprint.")}let e={};try{e=await Gc.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ir.error(r),ir.error(t),new Error(r)}return e}a(P$,"getFingerprint");async function YE(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");console.log("Validating license input...");let r=Gc.validateLicense(e,t);if(console.log("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(console.log("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(console.log(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ir.info("writing license to disk"),await b$.writeFile(D$,JSON.stringify({license_key:e,company:t}))}catch(s){throw ir.error("Failed to write License"),s}return"Registration successful."}a(YE,"parseLicense");async function B$(){let e=await v$();return YE(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(B$,"register");async function v$(){try{eN.checkPermission()}catch(s){return console.error(s.message)}let e=await Gc.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:jp.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:jp.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{tN.start()}catch(s){ir.error(s)}let r;try{r=await y$(t)}catch(s){throw console.error("There was a problem prompting for registration input. Exiting."),s}return r}a(v$,"promptForRegistration");async function H$(){let e={registered:!1,version:null,storage_type:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Gc.getLicense()}catch(r){throw ir.error(`There was an error when searching licenses due to: ${r.message}`),r}if(w$.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=L$.version(),e.storage_type=Hc.STORAGE_TYPES_ENUM.LMDB,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=U$.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(H$,"getRegistrationInfo")});var iN=S((O3,nN)=>{"use strict";var G$=_e(),qc=class{constructor(t,r,s,n,i,o,c,_,u,l,E,d,h){this.port=t,this.server_name=r+G$.SERVER_SUFFIX.HUB,this.pid_file=s,this.max_payload=1e7,this.jetstream={enabled:!1},this.tls={cert_file:n,key_file:i,ca_file:o,insecure:c},this.leafnodes={port:_,tls:{cert_file:n,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:l,routes:E,tls:{cert_file:n,key_file:i,ca_file:o,insecure:c}},this.accounts={SYS:{users:d},HDB:{users:h}},this.system_account="SYS"}};a(qc,"HubConfigObject");nN.exports=qc});var cN=S((p3,oN)=>{"use strict";var aN=_e(),Fc=class{constructor(t,r,s,n,i,o,c,_,u,l,E,d){this.port=t,this.server_name=r+aN.SERVER_SUFFIX.LEAF,this.pid_file=s,this.max_payload=1e7,this.jetstream={enabled:!0,store_dir:n,domain:r+aN.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:l,ca_file:E,insecure:d},this.leafnodes={remotes:[{tls:{ca_file:E,insecure:d},urls:i,account:"SYS"},{tls:{ca_file:E,insecure:d},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:_,jetstream:"enabled"}},this.system_account="SYS"}};a(Fc,"LeafConfigObject");oN.exports=Fc});var uN=S((N3,_N)=>{"use strict";var Vc=class{constructor(t,r){this.user=t,this.password=r}};a(Vc,"HdbUserObject");_N.exports=Vc});var EN=S((g3,lN)=>{"use strict";var q$=_e(),kc=class{constructor(t,r){this.user=t+q$.SERVER_SUFFIX.ADMIN,this.password=r}};a(kc,"SysUserObject");lN.exports=kc});var JE=S((I3,SN)=>{"use strict";var Un=require("path"),Kc=require("fs-extra"),F$=iN(),V$=cN(),k$=uN(),x$=EN(),QE=Wr(),Dn=b(),Mt=Sr(),Yc=T(),xc=_e(),{CONFIG_PARAMS:Ce}=Yc,Qc=I(),Wc=Y(),dN=Vr(),WE=ot(),yn="clustering",$$=1e4,hN=5;SN.exports={generateNatsConfig:Y$,removeNatsConfig:K$};async function Y$(e=!1,t=void 0){Wc.initSync();let r=Wc.get(Ce.ROOTPATH),s=Un.join(r,yn,xc.PID_FILES.HUB),n=Un.join(r,yn,xc.PID_FILES.LEAF),i=Un.join(r,yn,"leaf"),o=Un.join(r,yn,xc.NATS_CONFIG_FILES.HUB_SERVER),c=Un.join(r,yn,xc.NATS_CONFIG_FILES.LEAF_SERVER),_=Mt.getConfigFromFile(Ce.CLUSTERING_TLS_CERTIFICATE),u=Mt.getConfigFromFile(Ce.CLUSTERING_TLS_PRIVATEKEY),l=Mt.getConfigFromFile(Ce.CLUSTERING_TLS_CERT_AUTH),E=Mt.getConfigFromFile(Ce.CLUSTERING_TLS_INSECURE),d=Mt.getConfigFromFile(Ce.CLUSTERING_NODENAME),h=Mt.getConfigFromFile(Ce.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await WE.checkNATSServerInstalled()||Jc("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let m=await QE.listUsers(),R=Mt.getConfigFromFile(Ce.CLUSTERING_USER),w=await QE.getClusterUser();(Dn.isEmpty(w)||w.active!==!0)&&Jc(`invalid cluster user '${R}'`),e||(await $c(Ce.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await $c(Ce.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await $c(Ce.CLUSTERING_HUBSERVER_NETWORK_PORT),await $c(Ce.CLUSTERING_LEAFSERVER_NETWORK_PORT));let L=[],B=[];for(let[la,yr]of m.entries())yr.role.role===Yc.ROLE_TYPES_ENUM.CLUSTER_USER&&yr.active&&(L.push(new x$(yr.username,dN.decrypt(yr.hash))),B.push(new k$(yr.username,dN.decrypt(yr.hash))));let z=[],{hub_routes:V}=Mt.getClusteringRoutes();if(!Dn.isEmptyOrZeroLength(V))for(let la of V)z.push(`tls://${w.sys_name_encoded}:${w.uri_encoded_d_hash}@${la.host}:${la.port}`);let W=new F$(Mt.getConfigFromFile(Ce.CLUSTERING_HUBSERVER_NETWORK_PORT),d,s,_,u,l,E,h,Mt.getConfigFromFile(Ce.CLUSTERING_HUBSERVER_CLUSTER_NAME),Mt.getConfigFromFile(Ce.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),z,L,B);t=Dn.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Yc.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Kc.writeJson(o,W),Qc.trace(`Hub server config written to ${o}`));let ke=`tls://${w.sys_name_encoded}:${w.uri_encoded_d_hash}@0.0.0.0:${h}`,xe=`tls://${w.uri_encoded_name}:${w.uri_encoded_d_hash}@0.0.0.0:${h}`,ua=new V$(Mt.getConfigFromFile(Ce.CLUSTERING_LEAFSERVER_NETWORK_PORT),d,n,i,[ke],[xe],L,B,_,u,l,E);(t===void 0||t===Yc.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Kc.writeJson(c,ua),Qc.trace(`Leaf server config written to ${c}`))}a(Y$,"generateNatsConfig");async function $c(e){let t=Wc.get(e);Dn.isEmpty(t)&&Jc(`port undefined for '${e}'`),await Dn.isPortTaken(t)&&Jc(`'${e}' port '${t}' is unavailable`)}a($c,"isPortAvailable");function Jc(e){let t=`Error generating clustering config: ${e}`;Qc.error(t),console.error(t),process.exit(1)}a(Jc,"generateNatsConfigError");async function K$(e){let{port:t,config_file:r}=WE.getServerConfig(e),{username:s,decrypt_hash:n}=await QE.getClusterUser(),i=0,o=500;for(;i<hN;){try{let u=await WE.createConnection(t,s,n,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){Qc.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=hN)throw new Error(`removeNatsConfig timed out waiting to connect to ${e}`);await Dn.async_set_timeout(o*i)}let c="0".repeat($$),_=Un.join(Wc.get(Ce.ROOTPATH),yn,r);await Kc.writeFile(_,c),await Kc.remove(_)}a(K$,"removeNatsConfig")});var Xc=S((b3,pN)=>{"use strict";var ne=Y(),fN=Ai(),C=T(),ZE=_e(),Ae=require("path"),{PACKAGE_ROOT:Zc}=T(),Ee="/dev/null",Mn=Ae.join(Zc,"launchServiceScripts"),TN=Ae.join(Zc,"utility/scripts"),Q$=Ae.join(TN,C.HDB_RESTART_SCRIPT),mN=Ae.resolve(Zc,"dependencies",`${process.platform}-${process.arch}`,ZE.NATS_BINARY_NAME),He,Ge;function ar(){(He===void 0||Ge===void 0)&&(ne.initSync(),He=ne.get(C.HDB_SETTINGS_NAMES.LOG_TO_FILE),Ge=ne.get(C.HDB_SETTINGS_NAMES.LOG_PATH_KEY))}a(ar,"initLogConfig");function RN(){ar();let e=Ae.join(Ge,C.PROCESS_LOG_NAMES.IPC),t={name:C.PROCESS_DESCRIPTORS.IPC,exec_mode:"fork",env:{[C.PROCESS_NAME_ENV_PROP]:C.PROCESS_DESCRIPTORS.IPC},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:C.SERVICE_SERVERS_CWD.IPC};return He||(t.out_file=Ee,t.error_file=Ee),{...t,script:C.SERVICE_SERVERS.IPC}}a(RN,"generateIPCServerConfig");function AN(){ar(),ne.initSync(),He=ne.get(C.HDB_SETTINGS_NAMES.LOG_TO_FILE),Ge=ne.get(C.HDB_SETTINGS_NAMES.LOG_PATH_KEY);let e=Ae.join(Ge,C.PROCESS_LOG_NAMES.HDB),t=fN.licenseSearch(),r=t.ram_allocation?C.MEM_SETTING_KEY+t.ram_allocation:C.MEM_SETTING_KEY+C.RAM_ALLOCATION_ENUM.DEFAULT,s={name:C.PROCESS_DESCRIPTORS.HDB,script:C.LAUNCH_SERVICE_SCRIPTS.HDB,exec_mode:"cluster",env:{[C.PROCESS_NAME_ENV_PROP]:C.PROCESS_DESCRIPTORS.HDB},merge_logs:!0,out_file:e,error_file:e,instances:ne.get(C.CONFIG_PARAMS.HTTP_THREADS),node_args:r,cwd:Mn};return He||(s.out_file=Ee,s.error_file=Ee),s}a(AN,"generateHDBServerConfig");function ON(){ar(),ne.initSync(),He=ne.get(C.HDB_SETTINGS_NAMES.LOG_TO_FILE),Ge=ne.get(C.HDB_SETTINGS_NAMES.LOG_PATH_KEY);let e=Ae.join(Ge,C.PROCESS_LOG_NAMES.CUSTOM_FUNCTIONS),t=fN.licenseSearch(),r=t.ram_allocation?C.MEM_SETTING_KEY+t.ram_allocation:C.MEM_SETTING_KEY+C.RAM_ALLOCATION_ENUM.DEFAULT,s={name:C.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS,script:C.LAUNCH_SERVICE_SCRIPTS.CUSTOM_FUNCTIONS,exec_mode:"cluster",env:{[C.PROCESS_NAME_ENV_PROP]:C.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS},merge_logs:!0,out_file:e,error_file:e,instances:ne.get(C.CONFIG_PARAMS.HTTP_THREADS),node_args:r,cwd:Mn};return He||(s.out_file=Ee,s.error_file=Ee),s}a(ON,"generateCFServerConfig");function W$(){ar(),ne.initSync(),He=ne.get(C.HDB_SETTINGS_NAMES.LOG_TO_FILE),Ge=ne.get(C.HDB_SETTINGS_NAMES.LOG_PATH_KEY);let e=ne.get(C.CONFIG_PARAMS.ROOTPATH),t=Ae.join(e,"clustering",ZE.NATS_CONFIG_FILES.HUB_SERVER),r=Ae.join(Ge,C.PROCESS_LOG_NAMES.CLUSTERING_HUB),s={name:C.PROCESS_DESCRIPTORS.CLUSTERING_HUB,script:mN,args:`-c ${t}`,exec_mode:"fork",env:{[C.PROCESS_NAME_ENV_PROP]:C.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return He||(s.out_file=Ee,s.error_file=Ee),s}a(W$,"generateNatsHubServerConfig");function J$(){ar(),ne.initSync(),He=ne.get(C.HDB_SETTINGS_NAMES.LOG_TO_FILE),Ge=ne.get(C.HDB_SETTINGS_NAMES.LOG_PATH_KEY);let e=ne.get(C.CONFIG_PARAMS.ROOTPATH),t=Ae.join(e,"clustering",ZE.NATS_CONFIG_FILES.LEAF_SERVER),r=Ae.join(Ge,C.PROCESS_LOG_NAMES.CLUSTERING_LEAF),s={name:C.PROCESS_DESCRIPTORS.CLUSTERING_LEAF,script:mN,args:`-c ${t}`,exec_mode:"fork",env:{[C.PROCESS_NAME_ENV_PROP]:C.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return He||(s.out_file=Ee,s.error_file=Ee),s}a(J$,"generateNatsLeafServerConfig");function Z$(){ar(),ne.initSync();let e=Ae.join(Ge,C.PROCESS_LOG_NAMES.CLUSTERING_INGEST_SERVICE),t={name:C.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE,script:C.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE,exec_mode:"cluster",env:{[C.PROCESS_NAME_ENV_PROP]:C.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Mn};return He||(t.out_file=Ee,t.error_file=Ee),t}a(Z$,"generateNatsIngestServiceConfig");function X$(){ar(),ne.initSync();let e=Ae.join(Ge,C.PROCESS_LOG_NAMES.CLUSTERING_REPLY_SERVICE),t={name:C.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE,script:C.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,exec_mode:"cluster",env:{[C.PROCESS_NAME_ENV_PROP]:C.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Mn};return He||(t.out_file=Ee,t.error_file=Ee),t}a(X$,"generateNatsReplyServiceConfig");function z$(){ar(),ne.initSync();let e=Ae.join(Ge,C.PROCESS_LOG_NAMES.CLUSTERING_UPGRADE),t={name:C.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:C.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[C.PROCESS_NAME_ENV_PROP]:C.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Mn,autorestart:!1};return He||(t.out_file=Ee,t.error_file=Ee),t}a(z$,"generateClusteringUpgradeV4ServiceConfig");function j$(){ar();let e=Ae.join(Ge,C.PROCESS_LOG_NAMES.PM2),t={name:C.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:{[C.PROCESS_NAME_ENV_PROP]:C.PROCESS_DESCRIPTORS.RESTART_HDB},merge_logs:!0,out_file:e,error_file:e,instances:1,autorestart:!1,cwd:TN};return He||(t.out_file=Ee,t.error_file=Ee),{...t,script:Q$}}a(j$,"generateRestart");function eY(e){ar();let t=Ae.join(Ge,C.PROCESS_LOG_NAMES.JOBS),r=Ae.join(Zc,"server/jobs"),s={name:`JOB-${e}`,exec_mode:"fork",env:{[C.PROCESS_NAME_ENV_PROP]:`JOB-${e}`},merge_logs:!0,out_file:t,error_file:t,instances:1,cwd:Mn,autorestart:!1};return He||(s.out_file=Ee,s.error_file=Ee),{...s,script:Ae.join(r,"jobProcess.js")}}a(eY,"generateJobConfig");function tY(){return{apps:[RN(),AN(),ON()]}}a(tY,"generateAllServiceConfigs");pN.exports={generateAllServiceConfigs:tY,generateIPCServerConfig:RN,generateHDBServerConfig:AN,generateCFServerConfig:ON,generateRestart:j$,generateNatsHubServerConfig:W$,generateNatsLeafServerConfig:J$,generateNatsIngestServiceConfig:Z$,generateNatsReplyServiceConfig:X$,generateClusteringUpgradeV4ServiceConfig:z$,generateJobConfig:eY}});var $i=S((C3,MN)=>{"use strict";var P=T(),zc=b(),xi=JE(),jc=ot(),rY=_e(),x=require("pm2"),sY=require("fs-extra"),gr=Xc(),lt=Y(),Ir=I(),nY=Xc(),iY=Ls(),aY=require("util"),gN=aY.promisify(require("child_process").exec),IN=require("path");MN.exports={start:Ms,stop:t_,reload:CN,restart:wN,list:zE,describe:r_,connect:or,kill:UN,startAllServices:fY,startService:e_,getUniqueServicesList:jE,restartAllServices:TY,stopAllServices:mY,isServiceRegistered:yN,reloadStopStart:XE,restartHdb:LN,deleteProcess:hY,configureLogRotate:OY,startClustering:DN,isHdbRestartRunning:SY,isClusteringRunning:NY,stopClustering:pY,reloadClustering:gY};var{PACKAGE_ROOT:oY}=T(),cY="2.7.0",bN=IN.join(oY,"node_modules/pm2/bin/pm2"),_Y="Log rotate installed.",uY="Error installing log rotate.",lY="Log rotate updated.",EY="Error updating log rotate.",dY="The number of HarperDB processes running is different from the settings value. To restart and update the number HarperDB processes running you must stop and then start HarperDB";function or(){return new Promise((e,t)=>{x.connect((r,s)=>{r&&t(r),e(s)})})}a(or,"connect");function Ms(e){return new Promise(async(t,r)=>{try{await or()}catch(s){r(s)}x.start(e,(s,n)=>{s&&(x.disconnect(),r(s)),x.disconnect(),t(n)})})}a(Ms,"start");function t_(e){return new Promise(async(t,r)=>{try{await or()}catch(s){r(s)}x.stop(e,(s,n)=>{s&&(x.disconnect(),r(s)),x.delete(e,(i,o)=>{i&&(x.disconnect(),r(s)),x.disconnect(),t(o)})})})}a(t_,"stop");function CN(e){return new Promise(async(t,r)=>{try{await or()}catch(s){r(s)}x.reload(e,(s,n)=>{s&&(x.disconnect(),r(s)),x.disconnect(),t(n)})})}a(CN,"reload");function wN(e){return new Promise(async(t,r)=>{try{await or()}catch(s){r(s)}x.restart(e,(s,n)=>{s&&(x.disconnect(),r(s)),x.disconnect(),t(n)})})}a(wN,"restart");function hY(e){return new Promise(async(t,r)=>{try{await or()}catch(s){r(s)}x.delete(e,(s,n)=>{s&&(x.disconnect(),r(s)),x.disconnect(),t(n)})})}a(hY,"deleteProcess");async function LN(){await Ms(nY.generateRestart())}a(LN,"restartHdb");async function SY(){let e=await zE();for(let t in e)if(e[t].name===P.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(SY,"isHdbRestartRunning");function zE(){return new Promise(async(e,t)=>{try{await or()}catch(r){t(r)}x.list((r,s)=>{r&&(x.disconnect(),t(r)),x.disconnect(),e(s)})})}a(zE,"list");function r_(e){return new Promise(async(t,r)=>{try{await or()}catch(s){r(s)}x.describe(e,(s,n)=>{s&&(x.disconnect(),r(s)),x.disconnect(),t(n)})})}a(r_,"describe");function UN(){return new Promise(async(e,t)=>{try{await or()}catch(r){t(r)}x.killDaemon((r,s)=>{r&&(x.disconnect(),t(r)),x.disconnect(),e(s)})})}a(UN,"kill");async function fY(){try{await DN(),await Ms(gr.generateAllServiceConfigs())}catch(e){throw x.disconnect(),e}}a(fY,"startAllServices");async function e_(e){try{let t;switch(e=e.toLowerCase(),e){case P.PROCESS_DESCRIPTORS.IPC.toLowerCase():t=gr.generateIPCServerConfig();break;case P.PROCESS_DESCRIPTORS.HDB.toLowerCase():t=gr.generateHDBServerConfig();break;case P.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS.toLowerCase():t=gr.generateCFServerConfig();break;case P.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():t=gr.generateNatsIngestServiceConfig();break;case P.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():t=gr.generateNatsReplyServiceConfig();break;case P.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():t=gr.generateNatsHubServerConfig(),await Ms(t),await xi.removeNatsConfig(e);return;case P.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():t=gr.generateNatsLeafServerConfig(),await Ms(t),await xi.removeNatsConfig(e);return;case P.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():t=gr.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Ms(t)}catch(t){throw x.disconnect(),t}}a(e_,"startService");async function jE(){try{let e=await zE(),t={};for(let r=0,s=e.length;r<s;r++){let n=e[r];t[n.name]===void 0&&(t[n.name]={name:n.name,exec_mode:n.pm2_env.exec_mode})}return t}catch(e){throw x.disconnect(),e}}a(jE,"getUniqueServicesList");async function TY(e=[]){try{let t=!1,r=await jE();for(let s=0,n=Object.values(r).length;s<n;s++){let i=Object.values(r)[s],o=i.name;e.includes(o)||(i.exec_mode==="cluster_mode"?o===P.PROCESS_DESCRIPTORS.HDB?t=!0:await XE(o):await wN(o))}t&&await XE(P.PROCESS_DESCRIPTORS.HDB)}catch(t){throw x.disconnect(),t}}a(TY,"restartAllServices");async function mY(){try{let e=await jE();for(let t=0,r=Object.values(e).length;t<r;t++){let s=Object.values(e)[t];await t_(s.name)}if(await UN(),lt.get(P.CONFIG_PARAMS.OPERATIONSAPI_FOREGROUND)===!0){let t=(await sY.readFile(IN.join(lt.get(P.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),P.FOREGROUND_PID_FILE))).toString();try{process.kill(t,"SIGTERM")}catch(r){Ir.warn(`Error terminating foreground process: ${r}`)}}}catch(e){throw x.disconnect(),e}}a(mY,"stopAllServices");async function yN(e){return!zc.isEmptyOrZeroLength(await r_(e))}a(yN,"isServiceRegistered");async function XE(e){let t=e===P.PROCESS_DESCRIPTORS.HDB?lt.get(P.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES):lt.get(P.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES),r=await r_(e),s=zc.isEmptyOrZeroLength(r)?0:r.length;t!==s?e===P.PROCESS_DESCRIPTORS.HDB?Ir.error(dY):(await t_(e),await e_(e)):e===P.PROCESS_DESCRIPTORS.HDB?await LN():await CN(e)}a(XE,"reloadStopStart");function RY(){return new Promise(async(e,t)=>{try{await or()}catch(r){t(r)}x.stop(P.PROCESS_DESCRIPTORS.PM2_LOGROTATE,(r,s)=>{r&&(x.disconnect(),t(r)),x.disconnect(),e(s)})})}a(RY,"stopLogrotate");async function AY(){let{stdout:e,stderr:t}=await gN(`${process.platform==="win32"?"node":""} ${bN} install pm2-logrotate@${cY}`);if(Ir.debug(`loadLogRotate stdout: ${e}`),t)throw Ir.error(uY),t;Ir.info(_Y)}a(AY,"installLogRotate");async function NN(){let e={max_size:lt.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_MAX_SIZE),retain:lt.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_RETAIN),compress:lt.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_COMPRESS),dateFormat:lt.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_DATE_FORMAT),rotateModule:lt.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_ROTATE_MODULE),workerInterval:lt.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_WORKER_INTERVAL),rotateInterval:lt.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_ROTATE_INTERVAL),TZ:lt.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_TIMEZONE)},t="";for(let n in e)t+=`${process.platform==="win32"?"node":""} ${bN} set pm2-logrotate:${n} ${e[n]}`,n!=="TZ"&&(t+=" && ");let{stdout:r,stderr:s}=await gN(t);if(Ir.debug(`updateLogRotateConfig stdout: ${r}`),s)throw Ir.error(EY),s;Ir.info(lY)}a(NN,"updateLogRotateConfig");async function OY(){lt.initSync();let e=zc.autoCastBoolean(lt.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE)),t=await r_(P.PROCESS_DESCRIPTORS.PM2_LOGROTATE),r,s=!1;if(zc.isEmptyOrZeroLength(t)||(s=!0,r=t[0].pm2_env.status),e&&!s){await AY(),await NN();return}if(e&&s){await Ms(P.PROCESS_DESCRIPTORS.PM2_LOGROTATE),await NN();return}!e&&r===P.PM2_PROCESS_STATUSES.ONLINE&&await RY()}a(OY,"configureLogRotate");async function DN(){for(let t in P.CLUSTERING_PROCESSES){let r=P.CLUSTERING_PROCESSES[t];await e_(r)}await jc.createWorkQueueStream(rY.WORK_QUEUE_CONSUMER_NAMES),await jc.updateNodeNameLocalStreams();let e=await iY.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===P.PRE_4_0_0_VERSION){Ir.info("Starting clustering upgrade 4.0.0 process"),await e_(P.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0);break}}a(DN,"startClustering");async function pY(){for(let e in P.CLUSTERING_PROCESSES){let t=P.CLUSTERING_PROCESSES[e];await t_(t)}}a(pY,"stopClustering");async function NY(){for(let e in P.CLUSTERING_PROCESSES){let t=P.CLUSTERING_PROCESSES[e];if(await yN(t)===!1)return!1}return!0}a(NY,"isClusteringRunning");async function gY(){await xi.generateNatsConfig(!0),await jc.reloadNATSHub(),await jc.reloadNATSLeaf(),await xi.removeNatsConfig(P.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await xi.removeNatsConfig(P.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(gY,"reloadClustering")});var nd=S((w3,GN)=>{"use strict";var y=T(),K=I(),s_=b(),IY=eu(),ed=JE(),sd=ot(),bY=_e(),BN=require("minimist"),{handleHDBError:td,hdb_errors:CY}=D(),Yi=Sr(),{HTTP_STATUS_CODES:rd}=CY,q,PN=`Restarting HarperDB. This may take up to ${y.RESTART_TIMEOUT_MS/1e3} seconds.`,Ps="HarperDB is currently restarting and must complete before another HarperDB restart can be initialized.",wY="Invalid service",LY="'service' is required",UY="Restarting all services",yY="Clustering is not enabled so cannot be restarted";GN.exports={stop:MY,restartProcesses:DY,restartService:vN};async function DY(){K.createLogFile(y.PROCESS_LOG_NAMES.CLI,y.PROCESS_DESCRIPTORS.STOP);try{q===void 0&&(q=$i());let e=IY(Object.keys(y.CONFIG_PARAM_MAP),!0);s_.isEmptyOrZeroLength(Object.keys(e))||Yi.updateConfigValue(void 0,void 0,e,!0,!0);let t=Yi.getConfigFromFile(y.CONFIG_PARAMS.CLUSTERING_ENABLED),r=Yi.getConfigFromFile(y.CONFIG_PARAMS.CUSTOMFUNCTIONS_ENABLED),s=BN(process.argv);if(!s_.isEmpty(s.service)){if(typeof s.service!="string"){let c=`Restart service argument expected a string but received: ${s.service}`;return K.error(c),c}let o=s.service.split(",");for(let c of o){let _=c.toLowerCase();if(_===y.HDB_PROC_DESCRIPTOR.toLowerCase()&&await q.isHdbRestartRunning()===!0){K.notify(Ps),console.error(Ps);continue}if(y.PROCESS_DESCRIPTORS_VALIDATE[_]===void 0){console.error(`Restart received unrecognized service command argument: ${_}`),K.error(`Restart received unrecognized service command argument: ${_}`);continue}let u=y.PROCESS_DESCRIPTORS_VALIDATE[_];if(console.log(`Restarting ${u}`),K.trace(`Restarting ${u}`),u===y.PROCESS_DESCRIPTORS.PM2_LOGROTATE)await q.configureLogRotate();else if(_.toLowerCase().includes("clustering"))await Pn(_);else if(await q.isServiceRegistered(u))u===y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS&&!r?(await q.stop(y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS),K.trace(`Stopping ${y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS}`)):await vN({service:u});else if(u===y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS)if(r)await q.startService(u),K.trace(`Starting ${u}`);else{let l=`${u} is not enabled in harperdb-config.yaml and cannot be restarted.`;K.error(l),console.log(l)}else await q.startService(u);K.notify(`${u} successfully restarted.`)}return}if(await q.isHdbRestartRunning()===!0)return K.notify(Ps),console.error(Ps),Ps;console.log(PN),t&&await HN();let n=await q.isServiceRegistered(y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS);r&&!n&&(await q.startService(y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS),K.trace(`Starting ${y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS}`));let i=[y.PROCESS_DESCRIPTORS.CLUSTERING_HUB,y.PROCESS_DESCRIPTORS.CLUSTERING_LEAF,y.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE,y.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE];return!r&&n&&(i.push(y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS),await q.stop(y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS),K.trace(`Stopping ${y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS}`)),await q.configureLogRotate(),K.notify(UY),await q.restartAllServices(i),PN}catch(e){let t=`There was an error restarting HarperDB. ${e}`;return K.error(t),t}}a(DY,"restartProcesses");async function vN(e){if(K.createLogFile(y.PROCESS_LOG_NAMES.CLI,y.PROCESS_DESCRIPTORS.STOP),q===void 0&&(q=$i()),s_.isEmpty(e.service))throw td(new Error,LY,rd.BAD_REQUEST,void 0,void 0,!0);let t=e.service.toLowerCase();if(y.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw td(new Error,wY,rd.BAD_REQUEST,void 0,void 0,!0);let r=Yi.getConfigFromFile(y.CONFIG_PARAMS.CUSTOMFUNCTIONS_ENABLED),s=y.PROCESS_DESCRIPTORS_VALIDATE[t];if(s===y.PROCESS_DESCRIPTORS.HDB){if(await q.isHdbRestartRunning()===!0)return K.notify(Ps),Ps;await q.reloadStopStart(s)}else if(s===y.PROCESS_DESCRIPTORS.PM2_LOGROTATE)await q.configureLogRotate();else if(s.toLowerCase().includes("clustering"))await Pn(s);else if(s===y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS||s===y.SERVICES.CUSTOM_FUNCTIONS){let i=await q.isServiceRegistered(s);if(r)i?(await q.reloadStopStart(s),K.trace(`Reloading ${s}`)):(await q.startService(s),K.trace(`Starting ${s}`));else if(!r&&i)await q.stop(s),K.trace(`Stopping ${s}`);else{let o=`${s} is not enabled in harperdb-config.yaml and cannot be restarted.`;throw K.error(o),td(new Error,o,rd.BAD_REQUEST,void 0,void 0,!0)}}else await q.restart(s);let n=`Restarting ${s}`;return K.notify(n),n}a(vN,"restartService");async function MY(){K.createLogFile(y.PROCESS_LOG_NAMES.CLI,y.PROCESS_DESCRIPTORS.STOP);try{q===void 0&&(q=$i());let e=BN(process.argv);if(s_.isEmpty(e.service))console.log("Stopping HarperDB."),await q.stopAllServices(),K.notify("HarperDB has stopped");else{if(typeof e.service!="string"){let r=`Stop service argument expected a string but received: ${e.service}`;K.error(r),console.log(r)}let t=e.service.split(",");for(let r of t){let s=r.toLowerCase();if(y.PROCESS_DESCRIPTORS_VALIDATE[s]===void 0){K.error(`Stop received unrecognized service command argument: ${s}`);continue}s==="clustering"?await q.stopClustering():await q.stop(y.PROCESS_DESCRIPTORS_VALIDATE[s]);let n=`${y.PROCESS_DESCRIPTORS_VALIDATE[s]} successfully stopped.`;K.notify(n),console.log(n)}}}catch(e){throw console.error(e),e}}a(MY,"stop");async function HN(){await Pn(y.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Pn(y.PROCESS_DESCRIPTORS.CLUSTERING_LEAF),await Pn(y.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE),await Pn(y.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE),await sd.updateNodeNameLocalStreams(),await sd.closeConnection()}a(HN,"restartAllClusteringServices");async function Pn(e){e=y.PROCESS_DESCRIPTORS_VALIDATE[e.toLowerCase()];let t=Yi.getConfigFromFile(y.CONFIG_PARAMS.CLUSTERING_ENABLED),r=e==="clustering",s=e==="clustering config",n=r?void 0:await q.isServiceRegistered(e),i=r||s?await q.isClusteringRunning():void 0;switch(!0){case s:if(!i){K.error(yY);break}await q.reloadClustering();break;case(r&&i&&!t):await q.stopClustering();break;case(r&&!i&&t):await q.startClustering();break;case(r&&i&&t):await HN();break;case(r&&!i&&!t):K.error(`${e} is not enabled in harperdb-config.yaml and cannot be restarted.`);break;case(n&&!t):await q.stop(e),K.trace(`Stopping ${e}`);break;case(!n&&t):e!==y.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE&&e!==y.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE&&await ed.generateNatsConfig(!0,e),await q.startService(e),K.trace(`Starting ${e}`),e===y.PROCESS_DESCRIPTORS.CLUSTERING_LEAF&&await sd.createWorkQueueStream(bY.WORK_QUEUE_CONSUMER_NAMES);break;case(!n&&!t):K.error(`${e} is not enabled in harperdb-config.yaml and cannot be restarted.`);break;case(n&&t):e===y.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE||e===y.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE?await q.reload(e):(await ed.generateNatsConfig(!0,e),await q.restart(e),await ed.removeNatsConfig(e));break;default:K.error(`Error restarting ${e}`)}}a(Pn,"restartClustering")});var JN=S((U3,WN)=>{"use strict";var L3=require("lodash"),Xe=T(),{handleHDBError:qN,hdb_errors:PY}=D(),{HDB_ERROR_MSGS:BY,HTTP_STATUS_CODES:vY}=PY,id=I();WN.exports={getRolePermissions:GY};var Bs=Object.create(null),HY=a(e=>({key:e,perms:{}}),"perms_template_obj"),xN=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),$N=a((e=!1,t=!1,r=!1,s=!1)=>({[Xe.PERMS_CRUD_ENUM.READ]:e,[Xe.PERMS_CRUD_ENUM.INSERT]:t,[Xe.PERMS_CRUD_ENUM.UPDATE]:r,[Xe.PERMS_CRUD_ENUM.DELETE]:s}),"permissions_template"),ad=a((e=!1,t=!1,r=!1,s=!1,n=!1)=>({attribute_permissions:[],describe:e,...$N(t,r,s,n)}),"table_perms_template"),FN=a((e,t=$N())=>({attribute_name:e,describe:QN(t),[Ki]:t[Ki],[od]:t[od],[cd]:t[cd]}),"attr_perms_template"),VN=a((e,t=!1)=>({attribute_name:e,describe:t,[Ki]:t}),"timestamp_attr_perms_template"),{READ:Ki,INSERT:od,UPDATE:cd}=Xe.PERMS_CRUD_ENUM,YN=Object.values(Xe.PERMS_CRUD_ENUM),KN=[Ki,od,cd];function GY(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[Xe.SYSTEM_SCHEMA_NAME],t=e.role;let s=JSON.stringify([e.__updatedtime__,r]);if(Bs[t]&&Bs[t].key===s)return Bs[t].perms;let n=qY(e,r);return Bs[t]?Bs[t].key=s:Bs[t]=HY(s),Bs[t].perms=n,n}catch(r){if(!e[Xe.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Xe.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Xe.PERMS_UPDATE_RELEASE_TIMESTAMP){let s=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw id.error(s),id.debug(r),qN(new Error,BY.OUTDATED_PERMS_TRANSLATION_ERROR,vY.BAD_REQUEST)}else{let s=`There was an error while translating role permissions for role: ${t}.
|
|
8
8
|
${r.stack}`;throw id.error(s),qN(new Error)}}}a(GY,"getRolePermissions");function qY(e,t){let r=Object.create(null);r.super_user=!1;let s=e.permission;r[Xe.SYSTEM_SCHEMA_NAME]=s[Xe.SYSTEM_SCHEMA_NAME],r.structure_user=s.structure_user;let n=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(n===!0||n.indexOf(i)>-1){r[i]=FY(t[i]);return}r[i]=xN(),s[i]?Object.keys(t[i]).forEach(o=>{if(s[i].tables[o]){let c=s[i].tables[o],_=t[i][o],u=VY(c,_);r[i].describe||YN.forEach(l=>{u[l]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=ad()}):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=ad()})}),r}a(qY,"translateRolePermissions");function FY(e){let t=xN(!0);return Object.keys(e).forEach(r=>{t.tables[r]=ad(!0,!0,!0,!0,!0)}),t}a(FY,"createStructureUserPermissions");function VY(e,t){let{attribute_permissions:r}=e;if(r.length>0){let n=Object.assign({},e);n.attribute_permissions=[];let i=r.reduce((u,l)=>{let{attribute_name:E}=l,d=l;return Xe.TIME_STAMP_NAMES.includes(E)&&(d=VN(E,l[Ki])),u[E]=d,u},{}),o=t[Xe.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_HASH_ATTRIBUTE_KEY],c=!!i[o],_=FN(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let l=i[u];l.describe=QN(l),n.attribute_permissions.push(l),c||kY(l,_)}else if(u!==o){let l;Xe.TIME_STAMP_NAMES.includes(u)?l=VN(u):l=FN(u),n.attribute_permissions.push(l)}}),c||n.attribute_permissions.push(_),n.describe=kN(n),n}else return e.describe=kN(e),e}a(VY,"getTableAttrPerms");function kN(e){return YN.filter(t=>e[t]).length>0}a(kN,"getSchemaTableDescribePerm");function QN(e){return KN.filter(t=>e[t]).length>0}a(QN,"getAttributeDescribePerm");function kY(e,t){KN.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(kY,"checkForHashPerms")});var rg=S((y3,tg)=>{"use strict";var Te=require("joi"),ZN=require("fs-extra"),XN=require("path"),Bn=de(),zN=Y(),jN=T(),eg=I(),{hdb_errors:xY}=D(),{HDB_ERROR_MSGS:Et}=xY,ts=/^[a-zA-Z0-9-_]+$/;tg.exports={getDropCustomFunctionValidator:YY,setCustomFunctionValidator:KY,addCustomFunctionProjectValidator:QY,dropCustomFunctionProjectValidator:WY,packageCustomFunctionProjectValidator:JY,deployCustomFunctionProjectValidator:ZY};function Qi(e,t,r){try{let s=zN.get(jN.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),n=XN.join(s,t);return ZN.existsSync(n)?e?t:r.message(Et.PROJECT_EXISTS):e?r.message(Et.NO_PROJECT):t}catch(s){return eg.error(s),r.message(Et.VALIDATION_ERR)}}a(Qi,"checkProjectExists");function $Y(e,t,r,s){try{let n=zN.get(jN.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),i=XN.join(n,e,t,r+".js");return ZN.existsSync(i)?r:s.message(Et.NO_FILE)}catch(n){return eg.error(n),s.message(Et.VALIDATION_ERR)}}a($Y,"checkFileExists");function YY(e){let t=Te.object({project:Te.string().pattern(ts).custom(Qi.bind(null,!0)).required().messages({"string.pattern.base":Et.BAD_PROJECT_NAME}),type:Te.string().valid("helpers","routes").required(),file:Te.string().pattern(ts).custom($Y.bind(null,e.project,e.type)).required().messages({"string.pattern.base":Et.BAD_FILE_NAME})});return Bn.validateBySchema(e,t)}a(YY,"getDropCustomFunctionValidator");function KY(e){let t=Te.object({project:Te.string().pattern(ts).custom(Qi.bind(null,!0)).required().messages({"string.pattern.base":Et.BAD_PROJECT_NAME}),type:Te.string().valid("helpers","routes").required(),file:Te.string().pattern(ts).required().messages({"string.pattern.base":Et.BAD_FILE_NAME}),function_content:Te.string().required()});return Bn.validateBySchema(e,t)}a(KY,"setCustomFunctionValidator");function QY(e){let t=Te.object({project:Te.string().pattern(ts).custom(Qi.bind(null,!1)).required().messages({"string.pattern.base":Et.BAD_PROJECT_NAME})});return Bn.validateBySchema(e,t)}a(QY,"addCustomFunctionProjectValidator");function WY(e){let t=Te.object({project:Te.string().pattern(ts).custom(Qi.bind(null,!0)).required().messages({"string.pattern.base":Et.BAD_PROJECT_NAME})});return Bn.validateBySchema(e,t)}a(WY,"dropCustomFunctionProjectValidator");function JY(e){let t=Te.object({project:Te.string().pattern(ts).custom(Qi.bind(null,!0)).required().messages({"string.pattern.base":Et.BAD_PROJECT_NAME}),skip_node_modules:Te.boolean()});return Bn.validateBySchema(e,t)}a(JY,"packageCustomFunctionProjectValidator");function ZY(e){let t=Te.object({project:Te.string().pattern(ts).required().messages({"string.pattern.base":Et.BAD_PROJECT_NAME}),payload:Te.string().required().messages({"string.pattern.base":Et.BAD_PACKAGE})});return Bn.validateBySchema(e,t)}a(ZY,"deployCustomFunctionProjectValidator")});var ld=S((D3,ig)=>{"use strict";var we=require("fs-extra"),n_=require("fast-glob"),ie=require("path"),sg=require("tar-fs"),ng=require("uuid").v4,Wi=require("normalize-path"),vs=rg(),Le=I(),At=T(),Ot=Y(),{PACKAGE_ROOT:XY}=T(),{handleHDBError:ze,hdb_errors:zY}=D(),{HDB_ERROR_MSGS:rs,HTTP_STATUS_CODES:je}=zY,jY=ie.join(XY,"custom_function_template"),_d=ie.join(Ot.get(At.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp");function ud(){let e=Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY);if(!(e==="true"||e===!0||e==="TRUE"))throw ze(new Error,rs.NOT_ENABLED,je.BAD_REQUEST,void 0,void 0,!0)}a(ud,"isCFEnabled");function eK(){Le.trace("getting custom api status");let e={};try{e={is_enabled:Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY),port:Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY),directory:Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY)}}catch(t){throw ze(new Error,rs.FUNCTION_STATUS,je.INTERNAL_SERVER_ERROR,Le.ERR,t)}return e}a(eK,"customFunctionsStatus");function tK(){Le.trace("getting custom api endpoints");let e={},t=Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY);try{n_.sync(Wi(`${t}/*`),{onlyDirectories:!0}).forEach(s=>{let n=s.split("/").pop();e[n]={routes:n_.sync(Wi(`${s}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:n_.sync(Wi(`${s}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),static:we.existsSync(Wi(`${s}/static`))&&n_.sync(Wi(`${s}/static/**/*`)).length}})}catch(r){throw ze(new Error,rs.GET_FUNCTIONS,je.INTERNAL_SERVER_ERROR,Le.ERR,r)}return e}a(tK,"getCustomFunctions");function rK(e){e.project&&(e.project=ie.parse(e.project).name),e.file&&(e.file=ie.parse(e.file).name);let t=vs.getDropCustomFunctionValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("getting custom api endpoint file content");let r=Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s,type:n,file:i}=e,o=ie.join(r,s,n,i+".js");try{return we.readFileSync(o,{encoding:"utf8"})}catch(c){throw ze(new Error,rs.GET_FUNCTION,je.INTERNAL_SERVER_ERROR,Le.ERR,c)}}a(rK,"getCustomFunction");function sK(e){ud(),e.project&&(e.project=ie.parse(e.project).name),e.file&&(e.file=ie.parse(e.file).name);let t=vs.setCustomFunctionValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("setting custom function file content");let r=Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s,type:n,file:i,function_content:o}=e;try{return we.outputFileSync(ie.join(r,s,n,i+".js"),o),`Successfully updated custom function: ${i}.js`}catch(c){throw ze(new Error,rs.SET_FUNCTION,je.INTERNAL_SERVER_ERROR,Le.ERR,c)}}a(sK,"setCustomFunction");function nK(e){e.project&&(e.project=ie.parse(e.project).name),e.file&&(e.file=ie.parse(e.file).name);let t=vs.getDropCustomFunctionValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("dropping custom function file");let r=Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s,type:n,file:i}=e;try{return we.unlinkSync(ie.join(r,s,n,i+".js")),`Successfully deleted custom function: ${i}.js`}catch(o){throw ze(new Error,rs.DROP_FUNCTION,je.INTERNAL_SERVER_ERROR,Le.ERR,o)}}a(nK,"dropCustomFunction");function iK(e){ud(),e.project&&(e.project=ie.parse(e.project).name);let t=vs.addCustomFunctionProjectValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("adding custom function project");let r=Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s}=e;try{let n=ie.join(r,s);return we.mkdirSync(n,{recursive:!0}),we.copySync(jY,n),`Successfully created custom function project: ${s}`}catch(n){throw ze(new Error,rs.ADD_FUNCTION,je.INTERNAL_SERVER_ERROR,Le.ERR,n)}}a(iK,"addCustomFunctionProject");function aK(e){e.project&&(e.project=ie.parse(e.project).name);let t=vs.dropCustomFunctionProjectValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("dropping custom function project");let r=Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s}=e;try{let n=ie.join(r,s);return we.rmSync(n,{recursive:!0}),`Successfully deleted project: ${s}`}catch(n){throw ze(new Error,rs.DROP_FUNCTION_PROJECT,je.INTERNAL_SERVER_ERROR,Le.ERR,n)}}a(aK,"dropCustomFunctionProject");async function oK(e){e.project&&(e.project=ie.parse(e.project).name);let t=vs.packageCustomFunctionProjectValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("packaging custom function project");let r=Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s}=e,n=ie.join(r,s),i=ng();if(!we.existsSync(n)){let l=`Unable to locate custom function project: ${s}`;throw Le.error(l),l}we.ensureDirSync(_d);let c=ie.join(_d,`${i}.tar`),_={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(_={ignore:l=>l.includes(ie.join(n,"node_modules"))}),sg.pack(n,_).pipe(we.createWriteStream(c)),await new Promise(l=>setTimeout(l,2e3));let u=we.readFileSync(c,{encoding:"base64"});return we.unlinkSync(c),{project:s,payload:u,file:c}}a(oK,"packageCustomFunctionProject");async function cK(e){ud(),e.project&&(e.project=ie.parse(e.project).name);let t=vs.deployCustomFunctionProjectValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("deploying custom function project");let r=Ot.get(At.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s,payload:n,file:i}=e,o=ie.join(r,s);await we.ensureDir(o);let c,_;do c=ie.join(_d,ng()+".tar"),_=await we.pathExists(c);while(_);await we.outputFile(c,n,{encoding:"base64"});let u=we.createReadStream(c);return u.pipe(sg.extract(o)),await new Promise(l=>u.on("end",l)),await we.unlink(c),`Successfully deployed project: ${s}`}a(cK,"deployCustomFunctionProject");ig.exports={customFunctionsStatus:eK,getCustomFunctions:tK,getCustomFunction:rK,setCustomFunction:sK,dropCustomFunction:nK,addCustomFunctionProject:iK,dropCustomFunctionProject:aK,packageCustomFunctionProject:oK,deployCustomFunctionProject:cK}});var Ed=S((M3,og)=>{"use strict";var cr=require("joi"),ag=de();og.exports={readTransactionLogValidator:_K,deleteTransactionLogsBeforeValidator:uK};function _K(e){let t=cr.object({schema:cr.string().required(),table:cr.string().required(),from:cr.date().timestamp(),to:cr.date().timestamp(),limit:cr.number().min(1)});return ag.validateBySchema(e,t)}a(_K,"readTransactionLogValidator");function uK(e){let t=cr.object({schema:cr.string().required(),table:cr.string().required(),timestamp:cr.date().timestamp().required()});return ag.validateBySchema(e,t)}a(uK,"deleteTransactionLogsBeforeValidator")});var a_=S((P3,Eg)=>{"use strict";var dd=T(),i_=ot(),cg=b(),_g=Y(),ug=Vr(),{handleHDBError:vn,hdb_errors:lK}=D(),{HTTP_STATUS_CODES:Hn}=lK,{readTransactionLogValidator:EK,deleteTransactionLogsBeforeValidator:dK}=Ed(),lg="This operation relies on clustering and cannot run with it disable.",hK="Logs successfully deleted from transaction log.",SK="All logs successfully deleted from transaction log.";Eg.exports={readTransactionLog:fK,deleteTransactionLogsBefore:TK};async function fK(e){let t=EK(e);if(t)throw vn(t,t.message,Hn.BAD_REQUEST,void 0,void 0,!0);if(!_g.get(dd.CONFIG_PARAMS.CLUSTERING_ENABLED))throw vn(new Error,lg,Hn.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:s}=e,n=cg.checkSchemaTableExist(r,s);if(n)throw vn(new Error,n,Hn.NOT_FOUND,void 0,void 0,!0);let i=ug.createNatsTableStreamName(r,s),o=await i_.viewStream(i,parseInt(e.from),e.limit),c=[];for(let _=0,u=o.length;_<u;_++){let l=o[_],E=Math.floor(l?.nats_timestamp/1e6);if(e.to&&E>e.to)break;let d={operation:l?.entry?.operation,user:l?.entry?.__origin?.user,timestamp:E,records:l?.entry?.records};l?.entry?.operation===dd.OPERATIONS_ENUM.DELETE&&(d.hash_values=l?.entry?.hash_values),c.push(d)}return c}a(fK,"readTransactionLog");async function TK(e){let t=dK(e);if(t)throw vn(t,t.message,Hn.BAD_REQUEST,void 0,void 0,!0);if(!_g.get(dd.CONFIG_PARAMS.CLUSTERING_ENABLED))throw vn(new Error,lg,Hn.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:s,timestamp:n}=e,i=cg.checkSchemaTableExist(r,s);if(i)throw vn(new Error,i,Hn.NOT_FOUND,void 0,void 0,!0);let o=ug.createNatsTableStreamName(r,s),{jsm:c}=await i_.getNATSReferences(),_=await i_.getStreamInfo(o),u=new Date(_.state.first_ts).getTime();if(n<=u)return`No transactions exist before: ${n}`;let l=hK,E,d=new Date(_.state.last_ts).getTime();return n>d?(E=_.state.last_seq+1,l=SK):E=(await i_.viewStream(o,parseInt(n),1))[0].nats_sequence,await c.streams.purge(o,{seq:E}),l}a(TK,"deleteTransactionLogsBefore")});var Sd=S((B3,pg)=>{"use strict";var o_=require("joi"),c_=require("path"),dg=require("fs-extra"),{exec:mK}=require("child_process"),RK=require("util"),hg=RK.promisify(mK),AK=T(),{handleHDBError:Gn,hdb_errors:OK}=D(),{HTTP_STATUS_CODES:qn}=OK,Sg=Y(),pK=de(),__=I();Sg.initSync();var hd=Sg.get(AK.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),fg="npm install --omit=dev --json",NK=`${fg} --dry-run`;pg.exports={installModules:gK,auditModules:IK};async function Tg(e,t=void 0){let{stdout:r,stderr:s}=await hg(e,{cwd:t});if(s)throw new Error(s.replace(`
|