harperdb 4.5.0-beta.3 → 4.5.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bin/harperdb.js +73 -74
- package/bin/lite.js +74 -75
- package/config/yaml/defaultConfig.yaml +1 -0
- package/launchServiceScripts/launchInstallNATSServer.js +2 -2
- package/launchServiceScripts/launchNatsIngestService.js +74 -75
- package/launchServiceScripts/launchNatsReplyService.js +71 -72
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +71 -72
- package/npm-shrinkwrap.json +5 -5
- package/package.json +1 -1
- package/resources/DatabaseTransaction.d.ts +1 -1
- package/resources/blob.d.ts +5 -0
- package/server/jobs/jobProcess.js +72 -73
- package/server/threads/threadServer.js +74 -75
- package/studio/build-local/asset-manifest.json +3 -3
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/164.a6861c91.chunk.js +1 -0
- package/studio/build-local/static/js/main.20cb1d9f.js +2 -0
- package/utility/hdbTerms.d.ts +1 -0
- package/utility/scripts/restartHdb.js +72 -73
- package/studio/build-local/static/js/164.05df362d.chunk.js +0 -1
- package/studio/build-local/static/js/main.95c6282e.js +0 -2
- /package/studio/build-local/static/js/{main.95c6282e.js.LICENSE.txt → main.20cb1d9f.js.LICENSE.txt} +0 -0
package/bin/harperdb.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var AJ=Object.create;var Rf=Object.defineProperty;var RJ=Object.getOwnPropertyDescriptor;var yJ=Object.getOwnPropertyNames;var bJ=Object.getPrototypeOf,OJ=Object.prototype.hasOwnProperty;var a=(e,t)=>Rf(e,"name",{value:t,configurable:!0});var be=(e,t)=>()=>(e&&(t=e(e=0)),t);var w=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),ve=(e,t)=>{for(var r in t)Rf(e,r,{get:t[r],enumerable:!0})},sD=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of yJ(t))!OJ.call(e,s)&&s!==r&&Rf(e,s,{get:()=>t[s],enumerable:!(n=RJ(t,s))||n.enumerable});return e};var M=(e,t,r)=>(r=e!=null?AJ(bJ(e)):{},sD(t||!e||!e.__esModule?Rf(r,"default",{value:e,enumerable:!0}):r,e)),C=e=>sD(Rf({},"__esModule",{value:!0}),e);var st=w((Hye,aD)=>{var{join:NJ,dirname:iD}=require("node:path"),{existsSync:wJ,readFileSync:IJ}=require("node:fs");function CJ(){let t=__dirname,r,n=0;for(;!wJ(r=NJ(t,"package.json"));)if(t===(t=iD(t))||n++>10)throw new Error("Could not find package root");return r}a(CJ,"findPackageJson");var oD=CJ(),PJ=JSON.parse(IJ(oD,"utf8")),DJ=iD(oD);aD.exports={packageJson:PJ,PACKAGE_ROOT:DJ}});var rm=w((Fye,cD)=>{if(__filename.endsWith("dev.js")){let e=require("fast-glob"),{tmpdir:t}=require("node:os"),{relative:r,join:n}=require("node:path"),{existsSync:s,statSync:i,readFileSync:o,writeFileSync:c}=require("node:fs"),{isMainThread:l}=require("node:worker_threads"),{spawnSync:u,spawn:f}=require("node:child_process"),{PACKAGE_ROOT:d}=st(),p=["bin","components","dataLayer","resources","server","sqlTranslator","upgrade","utility","validation"],_="ts-build";if(l){let g=!1,R=!1;if((R=s(n(d,_)))?g=e.sync(p.map(E=>`${E}/**/*.ts`),{cwd:d}).some(E=>{let A=0,O=0;try{A=i(n(d,E)).mtimeMs-5e3,O=i(n(d,_,E.replace(/.ts$/,".js"))).mtimeMs}catch{}return A>O}):g=!0,g){console.log("Compiling TypeScript...");let E=u("npx",["tsc"],{cwd:d});if(E.stdout?.length&&console.log(E.stdout.toString()),E.stderr?.length&&console.log(E.stderr.toString()),R){let A=n(t(),"harperdb-tsc.pid"),O=!1;if(s(A))try{process.kill(+o(A,"utf8"),0),O=!0}catch{}if(!O){console.log("Starting background TypeScript compilation...");let v=f("npx",["tsc","--watch"],{detached:!0,cwd:d,stdio:"ignore"});c(A,v.pid.toString()),v.unref()}}}}let h=cD.constructor,S=h._findPath;h._findPath=function(g,R,E){if(g.startsWith(".")&&!E&&R.length===1&&R[0].startsWith(d)&&!R[0].includes("node_modules")){let A=r(d,R[0]),O;A.startsWith(_)?O=n(d,r(_,A)):O=n(d,_,A);let v=n(O,g),F=v+".js";if(s(F))return F;if(v.includes(".")&&s(v))return v}return S(g,R,E)}}});var q={};ve(q,{AUTH_AUDIT_STATUS:()=>Ws,AUTH_AUDIT_TYPES:()=>ua,BOOT_PROPS_FILE_NAME:()=>r2,BOOT_PROP_PARAMS:()=>dD,CLUSTERING_FLAG:()=>I2,CLUSTERING_PROCESSES:()=>GJ,CLUSTER_MESSAGE_TYPE_ENUM:()=>zA,CLUSTER_OPERATIONS:()=>g2,CONFIG_PARAMS:()=>B,CONFIG_PARAM_MAP:()=>fD,DATABASES_DIR_NAME:()=>yc,DATABASES_PARAM_CONFIG:()=>R2,DEFAULT_DATABASE_NAME:()=>$J,ESCAPED_FORWARD_SLASH_REGEX:()=>ZJ,FORWARD_SLASH_REGEX:()=>JJ,FUNC_VAL:()=>v2,GEO_CONVERSION_ENUM:()=>T2,HDB_COMPONENT_CONFIG_FILE:()=>vJ,HDB_CONFIG_FILE:()=>LJ,HDB_DEFAULT_CONFIG_FILE:()=>MJ,HDB_FILE_PERMISSIONS:()=>s2,HDB_HOME_DIR_NAME:()=>t2,HDB_PID_FILE:()=>qJ,HDB_PROCESS_SERVICES:()=>FJ,HDB_PROC_NAME:()=>UJ,HDB_RESTART_SCRIPT:()=>xJ,HDB_ROOT_DIR_NAME:()=>$A,HDB_SETTINGS_NAMES:()=>WA,HDB_SUPPORT_ADDRESS:()=>uD,INFO_TABLE_HASH_ATTRIBUTE:()=>u2,INSERT_MAX_CHARACTER_SIZE:()=>c2,INSTALL_PROMPTS:()=>a2,ITC_EVENT_TYPES:()=>QA,JOB_STATUS_ENUM:()=>p2,JOB_TYPE_ENUM:()=>y2,JWT_ENUM:()=>bf,LAUNCH_SERVICE_SCRIPTS:()=>YJ,LEGACY_CONFIG_PARAMS:()=>A2,LEGACY_DATABASES_DIR_NAME:()=>im,LICENSE_FILE_NAME:()=>_2,LICENSE_KEY_DIR_NAME:()=>YA,LICENSE_VALUES:()=>b2,LOG_LEVELS:()=>KJ,LOG_NAMES:()=>VJ,MEM_SETTING_KEY:()=>e2,METADATA_PROPERTY:()=>w2,NODE_ERROR_CODES:()=>N2,OPERATIONS_ENUM:()=>Vt,PERMS_CRUD_ENUM:()=>L2,PERMS_UPDATE_RELEASE_TIMESTAMP:()=>D2,PRE_4_0_0_VERSION:()=>U2,PROCESS_DESCRIPTORS:()=>kJ,PROCESS_NAME_ENV_PROP:()=>o2,RAM_ALLOCATION_ENUM:()=>O2,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:()=>am,REG_KEY_FILE_NAME:()=>f2,RESTART_TIMEOUT_MS:()=>n2,ROLE_TYPES_ENUM:()=>WJ,S3_BUCKET_AUTH_KEYS:()=>m2,SEARCH_NOT_FOUND_MESSAGE:()=>jJ,SEARCH_WILDCARDS:()=>M2,SERVICE_ACTIONS_ENUM:()=>S2,SUPPORT_HELP_MSG:()=>zJ,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:()=>d2,SYSTEM_SCHEMA_NAME:()=>yf,SYSTEM_TABLE_NAMES:()=>du,THREAD_TYPES:()=>JA,TIME_STAMP_NAMES:()=>P2,TIME_STAMP_NAMES_ENUM:()=>C2,TRANSACTIONS_DIR_NAME:()=>i2,UNICODE_FORWARD_SLASH:()=>XJ,UNICODE_PERIOD:()=>QJ,UPGRADE_JSON_FIELD_NAMES_ENUM:()=>l2,VALID_S3_FILE_TYPES:()=>h2,VALID_SQL_OPS_ENUM:()=>E2,VALUE_SEARCH_COMPARATORS:()=>om,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>jA});var nm,sm,LJ,MJ,$A,vJ,UJ,xJ,lD,qA,VA,KA,BJ,HJ,kJ,FJ,GJ,qJ,$J,VJ,KJ,YJ,WJ,uD,zJ,jJ,QJ,JJ,XJ,ZJ,e2,yf,t2,YA,r2,n2,s2,yc,im,i2,o2,dD,a2,c2,l2,du,u2,d2,f2,_2,p2,Vt,h2,m2,E2,g2,S2,T2,WA,A2,B,fD,R2,y2,zA,b2,O2,N2,w2,I2,_D,pD,C2,P2,D2,om,jA,L2,M2,v2,am,bf,QA,JA,U2,Ws,ua,H=be(()=>{nm=require("node:path"),sm=M(st()),LJ="harperdb-config.yaml",MJ="defaultConfig.yaml",$A="hdb",vJ="config.yaml",UJ="harperdb.js",xJ="restartHdb.js",lD="HarperDB",qA="Custom Functions",VA="Clustering Hub",KA="Clustering Leaf",BJ="Clustering Ingest Service",HJ="Clustering Reply Service",kJ={HDB:lD,CLUSTERING_HUB:VA,CLUSTERING_LEAF:KA,CLUSTERING_INGEST_SERVICE:BJ,CLUSTERING_REPLY_SERVICE:HJ,CUSTOM_FUNCTIONS:qA,RESTART_HDB:"Restart HDB",INSTALL:"Install",RUN:"Run",STOP:"Stop",UPGRADE:"Upgrade",REGISTER:"Register",JOB:"Job",CLUSTERING_UPGRADE_4_0_0:"Upgrade-4-0-0"},FJ={harperdb:lD,"clustering hub":VA,"clustering leaf":KA,"custom functions":qA,custom_functions:qA,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},GJ={CLUSTERING_HUB_PROC_DESCRIPTOR:VA,CLUSTERING_LEAF_PROC_DESCRIPTOR:KA},qJ="hdb.pid",$J="data",VJ={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},KJ={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},YJ={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:(0,nm.join)(sm.PACKAGE_ROOT,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:(0,nm.join)(sm.PACKAGE_ROOT,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:(0,nm.join)(sm.PACKAGE_ROOT,"launchServiceScripts/launchUpdateNodes4-0-0.js")},WJ={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},uD="support@harperdb.io",zJ=`For support, please submit a request at https://harperdbhelp.zendesk.com/hc/en-us/requests/new or contact ${uD}`,jJ="None of the specified records were found.",QJ="U+002E",JJ=/\//g,XJ="U+002F",ZJ=/U\+002F/g,e2="--max-old-space-size=",yf="system",t2=".harperdb",YA="keys",r2="hdb_boot_properties.file",n2=6e4,s2=448,yc="database",im="schema",i2="transactions",o2="PROCESS_NAME",dD={SETTINGS_PATH_KEY:"settings_path"},a2={TC_AGREEMENT:"TC_AGREEMENT",CLUSTERING_USER:"CLUSTERING_USER",CLUSTERING_PASSWORD:"CLUSTERING_PASSWORD",HDB_ADMIN_USERNAME:"HDB_ADMIN_USERNAME",HDB_ADMIN_PASSWORD:"HDB_ADMIN_PASSWORD",OPERATIONSAPI_ROOT:"OPERATIONSAPI_ROOT",ROOTPATH:"ROOTPATH",CLUSTERING_NODENAME:"CLUSTERING_NODENAME",CLUSTERING_ENABLED:"CLUSTERING_ENABLED",HDB_CONFIG:"HDB_CONFIG",DEFAULTS_MODE:"DEFAULTS_MODE",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},c2=250,l2={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},du={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"},u2="info_id",d2={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"},f2="060493.ks",_2=".license",p2={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},Vt={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts",GET_KEY:"get_key"},h2={CSV:".csv",JSON:".json"},m2={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},E2={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},g2={[Vt.INSERT]:Vt.INSERT,[Vt.UPDATE]:Vt.UPDATE,[Vt.UPSERT]:Vt.UPSERT,[Vt.DELETE]:Vt.DELETE},S2={DEV:"dev",RUN:"run",START:"start",INSTALL:"install",REGISTER:"register",STOP:"stop",RESTART:"restart",VERSION:"version",UPGRADE:"upgrade",HELP:"help",STATUS:"status",OPERATION:"operation",RENEWCERTS:"renew-certs",COPYDB:"copy-db"},T2={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},WA={HDB_ROOT_KEY:"HDB_ROOT",SERVER_PORT_KEY:"SERVER_PORT",CERT_KEY:"CERTIFICATE",PRIVATE_KEY_KEY:"PRIVATE_KEY",HTTP_SECURE_ENABLED_KEY:"HTTPS_ON",CORS_ENABLED_KEY:"CORS_ON",CORS_WHITELIST_KEY:"CORS_WHITELIST",LOG_LEVEL_KEY:"LOG_LEVEL",LOGGER_KEY:"LOGGER",LOG_PATH_KEY:"LOG_PATH",LOG_ROTATE:"LOG_ROTATE",LOG_ROTATE_MAX_SIZE:"LOG_ROTATE_MAX_SIZE",LOG_ROTATE_RETAIN:"LOG_ROTATE_RETAIN",LOG_ROTATE_COMPRESS:"LOG_ROTATE_COMPRESS",LOG_ROTATE_DATE_FORMAT:"LOG_ROTATE_DATE_FORMAT",LOG_ROTATE_ROTATE_MODULE:"LOG_ROTATE_ROTATE_MODULE",LOG_ROTATE_WORKER_INTERVAL:"LOG_ROTATE_WORKER_INTERVAL",LOG_ROTATE_ROTATE_INTERVAL:"LOG_ROTATE_ROTATE_INTERVAL",LOG_ROTATE_TIMEZONE:"LOG_ROTATE_TIMEZONE",LOG_DAILY_ROTATE_KEY:"LOG_DAILY_ROTATE",LOG_MAX_DAILY_FILES_KEY:"LOG_MAX_DAILY_FILES",PROPS_ENV_KEY:"NODE_ENV",SETTINGS_PATH_KEY:"settings_path",CLUSTERING_PORT_KEY:"CLUSTERING_PORT",CLUSTERING_NODE_NAME_KEY:"NODE_NAME",CLUSTERING_ENABLED_KEY:"CLUSTERING",ALLOW_SELF_SIGNED_SSL_CERTS:"ALLOW_SELF_SIGNED_SSL_CERTS",MAX_HDB_PROCESSES:"MAX_HDB_PROCESSES",INSTALL_USER:"install_user",CLUSTERING_USER_KEY:"CLUSTERING_USER",MAX_CLUSTERING_PROCESSES:"MAX_CLUSTERING_PROCESSES",SERVER_TIMEOUT_KEY:"SERVER_TIMEOUT_MS",SERVER_KEEP_ALIVE_TIMEOUT_KEY:"SERVER_KEEP_ALIVE_TIMEOUT",SERVER_HEADERS_TIMEOUT_KEY:"SERVER_HEADERS_TIMEOUT",DISABLE_TRANSACTION_LOG_KEY:"DISABLE_TRANSACTION_LOG",OPERATION_TOKEN_TIMEOUT_KEY:"OPERATION_TOKEN_TIMEOUT",REFRESH_TOKEN_TIMEOUT_KEY:"REFRESH_TOKEN_TIMEOUT",CUSTOM_FUNCTIONS_ENABLED_KEY:"CUSTOM_FUNCTIONS",CUSTOM_FUNCTIONS_PORT_KEY:"CUSTOM_FUNCTIONS_PORT",CUSTOM_FUNCTIONS_DIRECTORY_KEY:"CUSTOM_FUNCTIONS_DIRECTORY",MAX_CUSTOM_FUNCTION_PROCESSES:"MAX_CUSTOM_FUNCTION_PROCESSES",LOG_TO_FILE:"LOG_TO_FILE",LOG_TO_STDSTREAMS:"LOG_TO_STDSTREAMS",RUN_IN_FOREGROUND:"RUN_IN_FOREGROUND",LOCAL_STUDIO_ON:"LOCAL_STUDIO_ON",STORAGE_WRITE_ASYNC:"STORAGE_WRITE_ASYNC"},A2={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"},B={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",AUTHENTICATION_HASHFUNCTION:"authentication_hashFunction",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_CORSACCESSCONTROLALLOWHEADERS:"http_corsAccessControlAllowHeaders",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",HTTP_HTTP2:"http_http2",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_ROTATION_RETENTION:"logging_rotation_retention",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_NETWORK_HTTP2:"operationsApi_network_http2",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",REPLICATION_COPYTABLESTOCATCHUP:"replication_copyTablesToCatchUp",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_BLOBPATHS:"storage_blobPaths",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",STORAGE_RECLAMATION_THRESHOLD:"storage_reclamation_threshold",STORAGE_RECLAMATION_INTERVAL:"storage_reclamation_interval",STORAGE_RECLAMATION_EVICTIONFACTOR:"storage_reclamation_evictionFactor",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},fD={settings_path:dD.SETTINGS_PATH_KEY,hdb_root_key:B.ROOTPATH,hdb_root:B.ROOTPATH,rootpath:B.ROOTPATH,server_port_key:B.OPERATIONSAPI_NETWORK_PORT,server_port:B.OPERATIONSAPI_NETWORK_PORT,cert_key:B.TLS_CERTIFICATE,certificate:B.TLS_CERTIFICATE,private_key_key:B.TLS_PRIVATEKEY,private_key:B.TLS_PRIVATEKEY,http_secure_enabled_key:B.OPERATIONSAPI_NETWORK_HTTPS,https_on:B.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:B.OPERATIONSAPI_NETWORK_CORS,cors_on:B.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:B.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:B.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:B.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:B.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:B.LOGGING_LEVEL,log_level:B.LOGGING_LEVEL,log_path_key:B.LOGGING_ROOT,log_path:B.LOGGING_ROOT,clustering_node_name_key:B.CLUSTERING_NODENAME,node_name:B.CLUSTERING_NODENAME,clustering_enabled_key:B.CLUSTERING_ENABLED,clustering:B.CLUSTERING_ENABLED,max_http_threads:B.THREADS_COUNT,max_hdb_processes:B.THREADS_COUNT,server_timeout_key:B.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:B.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:B.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:B.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:B.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:B.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:B.LOGGING_AUDITLOG,disable_transaction_log:B.LOGGING_AUDITLOG,operation_token_timeout_key:B.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:B.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:B.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:B.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:B.HTTP_PORT,custom_functions_port:B.HTTP_PORT,custom_functions_directory_key:B.COMPONENTSROOT,custom_functions_directory:B.COMPONENTSROOT,max_custom_function_processes:B.THREADS_COUNT,logging_console:B.LOGGING_CONSOLE,log_to_file:B.LOGGING_FILE,log_to_stdstreams:B.LOGGING_STDSTREAMS,local_studio_on:B.LOCALSTUDIO_ENABLED,clustering_port:B.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:B.CLUSTERING_USER,customfunctions_network_port:B.HTTP_PORT,customfunctions_tls_certificate:B.TLS_CERTIFICATE,customfunctions_network_cors:B.HTTP_CORS,customfunctions_network_corsaccesslist:B.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:B.HTTP_HEADERSTIMEOUT,customfunctions_network_https:B.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:B.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:B.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:B.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:B.HTTP_TIMEOUT,customfunctions_tls:B.TLS,http_threads:B.THREADS_COUNT,threads:B.THREADS_COUNT,threads_count:B.THREADS_COUNT,customfunctions_processes:B.THREADS_COUNT,customfunctions_root:B.COMPONENTSROOT,operationsapi_root:B.ROOTPATH};for(let e in B){let t=B[e];fD[t.toLowerCase()]=t}R2={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},y2={csv_file_load:"csv_file_load",csv_data_load:Vt.CSV_DATA_LOAD,csv_url_load:Vt.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},zA={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"},b2={VERSION_DEFAULT:"2.2.0"},O2={DEVELOPMENT:8192,DEFAULT:512},N2={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},w2=Symbol("metadata"),I2="__clustering__",_D="__createdtime__",pD="__updatedtime__",C2={CREATED_TIME:_D,UPDATED_TIME:pD},P2=[_D,pD],D2=15984864e5,om={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},jA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},L2={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},M2=["*","%"],v2="func_val",am={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},bf={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},QA={SHUTDOWN:"shutdown",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",SCHEMA:"schema",USER:"user",CLUSTER_STATUS_RESPONSE:"cluster_status_response",CLUSTER_STATUS_REQUEST:"cluster_status_request",METRICS:"metrics",GET_METRICS:"get_metrics",RESTART:"restart",START_JOB:"start_job",NATS_CONSUMER_UPDATE:"nats_consumer_update"},JA={HTTP:"http"},U2="3.x.x",Ws={SUCCESS:"success",FAILURE:"failure"},ua={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var da=w((Gye,ED)=>{"use strict";var hD=require("minimist");ED.exports=x2;function x2(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=mD(process.env),n=mD(hD(process.argv))):(r=process.env,n=hD(process.argv));let s={};for(let i=0,o=e.length;i<o;i++){let c=e[i];n[c]!==void 0?s[c]=n[c].toString().trim():r[c]!==void 0&&(s[c]=r[c].toString().trim())}return s}a(x2,"assignCMDENVVariables");function mD(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(mD,"objKeysToLowerCase")});var Ri=w(zs=>{"use strict";global.Resource=zs.Resource=void 0;global.tables=zs.tables={};global.databases=zs.databases={};global.getUser=zs.getUser=void 0;global.authenticateUser=zs.authenticateUser=void 0;global.server=zs.server={};global.contentTypes=zs.contentTypes=null;global.threads=zs.threads=[];global.logger={};zs._assignPackageExport=(e,t)=>{global[e]=zs[e]=t}});var z=w((LD,MD)=>{"use strict";var oo=require("fs-extra"),{workerData:B2,threadId:H2,isMainThread:k2}=require("worker_threads"),bi=require("path"),AD=require("yaml"),RD=require("properties-reader"),Kt=(H(),C(q)),gD=da(),F2=require("os"),{PACKAGE_ROOT:tR}=st(),{_assignPackageExport:G2}=Ri(),SD=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),mr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},yD={STDOUT:"stdOut",STDERR:"stdErr"},q2=bi.join(tR,"logs"),$2=bi.join(tR,"config/yaml/",Kt.HDB_DEFAULT_CONFIG_FILE),V2=1e4,XA,yi,gs,Cr,cm,Of,lm,fa,Nf;Nf===void 0&&bD();Object.assign(LD,{notify:CD,fatal:PD,error:um,warn:DD,info:ND,debug:ID,trace:wD,setLogLevel:X2,log_level:Cr,loggerWithTag:W2,suppressLogging:z2,initLogSettings:bD,logCustomLevel:Q2,closeLogFile:rR,logsAtLevel:K2,getLogFilePath:a(()=>lm,"getLogFilePath"),OUTPUTS:yD,AuthAuditLog:t4});G2("logger",MD.exports);var ZA;function K2(e){return mr[Cr]<=mr[e]}a(K2,"logsAtLevel");function bD(e=!1){try{if(Nf===void 0||e){rR();let t=J2(),r=gD(["ROOTPATH"]);try{Nf=RD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!oo.pathExistsSync(bi.join(r.ROOTPATH,Kt.HDB_CONFIG_FILE)))throw n}if({level:Cr,config_log_path:Of,to_file:yi,to_stream:gs}=Z2(r.ROOTPATH?bi.join(r.ROOTPATH,Kt.HDB_CONFIG_FILE):Nf.get("settings_path")),cm=Kt.LOG_NAMES.HDB,lm=bi.join(Of,cm),k2)try{require("segfault-handler").registerHandler(bi.join(Of,"crash.log"))}catch{}}}catch(t){if(Nf=void 0,t.code===Kt.NODE_ERROR_CODES.ENOENT||t.code===Kt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=gD(Object.keys(Kt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Kt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Kt.CONFIG_PARAMS.LOGGING_LEVEL){Cr=l;continue}if(c===Kt.CONFIG_PARAMS.LOGGING_STDSTREAMS){gs=l;continue}c===Kt.CONFIG_PARAMS.LOGGING_FILE&&(yi=c),c===Kt.CONFIG_PARAMS.LOGGING_CONSOLE&&(XA=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=e4();yi=yi===void 0?s:yi,yi=TD(yi),gs=gs===void 0?i:gs,gs=TD(gs),Cr=Cr===void 0?n:Cr,Of=q2,cm=Kt.LOG_NAMES.INSTALL,lm=bi.join(Of,cm);return}throw um("Error initializing log settings"),um(t),t}process.env.DEV_MODE&&(gs=!0),Y2()}a(bD,"initLogSettings");var _a=!0;function Y2(){yi&&(process.stdout.write=function(e){return typeof e=="string"&&_a&&XA!==!1&&(eR(),e=e.toString(),e[e.length-1]===`
|
|
3
|
-
`&&(e=e.slice(0,-1)),
|
|
4
|
-
`&&(e=e.slice(0,-1)),
|
|
2
|
+
"use strict";var S2=Object.create;var yf=Object.defineProperty;var T2=Object.getOwnPropertyDescriptor;var A2=Object.getOwnPropertyNames;var R2=Object.getPrototypeOf,y2=Object.prototype.hasOwnProperty;var a=(e,t)=>yf(e,"name",{value:t,configurable:!0});var be=(e,t)=>()=>(e&&(t=e(e=0)),t);var w=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),ve=(e,t)=>{for(var r in t)yf(e,r,{get:t[r],enumerable:!0})},aD=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of A2(t))!y2.call(e,s)&&s!==r&&yf(e,s,{get:()=>t[s],enumerable:!(n=T2(t,s))||n.enumerable});return e};var M=(e,t,r)=>(r=e!=null?S2(R2(e)):{},aD(t||!e||!e.__esModule?yf(r,"default",{value:e,enumerable:!0}):r,e)),C=e=>aD(yf({},"__esModule",{value:!0}),e);var it=w((Fye,uD)=>{var{join:b2,dirname:cD}=require("node:path"),{existsSync:O2,readFileSync:N2}=require("node:fs");function w2(){let t=__dirname,r,n=0;for(;!O2(r=b2(t,"package.json"));)if(t===(t=cD(t))||n++>10)throw new Error("Could not find package root");return r}a(w2,"findPackageJson");var lD=w2(),I2=JSON.parse(N2(lD,"utf8")),C2=cD(lD);uD.exports={packageJson:I2,PACKAGE_ROOT:C2}});var nm=w((qye,dD)=>{if(__filename.endsWith("dev.js")){let e=require("fast-glob"),{tmpdir:t}=require("node:os"),{relative:r,join:n}=require("node:path"),{existsSync:s,statSync:i,readFileSync:o,writeFileSync:c}=require("node:fs"),{isMainThread:l}=require("node:worker_threads"),{spawnSync:u,spawn:f}=require("node:child_process");process.setSourceMapsEnabled(!0);let{PACKAGE_ROOT:d}=it(),p=["bin","components","dataLayer","resources","server","sqlTranslator","upgrade","utility","validation"],_="ts-build";if(l){let g=!1,R=!1;if((R=s(n(d,_)))?g=e.sync(p.map(E=>`${E}/**/*.ts`),{cwd:d}).some(E=>{let T=0,b=0;try{T=i(n(d,E)).mtimeMs-5e3,b=i(n(d,_,E.replace(/.ts$/,".js"))).mtimeMs}catch{}return T>b}):g=!0,g){console.log("Compiling TypeScript...");let E=u("npx",["tsc"],{cwd:d});if(E.stdout?.length&&console.log(E.stdout.toString()),E.stderr?.length&&console.log(E.stderr.toString()),R){let T=n(t(),"harperdb-tsc.pid"),b=!1;if(s(T))try{process.kill(+o(T,"utf8"),0),b=!0}catch{}if(!b){console.log("Starting background TypeScript compilation...");let v=f("npx",["tsc","--watch"],{detached:!0,cwd:d,stdio:"ignore"});c(T,v.pid.toString()),v.unref()}}}}let h=dD.constructor,S=h._findPath;h._findPath=function(g,R,E){if(g.startsWith(".")&&!E&&R.length===1&&R[0].startsWith(d)&&!R[0].includes("node_modules")){let T=r(d,R[0]),b;T.startsWith(_)?b=n(d,r(_,T)):b=n(d,_,T);let v=n(b,g),F=v+".js";if(s(F))return F;if(v.includes(".")&&s(v))return v}return S(g,R,E)}}});var G={};ve(G,{AUTH_AUDIT_STATUS:()=>Ys,AUTH_AUDIT_TYPES:()=>la,BOOT_PROPS_FILE_NAME:()=>eQ,BOOT_PROP_PARAMS:()=>pD,CLUSTERING_FLAG:()=>NQ,CLUSTERING_PROCESSES:()=>k2,CLUSTER_MESSAGE_TYPE_ENUM:()=>JA,CLUSTER_OPERATIONS:()=>mQ,CONFIG_PARAMS:()=>x,CONFIG_PARAM_MAP:()=>hD,DATABASES_DIR_NAME:()=>Nc,DATABASES_PARAM_CONFIG:()=>TQ,DEFAULT_DATABASE_NAME:()=>G2,ESCAPED_FORWARD_SLASH_REGEX:()=>Q2,FORWARD_SLASH_REGEX:()=>j2,FUNC_VAL:()=>LQ,GEO_CONVERSION_ENUM:()=>gQ,HDB_COMPONENT_CONFIG_FILE:()=>L2,HDB_CONFIG_FILE:()=>P2,HDB_DEFAULT_CONFIG_FILE:()=>D2,HDB_FILE_PERMISSIONS:()=>rQ,HDB_HOME_DIR_NAME:()=>Z2,HDB_PID_FILE:()=>F2,HDB_PROCESS_SERVICES:()=>H2,HDB_PROC_NAME:()=>M2,HDB_RESTART_SCRIPT:()=>v2,HDB_ROOT_DIR_NAME:()=>KA,HDB_SETTINGS_NAMES:()=>jA,HDB_SUPPORT_ADDRESS:()=>_D,INFO_TABLE_HASH_ATTRIBUTE:()=>cQ,INSERT_MAX_CHARACTER_SIZE:()=>oQ,INSTALL_PROMPTS:()=>iQ,ITC_EVENT_TYPES:()=>XA,JOB_STATUS_ENUM:()=>fQ,JOB_TYPE_ENUM:()=>AQ,JWT_ENUM:()=>Of,LAUNCH_SERVICE_SCRIPTS:()=>V2,LEGACY_CONFIG_PARAMS:()=>SQ,LEGACY_DATABASES_DIR_NAME:()=>om,LICENSE_FILE_NAME:()=>dQ,LICENSE_KEY_DIR_NAME:()=>zA,LICENSE_VALUES:()=>RQ,LOG_LEVELS:()=>$2,LOG_NAMES:()=>q2,MEM_SETTING_KEY:()=>X2,METADATA_PROPERTY:()=>OQ,NODE_ERROR_CODES:()=>bQ,OPERATIONS_ENUM:()=>Yt,PERMS_CRUD_ENUM:()=>PQ,PERMS_UPDATE_RELEASE_TIMESTAMP:()=>CQ,PRE_4_0_0_VERSION:()=>MQ,PROCESS_DESCRIPTORS:()=>B2,PROCESS_NAME_ENV_PROP:()=>sQ,RAM_ALLOCATION_ENUM:()=>yQ,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:()=>cm,REG_KEY_FILE_NAME:()=>uQ,RESTART_TIMEOUT_MS:()=>tQ,ROLE_TYPES_ENUM:()=>K2,S3_BUCKET_AUTH_KEYS:()=>pQ,SEARCH_NOT_FOUND_MESSAGE:()=>W2,SEARCH_WILDCARDS:()=>DQ,SERVICE_ACTIONS_ENUM:()=>EQ,SUPPORT_HELP_MSG:()=>Y2,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:()=>lQ,SYSTEM_SCHEMA_NAME:()=>bf,SYSTEM_TABLE_NAMES:()=>fu,THREAD_TYPES:()=>ZA,TIME_STAMP_NAMES:()=>IQ,TIME_STAMP_NAMES_ENUM:()=>wQ,TRANSACTIONS_DIR_NAME:()=>nQ,UNICODE_FORWARD_SLASH:()=>J2,UNICODE_PERIOD:()=>z2,UPGRADE_JSON_FIELD_NAMES_ENUM:()=>aQ,VALID_S3_FILE_TYPES:()=>_Q,VALID_SQL_OPS_ENUM:()=>hQ,VALUE_SEARCH_COMPARATORS:()=>am,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>QA});var sm,im,P2,D2,KA,L2,M2,v2,fD,VA,YA,WA,U2,x2,B2,H2,k2,F2,G2,q2,$2,V2,K2,_D,Y2,W2,z2,j2,J2,Q2,X2,bf,Z2,zA,eQ,tQ,rQ,Nc,om,nQ,sQ,pD,iQ,oQ,aQ,fu,cQ,lQ,uQ,dQ,fQ,Yt,_Q,pQ,hQ,mQ,EQ,gQ,jA,SQ,x,hD,TQ,AQ,JA,RQ,yQ,bQ,OQ,NQ,mD,ED,wQ,IQ,CQ,am,QA,PQ,DQ,LQ,cm,Of,XA,ZA,MQ,Ys,la,H=be(()=>{sm=require("node:path"),im=M(it()),P2="harperdb-config.yaml",D2="defaultConfig.yaml",KA="hdb",L2="config.yaml",M2="harperdb.js",v2="restartHdb.js",fD="HarperDB",VA="Custom Functions",YA="Clustering Hub",WA="Clustering Leaf",U2="Clustering Ingest Service",x2="Clustering Reply Service",B2={HDB:fD,CLUSTERING_HUB:YA,CLUSTERING_LEAF:WA,CLUSTERING_INGEST_SERVICE:U2,CLUSTERING_REPLY_SERVICE:x2,CUSTOM_FUNCTIONS:VA,RESTART_HDB:"Restart HDB",INSTALL:"Install",RUN:"Run",STOP:"Stop",UPGRADE:"Upgrade",REGISTER:"Register",JOB:"Job",CLUSTERING_UPGRADE_4_0_0:"Upgrade-4-0-0"},H2={harperdb:fD,"clustering hub":YA,"clustering leaf":WA,"custom functions":VA,custom_functions:VA,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},k2={CLUSTERING_HUB_PROC_DESCRIPTOR:YA,CLUSTERING_LEAF_PROC_DESCRIPTOR:WA},F2="hdb.pid",G2="data",q2={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},$2={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},V2={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:(0,sm.join)(im.PACKAGE_ROOT,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:(0,sm.join)(im.PACKAGE_ROOT,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:(0,sm.join)(im.PACKAGE_ROOT,"launchServiceScripts/launchUpdateNodes4-0-0.js")},K2={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},_D="support@harperdb.io",Y2=`For support, please submit a request at https://harperdbhelp.zendesk.com/hc/en-us/requests/new or contact ${_D}`,W2="None of the specified records were found.",z2="U+002E",j2=/\//g,J2="U+002F",Q2=/U\+002F/g,X2="--max-old-space-size=",bf="system",Z2=".harperdb",zA="keys",eQ="hdb_boot_properties.file",tQ=6e4,rQ=448,Nc="database",om="schema",nQ="transactions",sQ="PROCESS_NAME",pD={SETTINGS_PATH_KEY:"settings_path"},iQ={TC_AGREEMENT:"TC_AGREEMENT",CLUSTERING_USER:"CLUSTERING_USER",CLUSTERING_PASSWORD:"CLUSTERING_PASSWORD",HDB_ADMIN_USERNAME:"HDB_ADMIN_USERNAME",HDB_ADMIN_PASSWORD:"HDB_ADMIN_PASSWORD",OPERATIONSAPI_ROOT:"OPERATIONSAPI_ROOT",ROOTPATH:"ROOTPATH",CLUSTERING_NODENAME:"CLUSTERING_NODENAME",CLUSTERING_ENABLED:"CLUSTERING_ENABLED",HDB_CONFIG:"HDB_CONFIG",DEFAULTS_MODE:"DEFAULTS_MODE",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},oQ=250,aQ={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},fu={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"},cQ="info_id",lQ={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"},uQ="060493.ks",dQ=".license",fQ={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},Yt={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts",GET_KEY:"get_key"},_Q={CSV:".csv",JSON:".json"},pQ={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},hQ={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},mQ={[Yt.INSERT]:Yt.INSERT,[Yt.UPDATE]:Yt.UPDATE,[Yt.UPSERT]:Yt.UPSERT,[Yt.DELETE]:Yt.DELETE},EQ={DEV:"dev",RUN:"run",START:"start",INSTALL:"install",REGISTER:"register",STOP:"stop",RESTART:"restart",VERSION:"version",UPGRADE:"upgrade",HELP:"help",STATUS:"status",OPERATION:"operation",RENEWCERTS:"renew-certs",COPYDB:"copy-db"},gQ={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},jA={HDB_ROOT_KEY:"HDB_ROOT",SERVER_PORT_KEY:"SERVER_PORT",CERT_KEY:"CERTIFICATE",PRIVATE_KEY_KEY:"PRIVATE_KEY",HTTP_SECURE_ENABLED_KEY:"HTTPS_ON",CORS_ENABLED_KEY:"CORS_ON",CORS_WHITELIST_KEY:"CORS_WHITELIST",LOG_LEVEL_KEY:"LOG_LEVEL",LOGGER_KEY:"LOGGER",LOG_PATH_KEY:"LOG_PATH",LOG_ROTATE:"LOG_ROTATE",LOG_ROTATE_MAX_SIZE:"LOG_ROTATE_MAX_SIZE",LOG_ROTATE_RETAIN:"LOG_ROTATE_RETAIN",LOG_ROTATE_COMPRESS:"LOG_ROTATE_COMPRESS",LOG_ROTATE_DATE_FORMAT:"LOG_ROTATE_DATE_FORMAT",LOG_ROTATE_ROTATE_MODULE:"LOG_ROTATE_ROTATE_MODULE",LOG_ROTATE_WORKER_INTERVAL:"LOG_ROTATE_WORKER_INTERVAL",LOG_ROTATE_ROTATE_INTERVAL:"LOG_ROTATE_ROTATE_INTERVAL",LOG_ROTATE_TIMEZONE:"LOG_ROTATE_TIMEZONE",LOG_DAILY_ROTATE_KEY:"LOG_DAILY_ROTATE",LOG_MAX_DAILY_FILES_KEY:"LOG_MAX_DAILY_FILES",PROPS_ENV_KEY:"NODE_ENV",SETTINGS_PATH_KEY:"settings_path",CLUSTERING_PORT_KEY:"CLUSTERING_PORT",CLUSTERING_NODE_NAME_KEY:"NODE_NAME",CLUSTERING_ENABLED_KEY:"CLUSTERING",ALLOW_SELF_SIGNED_SSL_CERTS:"ALLOW_SELF_SIGNED_SSL_CERTS",MAX_HDB_PROCESSES:"MAX_HDB_PROCESSES",INSTALL_USER:"install_user",CLUSTERING_USER_KEY:"CLUSTERING_USER",MAX_CLUSTERING_PROCESSES:"MAX_CLUSTERING_PROCESSES",SERVER_TIMEOUT_KEY:"SERVER_TIMEOUT_MS",SERVER_KEEP_ALIVE_TIMEOUT_KEY:"SERVER_KEEP_ALIVE_TIMEOUT",SERVER_HEADERS_TIMEOUT_KEY:"SERVER_HEADERS_TIMEOUT",DISABLE_TRANSACTION_LOG_KEY:"DISABLE_TRANSACTION_LOG",OPERATION_TOKEN_TIMEOUT_KEY:"OPERATION_TOKEN_TIMEOUT",REFRESH_TOKEN_TIMEOUT_KEY:"REFRESH_TOKEN_TIMEOUT",CUSTOM_FUNCTIONS_ENABLED_KEY:"CUSTOM_FUNCTIONS",CUSTOM_FUNCTIONS_PORT_KEY:"CUSTOM_FUNCTIONS_PORT",CUSTOM_FUNCTIONS_DIRECTORY_KEY:"CUSTOM_FUNCTIONS_DIRECTORY",MAX_CUSTOM_FUNCTION_PROCESSES:"MAX_CUSTOM_FUNCTION_PROCESSES",LOG_TO_FILE:"LOG_TO_FILE",LOG_TO_STDSTREAMS:"LOG_TO_STDSTREAMS",RUN_IN_FOREGROUND:"RUN_IN_FOREGROUND",LOCAL_STUDIO_ON:"LOCAL_STUDIO_ON",STORAGE_WRITE_ASYNC:"STORAGE_WRITE_ASYNC"},SQ={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"},x={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",AUTHENTICATION_HASHFUNCTION:"authentication_hashFunction",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_CORSACCESSCONTROLALLOWHEADERS:"http_corsAccessControlAllowHeaders",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",HTTP_HTTP2:"http_http2",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_ROTATION_RETENTION:"logging_rotation_retention",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_NETWORK_HTTP2:"operationsApi_network_http2",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",REPLICATION_SHARD:"replication_shard",REPLICATION_COPYTABLESTOCATCHUP:"replication_copyTablesToCatchUp",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_BLOBPATHS:"storage_blobPaths",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",STORAGE_RECLAMATION_THRESHOLD:"storage_reclamation_threshold",STORAGE_RECLAMATION_INTERVAL:"storage_reclamation_interval",STORAGE_RECLAMATION_EVICTIONFACTOR:"storage_reclamation_evictionFactor",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},hD={settings_path:pD.SETTINGS_PATH_KEY,hdb_root_key:x.ROOTPATH,hdb_root:x.ROOTPATH,rootpath:x.ROOTPATH,server_port_key:x.OPERATIONSAPI_NETWORK_PORT,server_port:x.OPERATIONSAPI_NETWORK_PORT,cert_key:x.TLS_CERTIFICATE,certificate:x.TLS_CERTIFICATE,private_key_key:x.TLS_PRIVATEKEY,private_key:x.TLS_PRIVATEKEY,http_secure_enabled_key:x.OPERATIONSAPI_NETWORK_HTTPS,https_on:x.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:x.OPERATIONSAPI_NETWORK_CORS,cors_on:x.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:x.LOGGING_LEVEL,log_level:x.LOGGING_LEVEL,log_path_key:x.LOGGING_ROOT,log_path:x.LOGGING_ROOT,clustering_node_name_key:x.CLUSTERING_NODENAME,node_name:x.CLUSTERING_NODENAME,clustering_enabled_key:x.CLUSTERING_ENABLED,clustering:x.CLUSTERING_ENABLED,max_http_threads:x.THREADS_COUNT,max_hdb_processes:x.THREADS_COUNT,server_timeout_key:x.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:x.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:x.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:x.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:x.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:x.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:x.LOGGING_AUDITLOG,disable_transaction_log:x.LOGGING_AUDITLOG,operation_token_timeout_key:x.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:x.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:x.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:x.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:x.HTTP_PORT,custom_functions_port:x.HTTP_PORT,custom_functions_directory_key:x.COMPONENTSROOT,custom_functions_directory:x.COMPONENTSROOT,max_custom_function_processes:x.THREADS_COUNT,logging_console:x.LOGGING_CONSOLE,log_to_file:x.LOGGING_FILE,log_to_stdstreams:x.LOGGING_STDSTREAMS,local_studio_on:x.LOCALSTUDIO_ENABLED,clustering_port:x.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:x.CLUSTERING_USER,customfunctions_network_port:x.HTTP_PORT,customfunctions_tls_certificate:x.TLS_CERTIFICATE,customfunctions_network_cors:x.HTTP_CORS,customfunctions_network_corsaccesslist:x.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:x.HTTP_HEADERSTIMEOUT,customfunctions_network_https:x.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:x.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:x.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:x.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:x.HTTP_TIMEOUT,customfunctions_tls:x.TLS,http_threads:x.THREADS_COUNT,threads:x.THREADS_COUNT,threads_count:x.THREADS_COUNT,customfunctions_processes:x.THREADS_COUNT,customfunctions_root:x.COMPONENTSROOT,operationsapi_root:x.ROOTPATH};for(let e in x){let t=x[e];hD[t.toLowerCase()]=t}TQ={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},AQ={csv_file_load:"csv_file_load",csv_data_load:Yt.CSV_DATA_LOAD,csv_url_load:Yt.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},JA={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"},RQ={VERSION_DEFAULT:"2.2.0"},yQ={DEVELOPMENT:8192,DEFAULT:512},bQ={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},OQ=Symbol("metadata"),NQ="__clustering__",mD="__createdtime__",ED="__updatedtime__",wQ={CREATED_TIME:mD,UPDATED_TIME:ED},IQ=[mD,ED],CQ=15984864e5,am={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},QA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},PQ={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},DQ=["*","%"],LQ="func_val",cm={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},Of={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},XA={SHUTDOWN:"shutdown",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",SCHEMA:"schema",USER:"user",CLUSTER_STATUS_RESPONSE:"cluster_status_response",CLUSTER_STATUS_REQUEST:"cluster_status_request",METRICS:"metrics",GET_METRICS:"get_metrics",RESTART:"restart",START_JOB:"start_job",NATS_CONSUMER_UPDATE:"nats_consumer_update"},ZA={HTTP:"http"},MQ="3.x.x",Ys={SUCCESS:"success",FAILURE:"failure"},la={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var ua=w(($ye,TD)=>{"use strict";var gD=require("minimist");TD.exports=vQ;function vQ(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=SD(process.env),n=SD(gD(process.argv))):(r=process.env,n=gD(process.argv));let s={};for(let i=0,o=e.length;i<o;i++){let c=e[i];n[c]!==void 0?s[c]=n[c].toString().trim():r[c]!==void 0&&(s[c]=r[c].toString().trim())}return s}a(vQ,"assignCMDENVVariables");function SD(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(SD,"objKeysToLowerCase")});var Ti=w(Ws=>{"use strict";global.Resource=Ws.Resource=void 0;global.tables=Ws.tables={};global.databases=Ws.databases={};global.getUser=Ws.getUser=void 0;global.authenticateUser=Ws.authenticateUser=void 0;global.server=Ws.server={};global.contentTypes=Ws.contentTypes=null;global.threads=Ws.threads=[];global.logger={};Ws._assignPackageExport=(e,t)=>{global[e]=Ws[e]=t}});var z=w((UD,xD)=>{"use strict";var no=require("fs-extra"),{workerData:UQ,threadId:xQ,isMainThread:BQ}=require("worker_threads"),Ri=require("path"),bD=require("yaml"),OD=require("properties-reader"),Wt=(H(),C(G)),AD=ua(),HQ=require("os"),{PACKAGE_ROOT:nR}=it(),{_assignPackageExport:kQ}=Ti(),RD=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),Er={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},ND={STDOUT:"stdOut",STDERR:"stdErr"},FQ=Ri.join(nR,"logs"),GQ=Ri.join(nR,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),qQ=1e4,eR,Ai,ms,Pr,lm,Nf,um,da,wf;wf===void 0&&wD();Object.assign(UD,{notify:LD,fatal:MD,error:dm,warn:vD,info:CD,debug:DD,trace:PD,setLogLevel:JQ,log_level:Pr,loggerWithTag:KQ,suppressLogging:YQ,initLogSettings:wD,logCustomLevel:zQ,closeLogFile:sR,logsAtLevel:$Q,getLogFilePath:a(()=>um,"getLogFilePath"),OUTPUTS:ND,AuthAuditLog:ZQ});kQ("logger",xD.exports);var tR;function $Q(e){return Er[Pr]<=Er[e]}a($Q,"logsAtLevel");function wD(e=!1){try{if(wf===void 0||e){sR();let t=jQ(),r=AD(["ROOTPATH"]);try{wf=OD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!no.pathExistsSync(Ri.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:Pr,config_log_path:Nf,to_file:Ai,to_stream:ms}=QQ(r.ROOTPATH?Ri.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):wf.get("settings_path")),lm=Wt.LOG_NAMES.HDB,um=Ri.join(Nf,lm),BQ)try{require("segfault-handler").registerHandler(Ri.join(Nf,"crash.log"))}catch{}}}catch(t){if(wf=void 0,t.code===Wt.NODE_ERROR_CODES.ENOENT||t.code===Wt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=AD(Object.keys(Wt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Wt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Wt.CONFIG_PARAMS.LOGGING_LEVEL){Pr=l;continue}if(c===Wt.CONFIG_PARAMS.LOGGING_STDSTREAMS){ms=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(Ai=c),c===Wt.CONFIG_PARAMS.LOGGING_CONSOLE&&(eR=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=XQ();Ai=Ai===void 0?s:Ai,Ai=yD(Ai),ms=ms===void 0?i:ms,ms=yD(ms),Pr=Pr===void 0?n:Pr,Nf=FQ,lm=Wt.LOG_NAMES.INSTALL,um=Ri.join(Nf,lm);return}throw dm("Error initializing log settings"),dm(t),t}process.env.DEV_MODE&&(ms=!0),VQ()}a(wD,"initLogSettings");var fa=!0;function VQ(){Ai&&(process.stdout.write=function(e){return typeof e=="string"&&fa&&eR!==!1&&(rR(),e=e.toString(),e[e.length-1]===`
|
|
3
|
+
`&&(e=e.slice(0,-1)),no.appendFileSync(da,zs("stdout",[e]))),RD.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&fa&&eR!==!1&&(rR(),e[e.length-1]===`
|
|
4
|
+
`&&(e=e.slice(0,-1)),no.appendFileSync(da,zs("stderr",[e]))),RD.apply(process.stderr,arguments)})}a(VQ,"stdioLogging");function KQ(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(LD,"notify"),fatal:n(MD,"fatal"),error:n(dm,"error"),warn:n(vD,"warn"),info:n(CD,"info"),debug:n(DD,"debug"),trace:n(PD,"trace")};function n(s,i){return!t||Er[Pr]<=Er[i]?function(...o){return s(r,...o)}:null}}a(KQ,"loggerWithTag");function YQ(e){try{fa=!1,e()}finally{fa=!0}}a(YQ,"suppressLogging");var WQ=UQ?.name?.replace(/ /g,"-")||"main";function zs(e,t){let r=new Date(Date.now()).toISOString(),n="",s=t.length,i=s-1,o=[e],c=0,l;for(typeof t[0]=="object"&&(t[0]?.tagName?(o.push(t[0]?.tagName),c++):t[0]?.serviceName&&(l=t[0]?.serviceName,c++)),o.unshift(l||WQ+"/"+xQ);c<s;c++){let u=t[c];if(u instanceof Error&&u.stack)n+=u.stack,Object.keys(u).length>0&&(n+=`
|
|
5
5
|
`+JSON.stringify(u)),u.cause&&(t[c--]=u.cause,u&&(n+=`
|
|
6
6
|
Caused by:`));else if(typeof u=="object")try{n+=JSON.stringify(u)}catch{n+="Object ["+Object.keys(u)+"]"}else n+=u;c<i&&(n+=" ")}return`${r} [${o.join("] [")}]: ${n}
|
|
7
|
-
`}a(
|
|
8
|
-
`).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:n4.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(a4,"findPs")});var vt=w((Wye,xD)=>{"use strict";var c4="__dbis__",l4="__txns__",u4="__environment_name__",d4="__dbi_defintion__",f4={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"},_4=["__createdtime__","__updatedtime__"],p4="\uFFFF",UD={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},h4=Object.values(UD);xD.exports={AUDIT_STORE_NAME:l4,INTERNAL_DBIS_NAME:c4,DBI_DEFINITION_NAME:d4,SEARCH_TYPES:f4,TIMESTAMP_NAMES:_4,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:u4,TRANSACTIONS_DBI_NAMES_ENUM:UD,TRANSACTIONS_DBIS:h4,OVERFLOW_MARKER:p4}});var Bn=w((zye,KD)=>{"use strict";var BD=(H(),C(q)),HD=vt(),kD={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},FD=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),GD={500:FD("There was an error processing your request."),400:"Invalid request"},m4=GD[kD.INTERNAL_SERVER_ERROR],E4={OP_NOT_SUPPORTED_FOR_FS:a(e=>`${e} is not available for this instance because it uses the File System data store.`,"OP_NOT_SUPPORTED_FOR_FS"),MISSING_VALUE:a(e=>`${e} is missing.`,"MISSING_VALUE"),INVALID_VALUE:a(e=>`${e} is invalid.`,"INVALID_VALUE"),NOT_FOUND:a(e=>`${e} not found.`,"NOT_FOUND")},g4={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},S4={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),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:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},T4={BASE_PATH_REQUIRED:"base_path is required",DESTINATION_PATH_REQUIRED:"destination_path is required",ENV_NAME_REQUIRED:"env_name is required",INVALID_BASE_PATH:"invalid base_path",INVALID_DESTINATION_PATH:"invalid destination_path",INVALID_ENVIRONMENT:"invalid environment",ENV_REQUIRED:"env is required",DBI_NAME_REQUIRED:"dbi_name is required",DBI_DOES_NOT_EXIST:"dbi does not exist",HASH_ATTRIBUTE_REQUIRED:"hash_attribute is required",ID_REQUIRED:"id is required",IDS_REQUIRED:"ids is required",IDS_MUST_BE_ITERABLE:"ids must be iterable",FETCH_ATTRIBUTES_REQUIRED:"fetch_attributes is required",FETCH_ATTRIBUTES_MUST_BE_ARRAY:"fetch_attributes must be an array",ATTRIBUTE_REQUIRED:"attribute is required",SEARCH_VALUE_REQUIRED:"search_value is required",SEARCH_VALUE_TOO_LARGE:"search_value is too long",WRITE_ATTRIBUTES_REQUIRED:"write_attributes is required",WRITE_ATTRIBUTES_MUST_BE_ARRAY:"write_attributes must be an array",RECORDS_REQUIRED:"records is required",RECORDS_MUST_BE_ARRAY:"records must be an array",CANNOT_CREATE_INTERNAL_DBIS_NAME:`cannot create a dbi named ${HD.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${HD.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"},A4={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${BD.INSERT_MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),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 ${BD.INSERT_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"},qD={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"},R4={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:a(e=>`Operation '${e}' is restricted to 'super_user' roles`,"OP_IS_SU_ONLY"),OP_NOT_FOUND:a(e=>`Operation '${e}' not found`,"OP_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:a((e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,"UNKNOWN_OP_AUTH_ERROR"),USER_HAS_NO_PERMS:a(e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,"USER_HAS_NO_PERMS"),DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},y4={ATTR_PERM_MISSING:a((e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,"ATTR_PERM_MISSING"),ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:a((e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,"ATTR_PERM_NOT_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:a(e=>`Invalid attribute '${e}' in 'attribute_permissions'`,"INVALID_ATTRIBUTE_IN_PERMS"),INVALID_PERM_KEY:a(e=>`Invalid table permission key value '${e}'`,"INVALID_PERM_KEY"),INVALID_ATTR_PERM_KEY:a(e=>`Invalid attribute permission key value '${e}'`,"INVALID_ATTR_PERM_KEY"),INVALID_ROLE_JSON_KEYS:a(e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,"INVALID_ROLE_JSON_KEYS"),MISMATCHED_TABLE_ATTR_PERMS:a(e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,"MISMATCHED_TABLE_ATTR_PERMS"),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:a(e=>`A role with name '${e}' already exists`,"ROLE_ALREADY_EXISTS"),ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:a(e=>`Your role does not have permission to view database metadata for '${e}'`,"SCHEMA_PERM_ERROR"),SCHEMA_TABLE_PERM_ERROR:a((e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,"SCHEMA_TABLE_PERM_ERROR"),SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:a(e=>`Value for '${e}' permission must be a boolean`,"SU_CU_ROLE_BOOLEAN_ERROR"),STRUCTURE_USER_ROLE_TYPE_ERROR:a(e=>`Value for '${e}' permission must be a boolean or Array`,"STRUCTURE_USER_ROLE_TYPE_ERROR"),SU_CU_ROLE_NO_PERMS_ALLOWED:a(e=>`Roles with '${e}' set to true cannot have other permissions set.`,"SU_CU_ROLE_NO_PERMS_ALLOWED"),SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:a(e=>`Missing table ${e.toUpperCase()} permission`,"TABLE_PERM_MISSING"),TABLE_PERM_NOT_BOOLEAN:a(e=>`Table ${e.toUpperCase()} permission must be a boolean`,"TABLE_PERM_NOT_BOOLEAN")},b4={ATTR_NOT_FOUND:a((e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,"ATTR_NOT_FOUND"),ATTR_EXISTS_ERR:a((e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,"ATTR_EXISTS_ERR"),DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:a(e=>`Invalid table ${JSON.stringify(e)}`,"INVALID_TABLE_ERR"),SCHEMA_NOT_FOUND:a(e=>`database '${e}' does not exist`,"SCHEMA_NOT_FOUND"),SCHEMA_EXISTS_ERR:a(e=>`database '${e}' already exists`,"SCHEMA_EXISTS_ERR"),TABLE_EXISTS_ERR:a((e,t)=>`Table '${t}' already exists in '${e}'`,"TABLE_EXISTS_ERR"),SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:a((e,t)=>`Table '${e}.${t}' does not exist`,"TABLE_NOT_FOUND"),TABLE_REQUIRED_ERR:"table is required"},O4={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},N4={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},$D={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},VD={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},w4={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},I4={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},C4={...qD,...S4,...E4,...R4,...y4,...b4,...O4,...N4,...A4,...$D,...VD,...w4,...I4,...g4};KD.exports={CHECK_LOGS_WRAPPER:FD,HDB_ERROR_MSGS:C4,DEFAULT_ERROR_MSGS:GD,DEFAULT_ERROR_RESP:m4,HTTP_STATUS_CODES:kD,LMDB_ERRORS_ENUM:T4,AUTHENTICATION_ERROR_MSGS:qD,VALIDATION_ERROR_MSGS:$D,ITC_ERRORS:VD}});var pe=w((Qye,zD)=>{"use strict";var fu=Bn(),P4=z(),D4=(H(),C(q)),fm=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,YD),this.statusCode=n||fu.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(fu.DEFAULT_ERROR_MSGS[n]?fu.DEFAULT_ERROR_MSGS[n]:fu.DEFAULT_ERROR_MSGS[fu.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&P4[s](i)}},sR=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},iR=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function YD(e,t,r,n=D4.LOG_LEVELS.ERROR,s=null,i=!1){if(WD(e))return e;let o=new fm(e,t,r,n,s);return i&&delete o.stack,o}a(YD,"handleHDBError");function WD(e){return e.__proto__.constructor.name===fm.name}a(WD,"isHDBError");zD.exports={isHDBError:WD,handleHDBError:YD,ClientError:sR,ServerError:iR,hdb_errors:fu}});var gt=w((Xye,tL)=>{"use strict";var Lf=(H(),C(q)),L4=se(),fn=ae(),Mf=require("path"),M4=require("minimist"),jD=require("fs-extra"),QD=require("lodash");fn.initSync();var{CONFIG_PARAMS:pa,DATABASES_PARAM_CONFIG:If,SYSTEM_SCHEMA_NAME:_m}=Lf,Cf,Pf,Df;function JD(){if(Cf!==void 0)return Cf;if(fn.getHdbBasePath()!==void 0)return Cf=fn.get(pa.STORAGE_PATH)||Mf.join(fn.getHdbBasePath(),Lf.DATABASES_DIR_NAME),Cf}a(JD,"getBaseSchemaPath");function XD(){if(Pf!==void 0)return Pf;if(fn.getHdbBasePath()!==void 0)return Pf=eL(_m),Pf}a(XD,"getSystemSchemaPath");function ZD(){if(Df!==void 0)return Df;if(fn.getHdbBasePath()!==void 0)return Df=fn.get(Lf.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Mf.join(fn.getHdbBasePath(),Lf.TRANSACTIONS_DIR_NAME),Df}a(ZD,"getTransactionAuditStoreBasePath");function v4(e,t){let r=fn.get(pa.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Mf.join(ZD(),e.toString())}a(v4,"getTransactionAuditStorePath");function eL(e,t){e=e.toString(),t=t&&t.toString();let r=fn.get(Lf.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Mf.join(JD(),e)}a(eL,"getSchemaPath");function U4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,M4(process.argv));let n=r[pa.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!L4.isObject(n))throw o;i=n}for(let o of i){let c=o[_m];if(!c)continue;let l=fn.get(pa.DATABASES);l=l??{};let u=c?.tables?.[t]?.[If.PATH];if(u)return QD.set(l,[_m,If.TABLES,t,If.PATH],u),fn.setProperty(pa.DATABASES,l),u;let f=c?.[If.PATH];if(f)return QD.set(l,[_m,If.PATH],f),fn.setProperty(pa.DATABASES,l),f}}let s=r[pa.STORAGE_PATH.toUpperCase()];if(s){if(!jD.pathExistsSync(s))throw new Error(s+" does not exist");let i=Mf.join(s,e);return jD.mkdirsSync(i),fn.setProperty(pa.STORAGE_PATH,s),i}return XD()}a(U4,"initSystemSchemaPaths");function x4(){Cf=void 0,Pf=void 0,Df=void 0}a(x4,"resetPaths");tL.exports={getBaseSchemaPath:JD,getSystemSchemaPath:XD,getTransactionAuditStorePath:v4,getTransactionAuditStoreBasePath:ZD,getSchemaPath:eL,initSystemSchemaPaths:U4,resetPaths:x4}});var _n=w((rbe,oL)=>{"use strict";var B4=Bn().LMDB_ERRORS_ENUM,ebe=require("lmdb"),H4=vt(),tbe=require("buffer").Buffer,{OVERFLOW_MARKER:rL,MAX_SEARCH_KEY_LENGTH:pm}=H4,nL=["number","string","symbol","boolean","bigint"];function k4(e){if(e=e?.primaryStore||e,!e)throw new Error(B4.ENV_REQUIRED)}a(k4,"validateEnv");function F4(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(F4,"stringifyData");function G4(e){return e instanceof Date?e.valueOf():e}a(G4,"convertKeyValueToWrite");function q4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(nL.includes(typeof e))return e.length>pm?[e.slice(0,pm)+rL]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(nL.includes(typeof i))i.length>pm?r.push(i.slice(0,pm)+rL):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(q4,"getIndexedValues");var hm=0,sL=0;function iL(){sL=Date.now()-performance.now()}a(iL,"adjustStartTime");iL();var $4=6e4;setInterval(iL,$4).unref();function V4(){let e=performance.now()+sL;return e>hm?(hm=e,e):(hm+=488e-6,hm)}a(V4,"getNextMonotonicTime");oL.exports={validateEnv:k4,stringifyData:F4,convertKeyValueToWrite:G4,getNextMonotonicTime:V4,getIndexedValues:q4}});var vf=w((sbe,aL)=>{"use strict";var K4=(H(),C(q)).OPERATIONS_ENUM,oR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=K4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};aL.exports=oR});var Uf=w((abe,dL)=>{"use strict";var obe=vf(),mm=(H(),C(q)),aR=se(),cL=z(),Y4=require("uuid"),{handleHDBError:Em,hdb_errors:W4}=pe(),{HDB_ERROR_MSGS:gm,HTTP_STATUS_CODES:Sm}=W4;dL.exports=lL;function lL(e,t,r){for(let s=0;s<t.length;s++)uL(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];z4(i,r,e.operation)}}a(lL,"processRows");lL.validateAttribute=uL;function uL(e){if(Buffer.byteLength(String(e))>mm.INSERT_MAX_CHARACTER_SIZE)throw Em(new Error,gm.ATTR_NAME_LENGTH_ERR(e),Sm.BAD_REQUEST,void 0,void 0,!0);if(aR.isEmptyOrZeroLength(e)||aR.isEmpty(e.trim()))throw Em(new Error,gm.ATTR_NAME_NULLISH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(uL,"validateAttribute");function z4(e,t,r){if(!e.hasOwnProperty(t)||aR.isEmptyOrZeroLength(e[t])){if(r===mm.OPERATIONS_ENUM.INSERT||r===mm.OPERATIONS_ENUM.UPSERT){e[t]=Y4.v4();return}throw cL.error("Update transaction aborted due to record with no hash value:",e),Em(new Error,gm.RECORD_MISSING_HASH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>mm.INSERT_MAX_CHARACTER_SIZE)throw cL.error(e),Em(new Error,gm.HASH_VAL_LENGTH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(z4,"validateHash")});var fL,Hn,cR,_u=be(()=>{fL=require("events"),Hn=class extends fL.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new cR;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},cR=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});function SL(e){uR=e}function X4(){J4=setInterval(function(){for(let e of lR)if(e.stale){let t=e.getContext()?.url;mL.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},Q4).unref()}var dR,hL,mL,EL,gL,_L,lR,j4,xf,pL,uR,bc,Tm,Q4,J4,Am=be(()=>{dR=M(_n()),hL=M(pe()),mL=M(z()),EL=M(ae());H();gL=M(se()),_L=100,lR=new Set,j4=(0,gL.convertToMS)(EL.get(B.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(SL,"replicationConfirmation");bc=class e{static{a(this,"DatabaseTransaction")}#e;writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),lR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(lR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(xf&&!this.overloadChecked&&performance.now()-pL>j4)throw new hL.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,dR.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let _=d;_<this.validated;_++)this.writes[_]?.validate?.(this.timestamp);let p;for(let _=d;_<this.validated;_++){let h=this.writes[_];h&&(h.before||h.beforeIntermediate)&&(p=!0)}if(p)return(async()=>{try{for(let _=0;_<2;_++){let h;for(let S=d;S<this.validated;S++){let g=this.writes[S];if(!g)continue;let R=g[_===0?"before":"beforeIntermediate"];if(R){let E=R();h?h.push?h.push(E):h=[h,E]:h=E}}h&&await(h.push?Promise.all(h):h)}}catch(_){throw this.abort(),_}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let p=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||p}else l();else for(let p of this.writes)c(p)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<_L>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return xf||(xf=s,pL=performance.now(),xf.then(()=>{xf=null})),s.then(d=>{if(d){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let p=this.writes[0].store.rootStore.databaseName,_=this.writes[this.writes.length-1];uR&&_&&i.push(uR(p,_.store.getEntry(_.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+_L/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let f={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(p=>({txnTime:r,next:p}));f.next=d}return f}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}getContext(){return this.#e}setContext(t){this.#e=t}},Tm=class extends bc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,dR.getNextMonotonicTime)())}getReadTxn(){}},Q4=3e4;a(X4,"startMonitoringTxns");X4()});function Nt(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new bc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n.setContext(e),e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var TL,Oc=be(()=>{TL=M(Ri());Am();a(Nt,"transaction");(0,TL._assignPackageExport)("transaction",Nt);Nt.commit=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Nt.abort=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});function _R(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let d=u(l);for(let _=1;_<e.length;_++){let h=e[_],S=u(h);d=d.concat(S)}let p=new Set;return d.filter(_=>{let h=_.key??_;return p.has(h)?!1:(p.add(h),!0)})}else{let d=u(l),p=f(e.slice(1),!0,l.estimated_count);return p.length>0?o(d,p):d}function u(d){return d.conditions?_R(d.conditions,d.operator,r,n,s,i,o,c):mu(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function f(d,p,_){return d.map((h,S)=>{if(h.conditions){let E=h.operator==="or",A=f(h.conditions,!E,_);return E?(O,v)=>A.some(F=>F(O,v)):(O,v)=>A.every(F=>F(O,v))}let g=(h.attribute||h[0])===r.primaryKey,R=kf(h,r,i,c,g,_);return p&&S<d.length-1&&_&&(_=a3(r.primaryStore,h.estimated_count,_)),R}).filter(Boolean)}a(f,"mapConditionsToFilters")}function mu(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(c===void 0&&l!=="sort")throw new hn.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let E=o[0],A=Ni(n.attributes,E);if(A.relationship){if(o.length<2)throw new hn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let O=A.definition?.tableClass||A.elements?.definition?.tableClass,v=new Map,F=mu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,O,s,v);if(A.relationship.to){i[o[0]]=v;let G=!!Ni(O.attributes,A.relationship.to)?.elements;F=n3(F,A,O.primaryStore,G,v)}if(A.relationship.from){let G=a(Y=>(Y?.key!==void 0&&(Y=Y.key),mu({attribute:A.relationship.from,value:Y},t,r,n,s,v)),"searchEntry");A.elements?(i[o[0]]=v,F=s3(F,A,O.primaryStore,v,G)):F=F.flatMap(G)}return F}else if(o.length===1)o=o[0];else throw new hn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,f,d,p;c instanceof Date&&(c=c.getTime());let _;switch(pR[l]||l){case"lt":u=!0,f=c;break;case"le":u=!0,f=c,d=!0;break;case"gt":u=c,p=!0;break;case"ge":u=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],u=c,f=c.slice(0),f[f.length-1]=Oi.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),f=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),f=c[1],f instanceof Date&&(f=f.getTime()),d=l==="gele"||l==="gtle"||l==="between",p=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,f=c,d=!0;break;case"ne":if(c===null){u=c,p=!0;break}case"sort":case"contains":case"ends_with":u=!0,_=!0;break;default:throw new hn.ClientError(`Unknown query comparator "${l}"`)}let h,S=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>Ss.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Ss.MAX_SEARCH_KEY_LENGTH)+Ss.OVERFLOW_MARKER,p=!1,h=kf(e,n,null,i,S)),typeof f=="string"&&f.length>Ss.MAX_SEARCH_KEY_LENGTH&&(f=f.slice(0,Ss.MAX_SEARCH_KEY_LENGTH)+Ss.OVERFLOW_MARKER,d=!0,h=h??kf(e,n,null,i,S)),r){let E=u;u=f,f=E,E=!p,p=!d,d=E}let g=S?n.primaryStore:n.indices[o];if(!g||g.isIndexing||_||c===null&&!g.indexNulls){if(s===!1&&!g)throw new hn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&_)throw new hn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(g?.isIndexing)throw new hn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&g&&!g.indexNulls)throw new hn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??kf(e,n,null,i,S),!h)throw new hn.ClientError(`Unknown search operator ${e.comparator}`)}let R={start:u,end:f,inclusiveEnd:d,exclusiveStart:p,values:!0,versions:S,transaction:t,reverse:r};if(S){let E=g.getRange(R).map(h?function({key:A,value:O}){return this?.isSync?O&&h(O)?A:ha.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(O&&h(O)?A:ha.SKIP)}catch(G){F(G)}}))}:A=>A.value==null&&!(A.metadataFlags&(kn|Ea))?ha.SKIP:A);return E.hasEntries=!0,E}else return g?g.getRange(R).map(h?function({key:E,value:A}){let O;return typeof E=="string"&&E.length>Ss.MAX_SEARCH_KEY_LENGTH?O=n.primaryStore.get(A):O={[o]:E},this.isSync?h(O)?A:ha.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(h(O)?A:ha.SKIP)}catch(G){F(G)}}))}:({value:E})=>E):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:E,value:A}){return this.isSync?A&&h(A)?E:ha.SKIP:new Promise((O,v)=>setImmediate(()=>{try{O(A&&h(A)?E:ha.SKIP)}catch(F){v(F)}}))})}function Ni(e,t){if(Array.isArray(t))if(t.length>1){let r=Ni(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Ni(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function n3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=a((u,f)=>{let d=s.get(u);d?d.push(f):s.set(u,d=[f])},"add_entry");for(let u of e){let f=u.value??r.get(u.key??u),d=f?.[c];if(d!=null&&!s.filters?.some(p=>!p(f)))if(n)for(let p=0;p<d.length;p++)l(d[p],u);else l(d,u)}return i=s.keys()[Symbol.iterator](),this.next()}let o=i.next();return o.done?o:{value:o.value}},return(){if(i?.return)return i.return()}}}})}function s3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=f=>f[t.relationship.from]?.filter?.(d=>u.has(d));for(let f of e){if(n.filters){let d=r.get(f);if(n.filters.some(p=>!p(d)))continue}u.add(f)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(o=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function kf(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let f=c[0],d=Ni(t.attributes,f),p=d.definition?.tableClass||d.elements.definition?.tableClass,_=n?.[f],h=kf({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},p,r,_?.[f]?.joined,c[1]===p.primaryKey,i);if(!h)return;if(_){_.filters||(_.filters=[]),_.filters.push(h);return}let S=t.propertyResolvers?.[f],g,R=a((E,A)=>{let O,v;if(S){if(S.from&&h.idFilter){if(!g)if(h.idFilter.idSet?.size===1){for(let G of h.idFilter.idSet)e={attribute:S.from,value:G};g=u(S.from,h.idFilter,!0,!0)}else g=u(S.from,h.idFilter,!1,!0);let F=g(E);return g.idFilter&&(R.idFilter=g.idFilter),F}v=S(E,r,A),O=v?.value}else O=E[f];return O?Array.isArray(O)?O.some(h):h(O,v):!1},"recordFilter");return R}}switch(l instanceof Date&&(l=l.getTime()),pR[o]||o){case Ss.SEARCH_TYPES.EQUALS:case void 0:return u(c,f=>f===l,!0);case"contains":return u(c,f=>f?.toString().includes(l));case"ends_with":return u(c,f=>f?.toString().endsWith(l));case"starts_with":return u(c,f=>typeof f=="string"&&f.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,f=>{if(!Array.isArray(f))return!1;for(let d=0,p=l.length;d<p;d++)if(f[d]!==l[d])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,f=>(0,Oi.compareKeys)(f,l[0])>=0&&(0,Oi.compareKeys)(f,l[1])<=0,!0);case"gt":return u(c,f=>(0,Oi.compareKeys)(f,l)>0);case"ge":return u(c,f=>(0,Oi.compareKeys)(f,l)>=0);case"lt":return u(c,f=>(0,Oi.compareKeys)(f,l)<0);case"le":return u(c,f=>(0,Oi.compareKeys)(f,l)<=0);case"ne":return u(c,f=>(0,Oi.compareKeys)(f,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new hn.ClientError(`Unknown query comparator "${o}"`)}function u(f,d,p,_){let h;p=p&&!s&&t?.indices[f]&&i>3,p&&(e.estimated_count==null&&ym(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(p=!1));let S=0,g=3;function R(E){let A=E[f],O;if(typeof A!="object"||!A||_?O=d(A):Array.isArray(A)?O=A.some(d):A instanceof Date&&(O=d(A.getTime())),p&&(g++,!O&&!R.idFilter&&++S/g*(i-g)>h)){let v=mu(e,r.transaction.getReadTxn(),!1,t).map(Eu),F=new Set(v);R.idFilter=G=>F.has(Eu(G)),R.idFilter.idSet=F}return O}return a(R,"recordFilter"),s&&(R.idFilter=d),R}a(u,"attributeComparator")}function ym(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/ao(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=pR[n]||n,n===Ss.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=Ni(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=ym(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*ao(e.indices[i.relationship.from])/(ao(o.primaryStore)||1):c)}else{let i=e.indices[s];r.estimated_count=i?i.getValuesCount(r[1]??r.value):1/0}}else if(n==="contains"||n==="ends_with"||n==="ne"){let s=r[0]??r.attribute,i=e.indices[s];r.value===null&&n==="ne"?r.estimated_count=ao(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=t3*ao(e.primaryStore)+1:n==="between"?r.estimated_count=e3*ao(e.primaryStore)+1:n==="sort"?r.estimated_count=ao(e.primaryStore)+1:r.estimated_count=Z4*ao(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function bm(e){if(e)if(ma=e,pu.lastIndex=0,i3.test(e))try{let t=Bf(new hu,"");if(pn!==ma.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${pn} in '${ma}'`,t}else return new URLSearchParams(e)}function Bf(e,t){let r=pu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ma);){pn=r.lastIndex;let[,f,d]=n;if(o){if(f)throw new SyntaxError(`expected operator, but encountered '${f}'`);o=!1,c=!1}else c=!0;let p;switch(d){case"=":if(s!=null){if(f.length<=2)i=f;else throw new SyntaxError(`invalid FIQL operator ${f}`);l=AL}else{if(l=decodeURIComponent,i="equals",!f)throw new SyntaxError("attribute must be specified before equality comparator");s=Hf(f)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=r3[d],l=fR[i]?AL:decodeURIComponent,!f)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=Hf(f);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${d[0]?"'"+d[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${d?"'"+d+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s||null,value:l(f)};if(i==="eq"&&RL(h,f),s===""){let S=e.conditions[e.conditions.length-1];S.chainedConditions=S.chainedConditions||[],S.chainedConditions.push(h),S.operator=u}else Rm(e,u),e.conditions.push(h)}d==="&"?(u="and",s=void 0):d==="|"?(u="or",s=void 0):d==="&="?(u="and",s=""):d==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(Hf(f)),s=void 0;break;case"(":pu.lastIndex=pn;let _=Bf(f?[]:new hu,")");switch(f){case"":Rm(e,u),e.conditions.push(_);break;case"limit":switch(_.length){case 1:e.limit=+_[0];break;case 2:e.offset=+_[0],e.limit=_[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(_[0])&&_.length===1&&!_[0].name?(e.select=_[0],e.select.asArray=!0):_.length===1?e.select=_[0]:_.length===2&&_[1]===""?e.select=_.slice(0,1):e.select=_;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=yL(_);break;default:throw new SyntaxError(`unknown query function call ${f}`)}ma[pn]===","?r.lastIndex=++pn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!f)throw new SyntaxError("property sets must have a defined parent property name");pu.lastIndex=pn,p=Bf([],"}"),p.name=f,e.push(p),ma[pn]===","?r.lastIndex=++pn:o=!0;break;case"[":pu.lastIndex=pn,f?(p=Bf(new hu,"]"),p.name=f):p=Bf(e.conditions?new hu:[],"]"),e.conditions?(Rm(e,u),e.conditions.push(p),s=null):e.push(p),ma[pn]===","?r.lastIndex=++pn:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(f)};i==="eq"&&RL(h,f),Rm(e,u),e.conditions.push(h)}else if(f)throw new SyntaxError("no attribute or comparison specified")}else(f||e.length>0&&c)&&e.push(Hf(f));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${d[0]}'`):new SyntaxError(`unexpected token '${d[0]}'`);default:throw new SyntaxError(`unexpected operator '${d}'`)}if(t!==")"&&(r=s?o3:pu,r.lastIndex=pn),pn===ma.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function Rm(e,t){if(e.conditions.length>0)if(e.operator){if(e.operator!==t)throw new SyntaxError("Can not mix operators within a condition grouping")}else e.operator=t}function Hf(e){return e.indexOf(".")>-1?e.split(".").map(Hf):decodeURIComponent(e)}function AL(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new hn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function RL(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new hn.ClientError("wildcard can only be used at the end of a string")}function yL(e){let t=bL(e[0]);return e.length>1&&(t.next=yL(e.slice(1))),t}function bL(e){if(Array.isArray(e)){let t=bL(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}throw new SyntaxError(`Unknown sort type ${e}`)}function Eu(e){return Array.isArray(e)?e.join("\0"):e}function ao(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function a3(e,t,r){return t*r/ao(e)}var hn,Ss,Oi,ha,Z4,e3,t3,r3,fR,pR,i3,pu,o3,pn,ma,hu,Nc,Ff=be(()=>{hn=M(pe()),Ss=M(vt()),Oi=require("ordered-binary"),ha=require("lmdb");Gf();Z4=.3,e3=.1,t3=.05,r3={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},fR={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(_R,"executeConditions");a(mu,"searchByIndex");a(Ni,"findAttribute");a(n3,"joinTo");a(s3,"joinFrom");pR={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};a(kf,"filterByType");a(ym,"estimateCondition");i3=/[()[\]|!<>.]|(=\w*=)/,pu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,o3=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(bm,"parseQuery");a(Bf,"parseBlock");a(Rm,"assignOperator");a(Hf,"decodeProperty");a(AL,"typedDecoding");a(RL,"wildcardDecoding");a(yL,"toSortObject");a(bL,"toSortEntry");hu=class{static{a(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}};a(Eu,"flattenKey");a(ao,"estimatedEntryCount");a(a3,"intersectionEstimate");Nc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var mR={};ve(mR,{MultiPartId:()=>Nm,Resource:()=>$r,snake_case:()=>l3,transformForSelect:()=>wm});function l3(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function OL(e,t){if(wc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(wc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new Nm;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){wc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return wc=!0,null;e[e.length-1]==="/"&&(wc=!0)}return t.coerceId(decodeURIComponent(e))}function Fn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,f;if(r?(o?(f=i,o=o.getContext?.()||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(f=s,c=f[this.primaryKey]??null,o=i.getContext?.()||i):f=i:(f=s,s=void 0,c=f.getId?.()??f[this.primaryKey]),c===null&&(u=!0)):i?o=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string")if(this.directURLMapping)c=c.slice(1);else{let _=c.indexOf("?");if(_>-1){let S=this.parseQuery(c.slice(_+1));l?S&&(l=Object.assign(S,l)):l=S,c=c.slice(0,_)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let _ of s){if(typeof _=="object"&&_)break;c.push(_)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Nc(c),c==null&&(u=!0);o||(o={});let d;if(l?.ensureLoaded!=null||l?.async||u?(d={...t},l?.ensureLoaded!=null&&(d.ensureLoaded=l.ensureLoaded),l?.async&&(d.async=l.async),u&&(d.isCollection=!0)):d=t,o.transaction){let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)}else return Nt(o,()=>{let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)},d);function p(_){if(o.authorize){o.authorize=!1;let h=t.type==="read"?_.allowRead(o.user,l,o):t.type==="update"?_.doesExist?.()===!1?_.allowCreate(o.user,f,o):_.allowUpdate(o.user,f,o):t.type==="create"?_.allowCreate(o.user,f,o):_.allowDelete(o.user,l,o);if(h?.then)return h.then(S=>{if(!S)throw new Om(o.user);return typeof f?.then=="function"?f.then(g=>e(_,l,o,g)):e(_,l,o,f)});if(!h)throw new Om(o.user)}return typeof f?.then=="function"?f.then(h=>e(_,l,o,h)):e(_,l,o,f)}a(p,"authorizeActionOnResource")}}function Gn(e,t){let r=new IL.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function hR(e,t,r){let n=e.getRecord?.();if(n){let s=e.getChanges?.();return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function wm(e,t){let r=t.propertyResolvers,n=t.getContext?.(),s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):hR(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],f=i(hR(l,r,n));for(let d of e)u.push(f(d));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(p=>p&&typeof p=="object"?c(p):p);let u={},f=i(hR(l,r,n)),d;for(let p of e){let _=f(p);_===void 0&&o&&(_=null),_?.then?(d||(d=[]),d.push(_.then(h=>u[p.name||p]=h))):u[p.name||p]=_}return d?Promise.all(d).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let f=r[c.name]?.definition?.tableClass;l=s[c.name]=wm(c.select||c,f)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var NL,wL,IL,c3,$r,Om,wc,Nm,ga=be(()=>{NL=require("crypto");_u();wL=M(Ri()),IL=M(pe());Oc();Ff();c3={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},$r=class{static{a(this,"Resource")}#e;#t;#n;static transactions;static directURLMapping=!1;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=Fn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=wm(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=Fn(function(t,r,n,s){if(Array.isArray(s)&&t.#n){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(f=>f.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):Gn(t,"put")},{hasContent:!0,type:"update"});static patch=Fn(function(t,r,n,s){return t.patch?t.patch(s,r):Gn(t,"patch")},{hasContent:!0,type:"update"});static delete=Fn(function(t,r,n,s){return t.delete?t.delete(r):Gn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,NL.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),Nt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):Gn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=Fn(function(t,r,n,s){return t.invalidate?t.invalidate(r):Gn(t,"delete")},{hasContent:!1,type:"update"});static post=Fn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Fn(function(t,r,n,s){return t.connect?t.connect(s,r):Gn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Fn(function(t,r,n,s){return t.subscribe?t.subscribe(r):Gn(t,"subscribe")},{type:"read"});static publish=Fn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.publish(s,r):Gn(t,"publish")},{hasContent:!0,type:"create"});static search=Fn(function(t,r,n,s){let i=t.search?t.search(r):Gn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=wm(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Fn(function(t,r,n,s){return t.search?t.search(s,r):Gn(t,"search")},{hasContent:!0,type:"read"});static copy=Fn(function(t,r,n,s){return t.copy?t.copy(s,r):Gn(t,"copy")},{hasContent:!0,type:"create"});static move=Fn(function(t,r,n,s){return t.move?t.move(s,r):Gn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#n)return(await this.constructor.create(this.#e,t,this.#t)).#e;Gn(this,"post")}static isCollection(t){return t&&t.#n}get isCollection(){return this.#n}static coerceId(t){return t}static parseQuery(t){return bm(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1),c=r?.headers&&c3[o];if(c)r.requestedContentType=c,t=t.slice(0,s);else if(this.attributes?.find(l=>l.name===o))if(t=t.slice(0,s),n)n.property=o;else return{query:{property:o},id:OL(t,this),isCollection:wc}}let i=OL(t,this);return wc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(f=>f.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let f of l){let d=f.#e,p=u.get(d);p?p.push(f):u.set(d,[f])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s.#n=!0),s}subscribe(t){return new Hn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Hn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,wL._assignPackageExport)("Resource",$r);a(l3,"snake_case");Om=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(OL,"pathToId");Nm=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(Fn,"transactional");a(Gn,"missingMethod");a(hR,"selectFromObject");a(wm,"transformForSelect")});var Sa,ER=be(()=>{Sa=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var DL={};ve(DL,{Resources:()=>Im,keyArrayToString:()=>gu,resetResources:()=>u3,resources:()=>wi});function u3(){return wi=new Im}function gu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var CL,PL,Im,wi,Su=be(()=>{Oc();ER();CL=M(z()),PL=M(pe()),Im=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new PL.ServerError(`Conflicting paths for ${t}`);CL.default.error(c),i.Resource=new Sa(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let f=this.get(c.slice(0,u));f&&(f.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,o=t.length;for(;n<o;){s=n,n=t.indexOf("/",n),n===-1&&(n=o);let u=n===o?t:t.slice(0,n),f=this.get(u),d=-1;if(!f&&n===o&&(d=u.indexOf("?",s),d!==-1)){let p=u.slice(0,d);f=this.get(p)}if(f&&(!r||f.exportTypes?.[r]!==!1)){if(f.relativeURL=t.slice(d!==-1?d:n),!f.hasSubPaths)return f;i=f}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Nt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(u3,"resetResources");a(gu,"keyArrayToString")});var Tu={};ve(Tu,{server:()=>Ye});var LL,Ye,Vr=be(()=>{LL=M(Ri()),Ye={};(0,LL._assignPackageExport)("server",Ye)});var TR={};ve(TR,{loadGQLSchema:()=>_3,start:()=>SR,startOnMainThread:()=>f3});function SR({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:f}=await import("graphql"),d=o(new c(r.toString(),s)),p=new Map,_=[],h;for(let R of d.definitions)switch(R.kind){case l.OBJECT_TYPE_DEFINITION:let F=function(Y){if(Y.kind==="NonNullType"){let X=F(Y.type);return X.nullable=!1,X}if(Y.kind==="ListType")return{type:"array",elements:F(Y.type)};let ie={type:Y.name?.value};return Object.defineProperty(ie,"location",{value:Y.loc.startToken}),ie};a(F,"getProperty");let E=R.name.value,A=[],O={table:null,database:null,properties:A};p.set(E,O);for(let Y of R.directives){if(Y.name.value==="table"){for(let ie of Y.arguments)O[ie.name.value]=ie.value.value;O.schema&&(O.database=O.schema),O.table||(O.table=E),O.audit&&(O.audit=O.audit!=="false"),O.attributes=O.properties,_.push(O)}if(Y.name.value==="sealed"&&(O.sealed=!0),Y.name.value==="splitSegments"&&(O.splitSegments=!0),Y.name.value==="replicate"&&(O.replicate=!0),Y.name.value==="export"){O.export=!0;for(let ie of Y.arguments)typeof O.export!="object"&&(O.export={}),O.export[ie.name.value]=ie.value.value}}let v=!1,G={};for(let Y of R.fields){let te=F(Y.type);te.name=Y.name.value,A.push(te),G[te.name]=void 0;for(let ie of Y.directives){let X=ie.name.value;if(X==="primaryKey")v?console.warn("Can not define two attributes as a primary key at",ie.loc):(te.isPrimaryKey=!0,v=!0);else if(X==="indexed")te.indexed=!0;else if(X==="computed"){for(let ne of ie.arguments||[])if(ne.name.value==="from"){let Q=ne.value.value;te.computed={from:g(Q,ne,G)},te.version==null&&(te.version=Q)}else ne.name.value==="version"&&(te.version=ne.value.value);te.computed=te.computed||!0}else if(X==="relationship"){let ne={};for(let Q of ie.arguments)ne[Q.name.value]=Q.value.value;te.relationship=ne}else if(X==="createdTime")te.assignCreatedTime=!0;else if(X==="updatedTime")te.assignUpdatedTime=!0;else if(X==="expiresAt")te.expiresAt=!0;else if(X==="allow"){let ne=te.authorizedRoles=[];for(let Q of ie.arguments)Q.name.value==="role"&&ne.push(Q.value.value)}else server.knownGraphQLDirectives.includes(X)&&console.warn(`@${X} is an unknown directive, at`,ie.loc)}}O.type=E,E==="Query"&&(h=O)}function S(R){let E=p.get(R.type);E?(Object.defineProperty(R,"properties",{value:E.properties}),Object.defineProperty(R,"definition",{value:E})):R.type==="array"?S(R.elements):d3.includes(R.type)||(0,vL.getWorkerIndex)()===0&&console.error(`The type ${R.type} is unknown at line ${R.location.line}, column ${R.location.column}, in ${s}`)}a(S,"connectPropertyType");for(let R of p.values())for(let E of R.properties)S(E);for(let R of _)R.tableClass=e(R),R.export&&(R.export.name===""?i.set((0,gR.dirname)(n),R.tableClass):i.set((0,gR.dirname)(n)+"/"+(R.export.name||R.type),R.tableClass,R.export));function g(R,E,A){return new ML.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${R}; } } } } computed;`,{filename:s,lineOffset:E.loc.startToken.line-1,columnOffset:E.loc.startToken.column}).runInThisContext()(A)}a(g,"createComputedFrom")}}var gR,ML,vL,d3,f3,_3,UL=be(()=>{gR=require("path"),ML=require("node:vm");Pe();vL=M(et()),d3=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt","Blob"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(SR,"start");f3=SR,_3=SR({ensureTable:dt}).handleFile});var qL={};ve(qL,{parse:()=>RR,streamAsJSON:()=>qf,stringify:()=>Ic});function qf(e){return new AR({value:e})}function xL(e){return console.error(e),JSON.stringify(e.toString())}function BL(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Ic(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===FL)return GL(e);if(t.resolution)return t.resolution.then(()=>Ic(e));throw t}}function GL(e){let t=typeof e;if(t==="object"){if(e===null)return"null";e.toJSON&&(e=e.toJSON());let r;if(Array.isArray(e)){r="[";for(let n=0;n<e.length;n++)n>0&&(r+=","),r+=GL(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Ic(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function RR(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),m3.test(e)?p3.parse(e):JSON.parse(e)):null}var HL,kL,p3,h3,FL,AR,m3,yR=be(()=>{HL=require("stream"),kL=M(require("json-bigint-fixes")),p3=(0,kL.default)({useNativeBigInt:!0}),h3=1e4,FL={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw FL};a(qf,"streamAsJSON");AR=class extends HL.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),xL)}catch(s){yield xL(s)}else yield Ic(t)}else yield Ic(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);BL(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>h3?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return BL(this.readIterator(t.childIterator),n=>{if(n)return t.childIterator=null,this.readIterator(t)});do{let n=t.next();if(n.done)return!0;if(r=n.value,r==null)r="null";else{if(r.then)return this.flush(),Promise.resolve(r).then(s=>{if(s&&typeof s.return=="function")return t.childIterator=s,this.readIterator(t);if(this.push(s+""))return this.readIterator(t)});if(typeof r.return=="function")return t.childIterator=r,this.readIterator(t)}}while(this.push(r))}catch(r){return console.error(r),this.push(r.toString()),this.push(null),!0}}_destroy(t,r){for(let n of this.activeIterators)t?n.throw(t):n.return();r()}};a(xL,"handleError");a(BL,"when");a(Ic,"stringify");a(GL,"jsStringify");m3=/[[,:]\s*-?\d{16,}/;a(RR,"parse")});var Ii=w(Pm=>{var Cm=z();for(let e of["trace","debug","info","warn","error","fatal","notify"])Cm.logsAtLevel(e)&&(Pm[e]=Cm[e]);Pm.loggerWithTag=e=>Cm.loggerWithTag(e,!0);Pm.setLogLevel=Cm.setLogLevel});var Fm={};ve(Fm,{Blob:()=>Ci,blobsWereEncoded:()=>Pc,databasePaths:()=>Mm,decodeBlobsWithWrites:()=>wR,decodeFromDatabase:()=>Dc,decodeWithBlobCallback:()=>IR,deleteBlob:()=>JL,deleteBlobsInObject:()=>Aa,deleteRootBlobPathsForDB:()=>NR,encodeBlobsAsBuffers:()=>N3,encodeBlobsWithFilePath:()=>km,findBlobsInObject:()=>Yf,getFileId:()=>Bm,getFilePathForBlob:()=>ZL,getRootBlobPathsForDB:()=>Hm,setDeletionDelay:()=>T3});function jL(){}function JL(e){let t=ZL(e);t&&setTimeout(()=>{(0,je.unlink)(t,r=>{r&&Ta.default.debug?.("Error trying to remove blob file",r)})},QL)}function T3(e){QL=e}function XL(e){let t=mn.get(e);if(!t)t={storageIndex:0,fileId:null,store:Qs},mn.set(e,t);else{if(t.saving)return t;t.store=Qs}return R3(t),t.source?bR(e,t.source,t):t.contentBuffer?A3(e,t):bR(e,Vf.Readable.from(e.stream()),t),t}function bR(e,t,r){let{filePath:n,fileId:s,store:i,compress:o,flush:c}=r;return r.saving=new Promise((l,u)=>{let f=s+":blob";if(!i.attemptLock(f,0))throw new Error(`Unable to get lock for blob file ${s}`);let d=(0,je.createWriteStream)(n,{autoClose:!1,flags:"w"});if(t.errored){let g=Buffer.from(t.errored.toString());d.end(Buffer.concat([h(BigInt(g.length)+0xff000000000000n),g]));return}let p=!1;e.size!==void 0&&(d.write(h(e.size)),p=!0);let _;o?(p||d.write(g3),_=(0,Um.createDeflate)(),t.pipe(_).pipe(d)):(p||d.write(E3),t.pipe(d)),t.on("error",S);function h(g){let R=BigInt(g),E=new Uint8Array(Er),A=new DataView(E.buffer);return R|=BigInt(o?OR:zL)<<48n,A.setBigInt64(0,R),E}a(h,"createHeader");function S(g){i.unlock(f,0);let R=d.fd;g?(R&&(0,je.close)(R),u(g)):c?(0,je.fdatasync)(R,E=>{E&&u(E),l(),(0,je.close)(R)}):(l(),(0,je.close)(R))}a(S,"finished"),d.on("error",S).on("finish",()=>{if(p)S();else{let g=_?_.bytesWritten:d.bytesWritten-Er;e.size=g,(0,je.write)(d.fd,h(g),0,Er,0,S)}})}),e}function Bm(e){return mn.get(e)?.fileId}function ZL(e){let t=mn.get(e);return t?.fileId&&Kf(t)}function Hm(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=Mm.get(e);if(!t){if(!e.databaseName)throw new Error("No database name specified, can not determine blob storage path");let r=(0,xm.get)(B.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,lo.join)(n,e.databaseName)):t=[(0,lo.join)((0,xm.getHdbBasePath)(),"blobs",e.databaseName)],Mm.set(e,t)}return t}async function NR(e){let t=Mm.get(e);t&&await Promise.all(t.map(r=>eM(r)))}async function eM(e){for(let t of await(0,Js.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await eM((0,lo.join)(e,t.name));else try{await(0,Js.unlink)((0,lo.join)(e,t.name))}catch(r){Ta.default.warn?.("Error deleting file",r)}try{await(0,Js.rmdir)(e)}catch(t){Ta.default.warn?.("Error deleting directory",t)}}function Kf({storageIndex:e,fileId:t,store:r}){let n=Hm(r);return(0,lo.join)(n[e],t.slice(-9,-6)||"0",t.slice(-6,-3)||"0",t.length<=9?t.slice(-3):t.slice(0,-9)+t.slice(-3))}function A3(e,t){let r=t.contentBuffer,n=r.length;if(!(n<WL))return e.size=n,bR(e,Vf.Readable.from([r]),t)}function R3(e){let t=Hm(e.store),r=y3(),n=t?.length>1?b3(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=Kf(e),o=(0,lo.dirname)(i);(0,je.existsSync)(o)||(0,YL.ensureDirSync)(o),e.filePath=i}function y3(){let e=KL.get(Qs);if(!e){let t=0,r=Hm(Qs);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let o=0;if((0,je.existsSync)(n))for(let c of(0,je.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>o&&(o=l)}s+=o,n=(0,lo.join)(n,o.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(Qs.getUserSharedBuffer("blob-file-id",e.buffer)),KL.set(Qs,e)}return Number(Atomics.add(e,0,1n))}function b3(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(vm);for(let i=0;i<s.length;i++)s[i]=i%e.length;e.frequencyTable=s}return(e.lastUpdated??0)+6e4<r&&(e.lastUpdated=r,O3(e)),e.frequencyTable[t%vm]}async function O3(e){if(!Js.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let o=await(0,Js.statfs)(s),c=o.bavail*o.bsize;return Math.pow(c,.8)})),r=new Array(vm),n=t.map(s=>1/s);for(let s=0;s<vm;s++){let i=1/0,o=0;for(let c=0;c<n.length;c++)n[c]<i&&(o=c,i=n[c]);n[o]+=1/t[o],r[s]=o}e.frequencyTable=r}function km(e,t,r){Au=t,Qs=r,Pc=!1;try{return e()}finally{Au=void 0,Qs=void 0}}function N3(e){Pr=[];let t;try{t=e()}catch(n){throw Pr=void 0,n}let r=Pr.length<2?Pr[0]:Promise.all(Pr);return Pr=void 0,r?r.then(()=>e()):t}function wR(e,t){try{Pr=[],Cc=t,e()}catch(n){throw Cc=void 0,Pr=void 0,n}Cc=void 0;let r=Pr.length<2?Pr[0]:Promise.all(Pr);return Pr=void 0,r}function IR(e,t){try{return Cc=t,e()}finally{Cc=void 0}}function Dc(e,t){return Qs=t,e()}function Aa(e){Yf(e,t=>{JL(t)})}function Yf(e,t){if(e instanceof Ci)t(e);else if(e.constructor===Object||Array.isArray(e))for(let r in e)typeof e[r]=="object"&&Yf(e[r],t)}function w3(){return class{static{a(this,"Blob")}content;constructor(t){this.content=t[0]}stream(){return new ReadableStream({start(t){t.enqueue(this.content),t.close()}})}text(){return Promise.resolve(this.content.toString())}arrayBuffer(){return Promise.resolve(this.content.buffer)}get size(){return this.content.length}slice(){throw new Error("Not implemented")}bytes(){return Promise.resolve(this.content)}get type(){return""}}}var co,Js,je,Um,Vf,YL,xm,lo,Ta,WL,Er,zL,OR,$L,E3,g3,VL,mn,Cc,Ci,Au,Pr,Qs,Pc,$f,Dm,S3,Lm,QL,Mm,KL,vm,Ts=be(()=>{co=require("msgpackr"),Js=require("node:fs/promises"),je=require("node:fs"),Um=require("node:zlib"),Vf=require("node:stream"),YL=require("fs-extra"),xm=M(ae());H();lo=require("path"),Ta=M(Ii());uo();WL=8192,Er=8,zL=0,OR=1,$L=255,E3=new Uint8Array([0,zL,255,255,255,255,255,255]),g3=new Uint8Array([0,OR,255,255,255,255,255,255]),VL=0xffffffffffff,mn=new WeakMap,Ci=global.Blob||w3(),Pc=!1,$f=new Uint8Array(8),Dm=new DataView($f.buffer),S3=6e4;a(jL,"InstanceOfBlobWithNoConstructor");jL.prototype=Ci.prototype;Lm=class e extends jL{static{a(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=mn.get(this),{start:r,end:n,contentBuffer:s,asString:i}=t;return i||(s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?(t.asString=s.toString(),t.asString):(PR()&&CR(this.bytes().then(o=>t.contentBuffer=o)),`[blob: ${this.type}, ${this.size} bytes]`))}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=mn.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=Kf(t),o,c=a(async()=>{let l,u=Er;try{if(l=await(0,Js.readFile)(i),l.length>=Er){l.copy($f,0,0,Er);let d=Dm.getBigUint64(0);if(Number(d>>48n)===$L)throw new Error("Error in blob: "+buffer.subarray(Er));if(u=Number(d&0xffffffffffffn),u<n&&(u=n),u<VL&&(this.size=u,this.#t))for(let p of this.#t)p(u)}}catch(d){if(d.code!=="ENOENT")throw d;l=Buffer.alloc(0)}function f(d){if(u>d.length){let p=t.store,_=t.fileId+":blob";if(o)throw new Error("Incomplete blob");return new Promise((h,S)=>{if(p.attemptLock(_,0,()=>(o=!0,p.unlock(_,0),h(c()))))return o=!0,p.unlock(_,0),h(c())})}return(n!=null||r!=null)&&(d=d.subarray(r??0,n??d.length)),d}return a(f,"checkCompletion"),l[1]===OR?new Promise((d,p)=>{(0,Um.deflate)(l.subarray(Er),(_,h)=>{_?p(_):d(f(h))})}):f(l.subarray(Er))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=mn.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(h){h.enqueue(r),h.close()}});let i=Kf(t),o,c=0,l=0,u,f,d,p=this;return new ReadableStream({start(){let h=1e3,S=a((g,R)=>{(0,je.open)(i,"r",(E,A)=>{if(E){if(E.code==="ENOENT"&&d!==!1&&(Ta.default.debug?.("File does not exist yet, waiting for it to be created",i,h),h-- >0))return setTimeout(()=>{_(),S(g,R)},20).unref();R(E),p.#e?.forEach(O=>O(E))}else o=A,g(A)})},"openFile");return new Promise(S)},pull:a(h=>{let S=0,g=100;return new Promise(a(function R(E,A){function O(F){(0,je.close)(o),u&&u.close(),A(F),p.#e?.forEach(G=>G(F))}a(O,"onError");let v=Buffer.allocUnsafe(262144);(0,je.read)(o,v,0,v.length,c,(F,G,Y)=>{if(l+=G,F)return O(F);if(c===0){if(G<Er){g-- >0&&d!==!1?(_(),Ta.default.debug?.("File was empty, waiting for data to be written",i,g),setTimeout(()=>R(E,A),20).unref()):(Ta.default.debug?.("File was empty, throwing error",i,g),A(new Error(`Blob ${t.fileId} was empty`)));return}Y.copy($f,0,0,Er);let te=Dm.getBigUint64(0);if(Number(te>>48n)===$L)return O(new Error("Error in blob: "+Y.subarray(Er)));if(S=Number(te&0xffffffffffffn),S<VL&&p.size!==S&&(p.size=S,p.#t))for(let ie of p.#t)ie(S);Y=Y.subarray(Er,G),l-=Er}else if(G===0){let te=Buffer.allocUnsafe(8);return(0,je.read)(o,te,0,Er,0,ie=>{if(ie)return O(ie);if($f.set(te),S=Number(Dm.getBigUint64(0)&0xffffffffffffn),S>l){d!==!1?(f=setTimeout(()=>{O(new Error("File read timed out"))},S3).unref(),u=(0,je.watch)(i,{persistent:!1},()=>{clearTimeout(f),u.close(),_(),R(E,A)})):O(new Error("Blob is incomplete"));return}(0,je.close)(o),h.close(),E()})}else Y=Y.subarray(0,G);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=G,R(E,A);s&&l>=s&&(l>s&&(Y=Y.subarray(0,s-c)),l=S=s),n&&n>c&&(Y=Y.subarray(n-c))}c+=G;try{h.enqueue(Y)}catch(te){return Ta.default.debug?.("Error enqueuing chunk",te),E()}l===S&&((0,je.close)(o),h.close()),E()})},"readMore"))},"pull"),cancel(){(0,je.close)(o),clearTimeout(f),u&&u.close()}});function _(){if(d===void 0){let h=t.store,S=t.fileId+":blob";d=!h.attemptLock(S,0,()=>{d=!1,h.unlock(S,0)}),d||h.unlock(S,0)}return d}}slice(t,r,n){let s=mn.get(this),i=new e(n&&{type:n});if(s?.fileId){let o={...s,start:t,end:r};mn.set(i,o),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let o={...s,contentBuffer:s.contentBuffer.subarray(t,r)};mn.set(i,o),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(!t?.primaryStore?.rootStore)throw new Error("No target table specified");return XL(this).saving??Promise.resolve()}},QL=500;a(JL,"deleteBlob");a(T3,"setDeletionDelay");global.createBlob=function(e,t){let r=new Lm(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(mn.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Vf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Vf.Readable.from(e);else throw new Error("Invalid source type");return r};a(XL,"saveBlob");a(bR,"writeBlobWithStream");a(Bm,"getFileId");a(ZL,"getFilePathForBlob");Mm=new Map;a(Hm,"getRootBlobPathsForDB");a(NR,"deleteRootBlobPathsForDB");a(eM,"rimrafSteadily");a(Kf,"getFilePath");a(A3,"writeBlobWithBuffer");a(R3,"generateFilePath");KL=new Map;a(y3,"getNextFileId");vm=128;a(b3,"getNextStorageIndex");a(O3,"createFrequencyTableForStoragePaths");a(km,"encodeBlobsWithFilePath");a(N3,"encodeBlobsAsBuffers");a(wR,"decodeBlobsWithWrites");a(IR,"decodeWithBlobCallback");a(Dc,"decodeFromDatabase");a(Aa,"deleteBlobsInObject");a(Yf,"findBlobsInObject");(0,co.addExtension)({Class:Ci,type:11,unpack:a(function(e){let t=(0,co.unpack)(e),r=new Lm;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(!Qs)throw new Error("No store specified, can not load blob from storage");if(mn.set(r,{storageIndex:t[1],fileId:t[2],store:Qs}),Cc)return Cc(r)??r}else mn.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:a(function(e){let t=mn.get(e);if(Au!==void 0&&(Pc=!0,t?.recordId!==void 0&&t.recordId!==Au))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<WL)return r.size=t.contentBuffer.length,(0,co.pack)([r,t.contentBuffer])}if(Au!==void 0){if(t=XL(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Au,(0,co.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,je.readFileSync)(Kf(t));if(n.length>=Er&&(n.copy($f,0,0,Er),Number(Dm.getBigUint64(0)&0xffffffffffffn)===n.length-Er))return Buffer.concat([(0,co.pack)([r]),n]);if(Pr)Pr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&Pr)return Pr.push(e.bytes()),Buffer.alloc(0);throw n}else throw new Error("Blob has no storage info or buffer attached to it")},"pack")});(0,co.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(w3,"polyfillBlob")});var cM={};ve(cM,{asyncSerialization:()=>CR,contentTypes:()=>vR,findBestSerializer:()=>qm,getDeserializer:()=>po,hasAsyncSerialization:()=>PR,registerContentHandlers:()=>jf,serialize:()=>Qf,serializeMessage:()=>Ra,toCsvStream:()=>Gm});function C3(e){try{return e?.[0]===123?MR(e):e}catch{return e}}function jf(e){e.register(D3,{serializers:[{regex:/^application\/json$/,serializer:qf},{regex:/^application\/cbor$/,serializer:a(function(t){return new Lc.EncoderStream(zf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Mc.Readable.from((0,Pi.encodeIter)(t,zf)):(0,Pi.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),Gm(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Pi.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Lc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function qm(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[u,...f]=l.split(/\s*;\s*/),d=1,p={q:1};for(let h of f){let S=h.indexOf("=");p[h.substring(0,S)]=h.substring(S+1)}d=+p.q;let _=Kr.get(u);if(_){let h=(_.q||1)*d;h>s&&(n=_,i=_.type||u,s=h,o=p)}}if(!n){if(r)throw new nM.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(Kr.keys()).join(", "),406);n=Kr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Qf(e,t,r){let n=rM&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array||e instanceof Ci)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=qm(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&e&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){if(e.mapError){let c=e.getColumns;e=e.mapError(l=>(l.toJSON=()=>({error:l.name,message:l.message,...l.partialObject}),LR.default.warn?.(`Error serializing error ${t?.url||t}: ${l}`),l)),e.getColumns=c}let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,_o.createBrotliCompress)({params:{[_o.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?_o.constants.BROTLI_MODE_TEXT:_o.constants.BROTLI_MODE_GENERIC,[_o.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>rM?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,_o.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Ra(e,t,r){if(e?.contentType!=null&&e.data!=null)return e.data;fo=r?void 0:[];try{let n;if(t){let s=t.serialize;if(s)n=s(e);else{let i=qm(t);s=t.serialize=i.serializer.serialize,n=s(e)}}else n=Wf(e);return fo?.length>0?(fo.length===1?fo[0]:Promise.all(fo)).then(()=>Ra(e,t,!0)):n}finally{fo=void 0}}function CR(e){if(fo)fo.push(e);else throw new Error("Unable to serialize asynchronously")}function PR(){return!!fo}function L3(e){return new Promise((t,r)=>{let n=[];e.on("data",s=>n.push(s)),e.on("end",()=>t(Buffer.concat(n))),e.on("error",r)})}function v3(e){return M3.includes(e)}function U3(e){let t=e.indexOf(";"),r;if(t>-1){r={};let n=e.slice(t+1).split(";");for(let s of n){let[i,o]=s.split("=");r[i.trim()]=o.trim()}e=e.slice(0,t)}return{type:e,parameters:r}}function po(e="",t=!1){let r=U3(e),n=r.type&&Kr.get(r.type)?.deserialize||x3(r);return t?s=>L3(s).then(n):n}function x3(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!v3(e.parameters.charset)&&LR.default.info(`Unknown Buffer encoding ${e.parameters.charset} in content-type. Proceeding anyways.`),t=>({contentType:e.type,data:t.toString(e.parameters?.charset||"utf-8")})):e.type==="application/octet-stream"?t=>t:t=>{if(e.type==="")try{if(t?.[0]===123)return MR(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function B3(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}function Gm(e,t){let r=Mc.default.Readable.from(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator]?e:[e]),n={};t&&(n.fields=t.map(o=>({label:o,value:o})));let s={objectMode:!0},i=new I3(n,s);return r.pipe(i)}var Pi,Lc,_o,nM,Mc,sM,DR,iM,LR,I3,oM,Wf,MR,zf,Kr,vR,tM,aM,P3,D3,rM,fo,M3,uo=be(()=>{yR();Pi=require("msgpackr"),Lc=require("cbor-x"),_o=require("zlib"),nM=M(pe()),Mc=M(require("stream"));Vr();sM=M(Ri()),DR=M(ae());H();iM=M(require("yaml")),LR=M(Ii());Ts();({Transform:I3}=require("json2csv")),oM=DR.default.get(B.SERIALIZATION_BIGINT)!==!1,Wf=oM?Ic:JSON.stringify,MR=oM?RR:JSON.parse,zf={useRecords:!1,useToJSON:!0},Kr=new Map,vR=Kr;Ye.contentTypes=vR;(0,sM._assignPackageExport)("contentTypes",vR);Kr.set("application/json",{serializeStream:qf,serialize:Wf,deserialize(e){return MR(e)},q:.8});tM=new Lc.Encoder(zf);Kr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Lc.EncoderStream(zf).end(e)},serialize:tM.encode,deserialize:tM.decode,q:1});Kr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Mc.Readable.from((0,Pi.encodeIter)(e,zf)):(0,Pi.pack)(e)},serialize:Pi.pack,deserialize:Pi.unpack,q:.9});Kr.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),Gm(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),Gm(e,e?.getColumns?.())},q:.1});Kr.set("text/plain",{serialize(e){return e.toString()},serializeStream(e){return Mc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Kr.set("text/yaml",{serialize(e){return iM.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Kr.set("text/event-stream",{serializeStream:a(function(e){return Mc.Readable.from(B3(e,this.serialize))},"serializeStream"),serialize:a(function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
|
|
7
|
+
`}a(zs,"createLogRecord");function If(e){if(Ai){if(ID(e),ms){fa=!1;try{process.stdout.write(e)}finally{fa=!0}}}else ms&&process.stdout.write(e)}a(If,"logStdOut");function fm(e){if(Ai){if(ID(e),ms){fa=!1;try{process.stderr.write(e)}finally{fa=!0}}}else ms&&process.stderr.write(e)}a(fm,"logStdErr");function ID(e){rR(),da?no.appendFileSync(da,e):tR||console.log(e)}a(ID,"logToFile");function sR(){try{no.closeSync(da)}catch{}da=null}a(sR,"closeLogFile");function rR(){if(!da){try{da=no.openSync(um,"a")}catch(e){tR||(tR=!0,console.error(e))}setTimeout(()=>{sR()},qQ).unref()}}a(rR,"openLogFile");function CD(...e){Er[Pr]<=Er.info&&If(zs("info",e))}a(CD,"info");function PD(...e){Er[Pr]<=Er.trace&&If(zs("trace",e))}a(PD,"trace");function dm(...e){Er[Pr]<=Er.error&&fm(zs("error",e))}a(dm,"error");function DD(...e){Er[Pr]<=Er.debug&&If(zs("debug",e))}a(DD,"debug");function LD(...e){Er[Pr]<=Er.notify&&If(zs("notify",e))}a(LD,"notify");function MD(...e){Er[Pr]<=Er.fatal&&fm(zs("fatal",e))}a(MD,"fatal");function vD(...e){Er[Pr]<=Er.warn&&fm(zs("warn",e))}a(vD,"warn");function zQ(e,t,...r){t===ND.STDERR?fm(zs(e,r)):If(zs(e,r))}a(zQ,"logCustomLevel");function jQ(){let e;try{e=HQ.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=Ri.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return no.existsSync(t)||(t=Ri.join(nR,"utility/hdb_boot_properties.file")),t}a(jQ,"getPropsFilePath");function JQ(e){Pr=e}a(JQ,"setLogLevel");function yD(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(yD,"autoCastBoolean");function QQ(e){try{if(e.includes("config/settings.js")){let o=OD(e);return{level:o.get(Wt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:Ri.dirname(o.get(Wt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=bD.parseDocument(no.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),n=t.getIn(["logging","root"]),s=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:n,to_file:s,to_stream:i}}catch(t){if(t.code===Wt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(QQ,"getLogConfig");function XQ(){try{let e=bD.parseDocument(no.readFileSync(GQ,"utf8")),t=e.getIn(["logging","level"]),r=e.getIn(["logging","file"]),n=e.getIn(["logging","stdStreams"]);return{default_level:t,default_to_file:r,default_to_stream:n}}catch(e){console.error("Error accessing default config file for logging"),console.error(e)}}a(XQ,"getDefaultConfig");function ZQ(e,t,r,n,s,i){this.username=e,this.status=t,this.type=r,this.originating_ip=n,this.request_method=s,this.path=i}a(ZQ,"AuthAuditLog")});var iR=w((Wye,BD)=>{"use strict";var e4=require("util"),t4=require("path"),r4=require("child_process"),n4=e4.promisify(r4.execFile),s4=1e3*1e3*10;BD.exports={findPs:i4};async function i4(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await n4("ps",["wwxo",`pid,${r}`],{maxBuffer:s4});for(let s of n.trim().split(`
|
|
8
|
+
`).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:t4.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(i4,"findPs")});var xt=w((jye,kD)=>{"use strict";var o4="__dbis__",a4="__txns__",c4="__environment_name__",l4="__dbi_defintion__",u4={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"},d4=["__createdtime__","__updatedtime__"],f4="\uFFFF",HD={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},_4=Object.values(HD);kD.exports={AUDIT_STORE_NAME:a4,INTERNAL_DBIS_NAME:o4,DBI_DEFINITION_NAME:l4,SEARCH_TYPES:u4,TIMESTAMP_NAMES:d4,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:c4,TRANSACTIONS_DBI_NAMES_ENUM:HD,TRANSACTIONS_DBIS:_4,OVERFLOW_MARKER:f4}});var xn=w((Jye,zD)=>{"use strict";var FD=(H(),C(G)),GD=xt(),qD={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},$D=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),VD={500:$D("There was an error processing your request."),400:"Invalid request"},p4=VD[qD.INTERNAL_SERVER_ERROR],h4={OP_NOT_SUPPORTED_FOR_FS:a(e=>`${e} is not available for this instance because it uses the File System data store.`,"OP_NOT_SUPPORTED_FOR_FS"),MISSING_VALUE:a(e=>`${e} is missing.`,"MISSING_VALUE"),INVALID_VALUE:a(e=>`${e} is invalid.`,"INVALID_VALUE"),NOT_FOUND:a(e=>`${e} not found.`,"NOT_FOUND")},m4={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},E4={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),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:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},g4={BASE_PATH_REQUIRED:"base_path is required",DESTINATION_PATH_REQUIRED:"destination_path is required",ENV_NAME_REQUIRED:"env_name is required",INVALID_BASE_PATH:"invalid base_path",INVALID_DESTINATION_PATH:"invalid destination_path",INVALID_ENVIRONMENT:"invalid environment",ENV_REQUIRED:"env is required",DBI_NAME_REQUIRED:"dbi_name is required",DBI_DOES_NOT_EXIST:"dbi does not exist",HASH_ATTRIBUTE_REQUIRED:"hash_attribute is required",ID_REQUIRED:"id is required",IDS_REQUIRED:"ids is required",IDS_MUST_BE_ITERABLE:"ids must be iterable",FETCH_ATTRIBUTES_REQUIRED:"fetch_attributes is required",FETCH_ATTRIBUTES_MUST_BE_ARRAY:"fetch_attributes must be an array",ATTRIBUTE_REQUIRED:"attribute is required",SEARCH_VALUE_REQUIRED:"search_value is required",SEARCH_VALUE_TOO_LARGE:"search_value is too long",WRITE_ATTRIBUTES_REQUIRED:"write_attributes is required",WRITE_ATTRIBUTES_MUST_BE_ARRAY:"write_attributes must be an array",RECORDS_REQUIRED:"records is required",RECORDS_MUST_BE_ARRAY:"records must be an array",CANNOT_CREATE_INTERNAL_DBIS_NAME:`cannot create a dbi named ${GD.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${GD.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"},S4={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${FD.INSERT_MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),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 ${FD.INSERT_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"},KD={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"},T4={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:a(e=>`Operation '${e}' is restricted to 'super_user' roles`,"OP_IS_SU_ONLY"),OP_NOT_FOUND:a(e=>`Operation '${e}' not found`,"OP_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:a((e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,"UNKNOWN_OP_AUTH_ERROR"),USER_HAS_NO_PERMS:a(e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,"USER_HAS_NO_PERMS"),DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},A4={ATTR_PERM_MISSING:a((e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,"ATTR_PERM_MISSING"),ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:a((e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,"ATTR_PERM_NOT_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:a(e=>`Invalid attribute '${e}' in 'attribute_permissions'`,"INVALID_ATTRIBUTE_IN_PERMS"),INVALID_PERM_KEY:a(e=>`Invalid table permission key value '${e}'`,"INVALID_PERM_KEY"),INVALID_ATTR_PERM_KEY:a(e=>`Invalid attribute permission key value '${e}'`,"INVALID_ATTR_PERM_KEY"),INVALID_ROLE_JSON_KEYS:a(e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,"INVALID_ROLE_JSON_KEYS"),MISMATCHED_TABLE_ATTR_PERMS:a(e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,"MISMATCHED_TABLE_ATTR_PERMS"),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:a(e=>`A role with name '${e}' already exists`,"ROLE_ALREADY_EXISTS"),ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:a(e=>`Your role does not have permission to view database metadata for '${e}'`,"SCHEMA_PERM_ERROR"),SCHEMA_TABLE_PERM_ERROR:a((e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,"SCHEMA_TABLE_PERM_ERROR"),SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:a(e=>`Value for '${e}' permission must be a boolean`,"SU_CU_ROLE_BOOLEAN_ERROR"),STRUCTURE_USER_ROLE_TYPE_ERROR:a(e=>`Value for '${e}' permission must be a boolean or Array`,"STRUCTURE_USER_ROLE_TYPE_ERROR"),SU_CU_ROLE_NO_PERMS_ALLOWED:a(e=>`Roles with '${e}' set to true cannot have other permissions set.`,"SU_CU_ROLE_NO_PERMS_ALLOWED"),SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:a(e=>`Missing table ${e.toUpperCase()} permission`,"TABLE_PERM_MISSING"),TABLE_PERM_NOT_BOOLEAN:a(e=>`Table ${e.toUpperCase()} permission must be a boolean`,"TABLE_PERM_NOT_BOOLEAN")},R4={ATTR_NOT_FOUND:a((e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,"ATTR_NOT_FOUND"),ATTR_EXISTS_ERR:a((e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,"ATTR_EXISTS_ERR"),DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:a(e=>`Invalid table ${JSON.stringify(e)}`,"INVALID_TABLE_ERR"),SCHEMA_NOT_FOUND:a(e=>`database '${e}' does not exist`,"SCHEMA_NOT_FOUND"),SCHEMA_EXISTS_ERR:a(e=>`database '${e}' already exists`,"SCHEMA_EXISTS_ERR"),TABLE_EXISTS_ERR:a((e,t)=>`Table '${t}' already exists in '${e}'`,"TABLE_EXISTS_ERR"),SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:a((e,t)=>`Table '${e}.${t}' does not exist`,"TABLE_NOT_FOUND"),TABLE_REQUIRED_ERR:"table is required"},y4={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},b4={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},YD={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},WD={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},O4={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},N4={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},w4={...KD,...E4,...h4,...T4,...A4,...R4,...y4,...b4,...S4,...YD,...WD,...O4,...N4,...m4};zD.exports={CHECK_LOGS_WRAPPER:$D,HDB_ERROR_MSGS:w4,DEFAULT_ERROR_MSGS:VD,DEFAULT_ERROR_RESP:p4,HTTP_STATUS_CODES:qD,LMDB_ERRORS_ENUM:g4,AUTHENTICATION_ERROR_MSGS:KD,VALIDATION_ERROR_MSGS:YD,ITC_ERRORS:WD}});var pe=w((Xye,QD)=>{"use strict";var _u=xn(),I4=z(),C4=(H(),C(G)),_m=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,jD),this.statusCode=n||_u.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(_u.DEFAULT_ERROR_MSGS[n]?_u.DEFAULT_ERROR_MSGS[n]:_u.DEFAULT_ERROR_MSGS[_u.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&I4[s](i)}},oR=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},aR=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function jD(e,t,r,n=C4.LOG_LEVELS.ERROR,s=null,i=!1){if(JD(e))return e;let o=new _m(e,t,r,n,s);return i&&delete o.stack,o}a(jD,"handleHDBError");function JD(e){return e.__proto__.constructor.name===_m.name}a(JD,"isHDBError");QD.exports={isHDBError:JD,handleHDBError:jD,ClientError:oR,ServerError:aR,hdb_errors:_u}});var gt=w((ebe,sL)=>{"use strict";var Mf=(H(),C(G)),P4=ie(),fn=ae(),vf=require("path"),D4=require("minimist"),XD=require("fs-extra"),ZD=require("lodash");fn.initSync();var{CONFIG_PARAMS:_a,DATABASES_PARAM_CONFIG:Cf,SYSTEM_SCHEMA_NAME:pm}=Mf,Pf,Df,Lf;function eL(){if(Pf!==void 0)return Pf;if(fn.getHdbBasePath()!==void 0)return Pf=fn.get(_a.STORAGE_PATH)||vf.join(fn.getHdbBasePath(),Mf.DATABASES_DIR_NAME),Pf}a(eL,"getBaseSchemaPath");function tL(){if(Df!==void 0)return Df;if(fn.getHdbBasePath()!==void 0)return Df=nL(pm),Df}a(tL,"getSystemSchemaPath");function rL(){if(Lf!==void 0)return Lf;if(fn.getHdbBasePath()!==void 0)return Lf=fn.get(Mf.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||vf.join(fn.getHdbBasePath(),Mf.TRANSACTIONS_DIR_NAME),Lf}a(rL,"getTransactionAuditStoreBasePath");function L4(e,t){let r=fn.get(_a.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||vf.join(rL(),e.toString())}a(L4,"getTransactionAuditStorePath");function nL(e,t){e=e.toString(),t=t&&t.toString();let r=fn.get(Mf.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||vf.join(eL(),e)}a(nL,"getSchemaPath");function M4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,D4(process.argv));let n=r[_a.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!P4.isObject(n))throw o;i=n}for(let o of i){let c=o[pm];if(!c)continue;let l=fn.get(_a.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Cf.PATH];if(u)return ZD.set(l,[pm,Cf.TABLES,t,Cf.PATH],u),fn.setProperty(_a.DATABASES,l),u;let f=c?.[Cf.PATH];if(f)return ZD.set(l,[pm,Cf.PATH],f),fn.setProperty(_a.DATABASES,l),f}}let s=r[_a.STORAGE_PATH.toUpperCase()];if(s){if(!XD.pathExistsSync(s))throw new Error(s+" does not exist");let i=vf.join(s,e);return XD.mkdirsSync(i),fn.setProperty(_a.STORAGE_PATH,s),i}return tL()}a(M4,"initSystemSchemaPaths");function v4(){Pf=void 0,Df=void 0,Lf=void 0}a(v4,"resetPaths");sL.exports={getBaseSchemaPath:eL,getSystemSchemaPath:tL,getTransactionAuditStorePath:L4,getTransactionAuditStoreBasePath:rL,getSchemaPath:nL,initSystemSchemaPaths:M4,resetPaths:v4}});var _n=w((sbe,lL)=>{"use strict";var U4=xn().LMDB_ERRORS_ENUM,rbe=require("lmdb"),x4=xt(),nbe=require("buffer").Buffer,{OVERFLOW_MARKER:iL,MAX_SEARCH_KEY_LENGTH:hm}=x4,oL=["number","string","symbol","boolean","bigint"];function B4(e){if(e=e?.primaryStore||e,!e)throw new Error(U4.ENV_REQUIRED)}a(B4,"validateEnv");function H4(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(H4,"stringifyData");function k4(e){return e instanceof Date?e.valueOf():e}a(k4,"convertKeyValueToWrite");function F4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(oL.includes(typeof e))return e.length>hm?[e.slice(0,hm)+iL]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(oL.includes(typeof i))i.length>hm?r.push(i.slice(0,hm)+iL):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(F4,"getIndexedValues");var mm=0,aL=0;function cL(){aL=Date.now()-performance.now()}a(cL,"adjustStartTime");cL();var G4=6e4;setInterval(cL,G4).unref();function q4(){let e=performance.now()+aL;return e>mm?(mm=e,e):(mm+=488e-6,mm)}a(q4,"getNextMonotonicTime");lL.exports={validateEnv:B4,stringifyData:H4,convertKeyValueToWrite:k4,getNextMonotonicTime:q4,getIndexedValues:F4}});var Uf=w((obe,uL)=>{"use strict";var $4=(H(),C(G)).OPERATIONS_ENUM,cR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=$4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};uL.exports=cR});var xf=w((lbe,pL)=>{"use strict";var cbe=Uf(),Em=(H(),C(G)),lR=ie(),dL=z(),V4=require("uuid"),{handleHDBError:gm,hdb_errors:K4}=pe(),{HDB_ERROR_MSGS:Sm,HTTP_STATUS_CODES:Tm}=K4;pL.exports=fL;function fL(e,t,r){for(let s=0;s<t.length;s++)_L(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];Y4(i,r,e.operation)}}a(fL,"processRows");fL.validateAttribute=_L;function _L(e){if(Buffer.byteLength(String(e))>Em.INSERT_MAX_CHARACTER_SIZE)throw gm(new Error,Sm.ATTR_NAME_LENGTH_ERR(e),Tm.BAD_REQUEST,void 0,void 0,!0);if(lR.isEmptyOrZeroLength(e)||lR.isEmpty(e.trim()))throw gm(new Error,Sm.ATTR_NAME_NULLISH_ERR,Tm.BAD_REQUEST,void 0,void 0,!0)}a(_L,"validateAttribute");function Y4(e,t,r){if(!e.hasOwnProperty(t)||lR.isEmptyOrZeroLength(e[t])){if(r===Em.OPERATIONS_ENUM.INSERT||r===Em.OPERATIONS_ENUM.UPSERT){e[t]=V4.v4();return}throw dL.error("Update transaction aborted due to record with no hash value:",e),gm(new Error,Sm.RECORD_MISSING_HASH_ERR,Tm.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>Em.INSERT_MAX_CHARACTER_SIZE)throw dL.error(e),gm(new Error,Sm.HASH_VAL_LENGTH_ERR,Tm.BAD_REQUEST,void 0,void 0,!0)}a(Y4,"validateHash")});var hL,Bn,uR,pu=be(()=>{hL=require("events"),Bn=class extends hL.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new uR;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},uR=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});function RL(e){fR=e}function J4(){j4=setInterval(function(){for(let e of dR)if(e.stale){let t=e.getContext()?.url;SL.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},z4).unref()}var _R,gL,SL,TL,AL,mL,dR,W4,Bf,EL,fR,wc,Am,z4,j4,Rm=be(()=>{_R=M(_n()),gL=M(pe()),SL=M(z()),TL=M(ae());H();AL=M(ie()),mL=100,dR=new Set,W4=(0,AL.convertToMS)(TL.get(x.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(RL,"replicationConfirmation");wc=class e{static{a(this,"DatabaseTransaction")}#e;writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),dR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn?.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(dR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(Bf&&!this.overloadChecked&&performance.now()-EL>W4)throw new gL.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,_R.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let _=d;_<this.validated;_++)this.writes[_]?.validate?.(this.timestamp);let p;for(let _=d;_<this.validated;_++){let h=this.writes[_];h&&(h.before||h.beforeIntermediate)&&(p=!0)}if(p)return(async()=>{try{for(let _=0;_<2;_++){let h;for(let S=d;S<this.validated;S++){let g=this.writes[S];if(!g)continue;let R=g[_===0?"before":"beforeIntermediate"];if(R){let E=R();h?h.push?h.push(E):h=[h,E]:h=E}}h&&await(h.push?Promise.all(h):h)}}catch(_){throw this.abort(),_}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.doneWriting?2:1;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let p=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||p}else l();else for(let p of this.writes)c(p)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<mL>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return Bf||(Bf=s,EL=performance.now(),Bf.then(()=>{Bf=null})),s.then(d=>{if(d){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let p=this.writes[0].store.rootStore.databaseName,_=this.writes[this.writes.length-1];fR&&_&&i.push(fR(p,_.store.getEntry(_.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+mL/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let f={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(p=>({txnTime:r,next:p}));f.next=d}return f}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}getContext(){return this.#e}setContext(t){this.#e=t}},Am=class extends wc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,_R.getNextMonotonicTime)())}getReadTxn(){}},z4=3e4;a(J4,"startMonitoringTxns");J4()});function wt(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new wc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n.setContext(e),e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({doneWriting:!0});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var yL,Ic=be(()=>{yL=M(Ti());Rm();a(wt,"transaction");(0,yL._assignPackageExport)("transaction",wt);wt.commit=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};wt.abort=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});function hR(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let d=u(l);for(let _=1;_<e.length;_++){let h=e[_],S=u(h);d=d.concat(S)}let p=new Set;return d.filter(_=>{let h=_.key??_;return p.has(h)?!1:(p.add(h),!0)})}else{let d=u(l),p=f(e.slice(1),!0,l.estimated_count);return p.length>0?o(d,p):d}function u(d){return d.conditions?hR(d.conditions,d.operator,r,n,s,i,o,c):Eu(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function f(d,p,_){return d.map((h,S)=>{if(h.conditions){let E=h.operator==="or",T=f(h.conditions,!E,_);return E?(b,v)=>T.some(F=>F(b,v)):(b,v)=>T.every(F=>F(b,v))}let g=(h.attribute||h[0])===r.primaryKey,R=Ff(h,r,i,c,g,_);return p&&S<d.length-1&&_&&(_=i3(r.primaryStore,h.estimated_count,_)),R}).filter(Boolean)}a(f,"mapConditionsToFilters")}function Eu(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(c===void 0&&l!=="sort")throw new hn.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let E=o[0],T=bi(n.attributes,E);if(T.relationship){if(o.length<2)throw new hn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let b=T.definition?.tableClass||T.elements?.definition?.tableClass,v=new Map,F=Eu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,b,s,v);if(T.relationship.to){i[o[0]]=v;let q=!!bi(b.attributes,T.relationship.to)?.elements;F=t3(F,T,b.primaryStore,q,v)}if(T.relationship.from){let q=a(Y=>(Y?.key!==void 0&&(Y=Y.key),Eu({attribute:T.relationship.from,value:Y},t,r,n,s,v)),"searchEntry");T.elements?(i[o[0]]=v,F=r3(F,T,b.primaryStore,v,q)):F=F.flatMap(q)}return F}else if(o.length===1)o=o[0];else throw new hn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,f,d,p;c instanceof Date&&(c=c.getTime());let _;switch(mR[l]||l){case"lt":u=!0,f=c;break;case"le":u=!0,f=c,d=!0;break;case"gt":u=c,p=!0;break;case"ge":u=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],u=c,f=c.slice(0),f[f.length-1]=yi.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),f=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),f=c[1],f instanceof Date&&(f=f.getTime()),d=l==="gele"||l==="gtle"||l==="between",p=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,f=c,d=!0;break;case"ne":if(c===null){u=c,p=!0;break}case"sort":case"contains":case"ends_with":u=!0,_=!0;break;default:throw new hn.ClientError(`Unknown query comparator "${l}"`)}let h,S=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>Es.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Es.MAX_SEARCH_KEY_LENGTH)+Es.OVERFLOW_MARKER,p=!1,h=Ff(e,n,null,i,S)),typeof f=="string"&&f.length>Es.MAX_SEARCH_KEY_LENGTH&&(f=f.slice(0,Es.MAX_SEARCH_KEY_LENGTH)+Es.OVERFLOW_MARKER,d=!0,h=h??Ff(e,n,null,i,S)),r){let E=u;u=f,f=E,E=!p,p=!d,d=E}let g=S?n.primaryStore:n.indices[o];if(!g||g.isIndexing||_||c===null&&!g.indexNulls){if(s===!1&&!g)throw new hn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&_)throw new hn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(g?.isIndexing)throw new hn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&g&&!g.indexNulls)throw new hn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??Ff(e,n,null,i,S),!h)throw new hn.ClientError(`Unknown search operator ${e.comparator}`)}let R={start:u,end:f,inclusiveEnd:d,exclusiveStart:p,values:!0,versions:S,transaction:t,reverse:r};if(S){let E=g.getRange(R).map(h?function({key:T,value:b}){return this?.isSync?b&&h(b)?T:pa.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(b&&h(b)?T:pa.SKIP)}catch(q){F(q)}}))}:T=>T.value==null&&!(T.metadataFlags&(mn|ma))?pa.SKIP:T);return E.hasEntries=!0,E}else return g?g.getRange(R).map(h?function({key:E,value:T}){let b;return typeof E=="string"&&E.length>Es.MAX_SEARCH_KEY_LENGTH?b=n.primaryStore.get(T):b={[o]:E},this.isSync?h(b)?T:pa.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(h(b)?T:pa.SKIP)}catch(q){F(q)}}))}:({value:E})=>E):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:E,value:T}){return this.isSync?T&&h(T)?E:pa.SKIP:new Promise((b,v)=>setImmediate(()=>{try{b(T&&h(T)?E:pa.SKIP)}catch(F){v(F)}}))})}function bi(e,t){if(Array.isArray(t))if(t.length>1){let r=bi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?bi(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function t3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=a((u,f)=>{let d=s.get(u);d?d.push(f):s.set(u,d=[f])},"add_entry");for(let u of e){let f=u.value??r.get(u.key??u),d=f?.[c];if(d!=null&&!s.filters?.some(p=>!p(f)))if(n)for(let p=0;p<d.length;p++)l(d[p],u);else l(d,u)}return i=s.keys()[Symbol.iterator](),this.next()}let o=i.next();return o.done?o:{value:o.value}},return(){if(i?.return)return i.return()}}}})}function r3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=f=>f[t.relationship.from]?.filter?.(d=>u.has(d));for(let f of e){if(n.filters){let d=r.get(f);if(n.filters.some(p=>!p(d)))continue}u.add(f)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(o=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function Ff(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let f=c[0],d=bi(t.attributes,f),p=d.definition?.tableClass||d.elements.definition?.tableClass,_=n?.[f],h=Ff({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},p,r,_?.[f]?.joined,c[1]===p.primaryKey,i);if(!h)return;if(_){_.filters||(_.filters=[]),_.filters.push(h);return}let S=t.propertyResolvers?.[f],g,R=a((E,T)=>{let b,v;if(S){if(S.from&&h.idFilter){if(!g)if(h.idFilter.idSet?.size===1){for(let q of h.idFilter.idSet)e={attribute:S.from,value:q};g=u(S.from,h.idFilter,!0,!0)}else g=u(S.from,h.idFilter,!1,!0);let F=g(E);return g.idFilter&&(R.idFilter=g.idFilter),F}v=S(E,r,T),b=v?.value}else b=E[f];return b?Array.isArray(b)?b.some(h):h(b,v):!1},"recordFilter");return R}}switch(l instanceof Date&&(l=l.getTime()),mR[o]||o){case Es.SEARCH_TYPES.EQUALS:case void 0:return u(c,f=>f===l,!0);case"contains":return u(c,f=>f?.toString().includes(l));case"ends_with":return u(c,f=>f?.toString().endsWith(l));case"starts_with":return u(c,f=>typeof f=="string"&&f.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,f=>{if(!Array.isArray(f))return!1;for(let d=0,p=l.length;d<p;d++)if(f[d]!==l[d])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,f=>(0,yi.compareKeys)(f,l[0])>=0&&(0,yi.compareKeys)(f,l[1])<=0,!0);case"gt":return u(c,f=>(0,yi.compareKeys)(f,l)>0);case"ge":return u(c,f=>(0,yi.compareKeys)(f,l)>=0);case"lt":return u(c,f=>(0,yi.compareKeys)(f,l)<0);case"le":return u(c,f=>(0,yi.compareKeys)(f,l)<=0);case"ne":return u(c,f=>(0,yi.compareKeys)(f,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new hn.ClientError(`Unknown query comparator "${o}"`)}function u(f,d,p,_){let h;p=p&&!s&&t?.indices[f]&&i>3,p&&(e.estimated_count==null&&bm(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(p=!1));let S=0,g=3;function R(E){let T=E[f],b;if(typeof T!="object"||!T||_?b=d(T):Array.isArray(T)?b=T.some(d):T instanceof Date&&(b=d(T.getTime())),p&&(g++,!b&&!R.idFilter&&++S/g*(i-g)>h)){let v=Eu(e,r.transaction.getReadTxn(),!1,t).map(gu),F=new Set(v);R.idFilter=q=>F.has(gu(q)),R.idFilter.idSet=F}return b}return a(R,"recordFilter"),s&&(R.idFilter=d),R}a(u,"attributeComparator")}function bm(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/so(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=mR[n]||n,n===Es.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=bi(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=bm(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*so(e.indices[i.relationship.from])/(so(o.primaryStore)||1):c)}else{let i=e.indices[s];r.estimated_count=i?i.getValuesCount(r[1]??r.value):1/0}}else if(n==="contains"||n==="ends_with"||n==="ne"){let s=r[0]??r.attribute,i=e.indices[s];r.value===null&&n==="ne"?r.estimated_count=so(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=Z4*so(e.primaryStore)+1:n==="between"?r.estimated_count=X4*so(e.primaryStore)+1:n==="sort"?r.estimated_count=so(e.primaryStore)+1:r.estimated_count=Q4*so(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function Om(e){if(e)if(ha=e,hu.lastIndex=0,n3.test(e))try{let t=Hf(new mu,"");if(pn!==ha.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${pn} in '${ha}'`,t}else return new URLSearchParams(e)}function Hf(e,t){let r=hu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ha);){pn=r.lastIndex;let[,f,d]=n;if(o){if(f)throw new SyntaxError(`expected operator, but encountered '${f}'`);o=!1,c=!1}else c=!0;let p;switch(d){case"=":if(s!=null){if(f.length<=2)i=f;else throw new SyntaxError(`invalid FIQL operator ${f}`);l=bL}else{if(l=decodeURIComponent,i="equals",!f)throw new SyntaxError("attribute must be specified before equality comparator");s=kf(f)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=e3[d],l=pR[i]?bL:decodeURIComponent,!f)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=kf(f);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${d[0]?"'"+d[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${d?"'"+d+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s||null,value:l(f)};if(i==="eq"&&OL(h,f),s===""){let S=e.conditions[e.conditions.length-1];S.chainedConditions=S.chainedConditions||[],S.chainedConditions.push(h),S.operator=u}else ym(e,u),e.conditions.push(h)}d==="&"?(u="and",s=void 0):d==="|"?(u="or",s=void 0):d==="&="?(u="and",s=""):d==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(kf(f)),s=void 0;break;case"(":hu.lastIndex=pn;let _=Hf(f?[]:new mu,")");switch(f){case"":ym(e,u),e.conditions.push(_);break;case"limit":switch(_.length){case 1:e.limit=+_[0];break;case 2:e.offset=+_[0],e.limit=_[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(_[0])&&_.length===1&&!_[0].name?(e.select=_[0],e.select.asArray=!0):_.length===1?e.select=_[0]:_.length===2&&_[1]===""?e.select=_.slice(0,1):e.select=_;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=NL(_);break;default:throw new SyntaxError(`unknown query function call ${f}`)}ha[pn]===","?r.lastIndex=++pn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!f)throw new SyntaxError("property sets must have a defined parent property name");hu.lastIndex=pn,p=Hf([],"}"),p.name=f,e.push(p),ha[pn]===","?r.lastIndex=++pn:o=!0;break;case"[":hu.lastIndex=pn,f?(p=Hf(new mu,"]"),p.name=f):p=Hf(e.conditions?new mu:[],"]"),e.conditions?(ym(e,u),e.conditions.push(p),s=null):e.push(p),ha[pn]===","?r.lastIndex=++pn:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(f)};i==="eq"&&OL(h,f),ym(e,u),e.conditions.push(h)}else if(f)throw new SyntaxError("no attribute or comparison specified")}else(f||e.length>0&&c)&&e.push(kf(f));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${d[0]}'`):new SyntaxError(`unexpected token '${d[0]}'`);default:throw new SyntaxError(`unexpected operator '${d}'`)}if(t!==")"&&(r=s?s3:hu,r.lastIndex=pn),pn===ha.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function ym(e,t){if(e.conditions.length>0)if(e.operator){if(e.operator!==t)throw new SyntaxError("Can not mix operators within a condition grouping")}else e.operator=t}function kf(e){return e.indexOf(".")>-1?e.split(".").map(kf):decodeURIComponent(e)}function bL(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new hn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function OL(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new hn.ClientError("wildcard can only be used at the end of a string")}function NL(e){let t=wL(e[0]);return e.length>1&&(t.next=NL(e.slice(1))),t}function wL(e){if(Array.isArray(e)){let t=wL(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}throw new SyntaxError(`Unknown sort type ${e}`)}function gu(e){return Array.isArray(e)?e.join("\0"):e}function so(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function i3(e,t,r){return t*r/so(e)}var hn,Es,yi,pa,Q4,X4,Z4,e3,pR,mR,n3,hu,s3,pn,ha,mu,Cc,Gf=be(()=>{hn=M(pe()),Es=M(xt()),yi=require("ordered-binary"),pa=require("lmdb");qf();Q4=.3,X4=.1,Z4=.05,e3={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},pR={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(hR,"executeConditions");a(Eu,"searchByIndex");a(bi,"findAttribute");a(t3,"joinTo");a(r3,"joinFrom");mR={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};a(Ff,"filterByType");a(bm,"estimateCondition");n3=/[()[\]|!<>.]|(=\w*=)/,hu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,s3=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(Om,"parseQuery");a(Hf,"parseBlock");a(ym,"assignOperator");a(kf,"decodeProperty");a(bL,"typedDecoding");a(OL,"wildcardDecoding");a(NL,"toSortObject");a(wL,"toSortEntry");mu=class{static{a(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}};a(gu,"flattenKey");a(so,"estimatedEntryCount");a(i3,"intersectionEstimate");Cc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var gR={};ve(gR,{MultiPartId:()=>wm,Resource:()=>$r,snake_case:()=>a3,transformForSelect:()=>Im});function a3(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function IL(e,t){if(Pc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Pc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new wm;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Pc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Pc=!0,null;e[e.length-1]==="/"&&(Pc=!0)}return t.coerceId(decodeURIComponent(e))}function Hn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,f;if(r?(o?(f=i,o=o.getContext?.()||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(f=s,c=f[this.primaryKey]??null,o=i.getContext?.()||i):f=i:(f=s,s=void 0,c=f.getId?.()??f[this.primaryKey]),c===null&&(u=!0)):i?o=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string")if(this.directURLMapping)c=c.slice(1);else{let _=c.indexOf("?");if(_>-1){let S=this.parseQuery(c.slice(_+1));l?S&&(l=Object.assign(S,l)):l=S,c=c.slice(0,_)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let _ of s){if(typeof _=="object"&&_)break;c.push(_)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Cc(c),c==null&&(u=!0);o||(o={});let d;if(l?.ensureLoaded!=null||l?.async||u?(d={...t},l?.ensureLoaded!=null&&(d.ensureLoaded=l.ensureLoaded),l?.async&&(d.async=l.async),u&&(d.isCollection=!0)):d=t,o.transaction){let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)}else return wt(o,()=>{let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)},d);function p(_){if(o.authorize){o.authorize=!1;let h=t.type==="read"?_.allowRead(o.user,l,o):t.type==="update"?_.doesExist?.()===!1?_.allowCreate(o.user,f,o):_.allowUpdate(o.user,f,o):t.type==="create"?_.allowCreate(o.user,f,o):_.allowDelete(o.user,l,o);if(h?.then)return h.then(S=>{if(!S)throw new Nm(o.user);return typeof f?.then=="function"?f.then(g=>e(_,l,o,g)):e(_,l,o,f)});if(!h)throw new Nm(o.user)}return typeof f?.then=="function"?f.then(h=>e(_,l,o,h)):e(_,l,o,f)}a(p,"authorizeActionOnResource")}}function kn(e,t){let r=new DL.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function ER(e,t,r){let n=e.getRecord?.();if(n){let s=e.getChanges?.();return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function Im(e,t){let r=t.propertyResolvers,n=t.getContext?.(),s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):ER(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],f=i(ER(l,r,n));for(let d of e)u.push(f(d));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(p=>p&&typeof p=="object"?c(p):p);let u={},f=i(ER(l,r,n)),d;for(let p of e){let _=f(p);_===void 0&&o&&(_=null),_?.then?(d||(d=[]),d.push(_.then(h=>u[p.name||p]=h))):u[p.name||p]=_}return d?Promise.all(d).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let f=r[c.name]?.definition?.tableClass;l=s[c.name]=Im(c.select||c,f)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var CL,PL,DL,o3,$r,Nm,Pc,wm,Ea=be(()=>{CL=require("crypto");pu();PL=M(Ti()),DL=M(pe());Ic();Gf();o3={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},$r=class{static{a(this,"Resource")}#e;#t;#n;static transactions;static directURLMapping=!1;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=Hn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=Im(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=Hn(function(t,r,n,s){if(Array.isArray(s)&&t.#n){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(f=>f.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):kn(t,"put")},{hasContent:!0,type:"update"});static patch=Hn(function(t,r,n,s){return t.patch?t.patch(s,r):kn(t,"patch")},{hasContent:!0,type:"update"});static delete=Hn(function(t,r,n,s){return t.delete?t.delete(r):kn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,CL.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),wt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):kn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=Hn(function(t,r,n,s){return t.invalidate?t.invalidate(r):kn(t,"delete")},{hasContent:!1,type:"update"});static post=Hn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Hn(function(t,r,n,s){return t.connect?t.connect(s,r):kn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Hn(function(t,r,n,s){return t.subscribe?t.subscribe(r):kn(t,"subscribe")},{type:"read"});static publish=Hn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.publish(s,r):kn(t,"publish")},{hasContent:!0,type:"create"});static search=Hn(function(t,r,n,s){let i=t.search?t.search(r):kn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=Im(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Hn(function(t,r,n,s){return t.search?t.search(s,r):kn(t,"search")},{hasContent:!0,type:"read"});static copy=Hn(function(t,r,n,s){return t.copy?t.copy(s,r):kn(t,"copy")},{hasContent:!0,type:"create"});static move=Hn(function(t,r,n,s){return t.move?t.move(s,r):kn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#n)return(await this.constructor.create(this.#e,t,this.#t)).#e;kn(this,"post")}static isCollection(t){return t&&t.#n}get isCollection(){return this.#n}static coerceId(t){return t}static parseQuery(t){return Om(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1),c=r?.headers&&o3[o];if(c)r.requestedContentType=c,t=t.slice(0,s);else if(this.attributes?.find(l=>l.name===o))if(t=t.slice(0,s),n)n.property=o;else return{query:{property:o},id:IL(t,this),isCollection:Pc}}let i=IL(t,this);return Pc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(f=>f.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let f of l){let d=f.#e,p=u.get(d);p?p.push(f):u.set(d,[f])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s.#n=!0),s}subscribe(t){return new Bn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Bn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,PL._assignPackageExport)("Resource",$r);a(a3,"snake_case");Nm=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(IL,"pathToId");wm=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(Hn,"transactional");a(kn,"missingMethod");a(ER,"selectFromObject");a(Im,"transformForSelect")});var ga,SR=be(()=>{ga=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var vL={};ve(vL,{Resources:()=>Cm,keyArrayToString:()=>Su,resetResources:()=>c3,resources:()=>Oi});function c3(){return Oi=new Cm}function Su(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var LL,ML,Cm,Oi,Tu=be(()=>{Ic();SR();LL=M(z()),ML=M(pe()),Cm=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new ML.ServerError(`Conflicting paths for ${t}`);LL.default.error(c),i.Resource=new ga(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let f=this.get(c.slice(0,u));f&&(f.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,o=t.length;for(;n<o;){s=n,n=t.indexOf("/",n),n===-1&&(n=o);let u=n===o?t:t.slice(0,n),f=this.get(u),d=-1;if(!f&&n===o&&(d=u.indexOf("?",s),d!==-1)){let p=u.slice(0,d);f=this.get(p)}if(f&&(!r||f.exportTypes?.[r]!==!1)){if(f.relativeURL=t.slice(d!==-1?d:n),!f.hasSubPaths)return f;i=f}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return wt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(c3,"resetResources");a(Su,"keyArrayToString")});var Au={};ve(Au,{server:()=>We});var UL,We,Vr=be(()=>{UL=M(Ti()),We={};(0,UL._assignPackageExport)("server",We)});var RR={};ve(RR,{loadGQLSchema:()=>d3,start:()=>AR,startOnMainThread:()=>u3});function AR({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:f}=await import("graphql"),d=o(new c(r.toString(),s)),p=new Map,_=[],h;for(let R of d.definitions)switch(R.kind){case l.OBJECT_TYPE_DEFINITION:let F=function(Y){if(Y.kind==="NonNullType"){let Q=F(Y.type);return Q.nullable=!1,Q}if(Y.kind==="ListType")return{type:"array",elements:F(Y.type)};let se={type:Y.name?.value};return Object.defineProperty(se,"location",{value:Y.loc.startToken}),se};a(F,"getProperty");let E=R.name.value,T=[],b={table:null,database:null,properties:T};p.set(E,b);for(let Y of R.directives){if(Y.name.value==="table"){for(let se of Y.arguments)b[se.name.value]=se.value.value;b.schema&&(b.database=b.schema),b.table||(b.table=E),b.audit&&(b.audit=b.audit!=="false"),b.attributes=b.properties,_.push(b)}if(Y.name.value==="sealed"&&(b.sealed=!0),Y.name.value==="splitSegments"&&(b.splitSegments=!0),Y.name.value==="replicate"&&(b.replicate=!0),Y.name.value==="export"){b.export=!0;for(let se of Y.arguments)typeof b.export!="object"&&(b.export={}),b.export[se.name.value]=se.value.value}}let v=!1,q={};for(let Y of R.fields){let Z=F(Y.type);Z.name=Y.name.value,T.push(Z),q[Z.name]=void 0;for(let se of Y.directives){let Q=se.name.value;if(Q==="primaryKey")v?console.warn("Can not define two attributes as a primary key at",se.loc):(Z.isPrimaryKey=!0,v=!0);else if(Q==="indexed")Z.indexed=!0;else if(Q==="computed"){for(let ne of se.arguments||[])if(ne.name.value==="from"){let J=ne.value.value;Z.computed={from:g(J,ne,q)},Z.version==null&&(Z.version=J)}else ne.name.value==="version"&&(Z.version=ne.value.value);Z.computed=Z.computed||!0}else if(Q==="relationship"){let ne={};for(let J of se.arguments)ne[J.name.value]=J.value.value;Z.relationship=ne}else if(Q==="createdTime")Z.assignCreatedTime=!0;else if(Q==="updatedTime")Z.assignUpdatedTime=!0;else if(Q==="expiresAt")Z.expiresAt=!0;else if(Q==="allow"){let ne=Z.authorizedRoles=[];for(let J of se.arguments)J.name.value==="role"&&ne.push(J.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,se.loc)}}b.type=E,E==="Query"&&(h=b)}function S(R){let E=p.get(R.type);E?(Object.defineProperty(R,"properties",{value:E.properties}),Object.defineProperty(R,"definition",{value:E})):R.type==="array"?S(R.elements):l3.includes(R.type)||(0,BL.getWorkerIndex)()===0&&console.error(`The type ${R.type} is unknown at line ${R.location.line}, column ${R.location.column}, in ${s}`)}a(S,"connectPropertyType");for(let R of p.values())for(let E of R.properties)S(E);for(let R of _)R.tableClass=e(R),R.export&&(R.export.name===""?i.set((0,TR.dirname)(n),R.tableClass):i.set((0,TR.dirname)(n)+"/"+(R.export.name||R.type),R.tableClass,R.export));function g(R,E,T){return new xL.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${R}; } } } } computed;`,{filename:s,lineOffset:E.loc.startToken.line-1,columnOffset:E.loc.startToken.column}).runInThisContext()(T)}a(g,"createComputedFrom")}}var TR,xL,BL,l3,u3,d3,HL=be(()=>{TR=require("path"),xL=require("node:vm");De();BL=M(rt()),l3=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt","Blob"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(AR,"start");u3=AR,d3=AR({ensureTable:ft}).handleFile});var KL={};ve(KL,{parse:()=>bR,streamAsJSON:()=>$f,stringify:()=>Dc});function $f(e){return new yR({value:e})}function kL(e){return console.error(e),JSON.stringify(e.toString())}function FL(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Dc(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===$L)return VL(e);if(t.resolution)return t.resolution.then(()=>Dc(e));throw t}}function VL(e){let t=typeof e;if(t==="object"){if(e===null)return"null";e.toJSON&&(e=e.toJSON());let r;if(Array.isArray(e)){r="[";for(let n=0;n<e.length;n++)n>0&&(r+=","),r+=VL(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Dc(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function bR(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),p3.test(e)?f3.parse(e):JSON.parse(e)):null}var GL,qL,f3,_3,$L,yR,p3,OR=be(()=>{GL=require("stream"),qL=M(require("json-bigint-fixes")),f3=(0,qL.default)({useNativeBigInt:!0}),_3=1e4,$L={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw $L};a($f,"streamAsJSON");yR=class extends GL.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),kL)}catch(s){yield kL(s)}else yield Dc(t)}else yield Dc(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);FL(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>_3?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return FL(this.readIterator(t.childIterator),n=>{if(n)return t.childIterator=null,this.readIterator(t)});do{let n=t.next();if(n.done)return!0;if(r=n.value,r==null)r="null";else{if(r.then)return this.flush(),Promise.resolve(r).then(s=>{if(s&&typeof s.return=="function")return t.childIterator=s,this.readIterator(t);if(this.push(s+""))return this.readIterator(t)});if(typeof r.return=="function")return t.childIterator=r,this.readIterator(t)}}while(this.push(r))}catch(r){return console.error(r),this.push(r.toString()),this.push(null),!0}}_destroy(t,r){for(let n of this.activeIterators)t?n.throw(t):n.return();r()}};a(kL,"handleError");a(FL,"when");a(Dc,"stringify");a(VL,"jsStringify");p3=/[[,:]\s*-?\d{16,}/;a(bR,"parse")});var Ni=w(Dm=>{var Pm=z();for(let e of["trace","debug","info","warn","error","fatal","notify"])Pm.logsAtLevel(e)&&(Dm[e]=Pm[e]);Dm.loggerWithTag=e=>Pm.loggerWithTag(e,!0);Dm.setLogLevel=Pm.setLogLevel});var Gm={};ve(Gm,{Blob:()=>wi,blobsWereEncoded:()=>Mc,databasePaths:()=>vm,decodeBlobsWithWrites:()=>CR,decodeFromDatabase:()=>vc,decodeWithBlobCallback:()=>PR,deleteBlob:()=>eM,deleteBlobsInObject:()=>Ta,deleteRootBlobPathsForDB:()=>IR,encodeBlobsAsBuffers:()=>b3,encodeBlobsWithFilePath:()=>Fm,findBlobsInObject:()=>yu,getFileId:()=>Hm,getFilePathForBlob:()=>rM,getRootBlobPathsForDB:()=>km,setDeletionDelay:()=>g3});function XL(){}function eM(e){let t=rM(e);t&&setTimeout(()=>{(0,Je.unlink)(t,r=>{r&&Sa.default.debug?.("Error trying to remove blob file",r)})},ZL)}function g3(e){ZL=e}function tM(e){let t=En.get(e);if(!t)t={storageIndex:0,fileId:null,store:js},En.set(e,t);else{if(t.saving)return t;t.store=js}return T3(t),t.source?NR(e,t.source,t):t.contentBuffer?S3(e,t):NR(e,Kf.Readable.from(e.stream()),t),t}function NR(e,t,r){let{filePath:n,fileId:s,store:i,compress:o,flush:c}=r;return r.saving=new Promise((l,u)=>{let f=s+":blob";if(!i.attemptLock(f,0))throw new Error(`Unable to get lock for blob file ${s}`);let d=(0,Je.createWriteStream)(n,{autoClose:!1,flags:"w"});if(t.errored){let g=Buffer.from(t.errored.toString());d.end(Buffer.concat([h(BigInt(g.length)+0xff000000000000n),g]));return}let p=!1;e.size!==void 0&&(d.write(h(e.size)),p=!0);let _;o?(p||d.write(m3),_=(0,xm.createDeflate)(),t.pipe(_).pipe(d)):(p||d.write(h3),t.pipe(d)),t.on("error",S);function h(g){let R=BigInt(g),E=new Uint8Array(gr),T=new DataView(E.buffer);return R|=BigInt(o?wR:QL)<<48n,T.setBigInt64(0,R),E}a(h,"createHeader");function S(g){i.unlock(f,0);let R=d.fd;g?(R&&(0,Je.close)(R),u(g)):c?(0,Je.fdatasync)(R,E=>{E&&u(E),l(),(0,Je.close)(R)}):(l(),(0,Je.close)(R))}a(S,"finished"),d.on("error",S).on("finish",()=>{if(p)S();else{let g=_?_.bytesWritten:d.bytesWritten-gr;e.size=g,(0,Je.write)(d.fd,h(g),0,gr,0,S)}})}),e}function Hm(e){return En.get(e)?.fileId}function rM(e){let t=En.get(e);return t?.fileId&&Yf(t)}function km(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=vm.get(e);if(!t){if(!e.databaseName)throw new Error("No database name specified, can not determine blob storage path");let r=(0,Bm.get)(x.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,oo.join)(n,e.databaseName)):t=[(0,oo.join)((0,Bm.getHdbBasePath)(),"blobs",e.databaseName)],vm.set(e,t)}return t}async function IR(e){let t=vm.get(e);t&&await Promise.all(t.map(r=>nM(r)))}async function nM(e){for(let t of await(0,Js.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await nM((0,oo.join)(e,t.name));else try{await(0,Js.unlink)((0,oo.join)(e,t.name))}catch(r){Sa.default.warn?.("Error deleting file",r)}try{await(0,Js.rmdir)(e)}catch(t){Sa.default.warn?.("Error deleting directory",t)}}function Yf({storageIndex:e,fileId:t,store:r}){let n=km(r);return(0,oo.join)(n[e],t.slice(-9,-6)||"0",t.slice(-6,-3)||"0",t.length<=9?t.slice(-3):t.slice(0,-9)+t.slice(-3))}function S3(e,t){let r=t.contentBuffer,n=r.length;if(!(n<JL))return e.size=n,NR(e,Kf.Readable.from([r]),t)}function T3(e){let t=km(e.store),r=A3(),n=t?.length>1?R3(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=Yf(e),o=(0,oo.dirname)(i);(0,Je.existsSync)(o)||(0,jL.ensureDirSync)(o),e.filePath=i}function A3(){let e=zL.get(js);if(!e){let t=0,r=km(js);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let o=0;if((0,Je.existsSync)(n))for(let c of(0,Je.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>o&&(o=l)}s+=o,n=(0,oo.join)(n,o.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(js.getUserSharedBuffer("blob-file-id",e.buffer)),zL.set(js,e)}return Number(Atomics.add(e,0,1n))}function R3(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(Um);for(let i=0;i<s.length;i++)s[i]=i%e.length;e.frequencyTable=s}return(e.lastUpdated??0)+6e4<r&&(e.lastUpdated=r,y3(e)),e.frequencyTable[t%Um]}async function y3(e){if(!Js.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let o=await(0,Js.statfs)(s),c=o.bavail*o.bsize;return Math.pow(c,.8)})),r=new Array(Um),n=t.map(s=>1/s);for(let s=0;s<Um;s++){let i=1/0,o=0;for(let c=0;c<n.length;c++)n[c]<i&&(o=c,i=n[c]);n[o]+=1/t[o],r[s]=o}e.frequencyTable=r}function Fm(e,t,r){Ru=t,js=r,Mc=!1;try{return e()}finally{Ru=void 0,js=void 0}}function b3(e){Dr=[];let t;try{t=e()}catch(n){throw Dr=void 0,n}let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r?r.then(()=>e()):t}function CR(e,t){try{Dr=[],Lc=t,e()}catch(n){throw Lc=void 0,Dr=void 0,n}Lc=void 0;let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r}function PR(e,t){try{return Lc=t,e()}finally{Lc=void 0}}function vc(e,t){return js=t,e()}function Ta(e){yu(e,t=>{eM(t)})}function yu(e,t){if(e instanceof wi)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&yu(r,t);else if(e.constructor===Object)for(let r in e){let n=e[r];typeof n=="object"&&n&&yu(e[r],t)}}function O3(){return class{static{a(this,"Blob")}content;constructor(t){this.content=t[0]}stream(){return new ReadableStream({start(t){t.enqueue(this.content),t.close()}})}text(){return Promise.resolve(this.content.toString())}arrayBuffer(){return Promise.resolve(this.content.buffer)}get size(){return this.content.length}slice(){throw new Error("Not implemented")}bytes(){return Promise.resolve(this.content)}get type(){return""}}}var io,Js,Je,xm,Kf,jL,Bm,oo,Sa,JL,gr,QL,wR,YL,h3,m3,WL,En,Lc,wi,Ru,Dr,js,Mc,Vf,Lm,E3,Mm,ZL,vm,zL,Um,gs=be(()=>{io=require("msgpackr"),Js=require("node:fs/promises"),Je=require("node:fs"),xm=require("node:zlib"),Kf=require("node:stream"),jL=require("fs-extra"),Bm=M(ae());H();oo=require("path"),Sa=M(Ni());ao();JL=8192,gr=8,QL=0,wR=1,YL=255,h3=new Uint8Array([0,QL,255,255,255,255,255,255]),m3=new Uint8Array([0,wR,255,255,255,255,255,255]),WL=0xffffffffffff,En=new WeakMap,wi=global.Blob||O3(),Mc=!1,Vf=new Uint8Array(8),Lm=new DataView(Vf.buffer),E3=6e4;a(XL,"InstanceOfBlobWithNoConstructor");XL.prototype=wi.prototype;Mm=class e extends XL{static{a(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=En.get(this),{start:r,end:n,contentBuffer:s,asString:i}=t;return i||(s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?(t.asString=s.toString(),t.asString):(LR()&&DR(this.bytes().then(o=>t.contentBuffer=o)),`[blob: ${this.type}, ${this.size} bytes]`))}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=En.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=Yf(t),o,c=a(async()=>{let l,u=gr;try{if(l=await(0,Js.readFile)(i),l.length>=gr){l.copy(Vf,0,0,gr);let d=Lm.getBigUint64(0);if(Number(d>>48n)===YL)throw new Error("Error in blob: "+buffer.subarray(gr));if(u=Number(d&0xffffffffffffn),u<n&&(u=n),u<WL&&(this.size=u,this.#t))for(let p of this.#t)p(u)}}catch(d){if(d.code!=="ENOENT")throw d;l=Buffer.alloc(0)}function f(d){if(u>d.length){let p=t.store,_=t.fileId+":blob";if(o)throw new Error("Incomplete blob");return new Promise((h,S)=>{if(p.attemptLock(_,0,()=>(o=!0,p.unlock(_,0),h(c()))))return o=!0,p.unlock(_,0),h(c())})}return(n!=null||r!=null)&&(d=d.subarray(r??0,n??d.length)),d}return a(f,"checkCompletion"),l[1]===wR?new Promise((d,p)=>{(0,xm.deflate)(l.subarray(gr),(_,h)=>{_?p(_):d(f(h))})}):f(l.subarray(gr))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=En.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(S){S.enqueue(r),S.close()}});let i=Yf(t),o,c=0,l=0,u,f,d,p=!1,_=this;return new ReadableStream({start(){let S=1e3,g=a((R,E)=>{(0,Je.open)(i,"r",(T,b)=>{if(T){if(T.code==="ENOENT"&&d!==!1&&(Sa.default.debug?.("File does not exist yet, waiting for it to be created",i,S),S-- >0))return setTimeout(()=>{h(),g(R,E)},20).unref();E(T),_.#e?.forEach(v=>v(T))}else o=b,R(b)})},"openFile");return new Promise(g)},pull:a(S=>{let g=0,R=100;return new Promise(a(function E(T,b){function v(q){(0,Je.close)(o),clearTimeout(f),u&&u.close(),b(q),_.#e?.forEach(Y=>Y(q))}a(v,"onError");let F=Buffer.allocUnsafe(262144);(0,Je.read)(o,F,0,F.length,c,(q,Y,Z)=>{if(l+=Y,q)return v(q);if(c===0){if(Y<gr){R-- >0&&d!==!1?(h(),Sa.default.debug?.("File was empty, waiting for data to be written",i,R),setTimeout(()=>E(T,b),20).unref()):(Sa.default.debug?.("File was empty, throwing error",i,R),b(new Error(`Blob ${t.fileId} was empty`)));return}Z.copy(Vf,0,0,gr);let se=Lm.getBigUint64(0);if(Number(se>>48n)===YL)return v(new Error("Error in blob: "+Z.subarray(gr)));if(g=Number(se&0xffffffffffffn),g<WL&&_.size!==g&&(_.size=g,_.#t))for(let Q of _.#t)Q(g);Z=Z.subarray(gr,Y),l-=gr}else if(Y===0){let se=Buffer.allocUnsafe(8);return(0,Je.read)(o,se,0,gr,0,Q=>{if(Q)return v(Q);if(Vf.set(se),g=Number(Lm.getBigUint64(0)&0xffffffffffffn),g>l){h()?u?f=setTimeout(()=>{v(new Error("File read timed out"))},E3).unref():(u=(0,Je.watch)(i,{persistent:!1},()=>{u.close(),u=null,f&&(clearTimeout(f),f=null,E(T,b))}),E(T,b)):p?v(new Error("Blob is incomplete")):(p=!0,E(T,b));return}(0,Je.close)(o),S.close(),T()})}else Z=Z.subarray(0,Y);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=Y,E(T,b);s&&l>=s&&(l>s&&(Z=Z.subarray(0,s-c)),l=g=s),n&&n>c&&(Z=Z.subarray(n-c))}c+=Y;try{S.enqueue(Z)}catch(se){return Sa.default.debug?.("Error enqueuing chunk",se),T()}l===g&&((0,Je.close)(o),S.close()),T()})},"readMore"))},"pull"),cancel(){(0,Je.close)(o),clearTimeout(f),u&&u.close()}});function h(){if(d===void 0){let S=t.store,g=t.fileId+":blob";d=!S.attemptLock(g,0,()=>{d=!1,S.unlock(g,0)}),d||S.unlock(g,0)}return d}}slice(t,r,n){let s=En.get(this),i=new e(n&&{type:n});if(s?.fileId){let o={...s,start:t,end:r};En.set(i,o),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let o={...s,contentBuffer:s.contentBuffer.subarray(t,r)};En.set(i,o),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(!t?.primaryStore?.rootStore)throw new Error("No target table specified");return tM(this).saving??Promise.resolve()}},ZL=500;a(eM,"deleteBlob");a(g3,"setDeletionDelay");global.createBlob=function(e,t){let r=new Mm(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(En.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Kf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Kf.Readable.from(e);else throw new Error("Invalid source type");return r};a(tM,"saveBlob");a(NR,"writeBlobWithStream");a(Hm,"getFileId");a(rM,"getFilePathForBlob");vm=new Map;a(km,"getRootBlobPathsForDB");a(IR,"deleteRootBlobPathsForDB");a(nM,"rimrafSteadily");a(Yf,"getFilePath");a(S3,"writeBlobWithBuffer");a(T3,"generateFilePath");zL=new Map;a(A3,"getNextFileId");Um=128;a(R3,"getNextStorageIndex");a(y3,"createFrequencyTableForStoragePaths");a(Fm,"encodeBlobsWithFilePath");a(b3,"encodeBlobsAsBuffers");a(CR,"decodeBlobsWithWrites");a(PR,"decodeWithBlobCallback");a(vc,"decodeFromDatabase");a(Ta,"deleteBlobsInObject");a(yu,"findBlobsInObject");(0,io.addExtension)({Class:wi,type:11,unpack:a(function(e){let t=(0,io.unpack)(e),r=new Mm;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(!js)throw new Error("No store specified, can not load blob from storage");if(En.set(r,{storageIndex:t[1],fileId:t[2],store:js}),Lc)return Lc(r)??r}else En.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:a(function(e){let t=En.get(e);if(Ru!==void 0&&(Mc=!0,t?.recordId!==void 0&&t.recordId!==Ru))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<JL)return r.size=t.contentBuffer.length,(0,io.pack)([r,t.contentBuffer])}if(Ru!==void 0){if(t=tM(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Ru,(0,io.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Je.readFileSync)(Yf(t));if(n.length>=gr&&(n.copy(Vf,0,0,gr),Number(Lm.getBigUint64(0)&0xffffffffffffn)===n.length-gr))return Buffer.concat([(0,io.pack)([r]),n]);if(Dr)Dr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&Dr)return Dr.push(e.bytes()),Buffer.alloc(0);throw n}else throw new Error("Blob has no storage info or buffer attached to it")},"pack")});(0,io.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(O3,"polyfillBlob")});var dM={};ve(dM,{asyncSerialization:()=>DR,contentTypes:()=>xR,findBestSerializer:()=>$m,getDeserializer:()=>uo,hasAsyncSerialization:()=>LR,registerContentHandlers:()=>jf,serialize:()=>Jf,serializeMessage:()=>Aa,toCsvStream:()=>qm});function w3(e){try{return e?.[0]===123?UR(e):e}catch{return e}}function jf(e){e.register(C3,{serializers:[{regex:/^application\/json$/,serializer:$f},{regex:/^application\/cbor$/,serializer:a(function(t){return new Uc.EncoderStream(zf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?xc.Readable.from((0,Ii.encodeIter)(t,zf)):(0,Ii.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),qm(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Ii.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Uc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function $m(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[u,...f]=l.split(/\s*;\s*/),d=1,p={q:1};for(let h of f){let S=h.indexOf("=");p[h.substring(0,S)]=h.substring(S+1)}d=+p.q;let _=Kr.get(u);if(_){let h=(_.q||1)*d;h>s&&(n=_,i=_.type||u,s=h,o=p)}}if(!n){if(r)throw new oM.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(Kr.keys()).join(", "),406);n=Kr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Jf(e,t,r){let n=iM&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array||e instanceof wi)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=$m(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&e&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){if(e.mapError){let c=e.getColumns;e=e.mapError(l=>(l.toJSON=()=>({error:l.name,message:l.message,...l.partialObject}),vR.default.warn?.(`Error serializing error ${t?.url||t}: ${l}`),l)),e.getColumns=c}let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,lo.createBrotliCompress)({params:{[lo.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?lo.constants.BROTLI_MODE_TEXT:lo.constants.BROTLI_MODE_GENERIC,[lo.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>iM?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,lo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Aa(e,t,r){if(e?.contentType!=null&&e.data!=null)return e.data;co=r?void 0:[];try{let n;if(t){let s=t.serialize;if(s)n=s(e);else{let i=$m(t);s=t.serialize=i.serializer.serialize,n=s(e)}}else n=Wf(e);return co?.length>0?(co.length===1?co[0]:Promise.all(co)).then(()=>Aa(e,t,!0)):n}finally{co=void 0}}function DR(e){if(co)co.push(e);else throw new Error("Unable to serialize asynchronously")}function LR(){return!!co}function P3(e){return new Promise((t,r)=>{let n=[];e.on("data",s=>n.push(s)),e.on("end",()=>t(Buffer.concat(n))),e.on("error",r)})}function L3(e){return D3.includes(e)}function M3(e){let t=e.indexOf(";"),r;if(t>-1){r={};let n=e.slice(t+1).split(";");for(let s of n){let[i,o]=s.split("=");r[i.trim()]=o.trim()}e=e.slice(0,t)}return{type:e,parameters:r}}function uo(e="",t=!1){let r=M3(e),n=r.type&&Kr.get(r.type)?.deserialize||v3(r);return t?s=>P3(s).then(n):n}function v3(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!L3(e.parameters.charset)&&vR.default.info(`Unknown Buffer encoding ${e.parameters.charset} in content-type. Proceeding anyways.`),t=>({contentType:e.type,data:t.toString(e.parameters?.charset||"utf-8")})):e.type==="application/octet-stream"?t=>t:t=>{if(e.type==="")try{if(t?.[0]===123)return UR(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function U3(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}function qm(e,t){let r=xc.default.Readable.from(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator]?e:[e]),n={};t&&(n.fields=t.map(o=>({label:o,value:o})));let s={objectMode:!0},i=new N3(n,s);return r.pipe(i)}var Ii,Uc,lo,oM,xc,aM,MR,cM,vR,N3,lM,Wf,UR,zf,Kr,xR,sM,uM,I3,C3,iM,co,D3,ao=be(()=>{OR();Ii=require("msgpackr"),Uc=require("cbor-x"),lo=require("zlib"),oM=M(pe()),xc=M(require("stream"));Vr();aM=M(Ti()),MR=M(ae());H();cM=M(require("yaml")),vR=M(Ni());gs();({Transform:N3}=require("json2csv")),lM=MR.default.get(x.SERIALIZATION_BIGINT)!==!1,Wf=lM?Dc:JSON.stringify,UR=lM?bR:JSON.parse,zf={useRecords:!1,useToJSON:!0},Kr=new Map,xR=Kr;We.contentTypes=xR;(0,aM._assignPackageExport)("contentTypes",xR);Kr.set("application/json",{serializeStream:$f,serialize:Wf,deserialize(e){return UR(e)},q:.8});sM=new Uc.Encoder(zf);Kr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Uc.EncoderStream(zf).end(e)},serialize:sM.encode,deserialize:sM.decode,q:1});Kr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?xc.Readable.from((0,Ii.encodeIter)(e,zf)):(0,Ii.pack)(e)},serialize:Ii.pack,deserialize:Ii.unpack,q:.9});Kr.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),qm(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),qm(e,e?.getColumns?.())},q:.1});Kr.set("text/plain",{serialize(e){return e.toString()},serializeStream(e){return xc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Kr.set("text/yaml",{serialize(e){return cM.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Kr.set("text/event-stream",{serializeStream:a(function(e){return xc.Readable.from(U3(e,this.serialize))},"serializeStream"),serialize:a(function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
|
|
9
9
|
`),e.data){let r=e.data;typeof r=="object"&&(r=Wf(r)),t+="data: "+r+`
|
|
10
10
|
`}return e.id&&(t+="id: "+e.id+`
|
|
11
11
|
`),e.retry&&(t+="retry: "+e.retry+`
|
|
@@ -14,125 +14,124 @@ Caused by:`));else if(typeof u=="object")try{n+=JSON.stringify(u)}catch{n+="Obje
|
|
|
14
14
|
|
|
15
15
|
`:`data: ${e}
|
|
16
16
|
|
|
17
|
-
`},"serialize"),compressible:!1,q:.8});Kr.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});aM={type:"application/json",serializeStream:qf,serialize:Wf,deserialize:C3,q:.5};Kr.set("*/*",aM);Kr.set("",aM);a(C3,"tryJSONParse");a(jf,"registerContentHandlers");P3=require("fastify-plugin"),D3=P3(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=qm(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let f=l.getColumns;l=l.mapError(d=>(d.toJSON=()=>({error:d.name,message:d.message,...d.partialObject}),d)),l.getColumns=f}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((f,d)=>{s.header(f,d)},"set")}})})}),r()},{name:"content-type-negotiation"});a(qm,"findBestSerializer");rM=DR.default.get(B.HTTP_COMPRESSIONTHRESHOLD);a(Qf,"serialize");a(Ra,"serializeMessage");a(CR,"asyncSerialization");a(PR,"hasAsyncSerialization");a(L3,"streamToBuffer");M3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(v3,"isBufferEncoding");a(U3,"parseContentType");a(po,"getDeserializer");a(x3,"deserializerUnknownType");a(B3,"transformIterable");a(Gm,"toCsvStream")});var xR={};ve(xR,{start:()=>Y3});function H3(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new br(`Unexpected non-executable definition type ${e.kind}.`)}function lM(e){if(typeof e!="object"||e===null)throw new Di("Request body must be an object.");if(!("query"in e))throw new Di("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Di("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Di("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Di("Request body `operationName` field must be a string.")}function UR(e){return parseInt(e.value,10)}function dM(e){return parseFloat(e.value)}function fM(e,t,r){let n=r.get(e.name.value);return _M(n)?pM(n,t):{attribute:t,value:n}}function _M(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function pM(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],_M(n)?pM(n,t):{attribute:t,value:n}))}function k3(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Le.Kind.NULL:return{attribute:t,value:null};case Le.Kind.INT:return{attribute:t,value:UR(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:dM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return fM(e.value,t,r);case Le.Kind.OBJECT:return hM(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new br(`Value type, ${e.value.kind}, is not supported.`)}}function hM(e,t,r){return e.fields.flatMap(n=>k3(n,t,r))}function F3(e,t){switch(e.value.kind){case Le.Kind.NULL:return{attribute:e.name.value,value:null};case Le.Kind.INT:return{attribute:e.name.value,value:UR(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:dM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return fM(e.value,e.name.value,t);case Le.Kind.OBJECT:return hM(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new br(`Argument type, ${e.value.kind}, is not supported.`)}}function G3(e,t){return e.flatMap(r=>F3(r,t))}function $m(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Le.Kind.FIELD:return r;case Le.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new br(`Fragment \`${n}\` not found.`);return $m(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return $m(r.selectionSet,t)}})}function mM(e,t){return $m(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:mM(r.selectionSet,t)}:r.name.value)}async function q3(e,t,r,n){let s=wi.getMatch(e.name.value,"graphql");if(s===void 0)throw new br(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:mM(e.selectionSet,r),conditions:G3(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(o,n))c.push(l);return[e.name.value,c]}function EM(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return UR(e);case Le.Kind.FLOAT:return parseFloat(e.value);case Le.Kind.STRING:case Le.Kind.BOOLEAN:return e.value;case Le.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:EM(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new br(`Value type, ${e.kind}, is not supported.`)}}function $3(e,t){let r=new Map;for(let n of e){let s=n.variable.name.value,i=t?.[s];if(i===void 0&&n.defaultValue!==void 0&&(i=EM(n.defaultValue)),n.type.kind===Le.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new br(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function V3(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new br("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new br("Mutations are not supported yet.");let s=$3(e.variableDefinitions,t),i=await Promise.all($m(e.selectionSet,r).map(c=>q3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function uM({query:e,variables:t={},operationName:r},n){let s=Le.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(H3(u),u.kind===Le.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new br("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new br(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new br("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new br(`Operation \`${r}\` not found.`);let l=await V3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function K3(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return lM(r),uM(r,e)}case"POST":{let r=await po(e.headers.get("content-type"),!0)(e._nodeRequest);return lM(r),uM(r,e)}default:throw new Di("Method Not Allowed",405,{Allow:"GET, POST"})}}function Y3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await K3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Di)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof br)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof Di)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof br)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Le,br,Di,gM=be(()=>{Le=M(require("graphql"));uo();Su();a(H3,"assertExecutableDefinitionNode");a(lM,"assertRequestParams");a(UR,"processIntValueNode");a(dM,"processFloatValueNode");a(fM,"processVariableNode");a(_M,"isObject");a(pM,"transformObjectIntoQueryCondition");a(k3,"processObjectFieldNode");a(hM,"processObjectValueNode");a(F3,"processArgumentNode");a(G3,"buildConditionsQuery");a($m,"fillInFragments");a(mM,"buildSelectQuery");a(q3,"processFieldNode");a(EM,"processConstValueNode");a($3,"resolveVariables");a(V3,"executeOperation");a(uM,"resolver");br=class extends Error{static{a(this,"GraphQLQueryingError")}},Di=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(K3,"graphqlQueryingHandler");a(Y3,"start")});var Mi=w((Wbe,AM)=>{"use strict";var TM=se(),SM=(H(),C(q)),Ru=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Li=require("joi"),ya={schema_format:{pattern:Ru,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},W3=Li.alternatives(Li.string().min(1).max(ya.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Li.number(),Li.array()).required(),z3=Li.alternatives(Li.string().min(1).max(ya.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Li.number()),j3=Li.alternatives(Li.string().min(1).max(ya.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Li.number()).required();function Q3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ya.schema_length.maximum?`'${e}' maximum of 250 characters`:Ru.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(Q3,"checkValidTable");function J3(e,t){return TM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(J3,"validateSchemaExists");function X3(e,t){let r=t.state.ancestors[0].schema;return TM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(X3,"validateTableExists");function Z3(e,t){return e.toLowerCase()===SM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${SM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(Z3,"validateSchemaName");AM.exports={common_validators:ya,schema_regex:Ru,hdb_schema_table:W3,validateSchemaExists:J3,validateTableExists:X3,validateSchemaName:Z3,checkValidTable:Q3,hdb_database:z3,hdb_table:j3}});var ft=w((jbe,RM)=>{"use strict";var En=require("validate.js");En.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||En.validators.type.checks[t](e)?null:` must be a '${t}' value`};En.validators.type.checks={Object:a(function(e){return En.isObject(e)&&!En.isArray(e)},"Object"),Array:En.isArray,Integer:En.isInteger,Number:En.isNumber,String:En.isString,Date:En.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};En.validators.hasValidFileExt=function(e,t){return En.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};RM.exports={validateObject:eX,validateObjectAsync:tX,validateBySchema:rX};function eX(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=En(e,t,{format:"flat"});return r?new Error(r):null}a(eX,"validateObject");async function tX(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await En.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(tX,"validateObjectAsync");function rX(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(rX,"validateBySchema")});var HR=w((Jbe,bM)=>{var{hdb_table:nX,hdb_database:yM}=Mi(),sX=ft(),BR=require("joi"),iX={undefined:"undefined",null:"null"},oX=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||iX[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),aX=BR.object({database:yM,schema:yM,table:nX,records:BR.array().items(BR.object().custom(oX)).required()});bM.exports=function(e){return sX.validateBySchema(e,aX)}});var NM=w((Zbe,OM)=>{"use strict";var kR=class{static{a(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};OM.exports=kR});var IM=w((tOe,wM)=>{"use strict";var FR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};wM.exports=FR});var MM={};ve(MM,{HAS_EXPIRATION:()=>Ym,HAS_RESIDENCY_ID:()=>WR,HAS_STRUCTURE_UPDATE:()=>zm,LAST_TIMESTAMP_PLACEHOLDER:()=>t_,LOCAL_TIMESTAMP:()=>cX,METADATA:()=>Jf,NEW_TIMESTAMP_PLACEHOLDER:()=>PM,NO_TIMESTAMP:()=>GR,PENDING_LOCAL_TIME:()=>zR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>YR,RecordEncoder:()=>KR,TIMESTAMP_ASSIGN_LAST:()=>uX,TIMESTAMP_ASSIGN_NEW:()=>DM,TIMESTAMP_ASSIGN_PREVIOUS:()=>LM,TIMESTAMP_PLACEHOLDER:()=>Vm,TIMESTAMP_RECORD_PREVIOUS:()=>qR,handleLocalTimeForGets:()=>jm,recordUpdater:()=>jR,removeEntry:()=>Uc});function fX(){return e_[0]=e_[0]^64,lX.getFloat64(0)}function jm(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(o,c){e.readCount++;let l=r.call(this,o,c),u=l?.value,f=u?.[Jf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l&&(l.key=o),l};let n=e.get;e.get=function(o,c){let l=n.call(this,o,c);return l?.[Jf]>=0?l.value:l};let s=e.getRange;e.getRange=function(o){let c=s.call(this,o);return o.valuesForKey?c.map(l=>l?.value):o.values===!1||o.onlyCount?c:c.map(l=>{let u=l.value,f=u[Jf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l})};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let o=i.constructor,c=i.use,l=i.done;o.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,vc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<vc.length;u++){let f=vc[u].deref();(!f||f.isDone||f.isCommitted)&&vc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function jR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,p){d||l==null?yu=i?.localTime?qR|LM:GR:yu=l?i?.localTime?qR|16384:DM|16384:GR;let _=u?.expiresAt;if(_>=0&&(c|=Ym),Zf=c,$R=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:yu>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(VR=E,Zf|=WR,g|=xc),R!==E&&(g|=Bc,R||(R=0)),c&Ym&&(g|=n_),u?.originatingOperation&&(g|=r_),d&&(h.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&qn&&(r.getBinaryFast(i.localTime)||Aa(i.value));let A;if(s!==void 0&&(A=km(()=>e.put(n,s,h),n,e.rootStore),Pc&&(g|=qn)),l){let O=u?.user?.username;if(p&&(km(()=>e.encoder.encode(p),n,e.rootStore),Pc&&(g|=qn)),e.encoder.hasStructureUpdate&&(g|=zm,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,F=r.get(v);if(F){let G=wt(F).previousLocalTime;return A=r.put(v,bu(o,t,n,G,u?.nodeId??server.replication.getThisNodeId(r)??0,O,f,Xf,g,E,R,_),{ifVersion:S}),A}}A=r.put(s===void 0?PM:t_,bu(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,O,f,Xf,g,E,R,_,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return A}catch(R){throw R.message+=" id: "+n+" options: "+h,R}}}function Uc(e,t,r){if(t)return t.value&&t.metadataFlags&qn&&!e.auditStore.getBinaryFast(t.localTime)&&Aa(t.value),e.remove(t.key,r)}var CM,Km,Vm,t_,YR,PM,cX,Jf,e_,lX,GR,DM,uX,LM,qR,Ym,WR,zR,zm,dX,Xf,yu,Zf,$R,VR,KR,vc,Ou=be(()=>{CM=require("msgpackr");ho();Km=M(z());Ts();Ts();Vm=new Uint8Array([1,1,1,1,4,64,0,0]),t_=new Uint8Array([1,1,1,1,1,0,0,0]),YR=new Uint8Array([1,1,1,1,3,64,0,0]),PM=new Uint8Array([1,1,1,1,0,64,0,0]),cX=Symbol("local-timestamp"),Jf=Symbol("metadata"),e_=new Uint8Array(8),lX=new DataView(e_.buffer,0,8),GR=0,DM=0,uX=1,LM=3,qR=4,Ym=16,WR=32,zR=1,zm=256,yu=0,Zf=-1,$R=-1,VR=0,KR=class extends CM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(yu||Zf>=0){let o=0,c=yu;c&&(o+=8,yu=0);let l=Zf,u=$R,f=VR;l>=0&&(o+=4,Zf=-1,u>=0&&(o+=8,$R=-1),f&&(o+=4,VR=0));let d=dX=r.call(this,s,i|2048|o);Xf=d.subarray((d.start||0)+o,d.end);let p=d.start||0;return c&&(Vm[4]=c,Vm[5]=c>>8,d.set(Vm,p),p+=8),Pc&&(l|=qn),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,l|Wm<<24),p+=4,u>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setFloat64(p,u),p+=8),f&&(d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,f)),d}else return Xf=r.call(this,s,i),Xf};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(e_,0,c),c+=8;else for(let p=0;p<8;p++)e_[p]=t[c++];l=fX(),i=t[c]}let u,f;i<32&&(i===Wm?(o=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(o=i|t[c+1]<<5,c+=2),o&Ym&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&WR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=Dc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Jf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:Dc(()=>super.decode(t,r),this.rootStore)}catch(c){return Km.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(fX,"getTimestamp");a(jm,"handleLocalTimeForGets");vc=[];setInterval(()=>{for(let e=0;e<vc.length;e++){let t=vc[e].deref();!t||t.isDone||t.isCommitted?vc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Km.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Km.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(jR,"recordUpdater");a(Uc,"removeEntry")});var s_=w((aOe,UM)=>{"use strict";var vM=ae(),_X=(H(),C(q)),{RecordEncoder:pX}=(Ou(),C(MM));vM.initSync();var hX=vM.get(_X.CONFIG_PARAMS.STORAGE_CACHING)!==!1,QR=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=hX&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:pX})}};UM.exports=QR});var i_=w((lOe,xM)=>{"use strict";var $n=ae(),As=(H(),C(q));$n.initSync();var Qm=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",$n.get(As.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=$n.get(As.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),$n.get(As.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=$n.get(As.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=$n.get(As.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};xM.exports=Qm;Qm.MAX_DBS=1e4});var _t=w((dOe,YM)=>{"use strict";var XR=require("lmdb"),Xs=require("fs-extra"),Vn=require("path"),Jm=_n(),kM=z(),gn=Bn().LMDB_ERRORS_ENUM,Xm=IM(),ZR=s_(),FM=i_(),ba=vt(),BM=(H(),C(q)),{table:mX,resetDatabases:EX}=(Pe(),C(tt)),HM=ae(),Zs=ba.INTERNAL_DBIS_NAME,GM=ba.DBI_DEFINITION_NAME,gX="data.mdb",SX="lock.mdb",o_=".mdb",TX="-lock",JR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Rs(t,r),this.key_type=this.dbi[ba.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ba.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new XR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Zm(e,t){if(e===void 0)throw new Error(gn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(gn.ENV_NAME_REQUIRED)}a(Zm,"pathEnvNameValidation");async function ey(e,t,r=!0){try{await Xs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(gn.INVALID_BASE_PATH):n}try{let n=Vn.join(e,t+o_);return await Xs.access(n,Xs.constants.R_OK|Xs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Xs.access(Vn.join(e,t,gX),Xs.constants.R_OK|Xs.constants.F_OK),Vn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(gn.INVALID_ENVIRONMENT)}else throw new Error(gn.INVALID_ENVIRONMENT);throw n}}a(ey,"validateEnvironmentPath");function eE(e,t){if(Jm.validateEnv(e),t===void 0)throw new Error(gn.DBI_NAME_REQUIRED)}a(eE,"validateEnvDBIName");async function AX(e,t,r=!1,n=!1){Zm(e,t);let s=Vn.basename(e);t=t.toString();let i=HM.get(BM.CONFIG_PARAMS.DATABASES);i||HM.setProperty(BM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ey(e,t,n),qM(e,t,r)}catch(o){if(o.message===gn.INVALID_ENVIRONMENT){let c=Vn.join(e,t);await Xs.mkdirp(n?c:e);let l=new FM(n?c:c+o_,!1),u=XR.open(l);u.dbis=Object.create(null);let f=new ZR(!1);u.openDB(Zs,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=ty(e,t,r);return u[ba.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(AX,"createEnvironment");async function RX(e,t,r,n=!0){Zm(e,t),t=t.toString();let s=Vn.join(e,t);return mX({table:t,database:Vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(RX,"copyEnvironment");async function qM(e,t,r=!1){Zm(e,t),t=t.toString();let n=ty(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await ey(e,t),i=Vn.join(e,t+o_),o=s!=i,c=new FM(s,o),l=XR.open(c);l.dbis=Object.create(null);let u=VM(l);for(let f=0;f<u.length;f++)Rs(l,u[f]);return l[ba.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(qM,"openEnvironment");async function yX(e,t,r=!1){Zm(e,t),t=t.toString();let n=Vn.join(e,t+o_),s=await ey(e,t);if(global.lmdb_map!==void 0){let i=ty(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await $M(o),delete global.lmdb_map[i]}}await Xs.remove(s),await Xs.remove(s===n?s+TX:Vn.join(Vn.dirname(s),SX))}a(yX,"deleteEnvironment");async function $M(e){Jm.validateEnv(e);let t=e[ba.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a($M,"closeEnvironment");function ty(e,t,r=!1){let s=`${Vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(ty,"getCachedEnvironmentName");function bX(e){Jm.validateEnv(e);let t=Object.create(null),r=Rs(e,Zs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Zs)try{t[n]=Object.assign(new Xm,s)}catch{kM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(bX,"listDBIDefinitions");function VM(e){Jm.validateEnv(e);let t=[],r=Rs(e,Zs);for(let{key:n}of r.getRange({start:!1}))n!==Zs&&t.push(n);return t}a(VM,"listDBIs");function OX(e,t){let n=Rs(e,Zs).getEntry(t),s=new Xm;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{kM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(OX,"getDBIDefinition");function KM(e,t,r,n=!r){if(eE(e,t),t=t.toString(),t===Zs)throw new Error(gn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Rs(e,t)}catch(s){if(s.message===gn.DBI_DOES_NOT_EXIST){let i=new ZR(r,n===!0),o=e.openDB(t,i),c=new Xm(r===!0,n);return o[GM]=c,Rs(e,Zs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(KM,"createDBI");function Rs(e,t){if(eE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Zs?r=OX(e,t):r=new Xm,r===void 0)throw new Error(gn.DBI_DOES_NOT_EXIST);let n;try{let s=new ZR(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(gn.DBI_DOES_NOT_EXIST):s}return n[GM]=r,e.dbis[t]=n,n}a(Rs,"openDBI");function NX(e,t){eE(e,t),t=t.toString();let r=Rs(e,t),n=r.getStats();return r[ba.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(NX,"statDBI");async function wX(e,t){try{let r=Vn.join(e,t+o_);return(await Xs.stat(r)).size}catch{throw new Error(gn.INVALID_ENVIRONMENT)}}a(wX,"environmentDataSize");function IX(e,t){if(eE(e,t),t=t.toString(),t===Zs)throw new Error(gn.CANNOT_DROP_INTERNAL_DBIS_NAME);Rs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Rs(e,Zs).removeSync(t)}a(IX,"dropDBI");function CX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Rs(e,i)}catch(o){if(o.message===gn.DBI_DOES_NOT_EXIST)KM(e,i,i!==t,i===t),n=!0;else throw o}}n&&EX()}a(CX,"initializeDBIs");YM.exports={openDBI:Rs,openEnvironment:qM,createEnvironment:AX,listDBIs:VM,listDBIDefinitions:bX,createDBI:KM,dropDBI:IX,statDBI:NX,deleteEnvironment:yX,initializeDBIs:CX,TransactionCursor:JR,environmentDataSize:wX,copyEnvironment:RX,closeEnvironment:$M}});var zM=w((_Oe,WM)=>{"use strict";var ry=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};WM.exports=ry});var QM=w((hOe,jM)=>{"use strict";var ny=class{static{a(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};jM.exports=ny});var XM=w((EOe,JM)=>{"use strict";var sy=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};JM.exports=sy});var kc=w((ROe,tv)=>{"use strict";var PX=_t(),DX=zM(),LX=QM(),MX=XM(),vi=_n(),a_=Bn().LMDB_ERRORS_ENUM,vX=vt(),mo=(H(),C(q)),UX=se(),xX=require("uuid"),SOe=require("lmdb"),{handleHDBError:BX,hdb_errors:HX}=pe(),{OVERFLOW_MARKER:TOe,MAX_SEARCH_KEY_LENGTH:AOe}=vX,ZM=ae();ZM.initSync();var tE=ZM.get(mo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),iy=mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Hc=mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function kX(e,t,r,n,s=vi.getNextMonotonicTime()){ly(e,t,r,n),oy(e,t,r);let i=new DX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];ev(u,!0,s);let f=FX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return ay(o,c,n,i,s)}a(kX,"insertRecords");function FX(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let f=c([[{}]]);Array.isArray(f)&&(c=f[0][mo.FUNC_VAL],n[o]=c)}let l=vi.getIndexedValues(c),u=e.dbis[o];if(l){tE&&u.prefetch(l.map(f=>({key:f,value:s})),rE);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}tE&&e.dbis[t].prefetch([s],rE),e.dbis[t].put(s,n,n[Hc])})}a(FX,"insertRecord");function GX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(GX,"removeSkippedRecords");function ev(e,t,r){let n=r>0;(n||!Number.isInteger(e[Hc]))&&(e[Hc]=r||(r=vi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[iy]))&&(e[iy]=r||vi.getNextMonotonicTime()):delete e[iy]}a(ev,"setTimestamps");function oy(e,t,r){r.indexOf(mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),PX.initializeDBIs(e,t,r)}a(oy,"initializeTransaction");async function qX(e,t,r,n,s=vi.getNextMonotonicTime()){ly(e,t,r,n),oy(e,t,r);let i=new LX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],p;try{p=cy(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(p),l.push(d)}return ay(c,l,n,i,s,o)}a(qX,"updateRecords");async function $X(e,t,r,n,s=vi.getNextMonotonicTime()){try{ly(e,t,r,n)}catch(l){throw BX(l,l.message,HX.HTTP_STATUS_CODES.BAD_REQUEST)}oy(e,t,r);let i=new MX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;UX.isEmpty(u[t])?(f=xX.v4(),u[t]=f):f=u[t];let d=cy(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return ay(o,c,n,i,s)}a($X,"upsertRecords");async function ay(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||vi.getNextMonotonicTime(),GX(r,i),n}a(ay,"finalizeWrite");function cy(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,f=u;if(!u){if(i)return!1;u={}}if(ev(r,!f,o),Number.isInteger(r[Hc])&&u[Hc]>r[Hc])return!1;f&&s.original_records.push(u);let d,p=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let S=r[h],g=e.dbis[h];if(g===void 0)continue;let R=u[h];if(typeof S=="function"){let A=S([[u]]);Array.isArray(A)&&(S=A[0][mo.FUNC_VAL],r[h]=S)}if(S===R)continue;let E=vi.getIndexedValues(R);if(E){tE&&g.prefetch(E.map(A=>({key:A,value:n})),rE);for(let A=0,O=E.length;A<O;A++)g.remove(E[A],n)}if(E=vi.getIndexedValues(S),E){tE&&g.prefetch(E.map(A=>({key:A,value:n})),rE);for(let A=0,O=E.length;A<O;A++)g.put(E[A],n)}}let _={...u,...r};c.put(n,_,_[Hc])},"do_put");return l?d=c.ifVersion(n,l.version,p):d=c.ifNoExists(n,p),d.then(_=>_?!0:cy(e,t,r,n,s,i,o))}a(cy,"updateUpsertRecord");function VX(e,t,r){if(vi.validateEnv(e),t===void 0)throw new Error(a_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(a_.WRITE_ATTRIBUTES_REQUIRED):new Error(a_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(VX,"validateBasic");function ly(e,t,r,n){if(VX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(a_.RECORDS_REQUIRED):new Error(a_.RECORDS_MUST_BE_ARRAY)}a(ly,"validateWrite");function rE(){}a(rE,"noop");tv.exports={insertRecords:kX,updateRecords:qX,upsertRecords:$X}});var Eo=w((bOe,KX)=>{KX.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"revoked_certificates"},{attribute:"shard"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var nE=w((OOe,rv)=>{var{common_validators:Ui}=Mi(),l_=ft(),c_="is required",er={database:{presence:!1,format:Ui.schema_format,length:Ui.schema_length},schema:{presence:!1,format:Ui.schema_format,length:Ui.schema_length},table:{presence:!0,format:Ui.schema_format,length:Ui.schema_length},attribute:{presence:!0,format:Ui.schema_format,length:Ui.schema_length},hash_attribute:{presence:!0,format:Ui.schema_format,length:Ui.schema_length}};function u_(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(u_,"makeAttributesStrings");function YX(e){return e=u_(e),er.table.presence=!1,er.attribute.presence=!1,er.hash_attribute.presence=!1,l_.validateObject(e,er)}a(YX,"schema_object");function WX(e){return e=u_(e),er.table.presence={message:c_},er.attribute.presence=!1,er.hash_attribute.presence=!1,l_.validateObject(e,er)}a(WX,"table_object");function zX(e){return e=u_(e),er.table.presence={message:c_},er.attribute.presence=!1,l_.validateObject(e,er)}a(zX,"create_table_object");function jX(e){return e=u_(e),er.table.presence={message:c_},er.attribute.presence={message:c_},er.hash_attribute.presence=!1,l_.validateObject(e,er)}a(jX,"attribute_object");function QX(e){return e=u_(e),er.table.presence={message:c_},er.attribute.presence=!1,er.hash_attribute.presence=!1,l_.validateObject(e,er)}a(QX,"describe_table");function JX(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(JX,"validateTableResidence");rv.exports={schema_object:YX,create_table_object:zX,table_object:WX,attribute_object:jX,describe_table:QX,validateTableResidence:JX}});var sv=w((wOe,nv)=>{"use strict";var XX=require("uuid"),uy=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||XX.v4(),this.schema_table=`${this.schema}.${this.table}`}};nv.exports=uy});var sE=w((COe,iv)=>{"use strict";var ZX=sv(),dy=class extends ZX{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};iv.exports=dy});var av=w((DOe,ov)=>{"use strict";ov.exports=t6;var e6="inserted";function t6(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===e6?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(t6,"returnObject")});var iE=w((vOe,dv)=>{"use strict";var r6=(H(),C(q)),fy=_t(),n6=kc(),{getSystemSchemaPath:s6,getSchemaPath:i6}=gt(),MOe=Eo(),o6=nE(),a6=sE(),c6=av(),{handleHDBError:cv,hdb_errors:uv}=pe(),lv=se(),{HTTP_STATUS_CODES:l6}=uv,u6="inserted";dv.exports=d6;async function d6(e){let t=o6.attribute_object(e);if(t)throw cv(new Error,t.message,uv.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&lv.checkGlobalSchemaTable(e.schema,e.table);if(r)throw cv(new Error,r,l6.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=lv.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new a6(e.schema,e.table,e.attribute,e.id);try{let i=await fy.openEnvironment(i6(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);fy.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await fy.openEnvironment(s6(),r6.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await n6.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return c6(u6,c,{records:[s]},l)}catch(i){throw i}}a(d6,"lmdbCreateAttribute")});var d_=w((BOe,_v)=>{"use strict";var go=se(),fv=z(),xOe=HR(),{getDatabases:f6}=(Pe(),C(tt)),{ClientError:Fc}=pe();_v.exports=_6;function _6(e){if(go.isEmpty(e))throw new Fc("invalid update parameters defined.");if(go.isEmptyOrZeroLength(e.schema))throw new Fc("invalid schema specified.");if(go.isEmptyOrZeroLength(e.table))throw new Fc("invalid table specified.");if(!Array.isArray(e.records))throw new Fc("records must be an array");let t=f6()[e.schema]?.[e.table];if(go.isEmpty(t))throw new Fc(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&go.isEmptyOrZeroLength(o[r]))throw fv.error("a valid hash attribute must be provided with update record:",o),new Fc("a valid hash attribute must be provided with update record, check log for more info");if(!go.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw fv.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Fc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!go.isEmpty(o[r])&&o[r]!==""&&n.has(go.autoCast(o[r]))&&(o.skip=!0),n.add(go.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(_6,"insertUpdateValidate")});var hv=w((kOe,pv)=>{"use strict";var _y=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};pv.exports=_y});var gv=w((GOe,Ev)=>{"use strict";var py=_t(),p6=z(),mv=Bn().LMDB_ERRORS_ENUM;Ev.exports=h6;async function h6(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 py.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==mv.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await py.closeEnvironment(global.lmdb_map[n]),await py.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==mv.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){p6.error(t)}}a(h6,"cleanLMDBMap")});var Dv=w((VOe,Pv)=>{"use strict";var hy=require("recursive-iterator"),m6=require("alasql"),my=require("clone"),Sv=se(),{handleHDBError:Tv,hdb_errors:E6}=pe(),{HDB_ERROR_MSGS:Av,HTTP_STATUS_CODES:Rv}=E6,{getDatabases:g6}=(Pe(),C(tt)),S6=["DISTINCT_ARRAY"],yv=Symbol("validateTables"),Ey=Symbol("validateTable"),$Oe=Symbol("getAllColumns"),bv=Symbol("validateAllColumns"),oE=Symbol("findColumn"),Ov=Symbol("validateOrderBy"),f_=Symbol("validateSegment"),gy=Symbol("validateColumn"),Nv=Symbol("setColumnsForTable"),wv=Symbol("checkColumnsForAsterisk"),Iv=Symbol("validateGroupBy"),Cv=Symbol("hasColumns"),Sy=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[yv](),this[wv](),this[bv]()}[yv](){if(this[Cv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Ey](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Ey](t.table)})}}[Cv](){let t=!1,r=new hy(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Ey](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=g6();if(!r[t.databaseid])throw Tv(new Error,Av.SCHEMA_NOT_FOUND(t.databaseid),Rv.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Tv(new Error,Av.TABLE_NOT_FOUND(t.databaseid,t.tableid),Rv.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=my(s);i.table=my(t),this.attributes.push(i)})}[oE](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)}[wv](){let t=new hy(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[Nv](r.tableid)}[Nv](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new m6.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[bv](){this[f_](this.statement.columns,!1),this[f_](this.statement.joins,!1),this[f_](this.statement.where,!1),this[Iv](this.statement.group,!1),this[f_](this.statement.order,!0)}[f_](t,r){if(!t)return;let n=new hy(t),s=[];for(let{node:i,path:o}of n)!Sv.isEmpty(i)&&!Sv.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Ov](i):s.push(this[gy](i)));return s}[Iv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&S6.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=my(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[oE](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[oE](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[Ov](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[gy](t)}[gy](t){let r=this[oE](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};Pv.exports=Sy});var Uv=w((YOe,vv)=>{"use strict";var Lv=require("lodash"),__=require("mathjs"),T6=require("jsonata"),Mv=se();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Lv.uniqWith(e,Lv.isEqual):e,"distinct_array"),searchJSON:A6,mad:p_.bind(null,__.mad),mean:p_.bind(null,__.mean),mode:p_.bind(null,__.mode),prod:p_.bind(null,__.prod),median:p_.bind(null,__.median)};function p_(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(p_,"aggregateFunction");function A6(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(Mv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Mv.isEmpty(this.__ala__.res[r])){let n=T6(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(A6,"searchJSON")});var Bv=w((zOe,xv)=>{"use strict";var tr=require("moment"),Ty="YYYY-MM-DDTHH:mm:ss.SSSZZ";tr.suppressDeprecationWarnings=!0;xv.exports={current_date:a(()=>tr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>tr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return tr(e).utc().format("YYYY");case"month":return tr(e).utc().format("MM");case"day":return tr(e).utc().format("DD");case"hour":return tr(e).utc().format("HH");case"minute":return tr(e).utc().format("mm");case"second":return tr(e).utc().format("ss");case"millisecond":return tr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>tr(e).utc().format(Ty),"date"),date_format:a((e,t)=>tr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>tr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>tr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=tr(e).utc(),s=tr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>tr().utc().valueOf(),"now"),get_server_time:a(()=>tr().format(Ty),"get_server_time"),offset_utc:a((e,t)=>tr(e).utc().utcOffset(t).format(Ty),"offset_utc")}});var Gv=w((QOe,Fv)=>{"use strict";var R6=require("@turf/area"),y6=require("@turf/length"),b6=require("@turf/circle"),O6=require("@turf/difference"),N6=require("@turf/distance"),w6=require("@turf/boolean-contains"),I6=require("@turf/boolean-equal"),C6=require("@turf/boolean-disjoint"),P6=require("@turf/helpers"),Hv=(H(),C(q)),Ge=se(),So=z();Fv.exports={geoArea:D6,geoLength:L6,geoCircle:M6,geoDifference:v6,geoDistance:kv,geoNear:U6,geoContains:x6,geoEqual:B6,geoCrosses:H6,geoConvert:k6};function D6(e){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return R6.default(e)}catch(t){return So.trace(t,e),NaN}}a(D6,"geoArea");function L6(e,t){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return y6.default(e,{units:t||"kilometers"})}catch(r){return So.trace(r,e),NaN}}a(L6,"geoLength");function M6(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return b6.default(e,t,{units:r||"kilometers"})}catch(n){return So.trace(n,e,t),NaN}}a(M6,"geoCircle");function v6(e,t){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return O6(e,t)}catch(r){return So.trace(r,e,t),NaN}}a(v6,"geoDifference");function kv(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return N6.default(e,t,{units:r||"kilometers"})}catch(n){return So.trace(n,e,t),NaN}}a(kv,"geoDistance");function U6(e,t,r,n){if(Ge.isEmpty(e)||Ge.isEmpty(t))return!1;if(Ge.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return kv(e,t,n)<=r}catch(s){return So.trace(s,e,t),!1}}a(U6,"geoNear");function x6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return w6.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(x6,"geoContains");function B6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return I6.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(B6,"geoEqual");function H6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return!C6.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(H6,"geoCrosses");function k6(e,t,r){if(Ge.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Ge.isEmpty(t))throw new Error("geo_type is required");if(Ge.isEmpty(Hv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Hv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ge.autoCastJSON(e)),P6[t](e,r)}a(k6,"geoConvert")});var aE=w((XOe,qv)=>{var Gc=Uv(),Kn=Bv(),xi=Gv();qv.exports=e=>{e.aggr.mad=e.aggr.MAD=Gc.mad,e.aggr.mean=e.aggr.MEAN=Gc.mean,e.aggr.mode=e.aggr.MODE=Gc.mode,e.aggr.prod=e.aggr.PROD=Gc.prod,e.aggr.median=e.aggr.MEDIAN=Gc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Gc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Gc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Kn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Kn.current_time,e.fn.extract=e.fn.EXTRACT=Kn.extract,e.fn.date=e.fn.DATE=Kn.date,e.fn.date_format=e.fn.DATE_FORMAT=Kn.date_format,e.fn.date_add=e.fn.DATE_ADD=Kn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Kn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Kn.date_diff,e.fn.now=e.fn.NOW=Kn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Kn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Kn.get_server_time,e.fn.getdate=e.fn.GETDATE=Kn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Kn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=xi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=xi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=xi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=xi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=xi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=xi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=xi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=xi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=xi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=xi.geoNear}});var Yv=w((ZOe,Kv)=>{"use strict";var h_=require("lodash"),Sn=require("alasql");Sn.options.cache=!1;var F6=aE(),$v=require("clone"),cE=require("recursive-iterator"),Ue=z(),We=se(),Nu=Yn(),G6=(H(),C(q)),{hdb_errors:q6}=pe(),{getDatabases:Vv}=(Pe(),C(tt)),$6="IS NULL",ei="There was a problem performing this search. Please check the logs and try again.";F6(Sn);var Ay=class{static{a(this,"SQLSearch")}constructor(t,r){if(We.isEmpty(t))throw Ue.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),We.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!We.isEmptyOrZeroLength(n))return Ue.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Ue.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Ue.error(n),new Error(ei)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Ue.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Ue.error(n),new Error(ei)}if(Object.keys(this.data).length===0)return Ue.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Ue.error("Error thrown from processJoins in SQLSearch class method search."),Ue.error(n),new Error(ei)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Ue.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Ue.error(n),new Error(ei)}try{return t=await this._finalSQL(),t}catch(n){throw Ue.error("Error thrown from finalSQL in SQLSearch class method search."),Ue.error(n),new Error(ei)}}_getColumns(){let t=new cE(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push($v(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=h_.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=Vv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(We.isEmpty(this.statement.where)){Ue.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new cE(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!We.isEmpty(r)&&r.right)if(We.isNotEmptyAndHasValue(r.right.value)){let n=We.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Sn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=We.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Sn.yy.LogicValue({value:i}):n instanceof Sn.yy.StringValue&&We.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Sn.yy.NumValue({value:i}))});if(t){Ue.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new cE(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!We.isEmpty(G6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(We.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(We.isEmptyOrZeroLength(r.left.columnid)||We.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(We.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!We.isEmpty(r.right.value)||!We.isEmpty(r.left.value)?n.add(We.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(We.isEmptyOrZeroLength(this.all_table_attributes)&&We.isEmptyOrZeroLength(this.statement.from)&&We.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&h_.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(We.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);We.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(We.isEmptyOrZeroLength(this.all_table_attributes)&&!We.isEmptyOrZeroLength(this.columns.columns))return t;if(We.isEmptyOrZeroLength(this.all_table_attributes)&&We.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Sn.promise(r)}catch(r){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Ue.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push($v(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(We.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf($6)>-1&&this.tables.forEach(s=>{let i={columnid:Vv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=h_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!We.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!We.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let f=await Nu.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(f),new Error(ei)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let p=await Nu.getDataByValue(d);for(let[_,h]of p)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,_))}))}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(f),new Error(ei)}else if(!We.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!We.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,p=f.length;d<p;d++){let _=f[d];c.search_attribute=_.attribute,c.search_value=_.search_value;let h=await Nu.getDataByValue(c,_.operation);if(l)for(let[S]of h)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of h)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(f),new Error(ei)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await Nu.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,p]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(f),new Error(ei)}}}_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 Sn.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new Sn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Sn.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new Sn.yy.FuncValue:new Sn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(_=>{_.joinmode&&_.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(_.table);let h=_.joinmode+" JOIN ? AS "+(_.as?_.as:_.table.tableid);_.on&&(h+=" ON "+_.on.toString()),i.push(h),t.push(Object.values(this.data[`${_.table.databaseid_orig}_${_.table.as?_.table.as_orig:_.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(_=>{let h=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__hash_name,S=_.as?_.as_orig:_.tableid_orig;o.push({key:`'${S}.${h}'`,schema:_.databaseid_orig,table:_.as?_.as_orig:_.tableid_orig,keys:new Set}),r.push(`${_.as?_.as:_.tableid}.\`${h}\` AS "${S}.${h}"`),c[_.as?_.as_orig:_.tableid_orig]=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let 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(_=>{_.is_func?r.push(_.initial_select_column.toString()):_.initial_select_column.tableid?r.push(`${_.initial_select_column.tableid}.${_.initial_select_column.columnid} AS ${_.expression.columnid}`):r.push(`${_.initial_select_column.columnid} AS ${_.expression.columnid}`)}));let f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let p=[];try{let _=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,h=this._convertColumnsToIndexes(_,s);p=await Sn.promise(h,t),t=null}catch(_){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(_),new Error("There was a problem processing the data.")}if(p&&p.length>0){for(let _=0,h=p.length;_<h;_++){let S=p[_];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(_=>{let h=Object.keys(this.data[`${_.schema}_${_.table}`].__merged_data),S=h_.difference(h,[..._.keys].map(g=>g.toString()));for(let g=0,R=S.length;g<R;g++){let E=S[g];delete this.data[`${_.schema}_${_.table}`].__merged_data[E]}})}return{existing_attributes:c,joined_length:p?p.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new cE(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=h_.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw Ue.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Ue.error(i),new Error(ei)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let f in i)o.push(i[f][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await Nu.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let p=o[f],_=l.get(p);for(let h=0;h<u;h++){let S=s.columns[h],g=_[S]===void 0?null:_[S];this.data[n].__merged_data[p].push(g)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();Ue.trace(`Final SQL: ${s}`),n=await Sn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ue.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ue.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return Ue.error(q6.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),f=`${l}.[${c}]`;n=n.replace(u,f)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Nu.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Ue.error("There was an error when processing this SQL operation. Check your logs"),Ue.error(o),new Error(ei)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Kv.exports=Ay});var Yr=w((tNe,Wv)=>{"use strict";var V6=Dv();Wv.exports={searchByConditions:Y6,searchByHash:W6,searchByValue:z6,search:j6};var Ry=Yn(),{transformReq:yy}=se(),K6=Yv();async function Y6(e){return yy(e),Ry.searchByConditions(e)}a(Y6,"searchByConditions");async function W6(e){yy(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of Ry.searchByHash(e))r&&t.push(r);return t}a(W6,"searchByHash");async function z6(e){yy(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of Ry.searchByValue(e))t.push(r);return t}a(z6,"searchByValue");function j6(e,t){try{let r=new V6(e);r.validate(),new K6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(j6,"search")});var To=w((nNe,Jv)=>{"use strict";var m_=require("crypto"),Q6=ae(),{CONFIG_PARAMS:J6}=(H(),C(q)),jv="aes-256-cbc",X6=32,Z6=16,by=64,Qv=32,eZ=by+Qv,zv=new Map;Jv.exports={encrypt:tZ,decrypt:rZ,createNatsTableStreamName:nZ};function tZ(e){let t=m_.randomBytes(X6),r=m_.randomBytes(Z6),n=m_.createCipheriv(jv,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(tZ,"encrypt");function rZ(e){let t=e.substr(0,by),r=e.substr(by,Qv),n=e.substr(eZ,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=m_.createDecipheriv(jv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(rZ,"decrypt");function nZ(e,t){let r=Q6.get(J6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=zv.get(r);return n||(n=m_.createHash("md5").update(r).digest("hex"),zv.set(r,n)),n}a(nZ,"createNatsTableStreamName")});var Ao=w((oNe,eU)=>{"use strict";var iNe=Yr(),E_=z(),Xv=nE(),sZ=To(),lE=se(),{handleHDBError:uE,hdb_errors:iZ}=pe(),{HDB_ERROR_MSGS:dE,HTTP_STATUS_CODES:Oy}=iZ,Zv=ae();Zv.initSync();var{getDatabases:Ny}=(Pe(),C(tt)),oZ=require("fs-extra"),aZ=(H(),C(q));eU.exports={describeAll:cZ,describeTable:fE,describeSchema:lZ};async function cZ(e={}){try{let t=lE.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=Ny(),o={},c={},l=[],u=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let p=i[d];for(let _ in p)try{let h;if(t||s||r)h=await fE({schema:d,table:_,exact_count:u});else if(n&&n[d].describe&&n[d].tables[_].describe){let S=n[d].tables[_].attribute_permissions;h=await fE({schema:d,table:_,exact_count:u},S)}h&&l.push(h)}catch(h){E_.error(h)}}let f={};for(let d in l)t||s||r?(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?f[d]={}:c[d]&&(f[d]={});return f}catch(t){return E_.error("Got an error in describeAll"),E_.error(t),uE(new Error,dE.DESCRIBE_ALL_ERR)}}a(cZ,"describeAll");async function fE(e,t){lE.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=Xv.describe_table(e);if(i)throw i;let c=Ny()[r];if(!c)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),Oy.NOT_FOUND);let l=c[n];if(!l)throw uE(new Error,dE.TABLE_NOT_FOUND(e.schema,e.table),Oy.NOT_FOUND);function u(_){f.push({attribute:_.attribute,type:_.type,elements:_.elements?.type,indexed:_.indexed,is_primary_key:_.isPrimaryKey,assigned_created_time:_.assignCreatedTime,assigned_updated_time:_.assignUpdatedTime,nullable:_.nullable,properties:_.properties?_.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let f=[];if(s){let _={};s.forEach(h=>{h.describe&&(_[h.attribute_name]=!0)}),l.attributes.forEach(h=>{_[h.name]&&u(h)})}else l.attributes?.forEach(_=>u(_));let d;try{d=(await oZ.stat(l.primaryStore.env.path)).size}catch(_){E_.warn("unable to get database size",_)}let p={schema:r,name:l.tableName,hash_attribute:l.attributes.find(_=>_.isPrimaryKey||_.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:f,db_size:d};l.replicate!==void 0&&(p.replicate=l.replicate),l.expirationMS!==void 0&&(p.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(p.sealed=l.sealed),l.sources?.length>0&&(p.sources=l.sources.map(_=>_.name).filter(_=>_&&_!=="NATSReplicator"&&_!=="Replicator")),Zv.get(aZ.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(p.clustering_stream_name=sZ.createNatsTableStreamName(p.schema,p.name));try{let _=await l.getRecordCount({exactCount:e.exact_count==="true"});p.record_count=_.recordCount,p.table_size=l.getSize(),p.db_audit_size=l.getAuditSize(),p.estimated_record_range=_.estimatedRange;let h=l.auditStore;if(h)for(let S of h.getKeys({reverse:!0,limit:1}))p.last_updated_record=S[0];if(!p.last_updated_record&&l.indices.__updatedtime__)for(let S of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))p.last_updated_record=S}catch(_){E_.warn(`unable to stat table dbi due to ${_}`)}return p}a(fE,"descTable");async function lZ(e){lE.transformReq(e);let t=Xv.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=Ny()[n];if(!i)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),Oy.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),lE.isEmpty(l)||l.describe){let u=await fE({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(lZ,"describeSchema")});var ys=w((uNe,iU)=>{var uZ=Eo(),{callbackify:rU,promisify:dZ}=require("util"),{getDatabases:nU}=(Pe(),C(tt));iU.exports={setSchemaDataToGlobal:tU,getTableSchema:fZ,getSystemSchema:_Z,setSchemaDataToGlobalAsync:dZ(tU)};var sU=Ao(),cNe=rU(sU.describeAll),lNe=rU(sU.describeTable);function tU(e){global.hdb_schema=nU(),e&&e()}a(tU,"setSchemaDataToGlobal");function fZ(e,t,r){let n=nU()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}a(fZ,"getTableSchema");function _Z(){return uZ}a(_Z,"getSystemSchema")});var Iy=w((fNe,cU)=>{var pZ=ft(),wy=require("joi"),{hdb_table:hZ,hdb_database:oU}=Mi(),aU={schema:oU,database:oU,table:hZ},mZ={date:wy.date().iso().required()},EZ={timestamp:wy.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};cU.exports=function(e,t){let r=t==="timestamp"?{...aU,...EZ}:{...aU,...mZ},n=wy.object(r);return pZ.validateBySchema(e,n)}});var dU=w((_Ne,uU)=>{var gZ=ft(),Cy=require("joi"),{hdb_table:SZ,hdb_database:lU}=Mi(),TZ=Cy.object({schema:lU,database:lU,table:SZ,hash_values:Cy.array().required(),ids:Cy.array()});uU.exports=function(e){return gZ.validateBySchema(e,TZ)}});var My=w((pNe,fU)=>{"use strict";var Py=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},Dy=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},Ly=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};fU.exports={InsertObject:Py,NoSQLSeachObject:Dy,DeleteResponseObject:Ly}});var Vc=w((mNe,EU)=>{"use strict";var pU=Iy(),AZ=dU(),qc=se(),_U=require("moment"),hU=z(),{promisify:RZ,callbackify:yZ}=require("util"),$c=(H(),C(q)),bZ=ys(),vy=RZ(bZ.getTableSchema),Uy=Yn(),{DeleteResponseObject:OZ}=My(),{handleHDBError:Oa,hdb_errors:NZ}=pe(),{HDB_ERROR_MSGS:_E,HTTP_STATUS_CODES:Na}=NZ,wZ="records successfully deleted",IZ=yZ(mU);EU.exports={delete:IZ,deleteRecord:mU,deleteFilesBefore:CZ,deleteAuditLogsBefore:PZ};async function CZ(e){let t=pU(e,"date");if(t)throw Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),!_U(e.date,_U.ISO_8601).isValid())throw Oa(new Error,_E.INVALID_DATE,Na.BAD_REQUEST,$c.LOG_LEVELS.ERROR,_E.INVALID_DATE,!0);let n=qc.checkSchemaTableExist(e.schema,e.table);if(n)throw Oa(new Error,n,Na.NOT_FOUND,$c.LOG_LEVELS.ERROR,n,!0);let s=await Uy.deleteRecordsBefore(e);if(await vy(e.schema,e.table),hU.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(CZ,"deleteFilesBefore");async function PZ(e){let t=pU(e,"timestamp");if(t)throw Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),isNaN(e.timestamp))throw Oa(new Error,_E.INVALID_VALUE("Timestamp"),Na.BAD_REQUEST,$c.LOG_LEVELS.ERROR,_E.INVALID_VALUE("Timestamp"),!0);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw Oa(new Error,r,Na.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);let n=await Uy.deleteAuditLogsBefore(e);return await vy(e.schema,e.table),hU.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(PZ,"deleteAuditLogsBefore");async function mU(e){e.ids&&(e.hash_values=e.ids);let t=AZ(e);if(t)throw Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);qc.transformReq(e);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw Oa(new Error,r,Na.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);try{await vy(e.schema,e.table);let n=await Uy.deleteRecords(e);return qc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${wZ}`),n}catch(n){if(n.message===$c.SEARCH_NOT_FOUND_MESSAGE){let s=new OZ;return s.message=$c.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(mU,"deleteRecord")});var pE={};ve(pE,{HASH_FUNCTION:()=>T_,hash:()=>Hy,validate:()=>ky});function xy(e=S_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(g_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function Hy(e,t=T_[SU?.toUpperCase()]??"sha256"){return By[t](e)}function ky(e,t,r=T_[SU?.toUpperCase()]??"sha256"){return e?DZ[r](e,t):!1}var g_,wu,gU,SU,S_,TU,T_,By,DZ,hE=be(()=>{g_=M(require("node:crypto")),wu=M(require("argon2")),gU=M(ae());H();SU=(0,gU.get)(B.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),S_=16,TU=9,T_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(T_||{});a(xy,"generateSalt");By={md5:a((e,t=void 0)=>{t=t??xy(TU);let r=g_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??xy(S_);let r=g_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=xy(S_),r=await wu.hash(e,{type:wu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},DZ={md5:a((e,t)=>{let r=e.slice(0,TU);return e===By.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,S_);return e===By.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await wu.verify(e.slice(S_),t),"argon2id")};a(Hy,"hash");a(ky,"validate")});var RU=w((TNe,AU)=>{var Fy=ft(),Wr={username:{presence:!0,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 LZ(e){return Wr.password.presence=!0,Wr.username.presence=!0,Wr.role.presence=!0,Wr.active.presence=!0,Fy.validateObject(e,Wr)}a(LZ,"addUserValidation");function MZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,Fy.validateObject(e,Wr)}a(MZ,"alterUserValidation");function vZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,Fy.validateObject(e,Wr)}a(vZ,"dropUserValidation");AU.exports={addUserValidation:LZ,alterUserValidation:MZ,dropUserValidation:vZ}});var Tt=w((yNe,bU)=>{"use strict";var{platform:RNe}=require("os"),UZ="nats-server.zip",Gy="nats-server",xZ=process.platform==="win32"?`${Gy}.exe`:Gy,BZ=/^[^\s.,*>]+$/,yU="__request__",HZ=a(e=>`${e}.${yU}`,"REQUEST_SUBJECT"),kZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},FZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},GZ={HUB:"hub.pid",LEAF:"leaf.pid"},qZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},$Z={SUCCESS:"success",ERROR:"error"},VZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},KZ={TXN:"txn",MSGID:"msgid"},Iu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},YZ={[Iu.ERR]:1,[Iu.WRN]:2,[Iu.INF]:3,[Iu.DBG]:4,[Iu.TRC]:5},WZ={debug:"-D",trace:"-DVV"};bU.exports={NATS_SERVER_ZIP:UZ,NATS_SERVER_NAME:Gy,NATS_BINARY_NAME:xZ,PID_FILES:GZ,NATS_CONFIG_FILES:FZ,SERVER_SUFFIX:qZ,NATS_TERM_CONSTRAINTS_RX:BZ,REQUEST_SUFFIX:yU,UPDATE_REMOTE_RESPONSE_STATUSES:$Z,CLUSTER_STATUS_STATUSES:VZ,REQUEST_SUBJECT:HZ,SUBJECT_PREFIXES:KZ,MSG_HEADERS:kZ,LOG_LEVELS:Iu,LOG_LEVEL_FLAGS:WZ,LOG_LEVEL_HIERARCHY:YZ}});var qy=w(OU=>{"use strict";var zZ={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
|
|
17
|
+
`},"serialize"),compressible:!1,q:.8});Kr.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});uM={type:"application/json",serializeStream:$f,serialize:Wf,deserialize:w3,q:.5};Kr.set("*/*",uM);Kr.set("",uM);a(w3,"tryJSONParse");a(jf,"registerContentHandlers");I3=require("fastify-plugin"),C3=I3(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=$m(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let f=l.getColumns;l=l.mapError(d=>(d.toJSON=()=>({error:d.name,message:d.message,...d.partialObject}),d)),l.getColumns=f}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((f,d)=>{s.header(f,d)},"set")}})})}),r()},{name:"content-type-negotiation"});a($m,"findBestSerializer");iM=MR.default.get(x.HTTP_COMPRESSIONTHRESHOLD);a(Jf,"serialize");a(Aa,"serializeMessage");a(DR,"asyncSerialization");a(LR,"hasAsyncSerialization");a(P3,"streamToBuffer");D3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(L3,"isBufferEncoding");a(M3,"parseContentType");a(uo,"getDeserializer");a(v3,"deserializerUnknownType");a(U3,"transformIterable");a(qm,"toCsvStream")});var HR={};ve(HR,{start:()=>V3});function x3(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new Or(`Unexpected non-executable definition type ${e.kind}.`)}function fM(e){if(typeof e!="object"||e===null)throw new Ci("Request body must be an object.");if(!("query"in e))throw new Ci("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Ci("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Ci("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Ci("Request body `operationName` field must be a string.")}function BR(e){return parseInt(e.value,10)}function pM(e){return parseFloat(e.value)}function hM(e,t,r){let n=r.get(e.name.value);return mM(n)?EM(n,t):{attribute:t,value:n}}function mM(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function EM(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],mM(n)?EM(n,t):{attribute:t,value:n}))}function B3(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Le.Kind.NULL:return{attribute:t,value:null};case Le.Kind.INT:return{attribute:t,value:BR(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:pM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return hM(e.value,t,r);case Le.Kind.OBJECT:return gM(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.value.kind}, is not supported.`)}}function gM(e,t,r){return e.fields.flatMap(n=>B3(n,t,r))}function H3(e,t){switch(e.value.kind){case Le.Kind.NULL:return{attribute:e.name.value,value:null};case Le.Kind.INT:return{attribute:e.name.value,value:BR(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:pM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return hM(e.value,e.name.value,t);case Le.Kind.OBJECT:return gM(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Argument type, ${e.value.kind}, is not supported.`)}}function k3(e,t){return e.flatMap(r=>H3(r,t))}function Vm(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Le.Kind.FIELD:return r;case Le.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Or(`Fragment \`${n}\` not found.`);return Vm(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return Vm(r.selectionSet,t)}})}function SM(e,t){return Vm(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:SM(r.selectionSet,t)}:r.name.value)}async function F3(e,t,r,n){let s=Oi.getMatch(e.name.value,"graphql");if(s===void 0)throw new Or(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:SM(e.selectionSet,r),conditions:k3(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(o,n))c.push(l);return[e.name.value,c]}function TM(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return BR(e);case Le.Kind.FLOAT:return parseFloat(e.value);case Le.Kind.STRING:case Le.Kind.BOOLEAN:return e.value;case Le.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:TM(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function G3(e,t){let r=new Map;for(let n of e){let s=n.variable.name.value,i=t?.[s];if(i===void 0&&n.defaultValue!==void 0&&(i=TM(n.defaultValue)),n.type.kind===Le.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Or(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function q3(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new Or("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new Or("Mutations are not supported yet.");let s=G3(e.variableDefinitions,t),i=await Promise.all(Vm(e.selectionSet,r).map(c=>F3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function _M({query:e,variables:t={},operationName:r},n){let s=Le.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(x3(u),u.kind===Le.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Or("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new Or(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Or("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Or(`Operation \`${r}\` not found.`);let l=await q3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function $3(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return fM(r),_M(r,e)}case"POST":{let r=await uo(e.headers.get("content-type"),!0)(e._nodeRequest);return fM(r),_M(r,e)}default:throw new Ci("Method Not Allowed",405,{Allow:"GET, POST"})}}function V3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await $3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Ci)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Or)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof Ci)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Or)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Le,Or,Ci,AM=be(()=>{Le=M(require("graphql"));ao();Tu();a(x3,"assertExecutableDefinitionNode");a(fM,"assertRequestParams");a(BR,"processIntValueNode");a(pM,"processFloatValueNode");a(hM,"processVariableNode");a(mM,"isObject");a(EM,"transformObjectIntoQueryCondition");a(B3,"processObjectFieldNode");a(gM,"processObjectValueNode");a(H3,"processArgumentNode");a(k3,"buildConditionsQuery");a(Vm,"fillInFragments");a(SM,"buildSelectQuery");a(F3,"processFieldNode");a(TM,"processConstValueNode");a(G3,"resolveVariables");a(q3,"executeOperation");a(_M,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},Ci=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a($3,"graphqlQueryingHandler");a(V3,"start")});var Di=w((jbe,bM)=>{"use strict";var yM=ie(),RM=(H(),C(G)),bu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Pi=require("joi"),Ra={schema_format:{pattern:bu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},K3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(bu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number(),Pi.array()).required(),Y3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(bu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number()),W3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(bu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number()).required();function z3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Ra.schema_length.maximum?`'${e}' maximum of 250 characters`:bu.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(z3,"checkValidTable");function j3(e,t){return yM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(j3,"validateSchemaExists");function J3(e,t){let r=t.state.ancestors[0].schema;return yM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(J3,"validateTableExists");function Q3(e,t){return e.toLowerCase()===RM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${RM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(Q3,"validateSchemaName");bM.exports={common_validators:Ra,schema_regex:bu,hdb_schema_table:K3,validateSchemaExists:j3,validateTableExists:J3,validateSchemaName:Q3,checkValidTable:z3,hdb_database:Y3,hdb_table:W3}});var ot=w((Qbe,OM)=>{"use strict";var gn=require("validate.js");gn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||gn.validators.type.checks[t](e)?null:` must be a '${t}' value`};gn.validators.type.checks={Object:a(function(e){return gn.isObject(e)&&!gn.isArray(e)},"Object"),Array:gn.isArray,Integer:gn.isInteger,Number:gn.isNumber,String:gn.isString,Date:gn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};gn.validators.hasValidFileExt=function(e,t){return gn.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};OM.exports={validateObject:X3,validateObjectAsync:Z3,validateBySchema:eX};function X3(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=gn(e,t,{format:"flat"});return r?new Error(r):null}a(X3,"validateObject");async function Z3(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await gn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(Z3,"validateObjectAsync");function eX(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(eX,"validateBySchema")});var FR=w((Zbe,wM)=>{var{hdb_table:tX,hdb_database:NM}=Di(),rX=ot(),kR=require("joi"),nX={undefined:"undefined",null:"null"},sX=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||nX[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),iX=kR.object({database:NM,schema:NM,table:tX,records:kR.array().items(kR.object().custom(sX)).required()});wM.exports=function(e){return rX.validateBySchema(e,iX)}});var CM=w((tOe,IM)=>{"use strict";var GR=class{static{a(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};IM.exports=GR});var DM=w((nOe,PM)=>{"use strict";var qR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};PM.exports=qR});var xM={};ve(xM,{HAS_EXPIRATION:()=>Wm,HAS_RESIDENCY_ID:()=>jR,HAS_STRUCTURE_UPDATE:()=>jm,LAST_TIMESTAMP_PLACEHOLDER:()=>t_,LOCAL_TIMESTAMP:()=>oX,METADATA:()=>Qf,NEW_TIMESTAMP_PLACEHOLDER:()=>MM,NO_TIMESTAMP:()=>$R,PENDING_LOCAL_TIME:()=>JR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>zR,RecordEncoder:()=>WR,TIMESTAMP_ASSIGN_LAST:()=>cX,TIMESTAMP_ASSIGN_NEW:()=>vM,TIMESTAMP_ASSIGN_PREVIOUS:()=>UM,TIMESTAMP_PLACEHOLDER:()=>Km,TIMESTAMP_RECORD_PREVIOUS:()=>VR,handleLocalTimeForGets:()=>Jm,recordUpdater:()=>QR,removeEntry:()=>Hc});function uX(){return e_[0]=e_[0]^64,aX.getFloat64(0)}function Jm(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(o,c){e.readCount++;let l=r.call(this,o,c),u=l?.value,f=u?.[Qf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l&&(l.key=o),l};let n=e.get;e.get=function(o,c){let l=n.call(this,o,c);return l?.[Qf]>=0?l.value:l};let s=e.getRange;e.getRange=function(o){let c=s.call(this,o);return o.valuesForKey?c.map(l=>l?.value):o.values===!1||o.onlyCount?c:c.map(l=>{let u=l.value,f=u[Qf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l})};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let o=i.constructor,c=i.use,l=i.done;o.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Bc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Bc.length;u++){let f=Bc[u].deref();(!f||f.isDone||f.isCommitted)&&Bc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function QR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,p){d||l==null?Ou=i?.localTime?VR|UM:$R:Ou=l?i?.localTime?VR|16384:vM|16384:$R;let _=u?.expiresAt;if(_>=0&&(c|=Wm),Zf=c,KR=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Ou>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(YR=E,Zf|=jR,g|=kc),R!==E&&(g|=Fc,R||(R=0)),c&Wm&&(g|=n_),u?.originatingOperation&&(g|=r_),d&&(h.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&Fn&&(r.getBinaryFast(i.localTime)||Ta(i.value));let T;if(s!==void 0&&(T=Fm(()=>e.put(n,s,h),n,e.rootStore),Mc&&(g|=Fn)),l){let b=u?.user?.username;if(p&&(Fm(()=>e.encoder.encode(p),n,e.rootStore),Mc&&(g|=Fn)),e.encoder.hasStructureUpdate&&(g|=jm,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,F=r.get(v);if(F){let q=It(F).previousLocalTime;return T=r.put(v,Nu(o,t,n,q,u?.nodeId??server.replication.getThisNodeId(r)??0,b,f,Xf,g,E,R,_),{ifVersion:S}),T}}T=r.put(s===void 0?MM:t_,Nu(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,b,f,Xf,g,E,R,_,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return T}catch(R){throw R.message+=" id: "+n+" options: "+h,R}}}function Hc(e,t,r){if(t)return t.value&&t.metadataFlags&Fn&&!e.auditStore.getBinaryFast(t.localTime)&&Ta(t.value),e.remove(t.key,r)}var LM,Ym,Km,t_,zR,MM,oX,Qf,e_,aX,$R,vM,cX,UM,VR,Wm,jR,JR,jm,lX,Xf,Ou,Zf,KR,YR,WR,Bc,wu=be(()=>{LM=require("msgpackr");fo();Ym=M(z());gs();gs();Km=new Uint8Array([1,1,1,1,4,64,0,0]),t_=new Uint8Array([1,1,1,1,1,0,0,0]),zR=new Uint8Array([1,1,1,1,3,64,0,0]),MM=new Uint8Array([1,1,1,1,0,64,0,0]),oX=Symbol("local-timestamp"),Qf=Symbol("metadata"),e_=new Uint8Array(8),aX=new DataView(e_.buffer,0,8),$R=0,vM=0,cX=1,UM=3,VR=4,Wm=16,jR=32,JR=1,jm=256,Ou=0,Zf=-1,KR=-1,YR=0,WR=class extends LM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Ou||Zf>=0){let o=0,c=Ou;c&&(o+=8,Ou=0);let l=Zf,u=KR,f=YR;l>=0&&(o+=4,Zf=-1,u>=0&&(o+=8,KR=-1),f&&(o+=4,YR=0));let d=lX=r.call(this,s,i|2048|o);Xf=d.subarray((d.start||0)+o,d.end);let p=d.start||0;return c&&(Km[4]=c,Km[5]=c>>8,d.set(Km,p),p+=8),Mc&&(l|=Fn),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,l|zm<<24),p+=4,u>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setFloat64(p,u),p+=8),f&&(d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,f)),d}else return Xf=r.call(this,s,i),Xf};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(e_,0,c),c+=8;else for(let p=0;p<8;p++)e_[p]=t[c++];l=uX(),i=t[c]}let u,f;i<32&&(i===zm?(o=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(o=i|t[c+1]<<5,c+=2),o&Wm&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&jR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=vc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Qf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:vc(()=>super.decode(t,r),this.rootStore)}catch(c){return Ym.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(uX,"getTimestamp");a(Jm,"handleLocalTimeForGets");Bc=[];setInterval(()=>{for(let e=0;e<Bc.length;e++){let t=Bc[e].deref();!t||t.isDone||t.isCommitted?Bc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Ym.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Ym.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(QR,"recordUpdater");a(Hc,"removeEntry")});var s_=w((lOe,HM)=>{"use strict";var BM=ae(),dX=(H(),C(G)),{RecordEncoder:fX}=(wu(),C(xM));BM.initSync();var _X=BM.get(dX.CONFIG_PARAMS.STORAGE_CACHING)!==!1,XR=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=_X&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:fX})}};HM.exports=XR});var i_=w((dOe,kM)=>{"use strict";var Gn=ae(),Ss=(H(),C(G));Gn.initSync();var Qm=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Gn.get(Ss.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Gn.get(Ss.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Gn.get(Ss.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Gn.get(Ss.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};kM.exports=Qm;Qm.MAX_DBS=1e4});var _t=w((_Oe,jM)=>{"use strict";var ey=require("lmdb"),Qs=require("fs-extra"),qn=require("path"),Xm=_n(),qM=z(),Sn=xn().LMDB_ERRORS_ENUM,Zm=DM(),ty=s_(),$M=i_(),ya=xt(),FM=(H(),C(G)),{table:pX,resetDatabases:hX}=(De(),C(nt)),GM=ae(),Xs=ya.INTERNAL_DBIS_NAME,VM=ya.DBI_DEFINITION_NAME,mX="data.mdb",EX="lock.mdb",o_=".mdb",gX="-lock",ZR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Ts(t,r),this.key_type=this.dbi[ya.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ya.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new ey.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function eE(e,t){if(e===void 0)throw new Error(Sn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Sn.ENV_NAME_REQUIRED)}a(eE,"pathEnvNameValidation");async function ry(e,t,r=!0){try{await Qs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Sn.INVALID_BASE_PATH):n}try{let n=qn.join(e,t+o_);return await Qs.access(n,Qs.constants.R_OK|Qs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Qs.access(qn.join(e,t,mX),Qs.constants.R_OK|Qs.constants.F_OK),qn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Sn.INVALID_ENVIRONMENT)}else throw new Error(Sn.INVALID_ENVIRONMENT);throw n}}a(ry,"validateEnvironmentPath");function tE(e,t){if(Xm.validateEnv(e),t===void 0)throw new Error(Sn.DBI_NAME_REQUIRED)}a(tE,"validateEnvDBIName");async function SX(e,t,r=!1,n=!1){eE(e,t);let s=qn.basename(e);t=t.toString();let i=GM.get(FM.CONFIG_PARAMS.DATABASES);i||GM.setProperty(FM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ry(e,t,n),KM(e,t,r)}catch(o){if(o.message===Sn.INVALID_ENVIRONMENT){let c=qn.join(e,t);await Qs.mkdirp(n?c:e);let l=new $M(n?c:c+o_,!1),u=ey.open(l);u.dbis=Object.create(null);let f=new ty(!1);u.openDB(Xs,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=ny(e,t,r);return u[ya.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(SX,"createEnvironment");async function TX(e,t,r,n=!0){eE(e,t),t=t.toString();let s=qn.join(e,t);return pX({table:t,database:qn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(TX,"copyEnvironment");async function KM(e,t,r=!1){eE(e,t),t=t.toString();let n=ny(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await ry(e,t),i=qn.join(e,t+o_),o=s!=i,c=new $M(s,o),l=ey.open(c);l.dbis=Object.create(null);let u=WM(l);for(let f=0;f<u.length;f++)Ts(l,u[f]);return l[ya.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(KM,"openEnvironment");async function AX(e,t,r=!1){eE(e,t),t=t.toString();let n=qn.join(e,t+o_),s=await ry(e,t);if(global.lmdb_map!==void 0){let i=ny(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await YM(o),delete global.lmdb_map[i]}}await Qs.remove(s),await Qs.remove(s===n?s+gX:qn.join(qn.dirname(s),EX))}a(AX,"deleteEnvironment");async function YM(e){Xm.validateEnv(e);let t=e[ya.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(YM,"closeEnvironment");function ny(e,t,r=!1){let s=`${qn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(ny,"getCachedEnvironmentName");function RX(e){Xm.validateEnv(e);let t=Object.create(null),r=Ts(e,Xs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Xs)try{t[n]=Object.assign(new Zm,s)}catch{qM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(RX,"listDBIDefinitions");function WM(e){Xm.validateEnv(e);let t=[],r=Ts(e,Xs);for(let{key:n}of r.getRange({start:!1}))n!==Xs&&t.push(n);return t}a(WM,"listDBIs");function yX(e,t){let n=Ts(e,Xs).getEntry(t),s=new Zm;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{qM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(yX,"getDBIDefinition");function zM(e,t,r,n=!r){if(tE(e,t),t=t.toString(),t===Xs)throw new Error(Sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Ts(e,t)}catch(s){if(s.message===Sn.DBI_DOES_NOT_EXIST){let i=new ty(r,n===!0),o=e.openDB(t,i),c=new Zm(r===!0,n);return o[VM]=c,Ts(e,Xs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(zM,"createDBI");function Ts(e,t){if(tE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Xs?r=yX(e,t):r=new Zm,r===void 0)throw new Error(Sn.DBI_DOES_NOT_EXIST);let n;try{let s=new ty(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(Sn.DBI_DOES_NOT_EXIST):s}return n[VM]=r,e.dbis[t]=n,n}a(Ts,"openDBI");function bX(e,t){tE(e,t),t=t.toString();let r=Ts(e,t),n=r.getStats();return r[ya.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(bX,"statDBI");async function OX(e,t){try{let r=qn.join(e,t+o_);return(await Qs.stat(r)).size}catch{throw new Error(Sn.INVALID_ENVIRONMENT)}}a(OX,"environmentDataSize");function NX(e,t){if(tE(e,t),t=t.toString(),t===Xs)throw new Error(Sn.CANNOT_DROP_INTERNAL_DBIS_NAME);Ts(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Ts(e,Xs).removeSync(t)}a(NX,"dropDBI");function wX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Ts(e,i)}catch(o){if(o.message===Sn.DBI_DOES_NOT_EXIST)zM(e,i,i!==t,i===t),n=!0;else throw o}}n&&hX()}a(wX,"initializeDBIs");jM.exports={openDBI:Ts,openEnvironment:KM,createEnvironment:SX,listDBIs:WM,listDBIDefinitions:RX,createDBI:zM,dropDBI:NX,statDBI:bX,deleteEnvironment:AX,initializeDBIs:wX,TransactionCursor:ZR,environmentDataSize:OX,copyEnvironment:TX,closeEnvironment:YM}});var QM=w((hOe,JM)=>{"use strict";var sy=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};JM.exports=sy});var ZM=w((EOe,XM)=>{"use strict";var iy=class{static{a(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};XM.exports=iy});var tv=w((SOe,ev)=>{"use strict";var oy=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};ev.exports=oy});var qc=w((bOe,sv)=>{"use strict";var IX=_t(),CX=QM(),PX=ZM(),DX=tv(),Li=_n(),a_=xn().LMDB_ERRORS_ENUM,LX=xt(),_o=(H(),C(G)),MX=ie(),vX=require("uuid"),AOe=require("lmdb"),{handleHDBError:UX,hdb_errors:xX}=pe(),{OVERFLOW_MARKER:ROe,MAX_SEARCH_KEY_LENGTH:yOe}=LX,rv=ae();rv.initSync();var rE=rv.get(_o.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),ay=_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Gc=_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function BX(e,t,r,n,s=Li.getNextMonotonicTime()){dy(e,t,r,n),cy(e,t,r);let i=new CX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];nv(u,!0,s);let f=HX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return ly(o,c,n,i,s)}a(BX,"insertRecords");function HX(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let f=c([[{}]]);Array.isArray(f)&&(c=f[0][_o.FUNC_VAL],n[o]=c)}let l=Li.getIndexedValues(c),u=e.dbis[o];if(l){rE&&u.prefetch(l.map(f=>({key:f,value:s})),nE);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}rE&&e.dbis[t].prefetch([s],nE),e.dbis[t].put(s,n,n[Gc])})}a(HX,"insertRecord");function kX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(kX,"removeSkippedRecords");function nv(e,t,r){let n=r>0;(n||!Number.isInteger(e[Gc]))&&(e[Gc]=r||(r=Li.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[ay]))&&(e[ay]=r||Li.getNextMonotonicTime()):delete e[ay]}a(nv,"setTimestamps");function cy(e,t,r){r.indexOf(_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),IX.initializeDBIs(e,t,r)}a(cy,"initializeTransaction");async function FX(e,t,r,n,s=Li.getNextMonotonicTime()){dy(e,t,r,n),cy(e,t,r);let i=new PX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],p;try{p=uy(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(p),l.push(d)}return ly(c,l,n,i,s,o)}a(FX,"updateRecords");async function GX(e,t,r,n,s=Li.getNextMonotonicTime()){try{dy(e,t,r,n)}catch(l){throw UX(l,l.message,xX.HTTP_STATUS_CODES.BAD_REQUEST)}cy(e,t,r);let i=new DX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;MX.isEmpty(u[t])?(f=vX.v4(),u[t]=f):f=u[t];let d=uy(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return ly(o,c,n,i,s)}a(GX,"upsertRecords");async function ly(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Li.getNextMonotonicTime(),kX(r,i),n}a(ly,"finalizeWrite");function uy(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,f=u;if(!u){if(i)return!1;u={}}if(nv(r,!f,o),Number.isInteger(r[Gc])&&u[Gc]>r[Gc])return!1;f&&s.original_records.push(u);let d,p=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let S=r[h],g=e.dbis[h];if(g===void 0)continue;let R=u[h];if(typeof S=="function"){let T=S([[u]]);Array.isArray(T)&&(S=T[0][_o.FUNC_VAL],r[h]=S)}if(S===R)continue;let E=Li.getIndexedValues(R);if(E){rE&&g.prefetch(E.map(T=>({key:T,value:n})),nE);for(let T=0,b=E.length;T<b;T++)g.remove(E[T],n)}if(E=Li.getIndexedValues(S),E){rE&&g.prefetch(E.map(T=>({key:T,value:n})),nE);for(let T=0,b=E.length;T<b;T++)g.put(E[T],n)}}let _={...u,...r};c.put(n,_,_[Gc])},"do_put");return l?d=c.ifVersion(n,l.version,p):d=c.ifNoExists(n,p),d.then(_=>_?!0:uy(e,t,r,n,s,i,o))}a(uy,"updateUpsertRecord");function qX(e,t,r){if(Li.validateEnv(e),t===void 0)throw new Error(a_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(a_.WRITE_ATTRIBUTES_REQUIRED):new Error(a_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(qX,"validateBasic");function dy(e,t,r,n){if(qX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(a_.RECORDS_REQUIRED):new Error(a_.RECORDS_MUST_BE_ARRAY)}a(dy,"validateWrite");function nE(){}a(nE,"noop");sv.exports={insertRecords:BX,updateRecords:FX,upsertRecords:GX}});var po=w((NOe,$X)=>{$X.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"revoked_certificates"},{attribute:"shard"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var ov=w((wOe,iv)=>{"use strict";var VX=require("uuid"),fy=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||VX.v4(),this.schema_table=`${this.schema}.${this.table}`}};iv.exports=fy});var sE=w((COe,av)=>{"use strict";var KX=ov(),_y=class extends KX{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};av.exports=_y});var lv=w((DOe,cv)=>{"use strict";cv.exports=WX;var YX="inserted";function WX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===YX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(WX,"returnObject")});var iE=w((vOe,dv)=>{"use strict";var zX=(H(),C(G)),py=_t(),jX=qc(),{getSystemSchemaPath:JX,getSchemaPath:QX}=gt(),MOe=po(),{validateBySchema:XX}=ot(),c_=require("joi"),ZX=sE(),e6=lv(),{handleHDBError:t6,hdb_errors:r6,ClientError:n6}=pe(),uv=ie(),{HTTP_STATUS_CODES:s6}=r6,i6="inserted";dv.exports=o6;async function o6(e){let t=XX(e,c_.object({database:c_.string(),schema:c_.string(),table:c_.string().required(),attribute:c_.string().required()}));if(t)throw new n6(t.message);let r=!e.skip_table_check&&uv.checkGlobalSchemaTable(e.schema,e.table);if(r)throw t6(new Error,r,s6.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=uv.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new ZX(e.schema,e.table,e.attribute,e.id);try{let i=await py.openEnvironment(QX(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);py.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await py.openEnvironment(JX(),zX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await jX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return e6(i6,c,{records:[s]},l)}catch(i){throw i}}a(o6,"lmdbCreateAttribute")});var l_=w((BOe,_v)=>{"use strict";var ho=ie(),fv=z(),xOe=FR(),{getDatabases:a6}=(De(),C(nt)),{ClientError:$c}=pe();_v.exports=c6;function c6(e){if(ho.isEmpty(e))throw new $c("invalid update parameters defined.");if(ho.isEmptyOrZeroLength(e.schema))throw new $c("invalid schema specified.");if(ho.isEmptyOrZeroLength(e.table))throw new $c("invalid table specified.");if(!Array.isArray(e.records))throw new $c("records must be an array");let t=a6()[e.schema]?.[e.table];if(ho.isEmpty(t))throw new $c(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&ho.isEmptyOrZeroLength(o[r]))throw fv.error("a valid hash attribute must be provided with update record:",o),new $c("a valid hash attribute must be provided with update record, check log for more info");if(!ho.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw fv.error(`a valid hash value must be provided with ${e.operation} record:`,o),new $c(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!ho.isEmpty(o[r])&&o[r]!==""&&n.has(ho.autoCast(o[r]))&&(o.skip=!0),n.add(ho.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(c6,"insertUpdateValidate")});var hv=w((kOe,pv)=>{"use strict";var hy=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};pv.exports=hy});var gv=w((GOe,Ev)=>{"use strict";var my=_t(),l6=z(),mv=xn().LMDB_ERRORS_ENUM;Ev.exports=u6;async function u6(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 my.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==mv.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await my.closeEnvironment(global.lmdb_map[n]),await my.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==mv.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){l6.error(t)}}a(u6,"cleanLMDBMap")});var Dv=w((VOe,Pv)=>{"use strict";var Ey=require("recursive-iterator"),d6=require("alasql"),gy=require("clone"),Sv=ie(),{handleHDBError:Tv,hdb_errors:f6}=pe(),{HDB_ERROR_MSGS:Av,HTTP_STATUS_CODES:Rv}=f6,{getDatabases:_6}=(De(),C(nt)),p6=["DISTINCT_ARRAY"],yv=Symbol("validateTables"),Sy=Symbol("validateTable"),$Oe=Symbol("getAllColumns"),bv=Symbol("validateAllColumns"),oE=Symbol("findColumn"),Ov=Symbol("validateOrderBy"),u_=Symbol("validateSegment"),Ty=Symbol("validateColumn"),Nv=Symbol("setColumnsForTable"),wv=Symbol("checkColumnsForAsterisk"),Iv=Symbol("validateGroupBy"),Cv=Symbol("hasColumns"),Ay=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[yv](),this[wv](),this[bv]()}[yv](){if(this[Cv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Sy](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Sy](t.table)})}}[Cv](){let t=!1,r=new Ey(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Sy](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=_6();if(!r[t.databaseid])throw Tv(new Error,Av.SCHEMA_NOT_FOUND(t.databaseid),Rv.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Tv(new Error,Av.TABLE_NOT_FOUND(t.databaseid,t.tableid),Rv.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=gy(s);i.table=gy(t),this.attributes.push(i)})}[oE](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)}[wv](){let t=new Ey(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[Nv](r.tableid)}[Nv](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new d6.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[bv](){this[u_](this.statement.columns,!1),this[u_](this.statement.joins,!1),this[u_](this.statement.where,!1),this[Iv](this.statement.group,!1),this[u_](this.statement.order,!0)}[u_](t,r){if(!t)return;let n=new Ey(t),s=[];for(let{node:i,path:o}of n)!Sv.isEmpty(i)&&!Sv.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Ov](i):s.push(this[Ty](i)));return s}[Iv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&p6.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=gy(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[oE](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[oE](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[Ov](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[Ty](t)}[Ty](t){let r=this[oE](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};Pv.exports=Ay});var Uv=w((YOe,vv)=>{"use strict";var Lv=require("lodash"),d_=require("mathjs"),h6=require("jsonata"),Mv=ie();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Lv.uniqWith(e,Lv.isEqual):e,"distinct_array"),searchJSON:m6,mad:f_.bind(null,d_.mad),mean:f_.bind(null,d_.mean),mode:f_.bind(null,d_.mode),prod:f_.bind(null,d_.prod),median:f_.bind(null,d_.median)};function f_(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(f_,"aggregateFunction");function m6(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(Mv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Mv.isEmpty(this.__ala__.res[r])){let n=h6(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(m6,"searchJSON")});var Bv=w((zOe,xv)=>{"use strict";var er=require("moment"),Ry="YYYY-MM-DDTHH:mm:ss.SSSZZ";er.suppressDeprecationWarnings=!0;xv.exports={current_date:a(()=>er().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>er().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return er(e).utc().format("YYYY");case"month":return er(e).utc().format("MM");case"day":return er(e).utc().format("DD");case"hour":return er(e).utc().format("HH");case"minute":return er(e).utc().format("mm");case"second":return er(e).utc().format("ss");case"millisecond":return er(e).utc().format("SSS");default:break}},"extract"),date:a(e=>er(e).utc().format(Ry),"date"),date_format:a((e,t)=>er(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>er(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>er(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=er(e).utc(),s=er(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>er().utc().valueOf(),"now"),get_server_time:a(()=>er().format(Ry),"get_server_time"),offset_utc:a((e,t)=>er(e).utc().utcOffset(t).format(Ry),"offset_utc")}});var Gv=w((JOe,Fv)=>{"use strict";var E6=require("@turf/area"),g6=require("@turf/length"),S6=require("@turf/circle"),T6=require("@turf/difference"),A6=require("@turf/distance"),R6=require("@turf/boolean-contains"),y6=require("@turf/boolean-equal"),b6=require("@turf/boolean-disjoint"),O6=require("@turf/helpers"),Hv=(H(),C(G)),Ge=ie(),mo=z();Fv.exports={geoArea:N6,geoLength:w6,geoCircle:I6,geoDifference:C6,geoDistance:kv,geoNear:P6,geoContains:D6,geoEqual:L6,geoCrosses:M6,geoConvert:v6};function N6(e){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return E6.default(e)}catch(t){return mo.trace(t,e),NaN}}a(N6,"geoArea");function w6(e,t){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return g6.default(e,{units:t||"kilometers"})}catch(r){return mo.trace(r,e),NaN}}a(w6,"geoLength");function I6(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return S6.default(e,t,{units:r||"kilometers"})}catch(n){return mo.trace(n,e,t),NaN}}a(I6,"geoCircle");function C6(e,t){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return T6(e,t)}catch(r){return mo.trace(r,e,t),NaN}}a(C6,"geoDifference");function kv(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return A6.default(e,t,{units:r||"kilometers"})}catch(n){return mo.trace(n,e,t),NaN}}a(kv,"geoDistance");function P6(e,t,r,n){if(Ge.isEmpty(e)||Ge.isEmpty(t))return!1;if(Ge.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return kv(e,t,n)<=r}catch(s){return mo.trace(s,e,t),!1}}a(P6,"geoNear");function D6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return R6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(D6,"geoContains");function L6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return y6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(L6,"geoEqual");function M6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return!b6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(M6,"geoCrosses");function v6(e,t,r){if(Ge.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Ge.isEmpty(t))throw new Error("geo_type is required");if(Ge.isEmpty(Hv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Hv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ge.autoCastJSON(e)),O6[t](e,r)}a(v6,"geoConvert")});var aE=w((XOe,qv)=>{var Vc=Uv(),$n=Bv(),Mi=Gv();qv.exports=e=>{e.aggr.mad=e.aggr.MAD=Vc.mad,e.aggr.mean=e.aggr.MEAN=Vc.mean,e.aggr.mode=e.aggr.MODE=Vc.mode,e.aggr.prod=e.aggr.PROD=Vc.prod,e.aggr.median=e.aggr.MEDIAN=Vc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Vc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Vc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=$n.current_date,e.fn.current_time=e.fn.CURRENT_TIME=$n.current_time,e.fn.extract=e.fn.EXTRACT=$n.extract,e.fn.date=e.fn.DATE=$n.date,e.fn.date_format=e.fn.DATE_FORMAT=$n.date_format,e.fn.date_add=e.fn.DATE_ADD=$n.date_add,e.fn.date_sub=e.fn.DATE_SUB=$n.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=$n.date_diff,e.fn.now=e.fn.NOW=$n.now,e.fn.offset_utc=e.fn.OFFSET_UTC=$n.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=$n.get_server_time,e.fn.getdate=e.fn.GETDATE=$n.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=$n.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Mi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Mi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Mi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Mi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Mi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Mi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Mi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Mi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Mi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Mi.geoNear}});var Yv=w((ZOe,Kv)=>{"use strict";var __=require("lodash"),Tn=require("alasql");Tn.options.cache=!1;var U6=aE(),$v=require("clone"),cE=require("recursive-iterator"),xe=z(),ze=ie(),Iu=Vn(),x6=(H(),C(G)),{hdb_errors:B6}=pe(),{getDatabases:Vv}=(De(),C(nt)),H6="IS NULL",Zs="There was a problem performing this search. Please check the logs and try again.";U6(Tn);var yy=class{static{a(this,"SQLSearch")}constructor(t,r){if(ze.isEmpty(t))throw xe.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(),ze.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!ze.isEmptyOrZeroLength(n))return xe.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw xe.error("Error thrown from checkEmptySQL in SQLSearch class method search."),xe.error(n),new Error(Zs)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw xe.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),xe.error(n),new Error(Zs)}if(Object.keys(this.data).length===0)return xe.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw xe.error("Error thrown from processJoins in SQLSearch class method search."),xe.error(n),new Error(Zs)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw xe.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),xe.error(n),new Error(Zs)}try{return t=await this._finalSQL(),t}catch(n){throw xe.error("Error thrown from finalSQL in SQLSearch class method search."),xe.error(n),new Error(Zs)}}_getColumns(){let t=new cE(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push($v(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=__.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=Vv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(ze.isEmpty(this.statement.where)){xe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new cE(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!ze.isEmpty(r)&&r.right)if(ze.isNotEmptyAndHasValue(r.right.value)){let n=ze.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Tn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=ze.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Tn.yy.LogicValue({value:i}):n instanceof Tn.yy.StringValue&&ze.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Tn.yy.NumValue({value:i}))});if(t){xe.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new cE(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!ze.isEmpty(x6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(ze.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(ze.isEmptyOrZeroLength(r.left.columnid)||ze.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(ze.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"=":!ze.isEmpty(r.right.value)||!ze.isEmpty(r.left.value)?n.add(ze.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from)&&ze.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&__.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(ze.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);ze.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&!ze.isEmptyOrZeroLength(this.columns.columns))return t;if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Tn.promise(r)}catch(r){throw xe.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),xe.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push($v(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(ze.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(H6)>-1&&this.tables.forEach(s=>{let i={columnid:Vv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=__.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!ze.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let f=await Iu.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw xe.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),xe.error(f),new Error(Zs)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let p=await Iu.getDataByValue(d);for(let[_,h]of p)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,_))}))}catch(f){throw xe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),xe.error(f),new Error(Zs)}else if(!ze.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,p=f.length;d<p;d++){let _=f[d];c.search_attribute=_.attribute,c.search_value=_.search_value;let h=await Iu.getDataByValue(c,_.operation);if(l)for(let[S]of h)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of h)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw xe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),xe.error(f),new Error(Zs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await Iu.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,p]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw xe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),xe.error(f),new Error(Zs)}}}_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 Tn.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new Tn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Tn.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new Tn.yy.FuncValue:new Tn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(_=>{_.joinmode&&_.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(_.table);let h=_.joinmode+" JOIN ? AS "+(_.as?_.as:_.table.tableid);_.on&&(h+=" ON "+_.on.toString()),i.push(h),t.push(Object.values(this.data[`${_.table.databaseid_orig}_${_.table.as?_.table.as_orig:_.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(_=>{let h=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__hash_name,S=_.as?_.as_orig:_.tableid_orig;o.push({key:`'${S}.${h}'`,schema:_.databaseid_orig,table:_.as?_.as_orig:_.tableid_orig,keys:new Set}),r.push(`${_.as?_.as:_.tableid}.\`${h}\` AS "${S}.${h}"`),c[_.as?_.as_orig:_.tableid_orig]=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let 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(_=>{_.is_func?r.push(_.initial_select_column.toString()):_.initial_select_column.tableid?r.push(`${_.initial_select_column.tableid}.${_.initial_select_column.columnid} AS ${_.expression.columnid}`):r.push(`${_.initial_select_column.columnid} AS ${_.expression.columnid}`)}));let f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let p=[];try{let _=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,h=this._convertColumnsToIndexes(_,s);p=await Tn.promise(h,t),t=null}catch(_){throw xe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),xe.error(_),new Error("There was a problem processing the data.")}if(p&&p.length>0){for(let _=0,h=p.length;_<h;_++){let S=p[_];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(_=>{let h=Object.keys(this.data[`${_.schema}_${_.table}`].__merged_data),S=__.difference(h,[..._.keys].map(g=>g.toString()));for(let g=0,R=S.length;g<R;g++){let E=S[g];delete this.data[`${_.schema}_${_.table}`].__merged_data[E]}})}return{existing_attributes:c,joined_length:p?p.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new cE(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=__.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw xe.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),xe.error(i),new Error(Zs)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let f in i)o.push(i[f][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await Iu.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let p=o[f],_=l.get(p);for(let h=0;h<u;h++){let S=s.columns[h],g=_[S]===void 0?null:_[S];this.data[n].__merged_data[p].push(g)}}}}catch(r){throw xe.error("Error thrown from getDataByHash function in SQLSearch class method getData."),xe.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();xe.trace(`Final SQL: ${s}`),n=await Tn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),xe.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw xe.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),xe.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return xe.error(B6.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),xe.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),f=`${l}.[${c}]`;n=n.replace(u,f)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Iu.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw xe.error("There was an error when processing this SQL operation. Check your logs"),xe.error(o),new Error(Zs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Kv.exports=yy});var Yr=w((tNe,Wv)=>{"use strict";var k6=Dv();Wv.exports={searchByConditions:G6,searchByHash:q6,searchByValue:$6,search:V6};var by=Vn(),{transformReq:Oy}=ie(),F6=Yv();async function G6(e){return Oy(e),by.searchByConditions(e)}a(G6,"searchByConditions");async function q6(e){Oy(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of by.searchByHash(e))r&&t.push(r);return t}a(q6,"searchByHash");async function $6(e){Oy(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of by.searchByValue(e))t.push(r);return t}a($6,"searchByValue");function V6(e,t){try{let r=new k6(e);r.validate(),new F6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(V6,"search")});var Eo=w((nNe,Qv)=>{"use strict";var p_=require("crypto"),K6=ae(),{CONFIG_PARAMS:Y6}=(H(),C(G)),jv="aes-256-cbc",W6=32,z6=16,Ny=64,Jv=32,j6=Ny+Jv,zv=new Map;Qv.exports={encrypt:J6,decrypt:Q6,createNatsTableStreamName:X6};function J6(e){let t=p_.randomBytes(W6),r=p_.randomBytes(z6),n=p_.createCipheriv(jv,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(J6,"encrypt");function Q6(e){let t=e.substr(0,Ny),r=e.substr(Ny,Jv),n=e.substr(j6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=p_.createDecipheriv(jv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(Q6,"decrypt");function X6(e,t){let r=K6.get(Y6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=zv.get(r);return n||(n=p_.createHash("md5").update(r).digest("hex"),zv.set(r,n)),n}a(X6,"createNatsTableStreamName")});var go=w((oNe,tU)=>{"use strict";var iNe=Yr(),h_=z(),{validateBySchema:Xv}=ot(),Kc=require("joi"),Z6=Eo(),lE=ie(),{handleHDBError:uE,hdb_errors:eZ,ClientError:Zv}=pe(),{HDB_ERROR_MSGS:dE,HTTP_STATUS_CODES:wy}=eZ,eU=ae();eU.initSync();var{getDatabases:Iy}=(De(),C(nt)),tZ=require("fs-extra"),rZ=(H(),C(G));tU.exports={describeAll:nZ,describeTable:fE,describeSchema:sZ};async function nZ(e={}){try{let t=lE.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=Iy(),o={},c={},l=[],u=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let p=i[d];for(let _ in p)try{let h;if(t||s||r)h=await fE({schema:d,table:_,exact_count:u});else if(n&&n[d].describe&&n[d].tables[_].describe){let S=n[d].tables[_].attribute_permissions;h=await fE({schema:d,table:_,exact_count:u},S)}h&&l.push(h)}catch(h){h_.error(h)}}let f={};for(let d in l)t||s||r?(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?f[d]={}:c[d]&&(f[d]={});return f}catch(t){return h_.error("Got an error in describeAll"),h_.error(t),uE(new Error,dE.DESCRIBE_ALL_ERR)}}a(nZ,"describeAll");async function fE(e,t){lE.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=Xv(e,Kc.object({database:Kc.string(),table:Kc.string().required(),exact_count:Kc.boolean().strict()}));if(i)throw new Zv(i.message);let c=Iy()[r];if(!c)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),wy.NOT_FOUND);let l=c[n];if(!l)throw uE(new Error,dE.TABLE_NOT_FOUND(e.schema,e.table),wy.NOT_FOUND);function u(_){f.push({attribute:_.attribute,type:_.type,elements:_.elements?.type,indexed:_.indexed,is_primary_key:_.isPrimaryKey,assigned_created_time:_.assignCreatedTime,assigned_updated_time:_.assignUpdatedTime,nullable:_.nullable,properties:_.properties?_.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let f=[];if(s){let _={};s.forEach(h=>{h.describe&&(_[h.attribute_name]=!0)}),l.attributes.forEach(h=>{_[h.name]&&u(h)})}else l.attributes?.forEach(_=>u(_));let d;try{d=(await tZ.stat(l.primaryStore.env.path)).size}catch(_){h_.warn("unable to get database size",_)}let p={schema:r,name:l.tableName,hash_attribute:l.attributes.find(_=>_.isPrimaryKey||_.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:f,db_size:d};l.replicate!==void 0&&(p.replicate=l.replicate),l.expirationMS!==void 0&&(p.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(p.sealed=l.sealed),l.sources?.length>0&&(p.sources=l.sources.map(_=>_.name).filter(_=>_&&_!=="NATSReplicator"&&_!=="Replicator")),eU.get(rZ.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(p.clustering_stream_name=Z6.createNatsTableStreamName(p.schema,p.name));try{let _=await l.getRecordCount({exactCount:!!e.exact_count});p.record_count=_.recordCount,p.table_size=l.getSize(),p.db_audit_size=l.getAuditSize(),p.estimated_record_range=_.estimatedRange;let h=l.auditStore;if(h)for(let S of h.getKeys({reverse:!0,limit:1}))p.last_updated_record=S[0];if(!p.last_updated_record&&l.indices.__updatedtime__)for(let S of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))p.last_updated_record=S}catch(_){h_.warn(`unable to stat table dbi due to ${_}`)}return p}a(fE,"descTable");async function sZ(e){lE.transformReq(e);let t=Xv(e,Kc.object({database:Kc.string(),exact_count:Kc.boolean().strict()}));if(t)throw new Zv(t.message);let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=Iy()[n];if(!i)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),wy.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),lE.isEmpty(l)||l.describe){let u=await fE({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(sZ,"describeSchema")});var As=w((uNe,oU)=>{var iZ=po(),{callbackify:nU,promisify:oZ}=require("util"),{getDatabases:sU}=(De(),C(nt));oU.exports={setSchemaDataToGlobal:rU,getTableSchema:aZ,getSystemSchema:cZ,setSchemaDataToGlobalAsync:oZ(rU)};var iU=go(),cNe=nU(iU.describeAll),lNe=nU(iU.describeTable);function rU(e){global.hdb_schema=sU(),e&&e()}a(rU,"setSchemaDataToGlobal");function aZ(e,t,r){let n=sU()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}a(aZ,"getTableSchema");function cZ(){return iZ}a(cZ,"getSystemSchema")});var Py=w((fNe,lU)=>{var lZ=ot(),Cy=require("joi"),{hdb_table:uZ,hdb_database:aU}=Di(),cU={schema:aU,database:aU,table:uZ},dZ={date:Cy.date().iso().required()},fZ={timestamp:Cy.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lU.exports=function(e,t){let r=t==="timestamp"?{...cU,...fZ}:{...cU,...dZ},n=Cy.object(r);return lZ.validateBySchema(e,n)}});var fU=w((_Ne,dU)=>{var _Z=ot(),Dy=require("joi"),{hdb_table:pZ,hdb_database:uU}=Di(),hZ=Dy.object({schema:uU,database:uU,table:pZ,hash_values:Dy.array().required(),ids:Dy.array()});dU.exports=function(e){return _Z.validateBySchema(e,hZ)}});var Uy=w((pNe,_U)=>{"use strict";var Ly=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},My=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},vy=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};_U.exports={InsertObject:Ly,NoSQLSeachObject:My,DeleteResponseObject:vy}});var zc=w((mNe,gU)=>{"use strict";var hU=Py(),mZ=fU(),Yc=ie(),pU=require("moment"),mU=z(),{promisify:EZ,callbackify:gZ}=require("util"),Wc=(H(),C(G)),SZ=As(),xy=EZ(SZ.getTableSchema),By=Vn(),{DeleteResponseObject:TZ}=Uy(),{handleHDBError:ba,hdb_errors:AZ}=pe(),{HDB_ERROR_MSGS:_E,HTTP_STATUS_CODES:Oa}=AZ,RZ="records successfully deleted",yZ=gZ(EU);gU.exports={delete:yZ,deleteRecord:EU,deleteFilesBefore:bZ,deleteAuditLogsBefore:OZ};async function bZ(e){let t=hU(e,"date");if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);if(Yc.transformReq(e),!pU(e.date,pU.ISO_8601).isValid())throw ba(new Error,_E.INVALID_DATE,Oa.BAD_REQUEST,Wc.LOG_LEVELS.ERROR,_E.INVALID_DATE,!0);let n=Yc.checkSchemaTableExist(e.schema,e.table);if(n)throw ba(new Error,n,Oa.NOT_FOUND,Wc.LOG_LEVELS.ERROR,n,!0);let s=await By.deleteRecordsBefore(e);if(await xy(e.schema,e.table),mU.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(bZ,"deleteFilesBefore");async function OZ(e){let t=hU(e,"timestamp");if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);if(Yc.transformReq(e),isNaN(e.timestamp))throw ba(new Error,_E.INVALID_VALUE("Timestamp"),Oa.BAD_REQUEST,Wc.LOG_LEVELS.ERROR,_E.INVALID_VALUE("Timestamp"),!0);let r=Yc.checkSchemaTableExist(e.schema,e.table);if(r)throw ba(new Error,r,Oa.NOT_FOUND,Wc.LOG_LEVELS.ERROR,r,!0);let n=await By.deleteAuditLogsBefore(e);return await xy(e.schema,e.table),mU.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(OZ,"deleteAuditLogsBefore");async function EU(e){e.ids&&(e.hash_values=e.ids);let t=mZ(e);if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);Yc.transformReq(e);let r=Yc.checkSchemaTableExist(e.schema,e.table);if(r)throw ba(new Error,r,Oa.NOT_FOUND,Wc.LOG_LEVELS.ERROR,r,!0);try{await xy(e.schema,e.table);let n=await By.deleteRecords(e);return Yc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${RZ}`),n}catch(n){if(n.message===Wc.SEARCH_NOT_FOUND_MESSAGE){let s=new TZ;return s.message=Wc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(EU,"deleteRecord")});var pE={};ve(pE,{HASH_FUNCTION:()=>g_,hash:()=>Fy,validate:()=>Gy});function Hy(e=E_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(m_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function Fy(e,t=g_[TU?.toUpperCase()]??"sha256"){return ky[t](e)}function Gy(e,t,r=g_[TU?.toUpperCase()]??"sha256"){return e?NZ[r](e,t):!1}var m_,Cu,SU,TU,E_,AU,g_,ky,NZ,hE=be(()=>{m_=M(require("node:crypto")),Cu=M(require("argon2")),SU=M(ae());H();TU=(0,SU.get)(x.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),E_=16,AU=9,g_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(g_||{});a(Hy,"generateSalt");ky={md5:a((e,t=void 0)=>{t=t??Hy(AU);let r=m_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??Hy(E_);let r=m_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=Hy(E_),r=await Cu.hash(e,{type:Cu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},NZ={md5:a((e,t)=>{let r=e.slice(0,AU);return e===ky.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,E_);return e===ky.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await Cu.verify(e.slice(E_),t),"argon2id")};a(Fy,"hash");a(Gy,"validate")});var yU=w((TNe,RU)=>{var qy=ot(),Wr={username:{presence:!0,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 wZ(e){return Wr.password.presence=!0,Wr.username.presence=!0,Wr.role.presence=!0,Wr.active.presence=!0,qy.validateObject(e,Wr)}a(wZ,"addUserValidation");function IZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,qy.validateObject(e,Wr)}a(IZ,"alterUserValidation");function CZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,qy.validateObject(e,Wr)}a(CZ,"dropUserValidation");RU.exports={addUserValidation:wZ,alterUserValidation:IZ,dropUserValidation:CZ}});var Tt=w((yNe,OU)=>{"use strict";var{platform:RNe}=require("os"),PZ="nats-server.zip",$y="nats-server",DZ=process.platform==="win32"?`${$y}.exe`:$y,LZ=/^[^\s.,*>]+$/,bU="__request__",MZ=a(e=>`${e}.${bU}`,"REQUEST_SUBJECT"),vZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},UZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},xZ={HUB:"hub.pid",LEAF:"leaf.pid"},BZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},HZ={SUCCESS:"success",ERROR:"error"},kZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},FZ={TXN:"txn",MSGID:"msgid"},Pu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},GZ={[Pu.ERR]:1,[Pu.WRN]:2,[Pu.INF]:3,[Pu.DBG]:4,[Pu.TRC]:5},qZ={debug:"-D",trace:"-DVV"};OU.exports={NATS_SERVER_ZIP:PZ,NATS_SERVER_NAME:$y,NATS_BINARY_NAME:DZ,PID_FILES:xZ,NATS_CONFIG_FILES:UZ,SERVER_SUFFIX:BZ,NATS_TERM_CONSTRAINTS_RX:LZ,REQUEST_SUFFIX:bU,UPDATE_REMOTE_RESPONSE_STATUSES:HZ,CLUSTER_STATUS_STATUSES:kZ,REQUEST_SUBJECT:MZ,SUBJECT_PREFIXES:FZ,MSG_HEADERS:vZ,LOG_LEVELS:Pu,LOG_LEVEL_FLAGS:qZ,LOG_LEVEL_HIERARCHY:GZ}});var Vy=w(NU=>{"use strict";var $Z={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
|
|
18
18
|
`),key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
|
|
19
|
-
`)},jZ="certificate.pem",QZ="privateKey.pem",JZ="caCertificate.pem",XZ="natsCertificate.pem",ZZ="natsCaCertificate.pem",At={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},e8={tls_certificate:At.SERVER,tls_certificateAuthority:At.CA,customFunctions_tls_certificate:At.SERVER,customFunctions_tls_certificateAuthority:At.CA,operationsApi_tls_certificate:At["OPERATIONS-API"],operationsApi_tls_certificateAuthority:At["OPERATIONS-CA"]},t8={[At.SERVER]:2,[At.DEFAULT]:1},r8={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},n8={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},s8={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},i8={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},o8={[At.CA]:2,[At["DEFAULT-CA"]]:1};Object.assign(OU,{CERTIFICATE_PEM_NAME:jZ,PRIVATEKEY_PEM_NAME:QZ,CA_PEM_NAME:JZ,CERT_NAME:At,CERT_CONFIG_NAME_MAP:e8,CERT_PREFERENCE_APP:t8,CERT_PREFERENCE_OPS:r8,CERT_PREFERENCE_REP:n8,CA_CERT_PREFERENCE_REP:s8,CA_CERT_PREFERENCE_OPS:i8,CA_CERT_PREFERENCE_APP:o8,CERTIFICATE_VALUES:zZ,NATS_CERTIFICATE_PEM_NAME:XZ,NATS_CA_PEM_NAME:ZZ})});var Vy=w((wNe,DU)=>{"use strict";var CU=require("fs-extra"),Te=require("joi"),a8=require("os"),{boolean:Be,string:Rt,number:rr,array:Yc}=Te.types(),{totalmem:NU}=require("os"),Kc=require("path"),c8=z(),$y=se(),NNe=qy(),wU=(H(),C(q)),l8=ft(),IU="log",u8="components",d8="Invalid logging.rotation.maxSize unit. Available units are G, M or K",f8="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",_8="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",p8="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",h8="rootPath config parameter is undefined",Tn=Te.alternatives([rr.min(0),Rt]).optional().empty(null),mE=Te.alternatives([Yc.items(Rt,{host:Rt.required(),port:Tn},{hostname:Rt.required(),port:Tn}).empty(null),Yc.items(Rt)]),Bi,PU=!1;DU.exports={configValidator:m8,routesValidator:R8,route_constraints:mE};function m8(e,t=!1){if(PU=t,Bi=e.rootPath,$y.isEmpty(Bi))throw h8;let r=Be.optional(),n=rr.min(0).max(1e3).empty(null).default(A8),s=Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(A_),i=Rt.optional().empty(null),o=Rt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Te.string().empty(null).default(A_),l=Te.custom(g8).empty(null).default(A_),u=e.clustering?.enabled,f=Te.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Te.object({enabled:r,hubServer:Te.object({cluster:Te.object({name:Te.required().empty(null),network:Te.object({port:Tn,routes:mE}).required()}).required(),leafNodes:Te.object({network:Te.object({port:Tn}).required()}).required(),network:Te.object({port:Tn}).required()}).required(),leafServer:Te.object({network:Te.object({port:Tn,routes:mE}).required(),streams:Te.object({maxAge:rr.min(120).allow(null).optional(),maxBytes:rr.min(1).allow(null).optional(),maxMsgs:rr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:Te.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:Be.optional(),databaseLevel:Be.optional(),tls:Te.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Be.required(),verify:Be.optional()}),user:Rt.optional().empty(null)}).optional():d=Te.object({enabled:r,tls:Te.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Be.optional()})}).optional(),Te.object({authentication:Te.alternatives(Te.object({authorizeLocal:Be,cacheTTL:rr.required(),enableSessions:Be,hashFunction:Rt.valid("md5","sha256","argon2id").optional().empty(null)}),Be).optional(),analytics:Te.object({aggregatePeriod:rr}),replication:Te.object({hostname:Te.alternatives(Rt,rr).optional().empty(null),url:Rt.optional().empty(null),port:Tn,securePort:Tn,routes:Yc.optional().empty(null),databases:Te.alternatives(Rt,Yc),enableRootCAs:Be.optional(),copyTablesToCatchUp:Be.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Te.object({enabled:r}).required(),logging:Te.object({auditAuthEvents:Te.object({logFailed:Be,logSuccessful:Be}),file:Be.required(),level:Te.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Te.object({enabled:Be.optional(),compress:Be.optional(),interval:Rt.custom(T8).optional().empty(null),maxSize:Rt.custom(S8).optional().empty(null),path:Rt.optional().empty(null).default(A_)}).required(),root:s,stdStreams:Be.required(),auditLog:Be.required()}).required(),operationsApi:Te.object({network:Te.object({cors:Be.optional(),corsAccessList:Yc.optional(),headersTimeout:rr.min(1).optional(),keepAliveTimeout:rr.min(1).optional(),port:Tn,domainSocket:Te.optional().empty("hdb/operations-server").default(A_),securePort:Tn,timeout:rr.min(1).optional()}).optional(),tls:Te.alternatives([Te.array().items(f),f])}).required(),rootPath:Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Te.object({network:Te.object({port:Tn,securePort:Tn,mtls:Te.alternatives([Be.optional(),Te.object({user:Rt.optional(),certificateAuthority:i,required:Be.optional()})])}).required(),webSocket:Be.optional(),requireAuthentication:Be.optional()}),http:Te.object({compressionThreshold:rr.optional(),cors:Be.optional(),corsAccessList:Yc.optional(),headersTimeout:rr.min(1).optional(),port:Tn,securePort:Tn,maxHeaderSize:rr.optional(),mtls:Te.alternatives([Be.optional(),Te.object({user:Rt.optional(),certificateAuthority:i,required:Be.optional()})]),threadRange:Te.alternatives([Yc.optional(),Rt.optional()])}).required(),threads:Te.alternatives(n.optional(),Te.object({count:n.optional(),debug:Te.alternatives(Be.optional(),Te.object({startingPort:rr.min(1).optional(),host:Rt.optional(),waitForDebugger:Be.optional()})),maxHeapMemory:rr.min(0).optional()})),storage:Te.object({writeAsync:Be.required(),overlappingSync:Be.optional(),caching:Be.optional(),compression:Te.alternatives([Be.optional(),Te.object({dictionary:Rt.optional(),threshold:rr.optional()})]),compactOnStart:Be.optional(),compactOnStartKeepBackup:Be.optional(),noReadAhead:Be.optional(),path:l,prefetchWrites:Be.optional(),maxFreeSpaceToLoad:rr.optional(),maxFreeSpaceToRetain:rr.optional()}).required(),ignoreScripts:Be.optional(),tls:Te.alternatives([Te.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(m8,"configValidator");function E8(e){return PU||CU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(E8,"doesPathExist");function g8(e,t){Te.assert(e,Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=E8(e);if(r)return t.message(r)}a(g8,"validatePath");function S8(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(d8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(_8):e}a(S8,"validateRotationMaxSize");function T8(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(f8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(p8):e}a(T8,"validateRotationInterval");function A8(e,t){let r=t.state.path.join("."),n=a8.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||NU();return i=Math.round(Math.min(i,NU())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),c8.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(A8,"setDefaultThreads");function A_(e,t){let r=t.state.path.join(".");if(!$y.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if($y.isEmpty(Bi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Kc.join(Bi,u8);case"logging.root":return Kc.join(Bi,IU);case"clustering.leafServer.streams.path":return Kc.join(Bi,"clustering","leaf");case"storage.path":let n=Kc.join(Bi,wU.LEGACY_DATABASES_DIR_NAME);return CU.existsSync(n)?n:Kc.join(Bi,wU.DATABASES_DIR_NAME);case"logging.rotation.path":return Kc.join(Bi,IU);case"operationsApi.network.domainSocket":return r==null?null:Kc.join(Bi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(A_,"setDefaultRoot");function R8(e){let t=Te.object({routes:mE});return l8.validateBySchema({routes:e},t)}a(R8,"routesValidator")});var yt=w(qU=>{"use strict";var bs=(H(),C(q)),gr=se(),nr=z(),{configValidator:y8,routesValidator:LU}=Vy(),zr=require("fs-extra"),vU=require("yaml"),zn=require("path"),b8=require("is-number"),UU=require("properties-reader"),O8=require("lodash"),{handleHDBError:N8}=pe(),{HTTP_STATUS_CODES:w8,HDB_ERROR_MSGS:Cu}=Bn(),{server:I8}=(Vr(),C(Tu)),{PACKAGE_ROOT:xU}=st(),{DATABASES_PARAM_CONFIG:R_,CONFIG_PARAMS:Wn,CONFIG_PARAM_MAP:ti}=bs,C8="Unable to get config value because config is uninitialized",P8="Config successfully initialized",D8="Error backing up config file",L8="Empty parameter sent to getConfigValue",BU=zn.join(xU,"config","yaml",bs.HDB_DEFAULT_CONFIG_FILE),M8=zn.join(xU,"config","yaml","defaultNatsConfig.yaml"),v8="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",MU={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"},EE,It,gE;Object.assign(qU,{createConfigFile:U8,getDefaultConfig:x8,getConfigValue:kU,initConfig:SE,flattenConfig:Pu,updateConfigValue:FU,updateConfigObject:H8,getConfiguration:G8,setConfiguration:q8,readConfigFile:zy,getClusteringRoutes:$8,initOldConfig:GU,getConfigFromFile:V8,getConfigFilePath:Wc,addConfig:K8,deleteConfigFromFile:Y8,getConfigObj:W8,resolvePath:Ky,getFlatConfigObj:z8});function Ky(e){if(e?.startsWith("~/"))return zn.join(gr.getHomeDir(),e.slice(1));let t=ae();return zn.resolve(t.getHdbBasePath(),e)}a(Ky,"resolvePath");function U8(e,t=!1){let r=wa(BU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=vU.parseDocument(zr.readFileSync(M8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}EE=Pu(r.toJSON());let n;for(let c in e){let l=ti[c.toLowerCase()];if(l===Wn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),f=Yy(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){nr.error(d)}}}n&&HU(r,n),Wy(r,t);let s=r.toJSON();It=Pu(s);let i=r.getIn(["rootPath"]),o=zn.join(i,bs.HDB_CONFIG_FILE);if(zr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);zr.writeFileSync(o,String(r)),nr.trace(`Config file written to ${o}`)}a(U8,"createConfigFile");function HU(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!gr.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(R_.TABLES))for(let i in n[s][R_.TABLES])for(let o in n[s][R_.TABLES][i]){let c=n[s][R_.TABLES][i][o],l=[Wn.DATABASES,s,R_.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Wn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){nr.error("Error parsing schemas CLI/env config arguments",n)}}a(HU,"setSchemasConfig");function x8(e){if(EE===void 0){let r=wa(BU);EE=Pu(r.toJSON())}let t=ti[e.toLowerCase()];if(t!==void 0)return EE[t.toLowerCase()]}a(x8,"getDefaultConfig");function kU(e){if(e==null){nr.info(L8);return}if(It===void 0){nr.trace(C8);return}let t=ti[e.toLowerCase()];if(t!==void 0)return It[t.toLowerCase()]}a(kU,"getConfigValue");function Wc(e=gr.getPropsFilePath()){let t=gr.getEnvCliRootPath();if(t)return Ky(zn.join(t,bs.HDB_CONFIG_FILE));let r=UU(e);return Ky(r.get(bs.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Wc,"getConfigFilePath");function SE(e=!1){if(It===void 0||e){let t;if(!gr.noBootFile()){t=gr.getPropsFilePath();try{zr.accessSync(t,zr.constants.F_OK|zr.constants.R_OK)}catch(i){throw nr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Wc(t),n;if(r.includes("config/settings.js"))try{GU(r);return}catch(i){if(i.code!==bs.NODE_ERROR_CODES.ENOENT)throw i}try{n=wa(r)}catch(i){if(i.code===bs.NODE_ERROR_CODES.ENOENT){nr.trace(`HarperDB config file not found at ${r}.
|
|
20
|
-
This can occur during early stages of install where the config file has not yet been created`);return}else throw nr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}B8(n,r),Wy(n);let s=n.toJSON();if(I8.config=s,It=Pu(s),It.logging_rotation_rotate)for(let i in MU)It[i]&&nr.error(`Config ${MU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);nr.trace(P8)}}a(SE,"initConfig");function B8(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],zn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],zn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(nr.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);zr.writeFileSync(t,String(e))}}a(B8,"checkForUpdatedConfig");function Wy(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Cu.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Cu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=y8(r,t);if(n.error)throw Cu.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(Wy,"validateConfig");function H8(e,t){It===void 0&&(It={});let r=ti[e.toLowerCase()];if(r===void 0){nr.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a(H8,"updateConfigObject");function FU(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&SE();let o=kU(ti.hdb_root),c=zn.join(o,bs.HDB_CONFIG_FILE),l=wa(c),u;if(r&&It){let p=!1;for(let _ in r)if(r[_]!=It[_.toLowerCase()]){p=!0;break}if(!p){nr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===Wn.DATABASES)u=t;else if(r===void 0){let p;if(i)p=e;else if(p=ti[e.toLowerCase()],p===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=p.split("_"),h=Yy(p,t);l.setIn([..._],h)}else for(let p in r){let _=ti[p.toLowerCase()];if(_===Wn.HTTP_SECUREPORT&&r[p]===It[Wn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===Wn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[p]===It[Wn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===Wn.DATABASES){u=r[p];continue}if(_?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!_&&(p.endsWith("_package")||p.endsWith("_port"))&&(_=p),_!==void 0){let h=_.split("_"),S=bs.LEGACY_CONFIG_PARAMS[p.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,h=S.split("_"));let g=Yy(_,r[p]);_==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],g)}catch(R){nr.error(R)}}}u&&HU(l,u),Wy(l);let f=l.getIn(["rootPath"]),d=zn.join(f,bs.HDB_CONFIG_FILE);if(n===!0&&k8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);zr.writeFileSync(d,String(l)),s&&(It=Pu(l.toJSON())),nr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(FU,"updateConfigValue");function k8(e,t){try{let r=zn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${bs.HDB_CONFIG_FILE}.bak`);zr.copySync(e,r),nr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){nr.error(D8),nr.error(r)}}a(k8,"backupConfigFile");var F8=["databases"];function Pu(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),gE=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!F8.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Wn[l.toUpperCase()]&&ti[l]&&(s[ti[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Pu,"flattenConfig");function Yy(e,t){if(e===Wn.CLUSTERING_NODENAME||e===Wn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(b8(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||gr.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 gr.autoCast(t)}a(Yy,"castConfigValue");function G8(){let e=gr.getPropsFilePath(),t=Wc(e);return wa(t).toJSON()}a(G8,"getConfiguration");async function q8(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return FU(void 0,void 0,s,!0),v8}catch(i){throw typeof i=="string"||i instanceof String?N8(i,i,w8.BAD_REQUEST,void 0,void 0,!0):i}}a(q8,"setConfiguration");function zy(){let e=gr.getPropsFilePath();try{zr.accessSync(e,zr.constants.F_OK|zr.constants.R_OK)}catch(n){if(!gr.noBootFile())throw nr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Wc(e);return wa(t).toJSON()}a(zy,"readConfigFile");function wa(e){return vU.parseDocument(zr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(wa,"parseYamlDoc");function $8(){let e=zy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=gr.isEmptyOrZeroLength(t)?[]:t;let r=LU(t);if(r)throw Cu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=gr.isEmptyOrZeroLength(n)?[]:n;let s=LU(n);if(s)throw Cu.CONFIG_VALIDATION(s.message);if(!gr.isEmptyOrZeroLength(n)&&!gr.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!gr.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Cu.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a($8,"getClusteringRoutes");function GU(e){let t=UU(e);It={};for(let r in ti){let n=t.get(r.toUpperCase());if(gr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ti[r].toLowerCase();s===Wn.LOGGING_ROOT?It[s]=zn.dirname(n):It[s]=n}return It}a(GU,"initOldConfig");function V8(e){let t=zy();return O8.get(t,e.replaceAll("_","."))}a(V8,"getConfigFromFile");async function K8(e,t){let r=wa(Wc());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await zr.writeFile(Wc(),String(r))}a(K8,"addConfig");function Y8(e){let t=Wc(gr.getPropsFilePath()),r=wa(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=zn.join(n,bs.HDB_CONFIG_FILE);zr.writeFileSync(s,String(r))}a(Y8,"deleteConfigFromFile");function W8(){return gE||(SE(),gE)}a(W8,"getConfigObj");function z8(){return It||SE(),It}a(z8,"getFlatConfigObj")});var An=w((DNe,Or)=>{"use strict";var KU="username is required",YU="nothing to update, must supply active, role or password to update",WU="password cannot be an empty string",zU="If role is specified, it cannot be empty.",jU="active must be true or false";Or.exports.addUser=n5;Or.exports.alterUser=s5;Or.exports.dropUser=o5;Or.exports.getSuperUser=d5;Or.exports.userInfo=a5;Or.exports.listUsers=AE;Or.exports.listUsersExternal=c5;Or.exports.setUsersWithRolesCache=zc;Or.exports.findAndValidateUser=nb;Or.exports.getClusterUser=f5;Or.exports.getUsersWithRolesCache=u5;Or.exports.USERNAME_REQUIRED=KU;Or.exports.ALTERUSER_NOTHING_TO_UPDATE=YU;Or.exports.EMPTY_PASSWORD=WU;Or.exports.EMPTY_ROLE=zU;Or.exports.ACTIVE_BOOLEAN=jU;var QU=Rn(),j8=Vc(),y_=(hE(),C(pE)),JU=RU(),b_=Yr(),Zy=yo(),Hi=se(),XU=require("validate.js"),eb=z(),{promisify:Q8}=require("util"),tb=To(),Qy=(H(),C(q)),$U=Tt(),J8=yt(),X8=ae(),Z8=Eo(),{hdb_errors:e5,ClientError:ri}=pe(),{HTTP_STATUS_CODES:Ro,AUTHENTICATION_ERROR_MSGS:jy,HDB_ERROR_MSGS:Du}=e5,{UserEventMsg:rb}=ni(),Jy=require("lodash"),{server:TE}=(Vr(),C(Tu)),t5=z();TE.getUser=(e,t)=>nb(e,t,t!=null);TE.authenticateUser=(e,t)=>nb(e,t);var ZU={username:!0,active:!0,role:!0,password:!0},VU=new Map,r5=Q8(j8.delete),Xy=X8.get(Qy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??y_.HASH_FUNCTION.SHA256,ki;async function n5(e){let t=XU.cleanAttributes(e,ZU),r=JU.addUserValidation(t);if(r)throw new ri(r.message);let n=await b_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new ri(Du.ROLE_NAME_NOT_FOUND(t.role),Ro.NOT_FOUND);if(n.length>1)throw new ri(Du.DUP_ROLES_FOUND(t.role),Ro.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=tb.encrypt(t.password)),t.password=await y_.hash(t.password,Xy),t.hash_function=Xy,t.role=n[0].id;let s=await QU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(eb.debug(s),await zc(),s.skipped_hashes.length===1)throw new ri(Du.USER_ALREADY_EXISTS(t.username),Ro.CONFLICT);return Zy.signalUserChange(new rb(process.pid)),`${t.username} successfully added`}a(n5,"addUser");async function s5(e){let t=XU.cleanAttributes(e,ZU);if(Hi.isEmptyOrZeroLength(t.username))throw new Error(KU);if(Hi.isEmptyOrZeroLength(t.password)&&Hi.isEmptyOrZeroLength(t.role)&&Hi.isEmptyOrZeroLength(t.active))throw new Error(YU);if(!Hi.isEmpty(t.password)&&Hi.isEmptyOrZeroLength(t.password.trim()))throw new Error(WU);if(!Hi.isEmpty(t.active)&&!Hi.isBoolean(t.active))throw new Error(jU);if(!Hi.isEmpty(t.password)&&!Hi.isEmptyOrZeroLength(t.password.trim())&&(i5(t.username)&&(t.hash=tb.encrypt(t.password)),t.password=await y_.hash(t.password,Xy)),t.role==="")throw new Error(zU);if(t.role){let n=await b_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ri(Du.ALTER_USER_ROLE_NOT_FOUND(t.role),Ro.NOT_FOUND);if(n.length>1)throw new ri(Du.DUP_ROLES_FOUND(t.role),Ro.CONFLICT);t.role=n[0].id}let r=await QU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await zc(),Zy.signalUserChange(new rb(process.pid)),r}a(s5,"alterUser");function i5(e){let t=!1,r=ki.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(i5,"isClusterUser");async function o5(e){let t=JU.dropUserValidation(e);if(t)throw new ri(t.message);if(ki.get(e.username)===void 0)throw new ri(Du.USER_NOT_EXIST(e.username),Ro.NOT_FOUND);let r=await r5({table:"hdb_user",schema:"system",hash_values:[e.username]});return eb.debug(r),await zc(),Zy.signalUserChange(new rb(process.pid)),`${e.username} successfully deleted`}a(o5,"dropUser");async function a5(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Jy.cloneDeep(e.hdb_user);let r=await b_.searchByHash({schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]});return t.role=r[0],delete t.password,delete t.refresh_token,delete t.hash,delete t.hash_function,t}a(a5,"userInfo");async function c5(){let e=await AE();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(c5,"listUsersExternal");async function AE(){let e=await b_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Jy.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await b_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Jy.cloneDeep(s),s.role=t[s.role],l5(s.role),n.set(s.username,s);return n}a(AE,"listUsers");function l5(e){if(!e){eb.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(Z8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(l5,"appendSystemTablesToRole");async function zc(e=void 0){e?ki=e:ki=await AE()}a(zc,"setUsersWithRolesCache");async function u5(){return ki||await zc(),ki}a(u5,"getUsersWithRolesCache");async function nb(e,t,r=!0){ki||await zc();let n=ki.get(e);if(!n){if(!r)return{username:e};throw new ri(jy.GENERIC_AUTH_FAIL,Ro.UNAUTHORIZED)}if(n&&!n.active)throw new ri(jy.USER_INACTIVE,Ro.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(VU.get(t)===n.password)return s;{let i=y_.validate(n.password,t,n.hash_function||y_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)VU.set(t,n.password);else throw new ri(jy.GENERIC_AUTH_FAIL,Ro.UNAUTHORIZED)}}return s}a(nb,"findAndValidateUser");async function d5(){ki||await zc();for(let[,e]of ki)if(e.role.role==="super_user")return e}a(d5,"getSuperUser");async function f5(){let e=await AE(),t=J8.getConfigFromFile(Qy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==Qy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=tb.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+$U.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+$U.SERVER_SUFFIX.ADMIN,r}a(f5,"getClusterUser");var e0=[];TE.invalidateUser=function(e){for(let t of e0)try{t(e)}catch(r){t5.error("Error invalidating user",r)}};TE.onInvalidatedUser=function(e){e0.push(e)}});var N_=w((UNe,s0)=>{"use strict";var jc=z(),jn=(H(),C(q)),_5=gv(),MNe=ys(),vNe=Ao(),p5=An(),{validateEvent:t0}=ni(),O_=Yn(),h5=require("process"),{resetDatabases:m5}=(Pe(),C(tt)),E5={[jn.ITC_EVENT_TYPES.SCHEMA]:g5,[jn.ITC_EVENT_TYPES.USER]:n0};async function g5(e){let t=t0(e);if(t){jc.error(t);return}jc.trace("ITC schemaHandler received schema event:",e),await _5(e.message),await S5(e.message)}a(g5,"schemaHandler");async function S5(e){try{O_.resetReadTxn(jn.SYSTEM_SCHEMA_NAME,jn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),O_.resetReadTxn(jn.SYSTEM_SCHEMA_NAME,jn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),O_.resetReadTxn(jn.SYSTEM_SCHEMA_NAME,jn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=m5();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){jc.error(t)}}a(S5,"syncSchemaMetadata");var r0=[];async function n0(e){try{try{O_.resetReadTxn(jn.SYSTEM_SCHEMA_NAME,jn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),O_.resetReadTxn(jn.SYSTEM_SCHEMA_NAME,jn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){jc.warn(r)}let t=t0(e);if(t){jc.error(t);return}jc.trace(`ITC userHandler ${jn.HDB_ITC_CLIENT_PREFIX}${h5.pid} received user event:`,e),await p5.setUsersWithRolesCache();for(let r of r0)r()}catch(t){jc.error(t)}}a(n0,"userHandler");n0.addListener=function(e){r0.push(e)};s0.exports=E5});var ni=w((GNe,o0)=>{"use strict";var BNe=z(),sb=se(),T5=(H(),C(q)),{ITC_ERRORS:w_}=Bn(),{parentPort:HNe,threadId:A5,isMainThread:R5,workerData:kNe}=require("worker_threads"),{onMessageFromWorkers:y5,broadcast:FNe,broadcastWithAcknowledgement:b5}=et();o0.exports={sendItcEvent:O5,validateEvent:i0,SchemaEventMsg:N5,UserEventMsg:w5};var RE;y5(async(e,t)=>{RE=RE||N_(),i0(e),RE[e.type]&&await RE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function O5(e){return!R5&&e.message&&(e.message.originator=A5),b5(e)}a(O5,"sendItcEvent");function i0(e){if(typeof e!="object")return w_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||sb.isEmpty(e.type))return w_.MISSING_TYPE;if(!e.hasOwnProperty("message")||sb.isEmpty(e.message))return w_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||sb.isEmpty(e.message.originator))return w_.MISSING_ORIGIN;if(T5.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return w_.INVALID_EVENT(e.type)}a(i0,"validateEvent");function N5(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(N5,"SchemaEventMsg");function w5(e){this.originator=e}a(w5,"UserEventMsg")});var yo=w((VNe,u0)=>{"use strict";var a0=(H(),C(q)),$Ne=se(),yE=z(),c0=hv(),Lu,{sendItcEvent:l0}=ni();function I5(e){try{yE.info("signalSchemaChange called with message:",e),Lu=Lu||N_();let t=new c0(a0.ITC_EVENT_TYPES.SCHEMA,e);return Lu.schema(t),l0(t)}catch(t){yE.error(t)}}a(I5,"signalSchemaChange");function C5(e){try{yE.trace("signalUserChange called with message:",e),Lu=Lu||N_();let t=new c0(a0.ITC_EVENT_TYPES.USER,e);return Lu.user(t),l0(t)}catch(t){yE.error(t)}}a(C5,"signalUserChange");u0.exports={signalSchemaChange:I5,signalUserChange:C5}});var bE=w((YNe,f0)=>{"use strict";var d0=se(),P5=(H(),C(q)),D5=z(),L5=iE(),M5=sE(),v5=yo(),{SchemaEventMsg:U5}=ni(),x5="already exists in";f0.exports=B5;async function B5(e,t,r){if(d0.isEmptyOrZeroLength(r))return r;let n=[];d0.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await H5(e,t.schema,t.name,i)})),s}a(B5,"lmdbCheckForNewAttributes");async function H5(e,t,r,n){let s=new M5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await k5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(x5))D5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(H5,"createNewAttribute");async function k5(e){let t;return t=await L5(e),v5.signalSchemaChange(new U5(process.pid,P5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(k5,"createAttribute")});var Mu=w((zNe,_0)=>{"use strict";var ib=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};_0.exports=ib});var h0=w((QNe,p0)=>{"use strict";var F5=Mu(),G5=(H(),C(q)).OPERATIONS_ENUM,ob=class extends F5{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(G5.INSERT,r,n,s,i),this.records=t}};p0.exports=ob});var E0=w((XNe,m0)=>{"use strict";var q5=Mu(),$5=(H(),C(q)).OPERATIONS_ENUM,ab=class extends q5{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super($5.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};m0.exports=ab});var S0=w((ewe,g0)=>{"use strict";var V5=Mu(),K5=(H(),C(q)).OPERATIONS_ENUM,cb=class extends V5{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(K5.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};g0.exports=cb});var A0=w((rwe,T0)=>{"use strict";var Y5=Mu(),W5=(H(),C(q)).OPERATIONS_ENUM,lb=class extends Y5{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(W5.DELETE,n,s,t,i),this.original_records=r}};T0.exports=lb});var I_=w((iwe,O0)=>{"use strict";var swe=require("path"),R0=_t(),z5=h0(),j5=E0(),Q5=S0(),J5=A0(),vu=vt(),y0=se(),{CONFIG_PARAMS:X5}=(H(),C(q)),b0=ae();b0.initSync();var OE=(H(),C(q)).OPERATIONS_ENUM,{getTransactionAuditStorePath:Z5}=gt();O0.exports=e9;async function e9(e,t){if(b0.get(X5.LOGGING_AUDITLOG)===!1)return;let r=Z5(e.schema,e.table),n=await R0.openEnvironment(r,e.table,!0),s=t9(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){R0.initializeDBIs(n,vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,vu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),y0.isEmpty(s.user_name)||n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(e9,"writeTransaction");function t9(e,t){let r=y0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===OE.INSERT)return new z5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPDATE)return new j5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPSERT)return new Q5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.DELETE)return new J5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(t9,"createTransactionObject")});var ub=w((cwe,N0)=>{"use strict";var r9=d_(),awe=vf(),C_=(H(),C(q)),n9=Uf(),s9=kc().insertRecords,i9=_t(),o9=z(),a9=bE(),{getSchemaPath:c9}=gt(),l9=I_();N0.exports=u9;async function u9(e){try{let{schema_table:t,attributes:r}=r9(e);n9(e,r,t.hash_attribute),e.schema!==C_.SYSTEM_SCHEMA_NAME&&(r.includes(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await a9(e.hdb_auth_header,t,r),s=c9(e.schema,e.table),i=await i9.openEnvironment(s,e.table),o=await s9(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await l9(e,o)}catch(c){o9.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(u9,"lmdbCreateRecords")});var C0=w((uwe,I0)=>{"use strict";var w0=(H(),C(q)),d9=ub(),f9=vf(),_9=require("fs-extra"),{getSchemaPath:p9}=gt();I0.exports=h9;async function h9(e){let t=[{name:e.schema,createddate:Date.now()}],r=new f9(w0.SYSTEM_SCHEMA_NAME,w0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await d9(r),await _9.mkdirp(p9(e.schema))}a(h9,"lmdbCreateSchema")});var D0=w((fwe,P0)=>{"use strict";var db=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};P0.exports=db});var U0=w((Ewe,v0)=>{"use strict";var L0=_t(),fb=_n(),_b=Bn().LMDB_ERRORS_ENUM,m9=vt(),M0=z(),pwe=se(),E9=require("lmdb"),g9=D0(),S9=(H(),C(q)),{OVERFLOW_MARKER:hwe,MAX_SEARCH_KEY_LENGTH:mwe}=m9,T9=S9.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function A9(e,t,r,n){if(fb.validateEnv(e),t===void 0)throw new Error(_b.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(_b.IDS_REQUIRED):new Error(_b.IDS_MUST_BE_ITERABLE);try{let s=L0.listDBIs(e);L0.initializeDBIs(e,t,s);let i=new g9,o,c=[],l=[];for(let p=0,_=r.length;p<_;p++)try{o=r[p];let h=e.dbis[t].get(o);if(!h||n&&h[T9]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,E9.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let R=s[g];if(!h.hasOwnProperty(R)||R===t)continue;let E=e.dbis[R],A=h[R];if(A!=null)try{let O=fb.getIndexedValues(A);if(O)for(let v=0,F=O.length;v<F;v++)E.remove(O[v],o)}catch{M0.warn(`cannot delete from attribute: ${R}, ${A}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(h)}catch(h){M0.warn(h),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let p=0,_=f.length;p<_;p++)f[p]===!0?i.deleted.push(l[p]):(i.skipped.push(l[p]),u.push(p));let d=0;for(let p=0;p<u.length;p++){let _=u[p];i.original_records.splice(_-d,1),d++}return i.txn_time=fb.getNextMonotonicTime(),i}catch(s){throw s}}a(A9,"deleteRecords");v0.exports={deleteRecords:A9}});var P_=w((Swe,B0)=>{"use strict";var Uu=se(),R9=U0(),y9=_t(),{getSchemaPath:b9}=gt(),O9=I_(),N9=z();B0.exports=w9;async function w9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Uu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Uu.isEmptyOrZeroLength(e.hash_values)&&!Uu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Uu.isEmpty(l)||e.hash_values.push(l)}}if(Uu.isEmptyOrZeroLength(e.hash_values))return x0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Uu.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=b9(e.schema,e.table),i=await y9.openEnvironment(s,e.table),o=await R9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await O9(e,o)}catch(c){N9.error(`unable to write transaction due to ${c.message}`)}return x0(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(w9,"lmdbDeleteRecords");function x0(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(x0,"createDeleteResponse")});var hb=w((Rwe,H0)=>{"use strict";var I9=(H(),C(q)),Awe=_n();function pb(e,t){let r=Object.create(null);if(t.length===1&&I9.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(pb,"parseRow");function C9(e,t,r,n){let s=pb(r,e);n.push(s)}a(C9,"searchAll");function P9(e,t,r,n){let s=pb(r,e);n[t]=s}a(P9,"searchAllToMap");function D9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(D9,"iterateDBI");function Qc(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(Qc,"pushResults");function L9(e,t,r,n,s,i){t.toString().endsWith(e)&&Qc(t,r,n,s,i)}a(L9,"endsWith");function M9(e,t,r,n,s,i){t.toString().includes(e)&&Qc(t,r,n,s,i)}a(M9,"contains");function v9(e,t,r,n,s,i){t>e&&Qc(t,r,n,s,i)}a(v9,"greaterThanCompare");function U9(e,t,r,n,s,i){t>=e&&Qc(t,r,n,s,i)}a(U9,"greaterThanEqualCompare");function x9(e,t,r,n,s,i){t<e&&Qc(t,r,n,s,i)}a(x9,"lessThanCompare");function B9(e,t,r,n,s,i){t<=e&&Qc(t,r,n,s,i)}a(B9,"lessThanEqualCompare");H0.exports={parseRow:pb,searchAll:C9,searchAllToMap:P9,iterateDBI:D9,endsWith:L9,contains:M9,greaterThanCompare:v9,greaterThanEqualCompare:U9,lessThanCompare:x9,lessThanEqualCompare:B9,pushResults:Qc}});var xu=w((wwe,K0)=>{"use strict";var Ia=_t(),bwe=z(),Qn=_n(),NE=vt(),Yt=Bn().LMDB_ERRORS_ENUM,Owe=se(),H9=(H(),C(q)),wE=hb(),{parseRow:k9}=wE,Nwe=require("lmdb"),{OVERFLOW_MARKER:k0,MAX_SEARCH_KEY_LENGTH:F9}=NE;function F0(e,t,r,n=!1,s=void 0,i=void 0){return Jc(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(F0,"iterateFullIndex");function D_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Jc(e,t,r,(f,d,p,_)=>{let E={transaction:f,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return _===r?(E.values=!1,d.getRange(E).map(A=>({value:A}))):d.getRange(E)})}a(D_,"iterateRangeBetween");function Jc(e,t,r,n){let s=e.database||e,i=Ia.openDBI(s,r);i[NE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Ia.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Jc,"setupTransaction");function G0(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(k0)){if(!s)if(r)s=Ia.openDBI(e,r);else{let l=Ia.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=Ia.openDBI(e,l[u]),!s[NE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(G0,"getOverflowCheck");function G9(e,t,r,n=!1,s=void 0,i=void 0){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);return Jc(e,t,t,(o,c,l)=>(IE(r),r=L_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>k9(u.value,r))))}a(G9,"searchAll");function q9(e,t,r,n=!1,s=void 0,i=void 0){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);IE(r),r=L_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of F0(e,t,t,n,s,i))o.set(c,wE.parseRow(l,r));return o}a(q9,"searchAllToMap");function $9(e,t,r=!1,n=void 0,s=void 0){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=F0(e,void 0,t,r,n,s),c=o.transaction,l=G0(c.database,c,void 0,t);for(let{key:u,value:f}of o){let d=l(u,f);i[d]===void 0&&(i[d]=[]),i[d].push(f)}return i}a($9,"iterateDBI");function V9(e,t){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);return Ia.statDBI(e,t).entryCount}a(V9,"countAll");function K9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ca(e,r,n),Jc(e,t,r,(c,l,u,f)=>(n=Qn.convertKeyValueToWrite(n),f===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(K9,"equals");function Y9(e,t,r){return Ca(e,t,r),Ia.openDBI(e,t).getValuesCount(r)}a(Y9,"count");function W9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ca(e,r,n),Jc(e,null,r,(c,l)=>{n=Qn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let p of l.getKeys({transaction:c,start:n}))if(!p.startsWith(n)){d=p;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),f=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(p=>{let{key:_}=p;if(_!==d){if(_.toString().startsWith(n))return p;if(u===!0)return f.DONE}}),f.filter(p=>p)}else return f=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(u===!0)return f.DONE}),u?f:f.filter(d=>d)})}a(W9,"startsWith");function z9(e,t,r,n,s=!1,i=void 0,o=void 0){return q0(e,t,r,n,s,i,o,!0)}a(z9,"endsWith");function q0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Ca(e,r,n),Jc(e,null,r,(l,u,f,d)=>{let p=G0(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(_=>{let h=_.toString();return h.endsWith(k0)?u.getValues(_,{transaction:l}).map(S=>{let g=p(_,S);if(c?g.endsWith(n):g.includes(n))return{key:g,value:S}}).filter(S=>S):(c?h.endsWith(n):h.includes(n))?u[NE.DBI_DEFINITION_NAME].is_hash_attribute?{key:_,value:_}:u.getValues(_,{transaction:l}).map(S=>({key:_,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(q0,"contains");function j9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),D_(e,t,r,n,l,s,i,o,!0,!1)}a(j9,"greaterThan");function Q9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),D_(e,t,r,n,l,s,i,o,!1,!1)}a(Q9,"greaterThanEqual");function J9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),D_(e,t,r,l,n,s,i,o,!1,!0)}a(J9,"lessThan");function X9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),D_(e,t,r,l,n,s,i,o,!1,!1)}a(X9,"lessThanEqual");function Z9(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Qn.validateEnv(e),r===void 0)throw new Error(Yt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Yt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Yt.END_VALUE_REQUIRED);if(n=Qn.convertKeyValueToWrite(n),s=Qn.convertKeyValueToWrite(s),n>s)throw new Error(Yt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return D_(e,t,r,n,s,i,o,c)}a(Z9,"between");function e7(e,t,r,n){Qn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),r=L_(s,r),n===void 0)throw new Error(Yt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=wE.parseRow(c,r)),o}a(e7,"searchByHash");function t7(e,t,r){Qn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Yt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(t7,"checkHashExists");function r7(e,t,r,n,s=[]){return V0(e,t,r,n,s),$0(e,t,r,n,s).map(i=>i[1])}a(r7,"batchSearchByHash");function n7(e,t,r,n,s=[]){V0(e,t,r,n,s);let i=new Map;for(let[o,c]of $0(e,t,r,n,s))i.set(o,c);return i}a(n7,"batchSearchByHashToMap");function $0(e,t,r,n,s=[]){return Jc(e,t,t,(i,o,c)=>{r=L_(c,r);let l=r.length<3;return n.map(u=>{let f=c.dbis[t].get(u,{transaction:i,lazy:l});if(f)return[u,wE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a($0,"batchHashSearch");function V0(e,t,r,n,s){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),n==null)throw new Error(Yt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Yt.IDS_MUST_BE_ITERABLE)}a(V0,"initializeBatchSearchByHash");function IE(e){if(!Array.isArray(e))throw e===void 0?new Error(Yt.FETCH_ATTRIBUTES_REQUIRED):new Error(Yt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(IE,"validateFetchAttributes");function Ca(e,t,r){if(Qn.validateEnv(e),t===void 0)throw new Error(Yt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Yt.SEARCH_VALUE_REQUIRED);if(r?.length>F9)throw new Error(Yt.SEARCH_VALUE_TOO_LARGE)}a(Ca,"validateComparisonFunctions");function L_(e,t){return t.length===1&&H9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Ia.listDBIs(e)),t}a(L_,"setGetWholeRowAttributes");K0.exports={searchAll:G9,searchAllToMap:q9,count:Y9,countAll:V9,equals:K9,startsWith:W9,endsWith:z9,contains:q0,searchByHash:e7,setGetWholeRowAttributes:L_,batchSearchByHash:r7,batchSearchByHashToMap:n7,checkHashExists:t7,iterateDBI:$9,greaterThan:j9,greaterThanEqual:Q9,lessThan:J9,lessThanEqual:X9,between:Z9}});var Bu=w((Cwe,Q0)=>{var Y0=require("lodash"),W0=ft(),He=require("joi"),s7=se(),{hdb_schema_table:M_,checkValidTable:z0,hdb_table:j0,hdb_database:CE}=Mi(),{handleHDBError:i7,hdb_errors:o7}=pe(),{getDatabases:a7}=(Pe(),C(tt)),{HTTP_STATUS_CODES:c7}=o7,l7=He.object({database:CE,schema:CE,table:j0,search_attribute:M_,search_value:He.any().required(),get_attributes:He.array().min(1).items(He.alternatives(M_,He.object())).optional(),desc:He.bool(),limit:He.number().integer().min(1),offset:He.number().integer().min(0)}),u7=He.object({database:CE,schema:CE,table:j0,operator:He.string().valid("and","or").default("and").lowercase(),offset:He.number().integer().min(0),limit:He.number().integer().min(1),get_attributes:He.array().min(1).items(He.alternatives(M_,He.object())).optional(),sort:He.object({attribute:He.alternatives(M_,He.array().min(1)),descending:He.bool().optional()}).optional(),conditions:He.array().min(1).items(He.alternatives(He.object({operator:He.string().valid("and","or").default("and").lowercase(),conditions:He.array()}),He.object({search_attribute:He.alternatives(M_,He.array().min(1)),search_type:He.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:He.when("search_type",{switch:[{is:"equals",then:He.any()},{is:"between",then:He.array().items(He.alternatives([He.string(),He.number()])).length(2)}],otherwise:He.alternatives(He.string(),He.number())}).required()}))).required()});Q0.exports=function(e,t){let r=null;switch(t){case"value":r=W0.validateBySchema(e,l7);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(z0("database",e.schema)),i(z0("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(o=>typeof o=="string"||typeof o=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=W0.validateBySchema(e,u7);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=s7.checkGlobalSchemaTable(e.schema,e.table);if(s)return i7(new Error,s,c7.NOT_FOUND);let o=a7()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(f=>{for(let d=0,p=f.conditions.length;d<p;d++){let _=f.conditions[d];_.conditions?l(_):c.push(_.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=Y0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!Y0.some(o,d=>d===f||d.attribute===f||d.attribute===f.attribute));if(u&&u.length>0){let f=u.join(", ");return f=f.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${f}'`)}}return r}});var mb=w((Dwe,J0)=>{"use strict";var d7=_t(),f7=Bu(),{getSchemaPath:_7}=gt();J0.exports=p7;function p7(e){let t=f7(e,"hashes");if(t)throw t;let r=_7(e.schema,e.table);return d7.openEnvironment(r,e.table)}a(p7,"initialize")});var Eb=w((Mwe,X0)=>{"use strict";var h7=xu(),m7=mb();X0.exports=E7;async function E7(e){let t=await m7(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return h7.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(E7,"lmdbGetDataByHash")});var Hu=w((Uwe,Z0)=>{"use strict";var gb=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};Z0.exports=gb});var tx=w((Hwe,ex)=>{"use strict";var Bwe=Hu(),g7=xu(),S7=mb();ex.exports=T7;async function T7(e){let t=await S7(e),r=global.hdb_schema[e.schema][e.table];return g7.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(T7,"lmdbSearchByHash")});var si=w((Fwe,rx)=>{"use strict";var Sb=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,f=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=f}};rx.exports=Sb});var PE=w((qwe,cx)=>{"use strict";var jr=xu(),A7=_t(),R7=se(),ke=vt(),Xc=(H(),C(q)),y7=Eo(),nx=Bn().LMDB_ERRORS_ENUM,{getSchemaPath:b7}=gt(),bo=Xc.SEARCH_WILDCARDS;async function O7(e,t,r){let n;e.schema===Xc.SYSTEM_SCHEMA_NAME?n=y7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=ax(e,n.hash_attribute,r,t);return ix(e,s,n.hash_attribute,r)}a(O7,"prepSearch");async function ix(e,t,r,n){let s=b7(e.schema,e.table),i=await A7.openEnvironment(s,e.table),o=ox(i,e,t,r),c=o.transaction||i;if([ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,ke.SEARCH_TYPES.SEARCH_ALL,ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(N7(e,r)===!1){let f=e.search_attribute;if(f===r)return n?sx(o,()=>!0):o.map(p=>({[r]:p.key}));let d=a(p=>({[r]:p.value,[f]:p.key}),"toObject");return n?sx(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?jr.batchSearchByHashToMap(c,r,e.get_attributes,u):jr.batchSearchByHash(c,r,e.get_attributes,u)}a(ix,"executeSearch");function ox(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case ke.SEARCH_TYPES.EQUALS:s=jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.CONTAINS:s=jr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.ENDS_WITH:case ke.SEARCH_TYPES._ENDS_WITH:s=jr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.STARTS_WITH:case ke.SEARCH_TYPES._STARTS_WITH:s=jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.SEARCH_ALL:return jr.searchAll(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.BETWEEN:s=jr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN:case ke.SEARCH_TYPES._GREATER_THAN:s=jr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN_EQUAL:case ke.SEARCH_TYPES._GREATER_THAN_EQUAL:s=jr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN:case ke.SEARCH_TYPES._LESS_THAN:s=jr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN_EQUAL:case ke.SEARCH_TYPES._LESS_THAN_EQUAL:s=jr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(ox,"searchByType");function sx(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(sx,"createMapFromIterable");function N7(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}a(N7,"checkToFetchMore");function ax(e,t,r,n){if(R7.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),bo.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(bo[0])<0&&s.indexOf(bo[1])<0)return c===!0?r===!0?ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:ke.SEARCH_TYPES.EQUALS;if(bo.indexOf(i)>=0&&bo.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(bo.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(bo.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(bo[0])||s.includes(bo[1]))return ke.SEARCH_TYPES.EQUALS;throw new Error(nx.UNKNOWN_SEARCH_TYPE)}else switch(n){case Xc.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case Xc.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case Xc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case Xc.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case Xc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return ke.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(nx.UNKNOWN_SEARCH_TYPE)}}a(ax,"createSearchTypeFromSearchObject");cx.exports={executeSearch:ix,createSearchTypeFromSearchObject:ax,prepSearch:O7,searchByType:ox}});var ux=w((Kwe,lx)=>{"use strict";var Vwe=si(),w7=Bu(),I7=se(),C7=(H(),C(q)),P7=PE();lx.exports=D7;function D7(e,t){if(!I7.isEmpty(t)&&C7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=w7(e,"value");if(n)throw n;return P7.prepSearch(e,t,!0)}a(D7,"lmdbGetDataByValue")});var v_=w((zwe,dx)=>{"use strict";var Wwe=si(),L7=Bu(),M7=se(),v7=(H(),C(q)),U7=PE();dx.exports=x7;async function x7(e,t){if(!M7.isEmpty(t)&&v7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=L7(e,"value");if(n)throw n;return U7.prepSearch(e,t,!1)}a(x7,"lmdbSearchByValue")});var _x=w((Jwe,fx)=>{"use strict";var Qwe=vt(),Tb=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},Ab=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Rb=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};fx.exports={SearchByConditionsObject:Tb,SearchCondition:Ab,SortAttribute:Rb}});var gx=w((tIe,Ex)=>{"use strict";var Zwe=_x().SearchByConditionsObject,B7=si(),H7=Bu(),yb=xu(),DE=vt(),{Resource:eIe}=(ga(),C(mR)),mx=PE(),k7=hb(),F7=require("lodash"),{getSchemaPath:G7}=gt(),px=_t(),{handleHDBError:q7,hdb_errors:$7}=pe(),{HTTP_STATUS_CODES:V7}=$7,K7=1e8;Ex.exports=Y7;async function Y7(e){let t=H7(e,"conditions");if(t)throw q7(t,t.message,V7.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=G7(e.schema,e.table),n=await px.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)px.openDBI(n,u.search_attribute);let i=F7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===DE.SEARCH_TYPES.EQUALS?u.estimated_count=yb.count(n,u.search_attribute,u.search_value):f===DE.SEARCH_TYPES.CONTAINS||f===DE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=K7}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await hx(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],f=i.slice(1).map(mx.filterByType),d=f.length,p=yb.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(_=>u.get(_,{transaction:o,lazy:!0})),d>0&&(l=l.filter(_=>{for(let h=0;h<d;h++)if(!f[h](_))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(_=>k7.parseRow(_,p))}else{for(let d=1;d<i.length;d++){let p=i[d],_=await hx(o,e,p,s.hash_attribute);c=c.concat(_)}let u=new Set,f=e.offset||0;c=c.filter(d=>u.has(d)?!1:(u.add(d),!0)).slice(f,e.limit&&e.limit+f),l=yb.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(Y7,"lmdbSearchByConditions");async function hx(e,t,r,n){let s=new B7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===DE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,mx.searchByType(e,s,i,n).map(o=>o.value)}a(hx,"executeConditionSearch")});var U_=w((nIe,Sx)=>{"use strict";var W7=(H(),C(q)).OPERATIONS_ENUM,bb=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=W7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Sx.exports=bb});var Ob=w((iIe,wx)=>{"use strict";var yx=si(),bx=U_(),Ox=v_(),Nx=P_(),yn=(H(),C(q)),Tx=se(),Ax=_t(),{getTransactionAuditStorePath:z7,getSchemaPath:j7}=gt(),Rx=z();wx.exports=Q7;async function Q7(e){try{if(Tx.isEmpty(global.hdb_schema[e.schema])||Tx.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await J7(e),await X7(e);let t=j7(e.schema,e.table);try{await Ax.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Rx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=z7(e.schema,e.table);await Ax.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Rx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(Q7,"lmdbDropTable");async function J7(e){let t=new yx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Ox(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new bx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Nx(s)}a(J7,"deleteAttributesFromSystem");async function X7(e){let t=new yx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Ox(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new bx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Nx(s)}catch(i){throw i}}a(X7,"dropTableFromSystem")});var Cx=w((aIe,Ix)=>{"use strict";var Z7=require("fs-extra"),eee=si(),tee=Hu(),ree=U_(),nee=Ob(),see=P_(),iee=Eb(),oee=v_(),Oo=(H(),C(q)),{getSchemaPath:aee}=gt(),{handleHDBError:cee,hdb_errors:lee}=pe(),{HDB_ERROR_MSGS:uee,HTTP_STATUS_CODES:dee}=lee;Ix.exports=fee;async function fee(e){let t;try{t=await _ee(e.schema);let r=new eee(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await oee(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await nee(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new ree(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await see(s);let i=aee(t);await Z7.remove(i)}catch(r){throw r}}a(fee,"lmdbDropSchema");async function _ee(e){let t=new tee(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await iee(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw cee(new Error,uee.SCHEMA_NOT_FOUND(e),dee.NOT_FOUND,void 0,void 0,!0);return n}a(_ee,"validateDropSchema")});var x_=w((lIe,Px)=>{"use strict";var Nb=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Px.exports=Nb});var Ib=w((fIe,Dx)=>{"use strict";var pee=require("fs-extra"),LE=_t(),{getTransactionAuditStorePath:hee}=gt(),wb=vt(),dIe=x_();Dx.exports=mee;async function mee(e){let t;try{let r=hee(e.schema,e.table);await pee.mkdirp(r),t=await LE.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{LE.createDBI(t,wb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),LE.createDBI(t,wb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),LE.createDBI(t,wb.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(mee,"createTransactionsAuditEnvironment")});var vx=w((hIe,Mx)=>{"use strict";var Cb=(H(),C(q)),Lx=_t(),Eee=kc(),{getSystemSchemaPath:gee,getSchemaPath:See}=gt(),pIe=Eo(),Tee=iE(),Pb=sE(),Aee=z(),Ree=Ib();Mx.exports=yee;async function yee(e,t){let r=See(t.schema,t.table),n=new Pb(t.schema,t.table,Cb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Pb(t.schema,t.table,Cb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Pb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Lx.createEnvironment(r,t.table),e!==void 0){let o=await Lx.openEnvironment(gee(),Cb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await Eee.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Db(n),await Db(s),await Db(i)}await Ree(t)}catch(o){throw o}}a(yee,"lmdbCreateTable");async function Db(e){try{await Tee(e)}catch(t){Aee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Db,"createAttribute")});var xx=w((EIe,Ux)=>{"use strict";var bee=d_(),Oee=Uf(),Nee=bE(),B_=(H(),C(q)),wee=kc().updateRecords,Iee=_t(),{getSchemaPath:Cee}=gt(),Pee=I_(),Dee=z();Ux.exports=Lee;async function Lee(e){try{let{schema_table:t,attributes:r}=bee(e);Oee(e,r,t.hash_attribute),e.schema!==B_.SYSTEM_SCHEMA_NAME&&(r.includes(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(B_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(B_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Nee(e.hdb_auth_header,t,r),s=Cee(e.schema,e.table),i=await Iee.openEnvironment(s,e.table),o=await wee(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Pee(e,o)}catch(c){Dee.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(Lee,"lmdbUpdateRecords")});var Hx=w((SIe,Bx)=>{"use strict";var Mee=(H(),C(q)).OPERATIONS_ENUM,Lb=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Mee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Bx.exports=Lb});var Fx=w((RIe,kx)=>{"use strict";var AIe=Hx(),vee=d_(),Uee=Uf(),xee=bE(),H_=(H(),C(q)),Bee=kc().upsertRecords,Hee=_t(),{getSchemaPath:kee}=gt(),Fee=I_(),Gee=z(),{handleHDBError:qee,hdb_errors:$ee}=pe();kx.exports=Vee;async function Vee(e){let t;try{t=vee(e)}catch(l){throw qee(l,l.message,$ee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;Uee(e,n,r.hash_attribute),e.schema!==H_.SYSTEM_SCHEMA_NAME&&(n.includes(H_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(H_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(H_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(H_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await xee(e.hdb_auth_header,r,n),i=kee(e.schema,e.table),o=await Hee.openEnvironment(i,e.table),c=await Bee(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Fee(e,c)}catch(l){Gee.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(Vee,"lmdbUpsertRecords")});var qx=w((bIe,Gx)=>{"use strict";var Mb=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};Gx.exports=Mb});var Vx=w((NIe,$x)=>{"use strict";var vb=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};$x.exports=vb});var Wx=w((CIe,Yx)=>{"use strict";var Ub=_t(),{getTransactionAuditStorePath:Kee}=gt(),IIe=qx(),k_=vt(),Yee=se(),Kx=Vx(),Wee=require("util").promisify,zee=Wee(setTimeout),jee=1e4,Qee=100;Yx.exports=Jee;async function Jee(e){let t=Kee(e.schema,e.table),r=await Ub.openEnvironment(t,e.table,!0),n=Ub.listDBIs(r);Ub.initializeDBIs(r,k_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Kx;do s=await Xee(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=s.start_timestamp),s.end_timestamp!==void 0&&(i.end_timestamp=s.end_timestamp),i.transactions_deleted+=s.transactions_deleted,await zee(Qee);while(s.transactions_deleted>0);return i}a(Jee,"deleteAuditLogsBefore");async function Xee(e,t){let r=new Kx;try{let n=e.dbis[k_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[k_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Yee.isEmpty(c)||(s=e.dbis[k_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[k_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>jee)break}return await s,r}catch(n){throw n}}a(Xee,"deleteTransactions")});var jx=w((DIe,zx)=>{"use strict";var xb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};zx.exports=xb});var Jx=w((vIe,Qx)=>{"use strict";var Zee=si(),ete=U_(),MIe=jx(),Fi=(H(),C(q)),tte=se(),Bb=_t(),rte=Eo(),nte=v_(),ste=P_(),{getSchemaPath:ite}=gt();Qx.exports=ote;async function ote(e,t=!0){let r;e.schema===Fi.SYSTEM_SCHEMA_NAME?r=rte[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await cte(e),s=ite(e.schema,e.table),i=await Bb.openEnvironment(s,e.table);return t===!0&&await ate(e,i,r.hash_attribute),Bb.dropDBI(i,e.attribute),n}a(ote,"lmdbDropAttribute");async function ate(e,t,r){let n=Bb.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let f in c)f!==i&&(u[f]=c[f]);s=t.dbis[r].put(o,u,l)}await s}a(ate,"removeAttributeFromAllObjects");async function cte(e){let t=new Zee(Fi.SYSTEM_SCHEMA_NAME,Fi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Fi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Fi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Fi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await nte(t)).filter(o=>o[Fi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(tte.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Fi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new ete(Fi.SYSTEM_SCHEMA_NAME,Fi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return ste(i)}a(cte,"dropAttributeFromSystem")});var nB=w((BIe,rB)=>{"use strict";var Hb=_t(),ku=vt(),xIe=_n(),kb=(H(),C(q)),Xx=se(),{getTransactionAuditStorePath:lte}=gt(),ute=xu(),ME=Mu(),dte=z();rB.exports=fte;async function fte(e){let t=lte(e.schema,e.table),r=await Hb.openEnvironment(t,e.table,!0),n=Hb.listDBIs(r);Hb.initializeDBIs(r,ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case kb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Zx(r,e.search_values);case kb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,pte(r,e.search_values,s);case kb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return _te(r,e.search_values);default:return Zx(r)}}a(fte,"readAuditLog");function Zx(e,t=[0,Date.now()]){Xx.isEmpty(t[0])&&(t[0]=0),Xx.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new ME,s))}a(Zx,"searchTransactionsByTimestamp");function _te(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[ku.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,tB(e,i))}return Object.fromEntries(r)}a(_te,"searchTransactionsByUsername");function pte(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=ute.equals(e,ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ku.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let p=Number(d);n.has(p)?n.get(p).push(u.toString()):n.set(p,[u.toString()])}}let s=Array.from(n.keys()),i=tB(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);eB(l,"records",r,f,o),eB(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(pte,"searchTransactionsByHashValues");function eB(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),f=u[u.length-1];if(f.timestamp===i)f[t]=[c];else{let d=new ME(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new ME(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(eB,"loopRecords");function tB(e,t){let r=[];try{let n=e.dbis[ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new ME,i);r.push(o)}}catch(i){dte.warn(i)}return r}catch(n){throw n}}a(tB,"batchSearchTransactions")});var iB=w((GIe,sB)=>{"use strict";var{getSchemaPath:kIe}=gt(),FIe=_t(),{database:hte}=(Pe(),C(tt));sB.exports={writeTransaction:mte};async function mte(e,t,r){return hte({database:e,table:t}).transaction(r)}a(mte,"writeTransaction")});var lB=w(($Ie,cB)=>{"use strict";var{getSchemaPath:oB}=gt(),aB=_t();cB.exports={flush:Ete,resetReadTxn:gte};async function Ete(e,t){return(await aB.openEnvironment(oB(e,t),t.toString())).flushed}a(Ete,"flush");async function gte(e,t){try{(await aB.openEnvironment(oB(e,t),t.toString())).resetReadTxn()}catch{}}a(gte,"resetReadTxn")});var _B=w((KIe,fB)=>{"use strict";var{Readable:Ste}=require("stream"),{getDatabases:Tte}=(Pe(),C(tt)),{readSync:Ate,openSync:Rte,createReadStream:uB}=require("fs"),{open:yte}=require("lmdb"),dB=s_(),bte=i_(),{AUDIT_STORE_OPTIONS:Ote}=(ho(),C(pB)),{INTERNAL_DBIS_NAME:Nte,AUDIT_STORE_NAME:wte}=vt();fB.exports=Cte;var Fb=32768,Ite=100;async function Cte(e){let t=e.database||e.schema||"data",r=Tte()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let f=u.dbisDB,d=yte({noSync:!0,maxDbs:bte.MAX_DBS}),p,_=d.openDB(Nte,new dB(!1)),h=f.useReadTransaction(),S=0,g=a(async function(E,A){A.encoding="binary",A.encoder=void 0;let O=d.openDB(E,A),v=f.openDB(E,A);for(let{key:F,version:G,value:Y}of v.getRange({start:null,transaction:h,versions:v.useVersions}))p=O.put(F,Y,G),S++%Ite===0&&(await new Promise(te=>setTimeout(te,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:E,value:A}of f.getRange({transaction:h,start:!1}))if(s.some(O=>E.startsWith?.(O+"/"))){_.put(E,A);let[,O]=E.split("/"),v=!O,F=new dB(!v,v);await g(E,F)}e.include_audit&&await g(wte,{...Ote}),await p;let R=uB(d.path);return R.headers=l(),R.on("close",()=>{h.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=Rte(o.path);return o.transaction(()=>{let u=Buffer.alloc(Fb);Ate(c,u,0,Fb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=uB(null,{fd:c,start:Fb}),p=new Ste.from(async function*(){yield u;for await(let _ of d)f.openTimer&&(f.openTimer=0),yield _;f.done()}());return p.headers=l(),p});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(Cte,"getBackup")});var EB=w((WIe,mB)=>{"use strict";var Pte=z(),{handleHDBError:Dte}=pe(),Lte=NM(),Mte=iE(),vte=ub(),Ute=C0(),xte=P_(),Bte=Eb(),Hte=tx(),kte=ux(),Fte=v_(),Gte=gx(),qte=Cx(),$te=vx(),Vte=xx(),Kte=Fx(),Yte=Wx(),Wte=Ob(),zte=Jx(),jte=nB(),Qte=iB(),hB=lB(),Jte=_B(),Gb=class extends Lte{static{a(this,"LMDBBridge")}async searchByConditions(t){return Gte(t)}async getDataByHash(t){return await Bte(t)}async searchByHash(t){return await Hte(t)}async getDataByValue(t,r){return await kte(t,r)}async searchByValue(t){return await Fte(t)}async createSchema(t){return await Ute(t)}async dropSchema(t){return await qte(t)}async createTable(t,r){return await $te(t,r)}async dropTable(t){return await Wte(t)}async createAttribute(t){return await Mte(t)}async createRecords(t){return await vte(t)}async updateRecords(t){return await Vte(t)}async upsertRecords(t){try{return await Kte(t)}catch(r){throw Dte(r,null,null,Pte.ERR,r)}}async deleteRecords(t){return await xte(t)}async dropAttribute(t){return await zte(t)}async deleteAuditLogsBefore(t){return await Yte(t)}async readAuditLog(t){return await jte(t)}writeTransaction(t,r,n){return Qte.writeTransaction(t,r,n)}flush(t,r){return hB.flush(t,r)}resetReadTxn(t,r){return hB.resetReadTxn(t,r)}getBackup(t){return Jte(t)}};mB.exports=Gb});var $b={};ve($b,{add:()=>vE,applyReverse:()=>gB,getRecordAtTime:()=>qb,rebuildUpdateBefore:()=>UE});function vE(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function UE(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,vE(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function gB(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Xte[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=SB}}function qb(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=wt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":gB(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===SB&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=wt(l),f;switch(u.type){case"put":f=u.getValue(r);break;case"patch":f=u.getValue(r);break}for(let d in f)o[d]&&(s[d]=f[d],o[d]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var Xte,SB,xE=be(()=>{ho();a(vE,"add");vE.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};Xte={add:vE};a(UE,"rebuildUpdateBefore");a(gB,"applyReverse");SB={};a(qb,"getRecordAtTime")});function bn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function FE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a string, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(p=>typeof p=="string")||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a string, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="number"||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a number, attempt to assign ${p}`);bn(this)[l]=d},"set");break;case"Int":u=a(function(d){let p=d?.__op__?d.value:d;if(!(p>>0===p||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs((p>>0)-p)<=1)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new Jn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Long":u=a(function(d){let p=d?.__op__?d.value:d;if(!(Math.round(p)===d&&Math.abs(p)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs(p)<=9007199254740992)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new Jn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="bigint"||d==null&&c.nullable!==!1))if(typeof p=="string"||typeof p=="number")p=BigInt(p),d?.__op__?d.value=p:d=p;else throw new Jn.ClientError(`${l} must be a number, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new Jn.ClientError(`${l} must be a Date, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Ci||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){bn(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be an object, attempt to assign ${d}`);bn(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let _=d[l];if(_?.__op__){let h=this.getRecord()?.[l];return _.update(h)}return _}let p=this.getRecord()?.[l];if(p&&typeof p=="object"){let _=Vb(p,c);if(_)return d||this._setChanges(d=Object.create(null)),d[l]=_}return p},set:u,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,n[l]=f,(!(l in r)||Object.getOwnPropertyDescriptor(r,l)?.get?.isAttribute)&&Object.defineProperty(r,l,f)}i("getProperty",function(c){let l=n[c];if(l)return l.get.call(this);let u=this.getChanges();return u?.[c]!==void 0?u[c]:this.getRecord()?.[c]}),i("set",function(c,l){let u=n[c];if(u)return u.set.call(this,l);if(t.sealed)throw new Jn.ClientError("Can not add a property to a sealed table schema");bn(this)[c]=l}),i("deleteProperty",function(c){bn(this)[c]=void 0}),i("toJSON",function(){let c=this.getChanges?.(),l;for(let f in c){l||(l={...this.getRecord()});let d=c[f];if(d?.__op__){let p=l[f];d=d.update(p)}l[f]=d}return Object.keys(this).length>0&&(l||(l={...this.getRecord()}),Object.assign(l,this)),l||this.getRecord()}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty),r.then||i("then",null);function i(c,l){Object.defineProperty(r,c,{value:l,configurable:!0})}a(i,"setMethod");let o=r;do{let c=Object.getPrototypeOf(o);if(c===Object.prototype){Object.setPrototypeOf(o,AB);break}o=c}while(o&&o!==AB)}function Vb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends F_{static{a(this,"TrackedObject")}},FE(r,t)),new r(e)):new F_(e);case Array:let n=new HE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=Vb(o,t?.elements)),n[s]=o}return n;default:return e}}function GE(e){let t=e.getChanges?.(),r;for(let s in t){r||(r=e.getRecord?{...e.getRecord()}:{});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=GE(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=e.getRecord?{...e.getRecord()}:{}),Object.assign(r,e)),r||e.getRecord?.()||e}function el(e,t=e.getChanges?.()){let r;if(e.getRecord&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=el(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?.()});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=$b[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=el(s);r[n]=s}if(!Array.isArray(e))for(let n in e)Zte.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function BE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Zc]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(BE(i))return!0}else return!0}}else{let r=e.getChanges?.();if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s.getRecord?.()===i){if(BE(s))return!0}else return!0}else return!0}}return!1}var Jn,TB,AB,F_,Zte,Zc,HE,kE,Kb=be(()=>{Jn=M(pe());xE();Ts();a(bn,"getChanges");a(FE,"assignTrackedAccessors");TB=Object.prototype,AB=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(TB[t])return TB[t];let n=r.getChanges?.();if(n&&t in n)return n[t];let s=r.getRecord?.()[t];if(s&&typeof s=="object"){let i=Vb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(Vb,"trackObject");F_=class{static{a(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};FE(F_,{});a(GE,"collapseData");Zte=Object.prototype.hasOwnProperty;a(el,"updateAndFreeze");a(BE,"hasChanges");Zc=Symbol.for("has-array-changes"),HE=class extends Array{static{a(this,"TrackedArray")}#e;[Zc];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[Zc]=!0,super.splice(...t)}push(...t){return this[Zc]=!0,super.push(...t)}pop(){return this[Zc]=!0,super.pop()}unshift(...t){return this[Zc]=!0,super.unshift(...t)}shift(){return this[Zc]=!0,super.shift()}};HE.prototype.constructor=Array;kE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var CB={};ve(CB,{ResourceBridge:()=>zb});function jb({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function yB(e,t){let r=Gi(e),n=jb(e,r);if(!r)throw new ii.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Nt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],f;try{f=await r.get({id:u,lazy:s,select:n},i),f=f&&GE(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function Gi(e){let t=e.database||e.schema||tre,r=Je()[t];if(!r)throw(0,ii.handleHDBError)(new Error,ere.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function bB(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*OB(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var NB,qE,ii,wB,Yb,Wb,IB,ere,tre,rre,nre,RB,zb,PB=be(()=>{"use strict";NB=M(EB()),qE=M(Bu()),ii=M(pe());Pe();wB=M(d_());H();Yb=M(yo()),Wb=M(ni()),IB=M(se());Oc();Kb();({HDB_ERROR_MSGS:ere}=ii.hdb_errors),tre="data",rre=1e4,nre=10,zb=class extends NB.default{static{a(this,"ResourceBridge")}constructor(t){super(t),RB=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,qE.default)(t,"conditions");if(r)throw(0,ii.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Gi(t);if(!n)throw new ii.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:jb(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new ii.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}dt({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Gi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Gi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Gi(t).dropTable()}createSchema(t){return Fu({database:t.schema,table:null}),Yb.signalSchemaChange(new Wb.SchemaEventMsg(process.pid,Vt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Qb(t.schema),Yb.signalSchemaChange(new Wb.SchemaEventMsg(process.pid,Vt.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,RB.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,wB.default)(t),s,i=Je()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Nt(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(p=>p.name==f)||s.push(f);s.length>0&&await i.addAttributes(s.map(f=>({name:f,indexed:!0})))}let l=[],u=[];for(let f of t.records){let d=f[i.primaryKey],p=d!=null&&await i.get(d,o);if(t.requires_existing&&!p||t.requires_no_existing&&p){u.push(f[i.primaryKey]);continue}p&&(p=GE(p));for(let _ in f)if(Object.prototype.hasOwnProperty.call(f,_)){let h=f[_];if(typeof h=="function")try{let S=h([[p]]);Array.isArray(S)&&(h=S[0].func_val,f[_]=h)}catch(S){throw S.message+="Trying to set key "+_+" on object"+JSON.stringify(f),S}}if(p)for(let _ in p)Object.prototype.hasOwnProperty.call(f,_)||(f[_]=p[_]);await(d==null?i.create(f,o):i.put(f,o)),l.push(f[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=Je()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Nt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return bB(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Je()[t.schema][t.table];if(!r.createdTimeProperty)throw new ii.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:om.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let f=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...f.deleted_hashes),o.push(...f.skipped_hashes),await(0,IB.async_set_timeout)(nre),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%rre===0&&await u();return l.length>0&&await u(),s?bB(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,qE.default)(t,"hashes");if(r)throw r;return yB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of yB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&jA[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,qE.default)(t,"value");if(n)throw n;let s=Gi(t);if(!s)throw new ii.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===om.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:jb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Gi(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){Gi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Gi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Gi(t),n={};switch(t.search_type){case am.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case am.USERNAME:let s=t.search_values;for await(let i of OB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return OB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(jb,"getSelect");a(yB,"getRecords");a(Gi,"getTable");a(bB,"createDeleteResponse");a(OB,"groupRecordsInHistory")});var Yn=w((oCe,DB)=>{"use strict";var{ResourceBridge:sre}=(PB(),C(CB)),ire=ae();ire.initSync();var $E;function ore(){return $E||($E=new sre,$E)}a(ore,"getBridge");DB.exports=ore()});var Rn=w((cCe,UB)=>{"use strict";var KE=HR(),Dr=se(),are=require("util"),YE=Yn(),cre=ys(),LB=z(),{handleHDBError:tl,hdb_errors:lre}=pe(),{HTTP_STATUS_CODES:rl}=lre,ure=are.promisify(cre.getTableSchema),dre="updated",MB="inserted",vB="upserted";UB.exports={insert:_re,update:pre,upsert:hre,validation:fre,flush:mre};async function fre(e){if(Dr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Dr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Dr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await ure(e.schema,e.table),r=KE(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Dr.isEmptyOrZeroLength(c[n]))throw LB.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(!Dr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw LB.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Dr.isEmpty(c[n])&&c[n]!==""&&s.has(Dr.autoCast(c[n]))&&(c.skip=!0),s.add(Dr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(fre,"validation");async function _re(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=KE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Dr.transformReq(e);let r=Dr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await YE.createRecords(e);return VE(MB,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(_re,"insertData");async function pre(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=KE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Dr.transformReq(e);let r=Dr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await YE.updateRecords(e);return Dr.isEmpty(n.existing_rows)?VE(dre,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):VE(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(pre,"updateData");async function hre(e){if(e.operation!=="upsert")throw tl(new Error,"invalid operation, must be upsert",rl.INTERNAL_SERVER_ERROR);let t=KE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Dr.transformReq(e);let r=Dr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await YE.upsertRecords(e);return VE(vB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(hre,"upsertData");function VE(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===MB?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===vB?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(VE,"returnObject");function mre(e){return Dr.transformReq(e),YE.flush(e.schema,e.table)}a(mre,"flush")});var GB=w((uCe,FB)=>{var Gu=require("validate.js"),BB=ft(),qu=(H(),C(q)),{handleHDBError:Ere,hdb_errors:gre}=pe(),{HDB_ERROR_MSGS:Wt,HTTP_STATUS_CODES:Sre}=gre,Jb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Tre={STRUCTURE_USER:"structure_user"},xB=Object.values(qu.ROLE_TYPES_ENUM),Are="attribute_permissions",Rre="attribute_name",{PERMS_CRUD_ENUM:$u}=qu,yre=[Are,...Object.values($u)],HB=[$u.READ,$u.INSERT,$u.UPDATE],bre=[Rre,...HB];function Ore(e){let t=Jb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,kB(e,t)}a(Ore,"addRoleValidation");function Nre(e){let t=Jb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,kB(e,t)}a(Nre,"alterRoleValidation");function wre(e){let t=Jb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,BB.validateObject(e,t)}a(wre,"dropRoleValidation");var Ire=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function kB(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)Ire.includes(n[o])||s.push(n[o]);s.length>0&&sr(Wt.INVALID_ROLE_JSON_KEYS(s),r);let i=BB.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{sr(o,r)}),e.permission){let o=Cre(e);o&&sr(o,r),xB.forEach(c=>{e.permission[c]&&!Gu.isBoolean(e.permission[c])&&sr(Wt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(xB.indexOf(o)<0){if(o===Tre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,f=l.length;u<f;u++){let d=l[u];global.hdb_schema[d]||sr(Wt.SCHEMA_NOT_FOUND(d),r)}continue}sr(Wt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){sr(Wt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){sr(Wt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{yre.includes(f)||sr(Wt.INVALID_PERM_KEY(f),r,o,l)}),Object.values($u).forEach(f=>{Gu.isDefined(u[f])?Gu.isBoolean(u[f])||sr(Wt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):sr(Wt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){sr(Wt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){sr(Wt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:p})=>p),d={read:!1,insert:!1,update:!1};for(let p in u.attribute_permissions){let _=u.attribute_permissions[p];if(Object.keys(_).forEach(S=>{!bre.includes(S)&&S!==$u.DELETE&&sr(Wt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!Gu.isDefined(_.attribute_name)){sr(Wt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!f.includes(h)){sr(Wt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}HB.forEach(S=>{Gu.isDefined(_[S])?Gu.isBoolean(_[S])||sr(Wt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,l):sr(Wt.ATTR_PERM_MISSING(S,h),r,o,l)}),!d.read&&_.read===!0&&(d.read=!0),!d.insert&&_.insert===!0&&(d.insert=!0),!d.update&&_.update===!0&&(d.update=!0)}if(u.read===!1&&d.read===!0||u.insert===!1&&d.insert===!0||u.update===!1&&d.update===!0){let p=`${o}.${l}`;sr(Wt.MISMATCHED_TABLE_ATTR_PERMS(p),r,o,l)}}}}return Pre(r)}a(kB,"customValidate");FB.exports={addRoleValidation:Ore,alterRoleValidation:Nre,dropRoleValidation:wre};function Cre(e){let{operation:t,permission:r}=e;if(t===qu.OPERATIONS_ENUM.ADD_ROLE||t===qu.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Wt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?qu.ROLE_TYPES_ENUM.SUPER_USER:qu.ROLE_TYPES_ENUM.CLUSTER_USER;return Wt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Cre,"validateNoSUPerms");function Pre(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Wt.ROLE_PERMS_ERROR,...e};return Ere(new Error,n,Sre.BAD_REQUEST)}else return null}a(Pre,"generateRolePermResponse");function sr(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(sr,"addPermError")});var q_=w((_Ce,KB)=>{"use strict";var qB=Rn(),$B=Yr(),Dre=Vc(),Zb=GB(),eO=yo(),fCe=require("uuid").v4,Lre=require("util"),WE=(H(),C(q)),Mre=se(),tO=$B.searchByValue,vre=$B.searchByHash,Ure=Lre.promisify(Dre.delete),xre=si(),Bre=Hu(),{hdb_errors:Hre,handleHDBError:nl}=pe(),{HDB_ERROR_MSGS:VB,HTTP_STATUS_CODES:G_}=Hre,{UserEventMsg:rO}=ni();KB.exports={addRole:kre,alterRole:Fre,dropRole:Gre,listRoles:qre};function Xb(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(Xb,"scrubRoleDetails");async function kre(e){let t=Zb.addRoleValidation(e);if(t)throw t;e=Xb(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await tO(r)||[])}catch(i){throw nl(i)}if(n&&n.length>0)throw nl(new Error,VB.ROLE_ALREADY_EXISTS(e.role),G_.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await qB.insert(s),eO.signalUserChange(new rO(process.pid)),e=Xb(e),e}a(kre,"addRole");async function Fre(e){let t=Zb.alterRoleValidation(e);if(t)throw t;e=Xb(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await qB.update(r)}catch(s){throw nl(s)}if(n&&n?.message==="updated 0 of 1 records")throw nl(new Error,"Invalid role id",G_.BAD_REQUEST,void 0,void 0,!0);return await eO.signalUserChange(new rO(process.pid)),e}a(Fre,"alterRole");async function Gre(e){let t=Zb.dropRoleValidation(e);if(t)throw nl(new Error,t,G_.BAD_REQUEST,void 0,void 0,!0);let r=new Bre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await vre(r));if(n.length===0)throw nl(new Error,VB.ROLE_NOT_FOUND,G_.NOT_FOUND,void 0,void 0,!0);let s=new xre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await tO(s)),o=!1;if(Mre.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw nl(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,G_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Ure(c),eO.signalUserChange(new rO(process.pid)),`${n[0].role} successfully deleted`}a(Gre,"dropRole");async function qre(){return tO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(qre,"listRoles")});var nO={};ve(nO,{start:()=>zB,startOnMainThread:()=>Kre});function zB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,YB.parseDocument)(r.toString(),{simpleKeys:!0}).toJSON();for(let s in n){let i=n[s];i.permission||(i={permission:i},i.permission.access&&(i.access=i.permission.access,delete i.permission.access));for(let o in i.permission){if($re.includes(o))continue;let c=i.permission[o];c.tables||(i.permission[o]=c={tables:c});for(let l in c.tables){let u=c.tables[l];if(u.read=!!u.read,u.insert=!!u.insert,u.update=!!u.update,u.delete=!!u.delete,u.attributes){let f=[];for(let d in u.attributes){let p=u.attributes[d];p.attribute_name=d,f.push(p)}u.attribute_permissions=f,delete u.attributes}if(u.attribute_permissions){if(!Array.isArray(u.attribute_permissions))throw new Error("attribute_permissions must be an array if defined");for(let f of u.attribute_permissions)f.read=!!f.read,f.insert=!!f.insert,f.update=!!f.update}else u.attribute_permissions=null}}i.role=i.id=s,await Vre(i)}}}async function Vre(e){let t=Je().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,WB.isEqual)(i,e)?void 0:(e.id=r.id,(0,zE.alterRole)(e))}return(0,zE.addRole)(e)}var zE,YB,WB,$re,Kre,jB=be(()=>{Pe();zE=M(q_()),YB=require("yaml"),WB=require("lodash"),$re=["super_user","cluster_user","structure_user"];a(zB,"start");a(Vre,"ensureRole");Kre=zB});async function jE(e){let t=(0,XB.pathToFileURL)(e).toString();return Yre?($_||($_=Wre(jre)),(await(await $_).import(t)).namespace):import(t)}async function Wre(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),$_=new Compartment({console,Math,Date,fetch:zre,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,JB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:$r,tables:Xn,databases:qe})}};let n=await(0,QB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),$_}function zre(e,t){let r=typeof e=="string"||e.url;if(new URL(r).protocol!="https")throw new Error("Only https is allowed in fetch");return fetch(e,t)}function jre(){return{Resource:$r,tables:Xn}}var QB,JB,XB,Yre,$_,sO=be(()=>{ga();Pe();QB=require("fs/promises"),JB=require("path"),XB=require("url"),Yre=!1;a(jE,"secureImport");a(Wre,"getCompartment");a(zre,"secureOnlyFetch");a(jre,"getGlobalVars")});var oO={};ve(oO,{handleFile:()=>Qre});async function Qre(e,t,r,n){let s=new Map,i=await jE(r);c(i.default)&&n.set((0,iO.dirname)(t),i.default),o(i,(0,iO.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var iO,ZB=be(()=>{sO();iO=require("path");a(Qre,"handleFile")});var cO={};ve(cO,{start:()=>Jre});function Jre({resources:e}){e.set("login",aO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var aO,eH=be(()=>{ga();a(Jre,"start");aO=class extends $r{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var j_={};ve(j_,{addAnalyticsListener:()=>z_,calculateCPUUtilization:()=>SH,diffResourceUsage:()=>TH,recordAction:()=>ir,recordActionBinary:()=>Zn,setAnalyticsEnabled:()=>Xre});function Xre(e){pH=e}function Zre(e,t){if(typeof e=="number"){let r=t.values,n=r.index++;if(n>=r.length){let s=r;t.values=r=new Float32Array(n*2),r.set(s),r.index=n+1}r[n]=e,t.total+=e}else if(typeof e=="boolean")e&&t.total++,t.count++;else if(typeof e=="function")t.count++;else throw new TypeError("Invalid metric value type "+typeof e)}function ene(e,t,r,n,s,i){let o={};if(typeof t=="number")o.total=t,o.values=new Float32Array(4),o.values.index=1,o.values[0]=t,o.total=t;else if(typeof t=="boolean")o.total=t?1:0,o.count=1;else if(typeof t=="function")o.count=1,o.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);o.description={metric:r,path:n,method:s,type:i},JE.set(e,o)}function ir(e,t,r,n,s){if(!pH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=JE.get(i);o?Zre(e,o):ene(i,e,t,r,n,s),QE||tne()}function Zn(e,t,r,n,s){ir(!!e,t,r,n,s)}function z_(e){EH.push(e)}function tne(){QE=performance.now(),setTimeout(async()=>{let e=performance.now()-QE;QE=0;let t=[],r={time:Date.now(),period:e,threadId:sl.threadId,metrics:t};for(let[s,i]of JE){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],f;for(let d of gH){let p=Math.floor(c*d),_=o[p-1];if(p>l){let h=p-l;if(_===f){let S=u[u.length-1];typeof S=="number"?u[u.length-1]={value:S,count:1+h}:S.count+=h}else u.push(h>1?{value:_,count:h}:_),f=_;l=p}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await AH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:sl.threadId,byThread:!0,...n});for(let s of EH)s(t);JE=new Map,sl.parentPort?sl.parentPort.postMessage({type:mH,report:r}):bH({report:r})},hH).unref()}function XE(e,t,r){let n={id:(0,Y_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function SH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function TH(e,t){return{userCPUTime:t.userCPUTime/1e3-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime/1e3-(e?.systemCPUTime??0),minorPageFault:t.minorPageFault-(e?.minorPageFault??0),majorPageFault:t.majorPageFault-(e?.majorPageFault??0),fsRead:t.fsRead-(e?.fsRead??0),fsWrite:t.fsWrite-(e?.fsWrite??0),voluntaryContextSwitches:t.voluntaryContextSwitches-(e?.voluntaryContextSwitches??0),involuntaryContextSwitches:t.involuntaryContextSwitches-(e?.involuntaryContextSwitches??0)}}function rne(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let o=`${t}.${s}`,c=i.getSize(),l={database:t,table:s,size:c};XE(e,"table-size",l),il.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function tH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getAuditSize(),o=_H.default.statSync(s.primaryStore.env.path).size,c=rne(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};XE(e,"database-size",u),il.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){il.warn?.("Error getting DB size metrics",s)}}function rH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getStorageStats(),o={database:r,...i};XE(e,"storage-volume",o),il.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){il.warn?.("Error getting DB volumne metrics",s)}}async function nne(e,t=6e4){let r=uO(),n=RH(),s=new Promise(E=>{let A=performance.now();setImmediate(()=>{let O=performance.now();O-A>5e3&&il.warn?.("Unusually high event queue latency on the main thread of "+Math.round(O-A)+"ms"),A=performance.now()}),n.primaryStore.prefetch([1],()=>{let O=performance.now();O-A>5e3&&il.warn?.("Unusually high task queue latency on the main thread of "+Math.round(O-A)+"ms"),E(O-A)})}),i;for(let E of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(E.value?.time){i=E.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:E,value:A}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!A)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:O,threadId:v}=A;for(let F of O||[]){let{path:G,method:Y,type:te,metric:ie,count:X,total:ne,distribution:Q,threads:he,...Re}=F;X||(X=1);let Ce=ie+(G?"-"+G:"");Y!==void 0&&(Ce+="-"+Y),te!==void 0&&(Ce+="-"+te);let me=c.get(Ce);if(me){if(me.threads){let lt=me.threads[v];if(lt)me=lt;else{me.threads[v]={...Re};continue}}me.count||(me.count=1);let Zt=me.count;for(let lt in Re){let yr=Re[lt];typeof yr=="number"&&(me[lt]=(me[lt]*Zt+yr*X)/(Zt+X))}me.count+=X,ne>=0&&(me.total+=ne,me.ratio=me.total/me.count)}else me={period:t,...F},delete me.distribution,c.set(Ce,me),me.byThread&&(me.threads=[],me.threads[v]={...Re},u.push(me));if(Q){Q=Q.map(lt=>typeof lt=="number"?{value:lt,count:1}:lt);let Zt=l.get(Ce);Zt?Zt.push(...Q):l.set(Ce,Q)}}await AH()}for(let E of u){let{path:A,method:O,type:v,metric:F,count:G,total:Y,distribution:te,threads:ie,...X}=E;ie=ie.filter(ne=>ne);for(let ne in X){if(typeof E[ne]!="number")continue;let Q=0;for(let he of ie){let Re=he[ne];typeof Re=="number"&&(Q+=Re)}E[ne]=Q}E.count=ie.length,delete E.threads,delete E.byThread}for(let[E,A]of l){let O=c.get(E);A.sort((lt,yr)=>lt.value>yr.value?1:-1);let v=O.count-1,F=[],G=0,Y=0,te;for(let lt of gH){let yr=v*lt;for(;G<yr;)te=A[Y++],G+=te.count,Y===1&&G--;let Es=A[Y>1?Y-2:0];te||(te=A[0]),F.push(te.value-(te.value-Es.value)*(G-yr)/te.count)}let[ie,X,ne,Q,he,Re,Ce,me,Zt]=F;Object.assign(O,{p1:ie,p10:X,p25:ne,median:Q,p75:he,p90:Re,p95:Ce,p99:me,p999:Zt})}let d;for(let[E,A]of c)A.id=(0,Y_.getNextMonotonicTime)(),A.time=f,n.primaryStore.put(A.id,A,{append:!0}).then(O=>{O||n.primaryStore.put(A.id,A)}),d=!0;let p=Date.now(),{idle:_,active:h}=performance.eventLoopUtilization();if(d||h*10>_){let E=(0,Y_.getNextMonotonicTime)(),A={id:E,metric:"main-thread-utilization",idle:_-nH,active:h-sH,taskQueueLatency:await s,time:p,...process.memoryUsage()};n.primaryStore.put(E,A,{append:!0}).then(O=>{O||n.primaryStore.put(E,A)})}nH=_,sH=h;let S=process.resourceUsage(),g=TH(V_,S);g.time=p,g.period=V_.time?p-V_.time:t,g.cpuUtilization=SH(V_,g.period),XE(n,"resource-usage",g),V_=g;let R=Je();tH(n,R),tH(n,{system:R.system}),rH(n,R),rH(n,{system:R.system})}async function iH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function uO(){return oH||(oH=dt({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function RH(){return aH||(aH=dt({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function one(){yH=!0;let e=(0,W_.get)(B.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await nne(hH,e),await iH(uO(),sne),await iH(RH(),ine)},Math.min(e/2,2147483647)).unref()}function bH(e,t){let r=e.report;r.threadId=t?.threadId||sl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(cH+=n.mean*n.count);r.totalBytesProcessed=cH,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(lH.get(t))}),lH.set(t,t.performance.eventLoopUtilization())),r.id=(0,Y_.getNextMonotonicTime)(),uO().primaryStore.put(r.id,r),yH||one(),ane&&(OH=lne(r))}async function lne(e){if(await OH,!Pa){let r=(0,K_.dirname)((0,dH.getLogFilePath)());try{Pa=await(0,lO.open)((0,K_.join)(r,"analytics.log"),"r+")}catch{Pa=await(0,lO.open)((0,K_.join)(r,"analytics.log"),"w+")}}let t=(await Pa.stat()).size;if(t>cne){let r=Buffer.alloc(t);await Pa.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Pa.write(r,{position:0}),await Pa.truncate(r.length),t=r.length}await Pa.write(JSON.stringify(e)+`
|
|
21
|
-
`,t)}var sl,uH,dH,fH,K_,lO,Y_,W_,_H,il,JE,pH,QE,hH,mH,EH,gH,nH,sH,V_,AH,sne,ine,oH,aH,yH,cH,lH,ane,OH,Pa,cne,qi=be(()=>{sl=require("worker_threads"),uH=M(et());Pe();dH=M(z()),fH=M(Ii()),K_=require("path"),lO=require("fs/promises"),Y_=M(_n()),W_=M(ae());H();Vr();_H=M(require("node:fs")),il=(0,fH.loggerWithTag)("analytics");(0,W_.initSync)();JE=new Map,pH=(0,W_.get)(B.ANALYTICS_AGGREGATEPERIOD)>-1;a(Xre,"setAnalyticsEnabled");a(Zre,"recordExistingAction");a(ene,"recordNewAction");a(ir,"recordAction");Ye.recordAnalytics=ir;a(Zn,"recordActionBinary");QE=0,hH=1e3,mH="analytics-report",EH=[];a(z_,"addAnalyticsListener");gH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(tne,"sendAnalytics");a(XE,"storeMetric");a(SH,"calculateCPUUtilization");a(TH,"diffResourceUsage");a(rne,"storeTableSizeMetrics");a(tH,"storeDBSizeMetrics");a(rH,"storeVolumeMetrics");a(nne,"aggregation");nH=0,sH=0,V_={},AH=a(()=>new Promise(setImmediate),"rest");a(iH,"cleanup");sne=36e5,ine=31536e6;a(uO,"getRawAnalyticsTable");a(RH,"getAnalyticsTable");(0,uH.setChildListenerByType)(mH,bH);a(one,"startScheduledTasks");cH=0,lH=new Map,ane=!1;a(bH,"recordAnalytics");cne=1e6;a(lne,"logAnalytics")});var NH={};ve(NH,{Headers:()=>No,appendHeader:()=>ZE,mergeHeaders:()=>dO});function ZE(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function dO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new No(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var No,Q_=be(()=>{No=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(ZE,"appendHeader");a(dO,"mergeHeaders")});function DH(e){let t={openapi:une,info:{title:"HarperDB HTTP REST interface",version:PH.packageJson.version},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},f=[];if(o)for(let{type:A,name:O,elements:v,relationship:F,definition:G}of o){if(F)A==="array"?u[O]={type:"array",items:{$ref:Da+v.type}}:u[O]={$ref:Da+A};else{let Y=G??v?.definition;if(Y){if(!t.components.schemas[Y.type]){let te={};Y.properties.forEach(ie=>{te[ie.name]=new hO(fO[ie.type],ie.type)}),t.components.schemas[Y.type]=new CH(te)}A==="array"?u[O]={type:"array",items:{$ref:Da+Y.type}}:u[O]={$ref:Da+Y.type}}else A==="array"?v.type==="Any"||v.type=="ID"?u[O]={type:"array",items:{format:v.type}}:u[O]={type:"array",items:new hO(fO[v.type],v.type)}:A==="Any"||A=="ID"?u[O]={format:A}:u[O]=new hO(fO[A],A)}f.push(new mO(O,"query",u[O]))}let d=Object.keys(u),p=new mO(c,"path",{format:"ID"});p.required=!0,p.description="primary key of record";let _=new mO("property","path",{enum:d});_.required=!0,t.components.schemas[i]=new CH(u);let h=l.post!==Resource.prototype.post||l.update,S=typeof l.put=="function",g=typeof l.get=="function",R=typeof l.delete=="function",E="/"+s+"/";h&&(t.paths[E]={},t.paths[E].post=new dne(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new _O(f,r,{200:new pO({$ref:Da+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new IH(f,r,"delete all the records that match the provided query",{204:new wH})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new _O([p],r,{200:new pO({$ref:Da+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new fne([p],r,i,"create or update the record with the URL path that maps to the record's primary key")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new IH([p],r,"delete a record with the given primary key",{204:new wH})),g&&_.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new _O([p,_],r,{200:new pO({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function dne(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Da+e}}}},this.security=t,this.responses={200:{description:EO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function _O(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function pO(e){this.description=EO,this.content={"application/json":{schema:e}}}function wH(){this.description="successfully processed request, no content returned to client"}function fne(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Da+r}}}},this.responses={200:{description:EO}}}function IH(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function CH(e){this.type="object",this.properties=e}function hO(e,t){this.type=e,this.format=t}function mO(e,t,r){this.name=e,this.in=t,this.schema=r}var PH,une,fO,Da,EO,LH=be(()=>{PH=M(st()),une="3.0.3",fO={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Da="#/components/schemas/",EO="successful operation";a(DH,"generateJsonApi");a(dne,"Post");a(_O,"Get");a(pO,"Response200");a(wH,"Response204");a(fne,"Put");a(IH,"Delete");a(CH,"ResourceSchema");a(hO,"Type");a(mO,"Parameter")});var tg={};ve(tg,{parseHeaderValue:()=>SO,start:()=>hne});async function pne(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&bm(e);let i=new No;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==MH){let g=eg.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Nc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=SO(g);for(let E of R)switch(E.name){case"max-age":e.expiresAt=E.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let g=SO(u).map(R=>(R.next?.name==="confirm"&&R.next.value>=0&&(e.replicatedConfirmation=+R.next.value),R.name));e.replicateTo=g.length===1&&+g[0]>=0?+g[0]:g[0]==="*"?void 0:g}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let d=await Nt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=po(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Vu.ClientError(g,400)}if(e.authorize=!0,o===MH&&s==="GET"){if(e?.user?.role?.permission?.super_user)return DH(eg);throw new Vu.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new Vu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Vu.ServerError(`Method ${s} is not recognized`,501)}}),p=200,_;if(d==null)p=s==="GET"||s==="HEAD"?404:204,gO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=dO(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Qf(d.data,e,d)),d}else if(_=e.lastModified){_ne[0]=_;let g=String.fromCharCode(34,(Lr[0]&63)+62,(Lr[0]>>6)+(Lr[1]<<2&63)+62,(Lr[1]>>4)+(Lr[2]<<4&63)+62,(Lr[2]>>2)+62,(Lr[3]&63)+62,(Lr[3]>>6)+(Lr[4]<<2&63)+62,(Lr[4]>>4)+(Lr[5]<<4&63)+62,(Lr[5]>>2)+62,(Lr[6]&63)+62,(Lr[6]>>6)+(Lr[7]<<2&63)+62,34),R=r["if-none-match"];R&&g==R?(d?.onDone&&d.onDone(),p=304,d=void 0):i.setIfNone("ETag",g),gO.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}e.createdResource&&(p=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:p,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(h.wasCacheMiss=S,!S&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),d!==void 0&&(h.body=Qf(d,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?$i.warn(o):$i.info(o):$i.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Qf(o.contentType?o:o.toString(),e,c),c}}function hne(e){gO=e,!vH&&(vH=!0,eg=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return pne(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{J_++;let s=new Hn;UH||(UH=!0,z_(l=>{J_>0&&l.push({metric:"ws-connections",connections:J_,byThread:!0})}));let i;t.on("error",l=>{i=!0,$i.warn(l)});let o;t.on("message",a(function(u){o||(o=po(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);ir(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{J_--,Zn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=eg.getMatch(l,"ws");if(Zn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,ir(h=>({count:h.count,total:J_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new Nc(u.relativeURL),d=u.Resource;c=(await Nt(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let h=await Ra(_.value,r);t.send(h),ir(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?$i.warn(l):$i.info(l):$i.error(l),t.close(mne[l.statusCode]||1011,l.toString())}t.close()},e))}function SO(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var $i,Vu,Lr,_ne,gO,MH,vH,eg,UH,J_,mne,xH=be(()=>{uo();qi();$i=M(z()),Vu=M(pe());Ff();_u();Oc();Q_();LH();Ff();Lr=new Uint8Array(8),_ne=new Float64Array(Lr.buffer,0,1),gO={},MH="openapi";a(pne,"http");J_=0;a(hne,"start");mne={401:3e3,403:3003};a(SO,"parseHeaderValue")});var TO=w((qCe,HH)=>{var{recordAction:rg,recordActionBinary:BH}=(qi(),C(j_)),Ene=require("fastify-plugin"),gne=200;HH.exports=Ene(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,f,d;l.config?.isOperation?(u=n.body?.operation,f="operation"):(u=l.url,f="fastify-route",d=l.method),rg(o,"duration",u,d,f),BH(s.raw.statusCode<400,"success",u,d,f),BH(1,"response_"+s.raw.statusCode,u,d,f);let p=gne;i?.pipe?(i.on("data",g=>{p+=g.length}),i.on("end",()=>{rg(performance.now()-c,"transfer",u,d,f),rg(p,"bytes-sent",u,d,f)})):(p+=i?.length||0,rg(p,"bytes-sent",u,d,f));let _=o.toFixed(3),h=s.getHeader("Server-Timing"),S=`db;dur=${_}`;s.header("Server-Timing",h?`${h}, ${S}`:S)}),r()},{name:"hdb-request-time"})});var FH=w(($Ce,kH)=>{var Sne=ft(),Tne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};kH.exports=function(e){return Sne.validateObject(e,Tne)}});var ng=w((VCe,GH)=>{"use strict";var Ane=(H(),C(q)).OPERATIONS_ENUM,AO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Ane.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};GH.exports=AO});var ep={};ve(ep,{createTokens:()=>yne,getJWTRSAKeys:()=>cg,refreshOperationToken:()=>bne,validateOperationToken:()=>bO,validateRefreshToken:()=>lg});async function cg(){if(sg)return sg;try{let e=X_.default.join(Z_.default.getHdbBasePath(),YA),t=await ig.default.readFile(X_.default.join(e,bf.JWT_PASSPHRASE_NAME),"utf8"),r=await ig.default.readFile(X_.default.join(e,bf.JWT_PRIVATE_KEY_NAME),"utf8");return sg={publicKey:await ig.default.readFile(X_.default.join(e,bf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},sg}catch(e){throw ag.default.error(e),new oi.ClientError(Yu.NO_ENCRYPTION_KEYS,Ku.INTERNAL_SERVER_ERROR)}}async function yne(e){let t=(0,RO.validateBySchema)(e,Vi.default.object({username:Vi.default.string().optional(),password:Vi.default.string().optional(),role:Vi.default.string().optional(),expires_in:Vi.default.alternatives(Vi.default.string(),Vi.default.number()).optional()}));if(t)throw new oi.ClientError(t.message);let r;try{let d=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,d=!1),r=await(0,yO.findAndValidateUser)(e.username,e.password,d)}catch(d){throw ag.default.error(d),new oi.ClientError(Yu.INVALID_CREDENTIALS,Ku.UNAUTHORIZED)}if(!r)throw new oi.ClientError(Yu.INVALID_CREDENTIALS,Ku.UNAUTHORIZED);let n=!1,s=!1;r.role?.permission&&(n=r.role.permission.super_user===!0,s=r.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s};e.role&&(i.role=e.role);let o=await cg(),c=await Wu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??YH,algorithm:og,subject:"operation"}),l=await Wu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:Rne,algorithm:og,subject:"refresh"}),u=Hy(l,"sha256");if((await(0,qH.update)(new $H.default(yf,du.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new oi.ClientError(Yu.REFRESH_TOKEN_SAVE_FAILED,Ku.INTERNAL_SERVER_ERROR);return VH.default.signalUserChange(new KH.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function bne(e){let t=(0,RO.validateBySchema)(e,Vi.default.object({refresh_token:Vi.default.string().required()}).required());if(t)throw new oi.ClientError(t.message);let{refresh_token:r}=e;await lg(r);let n=await cg(),s=await Wu.default.decode(r);return{operation_token:await Wu.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:YH,algorithm:og,subject:"operation"})}}async function bO(e){return WH(e,"operation")}async function lg(e){return WH(e,"refresh")}async function WH(e,t){try{let r=await cg(),n=await Wu.default.verify(e,r.publicKey,{algorithms:og,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,yO.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!ky(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw ag.default.warn(r),r?.name==="TokenExpiredError"?new oi.ClientError(Yu.TOKEN_EXPIRED,Ku.FORBIDDEN):new oi.ClientError(Yu.INVALID_TOKEN,Ku.UNAUTHORIZED)}}var Wu,ig,X_,Vi,RO,oi,ag,yO,qH,$H,VH,KH,Z_,Ku,Yu,YH,Rne,og,sg,zu=be(()=>{Wu=M(require("jsonwebtoken")),ig=M(require("fs-extra")),X_=M(require("node:path")),Vi=M(require("joi")),RO=M(ft());H();oi=M(pe()),ag=M(z());hE();yO=M(An()),qH=M(Rn()),$H=M(ng()),VH=M(yo()),KH=M(ni()),Z_=M(ae()),{HTTP_STATUS_CODES:Ku,AUTHENTICATION_ERROR_MSGS:Yu}=oi.hdb_errors;Z_.default.initSync();YH=Z_.default.get(B.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Rne=Z_.default.get(B.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",og="RS256";a(cg,"getJWTRSAKeys");a(yne,"createTokens");a(bne,"refreshOperationToken");a(bO,"validateOperationToken");a(lg,"validateRefreshToken");a(WH,"validateToken")});var OO=w((jCe,QH)=>{"use strict";var One=FH(),ju=require("passport"),Nne=require("passport-local").Strategy,wne=require("passport-http").BasicStrategy,Ine=require("util"),Cne=An(),jH=Ine.callbackify(Cne.findAndValidateUser),zCe=Bn(),Pne=(H(),C(q)),zH=(zu(),C(ep));ju.use(new Nne(function(e,t,r){jH(e,t,r)}));ju.use(new wne(function(e,t,r){jH(e,t,r)}));ju.serializeUser(function(e,t){t(null,e)});ju.deserializeUser(function(e,t){t(null,e)});function Dne(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":ju.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Pne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?zH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):zH.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:ju.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Dne,"authorize");function Lne(e,t){let r=One(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(Lne,"checkPermissions");QH.exports={authorize:Dne,checkPermissions:Lne}});var ug=w((JCe,JH)=>{"use strict";var Mne=Yn();JH.exports={writeTransaction:vne};function vne(e,t,r){return Mne.writeTransaction(e,t,r)}a(vne,"writeTransaction")});var tk=w((ePe,ek)=>{"use strict";var Une=Yr(),xne=ys(),XH=z(),Bne=Rn(),ZCe=ug(),Hne=require("clone"),wO=require("alasql"),kne=aE(),ZH=require("util"),Fne=ZH.promisify(xne.getTableSchema),Gne=ZH.promisify(Une.search),qne=(H(),C(q)),NO=se();kne(wO);ek.exports={update:Vne};var $ne="There was a problem performing this update. Please check the logs and try again.";async function Vne({statement:e,hdb_user:t}){let r=await Fne(e.table.databaseid,e.table.tableid),n=Kne(e.columns);NO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=Hne(s),c=NO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=wO.parse(l).statements[0],f=await Gne(u),d=Yne(n,f);return Wne(o,d,t)}a(Vne,"update");function Kne(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=wO.compile(`SELECT ${r.expression.toString()} AS [${qne.FUNC_VAL}] FROM ?`)}),t}catch(t){throw XH.error(t),new Error($ne)}}a(Kne,"createUpdateRecord");function Yne(e,t){return NO.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(Yne,"buildUpdateRecords");async function Wne(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await Bne.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){XH.error(`Error delete new_attributes from update response: ${i}`)}return s}a(Wne,"updateRecords")});var nk=w((sPe,rk)=>{var zne=require("alasql"),jne=Yr(),Qne=z(),Jne=Yn(),CO=require("util"),IO=se(),Xne=(H(),C(q)),Zne=ys(),rPe=ug(),nPe=Rn(),ese="record",tse="successfully deleted",rse=CO.callbackify(ose),nse=CO.promisify(jne.search),sse=CO.promisify(Zne.getTableSchema);rk.exports={convertDelete:rse};function ise(e){return`${e.deleted_hashes.length} ${ese}${e.deleted_hashes.length===1?"":"s"} ${tse}`}a(ise,"generateReturnMessage");async function ose({statement:e,hdb_user:t}){let r=await sse(e.table.databaseid,e.table.tableid);IO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=IO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=zne.parse(o).statements[0],l={operation:Xne.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await nse(c);let u=await Jne.deleteRecords(l);return IO.isEmptyOrZeroLength(u.message)&&(u.message=ise(u)),delete u.txn_time,u}catch(u){throw Qne.error(u),u.hdb_code?u.message:u}}a(ose,"convertDelete")});var ck=w((oPe,ak)=>{"use strict";var ase=Ao(),{hdb_errors:sk}=pe(),{getDatabases:ik}=(Pe(),C(tt));ak.exports={checkSchemaExists:ok,checkSchemaTableExists:cse,schema_describe:ase};async function ok(e){if(!ik()[e])return sk.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(ok,"checkSchemaExists");async function cse(e,t){let r=await ok(e);if(r)return r;if(!ik()[e][t])return sk.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(cse,"checkSchemaTableExists")});var vO=w((dPe,Tk)=>{"use strict";var{decode:lse}=require("msgpackr"),{isMainThread:cPe,parentPort:lPe,threadId:uPe}=require("worker_threads"),_g=or(),Qu=Tt(),LO=(H(),C(q)),Qr=z(),DO=ae(),use=(H(),C(q)),{onMessageByType:dse}=et(),fk=To(),{recordAction:lk,recordActionBinary:fse}=(qi(),C(j_)),{publishToStream:_se}=_g,{ConsumerEvents:uk}=require("nats"),pse=Yr(),{promisify:hse}=require("util"),{decodeBlobsWithWrites:mse}=(Ts(),C(Fm)),_k=hse(setTimeout),pg=1e4,hg,fg,Ese,gse,pk,tp=new Map,Ju=new Map;Tk.exports={initialize:hk,ingestConsumer:MO,setSubscription:Sse,setIgnoreOrigin:Rse,getDatabaseSubscriptions:Ase,updateConsumer:mk};async function hk(){dse(LO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await mk(n)}),pk=!0,Qr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await _g.getNATSReferences();hg=e,fg=e.info.server_name,Ese=t,gse=r}a(hk,"initialize");async function mk(e){if(e.status==="start"){let{js:t,jsm:r}=await Ek(e.node_domain_name);MO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=tp.get(e.stream_name+e.node_domain_name);t&&(Qr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),tp.set(e.stream_name+e.node_domain_name,"close")),Ju.get(e.node_domain_name)==="failed"&&Ju.set(e.node_domain_name,"close")}}a(mk,"updateConsumer");var mg=new Map;function Sse(e,t,r){let n=mg.get(e);n||mg.set(e,n=new Map),n.set(t,r),pk||hk().then(Tse)}a(Sse,"setSubscription");async function Tse(){let e=await pse.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Qu.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await Ek(r),!n))break;let{schema:o,table:c}=i,l=fk.createNatsTableStreamName(o,c);MO(l,n,s,r)}}}a(Tse,"accessConsumers");async function Ek(e){let t,r,n=1;for(;!r;)try{t=await hg.jetstream({domain:e}),r=await hg.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Ju.get(e)==="close")break;Ju.set(e,"failed"),n%10===1&&Qr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<pg?n++*100:pg;await _k(i)}return{js:t,jsm:r}}a(Ek,"connectToRemoteJS");function Ase(){return mg}a(Ase,"getDatabaseSubscriptions");var gk;function Rse(e){gk=e}a(Rse,"setIgnoreOrigin");var Sk=100,dk=new Array(Sk),dg=0;async function MO(e,t,r,n){let{connection:s}=await _g.getNATSReferences();hg=s,fg=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,fg),Qr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Ju.get(n)==="close")break;o%10===1&&Qr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(Qr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await _g.createConsumer(r,e,fg,new Date(Date.now()).toISOString()));let f=o++*100<pg?o++*100:pg;await _k(f)}let c=!1,l;for(;!c;){if(tp.get(e+n)==="close"||Ju.get(n)==="close"){tp.delete(e+n),c=!0;continue}l=await i.consume({max_messages:DO.get(LO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),tp.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===uk.ConsumerDeleted&&(await l.close(),c=!0),f.type===uk.HeartbeatsMissed){let d=f.data;Qr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(Qr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let f of l)await dk[dg],dk[dg]=yse(f).catch(d=>{Qr.error(d)}),++dg>=Sk&&(dg=0)}catch(f){f.message==="consumer deleted"?(Qr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):Qr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(MO,"ingestConsumer");async function yse(e){let t;await mse(()=>{t=lse(e.data)}),lk(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),Qr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=DO.get(LO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Qu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Qu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Qu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!gk),fse(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Qu.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:f,hash_values:d,__origin:p,expiresAt:_}=t;Qr.trace("processing message:",o,c,u,(f?"records: "+f.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Qr.trace(`messageProcessor nats msg id: ${e.headers.get(Qu.MSG_HEADERS.NATS_MSG_ID)}`);let h;f||(f=d);let S=new Promise(v=>h=v),{timestamp:g,user:R,node_name:E}=p||{},A=mg.get(c)?.get(u);if(!A)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,A.send(t);else if(f.length===1&&!l)A.send({type:PO(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:h,user:R,nodeName:E});else{let v=f.map((F,G)=>({type:PO(o),value:F,expiresAt:_,id:d?.[G],table:u}));for(;l;)v.push({type:PO(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;A.send({type:"transaction",writes:v,table:u,timestamp:g,onCommit:h,user:R,nodeName:E})}DO.get(use.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&_se(e.subject.split(".").slice(0,-1).join("."),fk.createNatsTableStreamName(c,u),e.headers,e.data),await S;let O=Date.now()-g;g&&lk(O,"replication-latency",e.subject,o,"ingest")}catch(o){Qr.error(o)}e.ack()}a(yse,"messageProcessor");function PO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(PO,"convertOperation")});var or=w((gPe,Bk)=>{"use strict";var Nr=ae();Nr.initSync();var bse=require("fs-extra"),Ose=require("semver"),sp=require("path"),{monotonicFactory:Nse}=require("ulidx"),Rk=Nse(),wse=require("util"),yk=require("child_process"),Ise=wse.promisify(yk.exec),Cse=yk.spawn,Mr=Tt(),$e=(H(),C(q)),{packageJson:Pse,PACKAGE_ROOT:Dse}=st(),Eg=se(),ai=z(),gg=To(),Lse=ug(),rp=yt(),{broadcast:Mse,onMessageByType:vse,getWorkerIndex:Use}=et(),{isMainThread:bk}=require("worker_threads"),{Encoder:xse,decode:HO}=require("msgpackr"),Ok=new xse,{isEmpty:ll}=Eg,Nk=An(),_Pe=48*36e11;bk&&vse($e.ITC_EVENT_TYPES.RESTART,()=>{Jr=void 0,cl=void 0});var{connect:Bse,StorageType:Hse,RetentionPolicy:kse,AckPolicy:kO,DeliverPolicy:FO,DiscardPolicy:Fse,NatsConnection:pPe,JetStreamManager:hPe,JetStreamClient:mPe,StringCodec:EPe,JSONCodec:Gse,createInbox:GO,headers:qse,ErrorCode:Ak}=require("nats"),{recordAction:$se}=(qi(),C(j_)),{encodeBlobsAsBuffers:Vse}=(Ts(),C(Fm)),wk=Gse(),Kse="clustering",Yse=Pse.engines[Mr.NATS_SERVER_NAME],Wse=sp.join(Dse,"dependencies"),BO=sp.join(Wse,`${process.platform}-${process.arch}`,Mr.NATS_BINARY_NAME),UO,xO,np,ol,al;Bk.exports={runCommand:Ik,checkNATSServerInstalled:zse,createConnection:qO,getConnection:ip,getJetStreamManager:op,getJetStream:Pk,getNATSReferences:Ki,getServerList:Qse,createLocalStream:$O,listStreams:Dk,deleteLocalStream:Jse,getServerConfig:Xu,listRemoteStreams:Xse,viewStream:Zse,viewStreamIterator:eie,publishToStream:tie,request:sie,reloadNATS:VO,reloadNATSHub:iie,reloadNATSLeaf:oie,extractServerName:nie,requestErrorHandler:aie,createLocalTableStream:Uk,createTableStreams:uie,purgeTableStream:xk,purgeSchemaTableStreams:die,getStreamInfo:fie,updateLocalStreams:pie,closeConnection:jse,getJsmServerName:Sg,addNatsMsgHeader:Lk,clearClientCache:Ck,updateRemoteConsumer:cie,createConsumer:Mk,updateConsumerIterator:lie};async function Ik(e,t=void 0){let{stdout:r,stderr:n}=await Ise(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
19
|
+
`)},VZ="certificate.pem",KZ="privateKey.pem",YZ="caCertificate.pem",WZ="natsCertificate.pem",zZ="natsCaCertificate.pem",At={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},jZ={tls_certificate:At.SERVER,tls_certificateAuthority:At.CA,customFunctions_tls_certificate:At.SERVER,customFunctions_tls_certificateAuthority:At.CA,operationsApi_tls_certificate:At["OPERATIONS-API"],operationsApi_tls_certificateAuthority:At["OPERATIONS-CA"]},JZ={[At.SERVER]:2,[At.DEFAULT]:1},QZ={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},XZ={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},ZZ={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},e8={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},t8={[At.CA]:2,[At["DEFAULT-CA"]]:1};Object.assign(NU,{CERTIFICATE_PEM_NAME:VZ,PRIVATEKEY_PEM_NAME:KZ,CA_PEM_NAME:YZ,CERT_NAME:At,CERT_CONFIG_NAME_MAP:jZ,CERT_PREFERENCE_APP:JZ,CERT_PREFERENCE_OPS:QZ,CERT_PREFERENCE_REP:XZ,CA_CERT_PREFERENCE_REP:ZZ,CA_CERT_PREFERENCE_OPS:e8,CA_CERT_PREFERENCE_APP:t8,CERTIFICATE_VALUES:$Z,NATS_CERTIFICATE_PEM_NAME:WZ,NATS_CA_PEM_NAME:zZ})});var Yy=w((wNe,LU)=>{"use strict";var PU=require("fs-extra"),Re=require("joi"),r8=require("os"),{boolean:Be,string:Rt,number:tr,array:Jc}=Re.types(),{totalmem:wU}=require("os"),jc=require("path"),n8=z(),Ky=ie(),NNe=Vy(),IU=(H(),C(G)),s8=ot(),CU="log",i8="components",o8="Invalid logging.rotation.maxSize unit. Available units are G, M or K",a8="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",c8="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",l8="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",u8="rootPath config parameter is undefined",An=Re.alternatives([tr.min(0),Rt]).optional().empty(null),mE=Re.alternatives([Jc.items(Rt,{host:Rt.required(),port:An},{hostname:Rt.required(),port:An}).empty(null),Jc.items(Rt)]),vi,DU=!1;LU.exports={configValidator:d8,routesValidator:E8,route_constraints:mE};function d8(e,t=!1){if(DU=t,vi=e.rootPath,Ky.isEmpty(vi))throw u8;let r=Be.optional(),n=tr.min(0).max(1e3).empty(null).default(m8),s=Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(S_),i=Rt.optional().empty(null),o=Rt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Re.string().empty(null).default(S_),l=Re.custom(_8).empty(null).default(S_),u=e.clustering?.enabled,f=Re.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Re.object({enabled:r,hubServer:Re.object({cluster:Re.object({name:Re.required().empty(null),network:Re.object({port:An,routes:mE}).required()}).required(),leafNodes:Re.object({network:Re.object({port:An}).required()}).required(),network:Re.object({port:An}).required()}).required(),leafServer:Re.object({network:Re.object({port:An,routes:mE}).required(),streams:Re.object({maxAge:tr.min(120).allow(null).optional(),maxBytes:tr.min(1).allow(null).optional(),maxMsgs:tr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:Re.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:Be.optional(),databaseLevel:Be.optional(),tls:Re.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Be.required(),verify:Be.optional()}),user:Rt.optional().empty(null)}).optional():d=Re.object({enabled:r,tls:Re.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Be.optional()})}).optional(),Re.object({authentication:Re.alternatives(Re.object({authorizeLocal:Be,cacheTTL:tr.required(),enableSessions:Be,hashFunction:Rt.valid("md5","sha256","argon2id").optional().empty(null)}),Be).optional(),analytics:Re.object({aggregatePeriod:tr}),replication:Re.object({hostname:Re.alternatives(Rt,tr).optional().empty(null),url:Rt.optional().empty(null),port:An,securePort:An,routes:Jc.optional().empty(null),databases:Re.alternatives(Rt,Jc),enableRootCAs:Be.optional(),copyTablesToCatchUp:Be.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Re.object({enabled:r}).required(),logging:Re.object({auditAuthEvents:Re.object({logFailed:Be,logSuccessful:Be}),file:Be.required(),level:Re.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Re.object({enabled:Be.optional(),compress:Be.optional(),interval:Rt.custom(h8).optional().empty(null),maxSize:Rt.custom(p8).optional().empty(null),path:Rt.optional().empty(null).default(S_)}).required(),root:s,stdStreams:Be.required(),auditLog:Be.required()}).required(),operationsApi:Re.object({network:Re.object({cors:Be.optional(),corsAccessList:Jc.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:An,domainSocket:Re.optional().empty("hdb/operations-server").default(S_),securePort:An,timeout:tr.min(1).optional()}).optional(),tls:Re.alternatives([Re.array().items(f),f])}).required(),rootPath:Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Re.object({network:Re.object({port:An,securePort:An,mtls:Re.alternatives([Be.optional(),Re.object({user:Rt.optional(),certificateAuthority:i,required:Be.optional()})])}).required(),webSocket:Be.optional(),requireAuthentication:Be.optional()}),http:Re.object({compressionThreshold:tr.optional(),cors:Be.optional(),corsAccessList:Jc.optional(),headersTimeout:tr.min(1).optional(),port:An,securePort:An,maxHeaderSize:tr.optional(),mtls:Re.alternatives([Be.optional(),Re.object({user:Rt.optional(),certificateAuthority:i,required:Be.optional()})]),threadRange:Re.alternatives([Jc.optional(),Rt.optional()])}).required(),threads:Re.alternatives(n.optional(),Re.object({count:n.optional(),debug:Re.alternatives(Be.optional(),Re.object({startingPort:tr.min(1).optional(),host:Rt.optional(),waitForDebugger:Be.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:Re.object({writeAsync:Be.required(),overlappingSync:Be.optional(),caching:Be.optional(),compression:Re.alternatives([Be.optional(),Re.object({dictionary:Rt.optional(),threshold:tr.optional()})]),compactOnStart:Be.optional(),compactOnStartKeepBackup:Be.optional(),noReadAhead:Be.optional(),path:l,prefetchWrites:Be.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:Be.optional(),tls:Re.alternatives([Re.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(d8,"configValidator");function f8(e){return DU||PU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(f8,"doesPathExist");function _8(e,t){Re.assert(e,Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=f8(e);if(r)return t.message(r)}a(_8,"validatePath");function p8(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(o8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(c8):e}a(p8,"validateRotationMaxSize");function h8(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(a8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(l8):e}a(h8,"validateRotationInterval");function m8(e,t){let r=t.state.path.join("."),n=r8.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||wU();return i=Math.round(Math.min(i,wU())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),n8.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(m8,"setDefaultThreads");function S_(e,t){let r=t.state.path.join(".");if(!Ky.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Ky.isEmpty(vi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return jc.join(vi,i8);case"logging.root":return jc.join(vi,CU);case"clustering.leafServer.streams.path":return jc.join(vi,"clustering","leaf");case"storage.path":let n=jc.join(vi,IU.LEGACY_DATABASES_DIR_NAME);return PU.existsSync(n)?n:jc.join(vi,IU.DATABASES_DIR_NAME);case"logging.rotation.path":return jc.join(vi,CU);case"operationsApi.network.domainSocket":return r==null?null:jc.join(vi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(S_,"setDefaultRoot");function E8(e){let t=Re.object({routes:mE});return s8.validateBySchema({routes:e},t)}a(E8,"routesValidator")});var yt=w($U=>{"use strict";var Rs=(H(),C(G)),Sr=ie(),rr=z(),{configValidator:g8,routesValidator:MU}=Yy(),zr=require("fs-extra"),UU=require("yaml"),Yn=require("path"),S8=require("is-number"),xU=require("properties-reader"),T8=require("lodash"),{handleHDBError:A8}=pe(),{HTTP_STATUS_CODES:R8,HDB_ERROR_MSGS:Du}=xn(),{server:y8}=(Vr(),C(Au)),{PACKAGE_ROOT:BU}=it(),{DATABASES_PARAM_CONFIG:T_,CONFIG_PARAMS:Kn,CONFIG_PARAM_MAP:ei}=Rs,b8="Unable to get config value because config is uninitialized",O8="Config successfully initialized",N8="Error backing up config file",w8="Empty parameter sent to getConfigValue",HU=Yn.join(BU,"config","yaml",Rs.HDB_DEFAULT_CONFIG_FILE),I8=Yn.join(BU,"config","yaml","defaultNatsConfig.yaml"),C8="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",vU={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"},EE,Ct,gE;Object.assign($U,{createConfigFile:P8,getDefaultConfig:D8,getConfigValue:FU,initConfig:SE,flattenConfig:Lu,updateConfigValue:GU,updateConfigObject:M8,getConfiguration:x8,setConfiguration:B8,readConfigFile:Jy,getClusteringRoutes:H8,initOldConfig:qU,getConfigFromFile:k8,getConfigFilePath:Qc,addConfig:F8,deleteConfigFromFile:G8,getConfigObj:q8,resolvePath:Wy,getFlatConfigObj:$8});function Wy(e){if(e?.startsWith("~/"))return Yn.join(Sr.getHomeDir(),e.slice(1));let t=ae();return Yn.resolve(t.getHdbBasePath(),e)}a(Wy,"resolvePath");function P8(e,t=!1){let r=Na(HU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=UU.parseDocument(zr.readFileSync(I8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}EE=Lu(r.toJSON());let n;for(let c in e){let l=ei[c.toLowerCase()];if(l===Kn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),f=zy(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){rr.error(d)}}}n&&kU(r,n),jy(r,t);let s=r.toJSON();Ct=Lu(s);let i=r.getIn(["rootPath"]),o=Yn.join(i,Rs.HDB_CONFIG_FILE);if(zr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);zr.writeFileSync(o,String(r)),rr.trace(`Config file written to ${o}`)}a(P8,"createConfigFile");function kU(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Sr.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(T_.TABLES))for(let i in n[s][T_.TABLES])for(let o in n[s][T_.TABLES][i]){let c=n[s][T_.TABLES][i][o],l=[Kn.DATABASES,s,T_.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Kn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){rr.error("Error parsing schemas CLI/env config arguments",n)}}a(kU,"setSchemasConfig");function D8(e){if(EE===void 0){let r=Na(HU);EE=Lu(r.toJSON())}let t=ei[e.toLowerCase()];if(t!==void 0)return EE[t.toLowerCase()]}a(D8,"getDefaultConfig");function FU(e){if(e==null){rr.info(w8);return}if(Ct===void 0){rr.trace(b8);return}let t=ei[e.toLowerCase()];if(t!==void 0)return Ct[t.toLowerCase()]}a(FU,"getConfigValue");function Qc(e=Sr.getPropsFilePath()){let t=Sr.getEnvCliRootPath();if(t)return Wy(Yn.join(t,Rs.HDB_CONFIG_FILE));let r=xU(e);return Wy(r.get(Rs.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Qc,"getConfigFilePath");function SE(e=!1){if(Ct===void 0||e){let t;if(!Sr.noBootFile()){t=Sr.getPropsFilePath();try{zr.accessSync(t,zr.constants.F_OK|zr.constants.R_OK)}catch(i){throw rr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Qc(t),n;if(r.includes("config/settings.js"))try{qU(r);return}catch(i){if(i.code!==Rs.NODE_ERROR_CODES.ENOENT)throw i}try{n=Na(r)}catch(i){if(i.code===Rs.NODE_ERROR_CODES.ENOENT){rr.trace(`HarperDB config file not found at ${r}.
|
|
20
|
+
This can occur during early stages of install where the config file has not yet been created`);return}else throw rr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}L8(n,r),jy(n);let s=n.toJSON();if(y8.config=s,Ct=Lu(s),Ct.logging_rotation_rotate)for(let i in vU)Ct[i]&&rr.error(`Config ${vU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);rr.trace(O8)}}a(SE,"initConfig");function L8(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Yn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Yn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(rr.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);zr.writeFileSync(t,String(e))}}a(L8,"checkForUpdatedConfig");function jy(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Du.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Du.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=g8(r,t);if(n.error)throw Du.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(jy,"validateConfig");function M8(e,t){Ct===void 0&&(Ct={});let r=ei[e.toLowerCase()];if(r===void 0){rr.trace(`Unable to update config object because config param '${e}' does not exist`);return}Ct[r.toLowerCase()]=t}a(M8,"updateConfigObject");function GU(e,t,r=void 0,n=!1,s=!1,i=!1){Ct===void 0&&SE();let o=FU(ei.hdb_root),c=Yn.join(o,Rs.HDB_CONFIG_FILE),l=Na(c),u;if(r&&Ct){let p=!1;for(let _ in r)if(r[_]!=Ct[_.toLowerCase()]){p=!0;break}if(!p){rr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===Kn.DATABASES)u=t;else if(r===void 0){let p;if(i)p=e;else if(p=ei[e.toLowerCase()],p===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=p.split("_"),h=zy(p,t);l.setIn([..._],h)}else for(let p in r){let _=ei[p.toLowerCase()];if(_===Kn.HTTP_SECUREPORT&&r[p]===Ct[Kn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===Kn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[p]===Ct[Kn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===Kn.DATABASES){u=r[p];continue}if(_?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!_&&(p.endsWith("_package")||p.endsWith("_port"))&&(_=p),_!==void 0){let h=_.split("_"),S=Rs.LEGACY_CONFIG_PARAMS[p.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,h=S.split("_"));let g=zy(_,r[p]);_==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],g)}catch(R){rr.error(R)}}}u&&kU(l,u),jy(l);let f=l.getIn(["rootPath"]),d=Yn.join(f,Rs.HDB_CONFIG_FILE);if(n===!0&&v8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);zr.writeFileSync(d,String(l)),s&&(Ct=Lu(l.toJSON())),rr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(GU,"updateConfigValue");function v8(e,t){try{let r=Yn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${Rs.HDB_CONFIG_FILE}.bak`);zr.copySync(e,r),rr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){rr.error(N8),rr.error(r)}}a(v8,"backupConfigFile");var U8=["databases"];function Lu(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),gE=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!U8.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Kn[l.toUpperCase()]&&ei[l]&&(s[ei[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Lu,"flattenConfig");function zy(e,t){if(e===Kn.CLUSTERING_NODENAME||e===Kn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(S8(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Sr.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return Sr.autoCast(t)}a(zy,"castConfigValue");function x8(){let e=Sr.getPropsFilePath(),t=Qc(e);return Na(t).toJSON()}a(x8,"getConfiguration");async function B8(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return GU(void 0,void 0,s,!0),C8}catch(i){throw typeof i=="string"||i instanceof String?A8(i,i,R8.BAD_REQUEST,void 0,void 0,!0):i}}a(B8,"setConfiguration");function Jy(){let e=Sr.getPropsFilePath();try{zr.accessSync(e,zr.constants.F_OK|zr.constants.R_OK)}catch(n){if(!Sr.noBootFile())throw rr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Qc(e);return Na(t).toJSON()}a(Jy,"readConfigFile");function Na(e){return UU.parseDocument(zr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Na,"parseYamlDoc");function H8(){let e=Jy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Sr.isEmptyOrZeroLength(t)?[]:t;let r=MU(t);if(r)throw Du.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Sr.isEmptyOrZeroLength(n)?[]:n;let s=MU(n);if(s)throw Du.CONFIG_VALIDATION(s.message);if(!Sr.isEmptyOrZeroLength(n)&&!Sr.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Sr.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Du.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(H8,"getClusteringRoutes");function qU(e){let t=xU(e);Ct={};for(let r in ei){let n=t.get(r.toUpperCase());if(Sr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ei[r].toLowerCase();s===Kn.LOGGING_ROOT?Ct[s]=Yn.dirname(n):Ct[s]=n}return Ct}a(qU,"initOldConfig");function k8(e){let t=Jy();return T8.get(t,e.replaceAll("_","."))}a(k8,"getConfigFromFile");async function F8(e,t){let r=Na(Qc());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await zr.writeFile(Qc(),String(r))}a(F8,"addConfig");function G8(e){let t=Qc(Sr.getPropsFilePath()),r=Na(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Yn.join(n,Rs.HDB_CONFIG_FILE);zr.writeFileSync(s,String(r))}a(G8,"deleteConfigFromFile");function q8(){return gE||(SE(),gE)}a(q8,"getConfigObj");function $8(){return Ct||SE(),Ct}a($8,"getFlatConfigObj")});var Rn=w((DNe,Nr)=>{"use strict";var YU="username is required",WU="nothing to update, must supply active, role or password to update",zU="password cannot be an empty string",jU="If role is specified, it cannot be empty.",JU="active must be true or false";Nr.exports.addUser=X8;Nr.exports.alterUser=Z8;Nr.exports.dropUser=t5;Nr.exports.getSuperUser=o5;Nr.exports.userInfo=r5;Nr.exports.listUsers=AE;Nr.exports.listUsersExternal=n5;Nr.exports.setUsersWithRolesCache=Xc;Nr.exports.findAndValidateUser=ib;Nr.exports.getClusterUser=a5;Nr.exports.getUsersWithRolesCache=i5;Nr.exports.USERNAME_REQUIRED=YU;Nr.exports.ALTERUSER_NOTHING_TO_UPDATE=WU;Nr.exports.EMPTY_PASSWORD=zU;Nr.exports.EMPTY_ROLE=jU;Nr.exports.ACTIVE_BOOLEAN=JU;var QU=yn(),V8=zc(),A_=(hE(),C(pE)),XU=yU(),R_=Yr(),tb=To(),Ui=ie(),ZU=require("validate.js"),rb=z(),{promisify:K8}=require("util"),nb=Eo(),Xy=(H(),C(G)),VU=Tt(),Y8=yt(),W8=ae(),z8=po(),{hdb_errors:j8,ClientError:ti}=pe(),{HTTP_STATUS_CODES:So,AUTHENTICATION_ERROR_MSGS:Qy,HDB_ERROR_MSGS:Mu}=j8,{UserEventMsg:sb}=ri(),Zy=require("lodash"),{server:TE}=(Vr(),C(Au)),J8=z();TE.getUser=(e,t)=>ib(e,t,t!=null);TE.authenticateUser=(e,t)=>ib(e,t);var e0={username:!0,active:!0,role:!0,password:!0},KU=new Map,Q8=K8(V8.delete),eb=W8.get(Xy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??A_.HASH_FUNCTION.SHA256,xi;async function X8(e){let t=ZU.cleanAttributes(e,e0),r=XU.addUserValidation(t);if(r)throw new ti(r.message);let n=await R_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new ti(Mu.ROLE_NAME_NOT_FOUND(t.role),So.NOT_FOUND);if(n.length>1)throw new ti(Mu.DUP_ROLES_FOUND(t.role),So.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=nb.encrypt(t.password)),t.password=await A_.hash(t.password,eb),t.hash_function=eb,t.role=n[0].id;let s=await QU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(rb.debug(s),await Xc(),s.skipped_hashes.length===1)throw new ti(Mu.USER_ALREADY_EXISTS(t.username),So.CONFLICT);return tb.signalUserChange(new sb(process.pid)),`${t.username} successfully added`}a(X8,"addUser");async function Z8(e){let t=ZU.cleanAttributes(e,e0);if(Ui.isEmptyOrZeroLength(t.username))throw new Error(YU);if(Ui.isEmptyOrZeroLength(t.password)&&Ui.isEmptyOrZeroLength(t.role)&&Ui.isEmptyOrZeroLength(t.active))throw new Error(WU);if(!Ui.isEmpty(t.password)&&Ui.isEmptyOrZeroLength(t.password.trim()))throw new Error(zU);if(!Ui.isEmpty(t.active)&&!Ui.isBoolean(t.active))throw new Error(JU);if(!Ui.isEmpty(t.password)&&!Ui.isEmptyOrZeroLength(t.password.trim())&&(e5(t.username)&&(t.hash=nb.encrypt(t.password)),t.password=await A_.hash(t.password,eb)),t.role==="")throw new Error(jU);if(t.role){let n=await R_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ti(Mu.ALTER_USER_ROLE_NOT_FOUND(t.role),So.NOT_FOUND);if(n.length>1)throw new ti(Mu.DUP_ROLES_FOUND(t.role),So.CONFLICT);t.role=n[0].id}let r=await QU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await Xc(),tb.signalUserChange(new sb(process.pid)),r}a(Z8,"alterUser");function e5(e){let t=!1,r=xi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(e5,"isClusterUser");async function t5(e){let t=XU.dropUserValidation(e);if(t)throw new ti(t.message);if(xi.get(e.username)===void 0)throw new ti(Mu.USER_NOT_EXIST(e.username),So.NOT_FOUND);let r=await Q8({table:"hdb_user",schema:"system",hash_values:[e.username]});return rb.debug(r),await Xc(),tb.signalUserChange(new sb(process.pid)),`${e.username} successfully deleted`}a(t5,"dropUser");async function r5(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Zy.cloneDeep(e.hdb_user);let r=await R_.searchByHash({schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]});return t.role=r[0],delete t.password,delete t.refresh_token,delete t.hash,delete t.hash_function,t}a(r5,"userInfo");async function n5(){let e=await AE();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(n5,"listUsersExternal");async function AE(){let e=await R_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Zy.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await R_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Zy.cloneDeep(s),s.role=t[s.role],s5(s.role),n.set(s.username,s);return n}a(AE,"listUsers");function s5(e){if(!e){rb.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(z8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(s5,"appendSystemTablesToRole");async function Xc(e=void 0){e?xi=e:xi=await AE()}a(Xc,"setUsersWithRolesCache");async function i5(){return xi||await Xc(),xi}a(i5,"getUsersWithRolesCache");async function ib(e,t,r=!0){xi||await Xc();let n=xi.get(e);if(!n){if(!r)return{username:e};throw new ti(Qy.GENERIC_AUTH_FAIL,So.UNAUTHORIZED)}if(n&&!n.active)throw new ti(Qy.USER_INACTIVE,So.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(KU.get(t)===n.password)return s;{let i=A_.validate(n.password,t,n.hash_function||A_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)KU.set(t,n.password);else throw new ti(Qy.GENERIC_AUTH_FAIL,So.UNAUTHORIZED)}}return s}a(ib,"findAndValidateUser");async function o5(){xi||await Xc();for(let[,e]of xi)if(e.role.role==="super_user")return e}a(o5,"getSuperUser");async function a5(){let e=await AE(),t=Y8.getConfigFromFile(Xy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==Xy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=nb.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+VU.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+VU.SERVER_SUFFIX.ADMIN,r}a(a5,"getClusterUser");var t0=[];TE.invalidateUser=function(e){for(let t of t0)try{t(e)}catch(r){J8.error("Error invalidating user",r)}};TE.onInvalidatedUser=function(e){t0.push(e)}});var b_=w((UNe,i0)=>{"use strict";var Zc=z(),Wn=(H(),C(G)),c5=gv(),MNe=As(),vNe=go(),l5=Rn(),{validateEvent:r0}=ri(),y_=Vn(),u5=require("process"),{resetDatabases:d5}=(De(),C(nt)),f5={[Wn.ITC_EVENT_TYPES.SCHEMA]:_5,[Wn.ITC_EVENT_TYPES.USER]:s0};async function _5(e){let t=r0(e);if(t){Zc.error(t);return}Zc.trace("ITC schemaHandler received schema event:",e),await c5(e.message),await p5(e.message)}a(_5,"schemaHandler");async function p5(e){try{y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=d5();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Zc.error(t)}}a(p5,"syncSchemaMetadata");var n0=[];async function s0(e){try{try{y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Zc.warn(r)}let t=r0(e);if(t){Zc.error(t);return}Zc.trace(`ITC userHandler ${Wn.HDB_ITC_CLIENT_PREFIX}${u5.pid} received user event:`,e),await l5.setUsersWithRolesCache();for(let r of n0)r()}catch(t){Zc.error(t)}}a(s0,"userHandler");s0.addListener=function(e){n0.push(e)};i0.exports=f5});var ri=w((GNe,a0)=>{"use strict";var BNe=z(),ob=ie(),h5=(H(),C(G)),{ITC_ERRORS:O_}=xn(),{parentPort:HNe,threadId:m5,isMainThread:E5,workerData:kNe}=require("worker_threads"),{onMessageFromWorkers:g5,broadcast:FNe,broadcastWithAcknowledgement:S5}=rt();a0.exports={sendItcEvent:T5,validateEvent:o0,SchemaEventMsg:A5,UserEventMsg:R5};var RE;g5(async(e,t)=>{RE=RE||b_(),o0(e),RE[e.type]&&await RE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function T5(e){return!E5&&e.message&&(e.message.originator=m5),S5(e)}a(T5,"sendItcEvent");function o0(e){if(typeof e!="object")return O_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||ob.isEmpty(e.type))return O_.MISSING_TYPE;if(!e.hasOwnProperty("message")||ob.isEmpty(e.message))return O_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||ob.isEmpty(e.message.originator))return O_.MISSING_ORIGIN;if(h5.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return O_.INVALID_EVENT(e.type)}a(o0,"validateEvent");function A5(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(A5,"SchemaEventMsg");function R5(e){this.originator=e}a(R5,"UserEventMsg")});var To=w((VNe,d0)=>{"use strict";var c0=(H(),C(G)),$Ne=ie(),yE=z(),l0=hv(),vu,{sendItcEvent:u0}=ri();function y5(e){try{yE.info("signalSchemaChange called with message:",e),vu=vu||b_();let t=new l0(c0.ITC_EVENT_TYPES.SCHEMA,e);return vu.schema(t),u0(t)}catch(t){yE.error(t)}}a(y5,"signalSchemaChange");function b5(e){try{yE.trace("signalUserChange called with message:",e),vu=vu||b_();let t=new l0(c0.ITC_EVENT_TYPES.USER,e);return vu.user(t),u0(t)}catch(t){yE.error(t)}}a(b5,"signalUserChange");d0.exports={signalSchemaChange:y5,signalUserChange:b5}});var bE=w((YNe,_0)=>{"use strict";var f0=ie(),O5=(H(),C(G)),N5=z(),w5=iE(),I5=sE(),C5=To(),{SchemaEventMsg:P5}=ri(),D5="already exists in";_0.exports=L5;async function L5(e,t,r){if(f0.isEmptyOrZeroLength(r))return r;let n=[];f0.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await M5(e,t.schema,t.name,i)})),s}a(L5,"lmdbCheckForNewAttributes");async function M5(e,t,r,n){let s=new I5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await v5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(D5))N5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(M5,"createNewAttribute");async function v5(e){let t;return t=await w5(e),C5.signalSchemaChange(new P5(process.pid,O5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(v5,"createAttribute")});var Uu=w((zNe,p0)=>{"use strict";var ab=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};p0.exports=ab});var m0=w((JNe,h0)=>{"use strict";var U5=Uu(),x5=(H(),C(G)).OPERATIONS_ENUM,cb=class extends U5{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(x5.INSERT,r,n,s,i),this.records=t}};h0.exports=cb});var g0=w((XNe,E0)=>{"use strict";var B5=Uu(),H5=(H(),C(G)).OPERATIONS_ENUM,lb=class extends B5{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(H5.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};E0.exports=lb});var T0=w((ewe,S0)=>{"use strict";var k5=Uu(),F5=(H(),C(G)).OPERATIONS_ENUM,ub=class extends k5{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(F5.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};S0.exports=ub});var R0=w((rwe,A0)=>{"use strict";var G5=Uu(),q5=(H(),C(G)).OPERATIONS_ENUM,db=class extends G5{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(q5.DELETE,n,s,t,i),this.original_records=r}};A0.exports=db});var N_=w((iwe,N0)=>{"use strict";var swe=require("path"),y0=_t(),$5=m0(),V5=g0(),K5=T0(),Y5=R0(),xu=xt(),b0=ie(),{CONFIG_PARAMS:W5}=(H(),C(G)),O0=ae();O0.initSync();var OE=(H(),C(G)).OPERATIONS_ENUM,{getTransactionAuditStorePath:z5}=gt();N0.exports=j5;async function j5(e,t){if(O0.get(W5.LOGGING_AUDITLOG)===!1)return;let r=z5(e.schema,e.table),n=await y0.openEnvironment(r,e.table,!0),s=J5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){y0.initializeDBIs(n,xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,xu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),b0.isEmpty(s.user_name)||n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(j5,"writeTransaction");function J5(e,t){let r=b0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===OE.INSERT)return new $5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPDATE)return new V5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPSERT)return new K5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.DELETE)return new Y5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(J5,"createTransactionObject")});var fb=w((cwe,w0)=>{"use strict";var Q5=l_(),awe=Uf(),w_=(H(),C(G)),X5=xf(),Z5=qc().insertRecords,e9=_t(),t9=z(),r9=bE(),{getSchemaPath:n9}=gt(),s9=N_();w0.exports=i9;async function i9(e){try{let{schema_table:t,attributes:r}=Q5(e);X5(e,r,t.hash_attribute),e.schema!==w_.SYSTEM_SCHEMA_NAME&&(r.includes(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await r9(e.hdb_auth_header,t,r),s=n9(e.schema,e.table),i=await e9.openEnvironment(s,e.table),o=await Z5(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await s9(e,o)}catch(c){t9.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(i9,"lmdbCreateRecords")});var P0=w((uwe,C0)=>{"use strict";var I0=(H(),C(G)),o9=fb(),a9=Uf(),c9=require("fs-extra"),{getSchemaPath:l9}=gt();C0.exports=u9;async function u9(e){let t=[{name:e.schema,createddate:Date.now()}],r=new a9(I0.SYSTEM_SCHEMA_NAME,I0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await o9(r),await c9.mkdirp(l9(e.schema))}a(u9,"lmdbCreateSchema")});var L0=w((fwe,D0)=>{"use strict";var _b=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};D0.exports=_b});var x0=w((Ewe,U0)=>{"use strict";var M0=_t(),pb=_n(),hb=xn().LMDB_ERRORS_ENUM,d9=xt(),v0=z(),pwe=ie(),f9=require("lmdb"),_9=L0(),p9=(H(),C(G)),{OVERFLOW_MARKER:hwe,MAX_SEARCH_KEY_LENGTH:mwe}=d9,h9=p9.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function m9(e,t,r,n){if(pb.validateEnv(e),t===void 0)throw new Error(hb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(hb.IDS_REQUIRED):new Error(hb.IDS_MUST_BE_ITERABLE);try{let s=M0.listDBIs(e);M0.initializeDBIs(e,t,s);let i=new _9,o,c=[],l=[];for(let p=0,_=r.length;p<_;p++)try{o=r[p];let h=e.dbis[t].get(o);if(!h||n&&h[h9]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,f9.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let R=s[g];if(!h.hasOwnProperty(R)||R===t)continue;let E=e.dbis[R],T=h[R];if(T!=null)try{let b=pb.getIndexedValues(T);if(b)for(let v=0,F=b.length;v<F;v++)E.remove(b[v],o)}catch{v0.warn(`cannot delete from attribute: ${R}, ${T}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(h)}catch(h){v0.warn(h),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let p=0,_=f.length;p<_;p++)f[p]===!0?i.deleted.push(l[p]):(i.skipped.push(l[p]),u.push(p));let d=0;for(let p=0;p<u.length;p++){let _=u[p];i.original_records.splice(_-d,1),d++}return i.txn_time=pb.getNextMonotonicTime(),i}catch(s){throw s}}a(m9,"deleteRecords");U0.exports={deleteRecords:m9}});var I_=w((Swe,H0)=>{"use strict";var Bu=ie(),E9=x0(),g9=_t(),{getSchemaPath:S9}=gt(),T9=N_(),A9=z();H0.exports=R9;async function R9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Bu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Bu.isEmptyOrZeroLength(e.hash_values)&&!Bu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Bu.isEmpty(l)||e.hash_values.push(l)}}if(Bu.isEmptyOrZeroLength(e.hash_values))return B0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Bu.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=S9(e.schema,e.table),i=await g9.openEnvironment(s,e.table),o=await E9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await T9(e,o)}catch(c){A9.error(`unable to write transaction due to ${c.message}`)}return B0(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(R9,"lmdbDeleteRecords");function B0(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(B0,"createDeleteResponse")});var Eb=w((Rwe,k0)=>{"use strict";var y9=(H(),C(G)),Awe=_n();function mb(e,t){let r=Object.create(null);if(t.length===1&&y9.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(mb,"parseRow");function b9(e,t,r,n){let s=mb(r,e);n.push(s)}a(b9,"searchAll");function O9(e,t,r,n){let s=mb(r,e);n[t]=s}a(O9,"searchAllToMap");function N9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(N9,"iterateDBI");function el(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(el,"pushResults");function w9(e,t,r,n,s,i){t.toString().endsWith(e)&&el(t,r,n,s,i)}a(w9,"endsWith");function I9(e,t,r,n,s,i){t.toString().includes(e)&&el(t,r,n,s,i)}a(I9,"contains");function C9(e,t,r,n,s,i){t>e&&el(t,r,n,s,i)}a(C9,"greaterThanCompare");function P9(e,t,r,n,s,i){t>=e&&el(t,r,n,s,i)}a(P9,"greaterThanEqualCompare");function D9(e,t,r,n,s,i){t<e&&el(t,r,n,s,i)}a(D9,"lessThanCompare");function L9(e,t,r,n,s,i){t<=e&&el(t,r,n,s,i)}a(L9,"lessThanEqualCompare");k0.exports={parseRow:mb,searchAll:b9,searchAllToMap:O9,iterateDBI:N9,endsWith:w9,contains:I9,greaterThanCompare:C9,greaterThanEqualCompare:P9,lessThanCompare:D9,lessThanEqualCompare:L9,pushResults:el}});var Hu=w((wwe,Y0)=>{"use strict";var wa=_t(),bwe=z(),zn=_n(),NE=xt(),zt=xn().LMDB_ERRORS_ENUM,Owe=ie(),M9=(H(),C(G)),wE=Eb(),{parseRow:v9}=wE,Nwe=require("lmdb"),{OVERFLOW_MARKER:F0,MAX_SEARCH_KEY_LENGTH:U9}=NE;function G0(e,t,r,n=!1,s=void 0,i=void 0){return tl(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(G0,"iterateFullIndex");function C_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return tl(e,t,r,(f,d,p,_)=>{let E={transaction:f,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return _===r?(E.values=!1,d.getRange(E).map(T=>({value:T}))):d.getRange(E)})}a(C_,"iterateRangeBetween");function tl(e,t,r,n){let s=e.database||e,i=wa.openDBI(s,r);i[NE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&wa.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(tl,"setupTransaction");function q0(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(F0)){if(!s)if(r)s=wa.openDBI(e,r);else{let l=wa.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=wa.openDBI(e,l[u]),!s[NE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(q0,"getOverflowCheck");function x9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return tl(e,t,t,(o,c,l)=>(IE(r),r=P_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>v9(u.value,r))))}a(x9,"searchAll");function B9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);IE(r),r=P_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of G0(e,t,t,n,s,i))o.set(c,wE.parseRow(l,r));return o}a(B9,"searchAllToMap");function H9(e,t,r=!1,n=void 0,s=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=G0(e,void 0,t,r,n,s),c=o.transaction,l=q0(c.database,c,void 0,t);for(let{key:u,value:f}of o){let d=l(u,f);i[d]===void 0&&(i[d]=[]),i[d].push(f)}return i}a(H9,"iterateDBI");function k9(e,t){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return wa.statDBI(e,t).entryCount}a(k9,"countAll");function F9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ia(e,r,n),tl(e,t,r,(c,l,u,f)=>(n=zn.convertKeyValueToWrite(n),f===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(F9,"equals");function G9(e,t,r){return Ia(e,t,r),wa.openDBI(e,t).getValuesCount(r)}a(G9,"count");function q9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ia(e,r,n),tl(e,null,r,(c,l)=>{n=zn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let p of l.getKeys({transaction:c,start:n}))if(!p.startsWith(n)){d=p;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),f=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(p=>{let{key:_}=p;if(_!==d){if(_.toString().startsWith(n))return p;if(u===!0)return f.DONE}}),f.filter(p=>p)}else return f=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(u===!0)return f.DONE}),u?f:f.filter(d=>d)})}a(q9,"startsWith");function $9(e,t,r,n,s=!1,i=void 0,o=void 0){return $0(e,t,r,n,s,i,o,!0)}a($9,"endsWith");function $0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Ia(e,r,n),tl(e,null,r,(l,u,f,d)=>{let p=q0(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(_=>{let h=_.toString();return h.endsWith(F0)?u.getValues(_,{transaction:l}).map(S=>{let g=p(_,S);if(c?g.endsWith(n):g.includes(n))return{key:g,value:S}}).filter(S=>S):(c?h.endsWith(n):h.includes(n))?u[NE.DBI_DEFINITION_NAME].is_hash_attribute?{key:_,value:_}:u.getValues(_,{transaction:l}).map(S=>({key:_,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a($0,"contains");function V9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),C_(e,t,r,n,l,s,i,o,!0,!1)}a(V9,"greaterThan");function K9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),C_(e,t,r,n,l,s,i,o,!1,!1)}a(K9,"greaterThanEqual");function Y9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),C_(e,t,r,l,n,s,i,o,!1,!0)}a(Y9,"lessThan");function W9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),C_(e,t,r,l,n,s,i,o,!1,!1)}a(W9,"lessThanEqual");function z9(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(zn.validateEnv(e),r===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(zt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(zt.END_VALUE_REQUIRED);if(n=zn.convertKeyValueToWrite(n),s=zn.convertKeyValueToWrite(s),n>s)throw new Error(zt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return C_(e,t,r,n,s,i,o,c)}a(z9,"between");function j9(e,t,r,n){zn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),r=P_(s,r),n===void 0)throw new Error(zt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=wE.parseRow(c,r)),o}a(j9,"searchByHash");function J9(e,t,r){zn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(J9,"checkHashExists");function Q9(e,t,r,n,s=[]){return K0(e,t,r,n,s),V0(e,t,r,n,s).map(i=>i[1])}a(Q9,"batchSearchByHash");function X9(e,t,r,n,s=[]){K0(e,t,r,n,s);let i=new Map;for(let[o,c]of V0(e,t,r,n,s))i.set(o,c);return i}a(X9,"batchSearchByHashToMap");function V0(e,t,r,n,s=[]){return tl(e,t,t,(i,o,c)=>{r=P_(c,r);let l=r.length<3;return n.map(u=>{let f=c.dbis[t].get(u,{transaction:i,lazy:l});if(f)return[u,wE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(V0,"batchHashSearch");function K0(e,t,r,n,s){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(K0,"initializeBatchSearchByHash");function IE(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(IE,"validateFetchAttributes");function Ia(e,t,r){if(zn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>U9)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(Ia,"validateComparisonFunctions");function P_(e,t){return t.length===1&&M9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wa.listDBIs(e)),t}a(P_,"setGetWholeRowAttributes");Y0.exports={searchAll:x9,searchAllToMap:B9,count:G9,countAll:k9,equals:F9,startsWith:q9,endsWith:$9,contains:$0,searchByHash:j9,setGetWholeRowAttributes:P_,batchSearchByHash:Q9,batchSearchByHashToMap:X9,checkHashExists:J9,iterateDBI:H9,greaterThan:V9,greaterThanEqual:K9,lessThan:Y9,lessThanEqual:W9,between:z9}});var ku=w((Cwe,Q0)=>{var W0=require("lodash"),z0=ot(),He=require("joi"),Z9=ie(),{hdb_schema_table:D_,checkValidTable:j0,hdb_table:J0,hdb_database:CE}=Di(),{handleHDBError:e7,hdb_errors:t7}=pe(),{getDatabases:r7}=(De(),C(nt)),{HTTP_STATUS_CODES:n7}=t7,s7=He.object({database:CE,schema:CE,table:J0,search_attribute:D_,search_value:He.any().required(),get_attributes:He.array().min(1).items(He.alternatives(D_,He.object())).optional(),desc:He.bool(),limit:He.number().integer().min(1),offset:He.number().integer().min(0)}),i7=He.object({database:CE,schema:CE,table:J0,operator:He.string().valid("and","or").default("and").lowercase(),offset:He.number().integer().min(0),limit:He.number().integer().min(1),get_attributes:He.array().min(1).items(He.alternatives(D_,He.object())).optional(),sort:He.object({attribute:He.alternatives(D_,He.array().min(1)),descending:He.bool().optional()}).optional(),conditions:He.array().min(1).items(He.alternatives(He.object({operator:He.string().valid("and","or").default("and").lowercase(),conditions:He.array()}),He.object({search_attribute:He.alternatives(D_,He.array().min(1)),search_type:He.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:He.when("search_type",{switch:[{is:"equals",then:He.any()},{is:"between",then:He.array().items(He.alternatives([He.string(),He.number()])).length(2)}],otherwise:He.alternatives(He.string(),He.number())}).required()}))).required()});Q0.exports=function(e,t){let r=null;switch(t){case"value":r=z0.validateBySchema(e,s7);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(j0("database",e.schema)),i(j0("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(o=>typeof o=="string"||typeof o=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=z0.validateBySchema(e,i7);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Z9.checkGlobalSchemaTable(e.schema,e.table);if(s)return e7(new Error,s,n7.NOT_FOUND);let o=r7()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(f=>{for(let d=0,p=f.conditions.length;d<p;d++){let _=f.conditions[d];_.conditions?l(_):c.push(_.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=W0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!W0.some(o,d=>d===f||d.attribute===f||d.attribute===f.attribute));if(u&&u.length>0){let f=u.join(", ");return f=f.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${f}'`)}}return r}});var gb=w((Dwe,X0)=>{"use strict";var o7=_t(),a7=ku(),{getSchemaPath:c7}=gt();X0.exports=l7;function l7(e){let t=a7(e,"hashes");if(t)throw t;let r=c7(e.schema,e.table);return o7.openEnvironment(r,e.table)}a(l7,"initialize")});var Sb=w((Mwe,Z0)=>{"use strict";var u7=Hu(),d7=gb();Z0.exports=f7;async function f7(e){let t=await d7(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return u7.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(f7,"lmdbGetDataByHash")});var Fu=w((Uwe,ex)=>{"use strict";var Tb=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};ex.exports=Tb});var rx=w((Hwe,tx)=>{"use strict";var Bwe=Fu(),_7=Hu(),p7=gb();tx.exports=h7;async function h7(e){let t=await p7(e),r=global.hdb_schema[e.schema][e.table];return _7.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(h7,"lmdbSearchByHash")});var ni=w((Fwe,nx)=>{"use strict";var Ab=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,f=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=f}};nx.exports=Ab});var PE=w((qwe,lx)=>{"use strict";var jr=Hu(),m7=_t(),E7=ie(),ke=xt(),rl=(H(),C(G)),g7=po(),sx=xn().LMDB_ERRORS_ENUM,{getSchemaPath:S7}=gt(),Ao=rl.SEARCH_WILDCARDS;async function T7(e,t,r){let n;e.schema===rl.SYSTEM_SCHEMA_NAME?n=g7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=cx(e,n.hash_attribute,r,t);return ox(e,s,n.hash_attribute,r)}a(T7,"prepSearch");async function ox(e,t,r,n){let s=S7(e.schema,e.table),i=await m7.openEnvironment(s,e.table),o=ax(i,e,t,r),c=o.transaction||i;if([ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,ke.SEARCH_TYPES.SEARCH_ALL,ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(A7(e,r)===!1){let f=e.search_attribute;if(f===r)return n?ix(o,()=>!0):o.map(p=>({[r]:p.key}));let d=a(p=>({[r]:p.value,[f]:p.key}),"toObject");return n?ix(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?jr.batchSearchByHashToMap(c,r,e.get_attributes,u):jr.batchSearchByHash(c,r,e.get_attributes,u)}a(ox,"executeSearch");function ax(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case ke.SEARCH_TYPES.EQUALS:s=jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.CONTAINS:s=jr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.ENDS_WITH:case ke.SEARCH_TYPES._ENDS_WITH:s=jr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.STARTS_WITH:case ke.SEARCH_TYPES._STARTS_WITH:s=jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.SEARCH_ALL:return jr.searchAll(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.BETWEEN:s=jr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN:case ke.SEARCH_TYPES._GREATER_THAN:s=jr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN_EQUAL:case ke.SEARCH_TYPES._GREATER_THAN_EQUAL:s=jr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN:case ke.SEARCH_TYPES._LESS_THAN:s=jr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN_EQUAL:case ke.SEARCH_TYPES._LESS_THAN_EQUAL:s=jr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(ax,"searchByType");function ix(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(ix,"createMapFromIterable");function A7(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}a(A7,"checkToFetchMore");function cx(e,t,r,n){if(E7.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),Ao.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Ao[0])<0&&s.indexOf(Ao[1])<0)return c===!0?r===!0?ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:ke.SEARCH_TYPES.EQUALS;if(Ao.indexOf(i)>=0&&Ao.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(Ao.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(Ao.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(Ao[0])||s.includes(Ao[1]))return ke.SEARCH_TYPES.EQUALS;throw new Error(sx.UNKNOWN_SEARCH_TYPE)}else switch(n){case rl.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case rl.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case rl.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case rl.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case rl.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return ke.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(sx.UNKNOWN_SEARCH_TYPE)}}a(cx,"createSearchTypeFromSearchObject");lx.exports={executeSearch:ox,createSearchTypeFromSearchObject:cx,prepSearch:T7,searchByType:ax}});var dx=w((Kwe,ux)=>{"use strict";var Vwe=ni(),R7=ku(),y7=ie(),b7=(H(),C(G)),O7=PE();ux.exports=N7;function N7(e,t){if(!y7.isEmpty(t)&&b7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R7(e,"value");if(n)throw n;return O7.prepSearch(e,t,!0)}a(N7,"lmdbGetDataByValue")});var L_=w((zwe,fx)=>{"use strict";var Wwe=ni(),w7=ku(),I7=ie(),C7=(H(),C(G)),P7=PE();fx.exports=D7;async function D7(e,t){if(!I7.isEmpty(t)&&C7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=w7(e,"value");if(n)throw n;return P7.prepSearch(e,t,!1)}a(D7,"lmdbSearchByValue")});var px=w((Qwe,_x)=>{"use strict";var Jwe=xt(),Rb=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},yb=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},bb=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};_x.exports={SearchByConditionsObject:Rb,SearchCondition:yb,SortAttribute:bb}});var Sx=w((tIe,gx)=>{"use strict";var Zwe=px().SearchByConditionsObject,L7=ni(),M7=ku(),Ob=Hu(),DE=xt(),{Resource:eIe}=(Ea(),C(gR)),Ex=PE(),v7=Eb(),U7=require("lodash"),{getSchemaPath:x7}=gt(),hx=_t(),{handleHDBError:B7,hdb_errors:H7}=pe(),{HTTP_STATUS_CODES:k7}=H7,F7=1e8;gx.exports=G7;async function G7(e){let t=M7(e,"conditions");if(t)throw B7(t,t.message,k7.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=x7(e.schema,e.table),n=await hx.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)hx.openDBI(n,u.search_attribute);let i=U7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===DE.SEARCH_TYPES.EQUALS?u.estimated_count=Ob.count(n,u.search_attribute,u.search_value):f===DE.SEARCH_TYPES.CONTAINS||f===DE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=F7}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await mx(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],f=i.slice(1).map(Ex.filterByType),d=f.length,p=Ob.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(_=>u.get(_,{transaction:o,lazy:!0})),d>0&&(l=l.filter(_=>{for(let h=0;h<d;h++)if(!f[h](_))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(_=>v7.parseRow(_,p))}else{for(let d=1;d<i.length;d++){let p=i[d],_=await mx(o,e,p,s.hash_attribute);c=c.concat(_)}let u=new Set,f=e.offset||0;c=c.filter(d=>u.has(d)?!1:(u.add(d),!0)).slice(f,e.limit&&e.limit+f),l=Ob.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(G7,"lmdbSearchByConditions");async function mx(e,t,r,n){let s=new L7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===DE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Ex.searchByType(e,s,i,n).map(o=>o.value)}a(mx,"executeConditionSearch")});var M_=w((nIe,Tx)=>{"use strict";var q7=(H(),C(G)).OPERATIONS_ENUM,Nb=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=q7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Tx.exports=Nb});var wb=w((iIe,Ix)=>{"use strict";var bx=ni(),Ox=M_(),Nx=L_(),wx=I_(),bn=(H(),C(G)),Ax=ie(),Rx=_t(),{getTransactionAuditStorePath:$7,getSchemaPath:V7}=gt(),yx=z();Ix.exports=K7;async function K7(e){try{if(Ax.isEmpty(global.hdb_schema[e.schema])||Ax.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await Y7(e),await W7(e);let t=V7(e.schema,e.table);try{await Rx.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")yx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=$7(e.schema,e.table);await Rx.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")yx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(K7,"lmdbDropTable");async function Y7(e){let t=new bx(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Nx(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new Ox(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await wx(s)}a(Y7,"deleteAttributesFromSystem");async function W7(e){let t=new bx(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Nx(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new Ox(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await wx(s)}catch(i){throw i}}a(W7,"dropTableFromSystem")});var Px=w((aIe,Cx)=>{"use strict";var z7=require("fs-extra"),j7=ni(),J7=Fu(),Q7=M_(),X7=wb(),Z7=I_(),eee=Sb(),tee=L_(),Ro=(H(),C(G)),{getSchemaPath:ree}=gt(),{handleHDBError:nee,hdb_errors:see}=pe(),{HDB_ERROR_MSGS:iee,HTTP_STATUS_CODES:oee}=see;Cx.exports=aee;async function aee(e){let t;try{t=await cee(e.schema);let r=new j7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await tee(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await X7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Q7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Z7(s);let i=ree(t);await z7.remove(i)}catch(r){throw r}}a(aee,"lmdbDropSchema");async function cee(e){let t=new J7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await eee(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw nee(new Error,iee.SCHEMA_NOT_FOUND(e),oee.NOT_FOUND,void 0,void 0,!0);return n}a(cee,"validateDropSchema")});var v_=w((lIe,Dx)=>{"use strict";var Ib=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Dx.exports=Ib});var Pb=w((fIe,Lx)=>{"use strict";var lee=require("fs-extra"),LE=_t(),{getTransactionAuditStorePath:uee}=gt(),Cb=xt(),dIe=v_();Lx.exports=dee;async function dee(e){let t;try{let r=uee(e.schema,e.table);await lee.mkdirp(r),t=await LE.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{LE.createDBI(t,Cb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),LE.createDBI(t,Cb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),LE.createDBI(t,Cb.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(dee,"createTransactionsAuditEnvironment")});var Ux=w((hIe,vx)=>{"use strict";var Db=(H(),C(G)),Mx=_t(),fee=qc(),{getSystemSchemaPath:_ee,getSchemaPath:pee}=gt(),pIe=po(),hee=iE(),Lb=sE(),mee=z(),Eee=Pb();vx.exports=gee;async function gee(e,t){let r=pee(t.schema,t.table),n=new Lb(t.schema,t.table,Db.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Lb(t.schema,t.table,Db.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Lb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Mx.createEnvironment(r,t.table),e!==void 0){let o=await Mx.openEnvironment(_ee(),Db.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await fee.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Mb(n),await Mb(s),await Mb(i)}await Eee(t)}catch(o){throw o}}a(gee,"lmdbCreateTable");async function Mb(e){try{await hee(e)}catch(t){mee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Mb,"createAttribute")});var Bx=w((EIe,xx)=>{"use strict";var See=l_(),Tee=xf(),Aee=bE(),U_=(H(),C(G)),Ree=qc().updateRecords,yee=_t(),{getSchemaPath:bee}=gt(),Oee=N_(),Nee=z();xx.exports=wee;async function wee(e){try{let{schema_table:t,attributes:r}=See(e);Tee(e,r,t.hash_attribute),e.schema!==U_.SYSTEM_SCHEMA_NAME&&(r.includes(U_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(U_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(U_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(U_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Aee(e.hdb_auth_header,t,r),s=bee(e.schema,e.table),i=await yee.openEnvironment(s,e.table),o=await Ree(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Oee(e,o)}catch(c){Nee.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(wee,"lmdbUpdateRecords")});var kx=w((SIe,Hx)=>{"use strict";var Iee=(H(),C(G)).OPERATIONS_ENUM,vb=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Iee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Hx.exports=vb});var Gx=w((RIe,Fx)=>{"use strict";var AIe=kx(),Cee=l_(),Pee=xf(),Dee=bE(),x_=(H(),C(G)),Lee=qc().upsertRecords,Mee=_t(),{getSchemaPath:vee}=gt(),Uee=N_(),xee=z(),{handleHDBError:Bee,hdb_errors:Hee}=pe();Fx.exports=kee;async function kee(e){let t;try{t=Cee(e)}catch(l){throw Bee(l,l.message,Hee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;Pee(e,n,r.hash_attribute),e.schema!==x_.SYSTEM_SCHEMA_NAME&&(n.includes(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(x_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(x_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Dee(e.hdb_auth_header,r,n),i=vee(e.schema,e.table),o=await Mee.openEnvironment(i,e.table),c=await Lee(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Uee(e,c)}catch(l){xee.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(kee,"lmdbUpsertRecords")});var $x=w((bIe,qx)=>{"use strict";var Ub=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};qx.exports=Ub});var Kx=w((NIe,Vx)=>{"use strict";var xb=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};Vx.exports=xb});var zx=w((CIe,Wx)=>{"use strict";var Bb=_t(),{getTransactionAuditStorePath:Fee}=gt(),IIe=$x(),B_=xt(),Gee=ie(),Yx=Kx(),qee=require("util").promisify,$ee=qee(setTimeout),Vee=1e4,Kee=100;Wx.exports=Yee;async function Yee(e){let t=Fee(e.schema,e.table),r=await Bb.openEnvironment(t,e.table,!0),n=Bb.listDBIs(r);Bb.initializeDBIs(r,B_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Yx;do s=await Wee(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=s.start_timestamp),s.end_timestamp!==void 0&&(i.end_timestamp=s.end_timestamp),i.transactions_deleted+=s.transactions_deleted,await $ee(Kee);while(s.transactions_deleted>0);return i}a(Yee,"deleteAuditLogsBefore");async function Wee(e,t){let r=new Yx;try{let n=e.dbis[B_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[B_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Gee.isEmpty(c)||(s=e.dbis[B_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[B_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Vee)break}return await s,r}catch(n){throw n}}a(Wee,"deleteTransactions")});var Jx=w((DIe,jx)=>{"use strict";var Hb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};jx.exports=Hb});var Xx=w((vIe,Qx)=>{"use strict";var zee=ni(),jee=M_(),MIe=Jx(),Bi=(H(),C(G)),Jee=ie(),kb=_t(),Qee=po(),Xee=L_(),Zee=I_(),{getSchemaPath:ete}=gt();Qx.exports=tte;async function tte(e,t=!0){let r;e.schema===Bi.SYSTEM_SCHEMA_NAME?r=Qee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await nte(e),s=ete(e.schema,e.table),i=await kb.openEnvironment(s,e.table);return t===!0&&await rte(e,i,r.hash_attribute),kb.dropDBI(i,e.attribute),n}a(tte,"lmdbDropAttribute");async function rte(e,t,r){let n=kb.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let f in c)f!==i&&(u[f]=c[f]);s=t.dbis[r].put(o,u,l)}await s}a(rte,"removeAttributeFromAllObjects");async function nte(e){let t=new zee(Bi.SYSTEM_SCHEMA_NAME,Bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Xee(t)).filter(o=>o[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Jee.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new jee(Bi.SYSTEM_SCHEMA_NAME,Bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Zee(i)}a(nte,"dropAttributeFromSystem")});var sB=w((BIe,nB)=>{"use strict";var Fb=_t(),Gu=xt(),xIe=_n(),Gb=(H(),C(G)),Zx=ie(),{getTransactionAuditStorePath:ste}=gt(),ite=Hu(),ME=Uu(),ote=z();nB.exports=ate;async function ate(e){let t=ste(e.schema,e.table),r=await Fb.openEnvironment(t,e.table,!0),n=Fb.listDBIs(r);Fb.initializeDBIs(r,Gu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Gb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return eB(r,e.search_values);case Gb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,lte(r,e.search_values,s);case Gb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return cte(r,e.search_values);default:return eB(r)}}a(ate,"readAuditLog");function eB(e,t=[0,Date.now()]){Zx.isEmpty(t[0])&&(t[0]=0),Zx.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Gu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new ME,s))}a(eB,"searchTransactionsByTimestamp");function cte(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[Gu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,rB(e,i))}return Object.fromEntries(r)}a(cte,"searchTransactionsByUsername");function lte(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=ite.equals(e,Gu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Gu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let p=Number(d);n.has(p)?n.get(p).push(u.toString()):n.set(p,[u.toString()])}}let s=Array.from(n.keys()),i=rB(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);tB(l,"records",r,f,o),tB(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(lte,"searchTransactionsByHashValues");function tB(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),f=u[u.length-1];if(f.timestamp===i)f[t]=[c];else{let d=new ME(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new ME(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(tB,"loopRecords");function rB(e,t){let r=[];try{let n=e.dbis[Gu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new ME,i);r.push(o)}}catch(i){ote.warn(i)}return r}catch(n){throw n}}a(rB,"batchSearchTransactions")});var oB=w((GIe,iB)=>{"use strict";var{getSchemaPath:kIe}=gt(),FIe=_t(),{database:ute}=(De(),C(nt));iB.exports={writeTransaction:dte};async function dte(e,t,r){return ute({database:e,table:t}).transaction(r)}a(dte,"writeTransaction")});var uB=w(($Ie,lB)=>{"use strict";var{getSchemaPath:aB}=gt(),cB=_t();lB.exports={flush:fte,resetReadTxn:_te};async function fte(e,t){return(await cB.openEnvironment(aB(e,t),t.toString())).flushed}a(fte,"flush");async function _te(e,t){try{(await cB.openEnvironment(aB(e,t),t.toString())).resetReadTxn()}catch{}}a(_te,"resetReadTxn")});var pB=w((KIe,_B)=>{"use strict";var{Readable:pte}=require("stream"),{getDatabases:hte}=(De(),C(nt)),{readSync:mte,openSync:Ete,createReadStream:dB}=require("fs"),{open:gte}=require("lmdb"),fB=s_(),Ste=i_(),{AUDIT_STORE_OPTIONS:Tte}=(fo(),C(hB)),{INTERNAL_DBIS_NAME:Ate,AUDIT_STORE_NAME:Rte}=xt();_B.exports=bte;var qb=32768,yte=100;async function bte(e){let t=e.database||e.schema||"data",r=hte()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let f=u.dbisDB,d=gte({noSync:!0,maxDbs:Ste.MAX_DBS}),p,_=d.openDB(Ate,new fB(!1)),h=f.useReadTransaction(),S=0,g=a(async function(E,T){T.encoding="binary",T.encoder=void 0;let b=d.openDB(E,T),v=f.openDB(E,T);for(let{key:F,version:q,value:Y}of v.getRange({start:null,transaction:h,versions:v.useVersions}))p=b.put(F,Y,q),S++%yte===0&&(await new Promise(Z=>setTimeout(Z,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:E,value:T}of f.getRange({transaction:h,start:!1}))if(s.some(b=>E.startsWith?.(b+"/"))){_.put(E,T);let[,b]=E.split("/"),v=!b,F=new fB(!v,v);await g(E,F)}e.include_audit&&await g(Rte,{...Tte}),await p;let R=dB(d.path);return R.headers=l(),R.on("close",()=>{h.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=Ete(o.path);return o.transaction(()=>{let u=Buffer.alloc(qb);mte(c,u,0,qb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=dB(null,{fd:c,start:qb}),p=new pte.from(async function*(){yield u;for await(let _ of d)f.openTimer&&(f.openTimer=0),yield _;f.done()}());return p.headers=l(),p});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(bte,"getBackup")});var gB=w((WIe,EB)=>{"use strict";var Ote=z(),{handleHDBError:Nte}=pe(),wte=CM(),Ite=iE(),Cte=fb(),Pte=P0(),Dte=I_(),Lte=Sb(),Mte=rx(),vte=dx(),Ute=L_(),xte=Sx(),Bte=Px(),Hte=Ux(),kte=Bx(),Fte=Gx(),Gte=zx(),qte=wb(),$te=Xx(),Vte=sB(),Kte=oB(),mB=uB(),Yte=pB(),$b=class extends wte{static{a(this,"LMDBBridge")}async searchByConditions(t){return xte(t)}async getDataByHash(t){return await Lte(t)}async searchByHash(t){return await Mte(t)}async getDataByValue(t,r){return await vte(t,r)}async searchByValue(t){return await Ute(t)}async createSchema(t){return await Pte(t)}async dropSchema(t){return await Bte(t)}async createTable(t,r){return await Hte(t,r)}async dropTable(t){return await qte(t)}async createAttribute(t){return await Ite(t)}async createRecords(t){return await Cte(t)}async updateRecords(t){return await kte(t)}async upsertRecords(t){try{return await Fte(t)}catch(r){throw Nte(r,null,null,Ote.ERR,r)}}async deleteRecords(t){return await Dte(t)}async dropAttribute(t){return await $te(t)}async deleteAuditLogsBefore(t){return await Gte(t)}async readAuditLog(t){return await Vte(t)}writeTransaction(t,r,n){return Kte.writeTransaction(t,r,n)}flush(t,r){return mB.flush(t,r)}resetReadTxn(t,r){return mB.resetReadTxn(t,r)}getBackup(t){return Yte(t)}};EB.exports=$b});var Kb={};ve(Kb,{add:()=>vE,applyReverse:()=>SB,getRecordAtTime:()=>Vb,rebuildUpdateBefore:()=>UE});function vE(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function UE(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,vE(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function SB(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Wte[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=TB}}function Vb(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=It(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":SB(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===TB&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=It(l),f;switch(u.type){case"put":f=u.getValue(r);break;case"patch":f=u.getValue(r);break}for(let d in f)o[d]&&(s[d]=f[d],o[d]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var Wte,TB,xE=be(()=>{fo();a(vE,"add");vE.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};Wte={add:vE};a(UE,"rebuildUpdateBefore");a(SB,"applyReverse");TB={};a(Vb,"getRecordAtTime")});function On(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function FE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a string, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(p=>typeof p=="string")||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a string, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="number"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a number, attempt to assign ${p}`);On(this)[l]=d},"set");break;case"Int":u=a(function(d){let p=d?.__op__?d.value:d;if(!(p>>0===p||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs((p>>0)-p)<=1)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Long":u=a(function(d){let p=d?.__op__?d.value:d;if(!(Math.round(p)===d&&Math.abs(p)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs(p)<=9007199254740992)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="bigint"||d==null&&c.nullable!==!1))if(typeof p=="string"||typeof p=="number")p=BigInt(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be a number, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new jn.ClientError(`${l} must be a Date, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof wi||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){On(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be an object, attempt to assign ${d}`);On(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let _=d[l];if(_?.__op__){let h=this.getRecord()?.[l];return _.update(h)}return _}let p=this.getRecord()?.[l];if(p&&typeof p=="object"){let _=Yb(p,c);if(_)return d||this._setChanges(d=Object.create(null)),d[l]=_}return p},set:u,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,n[l]=f,(!(l in r)||Object.getOwnPropertyDescriptor(r,l)?.get?.isAttribute)&&Object.defineProperty(r,l,f)}i("getProperty",function(c){let l=n[c];if(l)return l.get.call(this);let u=this.getChanges();return u?.[c]!==void 0?u[c]:this.getRecord()?.[c]}),i("set",function(c,l){let u=n[c];if(u)return u.set.call(this,l);if(t.sealed)throw new jn.ClientError("Can not add a property to a sealed table schema");On(this)[c]=l}),i("deleteProperty",function(c){On(this)[c]=void 0}),i("toJSON",function(){let c=this.getChanges?.(),l;for(let f in c){l||(l={...this.getRecord()});let d=c[f];if(d?.__op__){let p=l[f];d=d.update(p)}l[f]=d}return Object.keys(this).length>0&&(l||(l={...this.getRecord()}),Object.assign(l,this)),l||this.getRecord()}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty),r.then||i("then",null);function i(c,l){Object.defineProperty(r,c,{value:l,configurable:!0})}a(i,"setMethod");let o=r;do{let c=Object.getPrototypeOf(o);if(c===Object.prototype){Object.setPrototypeOf(o,RB);break}o=c}while(o&&o!==RB)}function Yb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends H_{static{a(this,"TrackedObject")}},FE(r,t)),new r(e)):new H_(e);case Array:let n=new HE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=Yb(o,t?.elements)),n[s]=o}return n;default:return e}}function GE(e){let t=e.getChanges?.(),r;for(let s in t){r||(r=e.getRecord?{...e.getRecord()}:{});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=GE(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=e.getRecord?{...e.getRecord()}:{}),Object.assign(r,e)),r||e.getRecord?.()||e}function sl(e,t=e.getChanges?.()){let r;if(e.getRecord&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=sl(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?.()});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=Kb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=sl(s);r[n]=s}if(!Array.isArray(e))for(let n in e)zte.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function BE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[nl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(BE(i))return!0}else return!0}}else{let r=e.getChanges?.();if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s.getRecord?.()===i){if(BE(s))return!0}else return!0}else return!0}}return!1}var jn,AB,RB,H_,zte,nl,HE,kE,Wb=be(()=>{jn=M(pe());xE();gs();a(On,"getChanges");a(FE,"assignTrackedAccessors");AB=Object.prototype,RB=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(AB[t])return AB[t];let n=r.getChanges?.();if(n&&t in n)return n[t];let s=r.getRecord?.()[t];if(s&&typeof s=="object"){let i=Yb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(Yb,"trackObject");H_=class{static{a(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};FE(H_,{});a(GE,"collapseData");zte=Object.prototype.hasOwnProperty;a(sl,"updateAndFreeze");a(BE,"hasChanges");nl=Symbol.for("has-array-changes"),HE=class extends Array{static{a(this,"TrackedArray")}#e;[nl];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[nl]=!0,super.splice(...t)}push(...t){return this[nl]=!0,super.push(...t)}pop(){return this[nl]=!0,super.pop()}unshift(...t){return this[nl]=!0,super.unshift(...t)}shift(){return this[nl]=!0,super.shift()}};HE.prototype.constructor=Array;kE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var PB={};ve(PB,{ResourceBridge:()=>Jb});function Qb({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function bB(e,t){let r=Hi(e),n=Qb(e,r);if(!r)throw new si.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;wt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],f;try{f=await r.get({id:u,lazy:s,select:n},i),f=f&&GE(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function Hi(e){let t=e.database||e.schema||Jte,r=Xe()[t];if(!r)throw(0,si.handleHDBError)(new Error,jte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function OB(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*NB(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var wB,qE,si,IB,zb,jb,CB,jte,Jte,Qte,Xte,yB,Jb,DB=be(()=>{"use strict";wB=M(gB()),qE=M(ku()),si=M(pe());De();IB=M(l_());H();zb=M(To()),jb=M(ri()),CB=M(ie());Ic();Wb();({HDB_ERROR_MSGS:jte}=si.hdb_errors),Jte="data",Qte=1e4,Xte=10,Jb=class extends wB.default{static{a(this,"ResourceBridge")}constructor(t){super(t),yB=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,qE.default)(t,"conditions");if(r)throw(0,si.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Hi(t);if(!n)throw new si.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:Qb(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new si.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ft({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Hi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Hi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Hi(t).dropTable()}createSchema(t){return qu({database:t.schema,table:null}),zb.signalSchemaChange(new jb.SchemaEventMsg(process.pid,Yt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Xb(t.schema),zb.signalSchemaChange(new jb.SchemaEventMsg(process.pid,Yt.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,yB.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,IB.default)(t),s,i=Xe()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),wt(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(p=>p.name==f)||s.push(f);s.length>0&&await i.addAttributes(s.map(f=>({name:f,indexed:!0})))}let l=[],u=[];for(let f of t.records){let d=f[i.primaryKey],p=d!=null&&await i.get(d,o);if(t.requires_existing&&!p||t.requires_no_existing&&p){u.push(f[i.primaryKey]);continue}p&&(p=GE(p));for(let _ in f)if(Object.prototype.hasOwnProperty.call(f,_)){let h=f[_];if(typeof h=="function")try{let S=h([[p]]);Array.isArray(S)&&(h=S[0].func_val,f[_]=h)}catch(S){throw S.message+="Trying to set key "+_+" on object"+JSON.stringify(f),S}}if(p)for(let _ in p)Object.prototype.hasOwnProperty.call(f,_)||(f[_]=p[_]);await(d==null?i.create(f,o):i.put(f,o)),l.push(f[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=Xe()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),wt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return OB(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Xe()[t.schema][t.table];if(!r.createdTimeProperty)throw new si.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:am.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let f=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...f.deleted_hashes),o.push(...f.skipped_hashes),await(0,CB.async_set_timeout)(Xte),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Qte===0&&await u();return l.length>0&&await u(),s?OB(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,qE.default)(t,"hashes");if(r)throw r;return bB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of bB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&QA[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,qE.default)(t,"value");if(n)throw n;let s=Hi(t);if(!s)throw new si.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===am.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:Qb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Hi(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){Hi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Hi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Hi(t),n={};switch(t.search_type){case cm.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case cm.USERNAME:let s=t.search_values;for await(let i of NB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return NB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(Qb,"getSelect");a(bB,"getRecords");a(Hi,"getTable");a(OB,"createDeleteResponse");a(NB,"groupRecordsInHistory")});var Vn=w((oCe,LB)=>{"use strict";var{ResourceBridge:Zte}=(DB(),C(PB)),ere=ae();ere.initSync();var $E;function tre(){return $E||($E=new Zte,$E)}a(tre,"getBridge");LB.exports=tre()});var yn=w((cCe,xB)=>{"use strict";var KE=FR(),Lr=ie(),rre=require("util"),YE=Vn(),nre=As(),MB=z(),{handleHDBError:il,hdb_errors:sre}=pe(),{HTTP_STATUS_CODES:ol}=sre,ire=rre.promisify(nre.getTableSchema),ore="updated",vB="inserted",UB="upserted";xB.exports={insert:cre,update:lre,upsert:ure,validation:are,flush:dre};async function are(e){if(Lr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Lr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Lr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await ire(e.schema,e.table),r=KE(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Lr.isEmptyOrZeroLength(c[n]))throw MB.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(!Lr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw MB.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Lr.isEmpty(c[n])&&c[n]!==""&&s.has(Lr.autoCast(c[n]))&&(c.skip=!0),s.add(Lr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(are,"validation");async function cre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=KE(e);if(t)throw il(new Error,t.message,ol.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw il(new Error,r,ol.BAD_REQUEST);let n=await YE.createRecords(e);return VE(vB,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(cre,"insertData");async function lre(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=KE(e);if(t)throw il(new Error,t.message,ol.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw il(new Error,r,ol.BAD_REQUEST);let n=await YE.updateRecords(e);return Lr.isEmpty(n.existing_rows)?VE(ore,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):VE(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(lre,"updateData");async function ure(e){if(e.operation!=="upsert")throw il(new Error,"invalid operation, must be upsert",ol.INTERNAL_SERVER_ERROR);let t=KE(e);if(t)throw il(new Error,t.message,ol.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw il(new Error,r,ol.BAD_REQUEST);let n=await YE.upsertRecords(e);return VE(UB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(ure,"upsertData");function VE(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===vB?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===UB?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(VE,"returnObject");function dre(e){return Lr.transformReq(e),YE.flush(e.schema,e.table)}a(dre,"flush")});var qB=w((uCe,GB)=>{var $u=require("validate.js"),HB=ot(),Vu=(H(),C(G)),{handleHDBError:fre,hdb_errors:_re}=pe(),{HDB_ERROR_MSGS:jt,HTTP_STATUS_CODES:pre}=_re,Zb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),hre={STRUCTURE_USER:"structure_user"},BB=Object.values(Vu.ROLE_TYPES_ENUM),mre="attribute_permissions",Ere="attribute_name",{PERMS_CRUD_ENUM:Ku}=Vu,gre=[mre,...Object.values(Ku)],kB=[Ku.READ,Ku.INSERT,Ku.UPDATE],Sre=[Ere,...kB];function Tre(e){let t=Zb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,FB(e,t)}a(Tre,"addRoleValidation");function Are(e){let t=Zb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,FB(e,t)}a(Are,"alterRoleValidation");function Rre(e){let t=Zb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,HB.validateObject(e,t)}a(Rre,"dropRoleValidation");var yre=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function FB(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)yre.includes(n[o])||s.push(n[o]);s.length>0&&nr(jt.INVALID_ROLE_JSON_KEYS(s),r);let i=HB.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=bre(e);o&&nr(o,r),BB.forEach(c=>{e.permission[c]&&!$u.isBoolean(e.permission[c])&&nr(jt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(BB.indexOf(o)<0){if(o===hre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,f=l.length;u<f;u++){let d=l[u];global.hdb_schema[d]||nr(jt.SCHEMA_NOT_FOUND(d),r)}continue}nr(jt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(jt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){nr(jt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{gre.includes(f)||nr(jt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Ku).forEach(f=>{$u.isDefined(u[f])?$u.isBoolean(u[f])||nr(jt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(jt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(jt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(jt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:p})=>p),d={read:!1,insert:!1,update:!1};for(let p in u.attribute_permissions){let _=u.attribute_permissions[p];if(Object.keys(_).forEach(S=>{!Sre.includes(S)&&S!==Ku.DELETE&&nr(jt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!$u.isDefined(_.attribute_name)){nr(jt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!f.includes(h)){nr(jt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}kB.forEach(S=>{$u.isDefined(_[S])?$u.isBoolean(_[S])||nr(jt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,l):nr(jt.ATTR_PERM_MISSING(S,h),r,o,l)}),!d.read&&_.read===!0&&(d.read=!0),!d.insert&&_.insert===!0&&(d.insert=!0),!d.update&&_.update===!0&&(d.update=!0)}if(u.read===!1&&d.read===!0||u.insert===!1&&d.insert===!0||u.update===!1&&d.update===!0){let p=`${o}.${l}`;nr(jt.MISMATCHED_TABLE_ATTR_PERMS(p),r,o,l)}}}}return Ore(r)}a(FB,"customValidate");GB.exports={addRoleValidation:Tre,alterRoleValidation:Are,dropRoleValidation:Rre};function bre(e){let{operation:t,permission:r}=e;if(t===Vu.OPERATIONS_ENUM.ADD_ROLE||t===Vu.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return jt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Vu.ROLE_TYPES_ENUM.SUPER_USER:Vu.ROLE_TYPES_ENUM.CLUSTER_USER;return jt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(bre,"validateNoSUPerms");function Ore(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:jt.ROLE_PERMS_ERROR,...e};return fre(new Error,n,pre.BAD_REQUEST)}else return null}a(Ore,"generateRolePermResponse");function nr(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(nr,"addPermError")});var F_=w((_Ce,YB)=>{"use strict";var $B=yn(),VB=Yr(),Nre=zc(),tO=qB(),rO=To(),fCe=require("uuid").v4,wre=require("util"),WE=(H(),C(G)),Ire=ie(),nO=VB.searchByValue,Cre=VB.searchByHash,Pre=wre.promisify(Nre.delete),Dre=ni(),Lre=Fu(),{hdb_errors:Mre,handleHDBError:al}=pe(),{HDB_ERROR_MSGS:KB,HTTP_STATUS_CODES:k_}=Mre,{UserEventMsg:sO}=ri();YB.exports={addRole:vre,alterRole:Ure,dropRole:xre,listRoles:Bre};function eO(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(eO,"scrubRoleDetails");async function vre(e){let t=tO.addRoleValidation(e);if(t)throw t;e=eO(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await nO(r)||[])}catch(i){throw al(i)}if(n&&n.length>0)throw al(new Error,KB.ROLE_ALREADY_EXISTS(e.role),k_.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await $B.insert(s),rO.signalUserChange(new sO(process.pid)),e=eO(e),e}a(vre,"addRole");async function Ure(e){let t=tO.alterRoleValidation(e);if(t)throw t;e=eO(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await $B.update(r)}catch(s){throw al(s)}if(n&&n?.message==="updated 0 of 1 records")throw al(new Error,"Invalid role id",k_.BAD_REQUEST,void 0,void 0,!0);return await rO.signalUserChange(new sO(process.pid)),e}a(Ure,"alterRole");async function xre(e){let t=tO.dropRoleValidation(e);if(t)throw al(new Error,t,k_.BAD_REQUEST,void 0,void 0,!0);let r=new Lre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Cre(r));if(n.length===0)throw al(new Error,KB.ROLE_NOT_FOUND,k_.NOT_FOUND,void 0,void 0,!0);let s=new Dre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await nO(s)),o=!1;if(Ire.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw al(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,k_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Pre(c),rO.signalUserChange(new sO(process.pid)),`${n[0].role} successfully deleted`}a(xre,"dropRole");async function Bre(){return nO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Bre,"listRoles")});var iO={};ve(iO,{start:()=>jB,startOnMainThread:()=>Fre});function jB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,WB.parseDocument)(r.toString(),{simpleKeys:!0}).toJSON();for(let s in n){let i=n[s];i.permission||(i={permission:i},i.permission.access&&(i.access=i.permission.access,delete i.permission.access));for(let o in i.permission){if(Hre.includes(o))continue;let c=i.permission[o];c.tables||(i.permission[o]=c={tables:c});for(let l in c.tables){let u=c.tables[l];if(u.read=!!u.read,u.insert=!!u.insert,u.update=!!u.update,u.delete=!!u.delete,u.attributes){let f=[];for(let d in u.attributes){let p=u.attributes[d];p.attribute_name=d,f.push(p)}u.attribute_permissions=f,delete u.attributes}if(u.attribute_permissions){if(!Array.isArray(u.attribute_permissions))throw new Error("attribute_permissions must be an array if defined");for(let f of u.attribute_permissions)f.read=!!f.read,f.insert=!!f.insert,f.update=!!f.update}else u.attribute_permissions=null}}i.role=i.id=s,await kre(i)}}}async function kre(e){let t=Xe().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,zB.isEqual)(i,e)?void 0:(e.id=r.id,(0,zE.alterRole)(e))}return(0,zE.addRole)(e)}var zE,WB,zB,Hre,Fre,JB=be(()=>{De();zE=M(F_()),WB=require("yaml"),zB=require("lodash"),Hre=["super_user","cluster_user","structure_user"];a(jB,"start");a(kre,"ensureRole");Fre=jB});async function jE(e){let t=(0,ZB.pathToFileURL)(e).toString();if(Gre)return G_||(G_=qre(Vre)),(await(await G_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function qre(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),G_=new Compartment({console,Math,Date,fetch:$re,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,XB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:$r,tables:Jn,databases:qe})}};let n=await(0,QB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),G_}function $re(e,t){let r=typeof e=="string"||e.url;if(new URL(r).protocol!="https")throw new Error("Only https is allowed in fetch");return fetch(e,t)}function Vre(){return{Resource:$r,tables:Jn}}var QB,XB,ZB,Gre,G_,oO=be(()=>{Ea();De();QB=require("fs/promises"),XB=require("path"),ZB=require("url"),Gre=!1;a(jE,"secureImport");a(qre,"getCompartment");a($re,"secureOnlyFetch");a(Vre,"getGlobalVars")});var cO={};ve(cO,{handleFile:()=>Kre});async function Kre(e,t,r,n){let s=new Map,i=await jE(r);c(i.default)&&n.set((0,aO.dirname)(t),i.default),o(i,(0,aO.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var aO,eH=be(()=>{oO();aO=require("path");a(Kre,"handleFile")});var uO={};ve(uO,{start:()=>Yre});function Yre({resources:e}){e.set("login",lO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var lO,tH=be(()=>{Ea();a(Yre,"start");lO=class extends $r{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var W_={};ve(W_,{addAnalyticsListener:()=>Y_,calculateCPUUtilization:()=>TH,diffResourceUsage:()=>AH,recordAction:()=>sr,recordActionBinary:()=>Qn,setAnalyticsEnabled:()=>Wre});function Wre(e){hH=e}function zre(e,t){if(typeof e=="number"){let r=t.values,n=r.index++;if(n>=r.length){let s=r;t.values=r=new Float32Array(n*2),r.set(s),r.index=n+1}r[n]=e,t.total+=e}else if(typeof e=="boolean")e&&t.total++,t.count++;else if(typeof e=="function")t.count++;else throw new TypeError("Invalid metric value type "+typeof e)}function jre(e,t,r,n,s,i){let o={};if(typeof t=="number")o.total=t,o.values=new Float32Array(4),o.values.index=1,o.values[0]=t,o.total=t;else if(typeof t=="boolean")o.total=t?1:0,o.count=1;else if(typeof t=="function")o.count=1,o.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);o.description={metric:r,path:n,method:s,type:i},QE.set(e,o)}function sr(e,t,r,n,s){if(!hH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=QE.get(i);o?zre(e,o):jre(i,e,t,r,n,s),JE||Jre()}function Qn(e,t,r,n,s){sr(!!e,t,r,n,s)}function Y_(e){gH.push(e)}function Jre(){JE=performance.now(),setTimeout(async()=>{let e=performance.now()-JE;JE=0;let t=[],r={time:Date.now(),period:e,threadId:cl.threadId,metrics:t};for(let[s,i]of QE){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],f;for(let d of SH){let p=Math.floor(c*d),_=o[p-1];if(p>l){let h=p-l;if(_===f){let S=u[u.length-1];typeof S=="number"?u[u.length-1]={value:S,count:1+h}:S.count+=h}else u.push(h>1?{value:_,count:h}:_),f=_;l=p}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await RH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:cl.threadId,byThread:!0,...n});for(let s of gH)s(t);QE=new Map,cl.parentPort?cl.parentPort.postMessage({type:EH,report:r}):OH({report:r})},mH).unref()}function XE(e,t,r){let n={id:(0,V_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function TH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function AH(e,t){return{userCPUTime:t.userCPUTime/1e3-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime/1e3-(e?.systemCPUTime??0),minorPageFault:t.minorPageFault-(e?.minorPageFault??0),majorPageFault:t.majorPageFault-(e?.majorPageFault??0),fsRead:t.fsRead-(e?.fsRead??0),fsWrite:t.fsWrite-(e?.fsWrite??0),voluntaryContextSwitches:t.voluntaryContextSwitches-(e?.voluntaryContextSwitches??0),involuntaryContextSwitches:t.involuntaryContextSwitches-(e?.involuntaryContextSwitches??0)}}function Qre(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let o=`${t}.${s}`,c=i.getSize(),l={database:t,table:s,size:c};XE(e,"table-size",l),ll.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function rH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getAuditSize(),o=pH.default.statSync(s.primaryStore.env.path).size,c=Qre(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};XE(e,"database-size",u),ll.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){ll.warn?.("Error getting DB size metrics",s)}}function nH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getStorageStats(),o={database:r,...i};XE(e,"storage-volume",o),ll.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){ll.warn?.("Error getting DB volumne metrics",s)}}async function Xre(e,t=6e4){let r=fO(),n=yH(),s=new Promise(E=>{let T=performance.now();setImmediate(()=>{let b=performance.now();b-T>5e3&&ll.warn?.("Unusually high event queue latency on the main thread of "+Math.round(b-T)+"ms"),T=performance.now()}),n.primaryStore.prefetch([1],()=>{let b=performance.now();b-T>5e3&&ll.warn?.("Unusually high task queue latency on the main thread of "+Math.round(b-T)+"ms"),E(b-T)})}),i;for(let E of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(E.value?.time){i=E.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:E,value:T}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!T)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:b,threadId:v}=T;for(let F of b||[]){let{path:q,method:Y,type:Z,metric:se,count:Q,total:ne,distribution:J,threads:me,...ye}=F;Q||(Q=1);let Pe=se+(q?"-"+q:"");Y!==void 0&&(Pe+="-"+Y),Z!==void 0&&(Pe+="-"+Z);let he=c.get(Pe);if(he){if(he.threads){let dt=he.threads[v];if(dt)he=dt;else{he.threads[v]={...ye};continue}}he.count||(he.count=1);let Nt=he.count;for(let dt in ye){let br=ye[dt];typeof br=="number"&&(he[dt]=(he[dt]*Nt+br*Q)/(Nt+Q))}he.count+=Q,ne>=0&&(he.total+=ne,he.ratio=he.total/he.count)}else he={period:t,...F},delete he.distribution,c.set(Pe,he),he.byThread&&(he.threads=[],he.threads[v]={...ye},u.push(he));if(J){J=J.map(dt=>typeof dt=="number"?{value:dt,count:1}:dt);let Nt=l.get(Pe);Nt?Nt.push(...J):l.set(Pe,J)}}await RH()}for(let E of u){let{path:T,method:b,type:v,metric:F,count:q,total:Y,distribution:Z,threads:se,...Q}=E;se=se.filter(ne=>ne);for(let ne in Q){if(typeof E[ne]!="number")continue;let J=0;for(let me of se){let ye=me[ne];typeof ye=="number"&&(J+=ye)}E[ne]=J}E.count=se.length,delete E.threads,delete E.byThread}for(let[E,T]of l){let b=c.get(E);T.sort((dt,br)=>dt.value>br.value?1:-1);let v=b.count-1,F=[],q=0,Y=0,Z;for(let dt of SH){let br=v*dt;for(;q<br;)Z=T[Y++],q+=Z.count,Y===1&&q--;let hs=T[Y>1?Y-2:0];Z||(Z=T[0]),F.push(Z.value-(Z.value-hs.value)*(q-br)/Z.count)}let[se,Q,ne,J,me,ye,Pe,he,Nt]=F;Object.assign(b,{p1:se,p10:Q,p25:ne,median:J,p75:me,p90:ye,p95:Pe,p99:he,p999:Nt})}let d;for(let[E,T]of c)T.id=(0,V_.getNextMonotonicTime)(),T.time=f,n.primaryStore.put(T.id,T,{append:!0}).then(b=>{b||n.primaryStore.put(T.id,T)}),d=!0;let p=Date.now(),{idle:_,active:h}=performance.eventLoopUtilization();if(d||h*10>_){let E=(0,V_.getNextMonotonicTime)(),T={id:E,metric:"main-thread-utilization",idle:_-sH,active:h-iH,taskQueueLatency:await s,time:p,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(b=>{b||n.primaryStore.put(E,T)})}sH=_,iH=h;let S=process.resourceUsage(),g=AH(q_,S);g.time=p,g.period=q_.time?p-q_.time:t,g.cpuUtilization=TH(q_,g.period),XE(n,"resource-usage",g),q_=g;let R=Xe();rH(n,R),rH(n,{system:R.system}),nH(n,R),nH(n,{system:R.system})}async function oH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function fO(){return aH||(aH=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function yH(){return cH||(cH=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function tne(){bH=!0;let e=(0,K_.get)(x.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Xre(mH,e),await oH(fO(),Zre),await oH(yH(),ene)},Math.min(e/2,2147483647)).unref()}function OH(e,t){let r=e.report;r.threadId=t?.threadId||cl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(lH+=n.mean*n.count);r.totalBytesProcessed=lH,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(uH.get(t))}),uH.set(t,t.performance.eventLoopUtilization())),r.id=(0,V_.getNextMonotonicTime)(),fO().primaryStore.put(r.id,r),bH||tne(),rne&&(NH=sne(r))}async function sne(e){if(await NH,!Ca){let r=(0,$_.dirname)((0,fH.getLogFilePath)());try{Ca=await(0,dO.open)((0,$_.join)(r,"analytics.log"),"r+")}catch{Ca=await(0,dO.open)((0,$_.join)(r,"analytics.log"),"w+")}}let t=(await Ca.stat()).size;if(t>nne){let r=Buffer.alloc(t);await Ca.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Ca.write(r,{position:0}),await Ca.truncate(r.length),t=r.length}await Ca.write(JSON.stringify(e)+`
|
|
21
|
+
`,t)}var cl,dH,fH,_H,$_,dO,V_,K_,pH,ll,QE,hH,JE,mH,EH,gH,SH,sH,iH,q_,RH,Zre,ene,aH,cH,bH,lH,uH,rne,NH,Ca,nne,ki=be(()=>{cl=require("worker_threads"),dH=M(rt());De();fH=M(z()),_H=M(Ni()),$_=require("path"),dO=require("fs/promises"),V_=M(_n()),K_=M(ae());H();Vr();pH=M(require("node:fs")),ll=(0,_H.loggerWithTag)("analytics");(0,K_.initSync)();QE=new Map,hH=(0,K_.get)(x.ANALYTICS_AGGREGATEPERIOD)>-1;a(Wre,"setAnalyticsEnabled");a(zre,"recordExistingAction");a(jre,"recordNewAction");a(sr,"recordAction");We.recordAnalytics=sr;a(Qn,"recordActionBinary");JE=0,mH=1e3,EH="analytics-report",gH=[];a(Y_,"addAnalyticsListener");SH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Jre,"sendAnalytics");a(XE,"storeMetric");a(TH,"calculateCPUUtilization");a(AH,"diffResourceUsage");a(Qre,"storeTableSizeMetrics");a(rH,"storeDBSizeMetrics");a(nH,"storeVolumeMetrics");a(Xre,"aggregation");sH=0,iH=0,q_={},RH=a(()=>new Promise(setImmediate),"rest");a(oH,"cleanup");Zre=36e5,ene=31536e6;a(fO,"getRawAnalyticsTable");a(yH,"getAnalyticsTable");(0,dH.setChildListenerByType)(EH,OH);a(tne,"startScheduledTasks");lH=0,uH=new Map,rne=!1;a(OH,"recordAnalytics");nne=1e6;a(sne,"logAnalytics")});var wH={};ve(wH,{Headers:()=>yo,appendHeader:()=>ZE,mergeHeaders:()=>_O});function ZE(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function _O(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new yo(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var yo,z_=be(()=>{yo=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(ZE,"appendHeader");a(_O,"mergeHeaders")});function LH(e){let t={openapi:ine,info:{title:"HarperDB HTTP REST interface",version:DH.packageJson.version},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},f=[];if(o)for(let{type:T,name:b,elements:v,relationship:F,definition:q}of o){if(F)T==="array"?u[b]={type:"array",items:{$ref:Pa+v.type}}:u[b]={$ref:Pa+T};else{let Y=q??v?.definition;if(Y){if(!t.components.schemas[Y.type]){let Z={};Y.properties.forEach(se=>{Z[se.name]=new EO(pO[se.type],se.type)}),t.components.schemas[Y.type]=new PH(Z)}T==="array"?u[b]={type:"array",items:{$ref:Pa+Y.type}}:u[b]={$ref:Pa+Y.type}}else T==="array"?v.type==="Any"||v.type=="ID"?u[b]={type:"array",items:{format:v.type}}:u[b]={type:"array",items:new EO(pO[v.type],v.type)}:T==="Any"||T=="ID"?u[b]={format:T}:u[b]=new EO(pO[T],T)}f.push(new gO(b,"query",u[b]))}let d=Object.keys(u),p=new gO(c,"path",{format:"ID"});p.required=!0,p.description="primary key of record";let _=new gO("property","path",{enum:d});_.required=!0,t.components.schemas[i]=new PH(u);let h=l.post!==Resource.prototype.post||l.update,S=typeof l.put=="function",g=typeof l.get=="function",R=typeof l.delete=="function",E="/"+s+"/";h&&(t.paths[E]={},t.paths[E].post=new one(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new hO(f,r,{200:new mO({$ref:Pa+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new CH(f,r,"delete all the records that match the provided query",{204:new IH})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new hO([p],r,{200:new mO({$ref:Pa+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new ane([p],r,i,"create or update the record with the URL path that maps to the record's primary key")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new CH([p],r,"delete a record with the given primary key",{204:new IH})),g&&_.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new hO([p,_],r,{200:new mO({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function one(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Pa+e}}}},this.security=t,this.responses={200:{description:SO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function hO(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function mO(e){this.description=SO,this.content={"application/json":{schema:e}}}function IH(){this.description="successfully processed request, no content returned to client"}function ane(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Pa+r}}}},this.responses={200:{description:SO}}}function CH(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function PH(e){this.type="object",this.properties=e}function EO(e,t){this.type=e,this.format=t}function gO(e,t,r){this.name=e,this.in=t,this.schema=r}var DH,ine,pO,Pa,SO,MH=be(()=>{DH=M(it()),ine="3.0.3",pO={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Pa="#/components/schemas/",SO="successful operation";a(LH,"generateJsonApi");a(one,"Post");a(hO,"Get");a(mO,"Response200");a(IH,"Response204");a(ane,"Put");a(CH,"Delete");a(PH,"ResourceSchema");a(EO,"Type");a(gO,"Parameter")});var tg={};ve(tg,{parseHeaderValue:()=>AO,start:()=>une});async function lne(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&Om(e);let i=new yo;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==vH){let g=eg.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Cc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=AO(g);for(let E of R)switch(E.name){case"max-age":e.expiresAt=E.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let g=AO(u).map(R=>(R.next?.name==="confirm"&&R.next.value>=0&&(e.replicatedConfirmation=+R.next.value),R.name));e.replicateTo=g.length===1&&+g[0]>=0?+g[0]:g[0]==="*"?void 0:g}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let d=await wt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=uo(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Yu.ClientError(g,400)}if(e.authorize=!0,o===vH&&s==="GET"){if(e?.user?.role?.permission?.super_user)return LH(eg);throw new Yu.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new Yu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Yu.ServerError(`Method ${s} is not recognized`,501)}}),p=200,_;if(d==null)p=s==="GET"||s==="HEAD"?404:204,TO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=_O(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Jf(d.data,e,d)),d}else if(_=e.lastModified){cne[0]=_;let g=String.fromCharCode(34,(Mr[0]&63)+62,(Mr[0]>>6)+(Mr[1]<<2&63)+62,(Mr[1]>>4)+(Mr[2]<<4&63)+62,(Mr[2]>>2)+62,(Mr[3]&63)+62,(Mr[3]>>6)+(Mr[4]<<2&63)+62,(Mr[4]>>4)+(Mr[5]<<4&63)+62,(Mr[5]>>2)+62,(Mr[6]&63)+62,(Mr[6]>>6)+(Mr[7]<<2&63)+62,34),R=r["if-none-match"];R&&g==R?(d?.onDone&&d.onDone(),p=304,d=void 0):i.setIfNone("ETag",g),TO.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}e.createdResource&&(p=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:p,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(h.wasCacheMiss=S,!S&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),d!==void 0&&(h.body=Jf(d,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Fi.warn(o):Fi.info(o):Fi.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Jf(o.contentType?o:o.toString(),e,c),c}}function une(e){TO=e,!UH&&(UH=!0,eg=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return lne(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{j_++;let s=new Bn;xH||(xH=!0,Y_(l=>{j_>0&&l.push({metric:"ws-connections",connections:j_,byThread:!0})}));let i;t.on("error",l=>{i=!0,Fi.warn(l)});let o;t.on("message",a(function(u){o||(o=uo(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);sr(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{j_--,Qn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=eg.getMatch(l,"ws");if(Qn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,sr(h=>({count:h.count,total:j_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new Cc(u.relativeURL),d=u.Resource;c=(await wt(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let h=await Aa(_.value,r);t.send(h),sr(h.length,"bytes-sent",r.handlerPath,"message","ws"),t._socket.writableNeedDrain&&await new Promise(S=>t._socket.once("drain",S))}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Fi.warn(l):Fi.info(l):Fi.error(l),t.close(dne[l.statusCode]||1011,l.toString())}t.close()},e))}function AO(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var Fi,Yu,Mr,cne,TO,vH,UH,eg,xH,j_,dne,BH=be(()=>{ao();ki();Fi=M(z()),Yu=M(pe());Gf();pu();Ic();z_();MH();Gf();Mr=new Uint8Array(8),cne=new Float64Array(Mr.buffer,0,1),TO={},vH="openapi";a(lne,"http");j_=0;a(une,"start");dne={401:3e3,403:3003};a(AO,"parseHeaderValue")});var RO=w((qCe,kH)=>{var{recordAction:rg,recordActionBinary:HH}=(ki(),C(W_)),fne=require("fastify-plugin"),_ne=200;kH.exports=fne(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,f,d;l.config?.isOperation?(u=n.body?.operation,f="operation"):(u=l.url,f="fastify-route",d=l.method),rg(o,"duration",u,d,f),HH(s.raw.statusCode<400,"success",u,d,f),HH(1,"response_"+s.raw.statusCode,u,d,f);let p=_ne;i?.pipe?(i.on("data",g=>{p+=g.length}),i.on("end",()=>{rg(performance.now()-c,"transfer",u,d,f),rg(p,"bytes-sent",u,d,f)})):(p+=i?.length||0,rg(p,"bytes-sent",u,d,f));let _=o.toFixed(3),h=s.getHeader("Server-Timing"),S=`db;dur=${_}`;s.header("Server-Timing",h?`${h}, ${S}`:S)}),r()},{name:"hdb-request-time"})});var GH=w(($Ce,FH)=>{var pne=ot(),hne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};FH.exports=function(e){return pne.validateObject(e,hne)}});var ng=w((VCe,qH)=>{"use strict";var mne=(H(),C(G)).OPERATIONS_ENUM,yO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=mne.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};qH.exports=yO});var X_={};ve(X_,{createTokens:()=>gne,getJWTRSAKeys:()=>cg,refreshOperationToken:()=>Sne,validateOperationToken:()=>NO,validateRefreshToken:()=>lg});async function cg(){if(sg)return sg;try{let e=J_.default.join(Q_.default.getHdbBasePath(),zA),t=await ig.default.readFile(J_.default.join(e,Of.JWT_PASSPHRASE_NAME),"utf8"),r=await ig.default.readFile(J_.default.join(e,Of.JWT_PRIVATE_KEY_NAME),"utf8");return sg={publicKey:await ig.default.readFile(J_.default.join(e,Of.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},sg}catch(e){throw ag.default.error(e),new ii.ClientError(zu.NO_ENCRYPTION_KEYS,Wu.INTERNAL_SERVER_ERROR)}}async function gne(e){let t=(0,bO.validateBySchema)(e,Gi.default.object({username:Gi.default.string().optional(),password:Gi.default.string().optional(),role:Gi.default.string().optional(),expires_in:Gi.default.alternatives(Gi.default.string(),Gi.default.number()).optional()}));if(t)throw new ii.ClientError(t.message);let r;try{let d=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,d=!1),r=await(0,OO.findAndValidateUser)(e.username,e.password,d)}catch(d){throw ag.default.error(d),new ii.ClientError(zu.INVALID_CREDENTIALS,Wu.UNAUTHORIZED)}if(!r)throw new ii.ClientError(zu.INVALID_CREDENTIALS,Wu.UNAUTHORIZED);let n=!1,s=!1;r.role?.permission&&(n=r.role.permission.super_user===!0,s=r.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s};e.role&&(i.role=e.role);let o=await cg(),c=await ju.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??WH,algorithm:og,subject:"operation"}),l=await ju.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:Ene,algorithm:og,subject:"refresh"}),u=Fy(l,"sha256");if((await(0,$H.update)(new VH.default(bf,fu.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new ii.ClientError(zu.REFRESH_TOKEN_SAVE_FAILED,Wu.INTERNAL_SERVER_ERROR);return KH.default.signalUserChange(new YH.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function Sne(e){let t=(0,bO.validateBySchema)(e,Gi.default.object({refresh_token:Gi.default.string().required()}).required());if(t)throw new ii.ClientError(t.message);let{refresh_token:r}=e;await lg(r);let n=await cg(),s=await ju.default.decode(r);return{operation_token:await ju.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:WH,algorithm:og,subject:"operation"})}}async function NO(e){return zH(e,"operation")}async function lg(e){return zH(e,"refresh")}async function zH(e,t){try{let r=await cg(),n=await ju.default.verify(e,r.publicKey,{algorithms:og,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,OO.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!Gy(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw ag.default.warn(r),r?.name==="TokenExpiredError"?new ii.ClientError(zu.TOKEN_EXPIRED,Wu.FORBIDDEN):new ii.ClientError(zu.INVALID_TOKEN,Wu.UNAUTHORIZED)}}var ju,ig,J_,Gi,bO,ii,ag,OO,$H,VH,KH,YH,Q_,Wu,zu,WH,Ene,og,sg,Ju=be(()=>{ju=M(require("jsonwebtoken")),ig=M(require("fs-extra")),J_=M(require("node:path")),Gi=M(require("joi")),bO=M(ot());H();ii=M(pe()),ag=M(z());hE();OO=M(Rn()),$H=M(yn()),VH=M(ng()),KH=M(To()),YH=M(ri()),Q_=M(ae()),{HTTP_STATUS_CODES:Wu,AUTHENTICATION_ERROR_MSGS:zu}=ii.hdb_errors;Q_.default.initSync();WH=Q_.default.get(x.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Ene=Q_.default.get(x.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",og="RS256";a(cg,"getJWTRSAKeys");a(gne,"createTokens");a(Sne,"refreshOperationToken");a(NO,"validateOperationToken");a(lg,"validateRefreshToken");a(zH,"validateToken")});var wO=w((jCe,QH)=>{"use strict";var Tne=GH(),Qu=require("passport"),Ane=require("passport-local").Strategy,Rne=require("passport-http").BasicStrategy,yne=require("util"),bne=Rn(),JH=yne.callbackify(bne.findAndValidateUser),zCe=xn(),One=(H(),C(G)),jH=(Ju(),C(X_));Qu.use(new Ane(function(e,t,r){JH(e,t,r)}));Qu.use(new Rne(function(e,t,r){JH(e,t,r)}));Qu.serializeUser(function(e,t){t(null,e)});Qu.deserializeUser(function(e,t){t(null,e)});function Nne(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":Qu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===One.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?jH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):jH.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Qu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Nne,"authorize");function wne(e,t){let r=Tne(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(wne,"checkPermissions");QH.exports={authorize:Nne,checkPermissions:wne}});var ug=w((QCe,XH)=>{"use strict";var Ine=Vn();XH.exports={writeTransaction:Cne};function Cne(e,t,r){return Ine.writeTransaction(e,t,r)}a(Cne,"writeTransaction")});var rk=w((ePe,tk)=>{"use strict";var Pne=Yr(),Dne=As(),ZH=z(),Lne=yn(),ZCe=ug(),Mne=require("clone"),CO=require("alasql"),vne=aE(),ek=require("util"),Une=ek.promisify(Dne.getTableSchema),xne=ek.promisify(Pne.search),Bne=(H(),C(G)),IO=ie();vne(CO);tk.exports={update:kne};var Hne="There was a problem performing this update. Please check the logs and try again.";async function kne({statement:e,hdb_user:t}){let r=await Une(e.table.databaseid,e.table.tableid),n=Fne(e.columns);IO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=Mne(s),c=IO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=CO.parse(l).statements[0],f=await xne(u),d=Gne(n,f);return qne(o,d,t)}a(kne,"update");function Fne(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=CO.compile(`SELECT ${r.expression.toString()} AS [${Bne.FUNC_VAL}] FROM ?`)}),t}catch(t){throw ZH.error(t),new Error(Hne)}}a(Fne,"createUpdateRecord");function Gne(e,t){return IO.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(Gne,"buildUpdateRecords");async function qne(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await Lne.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){ZH.error(`Error delete new_attributes from update response: ${i}`)}return s}a(qne,"updateRecords")});var sk=w((sPe,nk)=>{var $ne=require("alasql"),Vne=Yr(),Kne=z(),Yne=Vn(),DO=require("util"),PO=ie(),Wne=(H(),C(G)),zne=As(),rPe=ug(),nPe=yn(),jne="record",Jne="successfully deleted",Qne=DO.callbackify(tse),Xne=DO.promisify(Vne.search),Zne=DO.promisify(zne.getTableSchema);nk.exports={convertDelete:Qne};function ese(e){return`${e.deleted_hashes.length} ${jne}${e.deleted_hashes.length===1?"":"s"} ${Jne}`}a(ese,"generateReturnMessage");async function tse({statement:e,hdb_user:t}){let r=await Zne(e.table.databaseid,e.table.tableid);PO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=PO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=$ne.parse(o).statements[0],l={operation:Wne.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Xne(c);let u=await Yne.deleteRecords(l);return PO.isEmptyOrZeroLength(u.message)&&(u.message=ese(u)),delete u.txn_time,u}catch(u){throw Kne.error(u),u.hdb_code?u.message:u}}a(tse,"convertDelete")});var lk=w((oPe,ck)=>{"use strict";var rse=go(),{hdb_errors:ik}=pe(),{getDatabases:ok}=(De(),C(nt));ck.exports={checkSchemaExists:ak,checkSchemaTableExists:nse,schema_describe:rse};async function ak(e){if(!ok()[e])return ik.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(ak,"checkSchemaExists");async function nse(e,t){let r=await ak(e);if(r)return r;if(!ok()[e][t])return ik.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(nse,"checkSchemaTableExists")});var xO=w((dPe,Ak)=>{"use strict";var{decode:sse}=require("msgpackr"),{isMainThread:cPe,parentPort:lPe,threadId:uPe}=require("worker_threads"),_g=ir(),Xu=Tt(),vO=(H(),C(G)),Jr=z(),MO=ae(),ise=(H(),C(G)),{onMessageByType:ose}=rt(),_k=Eo(),{recordAction:uk,recordActionBinary:ase}=(ki(),C(W_)),{publishToStream:cse}=_g,{ConsumerEvents:dk}=require("nats"),lse=Yr(),{promisify:use}=require("util"),{decodeBlobsWithWrites:dse}=(gs(),C(Gm)),pk=use(setTimeout),pg=1e4,hg,fg,fse,_se,hk,Z_=new Map,Zu=new Map;Ak.exports={initialize:mk,ingestConsumer:UO,setSubscription:pse,setIgnoreOrigin:Ese,getDatabaseSubscriptions:mse,updateConsumer:Ek};async function mk(){ose(vO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await Ek(n)}),hk=!0,Jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await _g.getNATSReferences();hg=e,fg=e.info.server_name,fse=t,_se=r}a(mk,"initialize");async function Ek(e){if(e.status==="start"){let{js:t,jsm:r}=await gk(e.node_domain_name);UO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=Z_.get(e.stream_name+e.node_domain_name);t&&(Jr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),Z_.set(e.stream_name+e.node_domain_name,"close")),Zu.get(e.node_domain_name)==="failed"&&Zu.set(e.node_domain_name,"close")}}a(Ek,"updateConsumer");var mg=new Map;function pse(e,t,r){let n=mg.get(e);n||mg.set(e,n=new Map),n.set(t,r),hk||mk().then(hse)}a(pse,"setSubscription");async function hse(){let e=await lse.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Xu.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await gk(r),!n))break;let{schema:o,table:c}=i,l=_k.createNatsTableStreamName(o,c);UO(l,n,s,r)}}}a(hse,"accessConsumers");async function gk(e){let t,r,n=1;for(;!r;)try{t=await hg.jetstream({domain:e}),r=await hg.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Zu.get(e)==="close")break;Zu.set(e,"failed"),n%10===1&&Jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<pg?n++*100:pg;await pk(i)}return{js:t,jsm:r}}a(gk,"connectToRemoteJS");function mse(){return mg}a(mse,"getDatabaseSubscriptions");var Sk;function Ese(e){Sk=e}a(Ese,"setIgnoreOrigin");var Tk=100,fk=new Array(Tk),dg=0;async function UO(e,t,r,n){let{connection:s}=await _g.getNATSReferences();hg=s,fg=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,fg),Jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Zu.get(n)==="close")break;o%10===1&&Jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(Jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await _g.createConsumer(r,e,fg,new Date(Date.now()).toISOString()));let f=o++*100<pg?o++*100:pg;await pk(f)}let c=!1,l;for(;!c;){if(Z_.get(e+n)==="close"||Zu.get(n)==="close"){Z_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:MO.get(vO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),Z_.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===dk.ConsumerDeleted&&(await l.close(),c=!0),f.type===dk.HeartbeatsMissed){let d=f.data;Jr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(Jr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let f of l)await fk[dg],fk[dg]=gse(f).catch(d=>{Jr.error(d)}),++dg>=Tk&&(dg=0)}catch(f){f.message==="consumer deleted"?(Jr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):Jr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(UO,"ingestConsumer");async function gse(e){let t;await dse(()=>{t=sse(e.data)}),uk(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),Jr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=MO.get(vO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Xu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Xu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Xu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!Sk),ase(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Xu.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:f,hash_values:d,__origin:p,expiresAt:_}=t;Jr.trace("processing message:",o,c,u,(f?"records: "+f.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Jr.trace(`messageProcessor nats msg id: ${e.headers.get(Xu.MSG_HEADERS.NATS_MSG_ID)}`);let h;f||(f=d);let S=new Promise(v=>h=v),{timestamp:g,user:R,node_name:E}=p||{},T=mg.get(c)?.get(u);if(!T)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,T.send(t);else if(f.length===1&&!l)T.send({type:LO(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:h,user:R,nodeName:E});else{let v=f.map((F,q)=>({type:LO(o),value:F,expiresAt:_,id:d?.[q],table:u}));for(;l;)v.push({type:LO(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;T.send({type:"transaction",writes:v,table:u,timestamp:g,onCommit:h,user:R,nodeName:E})}MO.get(ise.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&cse(e.subject.split(".").slice(0,-1).join("."),_k.createNatsTableStreamName(c,u),e.headers,e.data),await S;let b=Date.now()-g;g&&uk(b,"replication-latency",e.subject,o,"ingest")}catch(o){Jr.error(o)}e.ack()}a(gse,"messageProcessor");function LO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(LO,"convertOperation")});var ir=w((gPe,Hk)=>{"use strict";var wr=ae();wr.initSync();var Sse=require("fs-extra"),Tse=require("semver"),rp=require("path"),{monotonicFactory:Ase}=require("ulidx"),yk=Ase(),Rse=require("util"),bk=require("child_process"),yse=Rse.promisify(bk.exec),bse=bk.spawn,vr=Tt(),$e=(H(),C(G)),{packageJson:Ose,PACKAGE_ROOT:Nse}=it(),Eg=ie(),oi=z(),gg=Eo(),wse=ug(),ep=yt(),{broadcast:Ise,onMessageByType:Cse,getWorkerIndex:Pse}=rt(),{isMainThread:Ok}=require("worker_threads"),{Encoder:Dse,decode:FO}=require("msgpackr"),Nk=new Dse,{isEmpty:_l}=Eg,wk=Rn(),_Pe=48*36e11;Ok&&Cse($e.ITC_EVENT_TYPES.RESTART,()=>{Qr=void 0,fl=void 0});var{connect:Lse,StorageType:Mse,RetentionPolicy:vse,AckPolicy:GO,DeliverPolicy:qO,DiscardPolicy:Use,NatsConnection:pPe,JetStreamManager:hPe,JetStreamClient:mPe,StringCodec:EPe,JSONCodec:xse,createInbox:$O,headers:Bse,ErrorCode:Rk}=require("nats"),{recordAction:Hse}=(ki(),C(W_)),{encodeBlobsAsBuffers:kse}=(gs(),C(Gm)),Ik=xse(),Fse="clustering",Gse=Ose.engines[vr.NATS_SERVER_NAME],qse=rp.join(Nse,"dependencies"),kO=rp.join(qse,`${process.platform}-${process.arch}`,vr.NATS_BINARY_NAME),BO,HO,tp,ul,dl;Hk.exports={runCommand:Ck,checkNATSServerInstalled:$se,createConnection:VO,getConnection:np,getJetStreamManager:sp,getJetStream:Dk,getNATSReferences:qi,getServerList:Kse,createLocalStream:KO,listStreams:Lk,deleteLocalStream:Yse,getServerConfig:ed,listRemoteStreams:Wse,viewStream:zse,viewStreamIterator:jse,publishToStream:Jse,request:Zse,reloadNATS:YO,reloadNATSHub:eie,reloadNATSLeaf:tie,extractServerName:Xse,requestErrorHandler:rie,createLocalTableStream:xk,createTableStreams:iie,purgeTableStream:Bk,purgeSchemaTableStreams:oie,getStreamInfo:aie,updateLocalStreams:lie,closeConnection:Vse,getJsmServerName:Sg,addNatsMsgHeader:Mk,clearClientCache:Pk,updateRemoteConsumer:nie,createConsumer:vk,updateConsumerIterator:sie};async function Ck(e,t=void 0){let{stdout:r,stderr:n}=await yse(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
22
22
|
`,""));return r.replace(`
|
|
23
|
-
`,"")}a(Ik,"runCommand");async function zse(){try{await bse.access(BO)}catch{return!1}let e=await Ik(`${BO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Ose.eq(t,Yse)}a(zse,"checkNATSServerInstalled");async function qO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await Nk.getClusterUser();if(ll(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}ai.trace("create nats connection called");let i=await Bse({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Nr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Nr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Nr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),ai.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&ai.error("Error with Nats client connection, connection closed",o),i===Jr&&Ck()}),i}a(qO,"createConnection");function Ck(){Jr=void 0,ol=void 0,al=void 0,cl=void 0}a(Ck,"clearClientCache");async function jse(){Jr&&(await Jr.drain(),Jr=void 0,ol=void 0,al=void 0,cl=void 0)}a(jse,"closeConnection");var Jr,cl;async function ip(){return cl||(cl=qO(Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Jr=await cl),Jr||cl}a(ip,"getConnection");async function op(){if(ol)return ol;ll(Jr)&&await ip();let{domain:e}=Xu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ol=await Jr.jetstreamManager({domain:e,timeout:6e4}),ol}a(op,"getJetStreamManager");async function Pk(){if(al)return al;ll(Jr)&&await ip();let{domain:e}=Xu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return al=Jr.jetstream({domain:e,timeout:6e4}),al}a(Pk,"getJetStream");async function Ki(){let e=Jr||await ip(),t=ol||await op(),r=al||await Pk();return{connection:e,jsm:t,js:r}}a(Ki,"getNATSReferences");async function Qse(e){let t=Nr.get($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await Nk.getClusterUser(),s=await qO(t,r,n),i=GO(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=wk.decode(f.data);d.response_time=Date.now()-l,c.push(d)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Eg.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Qse,"getServerList");async function $O(e,t){let{jsm:r}=await Ki(),n=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Hse.File,retention:kse.Limits,subjects:t,discard:Fse.Old,max_msgs:s,max_bytes:i,max_age:n})}a($O,"createLocalStream");async function Dk(){let{jsm:e}=await Ki(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Dk,"listStreams");async function Jse(e){let{jsm:t}=await Ki();await t.streams.delete(e)}a(Jse,"deleteLocalStream");async function Xse(e){let{connection:t}=await Ki(),r=[],n=GO(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(wk.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(Xse,"listRemoteStreams");async function Zse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ki(),i=Rk(),o={durable_name:i,ack_policy:kO.Explicit};t&&(o.deliver_policy=FO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let f of l){let d=HO(f.data),p={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(p.origin=f.headers.get(Mr.MSG_HEADERS.ORIGIN)),u.push(p),f.ack(),f.info.pending===0)break}return await c.delete(),u}a(Zse,"viewStream");async function*eie(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ki(),i=Rk(),o={durable_name:i,ack_policy:kO.Explicit};t&&(o.deliver_policy=FO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let f=HO(u.data);f[0]||(f=[f]);for(let d of f){let p={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(p.origin=u.headers.get(Mr.MSG_HEADERS.ORIGIN)),yield p}if(u.ack(),u.info.pending===0)break}await c.delete()}a(eie,"viewStreamIterator");async function tie(e,t,r,n){ai.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Lk(n,r);let{js:s}=await Ki(),i=await Sg(),o=`${e}.${i}`,c=await Vse(()=>n instanceof Uint8Array?n:Ok.encode(n));try{ai.trace(`publishToStream publishing to subject: ${o}`),$se(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return vk(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){ai.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await $O(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(tie,"publishToStream");function Lk(e,t){t===void 0&&(t=qse());let r=Nr.get($e.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Mr.MSG_HEADERS.ORIGIN)&&r&&t.append(Mr.MSG_HEADERS.ORIGIN,r),t}a(Lk,"addNatsMsgHeader");function Xu(e){e=e.toLowerCase();let t=sp.join(Nr.get($e.CONFIG_PARAMS.ROOTPATH),Kse);if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return ll(xO)&&(xO={port:rp.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:rp.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.HUB,config_file:Mr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:sp.join(t,Mr.PID_FILES.HUB),hdb_nats_path:t}),xO;if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return ll(UO)&&(UO={port:rp.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:rp.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.LEAF,config_file:Mr.NATS_CONFIG_FILES.LEAF_SERVER,domain:rp.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.LEAF,pid_file_path:sp.join(t,Mr.PID_FILES.LEAF),hdb_nats_path:t}),UO;ai.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Xu,"getServerConfig");async function Mk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:kO.Explicit,durable_name:r,deliver_policy:FO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(Mk,"createConsumer");async function rie(e,t,r){await e.consumers.delete(t,r)}a(rie,"removeConsumer");function nie(e){return e.split(".")[1]}a(nie,"extractServerName");async function sie(e,t,r=6e4,n=GO()){if(!Eg.isObject(t))throw new Error("data param must be an object");let s=Ok.encode(t),{connection:i}=await Ki(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return HO(c.data)}a(sie,"request");function VO(e){return new Promise(async(t,r)=>{let n=Cse(BO,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(VO,"reloadNATS");async function iie(){let{pid_file_path:e}=Xu($e.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await VO(e)}a(iie,"reloadNATSHub");async function oie(){let{pid_file_path:e}=Xu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await VO(e)}a(oie,"reloadNATSLeaf");function aie(e,t,r){let n;switch(e.code){case Ak.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case Ak.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(aie,"requestErrorHandler");async function cie(e,t){let r=t+Mr.SERVER_SUFFIX.LEAF,{connection:n}=await Ki(),{jsm:s}=await mie(r),{schema:i,table:o}=e,c=gg.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await vk(async()=>{if(e.subscribe===!0)await Mk(s,c,n.info.server_name,l);else try{await rie(s,c,n.info.server_name)}catch(u){ai.trace(u)}})}a(cie,"updateRemoteConsumer");async function lie(e,t,r,n){let s=gg.createNatsTableStreamName(e,t),i=r+Mr.SERVER_SUFFIX.LEAF,o={type:$e.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!bk&&Use()<Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=vO();await c(o)}await Mse(o),n==="stop"&&await Eg.async_set_timeout(1e3)}a(lie,"updateConsumerIterator");function vk(e){return Lse.writeTransaction($e.SYSTEM_SCHEMA_NAME,$e.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(vk,"exclusiveLock");async function Uk(e,t){let r=gg.createNatsTableStreamName(e,t),n=await Sg(),s=_ie(e,t,n);await $O(r,[s])}a(Uk,"createLocalTableStream");async function uie(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await Uk(n,s)}}a(uie,"createTableStreams");async function xk(e,t,r=void 0){if(Nr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=gg.createNatsTableStreamName(e,t),{domain:s}=Xu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await ip()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")ai.warn(n);else throw n}}a(xk,"purgeTableStream");async function die(e,t){if(Nr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await xk(e,t[r])}a(die,"purgeSchemaTableStreams");async function fie(e){return(await op()).streams.info(e)}a(fie,"getStreamInfo");function _ie(e,t,r){return`${Mr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(_ie,"createSubjectName");async function Sg(){if(np)return np;if(np=(await op())?.nc?.info?.server_name,np===void 0)throw new Error("Unable to get jetstream manager server name");return np}a(Sg,"getJsmServerName");async function pie(){let e=await op(),t=await Sg(),r=await Dk();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=hie(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let f=u.join(".");ai.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(pie,"updateLocalStreams");function hie(e){let{config:t}=e,r=!1,n=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(hie,"updateStreamLimits");async function mie(e){let t,r;try{t=await Jr.jetstream({domain:e}),r=await Jr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw ai.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(mie,"connectToRemoteJS")});function KO(e){let t=e.get(Tg),r=t?(0,Zu.unpack)(t):null;r||(r={remoteNameToId:{}});let n=Xe(),s=!1;r.nodeName=Xe();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:cp(e)??1,nodes:[]})})}i[n]=0,e.putSync(Tg,(0,Zu.pack)(r))}return r}function ap(e){return KO(e).remoteNameToId}function kk(e,t){let r=KO(t),n=r.remoteNameToId,s=new Map,i=!1;for(let o in e){let c=e[o],l=n[o];if(l==null){let u=0;for(let f in n){let d=n[f];d>u&&(u=d)}l=u+1,n[o]=l,i=!0}s.set(c,l)}return i&&t.putSync(Tg,(0,Zu.pack)(r)),s}function Ag(e,t){let r=KO(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Tg,(0,Zu.pack)(r))}return Hk.trace?.("The remote node name map",e,n,s),s}var Hk,Zu,Tg,YO=be(()=>{Hk=M(Ii());es();Zu=require("msgpackr"),Tg=Symbol.for("remote-ids");a(KO,"getIdMappingRecord");a(ap,"exportIdMapping");a(kk,"remoteToLocalNodeId");a(Ag,"getIdOfRemoteNode")});var WO={};ve(WO,{commits_awaiting_replication:()=>td,getHDBNodeTable:()=>ar,getReplicationSharedStatus:()=>Rg,iterateRoutes:()=>up,shouldReplicateToNode:()=>lp,subscribeToNodeUpdates:()=>rd});function ar(){return Fk||(Fk=dt({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Rg(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function rd(e){ar().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;Vk.debug?.("adding node",n,"on node",Xe()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==Xe()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of ar().search({}))if(i.shard!=null){let o=s.get(i.shard);o||s.set(i.shard,o=[]),o.push(i)}server.shards=s,(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function lp(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&ar().primaryStore.get(Xe())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function Eie(){rd(e=>{La({},(t,r)=>{let n=e.name,s=Gk.get(n);if(s||Gk.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=Rg(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of td.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*up(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=ed.default.get(B.REPLICATION_SECUREPORT)??(!ed.default.get(B.REPLICATION_PORT)&&ed.default.get(B.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||ed.default.get(B.REPLICATION_PORT)||ed.default.get(B.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){qk.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime,revoked_certificates:t.revokedCertificates,shard:t.shard}}}var qk,$k,ed,Vk,Fk,Gk,td,ul=be(()=>{Pe();es();Am();qk=require("worker_threads"),$k=M(pe()),ed=M(ae());H();Vk=M(Ii());server.nodes=[];a(ar,"getHDBNodeTable");a(Rg,"getReplicationSharedStatus");a(rd,"subscribeToNodeUpdates");a(lp,"shouldReplicateToNode");Gk=new Map;SL((e,t,r)=>{if(r>server.nodes.length)throw new $k.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);td||(td=new Map,Eie());let n=td.get(e);return n||(n=[],td.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(Eie,"startSubscriptionToReplications");a(up,"iterateRoutes")});var zk={};ve(zk,{connectedToNode:()=>dl,disconnectedFromNode:()=>id,ensureNode:()=>Io,requestClusterStatus:()=>Wk,startOnMainThread:()=>jO});async function jO(e){let t=0,r=Je();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){yg.set(i,cp(l.auditStore));break}}}Yi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of up(e))try{let c=!o.subscriptions;if(c){let u=Xe();ar().primaryStore.get(u)===void 0&&await Io(u,{name:u,url:e.url??Ma(),replicates:!0})}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}rd(s)});let n;function s(i,o=i?.name){let c=Xe()&&o===Xe()||Ma()&&i?.url===Ma();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let p of ar().search([]))p.replicates&&p.name!==o&&s(p,p.name);n=d}if(ot.trace("Setting up node replication for",i),!i){for(let[d,p]of wo){let _;for(let[h,{worker:S,nodes:g}]of p){let R=g[0];if(R&&R.name==o){_=!0;for(let[E,{worker:A}]of p)p.delete(E),ot.warn("Node was deleted, unsubscribing from node",o,E,d),A?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){wo.get(d).iterator.remove(),wo.delete(d);return}}return}if(c)return;if(!i.url){ot.info(`Node ${i.name} is missing url`);return}let l=wo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ot.info(`Added node ${i.name} at ${i.url} for process ${Xe()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,p]of nd)if(i.url===p.url){nd.delete(d);break}nd.set(i.name,i)}let u=Je();if(l||(l=new Map,wo.set(i.url,l)),l.iterator=La(e,(d,p,_)=>{_?f(p,!0):f(p,!1)}),i.subscriptions)for(let d of i.subscriptions){let p=d.database||d.schema;u[p]||(ot.warn(`Database ${p} not found for node ${i.name}, making a subscription anyway`),f(p,!1))}function f(d,p){ot.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),h,S=[{replicateByDefault:p,...i}];yg.has(d)&&(S.push({replicateByDefault:p,name:Xe(),start_time:yg.get(d),end_time:Date.now(),replicates:!0}),yg.delete(d));let g=lp(i,d),R=Yi.workers.filter(E=>E.name==="http");if(_?(h=_.worker,_.nodes=S):g&&(t=t%R.length,h=R[t++],l.set(d,{worker:h,nodes:S,url:i.url}),h?.on("exit",()=>{l.get(d)?.worker===h&&(l.delete(d),f(d,p))})),g)setTimeout(()=>{let E={type:"subscribe-to-node",database:d,nodes:S};h?h.postMessage(E):sd(E)},gie);else{ot.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],ar().primaryStore.get(Xe())?.replicates),ar().primaryStore.get(Xe())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};h?h.postMessage(E):Og(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),id=a(function(i){try{ot.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(nd.keys()),c=o.sort(),l=c.indexOf(i.name||ci(i.url));if(l===-1){ot.warn("Disconnected node not found in node map",i.name,o);return}let u=wo.get(i.url),f=u?.get(i.database);if(!f){ot.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished)return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let p=(l+1)%c.length;for(;l!==p;){let _=c[p],h=nd.get(_);u=wo.get(h.url);let S=u?.get(i.database);if(!S){p=(p+1)%c.length;continue}let{worker:g,nodes:R}=S,E=!1;for(let A of f.nodes){if(R.some(O=>O.name===A.name)){ot.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}R.push(A),E=!0}if(!E){ot.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,ot.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):sd({database:i.database,nodes:R});return}ot.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){ot.error("Error failing over node",o)}},"disconnectedFromNode"),dl=a(function(i){let o=wo.get(i.url),c=o?.get(i.database);if(!c){ot.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,f=u.find(d=>d.name===i.name);c.redirectingTo=null,f&&(u.splice(u.indexOf(f),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):sd({database:i.database,nodes:u}))}},"connectedToNode"),(0,Yi.onMessageByType)("disconnected-from-node",id),(0,Yi.onMessageByType)("connected-to-node",dl),(0,Yi.onMessageByType)("request-cluster-status",Wk)}function Wk(e,t){let r=[];for(let[n,s]of nd)try{let i=wo.get(s.url);ot.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:f,nodes:d,latency:p}]of i)o.push({database:l,connected:f,latency:p,thread_id:u?.threadId,nodes:d.map(_=>_.name)});let c=(0,zO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ot.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Io(e,t){let r=ar();e=e??ci(t.url),t.name=e;try{if(t.ca){let s=new Yk.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){ot.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ot.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!Kk.default.get(B.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,zO.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}ot.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Yi,bg,ot,zO,Kk,Yk,gie,wo,id,dl,nd,yg,dp=be(()=>{Pe();Yi=M(et());es();bg=require("worker_threads");ul();ot=M(z()),zO=require("lodash"),Kk=M(ae());H();Yk=require("crypto"),gie=200,wo=new Map,nd=new Map,yg=new Map;a(jO,"startOnMainThread");a(Wk,"requestClusterStatus");bg.parentPort&&(id=a(e=>{bg.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),dl=a(e=>{bg.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Yi.onMessageByType)("subscribe-to-node",e=>{sd(e)}),(0,Yi.onMessageByType)("unsubscribe-from-node",e=>{Og(e)}));a(Io,"ensureNode")});var ts=w(EF=>{"use strict";var cr=require("path"),On=require("fs-extra"),od=require("node-forge"),eF=require("net"),{generateKeyPair:JO,X509Certificate:Co,createPrivateKey:tF}=require("crypto"),Sie=require("util");JO=Sie.promisify(JO);var bt=od.pki,li=require("joi"),{v4:rF}=require("uuid"),{validateBySchema:tN}=ft(),pt=z(),Os=ae(),Ns=(H(),C(q)),{CONFIG_PARAMS:ad}=Ns,ui=qy(),{ClientError:Ua}=pe(),Ng=require("node:tls"),{relative:nF,join:Tie}=require("node:path"),{CERT_PREFERENCE_APP:UPe,CERTIFICATE_VALUES:jk}=ui,Aie=da(),XO=yt(),{table:Rie,getDatabases:yie,databases:QO}=(Pe(),C(tt)),{getJWTRSAKeys:Qk}=(zu(),C(ep));Object.assign(EF,{generateKeys:sN,updateConfigCert:dF,createCsr:Die,signCertificate:Lie,setCertTable:cd,loadCertificates:cF,reviewSelfSignedCert:oN,createTLSSelector:_F,listCertificates:hF,addCertificate:Hie,removeCertificate:Fie,createNatsCerts:Uie,generateCertsKeys:vie,getReplicationCert:_p,getReplicationCertAuth:Pie,renewSelfSigned:xie,hostnamesFromCert:mF,getKey:Gie});var{urlToNodeName:sF,getThisNodeUrl:bie,getThisNodeName:Ig,clearThisNodeName:Oie}=(es(),C(Po)),{readFileSync:Nie,watchFile:wie,statSync:iF}=require("node:fs"),xPe=ae(),{getTicketKeys:Iie,onMessageFromWorkers:Cie}=et(),va=z(),{isMainThread:oF}=require("worker_threads"),{TLSSocket:aF,createSecureContext:BPe}=require("node:tls"),rN=3650,fp=["127.0.0.1","localhost","::1"],nN=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Cie(async e=>{e.type===Ns.ITC_EVENT_TYPES.RESTART&&(Os.initSync(!0),await oN())});var vr;function Ba(){return vr||(vr=yie().system.hdb_certificate,vr||(vr=Rie({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),vr}a(Ba,"getCertTable");async function _p(){let e=_F("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Ig());if(!r)return;let n=new Co(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(_p,"getReplicationCert");async function Pie(){Ba();let e=(await _p()).options.cert,r=new Co(e).issuer.match(/CN=(.*)/)?.[1];return vr.get(r)}a(Pie,"getReplicationCertAuth");var Jk,xa=new Map;function cF(){if(Jk)return;Jk=!0;let e=[{configKey:ad.TLS},{configKey:ad.OPERATIONSAPI_TLS}];Ba();let t=cr.dirname(XO.getConfigFilePath()),r;for(let{configKey:n}of e){let s=XO.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&nF(Tie(t,"keys"),o);c&&Xk(o,l=>{xa.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&oF){let f;Xk(u,d=>{if(jk.cert===d)return;let p=i.hostname??i.hostnames??i.host??i.hosts;p&&!Array.isArray(p)&&(p=[p]);let _=fF(u),h=new Co(_),S;try{S=aN(h)}catch(A){pt.error("error extracting common name from certificate",A);return}if(S==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new Co(jk.cert)))return;let g=vr.primaryStore.get(S),R=iF(u).mtimeMs,E=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&R<=E){R<E&&pt.info(`Certificate ${S} at ${u} is older (${new Date(R)}) than the certificate in the database (${E>1?new Date(E):"only self signed certificate available"})`);return}r=vr.put({name:S,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:_,private_key_name:c,is_authority:l,hostnames:p,file_timestamp:R,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(cF,"loadCertificates");function Xk(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&oF&&pt.warn(`Reloading ${r}:`,e),n=c,t(fF(e)))}catch(c){pt.error(`Error loading ${r}:`,e,c)}},"loadFile");On.existsSync(e)?s(iF(e)):pt.error(`${r} file not found:`,e),wie(e,{persistent:!1},s)}a(Xk,"loadAndWatch");function ZO(){let e=bie();if(e==null){let t=fp[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return sF(e)}a(ZO,"getHost");function wg(){let e=Ig();if(e==null){let t=fp[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(wg,"getCommonName");async function Die(){let e=await _p(),t=bt.certificateFromPem(e.options.cert),r=bt.privateKeyFromPem(e.options.key);pt.info("Creating CSR with cert named:",e.name);let n=bt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:wg()},...nN];pt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:lF()}];return pt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),od.pki.certificationRequestToPem(n)}a(Die,"createCsr");function lF(){let e=fp.includes(wg())?fp:[...fp,wg()];return e.includes(ZO())||e.push(ZO()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>eF.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(lF,"certExtensions");async function Lie(e){let t={},r=cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;Ba();for await(let f of vr.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(xa.has(f.private_key_name)){n=xa.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await On.exists(cr.join(r,f.private_key_name))){n=On.readFile(cr.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await eN();s=f.ca,n=f.private_key}n=bt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=bt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=bt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return pt.error(f),new Error("Error verifying CSR: "+f.message)}let c=od.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+rN),pt.info("sign cert setting validity:",c.validity),pt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),pt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;pt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,od.md.sha256.create()),t.certificate=bt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Lie,"signCertificate");async function Mie(e,t){await cd({name:Ig(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await cd({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:bt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Mie,"createCertificateTable");async function cd(e){let t=new Co(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},Ba(),await vr.patch(e)}a(cd,"setCertTable");async function sN(){let e=await JO("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:bt.publicKeyFromPem(e.publicKey),private_key:bt.privateKeyFromPem(e.privateKey)}}a(sN,"generateKeys");async function iN(e,t,r){let n=bt.createCertificate();if(!t){let o=await _p();t=bt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+rN);let i=[{name:"commonName",value:wg()},...nN];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(lF()),n.sign(e,od.md.sha256.create()),bt.certificateToPem(n)}a(iN,"generateCertificates");async function eN(){let e=await hF(),t;for(let r of e){if(!r.is_authority)continue;let n=await pF(r.private_key_name);if(r.private_key_name&&n&&new Co(r.certificate).checkPrivateKey(tF(n))){pt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;pt.trace("No CA found with matching private key")}a(eN,"getCertAuthority");async function uF(e,t,r=!0){let n=bt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+rN);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${Os.get(ad.REPLICATION_HOSTNAME)??sF(Os.get(ad.REPLICATION_URL))??rF().split("-")[0]}`},...nN];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,od.md.sha256.create());let o=cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME),c=cr.join(o,ui.PRIVATEKEY_PEM_NAME);return r&&await On.writeFile(c,bt.privateKeyToPem(e)),n}a(uF,"generateCertAuthority");async function vie(){let{private_key:e,public_key:t}=await sN(),r=await uF(e,t),n=await iN(e,t,r);await Mie(n,r),dF()}a(vie,"generateCertsKeys");async function Uie(){let e=await iN(bt.privateKeyFromPem(ui.CERTIFICATE_VALUES.key),void 0,bt.certificateFromPem(ui.CERTIFICATE_VALUES.cert)),t=cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME),r=cr.join(t,ui.NATS_CERTIFICATE_PEM_NAME);await On.exists(r)||await On.writeFile(r,e);let n=cr.join(t,ui.NATS_CA_PEM_NAME);await On.exists(n)||await On.writeFile(n,ui.CERTIFICATE_VALUES.cert)}a(Uie,"createNatsCerts");async function xie(){Ba();for await(let e of vr.search([{attribute:"is_self_signed",value:!0}]))await vr.delete(e.name);await oN()}a(xie,"renewSelfSigned");async function oN(){Oie(),await cF(),Ba();let e=await eN();if(!e){pt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=Os.get(ad.TLS_PRIVATEKEY),n=cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME),s,i=nF(n,r);try{s=bt.privateKeyFromPem(await On.readFile(r))}catch(c){pt.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await sN(),await On.exists(cr.join(n,ui.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${rF().split("-")[0]}.pem`),await On.writeFile(cr.join(n,i),bt.privateKeyToPem(s))}let o=await uF(s,bt.setRsaPublicKey(s.n,s.e),!1);await cd({name:o.subject.getField("CN").value,uses:["https"],certificate:bt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await _p()){let r=Ig();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await eN();let n=bt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await iN(bt.privateKeyFromPem(e.private_key),s,n);await cd({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(oN,"reviewSelfSignedCert");function dF(){let e=Aie(Object.keys(Ns.CONFIG_PARAM_MAP),!0),t=cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME),r=cr.join(t,ui.PRIVATEKEY_PEM_NAME),n=cr.join(t,ui.NATS_CERTIFICATE_PEM_NAME),s=cr.join(t,ui.NATS_CA_PEM_NAME),i=Ns.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),XO.updateConfigValue(void 0,void 0,o,!1,!0)}a(dF,"updateConfigCert");function fF(e){return e.startsWith("-----BEGIN")?e:Nie(e,"utf8")}a(fF,"readPEM");var Zk=Ng.createSecureContext;Ng.createSecureContext=function(e){if(!e.cert||!e.key)return Zk(e);let t={...e};delete t.key,delete t.cert;let r=Zk(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var Bie=aF.prototype._init;aF.prototype._init=function(e,t){Bie.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var fl=new Map;function _F(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),fl.clear();let f=0;for await(let d of QO.system.hdb_certificate.search([])){let p=d.certificate,_=new Co(p);d.is_authority&&(_.asString=p,fl.set(_.subject,p))}for await(let d of QO.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let p=e==="operations-api",_=d.is_self_signed?1:2;p&&d.uses?.includes?.("operations")&&(_+=1);let h=await pF(d.private_key_name),S=d.certificate,g=new Co(S);if(fl.has(g.issuer)&&(S+=`
|
|
24
|
-
`+fl.get(g.issuer)),!h||!S)throw new Error("Missing private key or certificate for secure server");let R={ciphers:d.ciphers,ticketKeys:Iie(),availableCAs:fl,ca:t&&Array.from(fl.values()),cert:S,key:h,key_file:d.private_key_name,is_self_signed:d.is_self_signed};o&&(R.sessionIdContext=o.sessionIdContext);let E=Ng.createSecureContext(R);E.name=d.name,E.options=R,E.quality=_,E.certificateAuthorities=Array.from(fl),E.certStart=S.toString().slice(0,100);let A=d.hostnames??mF(g);Array.isArray(A)||(A=[A]);let O;for(let v of A)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===ZO()&&(_+=2),eF.isIP(v)&&(O=!0);let F=r.get(v)?.quality??0;_>F&&r.set(v,E)}else va.error("No hostname found for certificate at",Ng.certificate);va.trace("Adding TLS",E.name,"for",o.ports||"client","cert named",d.name,"hostnames",A,"quality",_,"best quality",f),_>f&&(i.defaultContext=n=E,f=_,o&&(o.defaultContext=E))}catch(p){va.error("Error applying TLS for",d.name,p)}o?.secureContextsListeners.forEach(d=>d()),c(n)}catch(f){l(f)}}a(u,"updateTLS"),QO.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){va.info("TLS requested for",o||"(no SNI)");let l=o;for(;;){let f=r.get(l);if(f)return va.debug("Found certificate for",o,f.certStart),f.updatedContext&&(f=f.updatedContext),c(null,f);if(s&&l){let d=l.indexOf(".",1);d<0?l="":l=l.slice(d)}else break}o?va.debug("No certificate found to match",o,"using the default certificate"):va.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):va.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(_F,"createTLSSelector");async function pF(e){let t=xa.get(e);return!t&&e?await On.readFile(cr.join(Os.get(ad.ROOTPATH),Ns.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(pF,"getPrivateKeyByName");async function hF(){Ba();let e=[];for await(let t of vr.search([]))e.push(t);return e}a(hF,"listCertificates");async function Hie(e){let t=tN(e,li.object({name:li.string().required(),certificate:li.string().required(),is_authority:li.boolean().required(),private_key:li.string(),hosts:li.array(),uses:li.array()}));if(t)throw new Ua(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new Co(n),c=!1,l=!1,u;for(let[_,h]of xa)!s&&!c&&o.checkPrivateKey(tF(h))&&(c=!0,u=_),s&&s===h&&(l=!0,u=_);if(!i&&!s&&!c)throw new Ua("A suitable private key was not found for this certificate");let f;if(!r){try{f=aN(o)}catch(_){pt.error(_)}if(f==null)throw new Ua("Error extracting certificate common name, please provide a name parameter")}let d=kie(r??f);s&&!c&&!l&&(await On.writeFile(cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME,d+".pem"),s),xa.set(d,s));let p={name:r??f,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(p.private_key_name=u??d+".pem"),await cd(p),"Successfully added certificate: "+d}a(Hie,"addCertificate");function kie(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(kie,"sanitizeName");async function Fie(e){let t=tN(e,li.object({name:li.string().required()}));if(t)throw new Ua(t.message);let{name:r}=e;Ba();let n=await vr.get(r);if(!n)throw new Ua(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await vr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await On.remove(cr.join(Os.getHdbBasePath(),Ns.LICENSE_KEY_DIR_NAME,s)))}return await vr.delete(r),"Successfully removed "+r}a(Fie,"removeCertificate");function aN(e){return e.subject.match(/CN=(.*)/)?.[1]}a(aN,"extractCommonName");function mF(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[aN(e)]}a(mF,"hostnamesFromCert");async function Gie(e){if(e.bypass_auth!==!0)throw new Ua("Unauthorized","401");let t=tN(e,li.object({name:li.string().required()}));if(t)throw new Ua(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await Qk()).privateKey;if(r===".jwtPublic")return(await Qk()).publicKey;if(xa.get(r))return xa.get(e.name);throw new Ua("Key not found")}a(Gie,"getKey")});var xF={};ve(xF,{CONFIRMATION_STATUS_POSITION:()=>UF,NodeReplicationConnection:()=>pp,OPERATION_REQUEST:()=>fN,RECEIVED_TIME_POSITION:()=>pN,RECEIVED_VERSION_POSITION:()=>_N,SENDING_TIME_POSITION:()=>Mg,createWebSocket:()=>Ug,database_subscriptions:()=>ka,replicateOverWS:()=>hp,table_update_listeners:()=>mN});async function Ug(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Xe(),i;if(e.includes("wss://")){if(!lN){let l=(0,LF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),lN=u.secureContexts}if(i=lN.get(s),i&&le.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,vF.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=MF.createSecureContext({...i.options,ca:Array.from(pl)})),new PF.WebSocket(e,"harperdb-replication-v1",c)}function hp(e,t,r){let n=t.port||t.securePort,s=_l.pid%1e3+"-"+DF.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,f=t.databaseSubscriptions||ka,d,p,_=!1,h=t.subscription;h?.then&&h.then(m=>h=m);let S=t.tables||u&&Je()[u];if(!r){le.error?.("No authorization provided"),un(1008,"Unauthorized");return}let g=new Map,R=[],E=r.name;E&&t.connection&&(t.connection.nodeName=E);let A,O,v,F,G,Y,te,ie=1e3,X,ne=0,Q=0,he=0,Re=new Map,Ce=[],me=0,Zt;if(t.url){let m=a(()=>{G&&Q===e._socket?.bytesRead&&he===e._socket?.bytesWritten?e.terminate():(G=performance.now(),e.ping(),Q=e._socket?.bytesRead,he=e._socket?.bytesWritten)},"send_ping");v=setInterval(m,wF).unref(),m()}else lt();e._socket?.setMaxListeners(200);function lt(){clearTimeout(F),Q=e._socket?.bytesRead,he=e._socket?.bytesWritten,F=setTimeout(()=>{Q===e._socket?.bytesRead&&he===e._socket?.bytesWritten&&(le.warn?.(`Timeout waiting for ping from ${E}, terminating connection and reconnecting`),e.terminate())},wF*2).unref()}a(lt,"resetPingTimer");function yr(){return p||(p=Rg(d,u,E)),p}a(yr,"getSharedStatus"),u&&oa(u);let Es,xn,nu=[],su=[],xA,BA=[],Lt=[],mf=[],jh=150,Qh=25,Ef=0,Jh=0,De=!1,gf,ln,Ir,iu;e.on("message",m=>{ne=performance.now();try{let T=m.dataView=new hl(m.buffer,m.byteOffset,m.byteLength);if(m[0]>127){let P=(0,ze.decode)(m),[N,L,k]=P;switch(N){case SF:{if(L){if(E){if(E!==L){le.error?.(s,`Node name mismatch, expecting to connect to ${E}, but peer reported name as ${L}, disconnecting`),e.send((0,ze.encode)([ld])),un(1008,"Node name mismatch");return}}else if(E=L,t.connection?.tentativeNode){let U=t.connection.tentativeNode;U.name=E,t.connection.tentativeNode=null,Io(E,U)}if(t.connection&&(t.connection.nodeName=E),le.debug?.(s,"received node name:",E,"db:",u),!u)try{oa(u=P[2]),u==="system"&&(Es=La(t,(U,ue)=>{au(ue)&&aa(ue)}),e.on("close",()=>{Es?.remove()}))}catch(U){le.warn?.(s,"Error setting database",U),e.send((0,ze.encode)([ld])),un(1008,U.message);return}Fr()}break}case OF:{le.debug?.(s,"Received table definitions for",L.map(U=>U.table));for(let U of L){let ue=P[2];U.database=ue;let ce;au(ue)&&(ue==="system"?qe[ue]?.[U.table]||(ce=uN(U,qe[ue]?.[U.table])):ce=uN(U,qe[ue]?.[U.table]),d||(d=ce?.auditStore),S||(S=Je()?.[ue]))}break}case ld:un();break;case fN:try{let U=r?.replicates||r?.subscribers||r?.name;server.operation(L,{user:r},!U).then(ue=>{Array.isArray(ue)&&(ue={results:ue}),ue.requestId=L.requestId,e.send((0,ze.encode)([Pg,ue]))},ue=>{e.send((0,ze.encode)([Pg,{requestId:L.requestId,error:ue instanceof Error?ue.toString():ue}]))})}catch(U){e.send((0,ze.encode)([Pg,{requestId:L.requestId,error:U instanceof Error?U.toString():U}]))}break;case Pg:let{resolve:D,reject:x}=g.get(L.requestId);L.error?x(new Error(L.error)):D(L),g.delete(L.requestId);break;case cN:let $=P[3];S||(u?le.error?.(s,"No tables found for",u):le.error?.(s,"Database name never received"));let j=S[$];j=uN({table:$,database:u,attributes:L.attributes,schemaDefined:L.schemaDefined},j),nu[k]={name:$,decoder:new ze.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:L.typedStructs,structures:L.structures}),getEntry(U){return j.primaryStore.getEntry(U)},rootStore:j.primaryStore.rootStore};break;case TF:iu=d?kk(L,d):new Map,xA=P[2],le.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${xA}`);break;case AF:let oe=k;mf[oe]=L;break;case bF:yr()[UF]=L,le.trace?.(s,"received and broadcasting committed update",L),yr().buffer.notify();break;case yF:A=L,h.send({type:"end_txn",localTime:A,remoteNodeIds:R});break;case Dg:{let U=P[1],{fileId:ue,size:ce,finished:fe,error:ee}=U,W=Re.get(ue);le.debug?.("Received blob",ue,"has stream",!!W,"connectedToBlob",!!W?.connectedToBlob,"length",P[2].length,"finished",fe),W||(W=new dN.PassThrough,W.expectedSize=ce,Re.set(ue,W)),W.lastChunk=Date.now(),fe?(ee?(W.on("error",()=>{}),W.destroy(new Error("Blob error: "+ee))):W.end(P[2]),W.connectedToBlob&&Re.delete(ue)):W.write(P[2]);break}case RF:{let U=L,ue;try{let ce=P[3],fe=su[k]||(su[k]=S[P[4]]);if(!fe)return le.warn?.("Unknown table id trying to handle record request",k);let ee=fe.primaryStore.getBinaryFast(Symbol.for("structures")),W=ee.length;if(W!==Jh){Jh=W;let Ae=(0,ze.decode)(ee);e.send((0,ze.encode)([cN,{typedStructs:Ae.typed,structures:Ae.named},k,fe.tableName]))}let _e=fe.primaryStore.getBinaryFast(ce);if(_e){let Ae=fe.primaryStore.decoder.decode(_e,{valueAsBuffer:!0});ue=(0,ze.encode)([Cg,U,{value:Ae.value,expiresAt:Ae.expiresAt,version:Ae.version,residencyId:Ae.residencyId,nodeId:Ae.nodeId,user:Ae.user}])}else ue=(0,ze.encode)([Cg,U])}catch(ce){ue=(0,ze.encode)([Cg,U,{error:ce.message}])}e.send(ue);break}case Cg:{let{resolve:U,reject:ue,tableId:ce,key:fe}=g.get(P[1]),ee=P[2];if(ee?.error)ue(new Error(ee.error));else if(ee){let W=nu[ce].decoder.decode(ee.value);ee.value=W,ee.key=fe,U(ee)}else U();g.delete(P[1]);break}case gF:{Ir=L;let U,ue,ce=!1;if(h){if(u!==h.databaseName&&!h.then){le.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=f.get(u);if(le.debug?.(s,"received subscription request for",u,"at",Ir),!h){let Ee;h=new Promise(Qe=>{le.debug?.("Waiting for subscription to database "+u),Ee=Qe}),h.ready=Ee,ka.set(u,h)}if(r.name)ue=ar().subscribe(r.name),ue.then(async Ee=>{U=Ee;for await(let Qe of U){let nt=Qe.value;if(!(nt?.replicates===!0||nt?.replicates?.receives||nt?.subscriptions?.some(qt=>(qt.database||qt.schema)===u&&qt.publish!==!1))){ce=!0,e.send((0,ze.encode)([ld])),un(1008,`Unauthorized database subscription to ${u}`);return}}},Ee=>{le.error?.(s,"Error subscribing to HDB nodes",Ee)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,ze.encode)([ld])),un(1008,`Unauthorized database subscription to ${u}`);return}if(ln&&(le.debug?.(s,"stopping previous subscription",u),ln.emit("close")),Ir.length===0)return;let fe=Ir[0],ee=a(Ee=>{if(Ee&&(fe.replicateByDefault?!fe.tables.includes(Ee.tableName):fe.tables.includes(Ee.tableName)))return{table:Ee}},"tableToTableEntry"),W={txnTime:0},_e,Ae,ye=1/0,ut,rt=a((Ee,Qe)=>{if(Ee.type==="end_txn"){W.txnTime&&(o[i]!==66&&le.error?.("Invalid encoding of message"),cu(9),cu(vg),uu(ut=Qe),Gr()),i=c,W.txnTime=0;return}let nt=Ee.nodeId,qt=Ee.tableId,$t=Ae[qt];if(!$t&&($t=Ae[qt]=ee(h.tableById[qt]),!$t))return le.debug?.("Not subscribed to table",qt);let qr=$t.table,Tc=qr.primaryStore,Mt=Tc.encoder;(Ee.extendedType&zm||!Mt.typedStructs)&&(Mt._mergeStructures(Mt.getStructures()),Mt.typedStructs&&(Mt.lastTypedStructuresLength=Mt.typedStructs.length));let Zh=_e[nt];if(!(Zh&&Zh.startTime<Qe&&(!Zh.endTime||Zh.endTime>Qe)))return Lg&&le.trace?.(s,"skipping replication update",Ee.recordId,"to:",E,"from:",nt,"subscribed:",_e),nD();Lg&&le.trace?.(s,"sending replication update",Ee.recordId,"to:",E,"from:",nt,"subscribed:",_e);let HA=Ee.version;W.txnTime!==HA&&(W.txnTime&&(Lg&&le.trace?.(s,"new txn time, sending queued txn",W.txnTime),o[i]!==66&&le.error?.("Invalid encoding of message"),Gr()),W.txnTime=HA,i=c,uu(HA));let Ac=Ee.residencyId,kA=ou(Ac,qr),em;if(kA&&!kA.includes(E)){let Rc=ou(Ee.previousResidencyId,qr);if(Rc&&!Rc.includes(E)&&(Ee.type==="put"||Ee.type==="patch")||qr.getResidencyById)return nD();let Af=Ee.recordId;le.trace?.(s,"sending invalidation",Af,E,"from",nt);let la=0;Ac&&(la|=xc),Ee.previousResidencyId&&(la|=Bc);let Ys,dn=null;for(let tm in qr.indices){if(!dn){if(Ys=Ee.getValue(Tc,!0),!Ys)break;dn={}}dn[tm]=Ys[tm]}em=bu(Ee.version,qt,Af,null,nt,Ee.user,Ee.type==="put"||Ee.type==="patch"?"invalidate":Ee.type,Mt.encode(dn),la,Ac,Ee.previousResidencyId,Ee.expiresAt)}function nD(){le.trace?.(s,"skipping audit record",Ee.recordId),Y||(Y=setTimeout(()=>{Y=null,(ut||0)+NF/2<ye&&(Lg&&le.trace?.(s,"sending skipped sequence update",ye),e.send((0,ze.encode)([yF,ye])))},NF).unref())}a(nD,"skipAuditRecord");let FA=Mt.typedStructs,GA=Mt.structures;if((FA?.length!=$t.typed_length||GA?.length!=$t.structure_length)&&($t.typed_length=FA?.length,$t.structure_length=GA.length,le.debug?.(s,"send table struct",$t.typed_length,$t.structure_length),$t.sentName||($t.sentName=!0),e.send((0,ze.encode)([cN,{typedStructs:FA,structures:GA,attributes:qr.attributes,schemaDefined:qr.schemaDefined},qt,$t.table.tableName]))),Ac&&!Lt[Ac]&&(e.send((0,ze.encode)([AF,kA,Ac])),Lt[Ac]=!0),em)cu(em.length),lu(em);else{let Rc=Ee.encoded;Ee.extendedType&qn&&IR(()=>Ee.getValue(Tc),async la=>{let Ys=Bm(la);try{let dn;me++;for await(let tm of la.stream()){if(dn&&(le.debug?.("Sending blob chunk",Ys,"length",dn.length),e.send((0,ze.encode)([Dg,{fileId:Ys,size:la.size},dn]))),dn=tm,ce)return;e._socket.writableNeedDrain&&(le.debug?.("draining",Ys),await new Promise(TJ=>e._socket.once("drain",TJ)),le.debug?.("drained",Ys))}le.debug?.("Sending final blob chunk",Ys,"length",dn.length),e.send((0,ze.encode)([Dg,{fileId:Ys,size:la.size,finished:!0},dn]))}catch(dn){le.debug?.("Error sending blob",dn),e.send((0,ze.encode)([Dg,{fileId:Ys,finished:!0,error:dn.toString()},Buffer.alloc(0)]))}finally{me--,me<Qh&&Zt?.()}});let Af=Rc[0]===66?8:0;cu(Rc.length-Af),lu(Rc,Af),le.trace?.("wrote record",Ee.recordId,"length:",Rc.length)}},"sendAuditRecord"),Gr=a(()=>{c-i>8?(e.send(o.subarray(i,c)),le.debug?.(s,"Sent message, size:",c-i)):le.debug?.(s,"skipping empty transaction")},"sendQueuedData");ln=new hN.EventEmitter,ln.once("close",()=>{ce=!0,U?.end()});for(let{startTime:Ee}of Ir)Ee<ye&&(ye=Ee);(ue||Promise.resolve()).then(async()=>{h=await h,d=h.auditStore,Ae=h.tableById.map(ee),_e=[];for(let{name:Qe,startTime:nt,endTime:qt}of Ir){let $t=Ag(Qe,d);le.debug?.("subscription to",Qe,"using local id",$t,"starting",nt),_e[$t]={startTime:nt,endTime:qt}}aa(u),Es||(Es=ml(Qe=>{Qe.databaseName===u&&aa(u)}),xn=mp(Qe=>{Qe===u&&(e.send((0,ze.encode)([ld])),un())}),e.on("close",()=>{Es?.remove(),xn?.remove()})),e.send((0,ze.encode)([TF,ap(h.auditStore),Ir.map(({name:Qe})=>Qe)]));let Ee=!0;do{isFinite(ye)||(le.warn?.("Invalid sequence id "+ye),un(1008,"Invalid sequence id"+ye));let Qe;if(Ee&&!ce&&(Ee=!1,!(gN(d)<=ye)&&(CF.default.get(B.REPLICATION_COPYTABLESTOCATCHUP)??qie)&&server.nodes[0]?.name===E)){le.info?.("Replicating all tables to",E);let qt=ye,$t=xg(d);for(let qr in S){if(!ee(qr))continue;let Tc=S[qr];for(let Mt of Tc.primaryStore.getRange({snapshot:!1})){if(ce)return;Mt.localTime>=ye&&(le.trace?.(s,"Copying record from",u,qr,Mt.key,Mt.localTime),qt=Math.max(Mt.localTime,qt),Qe=!0,yr()[Mg]=1,rt({recordId:Mt.key,tableId:Tc.tableId,type:"put",getValue(){return Mt.value},encoded:Tc.primaryStore.getBinary(Mt.key),version:Mt.version,residencyId:Mt.residencyId,nodeId:$t,extendedType:Mt.metadataFlags},Mt.localTime))}}ye=qt}for(let{key:nt,value:qt}of d.getRange({start:ye||1,exclusiveStart:!0,snapshot:!1})){if(ce)return;let $t=wt(qt);le.debug?.("sending audit record",new Date(nt)),yr()[Mg]=nt,ye=nt,rt($t,nt),e._socket.writableNeedDrain?await new Promise(qr=>{le.debug?.(`Waiting for remote node ${E} to allow more commits ${e._socket.writableNeedDrain?"due to network backlog":"due to requested flow directive"}`),e._socket.once("drain",qr)}):me>Qh?await new Promise(qr=>{Zt=qr}):await new Promise(setImmediate),ln.startTime=nt,Qe=!0}Qe&&rt({type:"end_txn"},ye),yr()[Mg]=0,await BF(d)}while(!ce)}).catch(Ee=>{le.error?.(s,"Error handling subscription to node",Ee),un(1008,"Error handling subscription to node")});break}}return}T.position=8;let I=!0,y,b;do{yr();let P=T.readInt();if(P===9&&T.getUint8(T.position)==vg){T.position++,A=b=T.readFloat64(),p[_N]=A,p[pN]=Date.now(),le.trace?.("received remote sequence update",A,u);break}let N=T.position,L=wt(m,N,N+P),k=nu[L.tableId];k||le.error?.(`No table found with an id of ${L.tableId}`);let D;L.residencyId&&(D=mf[L.residencyId],le.trace?.(s,"received residency list",D,L.type,L.recordId));try{wR(()=>{y={table:k.name,id:L.recordId,type:L.type,nodeId:iu.get(L.nodeId),residencyList:D,timestamp:L.version,value:L.getValue(k),user:L.user,beginTxn:I,expiresAt:L.expiresAt}},x=>{let $=Bm(x),j=Re.get($);le.debug?.("Received transaction with blob",$,"has stream",!!j,"ended",!!j?.writableEnded),j?j.writableEnded&&Re.delete($):(j=new dN.PassThrough,Re.set($,j)),j.connectedToBlob=!0,j.lastChunk=Date.now(),x.size===void 0&&j.expectedSize&&(x.size=j.expectedSize);let oe=createBlob(j,x),U=oe.save({primaryStore:h.auditStore});return U&&(U.blobId=$,Ce.push(U),U.finally(()=>{le.debug?.(`Finished receiving blob stream ${$}`),Ce.splice(Ce.indexOf(U),1)})),oe})}catch(x){throw x.message+="typed structures for current decoder"+JSON.stringify(k.decoder.typedStructs),x}I=!1,le.trace?.(s,"received replication message",L.type,"id",y.id,"version",new Date(L.version),"nodeId",y.nodeId),p[_N]=L.version,p[pN]=Date.now(),h.send(y),T.position=N+P}while(T.position<m.byteLength);Ef++,ir(m.byteLength,"bytes-received",`${E}.${u}.${y?.table||"unknown_table"}`,"replication","ingest"),Ef>jh&&!De&&(De=!0,e.pause(),le.debug?.(`Commit backlog causing replication back-pressure, requesting that ${E} pause replication`)),h.send({type:"end_txn",localTime:A,remoteNodeIds:R,async onCommit(){if(y){let P=Date.now()-y.timestamp;ir(P,"replication-latency",E+"."+u+"."+y.table,y.type,"ingest")}Ef--,De&&(De=!1,e.resume(),le.debug?.(`Replication resuming ${E}`)),Ce.length>0&&await Promise.all(Ce),le.trace?.("All blobs finished"),!O&&b&&(le.trace?.(s,"queuing confirmation of a commit at",b),setTimeout(()=>{e.send((0,ze.encode)([bF,O])),le.trace?.(s,"sent confirmation of a commit at",O),O=null},$ie)),O=b,le.debug?.("last sequence committed",new Date(b),u)}})}catch(T){le.error?.(s,"Error handling incoming replication message",T)}}),e.on("ping",lt),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-G,dl({name:E,database:u,url:t.url,latency:t.connection.latency})),G=null}),e.on("close",(m,T)=>{clearInterval(v),clearTimeout(F),clearInterval(te),ln&&ln.emit("close"),gf&&gf.end();for(let[I,{reject:y}]of g)y(new Error(`Connection closed ${T?.toString()} ${m}`));le.debug?.(s,"closed",m,T?.toString())});function Sf(){}a(Sf,"recordRemoteNodeSequence");function un(m,T){e.isFinished=!0,e.close(m,T)}a(un,"close");function Fr(){if(_||(_=!0,t.connection?.on("subscriptions-updated",Fr)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let m=new Map;try{for(let y of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let b of y.value.nodes||[])b.lastTxnTime>(m.get(b.id)??0)&&m.set(b.id,b.lastTxnTime)}catch(y){if(!y.message.includes("Can not re"))throw y}let T=t.connection?.nodeSubscriptions?.[0];R=[];let I=t.connection?.nodeSubscriptions.map((y,b)=>{let P=[],{replicateByDefault:N}=y;if(y.subscriptions){for(let x of y.subscriptions)if(x.subscribe&&(x.schema||x.database)===u){let $=x.table;S?.[$]?.replicate!==!1&&P.push($)}N=!1}else for(let x in S)(N?S[x].replicate===!1:S[x].replicate)&&P.push(x);let L=d&&Ag(y.name,d),k=h?.dbisDB?.get([Symbol.for("seq"),L])??1,D=Math.max(k?.seqId??1,(typeof y.start_time=="string"?new Date(y.start_time).getTime():y.start_time)??1);if(le.debug?.("Starting time recorded in db",y.name,L,u,k?.seqId,"start time:",D,new Date(D)),T!==y){let x=d&&Ag(T.name,d),$=h?.dbisDB?.get([Symbol.for("seq"),x])??1;for(let j of $?.nodes||[])j.name===y.name&&(D=j.seqId,le.debug?.("Using sequence id from proxy node",T.name,D))}return R.push(L),m.get(L)>D&&(D=m.get(L),le.debug?.("Updating start time from more recent txn recorded",T.name,D)),{name:y.name,replicateByDefault:N,tables:P,startTime:D,endTime:y.end_time}});if(I)if(le.debug?.(s,"sending subscription request",I,h?.dbisDB?.path),clearTimeout(X),I.length>0)e.send((0,ze.encode)([gF,I]));else{let y=a(()=>{let b=performance.now();X=setTimeout(()=>{ne<=b?un(1008,"No nodes to subscribe to"):y()},ie)},"schedule_close");y()}}a(Fr,"sendSubscriptionRequestUpdate");function ou(m,T){if(!m)return;let I=BA[m];return I||(I=T.getResidencyRecord(m),BA[m]=I),I}a(ou,"getResidence");function au(m){return!(Ha&&Ha!="*"&&!Ha[m]&&!Ha.includes?.(m)&&!Ha.some?.(T=>T.name===m))}a(au,"checkDatabaseAccess");function oa(m){if(h=h||f.get(m),!au(m))throw new Error(`Access to database "${m}" is not permitted`);h||le.warn?.(`No database named "${m}" was declared and registered`),d=h?.auditStore,S||(S=Je()?.[m]);let T=Xe();if(T===E)throw T?new Error("Should not connect to self",T):new Error("Node name not defined");return Xh(T,m),!0}a(oa,"setDatabase");function Xh(m,T){let I=Je()?.[T],y=[];for(let b in I){let P=I[b];y.push({table:b,schemaDefined:P.schemaDefined,attributes:P.attributes.map(N=>({name:N.name,type:N.type,isPrimaryKey:N.isPrimaryKey}))})}le.trace?.("Sending database info for node",m,"database name",T),e.send((0,ze.encode)([SF,m,T,y]))}a(Xh,"sendNodeDBName");function aa(m){let T=Je()?.[m],I=[];for(let y in T){if(Ir&&!Ir.some(P=>P.replicateByDefault?!P.tables.includes(y):P.tables.includes(y)))continue;let b=T[y];I.push({table:y,schemaDefined:b.schemaDefined,attributes:b.attributes.map(P=>({name:P.name,type:P.type,isPrimaryKey:P.isPrimaryKey}))})}e.send((0,ze.encode)([OF,I,m]))}a(aa,"sendDBSchema"),te=setInterval(()=>{for(let[m,T]of Re)T.lastChunk+3e4<Date.now()&&(le.warn?.(`Timeout waiting for blob stream to finish ${m} from ${E}`),Re.delete(m),T.end())},3e4).unref();let ca=1,Tf=[];return{end(){gf&&gf.end(),ln&&ln.emit("close")},getRecord(m){let T=ca++;return new Promise((I,y)=>{let b=[RF,T,m.table.tableId,m.id];Tf[m.table.tableId]||(b.push(m.table.tableName),Tf[m.table.tableId]=!0),e.send((0,ze.encode)(b)),g.set(T,{tableId:m.table.tableId,key:m.id,resolve(P){let{table:N,entry:L}=m;I(P),P&&N._recordRelocate(L,P)},reject:y})})},sendOperation(m){let T=ca++;return m.requestId=T,e.send((0,ze.encode)([fN,m])),new Promise((I,y)=>{g.set(T,{resolve:I,reject:y})})}};function cu(m){K(5),m<128?o[c++]=m:m<16384?(l.setUint16(c,m|32768),c+=2):m<1056964608?(l.setUint32(c,m|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,m),c+=5)}function lu(m,T=0,I=m.length){let y=I-T;K(y),m.copy(o,c,T,I),c+=y}function uu(m){K(8),l.setFloat64(c,m),c+=8}function K(m){if(m+16>o.length-c){let T=Buffer.allocUnsafeSlow(c+m-i+65536>>10<<11);o.copy(T,0,i,c),c=c-i,i=0,o=T,l=new DataView(o.buffer,0,o.length)}}}function uN(e,t){let r=e.database??"data";if(r!=="data"&&!qe[r]){le.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(le.debug?.("(Re)creating",e),dt({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var CF,ze,PF,DF,le,hN,LF,MF,_l,vF,dN,gF,SF,TF,ld,AF,cN,RF,Cg,fN,Pg,yF,bF,OF,Dg,UF,_N,pN,Mg,qie,mN,ka,Lg,NF,$ie,wF,lN,IF,pp,EN=be(()=>{Pe();ho();YO();SN();es();CF=M(ae());H();Ou();ze=require("msgpackr"),PF=require("ws"),DF=require("worker_threads"),le=M(Ii());dp();hN=require("events"),LF=M(ts()),MF=M(require("node:tls"));ul();_l=M(require("node:process")),vF=require("node:net");qi();Ts();dN=require("node:stream"),gF=129,SF=140,TF=141,ld=142,AF=130,cN=132,RF=133,Cg=134,fN=136,Pg=137,yF=143,bF=144,OF=145,Dg=146,UF=0,_N=1,pN=2,Mg=3,qie=_l.env.HDB_LEADER_URL||_l.argv.includes("--HDB_LEADER_URL"),mN=new Map,ka=new Map,Lg=!0,NF=300,$ie=2,wF=3e4;a(Ug,"createWebSocket");IF=1e3,pp=class extends hN.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??ci(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=IF;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await Ug(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;le.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${_l.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),le[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=IF,dl({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=hp(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(le.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?le.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):le.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(id({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();le.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(hp,"replicateOverWS");a(uN,"ensureTableIfChanged")});var Po={};ve(Po,{clearThisNodeName:()=>Jie,disableReplication:()=>Wie,enabled_databases:()=>Ha,forEachReplicatedDatabase:()=>La,getThisNodeId:()=>xg,getThisNodeName:()=>Xe,getThisNodeUrl:()=>Ma,hostnameToUrl:()=>Fg,lastTimeInAuditStore:()=>cp,monitorNodeCAs:()=>KF,replicateOperation:()=>Zie,replication_certificate_authorities:()=>pl,sendOperationToNode:()=>gp,servers:()=>Kie,setReplicator:()=>WF,start:()=>Yie,startOnMainThread:()=>jO,subscribeToNode:()=>sd,unsubscribeFromNode:()=>Og,urlToNodeName:()=>ci});function Yie(e){if(e.port||(e.port=ws.default.get(B.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=ws.default.get(B.OPERATIONSAPI_NETWORK_SECUREPORT)),!Xe())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of up(e))t.set(ci(n.url),n);zie(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=Ye.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),hp(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&lr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,Ye.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&lr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=ar().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));if(c)if(c?.revoked_certificates?.includes(n.peerCertificate.serialNumber)){lr.warn("Revoked certificate used in attempt to connect to node",c.name,"certificate serial number",n.peerCertificate.serialNumber);return}else n.user=c;else lr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:lr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(pl);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.updatedContext=kg.createSecureContext(l)}catch(c){lr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),KF(s),ws.default.get(B.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function KF(e){let t=0;rd(r=>{r?.ca&&(pl.add(r.ca),pl.size!==t&&(t=pl.size,e?.()))})}function Wie(e=!0){VF=e}function zie(e){VF||(Je(),Ha=e.databases,La(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||ka;for(let[s,i]of Ep){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];WF(r,s,e),mN.get(s)?.forEach(i=>i(s))}}))}function WF(e,t,r){if(!t)return console.error(`Attempt to replicate non-existent table ${t.name} from database ${e}`);if(t.replicate===!1||t.sources?.some(s=>s.isReplicator))return;let n;t.sourcedFrom(class YF extends $r{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||ka,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(lr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Hn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let f;for(let p of c){let _=jie(p,YF.subscription,e);_?.isConnected&&!u.has(_)&&(!f||_.latency<f.latency)&&(f=_)}if(!f)throw l||new qF.ServerError("No connection to any other nodes are available",502);let d={requestId:Vie++,table:t,entry:i,id:i.key};u.add(f);try{return await f.getRecord(d)}catch(p){if(f.isConnected)throw p;lr.warn("Error in load from node",Hg,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function zF(e,t,r,n,s){let i=Ep.get(e);i||Ep.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new pp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function jie(e,t,r){let n=HF.get(e)?.get(r);if(n)return n;let s=ar().primaryStore.get(e);return s?.url&&(n=zF(s.url,t,r,e,s.authorization),HF.set(e,Ep.get(s.url))),n}async function gp(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ug(e.url,r),s=hp(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{lr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function sd(e){try{$F.isMainThread&&lr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=ka.get(e.database);if(!t){let n;t=new Promise(s=>{lr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,ka.set(e.database,t)}let r=zF(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>lp(n,e.database)),e.replicateByDefault)}catch(t){lr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Og({name:e,url:t,database:r}){lr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(ar().primaryStore.getRange({})));let n=Ep.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Qie(){if(TN!==void 0)return TN;let e=ws.default.get(B.OPERATIONSAPI_TLS_CERTIFICATE)||ws.default.get(B.TLS_CERTIFICATE);if(e)return TN=new FF.X509Certificate((0,GF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Xe(){return Hg||(Hg=ws.default.get("replication_hostname")??ci(ws.default.get("replication_url"))??Qie()??kF("operationsapi_network_secureport")??kF("operationsapi_network_port")??"127.0.0.1")}function Jie(){Hg=void 0}function kF(e){let t=ws.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Bg(e){let t=ws.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function xg(e){return ap(e)?.[Xe()]}function Ma(){let e=ws.default.get("replication_url");return e||Fg(Xe())}function Fg(e){let t=Bg("replication_port");if(t)return`ws://${e}:${t}`;if(t=Bg("replication_secureport"),t)return`wss://${e}:${t}`;if(t=Bg("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=Bg("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function ci(e){if(e)return new URL(e).hostname}function La(e,t){for(let n of Object.getOwnPropertyNames(qe))r(n);return mp(n=>{r(n)}),ml((n,s)=>{r(n.databaseName)});function r(n){let s=qe[n];lr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):Xie(n)&&t(s,n,!1)}a(r,"forDatabase")}function Xie(e){let t=qe[e];for(let r in t)if(t[r].replicate)return!0}function cp(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function Zie(e){let t={message:""};if(e.replicated){e.replicated=!1,lr.trace?.("Replicating operation",e.operation,"to nodes",Ye.nodes.map(n=>n.name));let r=await Promise.allSettled(Ye.nodes.map(n=>gp(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=Ye.nodes[s]?.name,i})}return t}var ws,lr,FF,GF,kg,qF,$F,VF,Vie,Kie,pl,Ha,Ep,HF,TN,Hg,es=be(()=>{Pe();ga();_u();EN();Vr();ws=M(ae()),lr=M(z()),FF=require("crypto"),GF=require("fs");dp();ul();H();YO();kg=M(require("node:tls")),qF=M(pe()),$F=require("worker_threads"),Vie=1,Kie=[],pl=ws.default.get(B.REPLICATION_ENABLEROOTCAS)!==!1?new Set(kg.rootCertificates):new Set;a(Yie,"start");a(KF,"monitorNodeCAs");a(Wie,"disableReplication");a(zie,"assignReplicationSource");a(WF,"setReplicator");Ep=new Map;a(zF,"getConnection");HF=new Map;a(jie,"getConnectionByName");a(gp,"sendOperationToNode");a(sd,"subscribeToNode");a(Og,"unsubscribeFromNode");a(Qie,"getCommonNameFromCert");a(Xe,"getThisNodeName");a(Jie,"clearThisNodeName");Object.defineProperty(Ye,"hostname",{get(){return Xe()}});a(kF,"getHostFromListeningPort");a(Bg,"getPortFromListeningPort");a(xg,"getThisNodeId");Ye.replication={getThisNodeId:xg,exportIdMapping:ap};a(Ma,"getThisNodeUrl");a(Fg,"hostnameToUrl");a(ci,"urlToNodeName");a(La,"forEachReplicatedDatabase");a(Xie,"hasExplicitlyReplicatedTable");a(cp,"lastTimeInAuditStore");a(Zie,"replicateOperation")});var Vg=w((uDe,ZF)=>{"use strict";var ud=nE(),dd=ck(),eoe=z(),toe=require("uuid").v4,lDe=require("clone"),qg=yo(),fd=(H(),C(q)),roe=require("util"),Fa=Yn(),{handleHDBError:Nn,hdb_errors:noe}=pe(),{HDB_ERROR_MSGS:Gg,HTTP_STATUS_CODES:wn}=noe,{SchemaEventMsg:$g}=ni(),jF=or(),{getDatabases:soe}=(Pe(),C(tt)),{transformReq:_d}=se(),{replicateOperation:QF}=(es(),C(Po));ZF.exports={createSchema:ioe,createSchemaStructure:JF,createTable:ooe,createTableStructure:XF,createAttribute:doe,dropSchema:aoe,dropTable:coe,dropAttribute:loe,getBackup:foe};async function ioe(e){let t=await JF(e);return qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),t}a(ioe,"createSchema");async function JF(e){let t=ud.schema_object(e);if(t)throw Nn(t,t.message,wn.BAD_REQUEST,void 0,void 0,!0);if(_d(e),!await dd.checkSchemaExists(e.schema))throw Nn(new Error,Gg.SCHEMA_EXISTS_ERR(e.schema),wn.BAD_REQUEST,fd.LOG_LEVELS.ERROR,Gg.SCHEMA_EXISTS_ERR(e.schema),!0);return await Fa.createSchema(e),`database '${e.schema}' successfully created`}a(JF,"createSchemaStructure");async function ooe(e){return _d(e),e.hash_attribute=e.primary_key??e.hash_attribute,await XF(e)}a(ooe,"createTable");async function XF(e){let t=ud.create_table_object(e);if(t)throw Nn(t,t.message,wn.BAD_REQUEST,void 0,void 0,!0);if(ud.validateTableResidence(e.residence),!await dd.checkSchemaTableExists(e.schema,e.table))throw Nn(new Error,Gg.TABLE_EXISTS_ERR(e.schema,e.table),wn.BAD_REQUEST,fd.LOG_LEVELS.ERROR,Gg.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:toe(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await Fa.createTable(n,e);else throw Nn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",wn.BAD_REQUEST);else await Fa.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(XF,"createTableStructure");async function aoe(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=ud.schema_object(e),n=t??r;if(n)throw Nn(n,n.message,wn.BAD_REQUEST,void 0,void 0,!0);_d(e);let s=await dd.checkSchemaExists(e.schema);if(s)throw Nn(new Error,s,wn.NOT_FOUND,fd.LOG_LEVELS.ERROR,s,!0);let i=await dd.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await Fa.dropSchema(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),await jF.purgeSchemaTableStreams(e.schema,o);let c=await QF(e);return c.message=`successfully deleted '${e.schema}'`,c}a(aoe,"dropSchema");async function coe(e){let t=ud.table_object(e);if(t)throw Nn(t,t.message,wn.BAD_REQUEST,void 0,void 0,!0);_d(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw Nn(new Error,r,wn.NOT_FOUND,fd.LOG_LEVELS.ERROR,r,!0);await Fa.dropTable(e),await jF.purgeTableStream(e.schema,e.table);let n=await QF(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(coe,"dropTable");async function loe(e){let t=ud.attribute_object(e);if(t)throw Nn(t,t.message,wn.BAD_REQUEST,void 0,void 0,!0);_d(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw Nn(new Error,r,wn.NOT_FOUND,fd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Nn(new Error,"You cannot drop a hash attribute",wn.BAD_REQUEST,void 0,void 0,!0);if(fd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Nn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,wn.BAD_REQUEST,void 0,void 0,!0);try{return await Fa.dropAttribute(e),uoe(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw eoe.error(`Got an error deleting attribute ${roe.inspect(e)}.`),n}}a(loe,"dropAttribute");function uoe(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(uoe,"dropAttributeFromGlobal");async function doe(e){_d(e);let t=soe()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Nn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,wn.BAD_REQUEST,void 0,void 0,!0);return await Fa.createAttribute(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(doe,"createAttribute");function foe(e){return Fa.getBackup(e)}a(foe,"getBackup")});var tG=w((fDe,eG)=>{"use strict";var{OPERATIONS_ENUM:_oe}=(H(),C(q)),AN=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=_oe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};eG.exports=AN});var RN=w((hDe,oG)=>{"use strict";var poe=Yn(),pDe=tG(),Kg=se(),Yg=(H(),C(q)),hoe=ae(),{handleHDBError:rG,hdb_errors:moe}=pe(),{HDB_ERROR_MSGS:nG,HTTP_STATUS_CODES:sG}=moe,Eoe=Object.values(Yg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),iG="To use this operation audit log must be enabled in harperdb-config.yaml";oG.exports=goe;async function goe(e){if(Kg.isEmpty(e.schema))throw new Error(nG.SCHEMA_REQUIRED_ERR);if(Kg.isEmpty(e.table))throw new Error(nG.TABLE_REQUIRED_ERR);if(!hoe.get(Yg.CONFIG_PARAMS.LOGGING_AUDITLOG))throw rG(new Error,iG,sG.BAD_REQUEST,Yg.LOG_LEVELS.ERROR,iG,!0);let t=Kg.checkSchemaTableExist(e.schema,e.table);if(t)throw rG(new Error,t,sG.NOT_FOUND,Yg.LOG_LEVELS.ERROR,t,!0);if(!Kg.isEmpty(e.search_type)&&Eoe.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await poe.readAuditLog(e)}a(goe,"readAuditLog")});var cG=w((EDe,aG)=>{"use strict";var{OPERATIONS_ENUM:Soe}=(H(),C(q)),yN=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Soe.GET_BACKUP,this.schema=t,this.table=r}};aG.exports=yN});var dG=w((ADe,uG)=>{"use strict";var Toe=Yn(),SDe=cG(),bN=se(),Aoe=(H(),C(q)),TDe=ae(),{handleHDBError:Roe,hdb_errors:yoe}=pe(),{HDB_ERROR_MSGS:lG,HTTP_STATUS_CODES:boe}=yoe;uG.exports=Ooe;async function Ooe(e){if(bN.isEmpty(e.schema))throw new Error(lG.SCHEMA_REQUIRED_ERR);if(bN.isEmpty(e.table))throw new Error(lG.TABLE_REQUIRED_ERR);let t=bN.checkSchemaTableExist(e.schema,e.table);if(t)throw Roe(new Error,t,boe.NOT_FOUND,Aoe.LOG_LEVELS.ERROR,t,!0);return await Toe.getBackup(read_audit_log_object)}a(Ooe,"getBackup")});var hG=w((yDe,pG)=>{"use strict";var Noe=ae(),Ga=require("joi"),woe=ft(),fG=require("moment"),Ioe=require("fs-extra"),ON=require("path"),Coe=require("lodash"),Sp=(H(),C(q)),{LOG_LEVELS:El}=(H(),C(q)),Poe="YYYY-MM-DD hh:mm:ss",Doe=ON.resolve(__dirname,"../logs");pG.exports=function(e){return woe.validateBySchema(e,Loe)};var Loe=Ga.object({from:Ga.custom(_G),until:Ga.custom(_G),level:Ga.valid(El.NOTIFY,El.FATAL,El.ERROR,El.WARN,El.INFO,El.DEBUG,El.TRACE),order:Ga.valid("asc","desc"),limit:Ga.number().min(1),start:Ga.number().min(0),log_name:Ga.custom(Moe)});function _G(e,t){if(fG(e,fG.ISO_8601).format(Poe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(_G,"validateDatetime");function Moe(e,t){if(Coe.invert(Sp.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Noe.get(Sp.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Sp.LOG_NAMES.HDB:e,i=s===Sp.LOG_NAMES.INSTALL?ON.join(Doe,Sp.LOG_NAMES.INSTALL):ON.join(n,s);return Ioe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Moe,"validateReadLogPath")});var wN=w((ODe,EG)=>{"use strict";var Wg=(H(),C(q)),voe=z(),Uoe=ae(),xoe=hG(),NN=require("path"),mG=require("fs-extra"),{once:Boe}=require("events"),{handleHDBError:Hoe,hdb_errors:koe}=pe(),{PACKAGE_ROOT:Foe}=st(),Goe=NN.join(Foe,"logs"),qoe=1e3,$oe=200;EG.exports=Voe;async function Voe(e){let t=xoe(e);if(t)throw Hoe(t,t.message,koe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Uoe.get(Wg.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Wg.LOG_NAMES.HDB:e.log_name,s=n===Wg.LOG_NAMES.INSTALL?NN.join(Goe,Wg.LOG_NAMES.INSTALL):NN.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,f=u?new Date(e.until):void 0,d=e.limit===void 0?qoe:e.limit,p=e.order===void 0?void 0:e.order,_=e.start===void 0?0:e.start,h=_+d,S=0;p==="desc"&&!l&&!f&&(S=Math.max(mG.statSync(s).size-(h+5)*$oe,0));let g=mG.createReadStream(s,{start:S});g.on("error",F=>{voe.error(F)});let R=0,E=[],A="",O;g.on("data",F=>{let G=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;F=A+F;let Y=0,te;for(;(te=G.exec(F))&&!g.destroyed;){O&&(O.message=F.slice(Y,te.index),v(O));let[ie,X,ne]=te,Q=ne.split("] ["),he=Q[0],Re=Q[1];Q.splice(0,2),O={timestamp:X,thread:he,level:Re,tags:Q,message:""},Y=te.index+ie.length}A=F.slice(Y)}),g.on("end",F=>{g.destroyed||O&&(O.message=A.trim(),v(O))}),g.resume();function v(F){let G,Y,te;switch(!0){case(i&&c&&u):G=new Date(F.timestamp),Y=new Date(l),te=new Date(f),F.level===o&&G>=Y&&G<=te&&R<_?R++:F.level===o&&G>=Y&&G<=te&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(i&&c):G=new Date(F.timestamp),Y=new Date(l),F.level===o&&G>=Y&&R<_?R++:F.level===o&&G>=Y&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(i&&u):G=new Date(F.timestamp),te=new Date(f),F.level===o&&G<=te&&R<_?R++:F.level===o&&G<=te&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(c&&u):G=new Date(F.timestamp),Y=new Date(l),te=new Date(f),G>=Y&&G<=te&&R<_?R++:G>=Y&&G<=te&&(qa(F,p,E),R++,R===h&&g.destroy());break;case i:F.level===o&&R<_?R++:F.level===o&&(qa(F,p,E),R++,R===h&&g.destroy());break;case c:G=new Date(F.timestamp),Y=new Date(l),G>=Y&&R<_?R++:G>=Y&&R>=_&&(qa(F,p,E),R++,R===h&&g.destroy());break;case u:G=new Date(F.timestamp),te=new Date(f),G<=te&&R<_?R++:G<=te&&R>=_&&(qa(F,p,E),R++,R===h&&g.destroy());break;default:R<_?R++:(qa(F,p,E),R++,R===h&&g.destroy())}}return a(v,"onLogMessage"),await Boe(g,"close"),E}a(Voe,"readLog");function qa(e,t,r){t==="desc"?Koe(e,r):t==="asc"?Yoe(e,r):r.push(e)}a(qa,"pushLineToResult");function Koe(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(Koe,"insertDescending");function Yoe(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(Yoe,"insertAscending")});var zg=w((DDe,AG)=>{"use strict";var IN=require("joi"),{string:pd,boolean:gG,date:Woe}=IN.types(),zoe=ft(),{validateSchemaExists:wDe,validateTableExists:IDe,validateSchemaName:CDe}=Mi(),joe=(H(),C(q)),Qoe=Tt(),SG=ae();SG.initSync();var PDe=pd.invalid(SG.get(joe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(Qoe.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),TG={operation:pd.valid("add_node","update_node","set_node_replication"),node_name:pd.optional(),subscriptions:IN.array().items({table:pd.optional(),schema:pd.optional(),database:pd.optional(),subscribe:gG.required(),publish:gG.required().custom(Xoe),start_time:Woe.iso()})};function Joe(e){return zoe.validateBySchema(e,IN.object(TG))}a(Joe,"addUpdateNodeValidator");function Xoe(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(Xoe,"checkForFalsy");AG.exports={addUpdateNodeValidator:Joe,validation_schema:TG}});var hd=w((MDe,RG)=>{"use strict";var CN=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},PN=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};RG.exports={Node:CN,NodeSubscription:PN}});var bG=w((UDe,yG)=>{"use strict";var Zoe=(H(),C(q)).OPERATIONS_ENUM,DN=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Zoe.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};yG.exports=DN});var Tp=w((BDe,OG)=>{"use strict";var LN=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},MN=class{static{a(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,o,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=o,c!==void 0&&(this.attributes=c)}};OG.exports={RemotePayloadObject:LN,RemotePayloadSubscription:MN}});var wG=w((kDe,NG)=>{"use strict";var vN=class{static{a(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=n,this.record_count=s,this.transaction_log_size=i,this.transaction_log_record_count=o}};NG.exports=vN});var CG=w((KDe,IG)=>{"use strict";var eae=wG(),GDe=vt(),qDe=_t(),tae=z(),{getSchemaPath:$De,getTransactionAuditStorePath:VDe}=gt(),{getDatabases:rae}=(Pe(),C(tt));IG.exports=nae;async function nae(e){let t=new eae;try{let r=rae()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){tae.warn(`unable to stat table dbi due to ${r}`)}return t}a(nae,"lmdbGetTableSize")});var DG=w((WDe,PG)=>{"use strict";var UN=class{static{a(this,"SystemInformationObject")}constructor(t,r,n,s,i,o,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=o,this.harperdb_processes=c}};PG.exports=UN});var Do=w((ZDe,UG)=>{"use strict";var sae=require("fs-extra"),iae=require("path"),Xr=require("systeminformation"),$a=z(),LG=or(),jDe=Tt(),md=(H(),C(q)),oae=CG(),aae=Ao(),{getThreadInfo:MG}=et(),Ap=ae();Ap.initSync();var cae=DG(),{openEnvironment:QDe}=_t(),{getSchemaPath:JDe}=gt(),{database:XDe,databases:xN}=(Pe(),C(tt)),jg;UG.exports={getHDBProcessInfo:FN,getNetworkInfo:qN,getDiskInfo:GN,getMemoryInfo:kN,getCPUInfo:HN,getTimeInfo:BN,getSystemInformation:$N,systemInformation:lae,getTableSize:VN,getMetrics:KN};function BN(){return Xr.time()}a(BN,"getTimeInfo");async function HN(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...f}=await Xr.cpu();f.cpu_speed=await Xr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:p,raw_currentload_irq:_,raw_currentload_nice:h,raw_currentload_system:S,raw_currentload_user:g,cpus:R,...E}=await Xr.currentLoad();return E.cpus=[],R.forEach(A=>{let{raw_load:O,raw_load_idle:v,raw_load_irq:F,raw_load_nice:G,raw_load_system:Y,raw_load_user:te,...ie}=A;E.cpus.push(ie)}),f.current_load=E,f}catch(e){return $a.error(`error in getCPUInfo: ${e}`),{}}}a(HN,"getCPUInfo");async function kN(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Xr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return $a.error(`error in getMemoryInfo: ${e}`),{}}}a(kN,"getMemoryInfo");async function FN(){let e={core:[],clustering:[]};try{let t=await Xr.processes(),r;try{r=Number.parseInt(await sae.readFile(iae.join(Ap.get(md.CONFIG_PARAMS.ROOTPATH),md.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===md.NODE_ERROR_CODES.ENOENT)$a.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return $a.error(`error in getHDBProcessInfo: ${t}`),e}}a(FN,"getHDBProcessInfo");async function GN(){let e={};try{if(!Ap.get(md.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Xr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Xr.fsStats();return e.read_write=u,e.size=await Xr.fsSize(),e}catch(t){return $a.error(`error in getDiskInfo: ${t}`),e}}a(GN,"getDiskInfo");async function qN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Ap.get(md.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Xr.networkInterfaceDefault(),e.latency=await Xr.inetChecksite("google.com"),(await Xr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:f,carrier_changes:d,...p}=n;e.interfaces.push(p)}),(await Xr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return $a.error(`error in getNetworkInfo: ${t}`),e}}a(qN,"getNetworkInfo");async function $N(){if(jg!==void 0)return jg;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Xr.osInfo();e=c;let l=await Xr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,jg=e,jg}catch(t){return $a.error(`error in getSystemInformation: ${t}`),e}}a($N,"getSystemInformation");async function VN(){let e=[],t=await aae.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await oae(n));return e}a(VN,"getTableSize");async function KN(){let e={};for(let t in xN){let r=e[t]={},n=r.tables={};for(let s in xN[t])try{let i=xN[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,f,d]=l.trim().split(" ");return{pid:u,thread:f,txnid:d}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){$a.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(KN,"getMetrics");async function vG(){if(Ap.get(md.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await LG.getNATSReferences(),t=await LG.listStreams(),r=[];for(let n of t){let s=[],i=await e.consumers.list(n.config.name);for await(let c of i)s.push({name:c.name,created:c.created,num_ack_pending:c.num_ack_pending,num_redelivered:c.num_redelivered,num_waiting:c.num_waiting,num_pending:c.num_pending});let o={stream_name:n.config.name,database:n.config.subjects[0].split(".")[1],table:n.config.subjects[0].split(".")[2],state:n.state,consumers:s};r.push(o)}return r}}a(vG,"getNatsStreamInfo");async function lae(e){let t=new cae;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await $N(),t.time=BN(),t.cpu=await HN(),t.memory=await kN(),t.disk=await GN(),t.network=await qN(),t.harperdb_processes=await FN(),t.table_size=await VN(),t.metrics=await KN(),t.threads=await MG(),t.replication=await vG(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await $N();break;case"time":t.time=BN();break;case"cpu":t.cpu=await HN();break;case"memory":t.memory=await kN();break;case"disk":t.disk=await GN();break;case"network":t.network=await qN();break;case"harperdb_processes":t.harperdb_processes=await FN();break;case"table_size":t.table_size=await VN();break;case"database_metrics":case"metrics":t.metrics=await KN();break;case"threads":t.threads=await MG();break;case"replication":t.replication=await vG();break;default:break}return t}a(lae,"systemInformation")});var Lo=w((nLe,kG)=>{"use strict";var uae=Rn(),YN=se(),dae=require("util"),gl=(H(),C(q)),xG=ae();xG.initSync();var fae=OO(),BG=Yr(),{Node:tLe,NodeSubscription:rLe}=hd(),_ae=Hu(),pae=bG(),{RemotePayloadObject:hae,RemotePayloadSubscription:mae}=Tp(),{handleHDBError:Eae,hdb_errors:gae}=pe(),{HTTP_STATUS_CODES:Sae,HDB_ERROR_MSGS:Tae}=gae,Aae=si(),Rae=Do(),{packageJson:yae}=st(),{getDatabases:bae}=(Pe(),C(tt)),Oae=dae.promisify(fae.authorize),Nae=BG.searchByHash,wae=BG.searchByValue;kG.exports={authHeaderToUser:Iae,isEmpty:Cae,getNodeRecord:Pae,upsertNodeRecord:Dae,buildNodePayloads:Lae,checkClusteringEnabled:Mae,getAllNodeRecords:vae,getSystemInfo:Uae,reverseSubscription:HG};async function Iae(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Oae(t,null),e}a(Iae,"authHeaderToUser");function Cae(e){return e==null}a(Cae,"isEmpty");async function Pae(e){let t=new _ae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Nae(t)}a(Pae,"getNodeRecord");async function Dae(e){let t=new pae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return uae.upsert(t)}a(Dae,"upsertNodeRecord");function HG(e){if(YN.isEmpty(e.subscribe)||YN.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:n}=e,s={schema:t,table:r,hash_attribute:n};return e.subscribe===!0&&e.publish===!1?(s.subscribe=!1,s.publish=!0):e.subscribe===!1&&e.publish===!0?(s.subscribe=!0,s.publish=!1):(s.subscribe=e.subscribe,s.publish=e.publish),s}a(HG,"reverseSubscription");function Lae(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,f=YN.getTableHashAttribute(l,u),{subscribe:d,publish:p}=HG(c),_=bae()[l]?.[u],h=new mae(l,u,f,p,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(h)}return new hae(r,t,s,n)}a(Lae,"buildNodePayloads");function Mae(){if(!xG.get(gl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Eae(new Error,Tae.CLUSTERING_NOT_ENABLED,Sae.BAD_REQUEST,void 0,void 0,!0)}a(Mae,"checkClusteringEnabled");async function vae(){let e=new Aae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await wae(e))}a(vae,"getAllNodeRecords");async function Uae(){let e=await Rae.getSystemInformation();return{hdb_version:yae.version,node_version:e.node_version,platform:e.platform}}a(Uae,"getSystemInfo")});var WN=w((iLe,WG)=>{"use strict";var Qg=or(),FG=se(),GG=Tt(),qG=(H(),C(q)),Jg=z(),$G=Vg(),xae=x_(),{RemotePayloadObject:Bae}=Tp(),{handleHDBError:VG,hdb_errors:Hae}=pe(),{HTTP_STATUS_CODES:KG}=Hae,{NodeSubscription:YG}=hd();WG.exports=kae;async function kae(e,t){let r;try{r=await Qg.request(`${t}.${GG.REQUEST_SUFFIX}`,new Bae(qG.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Jg.trace("Response from remote describe all request:",r)}catch(o){Jg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Qg.requestErrorHandler(o,"add_node",t);throw VG(new Error,c,KG.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===GG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw VG(new Error,o,KG.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,l=o.database??o.schema??"data";if(l===qG.SYSTEM_SCHEMA_NAME){await Qg.createLocalTableStream(l,c);let h=new YG(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=FG.doesSchemaExist(l),f=n[l]!==void 0,d=c?FG.doesTableExist(l,c):!0,p=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!f||!d&&!p){s.push(o);continue}if(!u&&f&&(Jg.trace(`addNode creating schema: ${l}`),await $G.createSchema({operation:"create_schema",schema:l})),!d&&p){Jg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new xae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await $G.createTable(h)}await Qg.createLocalTableStream(l,c);let _=new YG(l,c,o.publish,o.subscribe);_.start_time=o.start_time,i.push(_)}return{added:i,skipped:s}}a(kae,"reviewSubscriptions")});var Sl={};ve(Sl,{addNodeBack:()=>Vae,removeNodeBack:()=>Kae,setNode:()=>$ae});async function $ae(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=ci(t)):t=Fg(r);let n=(0,jG.validateBySchema)(e,qae);if(n)throw(0,Mo.handleHDBError)(n,n.message,Gae.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Mo.ClientError("url or hostname is required for remove_node operation");let _=r,h=ar(),S=await h.get(_);if(!S)throw new Mo.ClientError(_+" does not exist");try{await gp({url:S.url},{operation:Vt.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Xe():_},void 0)}catch(g){rs.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await h.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Mo.ClientError("url required for this operation");let s=Ma();if(s==null)throw new Mo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,Is.getReplicationCert)();let _=await(0,Is.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,Is.createCsr)(),rs.info("Sending CSR to target node:",t)):_&&(c=_.certificate,rs.info("Sending CA named",_.name,"to target node",t))}let l={operation:Vt.ADD_NODE_BACK,hostname:(0,QG.get)(B.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if(e.subscriptions?l.subscriptions=e.subscriptions.map(zG):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=zG(e);l.subscribe=_.subscribe,l.publish=_.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,f;try{u=await gp({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,rs.warn("Error adding node:",t,"to cluster:",_),f=_}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw f?(f.message+=" and connection was required to sign certificate",f):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&(rs.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Is.setCertTable)({name:Fae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Is.setCertTable)({name:Xe(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let d={url:t,ca:u?.usingCA};if(e.hostname&&(d.name=e.hostname),e.subscriptions?d.subscriptions=e.subscriptions:d.replicates=!0,e.start_time&&(d.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(d.authorization=e.authorization),e.revoked_certificates&&(d.revoked_certificates=e.revoked_certificates),e.shard&&(d.shard=e.shard),d.replicates){let _={url:s,ca:c,replicates:!0,subscriptions:null};e.retain_authorization&&(_.authorization=e.authorization),e.start_time&&(_.start_time=e.start_time),await Io(Xe(),_)}await Io(u?u.nodeName:d.name??ci(t),d);let p;return e.operation==="update_node"?p=`Successfully updated '${t}'`:p=`Successfully added '${t}' to cluster`,f&&(p+=" but there was an error updating target node: "+f.message),p}async function Vae(e){rs.trace("addNodeBack received request:",e);let t=await(0,Is.signCertificate)(e),r;e.csr?(r=t.signingCA,rs.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,rs.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization);let s=await(0,Is.getReplicationCertAuth)();if(n.replicates){let i={url:Ma(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Io(Xe(),i)}return await Io(e.hostname,n),t.nodeName=Xe(),t.usingCA=s?.certificate,rs.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Kae(e){rs.trace("removeNodeBack received request:",e),await ar().delete(e.name)}function zG(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Is,jG,Va,QG,rs,Mo,Fae,Gae,qae,Tl=be(()=>{Is=M(ts()),jG=M(ft()),Va=M(require("joi")),QG=M(ae());H();dp();ul();es();rs=M(z()),Mo=M(pe()),{pki:Fae}=require("node-forge"),{HTTP_STATUS_CODES:Gae}=Mo.hdb_errors,qae=Va.default.object({hostname:Va.default.string(),verify_tls:Va.default.boolean(),replicates:Va.default.boolean(),subscriptions:Va.default.array(),revoked_certificates:Va.default.array(),shard:Va.default.number()});a($ae,"setNode");a(Vae,"addNodeBack");a(Kae,"removeNodeBack");a(zG,"reverseSubscription")});var Ed=w((pLe,XG)=>{"use strict";var{handleHDBError:Xg,hdb_errors:Yae}=pe(),{HTTP_STATUS_CODES:Zg}=Yae,{addUpdateNodeValidator:Wae}=zg(),eS=z(),tS=(H(),C(q)),JG=Tt(),zae=se(),Rp=or(),yp=Lo(),zN=ae(),jae=WN(),{Node:Qae,NodeSubscription:Jae}=hd(),{broadcast:Xae}=et(),{setNode:Zae}=(Tl(),C(Sl)),fLe=ae(),_Le=(H(),C(q)),ece="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",tce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",rce=zN.get(tS.CONFIG_PARAMS.CLUSTERING_NODENAME);XG.exports=nce;async function nce(e,t=!1){if(eS.trace("addNode called with:",e),zN.get(tS.CONFIG_PARAMS.REPLICATION_URL)||zN.get(tS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Zae(e);yp.checkClusteringEnabled();let r=Wae(e);if(r)throw Xg(r,r.message,Zg.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await yp.getNodeRecord(n);if(!zae.isEmptyOrZeroLength(d))throw Xg(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Zg.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await jae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=ece,o;let c=yp.buildNodePayloads(s,rce,tS.OPERATIONS_ENUM.ADD_NODE,await yp.getSystemInfo()),l=[];for(let d=0,p=s.length;d<p;d++){let _=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new Jae(_.schema,_.table,_.publish,_.subscribe))}eS.trace("addNode sending remote payload:",c);let u;try{u=await Rp.request(`${n}.${JG.REQUEST_SUFFIX}`,c)}catch(d){eS.error(`addNode received error from request: ${d}`);for(let _=0,h=s.length;_<h;_++){let S=s[_];S.publish=!1,S.subscribe=!1,await Rp.updateRemoteConsumer(S,n)}let p=Rp.requestErrorHandler(d,"add_node",n);throw Xg(new Error,p,Zg.INTERNAL_SERVER_ERROR,"error",p)}if(u.status===JG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw Xg(new Error,d,Zg.INTERNAL_SERVER_ERROR,"error",d)}eS.trace(u);for(let d=0,p=s.length;d<p;d++){let _=s[d];await Rp.updateRemoteConsumer(_,n),_.subscribe===!0&&await Rp.updateConsumerIterator(_.schema,_.table,n,"start")}let f=new Qae(n,l,u.system_info);return await yp.upsertNodeRecord(f),Xae({type:"nats_update"}),i.length>0?o.message=tce:o.message=`Successfully added '${n}' to manifest`,o}a(nce,"addNode")});var XN=w((ELe,eq)=>{"use strict";var{handleHDBError:jN,hdb_errors:sce}=pe(),{HTTP_STATUS_CODES:QN}=sce,{addUpdateNodeValidator:ice}=zg(),bp=z(),rS=(H(),C(q)),ZG=Tt(),mLe=se(),Op=or(),Np=Lo(),JN=ae(),{cloneDeep:oce}=require("lodash"),ace=WN(),{Node:cce,NodeSubscription:lce}=hd(),{broadcast:uce}=et(),{setNode:dce}=(Tl(),C(Sl)),fce="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",_ce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",pce=JN.get(rS.CONFIG_PARAMS.CLUSTERING_NODENAME);eq.exports=hce;async function hce(e){if(bp.trace("updateNode called with:",e),JN.get(rS.CONFIG_PARAMS.REPLICATION_URL)??JN.get(rS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return dce(e);Np.checkClusteringEnabled();let t=ice(e);if(t)throw jN(t,t.message,QN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Np.getNodeRecord(r);s.length>0&&(n=oce(s));let{added:i,skipped:o}=await ace(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=fce,c;let l=Np.buildNodePayloads(i,pce,rS.OPERATIONS_ENUM.UPDATE_NODE,await Np.getSystemInfo());for(let f=0,d=i.length;f<d;f++){let p=i[f];bp.trace(`updateNode updating work stream for node: ${r} subscription:`,p),i[f].start_time===void 0&&delete i[f].start_time}bp.trace("updateNode sending remote payload:",l);let u;try{u=await Op.request(`${r}.${ZG.REQUEST_SUFFIX}`,l)}catch(f){bp.error(`updateNode received error from request: ${f}`);let d=Op.requestErrorHandler(f,"update_node",r);throw jN(new Error,d,QN.INTERNAL_SERVER_ERROR,"error",d)}if(u.status===ZG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${r}: ${u.message}`;throw jN(new Error,f,QN.INTERNAL_SERVER_ERROR,"error",f)}bp.trace(u);for(let f=0,d=i.length;f<d;f++){let p=i[f];await Op.updateRemoteConsumer(p,r),p.subscribe===!0?await Op.updateConsumerIterator(p.schema,p.table,r,"start"):await Op.updateConsumerIterator(p.schema,p.table,r,"stop")}return n||(n=[new cce(r,[],u.system_info)]),await mce(n[0],i,u.system_info),o.length>0?c.message=_ce:c.message=`Successfully updated '${r}'`,c}a(hce,"updateNode");async function mce(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let f=n.subscriptions[l];if(f.schema===o.schema&&f.table===o.table){f.publish=o.publish,f.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new lce(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Np.upsertNodeRecord(n),uce({type:"nats_update"})}a(mce,"updateNodeTable")});var iq=w((SLe,sq)=>{"use strict";var nq=require("joi"),{string:tq}=nq.types(),Ece=ft(),rq=(H(),C(q)),gce=ae(),Sce=Tt();sq.exports=Tce;function Tce(e){let t=tq.invalid(gce.get(rq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Sce.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=nq.object({operation:tq.valid(rq.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return Ece.validateBySchema(e,r)}a(Tce,"removeNodeValidator")});var nS=w((ALe,uq)=>{"use strict";var{handleHDBError:oq,hdb_errors:Ace}=pe(),{HTTP_STATUS_CODES:aq}=Ace,Rce=iq(),wp=z(),cq=Lo(),yce=se(),gd=(H(),C(q)),lq=Tt(),ZN=or(),ew=ae(),{RemotePayloadObject:bce}=Tp(),{NodeSubscription:Oce}=hd(),Nce=U_(),wce=Vc(),{broadcast:Ice}=et(),{setNode:Cce}=(Tl(),C(Sl)),Pce=ew.get(gd.CONFIG_PARAMS.CLUSTERING_NODENAME);uq.exports=Dce;async function Dce(e){if(wp.trace("removeNode called with:",e),ew.get(gd.CONFIG_PARAMS.REPLICATION_URL)??ew.get(gd.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Cce(e);cq.checkClusteringEnabled();let t=Rce(e);if(t)throw oq(t,t.message,aq.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await cq.getNodeRecord(r);if(yce.isEmptyOrZeroLength(n))throw oq(new Error,`Node '${r}' was not found.`,aq.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new bce(gd.OPERATIONS_ENUM.REMOVE_NODE,Pce,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await ZN.updateConsumerIterator(f.schema,f.table,r,"stop");try{await ZN.updateRemoteConsumer(new Oce(f.schema,f.table,!1,!1),r)}catch(d){wp.error(d)}}try{i=await ZN.request(`${r}.${lq.REQUEST_SUFFIX}`,s),wp.trace("Remove node reply from remote node:",r,i)}catch(l){wp.error("removeNode received error from request:",l),o=!0}let c=new Nce(gd.SYSTEM_SCHEMA_NAME,gd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await wce.deleteRecord(c),Ice({type:"nats_update"}),i?.status===lq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(wp.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(Dce,"removeNode")});var _q=w((yLe,fq)=>{"use strict";var dq=require("joi"),{string:Lce,array:Mce}=dq.types(),vce=ft(),Uce=zg();fq.exports=xce;function xce(e){let t=dq.object({operation:Lce.valid("configure_cluster").required(),connections:Mce.items(Uce.validation_schema).required()});return vce.validateBySchema(e,t)}a(xce,"configureClusterValidator")});var tw=w((OLe,gq)=>{"use strict";var pq=(H(),C(q)),sS=z(),Bce=se(),Hce=ae(),kce=nS(),Fce=Ed(),Gce=Lo(),qce=_q(),{handleHDBError:hq,hdb_errors:$ce}=pe(),{HTTP_STATUS_CODES:mq}=$ce,Vce="Configure cluster complete.",Kce="Failed to configure the cluster. Check the logs for more details.",Yce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";gq.exports=Wce;async function Wce(e){sS.trace("configure cluster called with:",e);let t=qce(e);if(t)throw hq(t,t.message,mq.BAD_REQUEST,void 0,void 0,!0);let r=await Gce.getAllNodeRecords(),n=[];if(Hce.get(pq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let p=await Eq(kce,{operation:pq.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name);n.push(p)}sS.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let f=0;f<i;f++){let d=e.connections[f],p=await Eq(Fce,d,d.node_name);s.push(p)}sS.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let f=0,d=u.length;f<d;f++){let p=u[f];p.status==="rejected"&&(sS.error(p.node_name,p?.error?.message,p?.error?.stack),o.includes(p.node_name)||o.push(p.node_name)),(p?.result?.message?.includes?.("Successfully")||p?.result?.includes?.("Successfully"))&&(l=!0),!(typeof p.result=="string"&&p.result.includes("Successfully removed")||p.status==="rejected")&&c.push({node_name:p?.node_name,response:p?.result})}if(Bce.isEmptyOrZeroLength(o))return{message:Vce,connections:c};if(l)return{message:Yce,failed_nodes:o,connections:c};throw hq(new Error,Kce,mq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Wce,"configureCluster");async function Eq(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(Eq,"functionWrapper")});var Rq=w((wLe,Aq)=>{"use strict";var Ip=require("joi"),zce=ft(),{validateSchemaExists:Sq,validateTableExists:jce,validateSchemaName:Tq}=Mi(),Qce=Ip.object({operation:Ip.string().valid("purge_stream"),schema:Ip.string().custom(Sq).custom(Tq).optional(),database:Ip.string().custom(Sq).custom(Tq).optional(),table:Ip.string().custom(jce).required()});function Jce(e){return zce.validateBySchema(e,Qce)}a(Jce,"purgeStreamValidator");Aq.exports=Jce});var rw=w((CLe,yq)=>{"use strict";var{handleHDBError:Xce,hdb_errors:Zce}=pe(),{HTTP_STATUS_CODES:ele}=Zce,tle=Rq(),rle=or(),nle=Lo();yq.exports=sle;async function sle(e){e.schema=e.schema??e.database;let t=tle(e);if(t)throw Xce(t,t.message,ele.BAD_REQUEST,void 0,void 0,!0);nle.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await rle.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(sle,"purgeStream")});var aS=w((DLe,Pq)=>{"use strict";var sw=Lo(),ile=or(),oS=ae(),Sd=(H(),C(q)),Al=Tt(),ole=se(),nw=z(),{RemotePayloadObject:ale}=Tp(),{ErrorCode:bq}=require("nats"),{parentPort:Oq}=require("worker_threads"),{onMessageByType:cle}=et(),{getThisNodeName:lle}=(es(),C(Po)),{requestClusterStatus:ule}=(dp(),C(zk)),{getReplicationSharedStatus:dle}=(ul(),C(WO)),{CONFIRMATION_STATUS_POSITION:fle,RECEIVED_VERSION_POSITION:_le,RECEIVED_TIME_POSITION:ple,SENDING_TIME_POSITION:hle}=(EN(),C(xF)),Nq=oS.get(Sd.CONFIG_PARAMS.CLUSTERING_ENABLED),wq=oS.get(Sd.CONFIG_PARAMS.CLUSTERING_NODENAME);Pq.exports={clusterStatus:mle,buildNodeStatus:Cq};var Iq;cle("cluster-status",async e=>{Iq(e)});async function mle(){if(oS.get(Sd.CONFIG_PARAMS.REPLICATION_URL)||oS.get(Sd.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(Oq){Oq.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{Iq=s});for(let s of n.connections){let i=s.name;for(let o of s.database_sockets){let c=o.database,l;for(let f of Object.values(databases[c]||{}))if(l=f.auditStore,l)break;if(!l)continue;let u=dle(l,c,i);o.lastCommitConfirmed=iS(u[fle]),o.lastReceivedRemoteTime=iS(u[_le]),o.lastReceivedLocalTime=iS(u[ple]),o.sendingMessage=iS(u[hle])}}}else n=ule();return n.node_name=lle(),n.is_enabled=!0,n}let e={node_name:wq,is_enabled:Nq,connections:[]};if(!Nq)return e;let t=await sw.getAllNodeRecords();if(ole.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Cq(t[n],e.connections));return await Promise.allSettled(r),e}a(mle,"clusterStatus");function iS(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}a(iS,"asDate");async function Cq(e,t){let r=e.name,n=new ale(Sd.OPERATIONS_ENUM.CLUSTER_STATUS,wq,void 0,await sw.getSystemInfo()),s,i,o=Al.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await ile.request(Al.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Al.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Al.CLUSTER_STATUS_STATUSES.CLOSED,nw.error(`Error getting node status from ${r} `,s))}catch(l){nw.warn(`Error getting node status from ${r}`,l),l.code===bq.NoResponders?o=Al.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===bq.Timeout?o=Al.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Al.CLUSTER_STATUS_STATUSES.CLOSED}let c=new Ele(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Sd.PRE_4_0_0_VERSION&&await sw.upsertNodeRecord(l)}catch(l){nw.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Cq,"buildNodeStatus");function Ele(e,t,r,n,s,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=o,this.system_info=c}a(Ele,"NodeStatusObject")});var lS=w((MLe,Dq)=>{"use strict";var{handleHDBError:gle,hdb_errors:Sle}=pe(),{HTTP_STATUS_CODES:Tle}=Sle,Ale=or(),Rle=Lo(),iw=se(),cS=require("joi"),yle=ft(),ble=2e3,Ole=cS.object({timeout:cS.number().min(1),connected_nodes:cS.boolean(),routes:cS.boolean()});Dq.exports=Nle;async function Nle(e){Rle.checkClusteringEnabled();let t=yle.validateBySchema(e,Ole);if(t)throw gle(t,t.message,Tle.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||iw.autoCastBoolean(n),o=s===void 0||iw.autoCastBoolean(s),c={nodes:[]},l=await Ale.getServerList(r??ble),u={};if(i)for(let f=0,d=l.length;f<d;f++){let p=l[f].statsz;p&&(u[l[f].server.name]=p.routes)}for(let f=0,d=l.length;f<d;f++){if(l[f].statsz)continue;let p=l[f].server,_=l[f].data;if(p.name.endsWith("-hub")){let h={name:p.name.slice(0,-4),response_time:l[f].response_time};i&&(h.connected_nodes=[],u[p.name]&&u[p.name].forEach(S=>{h.connected_nodes.includes(S.name.slice(0,-4))||h.connected_nodes.push(S.name.slice(0,-4))})),o&&(h.routes=_.cluster?.urls?_.cluster?.urls.map(S=>({host:S.split(":")[0],port:iw.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(Nle,"clusterNetwork")});var Uq=w((ULe,vq)=>{"use strict";var ow=require("joi"),Lq=ft(),{route_constraints:Mq}=Vy();vq.exports={setRoutesValidator:wle,deleteRoutesValidator:Ile};function wle(e){let t=ow.object({server:ow.valid("hub","leaf"),routes:Mq.required()});return Lq.validateBySchema(e,t)}a(wle,"setRoutesValidator");function Ile(e){let t=ow.object({routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Ile,"deleteRoutesValidator")});var uS=w((BLe,qq)=>{"use strict";var vo=yt(),aw=se(),Cs=(H(),C(q)),Td=ae(),xq=Uq(),{handleHDBError:Bq,hdb_errors:Cle}=pe(),{HTTP_STATUS_CODES:Hq}=Cle,kq="cluster routes successfully set",Fq="cluster routes successfully deleted";qq.exports={setRoutes:Dle,getRoutes:Lle,deleteRoutes:Mle};function Ple(e){let t=vo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=aw.autoCast(l.port);let u=r.some(d=>d.host===l.host&&d.port===l.port),f=n.some(d=>d.host===l.host&&d.port===l.port);u||f?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?vo.updateConfigValue(Cs.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):vo.updateConfigValue(Cs.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:kq,set:i,skipped:s}}a(Ple,"setRoutesNats");function Dle(e){let t=xq.setRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Td.get(Cs.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ple(e);let r=[],n=[],s=Td.get(Cs.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Gq(s,i)?n.push(i):(s.push(i),r.push(i))}),vo.updateConfigValue(Cs.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:kq,set:r,skipped:n}}a(Dle,"setRoutes");function Gq(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(Gq,"existsInArray");function Lle(){if(Td.get(Cs.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=vo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Td.get(Cs.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Lle,"getRoutes");function Mle(e){let t=xq.deleteRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Td.get(Cs.CONFIG_PARAMS.CLUSTERING_ENABLED))return vle(e);let r=[],n=[],s=Td.get(Cs.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Gq(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),vo.updateConfigValue(Cs.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Fq,deleted:r,skipped:n}}a(Mle,"deleteRoutes");function vle(e){let t=vo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let f=e.routes[l],d=!1;for(let p=0,_=r.length;p<_;p++){let h=r[p];if(f.host===h.host&&f.port===h.port){r.splice(p,1),d=!0,o=!0,s.push(f);break}}if(!d){let p=!0;for(let _=0,h=n.length;_<h;_++){let S=n[_];if(f.host===S.host&&f.port===S.port){n.splice(_,1),c=!0,p=!1,s.push(f);break}}p&&i.push(f)}}return o&&(r=aw.isEmptyOrZeroLength(r)?null:r,vo.updateConfigValue(Cs.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=aw.isEmptyOrZeroLength(n)?null:n,vo.updateConfigValue(Cs.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Fq,deleted:s,skipped:i}}a(vle,"deleteRoutesNats")});var Vq=w((kLe,$q)=>{"use strict";var Cp=require("alasql"),Rl=require("recursive-iterator"),di=z(),Ule=se(),Pp=(H(),C(q)),cw=class{static{a(this,"sql_statement_bucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,Ble(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>Pp.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!Pp.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,o=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][Pp.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=xle(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!Pp.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let f=new Cp.yy.Column({columnid:u});s.tableid&&(f.tableid=s.tableid),this.ast.columns.push(f),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function xle(e){return e.filter(t=>t[Pp.PERMS_CRUD_ENUM.READ])}a(xle,"filterReadRestrictedAttrs");function Ble(e,t,r,n,s){Hle(e,t,r,n,s)}a(Ble,"interpretAST");function Dp(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),s.set(o,i)}}a(Dp,"addSchemaTableToMap");function Hle(e,t,r,n,s){if(!e){di.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Cp.yy.Insert?qle(e,t,r):e instanceof Cp.yy.Select?kle(e,t,r,n,s):e instanceof Cp.yy.Update?Fle(e,t,r):e instanceof Cp.yy.Delete?Gle(e,t,r):di.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(Hle,"getRecordAttributesAST");function kle(e,t,r,n,s){if(!e){di.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Ule.isEmptyOrZeroLength(i)){di.error("No schema specified");return}e.from.forEach(c=>{Dp(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Dp(c.table,t,r,n,s)});let o=new Rl(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{di.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Rl(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let f=u.tableid?u.tableid:l;if(!t.get(i).has(f))if(r.has(f))f=r.get(f);else{di.info(`table specified as ${f} not found.`);continue}t.get(i).get(f).indexOf(u.columnid)<0&&t.get(i).get(f).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Rl(c.on);for(let{node:u}of l)if(u&&u.columnid){let f=u.tableid,d=s.get(f);if(!t.get(d).has(f))if(r.has(f))f=r.get(f);else{di.info(`table specified as ${f} not found.`);continue}t.get(d).get(f).indexOf(u.columnid)<0&&t.get(d).get(f).push(u.columnid)}}),e.order){let c=new Rl(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,f=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(f).has(u))if(r.has(u))u=r.get(u);else{di.info(`table specified as ${u} not found.`);return}t.get(f).get(u).indexOf(l.columnid)<0&&t.get(f).get(u).push(l.columnid)}}}a(kle,"getSelectAttributes");function Fle(e,t,r){if(!e){di.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Rl(e.columns),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&lw(e.table.tableid,s,i.columnid,t,r)}a(Fle,"getUpdateAttributes");function Gle(e,t,r){if(!e){di.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Rl(e.where),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&lw(e.table.tableid,s,i.columnid,t,r)}a(Gle,"getDeleteAttributes");function qle(e,t,r){if(!e){di.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Rl(e.columns),s=e.into.databaseid;Dp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&lw(e.into.tableid,s,i.columnid,t,r)}a(qle,"getInsertAttributes");function lw(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}a(lw,"pushAttribute");$q.exports=cw});var Yq=w((GLe,Kq)=>{"use strict";var dS=(H(),C(q)),fS=class{static{a(this,"BaseLicense")}constructor(t=0,r=dS.RAM_ALLOCATION_ENUM.DEFAULT,n=dS.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},uw=class extends fS{static{a(this,"ExtendedLicense")}constructor(t=0,r=dS.RAM_ALLOCATION_ENUM.DEFAULT,n=dS.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};Kq.exports={BaseLicense:fS,ExtendedLicense:uw}});var yd=w(($Le,Xq)=>{"use strict";var Rd=require("fs-extra"),_S=(hE(),C(pE)),zq=require("crypto"),$le=require("moment"),Vle=require("uuid").v4,Zr=z(),fw=require("path"),Kle=se(),yl=(H(),C(q)),{totalmem:Wq}=require("os"),Yle=Yq().ExtendedLicense,Ad="invalid license key format",Wle="061183",zle="mofi25",jle="aes-256-cbc",Qle=16,Jle=32,jq=ae(),{resolvePath:Qq}=yt();jq.initSync();var dw;Xq.exports={validateLicense:Jq,generateFingerPrint:Zle,licenseSearch:hw,getLicense:rue,checkMemoryLimit:nue};function _w(){return fw.join(jq.getHdbBasePath(),yl.LICENSE_KEY_DIR_NAME,yl.LICENSE_FILE_NAME)}a(_w,"getLicenseDirPath");function Xle(){let e=_w();return Qq(fw.join(e,yl.LICENSE_FILE_NAME))}a(Xle,"getLicenseFilePath");function pw(){let e=_w();return Qq(fw.join(e,yl.REG_KEY_FILE_NAME))}a(pw,"getFingerPrintFilePath");async function Zle(){let e=pw();try{return await Rd.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await eue();throw Zr.error(`Error writing fingerprint file to ${e}`),Zr.error(t),new Error("There was an error generating the fingerprint")}}a(Zle,"generateFingerPrint");async function eue(){let e=Vle(),t=_S.hash(e,_S.HASH_FUNCTION.MD5),r=pw();try{await Rd.mkdirp(_w()),await Rd.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Zr.error(`Error writing fingerprint file to ${r}`),Zr.error(n),new Error("There was an error generating the fingerprint")}return t}a(eue,"writeFingerprint");function Jq(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:yl.RAM_ALLOCATION_ENUM.DEFAULT,version:yl.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Zr.error("empty license key passed to validate."),r;let n=pw(),s=!1;try{s=Rd.statSync(n)}catch(i){Zr.error(i)}if(s){let i;try{i=Rd.readFileSync(n,"utf8")}catch{Zr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(zle),c=o[1];c=Buffer.concat([Buffer.from(c)],Qle);let l=Buffer.concat([Buffer.from(i)],Jle),u=zq.createDecipheriv(jle,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let f=null;try{f=u.update(o[0],"hex","utf8"),f.trim(),f+=u.final("utf8")}catch{let _=tue(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Ad),Zr.error(Ad),new Error(Ad)}let d;if(isNaN(f))try{d=JSON.parse(f),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(Ad),Zr.error(Ad),new Error(Ad)}else r.exp_date=f;r.exp_date<$le().valueOf()&&(r.valid_date=!1),_S.validate(o[1],`${Wle}${i}${t}`,_S.HASH_FUNCTION.MD5)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Zr.error("Invalid licence"),r}a(Jq,"validateLicense");function tue(e,t){try{let r=zq.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Zr.warn("Check old license failed")}}a(tue,"checkOldLicense");function hw(){let e=new Yle,t=[];try{t=Rd.readFileSync(Xle(),"utf-8").split(`\r
|
|
25
|
-
`)}catch(r){r.code==="ENOENT"?Zr.debug("no license file found"):Zr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(Kle.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=Jq(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){Zr.error("There was an error parsing the license string."),Zr.error(s),e.ram_allocation=yl.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return dw=e,e}a(hw,"licenseSearch");async function rue(){return dw||await hw(),dw}a(rue,"getLicense");function nue(){let e=hw().ram_allocation,t=process.constrainedMemory?.()||Wq();if(t=Math.round(Math.min(t,Wq())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(nue,"checkMemoryLimit")});var hS=w((KLe,r$)=>{var pS=yd(),Zq=require("chalk"),ns=z(),e$=require("prompt"),{promisify:sue}=require("util"),mw=(H(),C(q)),iue=require("fs-extra"),oue=require("path"),aue=se(),{packageJson:cue}=st(),t$=ae();t$.initSync();var lue=require("moment"),uue=sue(e$.get),due=oue.join(t$.getHdbBasePath(),mw.LICENSE_KEY_DIR_NAME,mw.LICENSE_FILE_NAME,mw.LICENSE_FILE_NAME);r$.exports={getFingerprint:_ue,setLicense:fue,parseLicense:Ew,register:pue,getRegistrationInfo:mue};async function fue(e){if(e&&e.key&&e.company){try{ns.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Ew(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ns.error(r),ns.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(fue,"setLicense");async function _ue(){let e={};try{e=await pS.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ns.error(r),ns.error(t),new Error(r)}return e}a(_ue,"getFingerprint");async function Ew(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ns.info("Validating license input...");let r=pS.validateLicense(e,t);if(ns.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(ns.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(ns.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ns.info("writing license to disk"),await iue.writeFile(due,JSON.stringify({license_key:e,company:t}))}catch(n){throw ns.error("Failed to write License"),n}return"Registration successful."}a(Ew,"parseLicense");async function pue(){let e=await hue();return Ew(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(pue,"register");async function hue(){let e=await pS.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Zq.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Zq.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{e$.start()}catch(n){ns.error(n)}let r;try{r=await uue(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(hue,"promptForRegistration");async function mue(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await pS.getLicense()}catch(r){throw ns.error(`There was an error when searching licenses due to: ${r.message}`),r}if(aue.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=cue.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=lue.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(mue,"getRegistrationInfo")});var s$=w((WLe,n$)=>{"use strict";var Eue=Tt(),gw=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d,p,_,h){this.port=t,o===null&&(o=void 0),this.server_name=r+Eue.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:f,port:d,routes:p,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:_},HDB:{users:h}},this.system_account="SYS"}};n$.exports=gw});var a$=w((jLe,o$)=>{"use strict";var i$=Tt(),Sw=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d){this.port=t,d===null&&(d=void 0),this.server_name=r+i$.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+i$.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:f,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};o$.exports=Sw});var l$=w((JLe,c$)=>{"use strict";var Tw=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};c$.exports=Tw});var d$=w((ZLe,u$)=>{"use strict";var gue=Tt(),Aw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+gue.SERVER_SUFFIX.ADMIN,this.password=r}};u$.exports=Aw});var SS=w((tMe,p$)=>{"use strict";var bl=require("path"),Ol=require("fs-extra"),Sue=s$(),Tue=a$(),Aue=l$(),Rue=d$(),Rw=An(),Od=se(),In=yt(),ES=(H(),C(q)),Lp=Tt(),{CONFIG_PARAMS:zt}=ES,Nd=z(),Mp=ae(),f$=To(),yw=or(),yue=ts(),bd="clustering",bue=1e4,_$=50;p$.exports={generateNatsConfig:Nue,removeNatsConfig:wue,getHubConfigPath:Oue};function Oue(){let e=Mp.get(zt.ROOTPATH);return bl.join(e,bd,Lp.NATS_CONFIG_FILES.HUB_SERVER)}a(Oue,"getHubConfigPath");async function Nue(e=!1,t=void 0){let r=Mp.get(zt.ROOTPATH);Ol.ensureDirSync(bl.join(r,"clustering","leaf")),Mp.initSync();let n=In.getConfigFromFile(zt.CLUSTERING_TLS_CERT_AUTH),s=In.getConfigFromFile(zt.CLUSTERING_TLS_PRIVATEKEY),i=In.getConfigFromFile(zt.CLUSTERING_TLS_CERTIFICATE);!await Ol.exists(i)&&!await Ol.exists(!n)&&await yue.createNatsCerts();let o=bl.join(r,bd,Lp.PID_FILES.HUB),c=bl.join(r,bd,Lp.PID_FILES.LEAF),l=In.getConfigFromFile(zt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=bl.join(r,bd,Lp.NATS_CONFIG_FILES.HUB_SERVER),f=bl.join(r,bd,Lp.NATS_CONFIG_FILES.LEAF_SERVER),d=In.getConfigFromFile(zt.CLUSTERING_TLS_INSECURE),p=In.getConfigFromFile(zt.CLUSTERING_TLS_VERIFY),_=In.getConfigFromFile(zt.CLUSTERING_NODENAME),h=In.getConfigFromFile(zt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await yw.checkNATSServerInstalled()||gS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await Rw.listUsers(),g=In.getConfigFromFile(zt.CLUSTERING_USER),R=await Rw.getClusterUser();(Od.isEmpty(R)||R.active!==!0)&&gS(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await mS(zt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await mS(zt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await mS(zt.CLUSTERING_HUBSERVER_NETWORK_PORT),await mS(zt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],A=[];for(let[ie,X]of S.entries())X.role?.role===ES.ROLE_TYPES_ENUM.CLUSTER_USER&&X.active&&(E.push(new Rue(X.username,f$.decrypt(X.hash))),A.push(new Aue(X.username,f$.decrypt(X.hash))));let O=[],{hub_routes:v}=In.getClusteringRoutes();if(!Od.isEmptyOrZeroLength(v))for(let ie of v)O.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${ie.host}:${ie.port}`);let F=new Sue(In.getConfigFromFile(zt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,p,h,In.getConfigFromFile(zt.CLUSTERING_HUBSERVER_CLUSTER_NAME),In.getConfigFromFile(zt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),O,E,A);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=Od.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ES.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Ol.writeJson(u,F),Nd.trace(`Hub server config written to ${u}`));let G=`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${R.uri_encoded_name}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,te=new Tue(In.getConfigFromFile(zt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[G],[Y],E,A,i,s,n,d);n==null&&delete te.tls.ca_file,(t===void 0||t===ES.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Ol.writeJson(f,te),Nd.trace(`Leaf server config written to ${f}`))}a(Nue,"generateNatsConfig");async function mS(e){let t=Mp.get(e);return Od.isEmpty(t)&&gS(`port undefined for '${e}'`),await Od.isPortTaken(t)&&gS(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(mS,"isPortAvailable");function gS(e){let t=`Error generating clustering config: ${e}`;Nd.error(t),console.error(t),process.exit(1)}a(gS,"generateNatsConfigError");async function wue(e){let{port:t,config_file:r}=yw.getServerConfig(e),{username:n,decrypt_hash:s}=await Rw.getClusterUser(),i=0,o=2e3;for(;i<_$;){try{let f=await yw.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){Nd.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${f}`)}if(i++,i>=_$)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&Nd.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Od.async_set_timeout(u)}let c="0".repeat(bue),l=bl.join(Mp.get(zt.ROOTPATH),bd,r);await Ol.writeFile(l,c),await Ol.remove(l),Nd.notify(e,"started.")}a(wue,"removeNatsConfig")});var T$=w((nMe,S$)=>{"use strict";var ss=ae(),Iue=yd(),Fe=(H(),C(q)),vp=Tt(),Uo=require("path"),{PACKAGE_ROOT:AS}=st(),h$=ae(),TS=se(),wd="/dev/null",Cue=Uo.join(AS,"launchServiceScripts"),m$=Uo.join(AS,"utility/scripts"),Pue=Uo.join(m$,Fe.HDB_RESTART_SCRIPT),E$=Uo.resolve(AS,"dependencies",`${process.platform}-${process.arch}`,vp.NATS_BINARY_NAME);function g$(){let t=Iue.licenseSearch().ram_allocation||Fe.RAM_ALLOCATION_ENUM.DEFAULT,r=Fe.MEM_SETTING_KEY+t,n={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return TS.noBootFile()&&(n[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TS.getEnvCliRootPath()),{name:Fe.PROCESS_DESCRIPTORS.HDB,script:Fe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:AS}}a(g$,"generateMainServerConfig");var Due=9930;function Lue(){ss.initSync(!0);let e=ss.get(Fe.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",vp.NATS_CONFIG_FILES.HUB_SERVER),r=Uo.join(ss.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=h$.get(Fe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[ss.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Due?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return ss.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wd,i.error_file=wd),i}a(Lue,"generateNatsHubServerConfig");var Mue=9940;function vue(){ss.initSync(!0);let e=ss.get(Fe.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",vp.NATS_CONFIG_FILES.LEAF_SERVER),r=Uo.join(ss.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=h$.get(Fe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[ss.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Mue?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return ss.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wd,i.error_file=wd),i}a(vue,"generateNatsLeafServerConfig");function Uue(){ss.initSync();let e=Uo.join(ss.get(Fe.CONFIG_PARAMS.LOGGING_ROOT),Fe.LOG_NAMES.HDB),t={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Fe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Cue,autorestart:!1};return ss.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=wd,t.error_file=wd),t}a(Uue,"generateClusteringUpgradeV4ServiceConfig");function xue(){let e={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.RESTART_HDB};return TS.noBootFile()&&(e[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TS.getEnvCliRootPath()),{...{name:Fe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:m$},script:Pue}}a(xue,"generateRestart");function Bue(){return{apps:[g$()]}}a(Bue,"generateAllServiceConfigs");S$.exports={generateAllServiceConfigs:Bue,generateMainServerConfig:g$,generateRestart:xue,generateNatsHubServerConfig:Lue,generateNatsLeafServerConfig:vue,generateClusteringUpgradeV4ServiceConfig:Uue}});var Id=w((oMe,v$)=>{"use strict";var Ze=(H(),C(q)),Hue=se(),Bo=SS(),RS=or(),xo=Tt(),Ka=T$(),yS=ae(),Nl=z(),kue=Lo(),{startWorker:A$,onMessageFromWorkers:Fue}=et(),Gue=Do(),iMe=require("util"),que=require("child_process"),$ue=require("fs"),{execFile:Vue}=que,Ve;v$.exports={enterPM2Mode:Kue,start:Ya,stop:bw,reload:y$,restart:b$,list:Ow,describe:w$,connect:Ho,kill:Que,startAllServices:Jue,startService:Nw,getUniqueServicesList:I$,restartAllServices:Xue,isServiceRegistered:C$,reloadStopStart:P$,restartHdb:N$,deleteProcess:zue,startClusteringProcesses:L$,startClusteringThreads:M$,isHdbRestartRunning:jue,isClusteringRunning:ede,stopClustering:Zue,reloadClustering:tde,expectedRestartOfChildren:O$};var Up=!1;Fue(e=>{e.type==="restart"&&yS.initSync(!0)});function Kue(){Up=!0}a(Kue,"enterPM2Mode");function Ho(){return Ve||(Ve=require("pm2")),new Promise((e,t)=>{Ve.connect((r,n)=>{r&&t(r),e(n)})})}a(Ho,"connect");var en,Yue=10,R$;function Ya(e,t=!1){if(Up)return Wue(e);let r=Vue(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=en.indexOf(r);o>-1&&en.splice(o,1),!R$&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Yue&&($ue.existsSync(Bo.getHubConfigPath())?Ya(e):(await Bo.generateNatsConfig(!0),Ya(e),await new Promise(c=>setTimeout(c,3e3)),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=yS.get(Ze.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,f;for(;l=c.exec(i);){if(l.index&&xo.LOG_LEVEL_HIERARCHY[o]>=xo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===xo.LOG_LEVELS.ERR||f===xo.LOG_LEVELS.WRN?Nl.OUTPUTS.STDERR:Nl.OUTPUTS.STDOUT;Nl.logCustomLevel(f||"info",_,n,i.slice(u,l.index).trim())}let[d,p]=l;u=l.index+d.length,f=xo.LOG_LEVELS[p]}if(xo.LOG_LEVEL_HIERARCHY[o]>=xo.LOG_LEVEL_HIERARCHY[f||"info"]){let d=f===xo.LOG_LEVELS.ERR||f===xo.LOG_LEVELS.WRN?Nl.OUTPUTS.STDERR:Nl.OUTPUTS.STDOUT;Nl.logCustomLevel(f||"info",d,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!en&&(en=[],!t)){let i=a(()=>{R$=!0,en&&(en.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}en.push(r)}a(Ya,"start");function Wue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ve.start(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(Wue,"startWithPM2");function bw(e){if(!Up){for(let t of en||[])t.name===e&&(en.splice(en.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ve.stop(e,async(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.delete(e,(i,o)=>{i&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(o)})})})}a(bw,"stop");function y$(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ve.reload(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(y$,"reload");function b$(e){if(!Up){O$();for(let t of en||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ve.restart(e,(n,s)=>{Ve.disconnect(),t(s)})})}a(b$,"restart");function O$(){for(let e of en||[])e.config&&(e.config.restarts=0)}a(O$,"expectedRestartOfChildren");function zue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ve.delete(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(zue,"deleteProcess");async function N$(){await Ya(Ka.generateRestart())}a(N$,"restartHdb");async function jue(){let e=await Ow();for(let t in e)if(e[t].name===Ze.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(jue,"isHdbRestartRunning");function Ow(){return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ve.list((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(Ow,"list");function w$(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ve.describe(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(w$,"describe");function Que(){if(!Up){for(let e of en||[])e.kill();en=[];return}return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ve.killDaemon((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(Que,"kill");async function Jue(){try{await L$(),await M$(),await Ya(Ka.generateAllServiceConfigs())}catch(e){throw Ve?.disconnect(),e}}a(Jue,"startAllServices");async function Nw(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Ze.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ka.generateMainServerConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ka.generateNatsIngestServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ka.generateNatsReplyServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ka.generateNatsHubServerConfig(),await Ya(r,t),await Bo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ka.generateNatsLeafServerConfig(),await Ya(r,t),await Bo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ka.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Ya(r)}catch(r){throw Ve?.disconnect(),r}}a(Nw,"startService");async function I$(){try{let e=await Ow(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Ve?.disconnect(),e}}a(I$,"getUniqueServicesList");async function Xue(e=[]){try{let t=!1,r=await I$();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===Ze.PROCESS_DESCRIPTORS.HDB?t=!0:await b$(o))}t&&await P$(Ze.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ve?.disconnect(),t}}a(Xue,"restartAllServices");async function C$(e){if(en?.find(r=>r.name===e))return!0;let t=await Gue.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(C$,"isServiceRegistered");async function P$(e){let t=yS.get(Ze.CONFIG_PARAMS.THREADS_COUNT)??yS.get(Ze.CONFIG_PARAMS.THREADS),r=await w$(e),n=Hue.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await bw(e),await Nw(e)):e===Ze.PROCESS_DESCRIPTORS.HDB?await N$():await y$(e)}a(P$,"reloadStopStart");var D$;async function L$(e=!1){for(let t in Ze.CLUSTERING_PROCESSES){let r=Ze.CLUSTERING_PROCESSES[t];await Nw(r,e)}}a(L$,"startClusteringProcesses");async function M$(){D$=A$(Ze.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Ze.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await RS.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await RS.updateLocalStreams();let e=await kue.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Ze.PRE_4_0_0_VERSION){Nl.info("Starting clustering upgrade 4.0.0 process"),A$(Ze.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(M$,"startClusteringThreads");async function Zue(){for(let e in Ze.CLUSTERING_PROCESSES)if(e!==Ze.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===Ze.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await D$.terminate();else{let t=Ze.CLUSTERING_PROCESSES[e];await bw(t)}}a(Zue,"stopClustering");async function ede(){for(let e in Ze.CLUSTERING_PROCESSES){let t=Ze.CLUSTERING_PROCESSES[e];if(await C$(t)===!1)return!1}return!0}a(ede,"isClusteringRunning");async function tde(){await Bo.generateNatsConfig(!0),await RS.reloadNATSHub(),await RS.reloadNATSLeaf(),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(tde,"reloadClustering")});var NS={};ve(NS,{compactOnStart:()=>rde,copyDb:()=>F$});async function rde(){Wa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,ww.get)(B.ROOTPATH),t=new Map,r=Je();(0,Iw.updateConfigValue)(B.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,bS.join)(e,"backup",n+".mdb"),o=(0,bS.join)(e,yc,n+"-copy.mdb"),c=0;try{c=await U$(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Wa.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await F$(n,o),console.log("Backing up",n,"to",i),await(0,wl.move)(s,i,{overwrite:!0})}try{Cd()}catch(n){Wa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,wl.move)(i,s,{overwrite:!0}),await(0,wl.remove)((0,bS.join)(e,yc,`${n}-copy.mdb-lock`));try{Cd()}catch(n){Wa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Wa.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,Iw.updateConfigValue)(B.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,wl.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Cd(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await U$(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
23
|
+
`,"")}a(Ck,"runCommand");async function $se(){try{await Sse.access(kO)}catch{return!1}let e=await Ck(`${kO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Tse.eq(t,Gse)}a($se,"checkNATSServerInstalled");async function VO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await wk.getClusterUser();if(_l(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}oi.trace("create nats connection called");let i=await Lse({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:wr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:wr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:wr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),oi.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&oi.error("Error with Nats client connection, connection closed",o),i===Qr&&Pk()}),i}a(VO,"createConnection");function Pk(){Qr=void 0,ul=void 0,dl=void 0,fl=void 0}a(Pk,"clearClientCache");async function Vse(){Qr&&(await Qr.drain(),Qr=void 0,ul=void 0,dl=void 0,fl=void 0)}a(Vse,"closeConnection");var Qr,fl;async function np(){return fl||(fl=VO(wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Qr=await fl),Qr||fl}a(np,"getConnection");async function sp(){if(ul)return ul;_l(Qr)&&await np();let{domain:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(_l(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ul=await Qr.jetstreamManager({domain:e,timeout:6e4}),ul}a(sp,"getJetStreamManager");async function Dk(){if(dl)return dl;_l(Qr)&&await np();let{domain:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(_l(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return dl=Qr.jetstream({domain:e,timeout:6e4}),dl}a(Dk,"getJetStream");async function qi(){let e=Qr||await np(),t=ul||await sp(),r=dl||await Dk();return{connection:e,jsm:t,js:r}}a(qi,"getNATSReferences");async function Kse(e){let t=wr.get($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await wk.getClusterUser(),s=await VO(t,r,n),i=$O(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=Ik.decode(f.data);d.response_time=Date.now()-l,c.push(d)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Eg.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Kse,"getServerList");async function KO(e,t){let{jsm:r}=await qi(),n=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Mse.File,retention:vse.Limits,subjects:t,discard:Use.Old,max_msgs:s,max_bytes:i,max_age:n})}a(KO,"createLocalStream");async function Lk(){let{jsm:e}=await qi(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Lk,"listStreams");async function Yse(e){let{jsm:t}=await qi();await t.streams.delete(e)}a(Yse,"deleteLocalStream");async function Wse(e){let{connection:t}=await qi(),r=[],n=$O(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(Ik.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(Wse,"listRemoteStreams");async function zse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await qi(),i=yk(),o={durable_name:i,ack_policy:GO.Explicit};t&&(o.deliver_policy=qO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let f of l){let d=FO(f.data),p={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(p.origin=f.headers.get(vr.MSG_HEADERS.ORIGIN)),u.push(p),f.ack(),f.info.pending===0)break}return await c.delete(),u}a(zse,"viewStream");async function*jse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await qi(),i=yk(),o={durable_name:i,ack_policy:GO.Explicit};t&&(o.deliver_policy=qO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let f=FO(u.data);f[0]||(f=[f]);for(let d of f){let p={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(p.origin=u.headers.get(vr.MSG_HEADERS.ORIGIN)),yield p}if(u.ack(),u.info.pending===0)break}await c.delete()}a(jse,"viewStreamIterator");async function Jse(e,t,r,n){oi.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Mk(n,r);let{js:s}=await qi(),i=await Sg(),o=`${e}.${i}`,c=await kse(()=>n instanceof Uint8Array?n:Nk.encode(n));try{oi.trace(`publishToStream publishing to subject: ${o}`),Hse(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return Uk(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){oi.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await KO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Jse,"publishToStream");function Mk(e,t){t===void 0&&(t=Bse());let r=wr.get($e.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(vr.MSG_HEADERS.ORIGIN)&&r&&t.append(vr.MSG_HEADERS.ORIGIN,r),t}a(Mk,"addNatsMsgHeader");function ed(e){e=e.toLowerCase();let t=rp.join(wr.get($e.CONFIG_PARAMS.ROOTPATH),Fse);if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return _l(HO)&&(HO={port:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.HUB,config_file:vr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:rp.join(t,vr.PID_FILES.HUB),hdb_nats_path:t}),HO;if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return _l(BO)&&(BO={port:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,config_file:vr.NATS_CONFIG_FILES.LEAF_SERVER,domain:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,pid_file_path:rp.join(t,vr.PID_FILES.LEAF),hdb_nats_path:t}),BO;oi.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(ed,"getServerConfig");async function vk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:GO.Explicit,durable_name:r,deliver_policy:qO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(vk,"createConsumer");async function Qse(e,t,r){await e.consumers.delete(t,r)}a(Qse,"removeConsumer");function Xse(e){return e.split(".")[1]}a(Xse,"extractServerName");async function Zse(e,t,r=6e4,n=$O()){if(!Eg.isObject(t))throw new Error("data param must be an object");let s=Nk.encode(t),{connection:i}=await qi(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return FO(c.data)}a(Zse,"request");function YO(e){return new Promise(async(t,r)=>{let n=bse(kO,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(YO,"reloadNATS");async function eie(){let{pid_file_path:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await YO(e)}a(eie,"reloadNATSHub");async function tie(){let{pid_file_path:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await YO(e)}a(tie,"reloadNATSLeaf");function rie(e,t,r){let n;switch(e.code){case Rk.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case Rk.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(rie,"requestErrorHandler");async function nie(e,t){let r=t+vr.SERVER_SUFFIX.LEAF,{connection:n}=await qi(),{jsm:s}=await die(r),{schema:i,table:o}=e,c=gg.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await Uk(async()=>{if(e.subscribe===!0)await vk(s,c,n.info.server_name,l);else try{await Qse(s,c,n.info.server_name)}catch(u){oi.trace(u)}})}a(nie,"updateRemoteConsumer");async function sie(e,t,r,n){let s=gg.createNatsTableStreamName(e,t),i=r+vr.SERVER_SUFFIX.LEAF,o={type:$e.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!Ok&&Pse()<wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=xO();await c(o)}await Ise(o),n==="stop"&&await Eg.async_set_timeout(1e3)}a(sie,"updateConsumerIterator");function Uk(e){return wse.writeTransaction($e.SYSTEM_SCHEMA_NAME,$e.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Uk,"exclusiveLock");async function xk(e,t){let r=gg.createNatsTableStreamName(e,t),n=await Sg(),s=cie(e,t,n);await KO(r,[s])}a(xk,"createLocalTableStream");async function iie(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await xk(n,s)}}a(iie,"createTableStreams");async function Bk(e,t,r=void 0){if(wr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=gg.createNatsTableStreamName(e,t),{domain:s}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await np()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")oi.warn(n);else throw n}}a(Bk,"purgeTableStream");async function oie(e,t){if(wr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await Bk(e,t[r])}a(oie,"purgeSchemaTableStreams");async function aie(e){return(await sp()).streams.info(e)}a(aie,"getStreamInfo");function cie(e,t,r){return`${vr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(cie,"createSubjectName");async function Sg(){if(tp)return tp;if(tp=(await sp())?.nc?.info?.server_name,tp===void 0)throw new Error("Unable to get jetstream manager server name");return tp}a(Sg,"getJsmServerName");async function lie(){let e=await sp(),t=await Sg(),r=await Lk();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=uie(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let f=u.join(".");oi.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(lie,"updateLocalStreams");function uie(e){let{config:t}=e,r=!1,n=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(uie,"updateStreamLimits");async function die(e){let t,r;try{t=await Qr.jetstream({domain:e}),r=await Qr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw oi.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(die,"connectToRemoteJS")});function WO(e){let t=e.get(Tg),r=t?(0,td.unpack)(t):null;r||(r={remoteNameToId:{}});let n=Ze(),s=!1;r.nodeName=Ze();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:op(e)??1,nodes:[]})})}i[n]=0,e.putSync(Tg,(0,td.pack)(r))}return r}function ip(e){return WO(e).remoteNameToId}function Fk(e,t){let r=WO(t),n=r.remoteNameToId,s=new Map,i=!1;for(let o in e){let c=e[o],l=n[o];if(l==null){let u=0;for(let f in n){let d=n[f];d>u&&(u=d)}l=u+1,n[o]=l,i=!0}s.set(c,l)}return i&&t.putSync(Tg,(0,td.pack)(r)),s}function Ag(e,t){let r=WO(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Tg,(0,td.pack)(r))}return kk.trace?.("The remote node name map",e,n,s),s}var kk,td,Tg,zO=be(()=>{kk=M(Ni());Xn();td=require("msgpackr"),Tg=Symbol.for("remote-ids");a(WO,"getIdMappingRecord");a(ip,"exportIdMapping");a(Fk,"remoteToLocalNodeId");a(Ag,"getIdOfRemoteNode")});var jO={};ve(jO,{commits_awaiting_replication:()=>nd,getHDBNodeTable:()=>or,getReplicationSharedStatus:()=>Rg,iterateRoutes:()=>cp,shouldReplicateToNode:()=>ap,subscribeToNodeUpdates:()=>sd});function or(){return Gk||(Gk=ft({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Rg(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function sd(e){or().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;Kk.debug?.("adding node",n,"on node",Ze()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==Ze()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of or().search({}))if(i.shard!=null){let o=s.get(i.shard);o||s.set(i.shard,o=[]),o.push(i)}server.shards=s,(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function ap(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&or().primaryStore.get(Ze())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function fie(){sd(e=>{Da({},(t,r)=>{let n=e.name,s=qk.get(n);if(s||qk.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=Rg(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of nd.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*cp(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=rd.default.get(x.REPLICATION_SECUREPORT)??(!rd.default.get(x.REPLICATION_PORT)&&rd.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||rd.default.get(x.REPLICATION_PORT)||rd.default.get(x.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){$k.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime,revoked_certificates:t.revokedCertificates,shard:t.shard}}}var $k,Vk,rd,Kk,Gk,qk,nd,pl=be(()=>{De();Xn();Rm();$k=require("worker_threads"),Vk=M(pe()),rd=M(ae());H();Kk=M(Ni());server.nodes=[];a(or,"getHDBNodeTable");a(Rg,"getReplicationSharedStatus");a(sd,"subscribeToNodeUpdates");a(ap,"shouldReplicateToNode");qk=new Map;RL((e,t,r)=>{if(r>server.nodes.length)throw new Vk.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);nd||(nd=new Map,fie());let n=nd.get(e);return n||(n=[],nd.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(fie,"startSubscriptionToReplications");a(cp,"iterateRoutes")});var jk={};ve(jk,{connectedToNode:()=>hl,disconnectedFromNode:()=>ad,ensureNode:()=>Oo,requestClusterStatus:()=>zk,startOnMainThread:()=>QO});async function QO(e){let t=0,r=Xe();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){yg.set(i,op(l.auditStore));break}}}$i.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of cp(e))try{let c=!o.subscriptions;if(c){let u=Ze(),f=or().primaryStore.get(u);if(f!==null){let d=e.url??La();(f===void 0||f.url!==d||f.shard!==e.shard)&&await Oo(u,{name:u,url:d,shard:e.shard,replicates:!0})}}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}sd(s)});let n;function s(i,o=i?.name){let c=Ze()&&o===Ze()||La()&&i?.url===La();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let p of or().search([]))p.replicates&&p.name!==o&&s(p,p.name);n=d}if(ct.trace("Setting up node replication for",i),!i){for(let[d,p]of bo){let _;for(let[h,{worker:S,nodes:g}]of p){let R=g[0];if(R&&R.name==o){_=!0;for(let[E,{worker:T}]of p)p.delete(E),ct.warn("Node was deleted, unsubscribing from node",o,E,d),T?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){bo.get(d).iterator.remove(),bo.delete(d);return}}return}if(c)return;if(!i.url){ct.info(`Node ${i.name} is missing url`);return}let l=bo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ct.info(`Added node ${i.name} at ${i.url} for process ${Ze()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,p]of id)if(i.url===p.url){id.delete(d);break}id.set(i.name,i)}let u=Xe();if(l||(l=new Map,bo.set(i.url,l)),l.iterator=Da(e,(d,p,_)=>{_?f(p,!0):f(p,!1)}),i.subscriptions)for(let d of i.subscriptions){let p=d.database||d.schema;u[p]||(ct.warn(`Database ${p} not found for node ${i.name}, making a subscription anyway`),f(p,!1))}function f(d,p){ct.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),h,S=[{replicateByDefault:p,...i}];yg.has(d)&&(S.push({replicateByDefault:p,name:Ze(),start_time:yg.get(d),end_time:Date.now(),replicates:!0}),yg.delete(d));let g=ap(i,d),R=$i.workers.filter(E=>E.name==="http");if(_?(h=_.worker,_.nodes=S):g&&(t=t%R.length,h=R[t++],l.set(d,{worker:h,nodes:S,url:i.url}),h?.on("exit",()=>{l.get(d)?.worker===h&&(l.delete(d),f(d,p))})),g)setTimeout(()=>{let E={type:"subscribe-to-node",database:d,nodes:S};h?h.postMessage(E):od(E)},_ie);else{ct.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],or().primaryStore.get(Ze())?.replicates),or().primaryStore.get(Ze())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};h?h.postMessage(E):Og(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),ad=a(function(i){try{ct.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(id.keys()),c=o.sort(),l=c.indexOf(i.name||ai(i.url));if(l===-1){ct.warn("Disconnected node not found in node map",i.name,o);return}let u=bo.get(i.url),f=u?.get(i.database);if(!f){ct.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished)return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let p=(l+1)%c.length;for(;l!==p;){let _=c[p],h=id.get(_);u=bo.get(h.url);let S=u?.get(i.database);if(!S){p=(p+1)%c.length;continue}let{worker:g,nodes:R}=S,E=!1;for(let T of f.nodes){if(R.some(b=>b.name===T.name)){ct.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}R.push(T),E=!0}if(!E){ct.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,ct.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):od({database:i.database,nodes:R});return}ct.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){ct.error("Error failing over node",o)}},"disconnectedFromNode"),hl=a(function(i){let o=bo.get(i.url),c=o?.get(i.database);if(!c){ct.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,f=u.find(d=>d.name===i.name);c.redirectingTo=null,f&&(u.splice(u.indexOf(f),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):od({database:i.database,nodes:u}))}},"connectedToNode"),(0,$i.onMessageByType)("disconnected-from-node",ad),(0,$i.onMessageByType)("connected-to-node",hl),(0,$i.onMessageByType)("request-cluster-status",zk)}function zk(e,t){let r=[];for(let[n,s]of id)try{let i=bo.get(s.url);ct.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:f,nodes:d,latency:p}]of i)o.push({database:l,connected:f,latency:p,thread_id:u?.threadId,nodes:d.map(_=>_.name)});let c=(0,JO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ct.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Oo(e,t){let r=or();e=e??ai(t.url),t.name=e;try{if(t.ca){let s=new Wk.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){ct.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ct.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!Yk.default.get(x.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,JO.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}ct.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var $i,bg,ct,JO,Yk,Wk,_ie,bo,ad,hl,id,yg,lp=be(()=>{De();$i=M(rt());Xn();bg=require("worker_threads");pl();ct=M(z()),JO=require("lodash"),Yk=M(ae());H();Wk=require("crypto"),_ie=200,bo=new Map,id=new Map,yg=new Map;a(QO,"startOnMainThread");a(zk,"requestClusterStatus");bg.parentPort&&(ad=a(e=>{bg.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),hl=a(e=>{bg.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,$i.onMessageByType)("subscribe-to-node",e=>{od(e)}),(0,$i.onMessageByType)("unsubscribe-from-node",e=>{Og(e)}));a(Oo,"ensureNode")});var Zn=w(gF=>{"use strict";var ar=require("path"),Nn=require("fs-extra"),cd=require("node-forge"),tF=require("net"),{generateKeyPair:ZO,X509Certificate:No,createPrivateKey:rF}=require("crypto"),pie=require("util");ZO=pie.promisify(ZO);var bt=cd.pki,ci=require("joi"),{v4:nF}=require("uuid"),{validateBySchema:nN}=ot(),pt=z(),ys=ae(),bs=(H(),C(G)),{CONFIG_PARAMS:ld}=bs,li=Vy(),{ClientError:va}=pe(),Ng=require("node:tls"),{relative:sF,join:hie}=require("node:path"),{CERT_PREFERENCE_APP:UPe,CERTIFICATE_VALUES:Jk}=li,mie=ua(),eN=yt(),{table:Eie,getDatabases:gie,databases:XO}=(De(),C(nt)),{getJWTRSAKeys:Qk}=(Ju(),C(X_));Object.assign(gF,{generateKeys:oN,updateConfigCert:fF,createCsr:Nie,signCertificate:wie,setCertTable:ud,loadCertificates:lF,reviewSelfSignedCert:cN,createTLSSelector:pF,listCertificates:mF,addCertificate:Mie,removeCertificate:Uie,createNatsCerts:Pie,generateCertsKeys:Cie,getReplicationCert:dp,getReplicationCertAuth:Oie,renewSelfSigned:Die,hostnamesFromCert:EF,getKey:xie});var{urlToNodeName:iF,getThisNodeUrl:Sie,getThisNodeName:Ig,clearThisNodeName:Tie}=(Xn(),C(wo)),{readFileSync:Aie,watchFile:Rie,statSync:oF}=require("node:fs"),xPe=ae(),{getTicketKeys:yie,onMessageFromWorkers:bie}=rt(),Ma=z(),{isMainThread:aF}=require("worker_threads"),{TLSSocket:cF,createSecureContext:BPe}=require("node:tls"),sN=3650,up=["127.0.0.1","localhost","::1"],iN=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];bie(async e=>{e.type===bs.ITC_EVENT_TYPES.RESTART&&(ys.initSync(!0),await cN())});var Ur;function xa(){return Ur||(Ur=gie().system.hdb_certificate,Ur||(Ur=Eie({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),Ur}a(xa,"getCertTable");async function dp(){let e=pF("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Ig());if(!r)return;let n=new No(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(dp,"getReplicationCert");async function Oie(){xa();let e=(await dp()).options.cert,r=new No(e).issuer.match(/CN=(.*)/)?.[1];return Ur.get(r)}a(Oie,"getReplicationCertAuth");var Xk,Ua=new Map;function lF(){if(Xk)return;Xk=!0;let e=[{configKey:ld.TLS},{configKey:ld.OPERATIONSAPI_TLS}];xa();let t=ar.dirname(eN.getConfigFilePath()),r;for(let{configKey:n}of e){let s=eN.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&sF(hie(t,"keys"),o);c&&Zk(o,l=>{Ua.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&aF){let f;Zk(u,d=>{if(Jk.cert===d)return;let p=i.hostname??i.hostnames??i.host??i.hosts;p&&!Array.isArray(p)&&(p=[p]);let _=_F(u),h=new No(_),S;try{S=lN(h)}catch(T){pt.error("error extracting common name from certificate",T);return}if(S==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new No(Jk.cert)))return;let g=Ur.primaryStore.get(S),R=oF(u).mtimeMs,E=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&R<=E){R<E&&pt.info(`Certificate ${S} at ${u} is older (${new Date(R)}) than the certificate in the database (${E>1?new Date(E):"only self signed certificate available"})`);return}r=Ur.put({name:S,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:_,private_key_name:c,is_authority:l,hostnames:p,file_timestamp:R,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(lF,"loadCertificates");function Zk(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&aF&&pt.warn(`Reloading ${r}:`,e),n=c,t(_F(e)))}catch(c){pt.error(`Error loading ${r}:`,e,c)}},"loadFile");Nn.existsSync(e)?s(oF(e)):pt.error(`${r} file not found:`,e),Rie(e,{persistent:!1},s)}a(Zk,"loadAndWatch");function tN(){let e=Sie();if(e==null){let t=up[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return iF(e)}a(tN,"getHost");function wg(){let e=Ig();if(e==null){let t=up[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(wg,"getCommonName");async function Nie(){let e=await dp(),t=bt.certificateFromPem(e.options.cert),r=bt.privateKeyFromPem(e.options.key);pt.info("Creating CSR with cert named:",e.name);let n=bt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:wg()},...iN];pt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:uF()}];return pt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),cd.pki.certificationRequestToPem(n)}a(Nie,"createCsr");function uF(){let e=up.includes(wg())?up:[...up,wg()];return e.includes(tN())||e.push(tN()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>tF.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(uF,"certExtensions");async function wie(e){let t={},r=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;xa();for await(let f of Ur.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(Ua.has(f.private_key_name)){n=Ua.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await Nn.exists(ar.join(r,f.private_key_name))){n=Nn.readFile(ar.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await rN();s=f.ca,n=f.private_key}n=bt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=bt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=bt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return pt.error(f),new Error("Error verifying CSR: "+f.message)}let c=cd.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+sN),pt.info("sign cert setting validity:",c.validity),pt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),pt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;pt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,cd.md.sha256.create()),t.certificate=bt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(wie,"signCertificate");async function Iie(e,t){await ud({name:Ig(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await ud({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:bt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Iie,"createCertificateTable");async function ud(e){let t=new No(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},xa(),await Ur.patch(e)}a(ud,"setCertTable");async function oN(){let e=await ZO("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:bt.publicKeyFromPem(e.publicKey),private_key:bt.privateKeyFromPem(e.privateKey)}}a(oN,"generateKeys");async function aN(e,t,r){let n=bt.createCertificate();if(!t){let o=await dp();t=bt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+sN);let i=[{name:"commonName",value:wg()},...iN];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(uF()),n.sign(e,cd.md.sha256.create()),bt.certificateToPem(n)}a(aN,"generateCertificates");async function rN(){let e=await mF(),t;for(let r of e){if(!r.is_authority)continue;let n=await hF(r.private_key_name);if(r.private_key_name&&n&&new No(r.certificate).checkPrivateKey(rF(n))){pt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;pt.trace("No CA found with matching private key")}a(rN,"getCertAuthority");async function dF(e,t,r=!0){let n=bt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+sN);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ys.get(ld.REPLICATION_HOSTNAME)??iF(ys.get(ld.REPLICATION_URL))??nF().split("-")[0]}`},...iN];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,cd.md.sha256.create());let o=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),c=ar.join(o,li.PRIVATEKEY_PEM_NAME);return r&&await Nn.writeFile(c,bt.privateKeyToPem(e)),n}a(dF,"generateCertAuthority");async function Cie(){let{private_key:e,public_key:t}=await oN(),r=await dF(e,t),n=await aN(e,t,r);await Iie(n,r),fF()}a(Cie,"generateCertsKeys");async function Pie(){let e=await aN(bt.privateKeyFromPem(li.CERTIFICATE_VALUES.key),void 0,bt.certificateFromPem(li.CERTIFICATE_VALUES.cert)),t=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),r=ar.join(t,li.NATS_CERTIFICATE_PEM_NAME);await Nn.exists(r)||await Nn.writeFile(r,e);let n=ar.join(t,li.NATS_CA_PEM_NAME);await Nn.exists(n)||await Nn.writeFile(n,li.CERTIFICATE_VALUES.cert)}a(Pie,"createNatsCerts");async function Die(){xa();for await(let e of Ur.search([{attribute:"is_self_signed",value:!0}]))await Ur.delete(e.name);await cN()}a(Die,"renewSelfSigned");async function cN(){Tie(),await lF(),xa();let e=await rN();if(!e){pt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=ys.get(ld.TLS_PRIVATEKEY),n=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),s,i=sF(n,r);try{s=bt.privateKeyFromPem(await Nn.readFile(r))}catch(c){pt.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await oN(),await Nn.exists(ar.join(n,li.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${nF().split("-")[0]}.pem`),await Nn.writeFile(ar.join(n,i),bt.privateKeyToPem(s))}let o=await dF(s,bt.setRsaPublicKey(s.n,s.e),!1);await ud({name:o.subject.getField("CN").value,uses:["https"],certificate:bt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await dp()){let r=Ig();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await rN();let n=bt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await aN(bt.privateKeyFromPem(e.private_key),s,n);await ud({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(cN,"reviewSelfSignedCert");function fF(){let e=mie(Object.keys(bs.CONFIG_PARAM_MAP),!0),t=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),r=ar.join(t,li.PRIVATEKEY_PEM_NAME),n=ar.join(t,li.NATS_CERTIFICATE_PEM_NAME),s=ar.join(t,li.NATS_CA_PEM_NAME),i=bs.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),eN.updateConfigValue(void 0,void 0,o,!1,!0)}a(fF,"updateConfigCert");function _F(e){return e.startsWith("-----BEGIN")?e:Aie(e,"utf8")}a(_F,"readPEM");var eF=Ng.createSecureContext;Ng.createSecureContext=function(e){if(!e.cert||!e.key)return eF(e);let t={...e};delete t.key,delete t.cert;let r=eF(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var Lie=cF.prototype._init;cF.prototype._init=function(e,t){Lie.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var ml=new Map;function pF(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),ml.clear();let f=0;for await(let d of XO.system.hdb_certificate.search([])){let p=d.certificate,_=new No(p);d.is_authority&&(_.asString=p,ml.set(_.subject,p))}for await(let d of XO.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let p=e==="operations-api",_=d.is_self_signed?1:2;p&&d.uses?.includes?.("operations")&&(_+=1);let h=await hF(d.private_key_name),S=d.certificate,g=new No(S);if(ml.has(g.issuer)&&(S+=`
|
|
24
|
+
`+ml.get(g.issuer)),!h||!S)throw new Error("Missing private key or certificate for secure server");let R={ciphers:d.ciphers,ticketKeys:yie(),availableCAs:ml,ca:t&&Array.from(ml.values()),cert:S,key:h,key_file:d.private_key_name,is_self_signed:d.is_self_signed};o&&(R.sessionIdContext=o.sessionIdContext);let E=Ng.createSecureContext(R);E.name=d.name,E.options=R,E.quality=_,E.certificateAuthorities=Array.from(ml),E.certStart=S.toString().slice(0,100);let T=d.hostnames??EF(g);Array.isArray(T)||(T=[T]);let b;for(let v of T)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===tN()&&(_+=2),tF.isIP(v)&&(b=!0);let F=r.get(v)?.quality??0;_>F&&r.set(v,E)}else Ma.error("No hostname found for certificate at",Ng.certificate);Ma.trace("Adding TLS",E.name,"for",o.ports||"client","cert named",d.name,"hostnames",T,"quality",_,"best quality",f),_>f&&(i.defaultContext=n=E,f=_,o&&(o.defaultContext=E))}catch(p){Ma.error("Error applying TLS for",d.name,p)}o?.secureContextsListeners.forEach(d=>d()),c(n)}catch(f){l(f)}}a(u,"updateTLS"),XO.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){Ma.info("TLS requested for",o||"(no SNI)");let l=o;for(;;){let f=r.get(l);if(f)return Ma.debug("Found certificate for",o,f.certStart),f.updatedContext&&(f=f.updatedContext),c(null,f);if(s&&l){let d=l.indexOf(".",1);d<0?l="":l=l.slice(d)}else break}o?Ma.debug("No certificate found to match",o,"using the default certificate"):Ma.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):Ma.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(pF,"createTLSSelector");async function hF(e){let t=Ua.get(e);return!t&&e?await Nn.readFile(ar.join(ys.get(ld.ROOTPATH),bs.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(hF,"getPrivateKeyByName");async function mF(){xa();let e=[];for await(let t of Ur.search([]))e.push(t);return e}a(mF,"listCertificates");async function Mie(e){let t=nN(e,ci.object({name:ci.string().required(),certificate:ci.string().required(),is_authority:ci.boolean().required(),private_key:ci.string(),hosts:ci.array(),uses:ci.array()}));if(t)throw new va(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new No(n),c=!1,l=!1,u;for(let[_,h]of Ua)!s&&!c&&o.checkPrivateKey(rF(h))&&(c=!0,u=_),s&&s===h&&(l=!0,u=_);if(!i&&!s&&!c)throw new va("A suitable private key was not found for this certificate");let f;if(!r){try{f=lN(o)}catch(_){pt.error(_)}if(f==null)throw new va("Error extracting certificate common name, please provide a name parameter")}let d=vie(r??f);s&&!c&&!l&&(await Nn.writeFile(ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME,d+".pem"),s),Ua.set(d,s));let p={name:r??f,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(p.private_key_name=u??d+".pem"),await ud(p),"Successfully added certificate: "+d}a(Mie,"addCertificate");function vie(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(vie,"sanitizeName");async function Uie(e){let t=nN(e,ci.object({name:ci.string().required()}));if(t)throw new va(t.message);let{name:r}=e;xa();let n=await Ur.get(r);if(!n)throw new va(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Ur.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await Nn.remove(ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME,s)))}return await Ur.delete(r),"Successfully removed "+r}a(Uie,"removeCertificate");function lN(e){return e.subject.match(/CN=(.*)/)?.[1]}a(lN,"extractCommonName");function EF(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[lN(e)]}a(EF,"hostnamesFromCert");async function xie(e){if(e.bypass_auth!==!0)throw new va("Unauthorized","401");let t=nN(e,ci.object({name:ci.string().required()}));if(t)throw new va(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await Qk()).privateKey;if(r===".jwtPublic")return(await Qk()).publicKey;if(Ua.get(r))return Ua.get(e.name);throw new va("Key not found")}a(xie,"getKey")});var BF={};ve(BF,{CONFIRMATION_STATUS_POSITION:()=>xF,NodeReplicationConnection:()=>fp,OPERATION_REQUEST:()=>pN,RECEIVED_TIME_POSITION:()=>mN,RECEIVED_VERSION_POSITION:()=>hN,SENDING_TIME_POSITION:()=>Mg,createWebSocket:()=>Ug,database_subscriptions:()=>Ha,replicateOverWS:()=>_p,table_update_listeners:()=>gN});async function Ug(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Ze(),i;if(e.includes("wss://")){if(!dN){let l=(0,MF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),dN=u.secureContexts}if(i=dN.get(s),i&&le.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,UF.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=vF.createSecureContext({...i.options,ca:Array.from(gl)})),new DF.WebSocket(e,"harperdb-replication-v1",c)}function _p(e,t,r){let n=t.port||t.securePort,s=El.pid%1e3+"-"+LF.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,f=t.databaseSubscriptions||Ha,d,p,_=!1,h=t.subscription;h?.then&&h.then(m=>h=m);let S=t.tables||u&&Xe()[u];if(!r){le.error?.("No authorization provided"),un(1008,"Unauthorized");return}let g=new Map,R=[],E=r.name;E&&t.connection&&(t.connection.nodeName=E);let T,b,v,F,q,Y,Z,se=1e3,Q,ne=0,J=0,me=0,ye=new Map,Pe=[],he=0,Nt;if(t.url){let m=a(()=>{q&&J===e._socket?.bytesRead&&me===e._socket?.bytesWritten?e.terminate():(q=performance.now(),e.ping(),J=e._socket?.bytesRead,me=e._socket?.bytesWritten)},"send_ping");v=setInterval(m,IF).unref(),m()}else dt();e._socket?.setMaxListeners(200);function dt(){clearTimeout(F),J=e._socket?.bytesRead,me=e._socket?.bytesWritten,F=setTimeout(()=>{J===e._socket?.bytesRead&&me===e._socket?.bytesWritten&&(le.warn?.(`Timeout waiting for ping from ${E}, terminating connection and reconnecting`),e.terminate())},IF*2).unref()}a(dt,"resetPingTimer");function br(){return p||(p=Rg(d,u,E)),p}a(br,"getSharedStatus"),u&&ia(u);let hs,Un,ou=[],au=[],HA,kA=[],vt=[],Ef=[],Jh=150,Qh=25,gf=0,Xh=0,Ie=!1,Sf,ln,Cr,cu;e.on("message",m=>{ne=performance.now();try{let A=m.dataView=new Sl(m.buffer,m.byteOffset,m.byteLength);if(m[0]>127){let P=(0,je.decode)(m),[N,L,k]=P;switch(N){case TF:{if(L){if(E){if(E!==L){le.error?.(s,`Node name mismatch, expecting to connect to ${E}, but peer reported name as ${L}, disconnecting`),e.send((0,je.encode)([dd])),un(1008,"Node name mismatch");return}}else if(E=L,t.connection?.tentativeNode){let U=t.connection.tentativeNode;U.name=E,t.connection.tentativeNode=null,Oo(E,U)}if(t.connection&&(t.connection.nodeName=E),le.debug?.(s,"received node name:",E,"db:",u),!u)try{ia(u=P[2]),u==="system"&&(hs=Da(t,(U,ue)=>{uu(ue)&&oa(ue)}),e.on("close",()=>{hs?.remove()}))}catch(U){le.warn?.(s,"Error setting database",U),e.send((0,je.encode)([dd])),un(1008,U.message);return}Gr()}break}case NF:{le.debug?.(s,"Received table definitions for",L.map(U=>U.table));for(let U of L){let ue=P[2];U.database=ue;let ce;uu(ue)&&(ue==="system"?qe[ue]?.[U.table]||(ce=fN(U,qe[ue]?.[U.table])):ce=fN(U,qe[ue]?.[U.table]),d||(d=ce?.auditStore),S||(S=Xe()?.[ue]))}break}case dd:un();break;case pN:try{let U=r?.replicates||r?.subscribers||r?.name;server.operation(L,{user:r},!U).then(ue=>{Array.isArray(ue)&&(ue={results:ue}),ue.requestId=L.requestId,e.send((0,je.encode)([Pg,ue]))},ue=>{e.send((0,je.encode)([Pg,{requestId:L.requestId,error:ue instanceof Error?ue.toString():ue}]))})}catch(U){e.send((0,je.encode)([Pg,{requestId:L.requestId,error:U instanceof Error?U.toString():U}]))}break;case Pg:let{resolve:D,reject:B}=g.get(L.requestId);L.error?B(new Error(L.error)):D(L),g.delete(L.requestId);break;case uN:let $=P[3];S||(u?le.error?.(s,"No tables found for",u):le.error?.(s,"Database name never received"));let j=S[$];j=fN({table:$,database:u,attributes:L.attributes,schemaDefined:L.schemaDefined},j),ou[k]={name:$,decoder:new je.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:L.typedStructs,structures:L.structures}),getEntry(U){return j.primaryStore.getEntry(U)},rootStore:j.primaryStore.rootStore};break;case AF:cu=d?Fk(L,d):new Map,HA=P[2],le.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${HA}`);break;case RF:let oe=k;Ef[oe]=L;break;case OF:br()[xF]=L,le.trace?.(s,"received and broadcasting committed update",L),br().buffer.notify();break;case bF:T=L,h.send({type:"end_txn",localTime:T,remoteNodeIds:R});break;case Dg:{let U=P[1],{fileId:ue,size:ce,finished:fe,error:te}=U,W=ye.get(ue);le.debug?.("Received blob",ue,"has stream",!!W,"connectedToBlob",!!W?.connectedToBlob,"length",P[2].length,"finished",fe),W||(W=new _N.PassThrough,W.expectedSize=ce,ye.set(ue,W)),W.lastChunk=Date.now(),fe?(te?(W.on("error",()=>{}),W.destroy(new Error("Blob error: "+te))):W.end(P[2]),W.connectedToBlob&&ye.delete(ue)):W.write(P[2]);break}case yF:{let U=L,ue;try{let ce=P[3],fe=au[k]||(au[k]=S[P[4]]);if(!fe)return le.warn?.("Unknown table id trying to handle record request",k);let te=fe.primaryStore.getBinaryFast(Symbol.for("structures")),W=te.length;if(W!==Xh){Xh=W;let Ee=(0,je.decode)(te);e.send((0,je.encode)([uN,{typedStructs:Ee.typed,structures:Ee.named},k,fe.tableName]))}let _e=fe.primaryStore.getBinaryFast(ce);if(_e){let Ee=fe.primaryStore.decoder.decode(_e,{valueAsBuffer:!0});ue=(0,je.encode)([Cg,U,{value:Ee.value,expiresAt:Ee.expiresAt,version:Ee.version,residencyId:Ee.residencyId,nodeId:Ee.nodeId,user:Ee.user}])}else ue=(0,je.encode)([Cg,U])}catch(ce){ue=(0,je.encode)([Cg,U,{error:ce.message}])}e.send(ue);break}case Cg:{let{resolve:U,reject:ue,tableId:ce,key:fe}=g.get(P[1]),te=P[2];if(te?.error)ue(new Error(te.error));else if(te){let W=ou[ce].decoder.decode(te.value);te.value=W,te.key=fe,U(te)}else U();g.delete(P[1]);break}case SF:{Cr=L;let U,ue,ce=!1;if(h){if(u!==h.databaseName&&!h.then){le.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=f.get(u);if(le.debug?.(s,"received subscription request for",u,"at",Cr),!h){let ge;h=new Promise(Qe=>{le.debug?.("Waiting for subscription to database "+u),ge=Qe}),h.ready=ge,Ha.set(u,h)}if(r.name)ue=or().subscribe(r.name),ue.then(async ge=>{U=ge;for await(let Qe of U){let st=Qe.value;if(!(st?.replicates===!0||st?.replicates?.receives||st?.subscriptions?.some(Vt=>(Vt.database||Vt.schema)===u&&Vt.publish!==!1))){ce=!0,e.send((0,je.encode)([dd])),un(1008,`Unauthorized database subscription to ${u}`);return}}},ge=>{le.error?.(s,"Error subscribing to HDB nodes",ge)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,je.encode)([dd])),un(1008,`Unauthorized database subscription to ${u}`);return}if(ln&&(le.debug?.(s,"stopping previous subscription",u),ln.emit("close")),Cr.length===0)return;let fe=Cr[0],te=a(ge=>{if(ge&&(fe.replicateByDefault?!fe.tables.includes(ge.tableName):fe.tables.includes(ge.tableName)))return{table:ge}},"tableToTableEntry"),W={txnTime:0},_e,Ee,Se=1/0,tt,Ye=a((ge,Qe)=>{if(ge.type==="end_txn"){W.txnTime&&(o[i]!==66&&le.error?.("Invalid encoding of message"),du(9),du(vg),Rc(tt=Qe),mr()),i=c,W.txnTime=0;return}let st=ge.nodeId,Vt=ge.tableId,Kt=Ee[Vt];if(!Kt&&(Kt=Ee[Vt]=te(h.tableById[Vt]),!Kt))return le.debug?.("Not subscribed to table",Vt);let qr=Kt.table,yc=qr.primaryStore,Ut=yc.encoder;(ge.extendedType&jm||!Ut.typedStructs)&&(Ut._mergeStructures(Ut.getStructures()),Ut.typedStructs&&(Ut.lastTypedStructuresLength=Ut.typedStructs.length));let em=_e[st];if(!(em&&em.startTime<Qe&&(!em.endTime||em.endTime>Qe)))return Lg&&le.trace?.(s,"skipping replication update",ge.recordId,"to:",E,"from:",st,"subscribed:",_e),oD();Lg&&le.trace?.(s,"sending replication update",ge.recordId,"to:",E,"from:",st,"subscribed:",_e);let FA=ge.version;W.txnTime!==FA&&(W.txnTime&&(Lg&&le.trace?.(s,"new txn time, sending queued txn",W.txnTime),o[i]!==66&&le.error?.("Invalid encoding of message"),mr()),W.txnTime=FA,i=c,Rc(FA));let bc=ge.residencyId,GA=lu(bc,qr),tm;if(GA&&!GA.includes(E)){let Oc=lu(ge.previousResidencyId,qr);if(Oc&&!Oc.includes(E)&&(ge.type==="put"||ge.type==="patch")||qr.getResidencyById)return oD();let Rf=ge.recordId;le.trace?.(s,"sending invalidation",Rf,E,"from",st);let ca=0;bc&&(ca|=kc),ge.previousResidencyId&&(ca|=Fc);let Ks,dn=null;for(let rm in qr.indices){if(!dn){if(Ks=ge.getValue(yc,!0),!Ks)break;dn={}}dn[rm]=Ks[rm]}tm=Nu(ge.version,Vt,Rf,null,st,ge.user,ge.type==="put"||ge.type==="patch"?"invalidate":ge.type,Ut.encode(dn),ca,bc,ge.previousResidencyId,ge.expiresAt)}function oD(){le.trace?.(s,"skipping audit record",ge.recordId),Y||(Y=setTimeout(()=>{Y=null,(tt||0)+wF/2<Se&&(Lg&&le.trace?.(s,"sending skipped sequence update",Se),e.send((0,je.encode)([bF,Se])))},wF).unref())}a(oD,"skipAuditRecord");let qA=Ut.typedStructs,$A=Ut.structures;if((qA?.length!=Kt.typed_length||$A?.length!=Kt.structure_length)&&(Kt.typed_length=qA?.length,Kt.structure_length=$A.length,le.debug?.(s,"send table struct",Kt.typed_length,Kt.structure_length),Kt.sentName||(Kt.sentName=!0),e.send((0,je.encode)([uN,{typedStructs:qA,structures:$A,attributes:qr.attributes,schemaDefined:qr.schemaDefined},Vt,Kt.table.tableName]))),bc&&!vt[bc]&&(e.send((0,je.encode)([RF,GA,bc])),vt[bc]=!0),tm)du(tm.length),Ac(tm);else{let Oc=ge.encoded;ge.extendedType&Fn&&PR(()=>ge.getValue(yc),async ca=>{let Ks=Hm(ca);try{let dn;he++;for await(let rm of ca.stream()){if(dn&&(le.debug?.("Sending blob chunk",Ks,"length",dn.length),e.send((0,je.encode)([Dg,{fileId:Ks,size:ca.size},dn]))),dn=rm,ce)return;e._socket.writableNeedDrain&&(le.debug?.("draining",Ks),await new Promise(g2=>e._socket.once("drain",g2)),le.debug?.("drained",Ks))}le.debug?.("Sending final blob chunk",Ks,"length",dn.length),e.send((0,je.encode)([Dg,{fileId:Ks,size:ca.size,finished:!0},dn]))}catch(dn){le.debug?.("Error sending blob",dn),e.send((0,je.encode)([Dg,{fileId:Ks,finished:!0,error:dn.toString()},Buffer.alloc(0)]))}finally{he--,he<Qh&&Nt?.()}});let Rf=Oc[0]===66?8:0;du(Oc.length-Rf),Ac(Oc,Rf),le.trace?.("wrote record",ge.recordId,"length:",Oc.length)}},"sendAuditRecord"),mr=a(()=>{c-i>8?(e.send(o.subarray(i,c)),le.debug?.(s,"Sent message, size:",c-i)):le.debug?.(s,"skipping empty transaction")},"sendQueuedData");ln=new EN.EventEmitter,ln.once("close",()=>{ce=!0,U?.end()});for(let{startTime:ge}of Cr)ge<Se&&(Se=ge);(ue||Promise.resolve()).then(async()=>{h=await h,d=h.auditStore,Ee=h.tableById.map(te),_e=[];for(let{name:Qe,startTime:st,endTime:Vt}of Cr){let Kt=Ag(Qe,d);le.debug?.("subscription to",Qe,"using local id",Kt,"starting",st),_e[Kt]={startTime:st,endTime:Vt}}oa(u),hs||(hs=Tl(Qe=>{Qe.databaseName===u&&oa(u)}),Un=pp(Qe=>{Qe===u&&(e.send((0,je.encode)([dd])),un())}),e.on("close",()=>{hs?.remove(),Un?.remove()})),e.send((0,je.encode)([AF,ip(h.auditStore),Cr.map(({name:Qe})=>Qe)]));let ge=!0;do{isFinite(Se)||(le.warn?.("Invalid sequence id "+Se),un(1008,"Invalid sequence id"+Se));let Qe;if(ge&&!ce&&(ge=!1,!(TN(d)<=Se)&&(PF.default.get(x.REPLICATION_COPYTABLESTOCATCHUP)??Bie)&&server.nodes[0]?.name===E)){le.info?.("Replicating all tables to",E);let Vt=Se,Kt=xg(d);for(let qr in S){if(!te(qr))continue;let yc=S[qr];for(let Ut of yc.primaryStore.getRange({snapshot:!1})){if(ce)return;Ut.localTime>=Se&&(le.trace?.(s,"Copying record from",u,qr,Ut.key,Ut.localTime),Vt=Math.max(Ut.localTime,Vt),Qe=!0,br()[Mg]=1,Ye({recordId:Ut.key,tableId:yc.tableId,type:"put",getValue(){return Ut.value},encoded:yc.primaryStore.getBinary(Ut.key),version:Ut.version,residencyId:Ut.residencyId,nodeId:Kt,extendedType:Ut.metadataFlags},Ut.localTime))}}Se=Vt}for(let{key:st,value:Vt}of d.getRange({start:Se||1,exclusiveStart:!0,snapshot:!1})){if(ce)return;let Kt=It(Vt);le.debug?.("sending audit record",new Date(st)),br()[Mg]=st,Se=st,Ye(Kt,st),e._socket.writableNeedDrain?await new Promise(qr=>{le.debug?.(`Waiting for remote node ${E} to allow more commits ${e._socket.writableNeedDrain?"due to network backlog":"due to requested flow directive"}`),e._socket.once("drain",qr)}):he>Qh?await new Promise(qr=>{Nt=qr}):await new Promise(setImmediate),ln.startTime=st,Qe=!0}Qe&&Ye({type:"end_txn"},Se),br()[Mg]=0,await HF(d)}while(!ce)}).catch(ge=>{le.error?.(s,"Error handling subscription to node",ge),un(1008,"Error handling subscription to node")});break}}return}A.position=8;let I=!0,y,O;do{br();let P=A.readInt();if(P===9&&A.getUint8(A.position)==vg){A.position++,T=O=A.readFloat64(),p[hN]=T,p[mN]=Date.now(),le.trace?.("received remote sequence update",T,u);break}let N=A.position,L=It(m,N,N+P),k=ou[L.tableId];k||le.error?.(`No table found with an id of ${L.tableId}`);let D;L.residencyId&&(D=Ef[L.residencyId],le.trace?.(s,"received residency list",D,L.type,L.recordId));try{CR(()=>{y={table:k.name,id:L.recordId,type:L.type,nodeId:cu.get(L.nodeId),residencyList:D,timestamp:L.version,value:L.getValue(k),user:L.user,beginTxn:I,expiresAt:L.expiresAt}},B=>{let $=Hm(B),j=ye.get($);le.debug?.("Received transaction with blob",$,"has stream",!!j,"ended",!!j?.writableEnded),j?j.writableEnded&&ye.delete($):(j=new _N.PassThrough,ye.set($,j)),j.connectedToBlob=!0,j.lastChunk=Date.now(),B.size===void 0&&j.expectedSize&&(B.size=j.expectedSize);let oe=createBlob(j,B),U=oe.save({primaryStore:h.auditStore});return U&&(U.blobId=$,Pe.push(U),U.finally(()=>{le.debug?.(`Finished receiving blob stream ${$}`),Pe.splice(Pe.indexOf(U),1)})),oe})}catch(B){throw B.message+="typed structures for current decoder"+JSON.stringify(k.decoder.typedStructs),B}I=!1,le.trace?.(s,"received replication message",L.type,"id",y.id,"version",new Date(L.version),"nodeId",y.nodeId),p[hN]=L.version,p[mN]=Date.now(),h.send(y),A.position=N+P}while(A.position<m.byteLength);gf++,sr(m.byteLength,"bytes-received",`${E}.${u}.${y?.table||"unknown_table"}`,"replication","ingest"),gf>Jh&&!Ie&&(Ie=!0,e.pause(),le.debug?.(`Commit backlog causing replication back-pressure, requesting that ${E} pause replication`)),h.send({type:"end_txn",localTime:T,remoteNodeIds:R,async onCommit(){if(y){let P=Date.now()-y.timestamp;sr(P,"replication-latency",E+"."+u+"."+y.table,y.type,"ingest")}gf--,Ie&&(Ie=!1,e.resume(),le.debug?.(`Replication resuming ${E}`)),Pe.length>0&&await Promise.all(Pe),le.trace?.("All blobs finished"),!b&&O&&(le.trace?.(s,"queuing confirmation of a commit at",O),setTimeout(()=>{e.send((0,je.encode)([OF,b])),le.trace?.(s,"sent confirmation of a commit at",b),b=null},Hie)),b=O,le.debug?.("last sequence committed",new Date(O),u)}})}catch(A){le.error?.(s,"Error handling incoming replication message",A)}}),e.on("ping",dt),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-q,hl({name:E,database:u,url:t.url,latency:t.connection.latency})),q=null}),e.on("close",(m,A)=>{clearInterval(v),clearTimeout(F),clearInterval(Z),ln&&ln.emit("close"),Sf&&Sf.end();for(let[I,{reject:y}]of g)y(new Error(`Connection closed ${A?.toString()} ${m}`));le.debug?.(s,"closed",m,A?.toString())});function Tf(){}a(Tf,"recordRemoteNodeSequence");function un(m,A){e.isFinished=!0,e.close(m,A)}a(un,"close");function Gr(){if(_||(_=!0,t.connection?.on("subscriptions-updated",Gr)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let m=new Map;try{for(let y of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let O of y.value.nodes||[])O.lastTxnTime>(m.get(O.id)??0)&&m.set(O.id,O.lastTxnTime)}catch(y){if(!y.message.includes("Can not re"))throw y}let A=t.connection?.nodeSubscriptions?.[0];R=[];let I=t.connection?.nodeSubscriptions.map((y,O)=>{let P=[],{replicateByDefault:N}=y;if(y.subscriptions){for(let B of y.subscriptions)if(B.subscribe&&(B.schema||B.database)===u){let $=B.table;S?.[$]?.replicate!==!1&&P.push($)}N=!1}else for(let B in S)(N?S[B].replicate===!1:S[B].replicate)&&P.push(B);let L=d&&Ag(y.name,d),k=h?.dbisDB?.get([Symbol.for("seq"),L])??1,D=Math.max(k?.seqId??1,(typeof y.start_time=="string"?new Date(y.start_time).getTime():y.start_time)??1);if(le.debug?.("Starting time recorded in db",y.name,L,u,k?.seqId,"start time:",D,new Date(D)),A!==y){let B=d&&Ag(A.name,d),$=h?.dbisDB?.get([Symbol.for("seq"),B])??1;for(let j of $?.nodes||[])j.name===y.name&&(D=j.seqId,le.debug?.("Using sequence id from proxy node",A.name,D))}return R.push(L),m.get(L)>D&&(D=m.get(L),le.debug?.("Updating start time from more recent txn recorded",A.name,D)),{name:y.name,replicateByDefault:N,tables:P,startTime:D,endTime:y.end_time}});if(I)if(le.debug?.(s,"sending subscription request",I,h?.dbisDB?.path),clearTimeout(Q),I.length>0)e.send((0,je.encode)([SF,I]));else{let y=a(()=>{let O=performance.now();Q=setTimeout(()=>{ne<=O?un(1008,"No nodes to subscribe to"):y()},se)},"schedule_close");y()}}a(Gr,"sendSubscriptionRequestUpdate");function lu(m,A){if(!m)return;let I=kA[m];return I||(I=A.getResidencyRecord(m),kA[m]=I),I}a(lu,"getResidence");function uu(m){return!(Ba&&Ba!="*"&&!Ba[m]&&!Ba.includes?.(m)&&!Ba.some?.(A=>A.name===m))}a(uu,"checkDatabaseAccess");function ia(m){if(h=h||f.get(m),!uu(m))throw new Error(`Access to database "${m}" is not permitted`);h||le.warn?.(`No database named "${m}" was declared and registered`),d=h?.auditStore,S||(S=Xe()?.[m]);let A=Ze();if(A===E)throw A?new Error("Should not connect to self",A):new Error("Node name not defined");return Zh(A,m),!0}a(ia,"setDatabase");function Zh(m,A){let I=Xe()?.[A],y=[];for(let O in I){let P=I[O];y.push({table:O,schemaDefined:P.schemaDefined,attributes:P.attributes.map(N=>({name:N.name,type:N.type,isPrimaryKey:N.isPrimaryKey}))})}le.trace?.("Sending database info for node",m,"database name",A),e.send((0,je.encode)([TF,m,A,y]))}a(Zh,"sendNodeDBName");function oa(m){let A=Xe()?.[m],I=[];for(let y in A){if(Cr&&!Cr.some(P=>P.replicateByDefault?!P.tables.includes(y):P.tables.includes(y)))continue;let O=A[y];I.push({table:y,schemaDefined:O.schemaDefined,attributes:O.attributes.map(P=>({name:P.name,type:P.type,isPrimaryKey:P.isPrimaryKey}))})}e.send((0,je.encode)([NF,I,m]))}a(oa,"sendDBSchema"),Z=setInterval(()=>{for(let[m,A]of ye)A.lastChunk+3e4<Date.now()&&(le.warn?.(`Timeout waiting for blob stream to finish ${m} from ${E}`),ye.delete(m),A.end())},3e4).unref();let aa=1,Af=[];return{end(){Sf&&Sf.end(),ln&&ln.emit("close")},getRecord(m){let A=aa++;return new Promise((I,y)=>{let O=[yF,A,m.table.tableId,m.id];Af[m.table.tableId]||(O.push(m.table.tableName),Af[m.table.tableId]=!0),e.send((0,je.encode)(O)),g.set(A,{tableId:m.table.tableId,key:m.id,resolve(P){let{table:N,entry:L}=m;I(P),P&&N._recordRelocate(L,P)},reject:y})})},sendOperation(m){let A=aa++;return m.requestId=A,e.send((0,je.encode)([pN,m])),new Promise((I,y)=>{g.set(A,{resolve:I,reject:y})})}};function du(m){V(5),m<128?o[c++]=m:m<16384?(l.setUint16(c,m|32768),c+=2):m<1056964608?(l.setUint32(c,m|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,m),c+=5)}function Ac(m,A=0,I=m.length){let y=I-A;V(y),m.copy(o,c,A,I),c+=y}function Rc(m){V(8),l.setFloat64(c,m),c+=8}function V(m){if(m+16>o.length-c){let A=Buffer.allocUnsafeSlow(c+m-i+65536>>10<<11);o.copy(A,0,i,c),c=c-i,i=0,o=A,l=new DataView(o.buffer,0,o.length)}}}function fN(e,t){let r=e.database??"data";if(r!=="data"&&!qe[r]){le.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(le.debug?.("(Re)creating",e),ft({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var PF,je,DF,LF,le,EN,MF,vF,El,UF,_N,SF,TF,AF,dd,RF,uN,yF,Cg,pN,Pg,bF,OF,NF,Dg,xF,hN,mN,Mg,Bie,gN,Ha,Lg,wF,Hie,IF,dN,CF,fp,SN=be(()=>{De();fo();zO();AN();Xn();PF=M(ae());H();wu();je=require("msgpackr"),DF=require("ws"),LF=require("worker_threads"),le=M(Ni());lp();EN=require("events"),MF=M(Zn()),vF=M(require("node:tls"));pl();El=M(require("node:process")),UF=require("node:net");ki();gs();_N=require("node:stream"),SF=129,TF=140,AF=141,dd=142,RF=130,uN=132,yF=133,Cg=134,pN=136,Pg=137,bF=143,OF=144,NF=145,Dg=146,xF=0,hN=1,mN=2,Mg=3,Bie=El.env.HDB_LEADER_URL||El.argv.includes("--HDB_LEADER_URL"),gN=new Map,Ha=new Map,Lg=!0,wF=300,Hie=2,IF=3e4;a(Ug,"createWebSocket");CF=1e3,fp=class extends EN.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??ai(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=CF;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await Ug(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;le.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${El.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),le[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=CF,hl({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=_p(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(le.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?le.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):le.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(ad({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();le.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(_p,"replicateOverWS");a(fN,"ensureTableIfChanged")});var wo={};ve(wo,{clearThisNodeName:()=>Yie,disableReplication:()=>qie,enabled_databases:()=>Ba,forEachReplicatedDatabase:()=>Da,getThisNodeId:()=>xg,getThisNodeName:()=>Ze,getThisNodeUrl:()=>La,hostnameToUrl:()=>Fg,lastTimeInAuditStore:()=>op,monitorNodeCAs:()=>YF,replicateOperation:()=>zie,replication_certificate_authorities:()=>gl,sendOperationToNode:()=>mp,servers:()=>Fie,setReplicator:()=>zF,start:()=>Gie,startOnMainThread:()=>QO,subscribeToNode:()=>od,unsubscribeFromNode:()=>Og,urlToNodeName:()=>ai});function Gie(e){if(e.port||(e.port=Os.default.get(x.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=Os.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),!Ze())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of cp(e))t.set(ai(n.url),n);$ie(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=We.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),_p(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&cr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,We.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&cr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=or().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));if(c)if(c?.revoked_certificates?.includes(n.peerCertificate.serialNumber)){cr.warn("Revoked certificate used in attempt to connect to node",c.name,"certificate serial number",n.peerCertificate.serialNumber);return}else n.user=c;else cr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:cr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(gl);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.updatedContext=kg.createSecureContext(l)}catch(c){cr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),YF(s),Os.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function YF(e){let t=0;sd(r=>{r?.ca&&(gl.add(r.ca),gl.size!==t&&(t=gl.size,e?.()))})}function qie(e=!0){KF=e}function $ie(e){KF||(Xe(),Ba=e.databases,Da(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Ha;for(let[s,i]of hp){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];zF(r,s,e),gN.get(s)?.forEach(i=>i(s))}}))}function zF(e,t,r){if(!t)return console.error(`Attempt to replicate non-existent table ${t.name} from database ${e}`);if(t.replicate===!1||t.sources?.some(s=>s.isReplicator))return;let n;t.sourcedFrom(class WF extends $r{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Ha,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(cr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Bn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let f;for(let p of c){let _=Vie(p,WF.subscription,e);_?.isConnected&&!u.has(_)&&(!f||_.latency<f.latency)&&(f=_)}if(!f)throw l||new $F.ServerError("No connection to any other nodes are available",502);let d={requestId:kie++,table:t,entry:i,id:i.key};u.add(f);try{return await f.getRecord(d)}catch(p){if(f.isConnected)throw p;cr.warn("Error in load from node",Hg,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function jF(e,t,r,n,s){let i=hp.get(e);i||hp.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new fp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function Vie(e,t,r){let n=kF.get(e)?.get(r);if(n)return n;let s=or().primaryStore.get(e);return s?.url&&(n=jF(s.url,t,r,e,s.authorization),kF.set(e,hp.get(s.url))),n}async function mp(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ug(e.url,r),s=_p(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{cr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function od(e){try{VF.isMainThread&&cr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Ha.get(e.database);if(!t){let n;t=new Promise(s=>{cr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Ha.set(e.database,t)}let r=jF(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>ap(n,e.database)),e.replicateByDefault)}catch(t){cr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Og({name:e,url:t,database:r}){cr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(or().primaryStore.getRange({})));let n=hp.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Kie(){if(RN!==void 0)return RN;let e=Os.default.get(x.OPERATIONSAPI_TLS_CERTIFICATE)||Os.default.get(x.TLS_CERTIFICATE);if(e)return RN=new GF.X509Certificate((0,qF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Ze(){return Hg||(Hg=Os.default.get("replication_hostname")??ai(Os.default.get("replication_url"))??Kie()??FF("operationsapi_network_secureport")??FF("operationsapi_network_port")??"127.0.0.1")}function Yie(){Hg=void 0}function FF(e){let t=Os.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Bg(e){let t=Os.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function xg(e){return ip(e)?.[Ze()]}function La(){let e=Os.default.get("replication_url");return e||Fg(Ze())}function Fg(e){let t=Bg("replication_port");if(t)return`ws://${e}:${t}`;if(t=Bg("replication_secureport"),t)return`wss://${e}:${t}`;if(t=Bg("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=Bg("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function ai(e){if(e)return new URL(e).hostname}function Da(e,t){for(let n of Object.getOwnPropertyNames(qe))r(n);return pp(n=>{r(n)}),Tl((n,s)=>{r(n.databaseName)});function r(n){let s=qe[n];cr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):Wie(n)&&t(s,n,!1)}a(r,"forDatabase")}function Wie(e){let t=qe[e];for(let r in t)if(t[r].replicate)return!0}function op(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function zie(e){let t={message:""};if(e.replicated){e.replicated=!1,cr.trace?.("Replicating operation",e.operation,"to nodes",We.nodes.map(n=>n.name));let r=await Promise.allSettled(We.nodes.map(n=>mp(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=We.nodes[s]?.name,i})}return t}var Os,cr,GF,qF,kg,$F,VF,KF,kie,Fie,gl,Ba,hp,kF,RN,Hg,Xn=be(()=>{De();Ea();pu();SN();Vr();Os=M(ae()),cr=M(z()),GF=require("crypto"),qF=require("fs");lp();pl();H();zO();kg=M(require("node:tls")),$F=M(pe()),VF=require("worker_threads"),kie=1,Fie=[],gl=Os.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1?new Set(kg.rootCertificates):new Set;a(Gie,"start");a(YF,"monitorNodeCAs");a(qie,"disableReplication");a($ie,"assignReplicationSource");a(zF,"setReplicator");hp=new Map;a(jF,"getConnection");kF=new Map;a(Vie,"getConnectionByName");a(mp,"sendOperationToNode");a(od,"subscribeToNode");a(Og,"unsubscribeFromNode");a(Kie,"getCommonNameFromCert");a(Ze,"getThisNodeName");a(Yie,"clearThisNodeName");Object.defineProperty(We,"hostname",{get(){return Ze()}});a(FF,"getHostFromListeningPort");a(Bg,"getPortFromListeningPort");a(xg,"getThisNodeId");We.replication={getThisNodeId:xg,exportIdMapping:ip};a(La,"getThisNodeUrl");a(Fg,"hostnameToUrl");a(ai,"urlToNodeName");a(Da,"forEachReplicatedDatabase");a(Wie,"hasExplicitlyReplicatedTable");a(op,"lastTimeInAuditStore");a(zie,"replicateOperation")});var Kg=w((lDe,eG)=>{"use strict";var fd=lk(),{validateBySchema:Ep}=ot(),{common_validators:_d,schema_regex:yN}=Di(),lr=require("joi"),jie=z(),Jie=require("uuid").v4,$g=To(),pd=(H(),C(G)),Qie=require("util"),ka=Vn(),{handleHDBError:Io,hdb_errors:Xie,ClientError:gp}=pe(),{HDB_ERROR_MSGS:Gg,HTTP_STATUS_CODES:Co}=Xie,{SchemaEventMsg:Vg}=ri(),JF=ir(),{getDatabases:Zie}=(De(),C(nt)),{transformReq:hd}=ie(),{replicateOperation:QF}=(Xn(),C(wo)),qg=lr.string().min(1).max(_d.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+_d.schema_format.message}),eoe=lr.string().min(1).max(_d.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+_d.schema_format.message}).required(),toe=lr.string().min(1).max(_d.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+_d.schema_format.message,"any.required":"'primary_key' is required","string.base":"'primary_key' must be a string"}).required();eG.exports={createSchema:roe,createSchemaStructure:XF,createTable:noe,createTableStructure:ZF,createAttribute:coe,dropSchema:soe,dropTable:ioe,dropAttribute:ooe,getBackup:loe};async function roe(e){let t=await XF(e);return $g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema)),t}a(roe,"createSchema");async function XF(e){let t=Ep(e,lr.object({database:qg,schema:qg}));if(t)throw new gp(t.message);if(hd(e),!await fd.checkSchemaExists(e.schema))throw Io(new Error,Gg.SCHEMA_EXISTS_ERR(e.schema),Co.BAD_REQUEST,pd.LOG_LEVELS.ERROR,Gg.SCHEMA_EXISTS_ERR(e.schema),!0);return await ka.createSchema(e),`database '${e.schema}' successfully created`}a(XF,"createSchemaStructure");async function noe(e){return hd(e),e.hash_attribute=e.primary_key??e.hash_attribute,await ZF(e)}a(noe,"createTable");async function ZF(e){let t=Ep(e,lr.object({database:qg,schema:qg,table:eoe,residence:lr.array().items(lr.string().min(1)).optional(),hash_attribute:toe}));if(t)throw new gp(t.message);if(!await fd.checkSchemaTableExists(e.schema,e.table))throw Io(new Error,Gg.TABLE_EXISTS_ERR(e.schema,e.table),Co.BAD_REQUEST,pd.LOG_LEVELS.ERROR,Gg.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Jie(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ka.createTable(n,e);else throw Io(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Co.BAD_REQUEST);else await ka.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(ZF,"createTableStructure");async function soe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string()}).or("database","schema").messages({"object.missing":"'database' is required"}));if(t)throw new gp(t.message);hd(e);let r=await fd.checkSchemaExists(e.schema);if(r)throw Io(new Error,r,Co.NOT_FOUND,pd.LOG_LEVELS.ERROR,r,!0);let n=await fd.schema_describe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await ka.dropSchema(e),$g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema)),await JF.purgeSchemaTableStreams(e.schema,s);let i=await QF(e);return i.message=`successfully deleted '${e.schema}'`,i}a(soe,"dropSchema");async function ioe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required()}));if(t)throw new gp(t.message);hd(e);let r=await fd.checkSchemaTableExists(e.schema,e.table);if(r)throw Io(new Error,r,Co.NOT_FOUND,pd.LOG_LEVELS.ERROR,r,!0);await ka.dropTable(e),await JF.purgeTableStream(e.schema,e.table);let n=await QF(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(ioe,"dropTable");async function ooe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required(),attribute:lr.string().required()}));if(t)throw new gp(t.message);hd(e);let r=await fd.checkSchemaTableExists(e.schema,e.table);if(r)throw Io(new Error,r,Co.NOT_FOUND,pd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Io(new Error,"You cannot drop a hash attribute",Co.BAD_REQUEST,void 0,void 0,!0);if(pd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Io(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Co.BAD_REQUEST,void 0,void 0,!0);try{return await ka.dropAttribute(e),aoe(e),$g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw jie.error(`Got an error deleting attribute ${Qie.inspect(e)}.`),n}}a(ooe,"dropAttribute");function aoe(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(aoe,"dropAttributeFromGlobal");async function coe(e){hd(e);let t=Zie()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Io(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Co.BAD_REQUEST,void 0,void 0,!0);return await ka.createAttribute(e),$g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(coe,"createAttribute");function loe(e){return ka.getBackup(e)}a(loe,"getBackup")});var rG=w((dDe,tG)=>{"use strict";var{OPERATIONS_ENUM:uoe}=(H(),C(G)),bN=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=uoe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};tG.exports=bN});var ON=w((pDe,aG)=>{"use strict";var doe=Vn(),_De=rG(),Yg=ie(),Wg=(H(),C(G)),foe=ae(),{handleHDBError:nG,hdb_errors:_oe}=pe(),{HDB_ERROR_MSGS:sG,HTTP_STATUS_CODES:iG}=_oe,poe=Object.values(Wg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),oG="To use this operation audit log must be enabled in harperdb-config.yaml";aG.exports=hoe;async function hoe(e){if(Yg.isEmpty(e.schema))throw new Error(sG.SCHEMA_REQUIRED_ERR);if(Yg.isEmpty(e.table))throw new Error(sG.TABLE_REQUIRED_ERR);if(!foe.get(Wg.CONFIG_PARAMS.LOGGING_AUDITLOG))throw nG(new Error,oG,iG.BAD_REQUEST,Wg.LOG_LEVELS.ERROR,oG,!0);let t=Yg.checkSchemaTableExist(e.schema,e.table);if(t)throw nG(new Error,t,iG.NOT_FOUND,Wg.LOG_LEVELS.ERROR,t,!0);if(!Yg.isEmpty(e.search_type)&&poe.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await doe.readAuditLog(e)}a(hoe,"readAuditLog")});var lG=w((mDe,cG)=>{"use strict";var{OPERATIONS_ENUM:moe}=(H(),C(G)),NN=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=moe.GET_BACKUP,this.schema=t,this.table=r}};cG.exports=NN});var fG=w((TDe,dG)=>{"use strict";var Eoe=Vn(),gDe=lG(),wN=ie(),goe=(H(),C(G)),SDe=ae(),{handleHDBError:Soe,hdb_errors:Toe}=pe(),{HDB_ERROR_MSGS:uG,HTTP_STATUS_CODES:Aoe}=Toe;dG.exports=Roe;async function Roe(e){if(wN.isEmpty(e.schema))throw new Error(uG.SCHEMA_REQUIRED_ERR);if(wN.isEmpty(e.table))throw new Error(uG.TABLE_REQUIRED_ERR);let t=wN.checkSchemaTableExist(e.schema,e.table);if(t)throw Soe(new Error,t,Aoe.NOT_FOUND,goe.LOG_LEVELS.ERROR,t,!0);return await Eoe.getBackup(read_audit_log_object)}a(Roe,"getBackup")});var mG=w((RDe,hG)=>{"use strict";var yoe=ae(),Fa=require("joi"),boe=ot(),_G=require("moment"),Ooe=require("fs-extra"),IN=require("path"),Noe=require("lodash"),Sp=(H(),C(G)),{LOG_LEVELS:Al}=(H(),C(G)),woe="YYYY-MM-DD hh:mm:ss",Ioe=IN.resolve(__dirname,"../logs");hG.exports=function(e){return boe.validateBySchema(e,Coe)};var Coe=Fa.object({from:Fa.custom(pG),until:Fa.custom(pG),level:Fa.valid(Al.NOTIFY,Al.FATAL,Al.ERROR,Al.WARN,Al.INFO,Al.DEBUG,Al.TRACE),order:Fa.valid("asc","desc"),limit:Fa.number().min(1),start:Fa.number().min(0),log_name:Fa.custom(Poe)});function pG(e,t){if(_G(e,_G.ISO_8601).format(woe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(pG,"validateDatetime");function Poe(e,t){if(Noe.invert(Sp.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=yoe.get(Sp.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Sp.LOG_NAMES.HDB:e,i=s===Sp.LOG_NAMES.INSTALL?IN.join(Ioe,Sp.LOG_NAMES.INSTALL):IN.join(n,s);return Ooe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Poe,"validateReadLogPath")});var PN=w((bDe,gG)=>{"use strict";var zg=(H(),C(G)),Doe=z(),Loe=ae(),Moe=mG(),CN=require("path"),EG=require("fs-extra"),{once:voe}=require("events"),{handleHDBError:Uoe,hdb_errors:xoe}=pe(),{PACKAGE_ROOT:Boe}=it(),Hoe=CN.join(Boe,"logs"),koe=1e3,Foe=200;gG.exports=Goe;async function Goe(e){let t=Moe(e);if(t)throw Uoe(t,t.message,xoe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Loe.get(zg.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?zg.LOG_NAMES.HDB:e.log_name,s=n===zg.LOG_NAMES.INSTALL?CN.join(Hoe,zg.LOG_NAMES.INSTALL):CN.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,f=u?new Date(e.until):void 0,d=e.limit===void 0?koe:e.limit,p=e.order===void 0?void 0:e.order,_=e.start===void 0?0:e.start,h=_+d,S=0;p==="desc"&&!l&&!f&&(S=Math.max(EG.statSync(s).size-(h+5)*Foe,0));let g=EG.createReadStream(s,{start:S});g.on("error",F=>{Doe.error(F)});let R=0,E=[],T="",b;g.on("data",F=>{let q=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;F=T+F;let Y=0,Z;for(;(Z=q.exec(F))&&!g.destroyed;){b&&(b.message=F.slice(Y,Z.index),v(b));let[se,Q,ne]=Z,J=ne.split("] ["),me=J[0],ye=J[1];J.splice(0,2),b={timestamp:Q,thread:me,level:ye,tags:J,message:""},Y=Z.index+se.length}T=F.slice(Y)}),g.on("end",F=>{g.destroyed||b&&(b.message=T.trim(),v(b))}),g.resume();function v(F){let q,Y,Z;switch(!0){case(i&&c&&u):q=new Date(F.timestamp),Y=new Date(l),Z=new Date(f),F.level===o&&q>=Y&&q<=Z&&R<_?R++:F.level===o&&q>=Y&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(i&&c):q=new Date(F.timestamp),Y=new Date(l),F.level===o&&q>=Y&&R<_?R++:F.level===o&&q>=Y&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(i&&u):q=new Date(F.timestamp),Z=new Date(f),F.level===o&&q<=Z&&R<_?R++:F.level===o&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(c&&u):q=new Date(F.timestamp),Y=new Date(l),Z=new Date(f),q>=Y&&q<=Z&&R<_?R++:q>=Y&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case i:F.level===o&&R<_?R++:F.level===o&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case c:q=new Date(F.timestamp),Y=new Date(l),q>=Y&&R<_?R++:q>=Y&&R>=_&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case u:q=new Date(F.timestamp),Z=new Date(f),q<=Z&&R<_?R++:q<=Z&&R>=_&&(Ga(F,p,E),R++,R===h&&g.destroy());break;default:R<_?R++:(Ga(F,p,E),R++,R===h&&g.destroy())}}return a(v,"onLogMessage"),await voe(g,"close"),E}a(Goe,"readLog");function Ga(e,t,r){t==="desc"?qoe(e,r):t==="asc"?$oe(e,r):r.push(e)}a(Ga,"pushLineToResult");function qoe(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(qoe,"insertDescending");function $oe(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a($oe,"insertAscending")});var jg=w((PDe,RG)=>{"use strict";var DN=require("joi"),{string:md,boolean:SG,date:Voe}=DN.types(),Koe=ot(),{validateSchemaExists:NDe,validateTableExists:wDe,validateSchemaName:IDe}=Di(),Yoe=(H(),C(G)),Woe=Tt(),TG=ae();TG.initSync();var CDe=md.invalid(TG.get(Yoe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(Woe.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),AG={operation:md.valid("add_node","update_node","set_node_replication"),node_name:md.optional(),subscriptions:DN.array().items({table:md.optional(),schema:md.optional(),database:md.optional(),subscribe:SG.required(),publish:SG.required().custom(joe),start_time:Voe.iso()})};function zoe(e){return Koe.validateBySchema(e,DN.object(AG))}a(zoe,"addUpdateNodeValidator");function joe(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(joe,"checkForFalsy");RG.exports={addUpdateNodeValidator:zoe,validation_schema:AG}});var Ed=w((LDe,yG)=>{"use strict";var LN=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},MN=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};yG.exports={Node:LN,NodeSubscription:MN}});var OG=w((vDe,bG)=>{"use strict";var Joe=(H(),C(G)).OPERATIONS_ENUM,vN=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Joe.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};bG.exports=vN});var Tp=w((xDe,NG)=>{"use strict";var UN=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},xN=class{static{a(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,o,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=o,c!==void 0&&(this.attributes=c)}};NG.exports={RemotePayloadObject:UN,RemotePayloadSubscription:xN}});var IG=w((HDe,wG)=>{"use strict";var BN=class{static{a(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=n,this.record_count=s,this.transaction_log_size=i,this.transaction_log_record_count=o}};wG.exports=BN});var PG=w((VDe,CG)=>{"use strict";var Qoe=IG(),FDe=xt(),GDe=_t(),Xoe=z(),{getSchemaPath:qDe,getTransactionAuditStorePath:$De}=gt(),{getDatabases:Zoe}=(De(),C(nt));CG.exports=eae;async function eae(e){let t=new Qoe;try{let r=Zoe()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){Xoe.warn(`unable to stat table dbi due to ${r}`)}return t}a(eae,"lmdbGetTableSize")});var LG=w((YDe,DG)=>{"use strict";var HN=class{static{a(this,"SystemInformationObject")}constructor(t,r,n,s,i,o,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=o,this.harperdb_processes=c}};DG.exports=HN});var Po=w((XDe,xG)=>{"use strict";var tae=require("fs-extra"),rae=require("path"),Xr=require("systeminformation"),qa=z(),MG=ir(),zDe=Tt(),gd=(H(),C(G)),nae=PG(),sae=go(),{getThreadInfo:vG}=rt(),Ap=ae();Ap.initSync();var iae=LG(),{openEnvironment:jDe}=_t(),{getSchemaPath:JDe}=gt(),{database:QDe,databases:kN}=(De(),C(nt)),Jg;xG.exports={getHDBProcessInfo:$N,getNetworkInfo:KN,getDiskInfo:VN,getMemoryInfo:qN,getCPUInfo:GN,getTimeInfo:FN,getSystemInformation:YN,systemInformation:oae,getTableSize:WN,getMetrics:zN};function FN(){return Xr.time()}a(FN,"getTimeInfo");async function GN(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...f}=await Xr.cpu();f.cpu_speed=await Xr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:p,raw_currentload_irq:_,raw_currentload_nice:h,raw_currentload_system:S,raw_currentload_user:g,cpus:R,...E}=await Xr.currentLoad();return E.cpus=[],R.forEach(T=>{let{raw_load:b,raw_load_idle:v,raw_load_irq:F,raw_load_nice:q,raw_load_system:Y,raw_load_user:Z,...se}=T;E.cpus.push(se)}),f.current_load=E,f}catch(e){return qa.error(`error in getCPUInfo: ${e}`),{}}}a(GN,"getCPUInfo");async function qN(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Xr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return qa.error(`error in getMemoryInfo: ${e}`),{}}}a(qN,"getMemoryInfo");async function $N(){let e={core:[],clustering:[]};try{let t=await Xr.processes(),r;try{r=Number.parseInt(await tae.readFile(rae.join(Ap.get(gd.CONFIG_PARAMS.ROOTPATH),gd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===gd.NODE_ERROR_CODES.ENOENT)qa.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return qa.error(`error in getHDBProcessInfo: ${t}`),e}}a($N,"getHDBProcessInfo");async function VN(){let e={};try{if(!Ap.get(gd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Xr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Xr.fsStats();return e.read_write=u,e.size=await Xr.fsSize(),e}catch(t){return qa.error(`error in getDiskInfo: ${t}`),e}}a(VN,"getDiskInfo");async function KN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Ap.get(gd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Xr.networkInterfaceDefault(),e.latency=await Xr.inetChecksite("google.com"),(await Xr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:f,carrier_changes:d,...p}=n;e.interfaces.push(p)}),(await Xr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return qa.error(`error in getNetworkInfo: ${t}`),e}}a(KN,"getNetworkInfo");async function YN(){if(Jg!==void 0)return Jg;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Xr.osInfo();e=c;let l=await Xr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,Jg=e,Jg}catch(t){return qa.error(`error in getSystemInformation: ${t}`),e}}a(YN,"getSystemInformation");async function WN(){let e=[],t=await sae.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await nae(n));return e}a(WN,"getTableSize");async function zN(){let e={};for(let t in kN){let r=e[t]={},n=r.tables={};for(let s in kN[t])try{let i=kN[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,f,d]=l.trim().split(" ");return{pid:u,thread:f,txnid:d}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){qa.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(zN,"getMetrics");async function UG(){if(Ap.get(gd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await MG.getNATSReferences(),t=await MG.listStreams(),r=[];for(let n of t){let s=[],i=await e.consumers.list(n.config.name);for await(let c of i)s.push({name:c.name,created:c.created,num_ack_pending:c.num_ack_pending,num_redelivered:c.num_redelivered,num_waiting:c.num_waiting,num_pending:c.num_pending});let o={stream_name:n.config.name,database:n.config.subjects[0].split(".")[1],table:n.config.subjects[0].split(".")[2],state:n.state,consumers:s};r.push(o)}return r}}a(UG,"getNatsStreamInfo");async function oae(e){let t=new iae;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await YN(),t.time=FN(),t.cpu=await GN(),t.memory=await qN(),t.disk=await VN(),t.network=await KN(),t.harperdb_processes=await $N(),t.table_size=await WN(),t.metrics=await zN(),t.threads=await vG(),t.replication=await UG(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await YN();break;case"time":t.time=FN();break;case"cpu":t.cpu=await GN();break;case"memory":t.memory=await qN();break;case"disk":t.disk=await VN();break;case"network":t.network=await KN();break;case"harperdb_processes":t.harperdb_processes=await $N();break;case"table_size":t.table_size=await WN();break;case"database_metrics":case"metrics":t.metrics=await zN();break;case"threads":t.threads=await vG();break;case"replication":t.replication=await UG();break;default:break}return t}a(oae,"systemInformation")});var Do=w((rLe,FG)=>{"use strict";var aae=yn(),jN=ie(),cae=require("util"),Rl=(H(),C(G)),BG=ae();BG.initSync();var lae=wO(),HG=Yr(),{Node:eLe,NodeSubscription:tLe}=Ed(),uae=Fu(),dae=OG(),{RemotePayloadObject:fae,RemotePayloadSubscription:_ae}=Tp(),{handleHDBError:pae,hdb_errors:hae}=pe(),{HTTP_STATUS_CODES:mae,HDB_ERROR_MSGS:Eae}=hae,gae=ni(),Sae=Po(),{packageJson:Tae}=it(),{getDatabases:Aae}=(De(),C(nt)),Rae=cae.promisify(lae.authorize),yae=HG.searchByHash,bae=HG.searchByValue;FG.exports={authHeaderToUser:Oae,isEmpty:Nae,getNodeRecord:wae,upsertNodeRecord:Iae,buildNodePayloads:Cae,checkClusteringEnabled:Pae,getAllNodeRecords:Dae,getSystemInfo:Lae,reverseSubscription:kG};async function Oae(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Rae(t,null),e}a(Oae,"authHeaderToUser");function Nae(e){return e==null}a(Nae,"isEmpty");async function wae(e){let t=new uae(Rl.SYSTEM_SCHEMA_NAME,Rl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return yae(t)}a(wae,"getNodeRecord");async function Iae(e){let t=new dae(Rl.SYSTEM_SCHEMA_NAME,Rl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return aae.upsert(t)}a(Iae,"upsertNodeRecord");function kG(e){if(jN.isEmpty(e.subscribe)||jN.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:n}=e,s={schema:t,table:r,hash_attribute:n};return e.subscribe===!0&&e.publish===!1?(s.subscribe=!1,s.publish=!0):e.subscribe===!1&&e.publish===!0?(s.subscribe=!0,s.publish=!1):(s.subscribe=e.subscribe,s.publish=e.publish),s}a(kG,"reverseSubscription");function Cae(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,f=jN.getTableHashAttribute(l,u),{subscribe:d,publish:p}=kG(c),_=Aae()[l]?.[u],h=new _ae(l,u,f,p,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(h)}return new fae(r,t,s,n)}a(Cae,"buildNodePayloads");function Pae(){if(!BG.get(Rl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw pae(new Error,Eae.CLUSTERING_NOT_ENABLED,mae.BAD_REQUEST,void 0,void 0,!0)}a(Pae,"checkClusteringEnabled");async function Dae(){let e=new gae(Rl.SYSTEM_SCHEMA_NAME,Rl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await bae(e))}a(Dae,"getAllNodeRecords");async function Lae(){let e=await Sae.getSystemInformation();return{hdb_version:Tae.version,node_version:e.node_version,platform:e.platform}}a(Lae,"getSystemInfo")});var JN=w((sLe,zG)=>{"use strict";var Qg=ir(),GG=ie(),qG=Tt(),$G=(H(),C(G)),Xg=z(),VG=Kg(),Mae=v_(),{RemotePayloadObject:vae}=Tp(),{handleHDBError:KG,hdb_errors:Uae}=pe(),{HTTP_STATUS_CODES:YG}=Uae,{NodeSubscription:WG}=Ed();zG.exports=xae;async function xae(e,t){let r;try{r=await Qg.request(`${t}.${qG.REQUEST_SUFFIX}`,new vae($G.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Xg.trace("Response from remote describe all request:",r)}catch(o){Xg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Qg.requestErrorHandler(o,"add_node",t);throw KG(new Error,c,YG.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===qG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw KG(new Error,o,YG.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,l=o.database??o.schema??"data";if(l===$G.SYSTEM_SCHEMA_NAME){await Qg.createLocalTableStream(l,c);let h=new WG(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=GG.doesSchemaExist(l),f=n[l]!==void 0,d=c?GG.doesTableExist(l,c):!0,p=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!f||!d&&!p){s.push(o);continue}if(!u&&f&&(Xg.trace(`addNode creating schema: ${l}`),await VG.createSchema({operation:"create_schema",schema:l})),!d&&p){Xg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Mae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await VG.createTable(h)}await Qg.createLocalTableStream(l,c);let _=new WG(l,c,o.publish,o.subscribe);_.start_time=o.start_time,i.push(_)}return{added:i,skipped:s}}a(xae,"reviewSubscriptions")});var yl={};ve(yl,{addNodeBack:()=>Gae,removeNodeBack:()=>qae,setNode:()=>Fae});async function Fae(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=ai(t)):t=Fg(r);let n=(0,JG.validateBySchema)(e,kae);if(n)throw(0,Lo.handleHDBError)(n,n.message,Hae.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Lo.ClientError("url or hostname is required for remove_node operation");let _=r,h=or(),S=await h.get(_);if(!S)throw new Lo.ClientError(_+" does not exist");try{await mp({url:S.url},{operation:Yt.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Ze():_},void 0)}catch(g){es.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await h.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Lo.ClientError("url required for this operation");let s=La();if(s==null)throw new Lo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,Ns.getReplicationCert)();let _=await(0,Ns.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,Ns.createCsr)(),es.info("Sending CSR to target node:",t)):_&&(c=_.certificate,es.info("Sending CA named",_.name,"to target node",t))}let l={operation:Yt.ADD_NODE_BACK,hostname:(0,Va.get)(x.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if((0,Va.get)(x.REPLICATION_SHARD)!==void 0&&(l.shard=(0,Va.get)(x.REPLICATION_SHARD)),e.subscriptions?l.subscriptions=e.subscriptions.map(jG):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=jG(e);l.subscribe=_.subscribe,l.publish=_.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,f;try{u=await mp({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,es.warn("Error adding node:",t,"to cluster:",_),f=_}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw f?(f.message+=" and connection was required to sign certificate",f):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&(es.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Ns.setCertTable)({name:Bae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Ns.setCertTable)({name:Ze(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let d={url:t,ca:u?.usingCA};if(e.hostname&&(d.name=e.hostname),e.subscriptions?d.subscriptions=e.subscriptions:d.replicates=!0,e.start_time&&(d.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(d.authorization=e.authorization),e.revoked_certificates&&(d.revoked_certificates=e.revoked_certificates),e.shard!==void 0&&(d.shard=e.shard),d.replicates){let _={url:s,ca:c,replicates:!0,subscriptions:null};(0,Va.get)(x.REPLICATION_SHARD)!==void 0&&(_.shard=(0,Va.get)(x.REPLICATION_SHARD)),e.retain_authorization&&(_.authorization=e.authorization),e.start_time&&(_.start_time=e.start_time),await Oo(Ze(),_)}await Oo(u?u.nodeName:d.name??ai(t),d);let p;return e.operation==="update_node"?p=`Successfully updated '${t}'`:p=`Successfully added '${t}' to cluster`,f&&(p+=" but there was an error updating target node: "+f.message),p}async function Gae(e){es.trace("addNodeBack received request:",e);let t=await(0,Ns.signCertificate)(e),r;e.csr?(r=t.signingCA,es.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,es.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization),e.shard!==void 0&&(n.shard=e.shard);let s=await(0,Ns.getReplicationCertAuth)();if(n.replicates){let i={url:La(),ca:s?.certificate,replicates:!0,subscriptions:null};(0,Va.get)(x.REPLICATION_SHARD)!==void 0&&(i.shard=(0,Va.get)(x.REPLICATION_SHARD)),e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Oo(Ze(),i)}return await Oo(e.hostname,n),t.nodeName=Ze(),t.usingCA=s?.certificate,es.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function qae(e){es.trace("removeNodeBack received request:",e),await or().delete(e.name)}function jG(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Ns,JG,$a,Va,es,Lo,Bae,Hae,kae,bl=be(()=>{Ns=M(Zn()),JG=M(ot()),$a=M(require("joi")),Va=M(ae());H();lp();pl();Xn();es=M(z()),Lo=M(pe()),{pki:Bae}=require("node-forge"),{HTTP_STATUS_CODES:Hae}=Lo.hdb_errors,kae=$a.default.object({hostname:$a.default.string(),verify_tls:$a.default.boolean(),replicates:$a.default.boolean(),subscriptions:$a.default.array(),revoked_certificates:$a.default.array(),shard:$a.default.number()});a(Fae,"setNode");a(Gae,"addNodeBack");a(qae,"removeNodeBack");a(jG,"reverseSubscription")});var Sd=w((_Le,XG)=>{"use strict";var{handleHDBError:Zg,hdb_errors:$ae}=pe(),{HTTP_STATUS_CODES:eS}=$ae,{addUpdateNodeValidator:Vae}=jg(),tS=z(),rS=(H(),C(G)),QG=Tt(),Kae=ie(),Rp=ir(),yp=Do(),QN=ae(),Yae=JN(),{Node:Wae,NodeSubscription:zae}=Ed(),{broadcast:jae}=rt(),{setNode:Jae}=(bl(),C(yl)),dLe=ae(),fLe=(H(),C(G)),Qae="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Xae="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Zae=QN.get(rS.CONFIG_PARAMS.CLUSTERING_NODENAME);XG.exports=ece;async function ece(e,t=!1){if(tS.trace("addNode called with:",e),QN.get(rS.CONFIG_PARAMS.REPLICATION_URL)||QN.get(rS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Jae(e);yp.checkClusteringEnabled();let r=Vae(e);if(r)throw Zg(r,r.message,eS.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await yp.getNodeRecord(n);if(!Kae.isEmptyOrZeroLength(d))throw Zg(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,eS.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Yae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Qae,o;let c=yp.buildNodePayloads(s,Zae,rS.OPERATIONS_ENUM.ADD_NODE,await yp.getSystemInfo()),l=[];for(let d=0,p=s.length;d<p;d++){let _=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new zae(_.schema,_.table,_.publish,_.subscribe))}tS.trace("addNode sending remote payload:",c);let u;try{u=await Rp.request(`${n}.${QG.REQUEST_SUFFIX}`,c)}catch(d){tS.error(`addNode received error from request: ${d}`);for(let _=0,h=s.length;_<h;_++){let S=s[_];S.publish=!1,S.subscribe=!1,await Rp.updateRemoteConsumer(S,n)}let p=Rp.requestErrorHandler(d,"add_node",n);throw Zg(new Error,p,eS.INTERNAL_SERVER_ERROR,"error",p)}if(u.status===QG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw Zg(new Error,d,eS.INTERNAL_SERVER_ERROR,"error",d)}tS.trace(u);for(let d=0,p=s.length;d<p;d++){let _=s[d];await Rp.updateRemoteConsumer(_,n),_.subscribe===!0&&await Rp.updateConsumerIterator(_.schema,_.table,n,"start")}let f=new Wae(n,l,u.system_info);return await yp.upsertNodeRecord(f),jae({type:"nats_update"}),i.length>0?o.message=Xae:o.message=`Successfully added '${n}' to manifest`,o}a(ece,"addNode")});var tw=w((mLe,eq)=>{"use strict";var{handleHDBError:XN,hdb_errors:tce}=pe(),{HTTP_STATUS_CODES:ZN}=tce,{addUpdateNodeValidator:rce}=jg(),bp=z(),nS=(H(),C(G)),ZG=Tt(),hLe=ie(),Op=ir(),Np=Do(),ew=ae(),{cloneDeep:nce}=require("lodash"),sce=JN(),{Node:ice,NodeSubscription:oce}=Ed(),{broadcast:ace}=rt(),{setNode:cce}=(bl(),C(yl)),lce="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",uce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",dce=ew.get(nS.CONFIG_PARAMS.CLUSTERING_NODENAME);eq.exports=fce;async function fce(e){if(bp.trace("updateNode called with:",e),ew.get(nS.CONFIG_PARAMS.REPLICATION_URL)??ew.get(nS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return cce(e);Np.checkClusteringEnabled();let t=rce(e);if(t)throw XN(t,t.message,ZN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Np.getNodeRecord(r);s.length>0&&(n=nce(s));let{added:i,skipped:o}=await sce(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=lce,c;let l=Np.buildNodePayloads(i,dce,nS.OPERATIONS_ENUM.UPDATE_NODE,await Np.getSystemInfo());for(let f=0,d=i.length;f<d;f++){let p=i[f];bp.trace(`updateNode updating work stream for node: ${r} subscription:`,p),i[f].start_time===void 0&&delete i[f].start_time}bp.trace("updateNode sending remote payload:",l);let u;try{u=await Op.request(`${r}.${ZG.REQUEST_SUFFIX}`,l)}catch(f){bp.error(`updateNode received error from request: ${f}`);let d=Op.requestErrorHandler(f,"update_node",r);throw XN(new Error,d,ZN.INTERNAL_SERVER_ERROR,"error",d)}if(u.status===ZG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${r}: ${u.message}`;throw XN(new Error,f,ZN.INTERNAL_SERVER_ERROR,"error",f)}bp.trace(u);for(let f=0,d=i.length;f<d;f++){let p=i[f];await Op.updateRemoteConsumer(p,r),p.subscribe===!0?await Op.updateConsumerIterator(p.schema,p.table,r,"start"):await Op.updateConsumerIterator(p.schema,p.table,r,"stop")}return n||(n=[new ice(r,[],u.system_info)]),await _ce(n[0],i,u.system_info),o.length>0?c.message=uce:c.message=`Successfully updated '${r}'`,c}a(fce,"updateNode");async function _ce(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let f=n.subscriptions[l];if(f.schema===o.schema&&f.table===o.table){f.publish=o.publish,f.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new oce(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Np.upsertNodeRecord(n),ace({type:"nats_update"})}a(_ce,"updateNodeTable")});var iq=w((gLe,sq)=>{"use strict";var nq=require("joi"),{string:tq}=nq.types(),pce=ot(),rq=(H(),C(G)),hce=ae(),mce=Tt();sq.exports=Ece;function Ece(e){let t=tq.invalid(hce.get(rq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(mce.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=nq.object({operation:tq.valid(rq.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return pce.validateBySchema(e,r)}a(Ece,"removeNodeValidator")});var sS=w((TLe,uq)=>{"use strict";var{handleHDBError:oq,hdb_errors:gce}=pe(),{HTTP_STATUS_CODES:aq}=gce,Sce=iq(),wp=z(),cq=Do(),Tce=ie(),Td=(H(),C(G)),lq=Tt(),rw=ir(),nw=ae(),{RemotePayloadObject:Ace}=Tp(),{NodeSubscription:Rce}=Ed(),yce=M_(),bce=zc(),{broadcast:Oce}=rt(),{setNode:Nce}=(bl(),C(yl)),wce=nw.get(Td.CONFIG_PARAMS.CLUSTERING_NODENAME);uq.exports=Ice;async function Ice(e){if(wp.trace("removeNode called with:",e),nw.get(Td.CONFIG_PARAMS.REPLICATION_URL)??nw.get(Td.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Nce(e);cq.checkClusteringEnabled();let t=Sce(e);if(t)throw oq(t,t.message,aq.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await cq.getNodeRecord(r);if(Tce.isEmptyOrZeroLength(n))throw oq(new Error,`Node '${r}' was not found.`,aq.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Ace(Td.OPERATIONS_ENUM.REMOVE_NODE,wce,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await rw.updateConsumerIterator(f.schema,f.table,r,"stop");try{await rw.updateRemoteConsumer(new Rce(f.schema,f.table,!1,!1),r)}catch(d){wp.error(d)}}try{i=await rw.request(`${r}.${lq.REQUEST_SUFFIX}`,s),wp.trace("Remove node reply from remote node:",r,i)}catch(l){wp.error("removeNode received error from request:",l),o=!0}let c=new yce(Td.SYSTEM_SCHEMA_NAME,Td.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await bce.deleteRecord(c),Oce({type:"nats_update"}),i?.status===lq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(wp.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(Ice,"removeNode")});var _q=w((RLe,fq)=>{"use strict";var dq=require("joi"),{string:Cce,array:Pce}=dq.types(),Dce=ot(),Lce=jg();fq.exports=Mce;function Mce(e){let t=dq.object({operation:Cce.valid("configure_cluster").required(),connections:Pce.items(Lce.validation_schema).required()});return Dce.validateBySchema(e,t)}a(Mce,"configureClusterValidator")});var sw=w((bLe,gq)=>{"use strict";var pq=(H(),C(G)),iS=z(),vce=ie(),Uce=ae(),xce=sS(),Bce=Sd(),Hce=Do(),kce=_q(),{handleHDBError:hq,hdb_errors:Fce}=pe(),{HTTP_STATUS_CODES:mq}=Fce,Gce="Configure cluster complete.",qce="Failed to configure the cluster. Check the logs for more details.",$ce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";gq.exports=Vce;async function Vce(e){iS.trace("configure cluster called with:",e);let t=kce(e);if(t)throw hq(t,t.message,mq.BAD_REQUEST,void 0,void 0,!0);let r=await Hce.getAllNodeRecords(),n=[];if(Uce.get(pq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let p=await Eq(xce,{operation:pq.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name);n.push(p)}iS.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let f=0;f<i;f++){let d=e.connections[f],p=await Eq(Bce,d,d.node_name);s.push(p)}iS.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let f=0,d=u.length;f<d;f++){let p=u[f];p.status==="rejected"&&(iS.error(p.node_name,p?.error?.message,p?.error?.stack),o.includes(p.node_name)||o.push(p.node_name)),(p?.result?.message?.includes?.("Successfully")||p?.result?.includes?.("Successfully"))&&(l=!0),!(typeof p.result=="string"&&p.result.includes("Successfully removed")||p.status==="rejected")&&c.push({node_name:p?.node_name,response:p?.result})}if(vce.isEmptyOrZeroLength(o))return{message:Gce,connections:c};if(l)return{message:$ce,failed_nodes:o,connections:c};throw hq(new Error,qce,mq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Vce,"configureCluster");async function Eq(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(Eq,"functionWrapper")});var Rq=w((NLe,Aq)=>{"use strict";var Ip=require("joi"),Kce=ot(),{validateSchemaExists:Sq,validateTableExists:Yce,validateSchemaName:Tq}=Di(),Wce=Ip.object({operation:Ip.string().valid("purge_stream"),schema:Ip.string().custom(Sq).custom(Tq).optional(),database:Ip.string().custom(Sq).custom(Tq).optional(),table:Ip.string().custom(Yce).required()});function zce(e){return Kce.validateBySchema(e,Wce)}a(zce,"purgeStreamValidator");Aq.exports=zce});var iw=w((ILe,yq)=>{"use strict";var{handleHDBError:jce,hdb_errors:Jce}=pe(),{HTTP_STATUS_CODES:Qce}=Jce,Xce=Rq(),Zce=ir(),ele=Do();yq.exports=tle;async function tle(e){e.schema=e.schema??e.database;let t=Xce(e);if(t)throw jce(t,t.message,Qce.BAD_REQUEST,void 0,void 0,!0);ele.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await Zce.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(tle,"purgeStream")});var cS=w((PLe,Pq)=>{"use strict";var aw=Do(),rle=ir(),aS=ae(),Ad=(H(),C(G)),Ol=Tt(),nle=ie(),ow=z(),{RemotePayloadObject:sle}=Tp(),{ErrorCode:bq}=require("nats"),{parentPort:Oq}=require("worker_threads"),{onMessageByType:ile}=rt(),{getThisNodeName:ole}=(Xn(),C(wo)),{requestClusterStatus:ale}=(lp(),C(jk)),{getReplicationSharedStatus:cle,getHDBNodeTable:lle}=(pl(),C(jO)),{CONFIRMATION_STATUS_POSITION:ule,RECEIVED_VERSION_POSITION:dle,RECEIVED_TIME_POSITION:fle,SENDING_TIME_POSITION:_le}=(SN(),C(BF)),Nq=aS.get(Ad.CONFIG_PARAMS.CLUSTERING_ENABLED),wq=aS.get(Ad.CONFIG_PARAMS.CLUSTERING_NODENAME);Pq.exports={clusterStatus:ple,buildNodeStatus:Cq};var Iq;ile("cluster-status",async e=>{Iq(e)});async function ple(){if(aS.get(Ad.CONFIG_PARAMS.REPLICATION_URL)||aS.get(Ad.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(Oq){Oq.postMessage({type:"request-cluster-status"}),n=await new Promise(i=>{Iq=i});for(let i of n.connections){let o=i.name;for(let c of i.database_sockets){let l=c.database,u;for(let d of Object.values(databases[l]||{}))if(u=d.auditStore,u)break;if(!u)continue;let f=cle(u,l,o);c.lastCommitConfirmed=oS(f[ule]),c.lastReceivedRemoteTime=oS(f[dle]),c.lastReceivedLocalTime=oS(f[fle]),c.sendingMessage=oS(f[_le])}}}else n=ale();n.node_name=ole();let s=lle().primaryStore.get(n.node_name);return s?.shard&&(n.shard=s.shard),s?.url&&(n.url=s.url),n.is_enabled=!0,n}let e={node_name:wq,is_enabled:Nq,connections:[]};if(!Nq)return e;let t=await aw.getAllNodeRecords();if(nle.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Cq(t[n],e.connections));return await Promise.allSettled(r),e}a(ple,"clusterStatus");function oS(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}a(oS,"asDate");async function Cq(e,t){let r=e.name,n=new sle(Ad.OPERATIONS_ENUM.CLUSTER_STATUS,wq,void 0,await aw.getSystemInfo()),s,i,o=Ol.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await rle.request(Ol.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Ol.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Ol.CLUSTER_STATUS_STATUSES.CLOSED,ow.error(`Error getting node status from ${r} `,s))}catch(l){ow.warn(`Error getting node status from ${r}`,l),l.code===bq.NoResponders?o=Ol.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===bq.Timeout?o=Ol.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Ol.CLUSTER_STATUS_STATUSES.CLOSED}let c=new hle(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Ad.PRE_4_0_0_VERSION&&await aw.upsertNodeRecord(l)}catch(l){ow.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Cq,"buildNodeStatus");function hle(e,t,r,n,s,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=o,this.system_info=c}a(hle,"NodeStatusObject")});var uS=w((LLe,Dq)=>{"use strict";var{handleHDBError:mle,hdb_errors:Ele}=pe(),{HTTP_STATUS_CODES:gle}=Ele,Sle=ir(),Tle=Do(),cw=ie(),lS=require("joi"),Ale=ot(),Rle=2e3,yle=lS.object({timeout:lS.number().min(1),connected_nodes:lS.boolean(),routes:lS.boolean()});Dq.exports=ble;async function ble(e){Tle.checkClusteringEnabled();let t=Ale.validateBySchema(e,yle);if(t)throw mle(t,t.message,gle.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||cw.autoCastBoolean(n),o=s===void 0||cw.autoCastBoolean(s),c={nodes:[]},l=await Sle.getServerList(r??Rle),u={};if(i)for(let f=0,d=l.length;f<d;f++){let p=l[f].statsz;p&&(u[l[f].server.name]=p.routes)}for(let f=0,d=l.length;f<d;f++){if(l[f].statsz)continue;let p=l[f].server,_=l[f].data;if(p.name.endsWith("-hub")){let h={name:p.name.slice(0,-4),response_time:l[f].response_time};i&&(h.connected_nodes=[],u[p.name]&&u[p.name].forEach(S=>{h.connected_nodes.includes(S.name.slice(0,-4))||h.connected_nodes.push(S.name.slice(0,-4))})),o&&(h.routes=_.cluster?.urls?_.cluster?.urls.map(S=>({host:S.split(":")[0],port:cw.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(ble,"clusterNetwork")});var Uq=w((vLe,vq)=>{"use strict";var lw=require("joi"),Lq=ot(),{route_constraints:Mq}=Yy();vq.exports={setRoutesValidator:Ole,deleteRoutesValidator:Nle};function Ole(e){let t=lw.object({server:lw.valid("hub","leaf"),routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Ole,"setRoutesValidator");function Nle(e){let t=lw.object({routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Nle,"deleteRoutesValidator")});var dS=w((xLe,qq)=>{"use strict";var Mo=yt(),uw=ie(),ws=(H(),C(G)),Rd=ae(),xq=Uq(),{handleHDBError:Bq,hdb_errors:wle}=pe(),{HTTP_STATUS_CODES:Hq}=wle,kq="cluster routes successfully set",Fq="cluster routes successfully deleted";qq.exports={setRoutes:Cle,getRoutes:Ple,deleteRoutes:Dle};function Ile(e){let t=Mo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=uw.autoCast(l.port);let u=r.some(d=>d.host===l.host&&d.port===l.port),f=n.some(d=>d.host===l.host&&d.port===l.port);u||f?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:kq,set:i,skipped:s}}a(Ile,"setRoutesNats");function Cle(e){let t=xq.setRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Rd.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ile(e);let r=[],n=[],s=Rd.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Gq(s,i)?n.push(i):(s.push(i),r.push(i))}),Mo.updateConfigValue(ws.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:kq,set:r,skipped:n}}a(Cle,"setRoutes");function Gq(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(Gq,"existsInArray");function Ple(){if(Rd.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=Mo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Rd.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Ple,"getRoutes");function Dle(e){let t=xq.deleteRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Rd.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED))return Lle(e);let r=[],n=[],s=Rd.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Gq(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),Mo.updateConfigValue(ws.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Fq,deleted:r,skipped:n}}a(Dle,"deleteRoutes");function Lle(e){let t=Mo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let f=e.routes[l],d=!1;for(let p=0,_=r.length;p<_;p++){let h=r[p];if(f.host===h.host&&f.port===h.port){r.splice(p,1),d=!0,o=!0,s.push(f);break}}if(!d){let p=!0;for(let _=0,h=n.length;_<h;_++){let S=n[_];if(f.host===S.host&&f.port===S.port){n.splice(_,1),c=!0,p=!1,s.push(f);break}}p&&i.push(f)}}return o&&(r=uw.isEmptyOrZeroLength(r)?null:r,Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=uw.isEmptyOrZeroLength(n)?null:n,Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Fq,deleted:s,skipped:i}}a(Lle,"deleteRoutesNats")});var Vq=w((HLe,$q)=>{"use strict";var Cp=require("alasql"),Nl=require("recursive-iterator"),ui=z(),Mle=ie(),Pp=(H(),C(G)),dw=class{static{a(this,"sql_statement_bucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,Ule(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>Pp.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!Pp.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,o=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][Pp.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=vle(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!Pp.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let f=new Cp.yy.Column({columnid:u});s.tableid&&(f.tableid=s.tableid),this.ast.columns.push(f),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function vle(e){return e.filter(t=>t[Pp.PERMS_CRUD_ENUM.READ])}a(vle,"filterReadRestrictedAttrs");function Ule(e,t,r,n,s){xle(e,t,r,n,s)}a(Ule,"interpretAST");function Dp(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),s.set(o,i)}}a(Dp,"addSchemaTableToMap");function xle(e,t,r,n,s){if(!e){ui.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Cp.yy.Insert?Fle(e,t,r):e instanceof Cp.yy.Select?Ble(e,t,r,n,s):e instanceof Cp.yy.Update?Hle(e,t,r):e instanceof Cp.yy.Delete?kle(e,t,r):ui.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(xle,"getRecordAttributesAST");function Ble(e,t,r,n,s){if(!e){ui.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Mle.isEmptyOrZeroLength(i)){ui.error("No schema specified");return}e.from.forEach(c=>{Dp(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Dp(c.table,t,r,n,s)});let o=new Nl(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{ui.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Nl(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let f=u.tableid?u.tableid:l;if(!t.get(i).has(f))if(r.has(f))f=r.get(f);else{ui.info(`table specified as ${f} not found.`);continue}t.get(i).get(f).indexOf(u.columnid)<0&&t.get(i).get(f).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Nl(c.on);for(let{node:u}of l)if(u&&u.columnid){let f=u.tableid,d=s.get(f);if(!t.get(d).has(f))if(r.has(f))f=r.get(f);else{ui.info(`table specified as ${f} not found.`);continue}t.get(d).get(f).indexOf(u.columnid)<0&&t.get(d).get(f).push(u.columnid)}}),e.order){let c=new Nl(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,f=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(f).has(u))if(r.has(u))u=r.get(u);else{ui.info(`table specified as ${u} not found.`);return}t.get(f).get(u).indexOf(l.columnid)<0&&t.get(f).get(u).push(l.columnid)}}}a(Ble,"getSelectAttributes");function Hle(e,t,r){if(!e){ui.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Nl(e.columns),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.table.tableid,s,i.columnid,t,r)}a(Hle,"getUpdateAttributes");function kle(e,t,r){if(!e){ui.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Nl(e.where),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.table.tableid,s,i.columnid,t,r)}a(kle,"getDeleteAttributes");function Fle(e,t,r){if(!e){ui.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Nl(e.columns),s=e.into.databaseid;Dp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.into.tableid,s,i.columnid,t,r)}a(Fle,"getInsertAttributes");function fw(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}a(fw,"pushAttribute");$q.exports=dw});var Yq=w((FLe,Kq)=>{"use strict";var fS=(H(),C(G)),_S=class{static{a(this,"BaseLicense")}constructor(t=0,r=fS.RAM_ALLOCATION_ENUM.DEFAULT,n=fS.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},_w=class extends _S{static{a(this,"ExtendedLicense")}constructor(t=0,r=fS.RAM_ALLOCATION_ENUM.DEFAULT,n=fS.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};Kq.exports={BaseLicense:_S,ExtendedLicense:_w}});var Od=w((qLe,Xq)=>{"use strict";var bd=require("fs-extra"),pS=(hE(),C(pE)),zq=require("crypto"),Gle=require("moment"),qle=require("uuid").v4,Zr=z(),hw=require("path"),$le=ie(),wl=(H(),C(G)),{totalmem:Wq}=require("os"),Vle=Yq().ExtendedLicense,yd="invalid license key format",Kle="061183",Yle="mofi25",Wle="aes-256-cbc",zle=16,jle=32,jq=ae(),{resolvePath:Jq}=yt();jq.initSync();var pw;Xq.exports={validateLicense:Qq,generateFingerPrint:Qle,licenseSearch:gw,getLicense:eue,checkMemoryLimit:tue};function mw(){return hw.join(jq.getHdbBasePath(),wl.LICENSE_KEY_DIR_NAME,wl.LICENSE_FILE_NAME)}a(mw,"getLicenseDirPath");function Jle(){let e=mw();return Jq(hw.join(e,wl.LICENSE_FILE_NAME))}a(Jle,"getLicenseFilePath");function Ew(){let e=mw();return Jq(hw.join(e,wl.REG_KEY_FILE_NAME))}a(Ew,"getFingerPrintFilePath");async function Qle(){let e=Ew();try{return await bd.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Xle();throw Zr.error(`Error writing fingerprint file to ${e}`),Zr.error(t),new Error("There was an error generating the fingerprint")}}a(Qle,"generateFingerPrint");async function Xle(){let e=qle(),t=pS.hash(e,pS.HASH_FUNCTION.MD5),r=Ew();try{await bd.mkdirp(mw()),await bd.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Zr.error(`Error writing fingerprint file to ${r}`),Zr.error(n),new Error("There was an error generating the fingerprint")}return t}a(Xle,"writeFingerprint");function Qq(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:wl.RAM_ALLOCATION_ENUM.DEFAULT,version:wl.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Zr.error("empty license key passed to validate."),r;let n=Ew(),s=!1;try{s=bd.statSync(n)}catch(i){Zr.error(i)}if(s){let i;try{i=bd.readFileSync(n,"utf8")}catch{Zr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(Yle),c=o[1];c=Buffer.concat([Buffer.from(c)],zle);let l=Buffer.concat([Buffer.from(i)],jle),u=zq.createDecipheriv(Wle,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let f=null;try{f=u.update(o[0],"hex","utf8"),f.trim(),f+=u.final("utf8")}catch{let _=Zle(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(yd),Zr.error(yd),new Error(yd)}let d;if(isNaN(f))try{d=JSON.parse(f),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(yd),Zr.error(yd),new Error(yd)}else r.exp_date=f;r.exp_date<Gle().valueOf()&&(r.valid_date=!1),pS.validate(o[1],`${Kle}${i}${t}`,pS.HASH_FUNCTION.MD5)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Zr.error("Invalid licence"),r}a(Qq,"validateLicense");function Zle(e,t){try{let r=zq.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Zr.warn("Check old license failed")}}a(Zle,"checkOldLicense");function gw(){let e=new Vle,t=[];try{t=bd.readFileSync(Jle(),"utf-8").split(`\r
|
|
25
|
+
`)}catch(r){r.code==="ENOENT"?Zr.debug("no license file found"):Zr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if($le.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=Qq(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){Zr.error("There was an error parsing the license string."),Zr.error(s),e.ram_allocation=wl.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return pw=e,e}a(gw,"licenseSearch");async function eue(){return pw||await gw(),pw}a(eue,"getLicense");function tue(){let e=gw().ram_allocation,t=process.constrainedMemory?.()||Wq();if(t=Math.round(Math.min(t,Wq())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(tue,"checkMemoryLimit")});var mS=w((VLe,r$)=>{var hS=Od(),Zq=require("chalk"),ts=z(),e$=require("prompt"),{promisify:rue}=require("util"),Sw=(H(),C(G)),nue=require("fs-extra"),sue=require("path"),iue=ie(),{packageJson:oue}=it(),t$=ae();t$.initSync();var aue=require("moment"),cue=rue(e$.get),lue=sue.join(t$.getHdbBasePath(),Sw.LICENSE_KEY_DIR_NAME,Sw.LICENSE_FILE_NAME,Sw.LICENSE_FILE_NAME);r$.exports={getFingerprint:due,setLicense:uue,parseLicense:Tw,register:fue,getRegistrationInfo:pue};async function uue(e){if(e&&e.key&&e.company){try{ts.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Tw(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ts.error(r),ts.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(uue,"setLicense");async function due(){let e={};try{e=await hS.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ts.error(r),ts.error(t),new Error(r)}return e}a(due,"getFingerprint");async function Tw(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ts.info("Validating license input...");let r=hS.validateLicense(e,t);if(ts.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(ts.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(ts.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ts.info("writing license to disk"),await nue.writeFile(lue,JSON.stringify({license_key:e,company:t}))}catch(n){throw ts.error("Failed to write License"),n}return"Registration successful."}a(Tw,"parseLicense");async function fue(){let e=await _ue();return Tw(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(fue,"register");async function _ue(){let e=await hS.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Zq.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Zq.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{e$.start()}catch(n){ts.error(n)}let r;try{r=await cue(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(_ue,"promptForRegistration");async function pue(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await hS.getLicense()}catch(r){throw ts.error(`There was an error when searching licenses due to: ${r.message}`),r}if(iue.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=oue.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=aue.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(pue,"getRegistrationInfo")});var s$=w((YLe,n$)=>{"use strict";var hue=Tt(),Aw=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d,p,_,h){this.port=t,o===null&&(o=void 0),this.server_name=r+hue.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:f,port:d,routes:p,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:_},HDB:{users:h}},this.system_account="SYS"}};n$.exports=Aw});var a$=w((zLe,o$)=>{"use strict";var i$=Tt(),Rw=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d){this.port=t,d===null&&(d=void 0),this.server_name=r+i$.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+i$.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:f,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};o$.exports=Rw});var l$=w((JLe,c$)=>{"use strict";var yw=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};c$.exports=yw});var d$=w((XLe,u$)=>{"use strict";var mue=Tt(),bw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+mue.SERVER_SUFFIX.ADMIN,this.password=r}};u$.exports=bw});var TS=w((eMe,p$)=>{"use strict";var Il=require("path"),Cl=require("fs-extra"),Eue=s$(),gue=a$(),Sue=l$(),Tue=d$(),Ow=Rn(),wd=ie(),wn=yt(),gS=(H(),C(G)),Lp=Tt(),{CONFIG_PARAMS:Jt}=gS,Id=z(),Mp=ae(),f$=Eo(),Nw=ir(),Aue=Zn(),Nd="clustering",Rue=1e4,_$=50;p$.exports={generateNatsConfig:bue,removeNatsConfig:Oue,getHubConfigPath:yue};function yue(){let e=Mp.get(Jt.ROOTPATH);return Il.join(e,Nd,Lp.NATS_CONFIG_FILES.HUB_SERVER)}a(yue,"getHubConfigPath");async function bue(e=!1,t=void 0){let r=Mp.get(Jt.ROOTPATH);Cl.ensureDirSync(Il.join(r,"clustering","leaf")),Mp.initSync();let n=wn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),s=wn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),i=wn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await Cl.exists(i)&&!await Cl.exists(!n)&&await Aue.createNatsCerts();let o=Il.join(r,Nd,Lp.PID_FILES.HUB),c=Il.join(r,Nd,Lp.PID_FILES.LEAF),l=wn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Il.join(r,Nd,Lp.NATS_CONFIG_FILES.HUB_SERVER),f=Il.join(r,Nd,Lp.NATS_CONFIG_FILES.LEAF_SERVER),d=wn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),p=wn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),_=wn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Nw.checkNATSServerInstalled()||SS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await Ow.listUsers(),g=wn.getConfigFromFile(Jt.CLUSTERING_USER),R=await Ow.getClusterUser();(wd.isEmpty(R)||R.active!==!0)&&SS(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await ES(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await ES(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await ES(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await ES(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],T=[];for(let[se,Q]of S.entries())Q.role?.role===gS.ROLE_TYPES_ENUM.CLUSTER_USER&&Q.active&&(E.push(new Tue(Q.username,f$.decrypt(Q.hash))),T.push(new Sue(Q.username,f$.decrypt(Q.hash))));let b=[],{hub_routes:v}=wn.getClusteringRoutes();if(!wd.isEmptyOrZeroLength(v))for(let se of v)b.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${se.host}:${se.port}`);let F=new Eue(wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,p,h,wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),b,E,T);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=wd.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===gS.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Cl.writeJson(u,F),Id.trace(`Hub server config written to ${u}`));let q=`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${R.uri_encoded_name}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,Z=new gue(wn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[q],[Y],E,T,i,s,n,d);n==null&&delete Z.tls.ca_file,(t===void 0||t===gS.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Cl.writeJson(f,Z),Id.trace(`Leaf server config written to ${f}`))}a(bue,"generateNatsConfig");async function ES(e){let t=Mp.get(e);return wd.isEmpty(t)&&SS(`port undefined for '${e}'`),await wd.isPortTaken(t)&&SS(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(ES,"isPortAvailable");function SS(e){let t=`Error generating clustering config: ${e}`;Id.error(t),console.error(t),process.exit(1)}a(SS,"generateNatsConfigError");async function Oue(e){let{port:t,config_file:r}=Nw.getServerConfig(e),{username:n,decrypt_hash:s}=await Ow.getClusterUser(),i=0,o=2e3;for(;i<_$;){try{let f=await Nw.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){Id.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${f}`)}if(i++,i>=_$)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&Id.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await wd.async_set_timeout(u)}let c="0".repeat(Rue),l=Il.join(Mp.get(Jt.ROOTPATH),Nd,r);await Cl.writeFile(l,c),await Cl.remove(l),Id.notify(e,"started.")}a(Oue,"removeNatsConfig")});var T$=w((rMe,S$)=>{"use strict";var rs=ae(),Nue=Od(),Fe=(H(),C(G)),vp=Tt(),vo=require("path"),{PACKAGE_ROOT:RS}=it(),h$=ae(),AS=ie(),Cd="/dev/null",wue=vo.join(RS,"launchServiceScripts"),m$=vo.join(RS,"utility/scripts"),Iue=vo.join(m$,Fe.HDB_RESTART_SCRIPT),E$=vo.resolve(RS,"dependencies",`${process.platform}-${process.arch}`,vp.NATS_BINARY_NAME);function g$(){let t=Nue.licenseSearch().ram_allocation||Fe.RAM_ALLOCATION_ENUM.DEFAULT,r=Fe.MEM_SETTING_KEY+t,n={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return AS.noBootFile()&&(n[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=AS.getEnvCliRootPath()),{name:Fe.PROCESS_DESCRIPTORS.HDB,script:Fe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:RS}}a(g$,"generateMainServerConfig");var Cue=9930;function Pue(){rs.initSync(!0);let e=rs.get(Fe.CONFIG_PARAMS.ROOTPATH),t=vo.join(e,"clustering",vp.NATS_CONFIG_FILES.HUB_SERVER),r=vo.join(rs.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=h$.get(Fe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[rs.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Cue?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Cd,i.error_file=Cd),i}a(Pue,"generateNatsHubServerConfig");var Due=9940;function Lue(){rs.initSync(!0);let e=rs.get(Fe.CONFIG_PARAMS.ROOTPATH),t=vo.join(e,"clustering",vp.NATS_CONFIG_FILES.LEAF_SERVER),r=vo.join(rs.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=h$.get(Fe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[rs.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Due?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Cd,i.error_file=Cd),i}a(Lue,"generateNatsLeafServerConfig");function Mue(){rs.initSync();let e=vo.join(rs.get(Fe.CONFIG_PARAMS.LOGGING_ROOT),Fe.LOG_NAMES.HDB),t={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Fe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:wue,autorestart:!1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Cd,t.error_file=Cd),t}a(Mue,"generateClusteringUpgradeV4ServiceConfig");function vue(){let e={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.RESTART_HDB};return AS.noBootFile()&&(e[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=AS.getEnvCliRootPath()),{...{name:Fe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:m$},script:Iue}}a(vue,"generateRestart");function Uue(){return{apps:[g$()]}}a(Uue,"generateAllServiceConfigs");S$.exports={generateAllServiceConfigs:Uue,generateMainServerConfig:g$,generateRestart:vue,generateNatsHubServerConfig:Pue,generateNatsLeafServerConfig:Lue,generateClusteringUpgradeV4ServiceConfig:Mue}});var Pd=w((iMe,v$)=>{"use strict";var et=(H(),C(G)),xue=ie(),xo=TS(),yS=ir(),Uo=Tt(),Ka=T$(),bS=ae(),Pl=z(),Bue=Do(),{startWorker:A$,onMessageFromWorkers:Hue}=rt(),kue=Po(),sMe=require("util"),Fue=require("child_process"),Gue=require("fs"),{execFile:que}=Fue,Ve;v$.exports={enterPM2Mode:$ue,start:Ya,stop:ww,reload:y$,restart:b$,list:Iw,describe:w$,connect:Bo,kill:zue,startAllServices:jue,startService:Cw,getUniqueServicesList:I$,restartAllServices:Jue,isServiceRegistered:C$,reloadStopStart:P$,restartHdb:N$,deleteProcess:Yue,startClusteringProcesses:L$,startClusteringThreads:M$,isHdbRestartRunning:Wue,isClusteringRunning:Xue,stopClustering:Que,reloadClustering:Zue,expectedRestartOfChildren:O$};var Up=!1;Hue(e=>{e.type==="restart"&&bS.initSync(!0)});function $ue(){Up=!0}a($ue,"enterPM2Mode");function Bo(){return Ve||(Ve=require("pm2")),new Promise((e,t)=>{Ve.connect((r,n)=>{r&&t(r),e(n)})})}a(Bo,"connect");var en,Vue=10,R$;function Ya(e,t=!1){if(Up)return Kue(e);let r=que(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=en.indexOf(r);o>-1&&en.splice(o,1),!R$&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Vue&&(Gue.existsSync(xo.getHubConfigPath())?Ya(e):(await xo.generateNatsConfig(!0),Ya(e),await new Promise(c=>setTimeout(c,3e3)),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=bS.get(et.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,f;for(;l=c.exec(i);){if(l.index&&Uo.LOG_LEVEL_HIERARCHY[o]>=Uo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===Uo.LOG_LEVELS.ERR||f===Uo.LOG_LEVELS.WRN?Pl.OUTPUTS.STDERR:Pl.OUTPUTS.STDOUT;Pl.logCustomLevel(f||"info",_,n,i.slice(u,l.index).trim())}let[d,p]=l;u=l.index+d.length,f=Uo.LOG_LEVELS[p]}if(Uo.LOG_LEVEL_HIERARCHY[o]>=Uo.LOG_LEVEL_HIERARCHY[f||"info"]){let d=f===Uo.LOG_LEVELS.ERR||f===Uo.LOG_LEVELS.WRN?Pl.OUTPUTS.STDERR:Pl.OUTPUTS.STDOUT;Pl.logCustomLevel(f||"info",d,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!en&&(en=[],!t)){let i=a(()=>{R$=!0,en&&(en.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}en.push(r)}a(Ya,"start");function Kue(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.start(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(Kue,"startWithPM2");function ww(e){if(!Up){for(let t of en||[])t.name===e&&(en.splice(en.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.stop(e,async(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.delete(e,(i,o)=>{i&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(o)})})})}a(ww,"stop");function y$(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.reload(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(y$,"reload");function b$(e){if(!Up){O$();for(let t of en||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.restart(e,(n,s)=>{Ve.disconnect(),t(s)})})}a(b$,"restart");function O$(){for(let e of en||[])e.config&&(e.config.restarts=0)}a(O$,"expectedRestartOfChildren");function Yue(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.delete(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(Yue,"deleteProcess");async function N$(){await Ya(Ka.generateRestart())}a(N$,"restartHdb");async function Wue(){let e=await Iw();for(let t in e)if(e[t].name===et.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Wue,"isHdbRestartRunning");function Iw(){return new Promise(async(e,t)=>{try{await Bo()}catch(r){t(r)}Ve.list((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(Iw,"list");function w$(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.describe(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(w$,"describe");function zue(){if(!Up){for(let e of en||[])e.kill();en=[];return}return new Promise(async(e,t)=>{try{await Bo()}catch(r){t(r)}Ve.killDaemon((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(zue,"kill");async function jue(){try{await L$(),await M$(),await Ya(Ka.generateAllServiceConfigs())}catch(e){throw Ve?.disconnect(),e}}a(jue,"startAllServices");async function Cw(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case et.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ka.generateMainServerConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ka.generateNatsIngestServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ka.generateNatsReplyServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ka.generateNatsHubServerConfig(),await Ya(r,t),await xo.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ka.generateNatsLeafServerConfig(),await Ya(r,t),await xo.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ka.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Ya(r)}catch(r){throw Ve?.disconnect(),r}}a(Cw,"startService");async function I$(){try{let e=await Iw(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Ve?.disconnect(),e}}a(I$,"getUniqueServicesList");async function Jue(e=[]){try{let t=!1,r=await I$();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===et.PROCESS_DESCRIPTORS.HDB?t=!0:await b$(o))}t&&await P$(et.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ve?.disconnect(),t}}a(Jue,"restartAllServices");async function C$(e){if(en?.find(r=>r.name===e))return!0;let t=await kue.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(C$,"isServiceRegistered");async function P$(e){let t=bS.get(et.CONFIG_PARAMS.THREADS_COUNT)??bS.get(et.CONFIG_PARAMS.THREADS),r=await w$(e),n=xue.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await ww(e),await Cw(e)):e===et.PROCESS_DESCRIPTORS.HDB?await N$():await y$(e)}a(P$,"reloadStopStart");var D$;async function L$(e=!1){for(let t in et.CLUSTERING_PROCESSES){let r=et.CLUSTERING_PROCESSES[t];await Cw(r,e)}}a(L$,"startClusteringProcesses");async function M$(){D$=A$(et.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:et.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await yS.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await yS.updateLocalStreams();let e=await Bue.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===et.PRE_4_0_0_VERSION){Pl.info("Starting clustering upgrade 4.0.0 process"),A$(et.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(M$,"startClusteringThreads");async function Que(){for(let e in et.CLUSTERING_PROCESSES)if(e!==et.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===et.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await D$.terminate();else{let t=et.CLUSTERING_PROCESSES[e];await ww(t)}}a(Que,"stopClustering");async function Xue(){for(let e in et.CLUSTERING_PROCESSES){let t=et.CLUSTERING_PROCESSES[e];if(await C$(t)===!1)return!1}return!0}a(Xue,"isClusteringRunning");async function Zue(){await xo.generateNatsConfig(!0),await yS.reloadNATSHub(),await yS.reloadNATSLeaf(),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Zue,"reloadClustering")});var wS={};ve(wS,{compactOnStart:()=>ede,copyDb:()=>F$});async function ede(){Wa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,Pw.get)(x.ROOTPATH),t=new Map,r=Xe();(0,Dw.updateConfigValue)(x.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,OS.join)(e,"backup",n+".mdb"),o=(0,OS.join)(e,Nc,n+"-copy.mdb"),c=0;try{c=await U$(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Wa.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await F$(n,o),console.log("Backing up",n,"to",i),await(0,Dl.move)(s,i,{overwrite:!0})}try{Dd()}catch(n){Wa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,Dl.move)(i,s,{overwrite:!0}),await(0,Dl.remove)((0,OS.join)(e,Nc,`${n}-copy.mdb-lock`));try{Dd()}catch(n){Wa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Wa.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,Dw.updateConfigValue)(x.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,Dl.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Dd(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await U$(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
26
26
|
Total record count before compaction: ${i}, total after: ${c}.
|
|
27
|
-
Database backup has not been removed and can be found here: ${s}`;Wa.error(l),console.error(l)}(0,
|
|
28
|
-
${r.stack}`;throw Mw.error(n),z$(new Error)}}}a(Sde,"getRolePermissions");function Tde(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Cn.SYSTEM_SCHEMA_NAME]=n[Cn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=Ade(t[i]);return}r[i]=X$(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=Rde(c,l);r[i].describe||eV.forEach(f=>{u[f]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=vw()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=vw()})}),r}a(Tde,"translateRolePermissions");function Ade(e){let t=X$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=vw(!0,!0,!0,!0,!0)}),t}a(Ade,"createStructureUserPermissions");function Rde(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,f)=>{let{attribute_name:d}=f,p=f;return Cn.TIME_STAMP_NAMES.includes(d)&&(p=Q$(d,f[Fp])),u[d]=p,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=j$(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let f=i[u];f.describe=rV(f),s.attribute_permissions.push(f),c||yde(f,l)}else if(u!==o){let f;Cn.TIME_STAMP_NAMES.includes(u)?f=Q$(u):f=j$(u),s.attribute_permissions.push(f)}}),c||s.attribute_permissions.push(l),s.describe=J$(s),s}else return e.describe=J$(e),e}a(Rde,"getTableAttrPerms");function J$(e){return eV.filter(t=>e[t]).length>0}a(J$,"getSchemaTableDescribePerm");function rV(e){return tV.filter(t=>e[t]).length>0}a(rV,"getAttributeDescribePerm");function yde(e,t){tV.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(yde,"checkForHashPerms")});var Gp={};ve(Gp,{authentication:()=>dV,bypassAuth:()=>Pde,login:()=>Lde,logout:()=>Mde,start:()=>Dde});function Pde(){uV=!0}async function dV(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let _=e.isOperationsServer?wde?Nde:[]:Ode?bde:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let h=is.get(B.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",S=new No([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",h],["Access-Control-Allow-Origin",i]]);return LS&&S.set("Access-Control-Allow-Credentials","true"),{status:200,headers:S}}o.push("Access-Control-Allow-Origin",i),LS&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(LS){i||(i=r.host);let _=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let S of h)if(S.startsWith(_)){let g=S.indexOf(";");l=S.slice(_.length,g===-1?S.length:g),u=await iV.get(l);break}e.session=u||(u={})}let f=a((_,h,S)=>{let g=new Dd.AuthAuditLog(_,h,ua.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=S,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),h===Ws.SUCCESS?Bw.notify(g):Bw.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&Bw.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let _=e.mtlsConfig.user;_!==null?((_===void 0||_==="Common Name"||_==="CN")&&(_=e.peerCertificate.subject.CN),e.user=await Ye.getUser(_,null,e),f(_,Ws.SUCCESS,"mTLS")):(0,Dd.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=Cl.get(n),!d){let _=n.indexOf(" "),h=n.slice(0,_),S=n.slice(_+1),g,R;try{switch(h){case"Basic":let E=atob(S),A=E.indexOf(":");g=E.slice(0,A),R=E.slice(A+1),d=g||R?await Ye.getUser(g,R,e):null;break;case"Bearer":try{d=await bO(S)}catch(O){if(O.message==="invalid token")try{return await lg(S),c({status:-1})}catch{throw O}}break}}catch(E){return Cde&&(Cl.get(S)||(Cl.set(S,S),f(g,Ws.FAILURE,h))),c({status:401,body:Ra({error:E.message},e)})}Cl.set(n,d),Ide&&f(d.username,Ws.SUCCESS,h)}e.user=d}else u?.user?e.user=await Ye.getUser(u.user,null,e):(uV&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,aV.getSuperUser)());LS&&(e.session.update=function(_){if(!l){l=(0,cV.v4)();let S=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",S):p?.headers?.set&&p.headers.set("Set-Cookie",S)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):p?.headers?.set&&(i&&p.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),p.headers.set("X-Hdb-Session","Secure"))),_.id=l,iV.put(_)},e.login=async function(_,h){let S=e.user=await Ye.authenticateUser(_,h,e);e.session.update({user:S&&(S.getId?.()??S.username)})});let p=await t(e);return p&&(p.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&wi.loginPath?(p.status=302,p.headers.set("Location",wi.loginPath(e))):p.headers.set("WWW-Authenticate","Basic")),c(p))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let f=l.headers;f||(l.headers=f=new No);for(let d=0;d<u;){let p=o[d++];f.set(p,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function Dde({server:e,port:t,securePort:r}){e.http(dV,t||r?{port:t,securePort:r}:{port:"all"}),oV||(oV=!0,setInterval(()=>{Cl=new Map},is.get(B.AUTHENTICATION_CACHETTL)).unref(),lV.user.addListener(()=>{Cl=new Map}))}async function Lde(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password??""),"Login successful"}async function Mde(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var aV,cV,is,Dd,lV,Bw,bde,Ode,Nde,wde,iV,LS,uV,Ide,Cde,Cl,oV,MS=be(()=>{aV=M(An());Vr();Su();zu();Pe();cV=require("uuid"),is=M(ae());H();Dd=M(z()),lV=M(N_());Q_();uo();Bw=(0,Dd.loggerWithTag)("auth-event");is.initSync();bde=is.get(B.HTTP_CORSACCESSLIST),Ode=is.get(B.HTTP_CORS),Nde=is.get(B.OPERATIONSAPI_NETWORK_CORSACCESSLIST),wde=is.get(B.OPERATIONSAPI_NETWORK_CORS),iV=dt({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),LS=is.get(B.AUTHENTICATION_ENABLESESSIONS)??!0,uV=process.env.AUTHENTICATION_AUTHORIZELOCAL??is.get(B.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,Ide=is.get(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Cde=is.get(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Cl=new Map;Ye.onInvalidatedUser(()=>{Cl=new Map});a(Pde,"bypassAuth");a(dV,"authentication");a(Dde,"start");a(Lde,"login");a(Mde,"logout")});var gV=w((IMe,EV)=>{"use strict";var Ne=require("joi"),fV=require("fs-extra"),_V=require("path"),os=ft(),pV=ae(),hV=(H(),C(q)),mV=z(),{hdb_errors:vde}=pe(),{HDB_ERROR_MSGS:tn}=vde,ko=/^[a-zA-Z0-9-_]+$/,Ude=/^[a-zA-Z0-9-_]+$/;EV.exports={getDropCustomFunctionValidator:Bde,setCustomFunctionValidator:Hde,addComponentValidator:qde,dropCustomFunctionProjectValidator:$de,packageComponentValidator:Vde,deployComponentValidator:Kde,setComponentFileValidator:kde,getComponentFileValidator:Gde,dropComponentFileValidator:Fde,addSSHKeyValidator:Yde,updateSSHKeyValidator:Wde,deleteSSHKeyValidator:zde,setSSHKnownHostsValidator:jde};function vS(e,t,r){try{let n=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),s=_V.join(n,t);return fV.existsSync(s)?e?t:r.message(tn.PROJECT_EXISTS):e?r.message(tn.NO_PROJECT):t}catch(n){return mV.error(n),r.message(tn.VALIDATION_ERR)}}a(vS,"checkProjectExists");function qp(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(qp,"checkFilePath");function xde(e,t,r,n){try{let s=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),i=_V.join(s,e,t,r+".js");return fV.existsSync(i)?r:n.message(tn.NO_FILE)}catch(s){return mV.error(s),n.message(tn.VALIDATION_ERR)}}a(xde,"checkFileExists");function Bde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(ko).custom(xde.bind(null,e.project,e.type)).custom(qp).required().messages({"string.pattern.base":tn.BAD_FILE_NAME})});return os.validateBySchema(e,t)}a(Bde,"getDropCustomFunctionValidator");function Hde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom(qp).required(),function_content:Ne.string().required()});return os.validateBySchema(e,t)}a(Hde,"setCustomFunctionValidator");function kde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).required(),payload:Ne.string().allow("").optional(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return os.validateBySchema(e,t)}a(kde,"setComponentFileValidator");function Fde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).optional()});return os.validateBySchema(e,t)}a(Fde,"dropComponentFileValidator");function Gde(e){let t=Ne.object({project:Ne.string().required(),file:Ne.string().custom(qp).required(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return os.validateBySchema(e,t)}a(Gde,"getComponentFileValidator");function qde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!1)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return os.validateBySchema(e,t)}a(qde,"addComponentValidator");function $de(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return os.validateBySchema(e,t)}a($de,"dropCustomFunctionProjectValidator");function Vde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean(),skip_symlinks:Ne.boolean()});return os.validateBySchema(e,t)}a(Vde,"packageComponentValidator");function Kde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.alternatives().try(Ne.boolean(),Ne.string().valid("rolling")).optional()});return os.validateBySchema(e,t)}a(Kde,"deployComponentValidator");function Yde(e){let t=Ne.object({name:Ne.string().pattern(Ude).required().messages({"string.pattern.base":tn.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return os.validateBySchema(e,t)}a(Yde,"addSSHKeyValidator");function Wde(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return os.validateBySchema(e,t)}a(Wde,"updateSSHKeyValidator");function zde(e){let t=Ne.object({name:Ne.string().required()});return os.validateBySchema(e,t)}a(zde,"deleteSSHKeyValidator");function jde(e){let t=Ne.object({known_hosts:Ne.string().required()});return os.validateBySchema(e,t)}a(jde,"setSSHKnownHostsValidator")});var Kp=w((PMe,bV)=>{"use strict";var US=require("joi"),ja=require("path"),Ld=require("fs-extra"),{exec:Qde}=require("child_process"),Jde=require("util"),SV=Jde.promisify(Qde),Md=(H(),C(q)),{PACKAGE_ROOT:Xde}=st(),{handleHDBError:$p,hdb_errors:Zde}=pe(),{HTTP_STATUS_CODES:Vp}=Zde,Pl=ae(),efe=ft(),Dl=z();Pl.initSync();var Hw=Pl.get(Md.CONFIG_PARAMS.COMPONENTSROOT),TV="npm install --force --omit=dev --json",tfe=`${TV} --dry-run`,rfe=Pl.get(Md.CONFIG_PARAMS.ROOTPATH),xS=ja.join(rfe,"ssh");bV.exports={installModules:ofe,auditModules:afe,installAllRootModules:nfe,uninstallRootModule:sfe,linkHarperdb:ife,runCommand:vd};async function nfe(e=!1,t=Pl.get(Md.CONFIG_PARAMS.ROOTPATH)){await BS();let r=!1,n=process.env;Ld.pathExistsSync(xS)&&Ld.readdirSync(xS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+ja.join(xS,"config")+" -o UserKnownHostsFile="+ja.join(xS,"known_hosts"),...process.env},r=!0)});try{let s=Pl.get(Md.CONFIG_PARAMS.ROOTPATH),i=ja.join(s,"node_modules","harperdb");Ld.lstatSync(i).isSymbolicLink()&&Ld.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Dl.error("Error removing symlink:",s)}await vd(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(nfe,"installAllRootModules");async function sfe(e){await vd(`npm uninstall ${e}`,Pl.get(Md.CONFIG_PARAMS.ROOTPATH))}a(sfe,"uninstallRootModule");async function ife(){await BS(),await vd(`npm link ${Xde}`,Pl.get(Md.CONFIG_PARAMS.ROOTPATH))}a(ife,"linkHarperdb");async function vd(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await SV(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
|
|
29
|
-
`,""))}return s&&!s.includes("Debugger listening")&&!s.includes("warn using --force")&&Dl.error("Error running NPM command:",e,s),Dl.trace(n,s),n?.replace(`
|
|
30
|
-
`,"")}a(vd,"runCommand");async function ofe(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Dl.warn(t,e);let r=yV(e);if(r)throw $p(r,r.message,Vp.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?tfe:TV;await BS(),await RV(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let f=ja.join(Hw,u),d,p=null;try{let{stdout:_,stderr:h}=await SV(i,{cwd:f});d=_?_.replace(`
|
|
27
|
+
Database backup has not been removed and can be found here: ${s}`;Wa.error(l),console.error(l)}(0,Pw.get)(x.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Dl.remove)(s))}}async function U$(e){let t=await(0,k$.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function F$(e,t){console.log("copyDb start");let r=Xe()[e],n;for(let d in r){n=r[d].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,x$.open)(new B$.default(t)),c=o.openDB(NS.INTERNAL_DBIS_NAME),l,u=0,f=s.useReadTransaction();try{for(let{key:p,value:_}of s.getRange({transaction:f})){let h=_.is_hash_attribute||_.isPrimaryKey,S,g;if(h&&(S=_.compression,g=CS(),g?_.compression=g:delete _.compression,S?.dictionary?.toString()===g?.dictionary?.toString()&&(S=null,g=null)),c.put(p,_),!(h||_.indexed))continue;let R=new H$.default(!h,h);R.encoding="binary",R.compression=S;let E=n.openDB(p,R);E.decoder=null,E.decoderCopies=!1,E.encoding="binary",R.compression=g;let T=o.openDB(p,R);T.encoder=null,console.log("copying",p,"from",e,"to",t),await d(E,T,h,f)}if(i){let p=n.openDB(NS.AUDIT_STORE_NAME,xp);console.log("copying audit log for",e,"to",t),d(i,p,!1,f)}async function d(p,_,h,S){let g=0,R=0,E=1e7,T=null;for(;E-- >0;)try{for(let b of p.getKeys({start:T,transaction:S}))try{T=b;let{value:v,version:F}=p.getEntry(b,{transaction:S});l=_.put(b,v,h?F:void 0),g++,S.openTimer&&(S.openTimer=0),R+=(b?.length||10)+v.length,u++>5e3&&(await l,console.log("copied",g,"entries",R,"bytes"),u=0)}catch(v){console.error("Error copying record",typeof b=="symbol"?"symbol":b,"from",e,"to",t,v)}console.log("finish copying, copied",g,"entries",R,"bytes");return}catch{if(typeof T=="string"){if(T==="z")return console.error("Reached end of dbi",T,"for",e,"to",t);T=T.slice(0,-2)+"z"}else if(typeof T=="number")T++;else return console.error("Unknown key type",T,"for",e,"to",t)}}a(d,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{f.done(),o.close()}}var x$,OS,Dl,Pw,B$,H$,NS,k$,Dw,Wa,IS=be(()=>{De();x$=require("lmdb"),OS=require("path"),Dl=require("fs-extra"),Pw=M(ae()),B$=M(i_()),H$=M(s_()),NS=M(xt());H();fo();k$=M(go()),Dw=M(yt()),Wa=M(z());a(ede,"compactOnStart");a(U$,"getTotalDBRecordCount");a(F$,"copyDb")});var za=w((pMe,W$)=>{"use strict";var tde=require("minimist"),{isMainThread:Mw,parentPort:Hp,threadId:dMe}=require("worker_threads"),at=(H(),C(G)),Vi=z(),vw=ie(),DS=TS(),PS=ir(),fMe=Tt(),V$=yt(),di=Pd(),G$=Po(),{compactOnStart:rde}=(IS(),C(wS)),nde=ua(),{restartWorkers:LS,onMessageByType:sde}=rt(),{handleHDBError:ide,hdb_errors:ode}=pe(),{HTTP_STATUS_CODES:ade}=ode,kp=ae(),{sendOperationToNode:q$,getThisNodeName:cde,monitorNodeCAs:lde}=(Xn(),C(wo)),{getHDBNodeTable:_Me}=(pl(),C(jO));kp.initSync();var Bp=`Restarting HarperDB. This may take up to ${at.RESTART_TIMEOUT_MS/1e3} seconds.`,ude="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",$$="Clustering is not enabled so cannot be restarted",dde="Invalid service",Ld,Is;W$.exports={restart:K$,restartService:Uw};Mw&&sde(at.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await Uw({service:e.workerType}):K$({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function K$(e){Is=Object.keys(e).length===0,Ld=await di.isServiceRegistered(at.PROCESS_DESCRIPTORS.HDB);let t=tde(process.argv);if(t.service){await Uw(t);return}if(Is&&!Ld){console.error(ude);return}if(Is&&console.log(Bp),Ld){di.enterPM2Mode(),Vi.notify(Bp);let r=nde(Object.keys(at.CONFIG_PARAM_MAP),!0);return vw.isEmptyOrZeroLength(Object.keys(r))||V$.updateConfigValue(void 0,void 0,r,!0,!0),fde(),Bp}return Mw?(Vi.notify(Bp),kp.get(at.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await rde(),process.env.HARPER_EXIT_ON_RESTART&&process.exit(0),setTimeout(()=>{LS()},50)):Hp.postMessage({type:at.ITC_EVENT_TYPES.RESTART}),Bp}a(K$,"restart");async function Uw(e){let{service:t}=e;if(at.HDB_PROCESS_SERVICES[t]===void 0)throw ide(new Error,dde,ade.BAD_REQUEST,void 0,void 0,!0);if(di.expectedRestartOfChildren(),Ld=await di.isServiceRegistered(at.PROCESS_DESCRIPTORS.HDB),!Mw){e.replicated&&lde(),Hp.postMessage({type:at.ITC_EVENT_TYPES.RESTART,workerType:t}),Hp.ref(),await new Promise(s=>{Hp.on("message",i=>{i.type==="restart-complete"&&(s(),Hp.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===cde())continue;let{job_id:i}=await q$(s,e);n.push(await new Promise((o,c)=>{let u=2400,f=setInterval(async()=>{if(u--<=0){clearInterval(f);let _=new Error("Timed out waiting for restart job to complete");_.replicated=n,c(_)}let p=(await q$(s,{operation:"get_job",id:i})).results[0];if(p.status==="COMPLETE"&&(clearInterval(f),o({node:s.name,message:p.message})),p.status==="ERROR"){clearInterval(f);let _=new Error(p.message);_.replicated=n,c(_)}},250)}))}return{replicated:n}}return}let r;switch(t){case at.HDB_PROCESS_SERVICES.clustering:if(!kp.get(at.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Is&&console.log("Restarting clustering"),Vi.notify("Restarting clustering"),await Y$();break;case at.HDB_PROCESS_SERVICES.clustering_config:case at.HDB_PROCESS_SERVICES["clustering config"]:if(!kp.get(at.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Is&&console.log("Restarting clustering_config"),Vi.notify("Restarting clustering_config"),await di.reloadClustering();break;case"custom_functions":case"custom functions":case at.HDB_PROCESS_SERVICES.harperdb:case at.HDB_PROCESS_SERVICES.http_workers:case at.HDB_PROCESS_SERVICES.http:if(Is&&!Ld){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Is&&console.log("Restarting http_workers"),Vi.notify("Restarting http_workers"),Is?await di.restart(at.PROCESS_DESCRIPTORS.HDB):await LS("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Vi.error(r),Is&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(Uw,"restartService");async function fde(){await Y$(),await di.restart(at.PROCESS_DESCRIPTORS.HDB),await vw.async_set_timeout(2e3),kp.get(at.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await Lw(),Is&&(await PS.closeConnection(),process.exit(0))}a(fde,"restartPM2Mode");async function Y$(){if(!V$.getConfigFromFile(at.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await G$.getHDBProcessInfo()).clustering.length===0)Vi.trace("Clustering not running, restart will start clustering services"),await DS.generateNatsConfig(!0),await di.startClusteringProcesses(),await di.startClusteringThreads(),await Lw(),Is&&await PS.closeConnection();else{await DS.generateNatsConfig(!0),Ld?(Vi.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await di.restart(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await di.restart(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await G$.getHDBProcessInfo()).clustering.forEach(s=>{Vi.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await vw.async_set_timeout(3e3),await Lw(),await PS.updateLocalStreams(),Is&&await PS.closeConnection(),Vi.trace("Restart clustering restarting ingest and reply service threads");let t=LS(at.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=LS(at.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(Y$,"restartClustering");async function Lw(){await DS.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await DS.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(Lw,"removeNatsConfig")});var sV=w((EMe,nV)=>{"use strict";var mMe=require("lodash"),In=(H(),C(G)),{handleHDBError:z$,hdb_errors:_de}=pe(),{HDB_ERROR_MSGS:pde,HTTP_STATUS_CODES:hde}=_de,xw=z();nV.exports={getRolePermissions:Ede};var Ll=Object.create(null),mde=a(e=>({key:e,perms:{}}),"perms_template_obj"),X$=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),Z$=a((e=!1,t=!1,r=!1,n=!1)=>({[In.PERMS_CRUD_ENUM.READ]:e,[In.PERMS_CRUD_ENUM.INSERT]:t,[In.PERMS_CRUD_ENUM.UPDATE]:r,[In.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),Bw=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...Z$(t,r,n,s)}),"table_perms_template"),j$=a((e,t=Z$())=>({attribute_name:e,describe:rV(t),[Fp]:t[Fp],[Hw]:t[Hw],[kw]:t[kw]}),"attr_perms_template"),J$=a((e,t=!1)=>({attribute_name:e,describe:t,[Fp]:t}),"timestamp_attr_perms_template"),{READ:Fp,INSERT:Hw,UPDATE:kw}=In.PERMS_CRUD_ENUM,eV=Object.values(In.PERMS_CRUD_ENUM),tV=[Fp,Hw,kw];function Ede(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[In.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Ll[t]&&Ll[t].key===n)return Ll[t].perms;let s=gde(e,r);return Ll[t]?Ll[t].key=n:Ll[t]=mde(n),Ll[t].perms=s,s}catch(r){if(!e[In.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[In.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<In.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw xw.error(n),xw.debug(r),z$(new Error,pde.OUTDATED_PERMS_TRANSLATION_ERROR,hde.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
28
|
+
${r.stack}`;throw xw.error(n),z$(new Error)}}}a(Ede,"getRolePermissions");function gde(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[In.SYSTEM_SCHEMA_NAME]=n[In.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=Sde(t[i]);return}r[i]=X$(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=Tde(c,l);r[i].describe||eV.forEach(f=>{u[f]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=Bw()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=Bw()})}),r}a(gde,"translateRolePermissions");function Sde(e){let t=X$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=Bw(!0,!0,!0,!0,!0)}),t}a(Sde,"createStructureUserPermissions");function Tde(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,f)=>{let{attribute_name:d}=f,p=f;return In.TIME_STAMP_NAMES.includes(d)&&(p=J$(d,f[Fp])),u[d]=p,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=j$(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let f=i[u];f.describe=rV(f),s.attribute_permissions.push(f),c||Ade(f,l)}else if(u!==o){let f;In.TIME_STAMP_NAMES.includes(u)?f=J$(u):f=j$(u),s.attribute_permissions.push(f)}}),c||s.attribute_permissions.push(l),s.describe=Q$(s),s}else return e.describe=Q$(e),e}a(Tde,"getTableAttrPerms");function Q$(e){return eV.filter(t=>e[t]).length>0}a(Q$,"getSchemaTableDescribePerm");function rV(e){return tV.filter(t=>e[t]).length>0}a(rV,"getAttributeDescribePerm");function Ade(e,t){tV.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(Ade,"checkForHashPerms")});var Gp={};ve(Gp,{authentication:()=>dV,bypassAuth:()=>Ide,login:()=>Pde,logout:()=>Dde,start:()=>Cde});function Ide(){uV=!0}async function dV(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let _=e.isOperationsServer?Ode?bde:[]:yde?Rde:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let h=ns.get(x.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",S=new yo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",h],["Access-Control-Allow-Origin",i]]);return MS&&S.set("Access-Control-Allow-Credentials","true"),{status:200,headers:S}}o.push("Access-Control-Allow-Origin",i),MS&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(MS){i||(i=r.host);let _=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let S of h)if(S.startsWith(_)){let g=S.indexOf(";");l=S.slice(_.length,g===-1?S.length:g),u=await iV.get(l);break}e.session=u||(u={})}let f=a((_,h,S)=>{let g=new Md.AuthAuditLog(_,h,la.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=S,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),h===Ys.SUCCESS?Fw.notify(g):Fw.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&Fw.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let _=e.mtlsConfig.user;_!==null?((_===void 0||_==="Common Name"||_==="CN")&&(_=e.peerCertificate.subject.CN),e.user=await We.getUser(_,null,e),f(_,Ys.SUCCESS,"mTLS")):(0,Md.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=Ml.get(n),!d){let _=n.indexOf(" "),h=n.slice(0,_),S=n.slice(_+1),g,R;try{switch(h){case"Basic":let E=atob(S),T=E.indexOf(":");g=E.slice(0,T),R=E.slice(T+1),d=g||R?await We.getUser(g,R,e):null;break;case"Bearer":try{d=await NO(S)}catch(b){if(b.message==="invalid token")try{return await lg(S),c({status:-1})}catch{throw b}}break}}catch(E){return wde&&(Ml.get(S)||(Ml.set(S,S),f(g,Ys.FAILURE,h))),c({status:401,body:Aa({error:E.message},e)})}Ml.set(n,d),Nde&&f(d.username,Ys.SUCCESS,h)}e.user=d}else u?.user?e.user=await We.getUser(u.user,null,e):(uV&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,aV.getSuperUser)());MS&&(e.session.update=function(_){if(!l){l=(0,cV.v4)();let S=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",S):p?.headers?.set&&p.headers.set("Set-Cookie",S)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):p?.headers?.set&&(i&&p.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),p.headers.set("X-Hdb-Session","Secure"))),_.id=l,iV.put(_)},e.login=async function(_,h){let S=e.user=await We.authenticateUser(_,h,e);e.session.update({user:S&&(S.getId?.()??S.username)})});let p=await t(e);return p&&(p.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Oi.loginPath?(p.status=302,p.headers.set("Location",Oi.loginPath(e))):p.headers.set("WWW-Authenticate","Basic")),c(p))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let f=l.headers;f||(l.headers=f=new yo);for(let d=0;d<u;){let p=o[d++];f.set(p,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function Cde({server:e,port:t,securePort:r}){e.http(dV,t||r?{port:t,securePort:r}:{port:"all"}),oV||(oV=!0,setInterval(()=>{Ml=new Map},ns.get(x.AUTHENTICATION_CACHETTL)).unref(),lV.user.addListener(()=>{Ml=new Map}))}async function Pde(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password??""),"Login successful"}async function Dde(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var aV,cV,ns,Md,lV,Fw,Rde,yde,bde,Ode,iV,MS,uV,Nde,wde,Ml,oV,vS=be(()=>{aV=M(Rn());Vr();Tu();Ju();De();cV=require("uuid"),ns=M(ae());H();Md=M(z()),lV=M(b_());z_();ao();Fw=(0,Md.loggerWithTag)("auth-event");ns.initSync();Rde=ns.get(x.HTTP_CORSACCESSLIST),yde=ns.get(x.HTTP_CORS),bde=ns.get(x.OPERATIONSAPI_NETWORK_CORSACCESSLIST),Ode=ns.get(x.OPERATIONSAPI_NETWORK_CORS),iV=ft({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),MS=ns.get(x.AUTHENTICATION_ENABLESESSIONS)??!0,uV=process.env.AUTHENTICATION_AUTHORIZELOCAL??ns.get(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,Nde=ns.get(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,wde=ns.get(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Ml=new Map;We.onInvalidatedUser(()=>{Ml=new Map});a(Ide,"bypassAuth");a(dV,"authentication");a(Cde,"start");a(Pde,"login");a(Dde,"logout")});var gV=w((wMe,EV)=>{"use strict";var Ne=require("joi"),fV=require("fs-extra"),_V=require("path"),ss=ot(),pV=ae(),hV=(H(),C(G)),mV=z(),{hdb_errors:Lde}=pe(),{HDB_ERROR_MSGS:tn}=Lde,Ho=/^[a-zA-Z0-9-_]+$/,Mde=/^[a-zA-Z0-9-_]+$/;EV.exports={getDropCustomFunctionValidator:Ude,setCustomFunctionValidator:xde,addComponentValidator:Fde,dropCustomFunctionProjectValidator:Gde,packageComponentValidator:qde,deployComponentValidator:$de,setComponentFileValidator:Bde,getComponentFileValidator:kde,dropComponentFileValidator:Hde,addSSHKeyValidator:Vde,updateSSHKeyValidator:Kde,deleteSSHKeyValidator:Yde,setSSHKnownHostsValidator:Wde};function US(e,t,r){try{let n=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),s=_V.join(n,t);return fV.existsSync(s)?e?t:r.message(tn.PROJECT_EXISTS):e?r.message(tn.NO_PROJECT):t}catch(n){return mV.error(n),r.message(tn.VALIDATION_ERR)}}a(US,"checkProjectExists");function qp(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(qp,"checkFilePath");function vde(e,t,r,n){try{let s=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),i=_V.join(s,e,t,r+".js");return fV.existsSync(i)?r:n.message(tn.NO_FILE)}catch(s){return mV.error(s),n.message(tn.VALIDATION_ERR)}}a(vde,"checkFileExists");function Ude(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(Ho).custom(vde.bind(null,e.project,e.type)).custom(qp).required().messages({"string.pattern.base":tn.BAD_FILE_NAME})});return ss.validateBySchema(e,t)}a(Ude,"getDropCustomFunctionValidator");function xde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom(qp).required(),function_content:Ne.string().required()});return ss.validateBySchema(e,t)}a(xde,"setCustomFunctionValidator");function Bde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).required(),payload:Ne.string().allow("").optional(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ss.validateBySchema(e,t)}a(Bde,"setComponentFileValidator");function Hde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).optional()});return ss.validateBySchema(e,t)}a(Hde,"dropComponentFileValidator");function kde(e){let t=Ne.object({project:Ne.string().required(),file:Ne.string().custom(qp).required(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ss.validateBySchema(e,t)}a(kde,"getComponentFileValidator");function Fde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!1)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return ss.validateBySchema(e,t)}a(Fde,"addComponentValidator");function Gde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return ss.validateBySchema(e,t)}a(Gde,"dropCustomFunctionProjectValidator");function qde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean(),skip_symlinks:Ne.boolean()});return ss.validateBySchema(e,t)}a(qde,"packageComponentValidator");function $de(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.alternatives().try(Ne.boolean(),Ne.string().valid("rolling")).optional()});return ss.validateBySchema(e,t)}a($de,"deployComponentValidator");function Vde(e){let t=Ne.object({name:Ne.string().pattern(Mde).required().messages({"string.pattern.base":tn.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return ss.validateBySchema(e,t)}a(Vde,"addSSHKeyValidator");function Kde(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return ss.validateBySchema(e,t)}a(Kde,"updateSSHKeyValidator");function Yde(e){let t=Ne.object({name:Ne.string().required()});return ss.validateBySchema(e,t)}a(Yde,"deleteSSHKeyValidator");function Wde(e){let t=Ne.object({known_hosts:Ne.string().required()});return ss.validateBySchema(e,t)}a(Wde,"setSSHKnownHostsValidator")});var Kp=w((CMe,yV)=>{"use strict";var xS=require("joi"),ja=require("path"),vd=require("fs-extra"),{exec:zde,spawn:jde}=require("child_process"),Jde=require("util"),Qde=Jde.promisify(zde),Ud=(H(),C(G)),{PACKAGE_ROOT:Xde}=it(),{handleHDBError:$p,hdb_errors:Zde}=pe(),{HTTP_STATUS_CODES:Vp}=Zde,vl=ae(),efe=ot(),Ja=z(),{once:tfe}=require("events");vl.initSync();var Gw=vl.get(Ud.CONFIG_PARAMS.COMPONENTSROOT),SV="npm install --force --omit=dev --json",rfe=`${SV} --dry-run`,nfe=vl.get(Ud.CONFIG_PARAMS.ROOTPATH),BS=ja.join(nfe,"ssh");yV.exports={installModules:afe,auditModules:cfe,installAllRootModules:sfe,uninstallRootModule:ife,linkHarperdb:ofe,runCommand:xd};async function sfe(e=!1,t=vl.get(Ud.CONFIG_PARAMS.ROOTPATH)){await HS();let r=!1,n=process.env;vd.pathExistsSync(BS)&&vd.readdirSync(BS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+ja.join(BS,"config")+" -o UserKnownHostsFile="+ja.join(BS,"known_hosts"),...process.env},r=!0)});try{let s=vl.get(Ud.CONFIG_PARAMS.ROOTPATH),i=ja.join(s,"node_modules","harperdb");vd.lstatSync(i).isSymbolicLink()&&vd.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Ja.error("Error removing symlink:",s)}await xd(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(sfe,"installAllRootModules");async function ife(e){await xd(`npm uninstall ${e}`,vl.get(Ud.CONFIG_PARAMS.ROOTPATH))}a(ife,"uninstallRootModule");async function ofe(){await HS(),await xd(`npm link ${Xde}`,vl.get(Ud.CONFIG_PARAMS.ROOTPATH))}a(ofe,"linkHarperdb");async function xd(e,t=void 0,r=process.env){Ja.debug({tagName:"npm_run_command"},`running command: \`${e}\``);let n=jde(e,{shell:!0,cwd:t,env:r,stdio:["ignore","pipe","pipe"]}),s="",i="";n.stdout.on("data",c=>{let l=c.toString();Ja.debug({tagName:"npm_run_command:stdout"},l),s+=l}),n.stderr.on("data",c=>{let l=c.toString();Ja.error({tagName:"npm_run_command:stderr"},l),i+=l});let[o]=await tfe(n,"close");if(o!==0)throw new Error(`Command \`${e}\` exited with code ${o}.${i===""?"":` Error: ${i}`}`);return s||void 0}a(xd,"runCommand");async function afe(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Ja.warn(t,e);let r=RV(e);if(r)throw $p(r,r.message,Vp.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?rfe:SV;await HS(),await AV(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let f=ja.join(Gw,u),d,p=null;try{let{stdout:_,stderr:h}=await Qde(i,{cwd:f});d=_?_.replace(`
|
|
31
29
|
`,""):null,p=h?h.replace(`
|
|
32
|
-
`,""):null}catch(_){_.stderr?o[u].npm_error=
|
|
33
|
-
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(AV,"parseNPMStdErr");async function afe(e){Dl.info(`starting auditModules for request: ${e}`);let t=yV(e);if(t)throw $p(t,t.message,Vp.BAD_REQUEST);let{projects:r}=e;await BS(),await RV(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=ja.join(Hw,o);n[o]={npm_output:null,npm_error:null};try{let l=await vd("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=AV(l.stderr)}}return Dl.info(`finished auditModules with response ${n}`),n}a(afe,"auditModules");async function BS(){return await vd("npm -v"),!0}a(BS,"checkNPMInstalled");async function RV(e){if(!Array.isArray(e)||e.length===0)throw $p(new Error,"projects argument must be an array with at least 1 element",Vp.BAD_REQUEST,void 0,void 0,!0);let t=[],r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n],o=ja.join(Hw,i.toString());if(!await Ld.pathExists(o)){t.push(i);continue}let l=ja.join(o,"package.json");await Ld.pathExists(l)||r.push(i)}if(t.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Vp.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Vp.BAD_REQUEST,void 0,void 0,!0)}a(RV,"checkProjectPaths");function yV(e){let t=US.object({projects:US.array().min(1).items(US.string()).required(),dry_run:US.boolean().default(!1)});return efe.validateBySchema(e,t)}a(yV,"modulesValidator")});var Fw=w((LMe,PV)=>{"use strict";var Ds=require("fs-extra"),Wp=require("path"),Yp=z(),OV=se(),{PACKAGE_ROOT:cfe}=st(),kw=(H(),C(q)),CV=ae(),lfe=yt();PV.exports=ufe;async function ufe(){let e=dfe(),t=CV.get(kw.CONFIG_PARAMS.ROOTPATH),r=Wp.join(t,"package.json"),n={dependencies:{harperdb:"file:"+cfe}},s=Wp.join(t,"node_modules");Ds.ensureDirSync(s);let i,o=!0,c=!1;try{i=Ds.readJsonSync(r)}catch(l){if(OV.isEmptyOrZeroLength(e))return;if(l.code!==kw.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!OV.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let f=wV(u);n.dependencies[l]=f+u}if(!o){Yp.notify("Installing components"),await IV(r,n,null),await NV(t,e);return}for(let{name:l,package:u}of e){let f=i.dependencies[l],d=wV(u);if(f===void 0||f!==d+u){c=!0;break}if(u.startsWith("file:"))try{if(Ds.statSync(new URL(u+"/package.json")).mtimeMs>Ds.statSync(r).mtimeMs){c=!0;break}}catch(p){Yp.info(`Error checking ${u}/package.json modification time`,p);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Yp.notify("Removing component",l),c=!0);c&&(Yp.notify("Updating components."),await IV(r,n,i),await NV(t,e))}a(ufe,"installComponents");function NV(e,t){return Promise.all(t.map(({name:r})=>{let n=Wp.join(e,"node_modules",r),s=Wp.join(e,"components",r);if(Ds.existsSync(n)&&Ds.lstatSync(n).isDirectory())return Ds.move(n,s,{overwrite:!0}).then(()=>{Ds.symlink(s,n)})}))}a(NV,"moveModuleToComponents");function dfe(){let e=lfe.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(dfe,"getComponentsConfig");function wV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Wp.extname(e)||Ds.existsSync(e)?"file:":"github:"}a(wV,"getPkgPrefix");async function IV(e,t,r){Yp.trace("npm installing components package.json",t),Ds.writeFileSync(e,JSON.stringify(t,null," "));try{await Kp().installAllRootModules(CV.get(kw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Ds.writeFileSync(e,JSON.stringify(r,null," ")):Ds.unlinkSync(e),n}}a(IV,"installPackages")});var Gw={};ve(Gw,{packageDirectory:()=>ffe});function ffe(e,t={skip_node_modules:!1,skip_symlinks:!1}){return new Promise((r,n)=>{let s=[];LV.default.pack(e,{dereference:!t.skip_symlinks,ignore:t.skip_node_modules?i=>i.includes("node_modules")||i.includes((0,DV.join)("cache","webpack")):void 0}).pipe((0,MV.createGzip)()).on("data",i=>s.push(i)).on("end",()=>{r(Buffer.concat(s))}).on("error",n)})}var DV,LV,MV,qw=be(()=>{DV=require("path"),LV=M(require("tar-fs")),MV=require("node:zlib");a(ffe,"packageDirectory")});var Kw=w(BV=>{"use strict";var Oe=require("fs-extra"),$w=require("fast-glob"),we=require("path"),_fe=require("tar-fs"),pfe=require("gunzip-maybe"),Vw=require("normalize-path"),Pn=gV(),Ut=z(),at=(H(),C(q)),jt=ae(),HS=yt(),hfe=se(),{PACKAGE_ROOT:mfe}=st(),{handleHDBError:xt,hdb_errors:Efe}=pe(),{basename:gfe}=require("path"),Sfe=Fw(),UV=ae(),{Readable:Tfe}=require("stream"),{isMainThread:Afe}=require("worker_threads"),{HDB_ERROR_MSGS:Ll,HTTP_STATUS_CODES:Bt}=Efe,xV=et(),{replicateOperation:_i}=(es(),C(Po)),{packageDirectory:Rfe}=(qw(),C(Gw)),vV=Kp(),yfe=we.join(mfe,"application-template"),bfe=jt.get(at.CONFIG_PARAMS.ROOTPATH),Qa=we.join(bfe,"ssh"),Fo=we.join(Qa,"known_hosts");function Ofe(){Ut.trace("getting custom api status");let e={};try{e={port:jt.get(at.CONFIG_PARAMS.HTTP_PORT),directory:jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw xt(new Error,Ll.FUNCTION_STATUS,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,t)}return e}a(Ofe,"customFunctionsStatus");function Nfe(){Ut.trace("getting custom api endpoints");let e={},t=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT);try{$w.sync(Vw(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:$w.sync(Vw(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:$w.sync(Vw(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw xt(new Error,Ll.GET_FUNCTIONS,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,r)}return e}a(Nfe,"getCustomFunctions");function wfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Pn.getDropCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("getting custom api endpoint file content");let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=we.join(r,n,s,i+".js");try{return Oe.readFileSync(o,{encoding:"utf8"})}catch(c){throw xt(new Error,Ll.GET_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,c)}}a(wfe,"getCustomFunction");async function Ife(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Pn.setCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("setting custom function file content");let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Oe.outputFileSync(we.join(r,n,s,i+".js"),o);let c=await _i(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw xt(new Error,Ll.SET_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,c)}}a(Ife,"setCustomFunction");async function Cfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Pn.getDropCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("dropping custom function file");let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Oe.unlinkSync(we.join(r,n,s,i+".js"));let o=await _i(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw xt(new Error,Ll.DROP_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,o)}}a(Cfe,"dropCustomFunction");async function Pfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.addComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("adding component");let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=we.join(r,n);Oe.mkdirSync(s,{recursive:!0}),Oe.copySync(yfe,s);let i=await _i(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw xt(new Error,Ll.ADD_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,s)}}a(Pfe,"addComponent");async function Dfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.dropCustomFunctionProjectValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("dropping custom function project");let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=jt.get(at.CONFIG_PARAMS.APPS);if(!hfe.isEmptyOrZeroLength(s)){let i=!1;for(let[o,c]of s.entries())if(c.name===n){s.splice(o,1),i=!0;break}if(i)return HS.updateConfigValue(at.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=we.join(r,n);Oe.rmSync(i,{recursive:!0});let o=await _i(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw xt(new Error,Ll.DROP_FUNCTION_PROJECT,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,i)}}a(Dfe,"dropCustomFunctionProject");async function Lfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.packageComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ut.trace("packaging component",n);let s;try{s=await Oe.realpath(we.join(r,n))}catch(o){if(o.code!==at.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Oe.realpath(we.join(jt.get(at.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===at.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await Rfe(s,e)).toString("base64");return{project:n,payload:i}}a(Lfe,"packageComponent");async function Mfe(e){e.project?e.project=we.parse(e.project).name:e.package&&(e.project=vfe(e.package));let t=Pn.deployComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(Ut.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=we.join(r,n),i="file:"+c,await Oe.emptyDir(c);let S=Tfe.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((E,A)=>{S.pipe(pfe()).pipe(_fe.extract(c,{finish:E})).on("error",A)});let g=await Oe.readdir(c);g.length===1&&g[0]==="package"&&(await Oe.copy(we.join(c,"package"),c),await Oe.remove(we.join(c,"package")));let R=we.join(c,"node_modules");o?await vV.runCommand(o,c):Oe.existsSync(R)||await vV.installAllRootModules(!1,c)}else{await HS.addConfig(n,{package:i}),await Sfe();let S=UV.get(at.CONFIG_PARAMS.ROOTPATH);c=we.join(S,"node_modules",n)}if(Afe)return;let l=new Map;l.isWorker=!0;let u=(jp(),C(zp)),f;u.setErrorReporter(S=>f=S);let d=gfe(c),p=u.component_errors.get(d);try{await u.loadComponent(c,l)}finally{u.component_errors.set(d,p)}if(f)throw f;Ut.info("Installed component");let _=e.restart==="rolling";e.restart=_?!1:e.restart;let h=await _i(e);if(e.restart===!0)xV.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(_){let g=await Yw().executeJob({operation:"restart_service",service:"http",replicated:!0});h.restartJobId=g.job_id,h.message=`Successfully deployed: ${n}, restarting HarperDB`}else h.message=`Successfully deployed: ${n}`;return h}a(Mfe,"deployComponent");function vfe(e){if(e.startsWith("git+ssh://"))return we.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return we.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Oe.readFileSync(we.join(e,"package.json"),"utf8"));return we.basename(t)}catch{}return we.basename(e)}a(vfe,"getProjectNameFromPackage");async function Ufe(){let e=a(async(s,i)=>{try{let o=await Oe.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=we.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let f={name:l,entries:[]};i.entries.push(f),await e(u,f)}else{let f=await Oe.stat(u),d={name:we.basename(l),mtime:f.mtime,size:f.size};i.entries.push(d)}}return i}catch(o){return Ut.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{name:jt.get(at.CONFIG_PARAMS.COMPONENTSROOT).split(we.sep).slice(-1).pop(),entries:[]}),n=(jp(),C(zp)).component_errors;for(let s of t.entries){let i=n.get(s.name);i?s.error=n.get(s.name):i===void 0&&(s.error="The component has not been loaded yet (may need a restart)")}return t}a(Ufe,"getComponents");async function xfe(e){let t=Pn.getComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let n=HS.getConfigObj()[e.project]||e.project==="harperdb"?we.join(UV.get(at.CONFIG_PARAMS.ROOTPATH),"node_modules"):jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Oe.stat(we.join(n,e.project,e.file));return{message:await Oe.readFile(we.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===at.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${we.join(e.project,e.file)}'`):i}}a(xfe,"getComponentFile");async function Bfe(e){let t=Pn.setComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=we.join(jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Oe.ensureFile(n),await Oe.outputFile(n,e.payload,r)):await Oe.ensureDir(n);let s=await _i(e);return s.message="Successfully set component: "+e.file,s}a(Bfe,"setComponentFile");async function Hfe(e){let t=Pn.dropComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?we.join(r,n):r,i=we.join(jt.get(at.CONFIG_PARAMS.COMPONENTSROOT),s),o=we.join(jt.get(at.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await Oe.pathExists(o)&&await Oe.unlink(o),await Oe.pathExists(i)&&await Oe.remove(i);let c=we.join(jt.get(at.CONFIG_PARAMS.ROOTPATH),"package.json");if(await Oe.pathExists(c)){let u=JSON.parse(await Oe.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await Oe.writeFile(c,JSON.stringify(u,null,2),"utf8")}HS.deleteConfigFromFile([r]);let l=await _i(e);return e.restart===!0?(xV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(Hfe,"dropComponent");async function kfe(e){let t=Pn.addSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Ut.trace("adding ssh key",r);let c=we.join(Qa,r+".key"),l=we.join(Qa,"config");if(await Oe.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Oe.outputFile(c,n),await Oe.chmod(c,"0600");let u=`#${r}
|
|
30
|
+
`,""):null}catch(_){_.stderr?o[u].npm_error=TV(_.stderr):o[u].npm_error=_.message;continue}try{o[u].npm_output=JSON.parse(d)}catch{o[u].npm_output=d}try{o[u].npm_error=JSON.parse(p)}catch{o[u].npm_error=p}}return Ja.info(`finished installModules with response ${o}`),o.warning=t,o}a(afe,"installModules");function TV(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
|
|
31
|
+
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(TV,"parseNPMStdErr");async function cfe(e){Ja.info(`starting auditModules for request: ${e}`);let t=RV(e);if(t)throw $p(t,t.message,Vp.BAD_REQUEST);let{projects:r}=e;await HS(),await AV(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=ja.join(Gw,o);n[o]={npm_output:null,npm_error:null};try{let l=await xd("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=TV(l.stderr)}}return Ja.info(`finished auditModules with response ${n}`),n}a(cfe,"auditModules");async function HS(){return await xd("npm -v"),!0}a(HS,"checkNPMInstalled");async function AV(e){if(!Array.isArray(e)||e.length===0)throw $p(new Error,"projects argument must be an array with at least 1 element",Vp.BAD_REQUEST,void 0,void 0,!0);let t=[],r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n],o=ja.join(Gw,i.toString());if(!await vd.pathExists(o)){t.push(i);continue}let l=ja.join(o,"package.json");await vd.pathExists(l)||r.push(i)}if(t.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Vp.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Vp.BAD_REQUEST,void 0,void 0,!0)}a(AV,"checkProjectPaths");function RV(e){let t=xS.object({projects:xS.array().min(1).items(xS.string()).required(),dry_run:xS.boolean().default(!1)});return efe.validateBySchema(e,t)}a(RV,"modulesValidator")});var $w=w((DMe,CV)=>{"use strict";var Cs=require("fs-extra"),Wp=require("path"),Yp=z(),bV=ie(),{PACKAGE_ROOT:lfe}=it(),qw=(H(),C(G)),IV=ae(),ufe=yt();CV.exports=dfe;async function dfe(){let e=ffe(),t=IV.get(qw.CONFIG_PARAMS.ROOTPATH),r=Wp.join(t,"package.json"),n={dependencies:{harperdb:"file:"+lfe}},s=Wp.join(t,"node_modules");Cs.ensureDirSync(s);let i,o=!0,c=!1;try{i=Cs.readJsonSync(r)}catch(l){if(bV.isEmptyOrZeroLength(e))return;if(l.code!==qw.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!bV.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let f=NV(u);n.dependencies[l]=f+u}if(!o){Yp.notify("Installing components"),await wV(r,n,null),await OV(t,e);return}for(let{name:l,package:u}of e){let f=i.dependencies[l],d=NV(u);if(f===void 0||f!==d+u){c=!0;break}if(u.startsWith("file:"))try{if(Cs.statSync(new URL(u+"/package.json")).mtimeMs>Cs.statSync(r).mtimeMs){c=!0;break}}catch(p){Yp.info(`Error checking ${u}/package.json modification time`,p);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Yp.notify("Removing component",l),c=!0);c&&(Yp.notify("Updating components."),await wV(r,n,i),await OV(t,e))}a(dfe,"installComponents");function OV(e,t){return Promise.all(t.map(({name:r})=>{let n=Wp.join(e,"node_modules",r),s=Wp.join(e,"components",r);if(Cs.existsSync(n)&&Cs.lstatSync(n).isDirectory())return Cs.move(n,s,{overwrite:!0}).then(()=>{Cs.symlink(s,n)})}))}a(OV,"moveModuleToComponents");function ffe(){let e=ufe.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(ffe,"getComponentsConfig");function NV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Wp.extname(e)||Cs.existsSync(e)?"file:":"github:"}a(NV,"getPkgPrefix");async function wV(e,t,r){Yp.trace("npm installing components package.json",t),Cs.writeFileSync(e,JSON.stringify(t,null," "));try{await Kp().installAllRootModules(IV.get(qw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Cs.writeFileSync(e,JSON.stringify(r,null," ")):Cs.unlinkSync(e),n}}a(wV,"installPackages")});var Vw={};ve(Vw,{packageDirectory:()=>_fe});function _fe(e,t={skip_node_modules:!1,skip_symlinks:!1}){return new Promise((r,n)=>{let s=[];DV.default.pack(e,{dereference:!t.skip_symlinks,ignore:t.skip_node_modules?i=>i.includes("node_modules")||i.includes((0,PV.join)("cache","webpack")):void 0}).pipe((0,LV.createGzip)()).on("data",i=>s.push(i)).on("end",()=>{r(Buffer.concat(s))}).on("error",n)})}var PV,DV,LV,Kw=be(()=>{PV=require("path"),DV=M(require("tar-fs")),LV=require("node:zlib");a(_fe,"packageDirectory")});var zw=w(xV=>{"use strict";var Oe=require("fs-extra"),Yw=require("fast-glob"),we=require("path"),pfe=require("tar-fs"),hfe=require("gunzip-maybe"),Ww=require("normalize-path"),Cn=gV(),Bt=z(),lt=(H(),C(G)),Qt=ae(),kS=yt(),mfe=ie(),{PACKAGE_ROOT:Efe}=it(),{handleHDBError:Ht,hdb_errors:gfe}=pe(),{basename:Sfe}=require("path"),Tfe=$w(),vV=ae(),{Readable:Afe}=require("stream"),{isMainThread:Rfe}=require("worker_threads"),{HDB_ERROR_MSGS:Ul,HTTP_STATUS_CODES:kt}=gfe,UV=rt(),{replicateOperation:fi}=(Xn(),C(wo)),{packageDirectory:yfe}=(Kw(),C(Vw)),MV=Kp(),bfe=we.join(Efe,"application-template"),Ofe=Qt.get(lt.CONFIG_PARAMS.ROOTPATH),Qa=we.join(Ofe,"ssh"),ko=we.join(Qa,"known_hosts");function Nfe(){Bt.trace("getting custom api status");let e={};try{e={port:Qt.get(lt.CONFIG_PARAMS.HTTP_PORT),directory:Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Ht(new Error,Ul.FUNCTION_STATUS,kt.INTERNAL_SERVER_ERROR,Bt.ERR,t)}return e}a(Nfe,"customFunctionsStatus");function wfe(){Bt.trace("getting custom api endpoints");let e={},t=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT);try{Yw.sync(Ww(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:Yw.sync(Ww(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:Yw.sync(Ww(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Ht(new Error,Ul.GET_FUNCTIONS,kt.INTERNAL_SERVER_ERROR,Bt.ERR,r)}return e}a(wfe,"getCustomFunctions");function Ife(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Cn.getDropCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("getting custom api endpoint file content");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=we.join(r,n,s,i+".js");try{return Oe.readFileSync(o,{encoding:"utf8"})}catch(c){throw Ht(new Error,Ul.GET_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,c)}}a(Ife,"getCustomFunction");async function Cfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Cn.setCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("setting custom function file content");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Oe.outputFileSync(we.join(r,n,s,i+".js"),o);let c=await fi(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Ht(new Error,Ul.SET_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,c)}}a(Cfe,"setCustomFunction");async function Pfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Cn.getDropCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("dropping custom function file");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Oe.unlinkSync(we.join(r,n,s,i+".js"));let o=await fi(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Ht(new Error,Ul.DROP_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,o)}}a(Pfe,"dropCustomFunction");async function Dfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Cn.addComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("adding component");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=we.join(r,n);Oe.mkdirSync(s,{recursive:!0}),Oe.copySync(bfe,s);let i=await fi(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Ht(new Error,Ul.ADD_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,s)}}a(Dfe,"addComponent");async function Lfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Cn.dropCustomFunctionProjectValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("dropping custom function project");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Qt.get(lt.CONFIG_PARAMS.APPS);if(!mfe.isEmptyOrZeroLength(s)){let i=!1;for(let[o,c]of s.entries())if(c.name===n){s.splice(o,1),i=!0;break}if(i)return kS.updateConfigValue(lt.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=we.join(r,n);Oe.rmSync(i,{recursive:!0});let o=await fi(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Ht(new Error,Ul.DROP_FUNCTION_PROJECT,kt.INTERNAL_SERVER_ERROR,Bt.ERR,i)}}a(Lfe,"dropCustomFunctionProject");async function Mfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Cn.packageComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Bt.trace("packaging component",n);let s;try{s=await Oe.realpath(we.join(r,n))}catch(o){if(o.code!==lt.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Oe.realpath(we.join(Qt.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===lt.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await yfe(s,e)).toString("base64");return{project:n,payload:i}}a(Mfe,"packageComponent");async function vfe(e){e.project?e.project=we.parse(e.project).name:e.package&&(e.project=Ufe(e.package));let t=Cn.deployComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(Bt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=we.join(r,n),i="file:"+c,await Oe.emptyDir(c);let S=Afe.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((E,T)=>{S.pipe(hfe()).pipe(pfe.extract(c,{finish:E})).on("error",T)});let g=await Oe.readdir(c);g.length===1&&g[0]==="package"&&(await Oe.copy(we.join(c,"package"),c),await Oe.remove(we.join(c,"package")));let R=we.join(c,"node_modules");o?await MV.runCommand(o,c):Oe.existsSync(R)||await MV.installAllRootModules(!1,c)}else{await kS.addConfig(n,{package:i}),await Tfe();let S=vV.get(lt.CONFIG_PARAMS.ROOTPATH);c=we.join(S,"node_modules",n)}if(Rfe)return;let l=new Map;l.isWorker=!0;let u=(jp(),C(zp)),f;u.setErrorReporter(S=>f=S);let d=Sfe(c),p=u.component_errors.get(d);try{await u.loadComponent(c,l)}finally{u.component_errors.set(d,p)}if(f)throw f;Bt.info("Installed component");let _=e.restart==="rolling";e.restart=_?!1:e.restart;let h=await fi(e);if(e.restart===!0)UV.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(_){let g=await jw().executeJob({operation:"restart_service",service:"http",replicated:!0});h.restartJobId=g.job_id,h.message=`Successfully deployed: ${n}, restarting HarperDB`}else h.message=`Successfully deployed: ${n}`;return h}a(vfe,"deployComponent");function Ufe(e){if(e.startsWith("git+ssh://"))return we.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return we.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Oe.readFileSync(we.join(e,"package.json"),"utf8"));return we.basename(t)}catch{}return we.basename(e)}a(Ufe,"getProjectNameFromPackage");async function xfe(){let e=a(async(s,i)=>{try{let o=await Oe.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=we.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let f={name:l,entries:[]};i.entries.push(f),await e(u,f)}else{let f=await Oe.stat(u),d={name:we.basename(l),mtime:f.mtime,size:f.size};i.entries.push(d)}}return i}catch(o){return Bt.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{name:Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT).split(we.sep).slice(-1).pop(),entries:[]}),n=(jp(),C(zp)).component_errors;for(let s of t.entries){let i=n.get(s.name);i?s.error=n.get(s.name):i===void 0&&(s.error="The component has not been loaded yet (may need a restart)")}return t}a(xfe,"getComponents");async function Bfe(e){let t=Cn.getComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let n=kS.getConfigObj()[e.project]||e.project==="harperdb"?we.join(vV.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules"):Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Oe.stat(we.join(n,e.project,e.file));return{message:await Oe.readFile(we.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===lt.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${we.join(e.project,e.file)}'`):i}}a(Bfe,"getComponentFile");async function Hfe(e){let t=Cn.setComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=we.join(Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Oe.ensureFile(n),await Oe.outputFile(n,e.payload,r)):await Oe.ensureDir(n);let s=await fi(e);return s.message="Successfully set component: "+e.file,s}a(Hfe,"setComponentFile");async function kfe(e){let t=Cn.dropComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?we.join(r,n):r,i=we.join(Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),s),o=we.join(Qt.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await Oe.pathExists(o)&&await Oe.unlink(o),await Oe.pathExists(i)&&await Oe.remove(i);let c=we.join(Qt.get(lt.CONFIG_PARAMS.ROOTPATH),"package.json");if(await Oe.pathExists(c)){let u=JSON.parse(await Oe.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await Oe.writeFile(c,JSON.stringify(u,null,2),"utf8")}kS.deleteConfigFromFile([r]);let l=await fi(e);return e.restart===!0?(UV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(kfe,"dropComponent");async function Ffe(e){let t=Cn.addSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Bt.trace("adding ssh key",r);let c=we.join(Qa,r+".key"),l=we.join(Qa,"config");if(await Oe.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Oe.outputFile(c,n),await Oe.chmod(c,"0600");let u=`#${r}
|
|
34
32
|
Host ${s}
|
|
35
33
|
HostName ${i}
|
|
36
34
|
User git
|
|
37
35
|
IdentityFile ${c}
|
|
38
36
|
IdentitiesOnly yes`;await Oe.pathExists(l)?await Oe.appendFile(l,`
|
|
39
|
-
`+u):await Oe.outputFile(l,u);let f="";if(await Oe.pathExists(
|
|
40
|
-
`)}catch{f=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Oe.appendFile(Fo,o);let d=await _i(e);return d.message=`Added ssh key: ${r}${f}`,d}a(kfe,"addSSHKey");async function Ffe(e){let t=Pn.updateSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r,key:n}=e;Ut.trace("updating ssh key",r);let s=we.join(Qa,r+".key");if(!await Oe.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Oe.outputFile(s,n);let i=await _i(e);return i.message=`Updated ssh key: ${r}`,i}a(Ffe,"updateSSHKey");async function Gfe(e){let t=Pn.deleteSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r}=e;Ut.trace("deleting ssh key",r);let n=we.join(Qa,r+".key"),s=we.join(Qa,"config");if(!await Oe.pathExists(n))throw new Error("Key does not exist");let i=await Oe.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Oe.outputFile(s,i),Oe.removeSync(n);let c=await _i(e);return c.message=`Deleted ssh key: ${r}`,c}a(Gfe,"deleteSSHKey");async function qfe(e){let t=[];return await Oe.pathExists(Qa)&&(await Oe.readdir(Qa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(qfe,"listSSHKeys");async function $fe(e){let t=Pn.setSSHKnownHostsValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{known_hosts:r}=e;await Oe.outputFile(Fo,r);let n=await _i(e);return n.message="Known hosts successfully set",n}a($fe,"setSSHKnownHosts");async function Vfe(e){return await Oe.pathExists(Fo)?{known_hosts:await Oe.readFile(Fo,"utf8")}:{known_hosts:null}}a(Vfe,"getSSHKnownHosts");Object.assign(BV,{customFunctionsStatus:Ofe,getCustomFunctions:Nfe,getCustomFunction:wfe,setCustomFunction:Ife,dropCustomFunction:Cfe,addComponent:Pfe,dropCustomFunctionProject:Dfe,packageComponent:Lfe,deployComponent:Mfe,getComponents:Ufe,getComponentFile:xfe,setComponentFile:Bfe,dropComponent:Hfe,addSSHKey:kfe,updateSSHKey:Ffe,deleteSSHKey:Gfe,listSSHKeys:qfe,setSSHKnownHosts:$fe,getSSHKnownHosts:Vfe})});var Ww=w((BMe,kV)=>{"use strict";var Ls=require("joi"),HV=ft();kV.exports={readTransactionLogValidator:Kfe,deleteTransactionLogsBeforeValidator:Yfe};function Kfe(e){let t=Ls.object({schema:Ls.string(),database:Ls.string(),table:Ls.string().required(),from:Ls.date().timestamp(),to:Ls.date().timestamp(),limit:Ls.number().min(1)});return HV.validateBySchema(e,t)}a(Kfe,"readTransactionLogValidator");function Yfe(e){let t=Ls.object({schema:Ls.string(),database:Ls.string(),table:Ls.string().required(),timestamp:Ls.date().timestamp().required()});return HV.validateBySchema(e,t)}a(Yfe,"deleteTransactionLogsBeforeValidator")});var GS=w((kMe,KV)=>{"use strict";var zw=(H(),C(q)),Qp=or(),FV=se(),GV=ae(),qV=To(),$V=z(),{handleHDBError:kS,hdb_errors:Wfe}=pe(),{HTTP_STATUS_CODES:FS}=Wfe,{readTransactionLogValidator:zfe,deleteTransactionLogsBeforeValidator:jfe}=Ww(),VV=Yn(),Qfe="Logs successfully deleted from transaction log.",Jfe="All logs successfully deleted from transaction log.";KV.exports={readTransactionLog:Xfe,deleteTransactionLogsBefore:e_e};async function Xfe(e){let t=zfe(e);if(t)throw kS(t,t.message,FS.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=FV.checkSchemaTableExist(e.database,e.table);if(r)throw kS(new Error,r,FS.NOT_FOUND,void 0,void 0,!0);return GV.get(zw.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Zfe(e):($V.info("Reading HarperDB logs used by Plexus"),(e.from||e.to)&&(e.search_type="timestamp",e.search_values=[e.from??0],e.to&&(e.search_values[1]=e.to)),VV.readAuditLog(e))}a(Xfe,"readTransactionLog");async function*Zfe(e){let t=qV.createNatsTableStreamName(e.database,e.table),r=await Qp.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===zw.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Zfe,"readTransactionLogNats");async function e_e(e){let t=jfe(e);if(t)throw kS(t,t.message,FS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!GV.get(zw.CONFIG_PARAMS.CLUSTERING_ENABLED))return $V.info("Delete transaction logs called for Plexus"),VV.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=FV.checkSchemaTableExist(r,n);if(i)throw kS(new Error,i,FS.NOT_FOUND,void 0,void 0,!0);let o=qV.createNatsTableStreamName(r,n),{jsm:c}=await Qp.getNATSReferences(),l=await Qp.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let f=Qfe,d,p=new Date(l.state.last_ts).getTime();return s>p?(d=l.state.last_seq+1,f=Jfe):d=(await Qp.viewStream(o,parseInt(s),1))[0].nats_sequence,await Qp.purgeTableStream(r,n,{seq:d}),f}a(e_e,"deleteTransactionLogsBefore")});var WV=w((GMe,YV)=>{"use strict";var jw=class{static{a(this,"PermissionTableResponseObject")}constructor(t,r,n=[],s=[]){this.schema=t,this.table=r,this.required_table_permissions=n,this.required_attribute_permissions=s}};YV.exports=jw});var jV=w(($Me,zV)=>{"use strict";var Qw=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};zV.exports=Qw});var Xw=w((KMe,JV)=>{"use strict";var QV=WV(),t_e=jV(),{HDB_ERROR_MSGS:r_e}=Bn(),Jw=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=r_e.OP_AUTH_PERMS_ERROR,this.unauthorized_access={},this.invalid_schema_items=[]}handleUnauthorizedItem(t){return this.invalid_schema_items=[],this.unauthorized_access=[t],this}handleInvalidItem(t){return this.invalid_schema_items=[t],this.unauthorized_access=[],this}addInvalidItem(t,r,n){if(r&&n){let s=`${r}_${n}`;if(this.unauthorized_access[s])return}this.invalid_schema_items.push(t)}addUnauthorizedTable(t,r,n){let s=new QV(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new t_e(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new QV(r,n,[],i);this.unauthorized_access[o]=c}}getPermsResponse(){let t=Object.values(this.unauthorized_access);return t.length>0||this.invalid_schema_items.length>0?(this.unauthorized_access=t,this):null}};JV.exports=Jw});var KS=w((jMe,p1)=>{"use strict";var Zw=Rn(),qS=Yr(),Ms=Vg(),Zp=Ao(),eI=Vc(),n_e=RN(),s_e=dG(),eh=An(),$S=q_(),Sr=z(),i_e=wN(),o_e=Ed(),a_e=XN(),c_e=nS(),l_e=tw(),u_e=rw(),d_e=aS(),f_e=lS(),tI=uS(),Go=se(),__e=Vq(),rI=hS(),e1=za(),rn=(H(),C(q)),t1=sV(),p_e=Do(),r1=(zu(),C(ep)),n1=(MS(),C(Gp)),s1=yt(),ur=Kw(),h_e=require("alasql"),i1=GS(),o1=Kp(),Ud=ts(),a1=(Tl(),C(Sl)),c1=Xw(),{handleHDBError:Dn,hdb_errors:l1}=pe(),{addNodeBack:WMe,removeNodeBack:zMe}=(Tl(),C(Sl)),{HDB_ERROR_MSGS:Ur,HTTP_STATUS_CODES:Jp}=l1,J=new Map,u1="delete",Ja="insert",qo="read",Ml="update",Xp="describe",XV=Zp.describeSchema.name,ZV=Zp.describeTable.name,d1={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},m_e={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},E_e="catchup",g_e="handleGetJob",S_e="handleGetJobsByStartDate",VS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},T_e=[Ms.createTable.name,Ms.createAttribute.name,Ms.dropTable.name,Ms.dropAttribute.name],f1={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},re=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};J.set(Zw.insert.name,new re(!1,[Ja]));J.set(Zw.update.name,new re(!1,[Ml]));J.set(Zw.upsert.name,new re(!1,[Ja,Ml]));J.set(qS.searchByConditions.name,new re(!1,[qo]));J.set(qS.searchByHash.name,new re(!1,[qo]));J.set(qS.searchByValue.name,new re(!1,[qo]));J.set(qS.search.name,new re(!1,[qo]));J.set(Ms.createSchema.name,new re(!0,[]));J.set(Ms.createTable.name,new re(!0,[]));J.set(Ms.createAttribute.name,new re(!1,[Ja]));J.set(Ms.dropSchema.name,new re(!0,[]));J.set(Ms.dropTable.name,new re(!0,[]));J.set(Ms.dropAttribute.name,new re(!0,[]));J.set(Zp.describeSchema.name,new re(!1,[qo]));J.set(Zp.describeTable.name,new re(!1,[qo]));J.set(eI.deleteRecord.name,new re(!1,[u1]));J.set(eh.addUser.name,new re(!0,[]));J.set(eh.alterUser.name,new re(!0,[]));J.set(eh.dropUser.name,new re(!0,[]));J.set(eh.listUsersExternal.name,new re(!0,[]));J.set($S.listRoles.name,new re(!0,[]));J.set($S.addRole.name,new re(!0,[]));J.set($S.alterRole.name,new re(!0,[]));J.set($S.dropRole.name,new re(!0,[]));J.set(i_e.name,new re(!0,[]));J.set(o_e.name,new re(!0,[]));J.set(a_e.name,new re(!0,[]));J.set(c_e.name,new re(!0,[]));J.set(l_e.name,new re(!0,[]));J.set(u_e.name,new re(!0,[]));J.set(tI.setRoutes.name,new re(!0,[]));J.set(tI.getRoutes.name,new re(!0,[]));J.set(tI.deleteRoutes.name,new re(!0,[]));J.set(s1.setConfiguration.name,new re(!0,[]));J.set(d_e.clusterStatus.name,new re(!0,[]));J.set(f_e.name,new re(!0,[]));J.set(rI.getFingerprint.name,new re(!0,[]));J.set(rI.setLicense.name,new re(!0,[]));J.set(eI.deleteFilesBefore.name,new re(!0,[]));J.set(eI.deleteAuditLogsBefore.name,new re(!0,[]));J.set(e1.restart.name,new re(!0,[]));J.set(e1.restartService.name,new re(!0,[]));J.set(n_e.name,new re(!0,[]));J.set(s_e.name,new re(!0,[qo]));J.set(p_e.systemInformation.name,new re(!0,[]));J.set(s1.getConfiguration.name,new re(!0,[]));J.set(i1.readTransactionLog.name,new re(!0,[]));J.set(i1.deleteTransactionLogsBefore.name,new re(!0,[]));J.set(o1.installModules.name,new re(!0,[]));J.set(o1.auditModules.name,new re(!0,[]));J.set(Ud.createCsr.name,new re(!0,[]));J.set(Ud.signCertificate.name,new re(!0,[]));J.set(Ud.listCertificates.name,new re(!0,[]));J.set(Ud.addCertificate.name,new re(!0,[]));J.set(Ud.removeCertificate.name,new re(!0,[]));J.set(Ud.getKey.name,new re(!0,[]));J.set(a1.addNodeBack.name,new re(!0,[]));J.set(a1.removeNodeBack.name,new re(!0,[]));J.set(r1.createTokens.name,new re(!1,[]));J.set(r1.refreshOperationToken.name,new re(!1,[]));J.set(n1.login.name,new re(!1,[]));J.set(n1.logout.name,new re(!1,[]));J.set(ur.customFunctionsStatus.name,new re(!0,[]));J.set(ur.getCustomFunctions.name,new re(!0,[]));J.set(ur.getComponents.name,new re(!0,[]));J.set(ur.getComponentFile.name,new re(!0,[]));J.set(ur.setComponentFile.name,new re(!0,[]));J.set(ur.dropComponent.name,new re(!0,[]));J.set(ur.getCustomFunction.name,new re(!0,[]));J.set(ur.setCustomFunction.name,new re(!0,[]));J.set(ur.dropCustomFunction.name,new re(!0,[]));J.set(ur.addComponent.name,new re(!0,[]));J.set(ur.dropCustomFunctionProject.name,new re(!0,[]));J.set(ur.packageComponent.name,new re(!0,[]));J.set(ur.deployComponent.name,new re(!0,[]));J.set(ur.addSSHKey.name,new re(!0,[]));J.set(ur.updateSSHKey.name,new re(!0,[]));J.set(ur.deleteSSHKey.name,new re(!0,[]));J.set(ur.listSSHKeys.name,new re(!0,[]));J.set(ur.setSSHKnownHosts.name,new re(!0,[]));J.set(ur.getSSHKnownHosts.name,new re(!0,[]));J.set(rI.getRegistrationInfo.name,new re(!1,[]));J.set(eh.userInfo.name,new re(!1,[]));J.set(Zp.describeAll.name,new re(!1,[]));J.set(g_e,new re(!1,[]));J.set(S_e,new re(!0,[]));J.set(E_e,new re(!0,[]));J.set(VS.CSV_DATA_LOAD,new re(!1,[Ja,Ml]));J.set(VS.CSV_URL_LOAD,new re(!1,[Ja,Ml]));J.set(VS.CSV_FILE_LOAD,new re(!1,[Ja,Ml]));J.set(VS.IMPORT_FROM_S3,new re(!1,[Ja,Ml]));J.set(f1.EXPORT_TO_S3,new re(!0,[]));J.set(f1.EXPORT_LOCAL,new re(!0,[]));J.set(rn.VALID_SQL_OPS_ENUM.DELETE,new re(!1,[u1]));J.set(rn.VALID_SQL_OPS_ENUM.SELECT,new re(!1,[qo]));J.set(rn.VALID_SQL_OPS_ENUM.INSERT,new re(!1,[Ja]));J.set(rn.VALID_SQL_OPS_ENUM.UPDATE,new re(!1,[Ml]));p1.exports={verifyPerms:R_e,verifyPermsAst:A_e,verifyBulkLoadAttributePerms:b_e};function A_e(e,t,r){if(Go.isEmptyOrZeroLength(e))throw Sr.info("verify_perms_ast has an empty user parameter"),Dn(new Error);if(Go.isEmptyOrZeroLength(t))throw Sr.info("verify_perms_ast has an empty user parameter"),Dn(new Error);if(Go.isEmptyOrZeroLength(r))throw Sr.info("verify_perms_ast has a null operation parameter"),Dn(new Error);try{let n=new c1,s=new __e(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Sr.info("No schemas defined in verifyPermsAst(), will not continue."),Dn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&d1[r])throw Dn(new Error,Ur.DROP_SYSTEM,Jp.FORBIDDEN);if(c&&!l)return null;let u=t1.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof h_e.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let d=0;d<i.length;d++){let p=s.getTablesBySchemaName(i[d]);p&&o.set(i[d],p)}let f=_1(t,r,o,n);return f||(o.forEach((d,p)=>{for(let _=0;_<d.length;_++){let h=s.getAttributesBySchemaTableName(p,d[_]),S=sI(t.role.permission,p,d[_]);nI(h,S,r,d[_],p,n)}}),n.getPermsResponse())}catch(n){throw Dn(n)}}a(A_e,"verifyPermsAst");function R_e(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Sr.info("null required parameter in verifyPerms"),Dn(new Error,Ur.DEFAULT_INVALID_REQUEST,Jp.BAD_REQUEST);let r;t instanceof Function?r=t.name:r=t;let n=e.action,s=e.schema??e.database,i=e.table,o=new Map;s&&i&&o.set(s,[i]);let c=new c1;if(Go.isEmptyOrZeroLength(e.hdb_user?.role)||Go.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return Sr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(Ur.USER_HAS_NO_PERMS(e.hdb_user?.username));let l=!!e.hdb_user?.role?.permission?.super_user,u=e.hdb_user?.role?.permission?.structure_user,f=o.has(rn.SYSTEM_SCHEMA_NAME)||s===rn.SYSTEM_SCHEMA_NAME;if(l&&f&&m_e[e.operation]&&(i===rn.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===rn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===rn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(f&&d1[r])throw Dn(new Error,Ur.DROP_SYSTEM,Jp.FORBIDDEN);if(l&&!f||u===!0&&(r===Ms.createSchema.name||r===Ms.dropSchema.name))return null;if(T_e.indexOf(r)>=0&&(u===!0||Array.isArray(u)))return u===!0||u.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let d=t1.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=d),(r===XV||r===ZV)&&!d.super_user){if(s===rn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Ur.SCHEMA_PERM_ERROR(s));if(r===XV&&(!d[s]||!d[s][Xp]))return c.handleInvalidItem(Ur.SCHEMA_NOT_FOUND(s));if(r===ZV&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Xp]))return c.handleInvalidItem(Ur.TABLE_NOT_FOUND(s,i))}let p=_1(e.hdb_user,r,o,c,n);if(p)return p;if(J.get(r)&&J.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&rn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let S=[],g=d[s].tables[i];g[rn.PERMS_CRUD_ENUM.READ]&&(g.attribute_permissions.length>0?g.attribute_permissions.filter(E=>E[rn.PERMS_CRUD_ENUM.READ]).forEach(E=>{S.push(E.attribute_name)}):S=global.hdb_schema[s][i].attributes.map(R=>R.attribute),e.get_attributes=S)}let _=y_e(e),h=sI(e.hdb_user?.role?.permission,s,i);return nI(_,h,r,i,s,c,n),c.getPermsResponse()}a(R_e,"verifyPerms");function _1(e,t,r,n,s){if(Go.arrayHasEmptyValues([e,t,r]))throw Sr.info("hasPermissions has an invalid parameter"),Dn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||J.get(t).requires_su))return null;if(!J.get(t))throw Sr.info(`operation ${t} not found.`),Dn(new Error,Ur.OP_NOT_FOUND(t),Jp.BAD_REQUEST);if(J.get(t)&&J.get(t).requires_su)return Sr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Ur.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Xp]===!1){n.addInvalidItem(Ur.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(Ur.SCHEMA_NOT_FOUND(l));continue}let u=r.get(l);for(let f of u){let d=o[l].tables[f];if(!d||d[Xp]===!1)n.addInvalidItem(Ur.TABLE_NOT_FOUND(l,f));else try{let p=[],_=J.get(t).perms;!Go.isEmpty(s)&&_.includes(s)&&(_=[s]);for(let h=0;h<_.length;h++){let S=_[h],g=d[S];(g==null||g===!1)&&(Sr.info(`Required ${S} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),p.push(S))}p.length>0&&n.addUnauthorizedTable(l,f,p)}catch(p){let _=Ur.UNKNOWN_OP_AUTH_ERROR(t,l,f);throw Sr.error(_),Sr.error(p),Dn(l1.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(_1,"hasPermissions");function nI(e,t,r,n,s,i,o){if(!e||!t)throw Sr.info("no attributes specified in checkAttributePerms."),Dn(new Error);let c=J.get(r).perms;if(!c||c==="")throw Sr.info(`no permissions found for ${r} in checkAttributePerms().`),Dn(new Error);if(Go.isEmptyOrZeroLength(t))return Sr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let f of e){let d=t.get(f);if(d){if(d[Xp]===!1){i.addInvalidItem(Ur.ATTR_NOT_FOUND(s,n,f),s,n);continue}if(c)for(let p of c){if(rn.TIME_STAMP_NAMES.includes(d.attribute_name)&&p!==qo)throw Dn(new Error,Ur.SYSTEM_TIMESTAMP_PERMS_ERR,Jp.FORBIDDEN);d[p]===!1&&(l[d.attribute_name]?l[d.attribute_name].push(p):l[d.attribute_name]=[p])}}else i.addInvalidItem(Ur.ATTR_NOT_FOUND(s,n,f),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(nI,"checkAttributePerms");function y_e(e){let t=new Set;try{if(e.action)return t;if(e.operation===rn.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){Sr.info(r)}return t}a(y_e,"getRecordAttributes");function sI(e,t,r){let n=new Map;if(Go.isEmpty(e))return Sr.info("no hdb_user specified in getAttributePermissions"),n;if(e.super_user||!t||!r)return n;try{e[t].tables[r].attribute_permissions.forEach(s=>{n.has(s.attribute_name)||n.set(s.attribute_name,s)})}catch{Sr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(sI,"getAttributePermissions");function b_e(e,t,r,n,s,i,o){let c=new Set(i),l=sI(e,n,s);nI(c,l,t,s,n,o,r)}a(b_e,"verifyBulkLoadAttributePerms")});var WS=w((JMe,S1)=>{"use strict";S1.exports={evaluateSQL:B_e,processAST:g1,convertSQLToAST:E1,checkASTPermissions:m1};var O_e=Rn(),h1=require("util"),N_e=h1.callbackify(O_e.insert),w_e=Yr().search,I_e=tk().update,C_e=h1.callbackify(I_e),P_e=nk().convertDelete,Xa=require("alasql"),D_e=KS(),YS=z(),L_e=aE(),M_e=se(),th=(H(),C(q)),{hdb_errors:v_e,handleHDBError:iI}=pe(),{HTTP_STATUS_CODES:oI}=v_e;L_e(Xa);var U_e=403,x_e="There was a problem performing this insert. Please check the logs and try again.",aI=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function B_e(e,t){let r=e.parsed_sql_object;if(!r){r=E1(e.sql);let n,s=r.ast.statements[0];if(s instanceof Xa.yy.Insert?n=s.into.databaseid:s instanceof Xa.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Xa.yy.Update||s instanceof Xa.yy.Delete?n=s.table.databaseid:YS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Xa.yy.Select)&&M_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}g1(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(B_e,"evaluateSQL");function m1(e,t){let r;try{r=D_e.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(m1,"checkASTPermissions");function E1(e){let t=new aI;if(!e)throw iI(new Error,"The 'sql' parameter is missing from the request body",oI.BAD_REQUEST);try{let r=e.trim(),n=Xa.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
41
|
-
`);throw n[1]?iI(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,oI.BAD_REQUEST):iI(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",oI.BAD_REQUEST)}return t}a(E1,"convertSQLToAST");function g1(e,t,r){try{let n=H_e;if(!e.bypass_auth&&!t.permissions_checked){let i=m1(e,t);if(i&&i.length>0)return r(U_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case th.VALID_SQL_OPS_ENUM.SELECT:n=w_e,s=t.ast.statements[0];break;case th.VALID_SQL_OPS_ENUM.INSERT:n=k_e;break;case th.VALID_SQL_OPS_ENUM.UPDATE:n=C_e;break;case th.VALID_SQL_OPS_ENUM.DELETE:n=P_e;break;default:throw new Error(`unsupported SQL type ${t.variant} in SQL: ${e}`)}n(s,(i,o)=>{if(i){r(i);return}r(null,o)})}catch(n){return r(n)}}a(g1,"processAST");function H_e(e,t){YS.info(e),t("unknown sql statement")}a(H_e,"nullFunction");function k_e({statement:e,hdb_user:t},r){let n=e.into,s={schema:n.databaseid,table:n.tableid,operation:"insert",hdb_user:t},i=e.columns.map(o=>o.columnid);try{s.records=F_e(i,e.values)}catch(o){return r(o)}N_e(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){YS.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(k_e,"convertInsert");function F_e(e,t){try{return t.map(r=>{if(e.length!==r.length)throw"number of values do not match number of columns in insert";let n={};return r.forEach((s,i)=>{if(s.columnid)throw"cannot use a column in insert value";"value"in s?n[e[i]]=s.value:n[e[i]]=Xa.compile(`SELECT ${s.toString()} AS [${th.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw YS.error(r),new Error(x_e)}}a(F_e,"createDataObjects")});var _I=w((tve,y1)=>{var JS=require("clone"),XS=ft(),G_e=se(),jS=(H(),C(q)),ZMe=z(),cI=require("fs"),uI=require("joi"),{string:QS}=uI.types(),{hdb_errors:q_e,handleHDBError:zS}=pe(),{HDB_ERROR_MSGS:eve,HTTP_STATUS_CODES:lI}=q_e,{common_validators:xd}=Mi(),T1=" is required",$_e=["insert","update","upsert"],dI={database:{presence:!1,format:xd.schema_format,length:xd.schema_length},schema:{presence:!1,format:xd.schema_format,length:xd.schema_length},table:{presence:!0,format:xd.schema_format,length:xd.schema_length},action:{inclusion:{within:$_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},V_e={schema:QS.required(),table:QS.required(),action:QS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:K_e,AWS_SECRET:Y_e,AWS_BUCKET:W_e,AWS_FILE_KEY:z_e,REGION:j_e}=jS.S3_BUCKET_AUTH_KEYS,Q_e={s3:{presence:!0},[`s3.${K_e}`]:{presence:!0,type:"String"},[`s3.${Y_e}`]:{presence:!0,type:"String"},[`s3.${W_e}`]:{presence:!0,type:"String"},[`s3.${z_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${j_e}`]:{presence:!0,type:"String"}},A1=JS(dI);A1.data.presence={message:T1};var R1=JS(dI);R1.file_path.presence={message:T1};var J_e=Object.assign(JS(dI),Q_e),fI=JS(V_e);fI.csv_url=QS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();fI.passthrough_headers=uI.object();function X_e(e){let t=XS.validateObject(e,A1);return ZS(e,t)}a(X_e,"dataObject");function Z_e(e){let t=XS.validateBySchema(e,uI.object(fI));return ZS(e,t)}a(Z_e,"urlObject");function epe(e){let t=XS.validateObject(e,R1);return ZS(e,t)}a(epe,"fileObject");function tpe(e){let t=XS.validateObject(e,J_e);return ZS(e,t)}a(tpe,"s3FileObject");function ZS(e,t){if(!t){let r=G_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return zS(new Error,r,lI.BAD_REQUEST);if(e.operation===jS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{cI.accessSync(e.file_path,cI.constants.R_OK|cI.constants.F_OK)}catch(n){return n.code===jS.NODE_ERROR_CODES.ENOENT?zS(n,`No such file or directory ${n.path}`,lI.BAD_REQUEST):n.code===jS.NODE_ERROR_CODES.EACCES?zS(n,`Permission denied ${n.path}`,lI.BAD_REQUEST):zS(n)}}return t}a(ZS,"postValidateChecks");y1.exports={dataObject:X_e,urlObject:Z_e,fileObject:epe,s3FileObject:tpe}});var pI=w((nve,b1)=>{"use strict";var rh=z(),eT=(H(),C(q));async function rpe(e,t,r,n=void 0){if(!e||typeof e!="function")throw new Error("Invalid function parameter");let s;try{return s=await e(t),r&&await r(t,s,n),t.operation===eT.OPERATIONS_ENUM.INSERT||t.operation===eT.OPERATIONS_ENUM.UPDATE||t.operation===eT.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===eT.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(rh.info(i.message),i):i.http_resp_msg?(rh.error(`Error calling operation: ${e.name}`),rh.error(i.http_resp_msg),i):(rh.error(`Error calling operation: ${e.name}`),rh.error(i),i)}}a(rpe,"callOperationFunctionAsAwait");b1.exports={callOperationFunctionAsAwait:rpe}});var hI=w((ive,N1)=>{"use strict";var{S3:npe,GetObjectCommand:spe}=require("@aws-sdk/client-s3");N1.exports={getFileStreamFromS3:ipe,getS3AuthObj:O1};async function ipe(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await O1(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new spe(r))).Body}a(ipe,"getFileStreamFromS3");function O1(e,t,r){return new npe({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(O1,"getS3AuthObj")});var I1=w((ave,w1)=>{"use strict";var mI=class{static{a(this,"BulkLoadFileObject")}constructor(t,r,n,s,i,o,c=null){this.op=t,this.action=r,this.schema=n,this.table=s,this.file_path=i,this.file_type=o,this.role_perms=c}},EI=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};w1.exports={BulkLoadFileObject:mI,BulkLoadDataObject:EI}});var P1=w((lve,C1)=>{"use strict";var gI=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};C1.exports=gI});var bI=w((hve,W1)=>{"use strict";var tT=Rn(),nT=_I(),ope=require("needle"),pi=(H(),C(q)),dve=Tt(),Bd=se(),{handleHDBError:Ht,hdb_errors:k1}=pe(),{HTTP_STATUS_CODES:xr,HDB_ERROR_MSGS:Tr,CHECK_LOGS_WRAPPER:Ul}=k1,Hd=z(),SI=require("papaparse");Bd.promisifyPapaParse();var hi=require("fs-extra"),ape=require("path"),{chain:D1}=require("stream-chain"),L1=require("stream-json/streamers/StreamArray"),M1=require("stream-json/utils/Batch"),v1=require("stream-chain/utils/comp"),{finished:U1}=require("stream"),cpe=ae(),F1=pI(),lpe=hI(),{BulkLoadFileObject:AI,BulkLoadDataObject:upe}=I1(),RI=Xw(),{verifyBulkLoadAttributePerms:G1}=KS(),fve=P1(),_ve=or(),pve=To(),{databases:dpe}=(Pe(),C(tt)),{coerceType:fpe}=(Gf(),C(OI)),x1="No records parsed from csv file.",vl=`${cpe.get("HDB_ROOT")}/tmp`,{schema_regex:_pe}=Mi(),B1=1024*1024*2,H1=5e3,ppe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};W1.exports={csvDataLoad:hpe,csvURLLoad:mpe,csvFileLoad:Epe,importFromS3:gpe};async function hpe(e,t){let r=nT.dataObject(e);if(r)throw Ht(r,r.message,xr.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=V1(e.schema,e.table),i=SI.parse(e.data,{header:!0,skipEmptyLines:!0,transform:TI.bind(null,s),dynamicTyping:!1}),o=new RI;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&G1(e.hdb_user?.role?.permission,this.job_operation_function.name,e.action,e.schema,e.table,i.meta.fields,o);let c=o.getPermsResponse();if(c)throw Ht(new Error,c,xr.BAD_REQUEST,void 0,void 0,!0);let l=new upe(e.action,e.schema,e.table,i.data);return n=await F1.callOperationFunctionAsAwait(K1,l,null),n.message===x1?x1:Y1(n.records,n.number_written)}catch(s){throw xl(s)}}a(hpe,"csvDataLoad");async function mpe(e){let t=nT.urlObject(e);if(t)throw Ht(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${vl}/${r}`;try{await Spe(e,r)}catch(s){throw Hd.error(Tr.DOWNLOAD_FILE_ERR(r)+" - "+s),Ht(s,Ul(Tr.DOWNLOAD_FILE_ERR(r)))}try{let s=new AI(this.job_operation_function.name,e.action,e.schema,e.table,n,pi.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await yI(s);return await rT(n),i}catch(s){throw await rT(n),xl(s)}}a(mpe,"csvURLLoad");async function Epe(e){let t=nT.fileObject(e);if(t)throw Ht(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r=new AI(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,pi.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await yI(r)}catch(n){throw xl(n)}}a(Epe,"csvFileLoad");async function gpe(e){let t=nT.s3FileObject(e);if(t)throw Ht(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=ape.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${vl}/${s}`;let i=new AI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Tpe(s,e);let o=await yI(i);return await rT(r),o}catch(n){throw await rT(r),xl(n)}}a(gpe,"importFromS3");async function Spe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await ope("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw Ht(n,s,n.statusCode,pi.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Rpe(r,e.csv_url),await Ape(t,r.raw)}a(Spe,"downloadCSVFile");async function Tpe(e,t){try{let r=`${vl}/${e}`;await hi.mkdirp(vl),await hi.writeFile(`${vl}/${e}`,"",{flag:"a+"});let n=await hi.createWriteStream(r),s=await lpe.getFileStreamFromS3(t);await new Promise((i,o)=>{s.on("error",function(c){o(c)}),s.pipe(n).on("error",function(c){o(c)}).on("close",function(){Hd.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Hd.error(Tr.S3_DOWNLOAD_ERR+" - "+r),Ht(r,Ul(Tr.S3_DOWNLOAD_ERR))}}a(Tpe,"downloadFileFromS3");async function Ape(e,t){try{await hi.mkdirp(vl),await hi.writeFile(`${vl}/${e}`,t)}catch(r){throw Hd.error(Tr.WRITE_TEMP_FILE_ERR),Ht(r,Ul(Tr.DEFAULT_BULK_LOAD_ERR))}}a(Ape,"writeFileToTempFolder");async function rT(e){if(e)try{await hi.access(e),await hi.unlink(e)}catch{Hd.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(rT,"deleteTempFile");function Rpe(e,t){if(e.statusCode!==k1.HTTP_STATUS_CODES.OK)throw Ht(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,xr.BAD_REQUEST);if(!ppe[e.headers["content-type"]])throw Ht(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,xr.BAD_REQUEST);if(!e.raw)throw Ht(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,xr.BAD_REQUEST)}a(Rpe,"validateURLResponse");async function yI(e){try{let t;switch(e.file_type){case pi.VALID_S3_FILE_TYPES.CSV:t=await ype(e);break;case pi.VALID_S3_FILE_TYPES.JSON:t=await bpe(e);break;default:throw Ht(new Error,Tr.DEFAULT_BULK_LOAD_ERR,xr.BAD_REQUEST,pi.LOG_LEVELS.ERROR,Tr.INVALID_FILE_EXT_ERR(e))}return Y1(t.records,t.number_written)}catch(t){throw xl(t)}}a(yI,"fileLoad");async function q1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;s&&s.pause();let o={operation:e.action,schema:e.schema,table:e.table,records:i};try{let{attributes:c}=await tT.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&G1(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=Ht(c);r(l)}}a(q1,"validateChunk");async function $1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Bd.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Bd.isEmpty(c)&&!Bd.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(u=>c.add(u))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await F1.callOperationFunctionAsAwait(K1,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=Ht(c,Ul(Tr.INSERT_CSV_ERR),xr.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Tr.INSERT_CSV_ERR+" - "+c);r(l)}}a($1,"insertChunk");async function ype(e){let t={records:0,number_written:0},r=V1(e.schema,e.table);try{let n=new RI,s=hi.createReadStream(e.file_path,{highWaterMark:B1});s.setEncoding("utf8"),await SI.parsePromise(s,q1.bind(null,e,n),TI.bind(null,r));let i=n.getPermsResponse();if(i)throw Ht(new Error,i,xr.BAD_REQUEST);return s=hi.createReadStream(e.file_path,{highWaterMark:B1}),s.setEncoding("utf8"),await SI.parsePromise(s,$1.bind(null,e,t),TI.bind(null,r)),s.destroy(),t}catch(n){throw Ht(n,Ul(Tr.PAPA_PARSE_ERR),xr.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Tr.PAPA_PARSE_ERR+n)}}a(ype,"callPapaParse");function V1(e,t){let r=dpe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>fpe(i,s));return n}a(V1,"createTransformMap");function TI(e,t,r){let n=e.get(r);return n?n(t):Bd.autoCast(t)}a(TI,"typeFunction");async function bpe(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new RI,s=D1([hi.createReadStream(e.file_path,{encoding:"utf-8"}),L1.withParser(),c=>c.value,new M1({batchSize:H1}),v1(async c=>{await q1(e,n,r,c)})]);await new Promise((c,l)=>{U1(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw Ht(new Error,i,xr.BAD_REQUEST);let o=D1([hi.createReadStream(e.file_path,{encoding:"utf-8"}),L1.withParser(),c=>c.value,new M1({batchSize:H1}),v1(async c=>{await $1(e,t,r,c)})]);return await new Promise((c,l)=>{U1(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw Ht(n,Ul(Tr.INSERT_JSON_ERR),xr.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Tr.INSERT_JSON_ERR+n)}}a(bpe,"insertJson");async function K1(e){let t={};try{e.data&&e.data.length>0&&Ope(e.data[0])?t=await Npe(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Hd.info(t.message))}catch(r){throw xl(r)}return t}a(K1,"callBulkFileLoad");function Ope(e){let t=Object.keys(e);for(let r of t)if(!_pe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(Ope,"validateColumnNames");async function Npe(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=tT.insert;break;case"update":i=tT.update;break;case"upsert":i=tT.upsert;break;default:throw Ht(new Error,Tr.INVALID_ACTION_PARAM_ERR(n),xr.BAD_REQUEST,pi.LOG_LEVELS.ERROR,Tr.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let f=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][f])>=0&&e.splice(d,1)}let l=Bd.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw xl(o)}}a(Npe,"bulkFileLoad");function Y1(e,t){return`successfully loaded ${t} of ${e} records`}a(Y1,"buildResponseMsg");function xl(e){return Ht(e,Ul(Tr.DEFAULT_BULK_LOAD_ERR),xr.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Tr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(xl,"buildTopLevelErrMsg")});var II=w((Eve,tK)=>{"use strict";var wI=Yr(),wpe=hI(),{AsyncParser:Ipe}=require("json2csv"),sT=require("stream"),as=se(),NI=require("fs-extra"),Cpe=require("path"),vs=z(),{promisify:Q1}=require("util"),nh=se(),{handleHDBError:dr,hdb_errors:Ppe}=pe(),{HDB_ERROR_MSGS:Ln,HTTP_STATUS_CODES:fr}=Ppe,{streamAsJSON:Dpe}=(yR(),C(qL)),{Upload:Lpe}=require("@aws-sdk/lib-storage"),{toCsvStream:Mpe}=(uo(),C(cM)),z1=["search_by_value","search_by_hash","sql","search_by_conditions"],j1=["json","csv"],J1="json",X1="csv",vpe="Successfully exported JSON locally.",Upe="Successfully exported CSV locally.",xpe=1e3,Bpe=wI.searchByHash,Hpe=wI.searchByValue,kpe=Q1(sT.finished);tK.exports={export_to_s3:$pe,export_local:Fpe};async function Fpe(e){vs.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=Z1(e);if(!as.isEmpty(t))throw vs.error(t),dr(new Error,t,fr.BAD_REQUEST,void 0,void 0,!0);if(as.isEmpty(e.path))throw vs.error(Ln.MISSING_VALUE("path")),dr(new Error,Ln.MISSING_VALUE("path"),fr.BAD_REQUEST,void 0,void 0,!0);let r=(as.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Cpe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=as.buildFolderPath(e.path,r);await Gpe(e.path);let s=await eK(e);return await qpe(n,e.format,s)}a(Fpe,"export_local");async function Gpe(e){if(vs.trace("in confirmPath"),as.isEmptyOrZeroLength(e))throw dr(new Error,`Invalid path: ${e}`,fr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await NI.stat(e)}catch(r){let n;throw r.code==="ENOENT"?n=`path '${e}' does not exist`:r.code==="EACCES"?n=`access to path '${e}' is denied`:n=r.message,vs.error(n),dr(new Error,n,fr.BAD_REQUEST,void 0,void 0,!0)}if(!t.isDirectory()){let r=`path '${e}' is not a directory, please supply a valid folder path`;throw vs.error(r),dr(new Error,r,fr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(Gpe,"confirmPath");async function qpe(e,t,r){if(vs.trace("in saveToLocal"),nh.isEmptyOrZeroLength(e))throw dr(new Error,Ln.INVALID_VALUE("file_path"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmptyOrZeroLength(t))throw dr(new Error,Ln.INVALID_VALUE("Source format"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmpty(r))throw dr(new Error,Ln.NOT_FOUND("Data"),fr.BAD_REQUEST,void 0,void 0,!0);if(t===J1){let n=NI.createWriteStream(e);return Dpe(r).pipe(n),await kpe(n),{message:vpe,path:e}}else if(t===X1){let n=NI.createWriteStream(e),s=sT.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(f=>({label:f,value:f})));let c={objectMode:!0};return await new Ipe(i,c).fromInput(s).toOutput(n).promise(!1),{message:Upe,path:e}}throw dr(new Error,Ln.INVALID_VALUE("format"),fr.BAD_REQUEST)}a(qpe,"saveToLocal");async function $pe(e){if(!e.s3||Object.keys(e.s3).length===0)throw dr(new Error,Ln.MISSING_VALUE("S3 object"),fr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw dr(new Error,Ln.MISSING_VALUE("aws_access_key_id"),fr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw dr(new Error,Ln.MISSING_VALUE("aws_secret_access_key"),fr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.bucket))throw dr(new Error,Ln.MISSING_VALUE("bucket"),fr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.key))throw dr(new Error,Ln.MISSING_VALUE("key"),fr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.region))throw dr(new Error,Ln.MISSING_VALUE("region"),fr.BAD_REQUEST);let t=Z1(e);if(!as.isEmpty(t))throw dr(new Error,t,fr.BAD_REQUEST);vs.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await eK(e)}catch(l){throw vs.error(l),l}let n,s=await wpe.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new sT.PassThrough;if(e.format===X1){i=e.s3.key+".csv";let l=Mpe(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===J1){i=e.s3.key+".json";let l=new sT.Readable;l.pipe(o),l.on("error",d=>{throw d}),l.push("[");let u=r.length,f="";for(let[d,p]of r.entries()){let _=d===u-1?JSON.stringify(p):JSON.stringify(p)+",";f+=_,d!==0&&d%xpe===0&&(l.push(f),f="")}f.length!==0&&l.push(f),l.push("]"),l.push(null)}else throw dr(new Error,Ln.INVALID_VALUE("format"),fr.BAD_REQUEST);return new Lpe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a($pe,"export_to_s3");function Z1(e){if(vs.trace("in exportCoreValidation"),as.isEmpty(e.format))return"format missing";if(j1.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${j1.join(", ")}`;let t=e.search_operation.operation;if(as.isEmpty(t))return"search_operation.operation missing";if(z1.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${z1.join(", ")}`}a(Z1,"exportCoreValidation");async function eK(e){vs.trace("in getRecords");let t,r;if(nh.isEmpty(e.search_operation)||nh.isEmptyOrZeroLength(e.search_operation.operation))throw dr(new Error,Ln.INVALID_VALUE("Search operation"),fr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=Hpe;break;case"search_by_hash":t=Bpe;break;case"search_by_conditions":t=wI.searchByConditions;break;case"sql":{let n=WS();t=Q1(n.evaluateSQL);break}default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,vs.error(r),dr(new Error,r,fr.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(eK,"getRecords")});var nK=w((Sve,rK)=>{"use strict";var CI=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};rK.exports=CI});var oK=w((Ave,iK)=>{"use strict";var Vpe=(H(),C(q)),sK=require("moment"),Kpe=require("uuid").v4,PI=class{static{a(this,"JobObject")}constructor(){this.id=Kpe(),this.type=void 0,this.start_datetime=sK().valueOf(),this.created_datetime=sK().valueOf(),this.end_datetime=void 0,this.status=Vpe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};iK.exports=PI});var DI=w((yve,pK)=>{"use strict";var Ype=require("uuid").v4,dK=Rn(),fK=Yr(),Wpe=si(),zpe=Hu(),jpe=nK(),Ot=(H(),C(q)),Qpe=oK(),Jpe=ng(),mi=z(),Xpe=vf(),kd=se(),{promisify:Zpe}=require("util"),Bl=require("moment"),ehe=WS(),iT=_I(),aK=Iy(),{deleteTransactionLogsBeforeValidator:the}=Ww(),{handleHDBError:cK,hdb_errors:rhe,ClientError:nhe}=pe(),{HTTP_STATUS_CODES:lK}=rhe,uK=fK.searchByValue,she=fK.searchByHash,ihe=dK.insert,ohe=Zpe(ehe.evaluateSQL),ahe=dK.update;pK.exports={addJob:uhe,updateJob:fhe,handleGetJob:che,handleGetJobsByStartDate:lhe,getJobById:_K};async function che(e){if(e.id===void 0)throw new nhe("'id' is required");let t=await _K(e.id);return kd.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}a(che,"handleGetJob");async function lhe(e){try{let t=await dhe(e);if(mi.trace(`Searching for jobs from ${e.from_date} to ${e.to_date}`),t&&t.length>0)for(let r of t)r.start_datetime&&(r.start_datetime_converted=Bl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Bl(r.end_datetime)),r.request!==void 0&&delete r.request,delete r.__createdtime__,delete r.__updatedtime__;return t}catch(t){let r=`There was an error searching jobs by date: ${t}`;throw mi.error(r),new Error(r)}}a(lhe,"handleGetJobsByStartDate");async function uhe(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||kd.isEmptyOrZeroLength(e.operation)){let f="job parameter is invalid";return mi.info(f),t.error=f,t}if(!Ot.JOB_TYPE_ENUM[e.operation])return mi.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case Ot.OPERATIONS_ENUM.CSV_FILE_LOAD:n=iT.fileObject(e);break;case Ot.OPERATIONS_ENUM.CSV_URL_LOAD:n=iT.urlObject(e);break;case Ot.OPERATIONS_ENUM.CSV_DATA_LOAD:n=iT.dataObject(e);break;case Ot.OPERATIONS_ENUM.IMPORT_FROM_S3:n=iT.s3FileObject(e);break;case Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=aK(e,"date");break;case Ot.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=aK(e,"timestamp");break;case Ot.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=the(e);break;case Ot.OPERATIONS_ENUM.RESTART_SERVICE:if(Ot.HDB_PROCESS_SERVICES[e.service]===void 0)throw cK(new Error,"Invalid service",lK.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw cK(n,n.message,lK.BAD_REQUEST,void 0,void 0,!0);let s=new Qpe;s.type=e.operation===Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new Wpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await uK(i))}catch(f){let d=`There was an error inserting a new job: ${f}`;return mi.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Ype();try{o=await uK(i)}catch(f){let d=`There was an error inserting a new job: ${f}`;return mi.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return mi.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Xpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await ihe(l)}catch(f){return mi.error(`There was an error inserting a job for job type: ${e.operation} -- ${f}`),t.success=!1,t}if(u.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let f=`Created a job with type ${s.type} and id ${s.id}`;t.message=f,t.createdJob=s,t.success=!0,mi.trace(f)}return t}a(uhe,"addJob");async function dhe(e){let t=Bl(e.from_date,Bl.ISO_8601),r=Bl(e.to_date,Bl.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new jpe(n,e.hdb_user);try{return await ohe(s)}catch(i){throw mi.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(dhe,"getJobsInDateRange");async function _K(e){if(kd.isEmptyOrZeroLength(e))return kd.errorizeMessage("Invalid job ID specified.");let t=new zpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await she(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return mi.error(n),kd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(_K,"getJobById");async function fhe(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(kd.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===Ot.JOB_STATUS_ENUM.COMPLETE||e.status===Ot.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Bl().valueOf());let t=new Jpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await ahe(t),r}a(fhe,"updateJob")});var RK=w((Ove,AK)=>{"use strict";var hK=se(),Ar=(H(),C(q)),_he=require("moment"),oT=bI(),sh=z(),mK=DI(),EK=II(),gK=Vc(),SK=et(),phe=GS(),hhe=za(),{parentPort:mhe,isMainThread:TK}=require("worker_threads"),{onMessageByType:Ehe}=et(),LI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function ghe(e){if(!e||Object.keys(e).length===0)throw new Error("Empty runner passed to parseMessage");if(!e.json||Object.keys(e.json).length===0)throw new Error("Empty JSON passed to parseMessage");if(!e.job||Object.keys(e.job).length===0)throw new Error("Empty job passed to parseMessage");if(hK.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(hK.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Ar.JOB_TYPE_ENUM.csv_file_load:await zi(e,oT.csvFileLoad);break;case Ar.JOB_TYPE_ENUM.csv_url_load:await zi(e,oT.csvURLLoad);break;case Ar.JOB_TYPE_ENUM.csv_data_load:await zi(e,oT.csvDataLoad);break;case Ar.JOB_TYPE_ENUM.import_from_s3:await zi(e,oT.importFromS3);break;case Ar.JOB_TYPE_ENUM.empty_trash:break;case Ar.JOB_TYPE_ENUM.export_local:await zi(e,EK.export_local);break;case Ar.JOB_TYPE_ENUM.export_to_s3:await zi(e,EK.export_to_s3);break;case Ar.JOB_TYPE_ENUM.delete_files_before:case Ar.JOB_TYPE_ENUM.delete_records_before:await zi(e,gK.deleteFilesBefore);break;case Ar.JOB_TYPE_ENUM.delete_audit_logs_before:await zi(e,gK.deleteAuditLogsBefore);break;case Ar.JOB_TYPE_ENUM.delete_transaction_logs_before:await zi(e,phe.deleteTransactionLogsBefore);break;case Ar.JOB_TYPE_ENUM.restart_service:return await zi(e,hhe.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(ghe,"parseMessage");async function zi(e,t){try{e.job.status=Ar.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=_he().valueOf(),await mK.updateJob(e.job),await She(e.job.id)}catch(r){let n=r.message!==void 0?r.message:r;typeof n=="string"?(n=`There was an error running ${t.name} job with id ${e.job.id} - ${n}`,r.message=n):sh.error(`There was an error running ${t.name} job with id ${e.job.id}`),sh.error(n),e.job.message=n,e.job.status=Ar.JOB_STATUS_ENUM.ERROR;try{await mK.updateJob(e.job)}catch(s){throw sh.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(zi,"runJob");async function She(e){sh.trace("launching job thread:",e),TK?SK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):mhe.postMessage({type:Ar.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(She,"launchJobThread");TK&&Ehe(Ar.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{SK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){sh.error(r)}});AK.exports={parseMessage:ghe,RunnerMessage:LI}});var bK=w((wve,yK)=>{"use strict";var MI=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};yK.exports=MI});var Yw=w((Pve,kI)=>{"use strict";var dT=Yr(),xI=WS(),aT=bI(),$o=Vg(),cT=Ao(),oh=Vc(),The=RN(),ih=An(),lT=q_(),Ct=Kw(),uT=z(),Ahe=wN(),Rhe=Ed(),OK=XN(),yhe=nS(),bhe=tw(),Ohe=rw(),Nhe=aS(),whe=lS(),vI=uS(),NK=II(),Ihe=KS(),BI=DI(),V=(H(),C(q)),{hdb_errors:ch,handleHDBError:ah}=pe(),{HTTP_STATUS_CODES:wK}=ch,UI=hS(),IK=za(),HK=require("util"),Gd=Rn(),Che=ys(),Phe=Do(),CK=RK(),PK=(zu(),C(ep)),DK=(MS(),C(Gp)),LK=yt(),MK=GS(),vK=Kp(),{setServerUtilities:Dhe}=(Gf(),C(OI)),{CONTEXT:Cve}=(ga(),C(mR)),{_assignPackageExport:Lhe}=Ri(),{transformReq:Mhe}=se(),{server:vhe}=(Vr(),C(Tu)),nn=uT.loggerWithTag("operation"),Fd=ts(),UK=(Tl(),C(Sl)),Uhe=pI(),xK=dT.searchByHash,xhe=dT.searchByValue,Bhe=HK.promisify(dT.search),Hhe=HK.promisify(xI.evaluateSQL),khe={[V.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[V.OPERATIONS_ENUM.CREATE_TABLE]:!0,[V.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[V.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[V.OPERATIONS_ENUM.DROP_TABLE]:!0,[V.OPERATIONS_ENUM.DROP_SCHEMA]:!0},Z=bK();async function kK(e,t){try{if(e.body.operation!=="read_log"&&(uT.log_level===V.LOG_LEVELS.INFO||uT.log_level===V.LOG_LEVELS.DEBUG||uT.log_level===V.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;nn.info(c)}}catch(n){nn.error(n)}let r=await Uhe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return khe[e.body.operation]&&Che.setSchemaDataToGlobal(n=>{n&&nn.error(n)}),r}a(kK,"processLocalTransaction");var BK=Ghe();kI.exports={chooseOperation:FK,getOperationFunction:GK,operation:HI,processLocalTransaction:kK,executeJob:Us};Dhe(kI.exports);vhe.operation=HI;function FK(e){let t;try{t=GK(e)}catch(s){throw nn.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=xI.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=xI.checkASTPermissions(e,i);if(o)throw nn.error(`${wK.FORBIDDEN} from operation ${e.operation}`),nn.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==V.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==V.OPERATIONS_ENUM.LOGIN&&e.operation!==V.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=Ihe.verifyPerms(i,s);if(o)throw nn.error(`${wK.FORBIDDEN} from operation ${e.operation}`),nn.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw ah(s,"There was an error when trying to choose an operation path")}return r}a(FK,"chooseOperation");function GK(e){if(nn.trace(`getOperationFunction with operation: ${e.operation}`),BK.has(e.operation))return BK.get(e.operation);throw ah(new Error,ch.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),ch.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(GK,"getOperationFunction");Lhe("operation",HI);function HI(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=FK(e);return kK({body:e},n)}a(HI,"operation");async function Fhe(e){nn.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[V.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case V.OPERATIONS_ENUM.INSERT:o=await Gd.insert(i);break;case V.OPERATIONS_ENUM.UPDATE:o=await Gd.update(i);break;case V.OPERATIONS_ENUM.UPSERT:o=await Gd.upsert(i);break;case V.OPERATIONS_ENUM.DELETE:o=await oh.deleteRecord(i);break;default:nn.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){nn.info("Invalid operation in transaction"),nn.error(o)}}a(Fhe,"catchup");async function Us(e){Mhe(e);let t,r;try{r=await BI.addJob(e),t=r.createdJob,nn.info("addJob result",r);let n=new CK.RunnerMessage(t,e);return{message:await CK.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw nn.error(s),ah(n,s)}}a(Us,"executeJob");function Ghe(){let e=new Map;return e.set(V.OPERATIONS_ENUM.INSERT,new Z(Gd.insert)),e.set(V.OPERATIONS_ENUM.UPDATE,new Z(Gd.update)),e.set(V.OPERATIONS_ENUM.UPSERT,new Z(Gd.upsert)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new Z(dT.searchByConditions)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_HASH,new Z(xK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_ID,new Z(xK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_VALUE,new Z(xhe)),e.set(V.OPERATIONS_ENUM.SEARCH,new Z(Bhe)),e.set(V.OPERATIONS_ENUM.SQL,new Z(Hhe)),e.set(V.OPERATIONS_ENUM.CSV_DATA_LOAD,new Z(Us,aT.csvDataLoad)),e.set(V.OPERATIONS_ENUM.CSV_FILE_LOAD,new Z(Us,aT.csvFileLoad)),e.set(V.OPERATIONS_ENUM.CSV_URL_LOAD,new Z(Us,aT.csvURLLoad)),e.set(V.OPERATIONS_ENUM.IMPORT_FROM_S3,new Z(Us,aT.importFromS3)),e.set(V.OPERATIONS_ENUM.CREATE_SCHEMA,new Z($o.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_DATABASE,new Z($o.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_TABLE,new Z($o.createTable)),e.set(V.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new Z($o.createAttribute)),e.set(V.OPERATIONS_ENUM.DROP_SCHEMA,new Z($o.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_DATABASE,new Z($o.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_TABLE,new Z($o.dropTable)),e.set(V.OPERATIONS_ENUM.DROP_ATTRIBUTE,new Z($o.dropAttribute)),e.set(V.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new Z(cT.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_DATABASE,new Z(cT.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_TABLE,new Z(cT.describeTable)),e.set(V.OPERATIONS_ENUM.DESCRIBE_ALL,new Z(cT.describeAll)),e.set(V.OPERATIONS_ENUM.DELETE,new Z(oh.deleteRecord)),e.set(V.OPERATIONS_ENUM.ADD_USER,new Z(ih.addUser)),e.set(V.OPERATIONS_ENUM.ALTER_USER,new Z(ih.alterUser)),e.set(V.OPERATIONS_ENUM.DROP_USER,new Z(ih.dropUser)),e.set(V.OPERATIONS_ENUM.LIST_USERS,new Z(ih.listUsersExternal)),e.set(V.OPERATIONS_ENUM.LIST_ROLES,new Z(lT.listRoles)),e.set(V.OPERATIONS_ENUM.ADD_ROLE,new Z(lT.addRole)),e.set(V.OPERATIONS_ENUM.ALTER_ROLE,new Z(lT.alterRole)),e.set(V.OPERATIONS_ENUM.DROP_ROLE,new Z(lT.dropRole)),e.set(V.OPERATIONS_ENUM.USER_INFO,new Z(ih.userInfo)),e.set(V.OPERATIONS_ENUM.READ_LOG,new Z(Ahe)),e.set(V.OPERATIONS_ENUM.ADD_NODE,new Z(Rhe)),e.set(V.OPERATIONS_ENUM.UPDATE_NODE,new Z(OK)),e.set(V.OPERATIONS_ENUM.SET_NODE_REPLICATION,new Z(OK)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE,new Z(yhe)),e.set(V.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new Z(bhe)),e.set(V.OPERATIONS_ENUM.PURGE_STREAM,new Z(Ohe)),e.set(V.OPERATIONS_ENUM.SET_CONFIGURATION,new Z(LK.setConfiguration)),e.set(V.OPERATIONS_ENUM.CLUSTER_STATUS,new Z(Nhe.clusterStatus)),e.set(V.OPERATIONS_ENUM.CLUSTER_NETWORK,new Z(whe)),e.set(V.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new Z(vI.setRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new Z(vI.getRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new Z(vI.deleteRoutes)),e.set(V.OPERATIONS_ENUM.EXPORT_TO_S3,new Z(Us,NK.export_to_s3)),e.set(V.OPERATIONS_ENUM.CREATE_CSR,new Z(Fd.createCsr)),e.set(V.OPERATIONS_ENUM.SIGN_CERTIFICATE,new Z(Fd.signCertificate)),e.set(V.OPERATIONS_ENUM.LIST_CERTIFICATES,new Z(Fd.listCertificates)),e.set(V.OPERATIONS_ENUM.ADD_CERTIFICATES,new Z(Fd.addCertificate)),e.set(V.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new Z(Fd.removeCertificate)),e.set(V.OPERATIONS_ENUM.GET_KEY,new Z(Fd.getKey)),e.set(V.OPERATIONS_ENUM.ADD_NODE_BACK,new Z(UK.addNodeBack)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE_BACK,new Z(UK.removeNodeBack)),e.set(V.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new Z(Us,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new Z(Us,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.EXPORT_LOCAL,new Z(Us,NK.export_local)),e.set(V.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new Z(BI.handleGetJobsByStartDate)),e.set(V.OPERATIONS_ENUM.GET_JOB,new Z(BI.handleGetJob)),e.set(V.OPERATIONS_ENUM.GET_FINGERPRINT,new Z(UI.getFingerprint)),e.set(V.OPERATIONS_ENUM.SET_LICENSE,new Z(UI.setLicense)),e.set(V.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new Z(UI.getRegistrationInfo)),e.set(V.OPERATIONS_ENUM.RESTART,new Z(IK.restart)),e.set(V.OPERATIONS_ENUM.RESTART_SERVICE,new Z(Us,IK.restartService)),e.set(V.OPERATIONS_ENUM.CATCHUP,new Z(Fhe)),e.set(V.OPERATIONS_ENUM.SYSTEM_INFORMATION,new Z(Phe.systemInformation)),e.set(V.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new Z(Us,oh.deleteAuditLogsBefore)),e.set(V.OPERATIONS_ENUM.READ_AUDIT_LOG,new Z(The)),e.set(V.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new Z(PK.createTokens)),e.set(V.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new Z(PK.refreshOperationToken)),e.set(V.OPERATIONS_ENUM.LOGIN,new Z(DK.login)),e.set(V.OPERATIONS_ENUM.LOGOUT,new Z(DK.logout)),e.set(V.OPERATIONS_ENUM.GET_CONFIGURATION,new Z(LK.getConfiguration)),e.set(V.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new Z(Ct.customFunctionsStatus)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new Z(Ct.getCustomFunctions)),e.set(V.OPERATIONS_ENUM.GET_COMPONENT_FILE,new Z(Ct.getComponentFile)),e.set(V.OPERATIONS_ENUM.GET_COMPONENTS,new Z(Ct.getComponents)),e.set(V.OPERATIONS_ENUM.SET_COMPONENT_FILE,new Z(Ct.setComponentFile)),e.set(V.OPERATIONS_ENUM.DROP_COMPONENT,new Z(Ct.dropComponent)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new Z(Ct.getCustomFunction)),e.set(V.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new Z(Ct.setCustomFunction)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new Z(Ct.dropCustomFunction)),e.set(V.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new Z(Ct.addComponent)),e.set(V.OPERATIONS_ENUM.ADD_COMPONENT,new Z(Ct.addComponent)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new Z(Ct.dropCustomFunctionProject)),e.set(V.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new Z(Ct.packageComponent)),e.set(V.OPERATIONS_ENUM.PACKAGE_COMPONENT,new Z(Ct.packageComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new Z(Ct.deployComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_COMPONENT,new Z(Ct.deployComponent)),e.set(V.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new Z(MK.readTransactionLog)),e.set(V.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new Z(Us,MK.deleteTransactionLogsBefore)),e.set(V.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new Z(vK.installModules)),e.set(V.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new Z(vK.auditModules)),e.set(V.OPERATIONS_ENUM.GET_BACKUP,new Z($o.getBackup)),e.set(V.OPERATIONS_ENUM.ADD_SSH_KEY,new Z(Ct.addSSHKey)),e.set(V.OPERATIONS_ENUM.UPDATE_SSH_KEY,new Z(Ct.updateSSHKey)),e.set(V.OPERATIONS_ENUM.DELETE_SSH_KEY,new Z(Ct.deleteSSHKey)),e.set(V.OPERATIONS_ENUM.LIST_SSH_KEYS,new Z(Ct.listSSHKeys)),e.set(V.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new Z(Ct.setSSHKnownHosts)),e.set(V.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new Z(Ct.getSSHKnownHosts)),e}a(Ghe,"initializeOperationFunctionMap")});var pT=w((Lve,VK)=>{"use strict";var fT=(H(),C(q)),qhe=se(),lh=z(),{handleHDBError:FI,hdb_errors:_T}=pe(),{isMainThread:$he}=require("worker_threads"),{Readable:Vhe}=require("stream"),qK=require("os"),Khe=require("util"),Yhe=OO(),Whe=Khe.promisify(Yhe.authorize),$K=Yw(),{createGzip:zhe,constants:jhe}=require("zlib"),Qhe=[fT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,fT.OPERATIONS_ENUM.LOGIN,fT.OPERATIONS_ENUM.LOGOUT];function Jhe(e){let t=`Found an uncaught exception with message: ${e.message}. ${qK.EOL}Stack: ${e.stack} ${qK.EOL}Terminating ${$he?"HDB":"thread"}.`;console.error(t),lh.fatal(t),process.exit(1)}a(Jhe,"handleServerUncaughtException");function Xhe(e,t,r){if(lh[e.logLevel||"error"](e),e.statusCode)return typeof e.http_resp_msg!="object"?r.code(e.statusCode).send({error:e.http_resp_msg||e.message}):r.code(e.statusCode).send(e.http_resp_msg);let n=e.statusCode?e.statusCode:_T.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR;return typeof e=="string"?r.code(n).send({error:e}):r.code(n).send(e.message?{error:e.message}:e)}a(Xhe,"serverErrorHandler");function Zhe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=FI(new Error,"Invalid JSON.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(qhe.isEmpty(e.body.operation)){let n=FI(new Error,"Request body must include an 'operation' property.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Zhe,"reqBodyValidationHandler");function eme(e,t,r){let n;!Qhe.includes(e.body.operation)||e.body.operation===fT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&!e.body.username&&!e.body.password?Whe(e,t).then(i=>{n=i,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(i=>{lh.warn(i),lh.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${i.stack}"`);let o=typeof i=="string"?{error:i}:{error:i.message};r(FI(i,o,_T.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.hdb_auth_header=e.headers.authorization,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(eme,"authHandler");async function tme(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=$K.chooseOperation(e.body);let s=await $K.processLocalTransaction(e,n);if(s instanceof Vhe&&s.headers){for(let[i,o]of s.headers)t.header(i,o);e.headers["accept-encoding"]?.includes("gzip")&&(t.header("content-encoding","gzip"),s=s.pipe(zhe({level:jhe.Z_BEST_SPEED})))}return s}catch(s){throw lh.error(s),s}}a(tme,"handlePostRequest");VK.exports={authHandler:eme,handlePostRequest:tme,handleServerUncaughtException:Jhe,serverErrorHandler:Xhe,reqBodyValidationHandler:Zhe}});var zK=w((vve,WK)=>{"use strict";var rme=require("fastify-plugin"),{handlePostRequest:KK,authHandler:nme,reqBodyValidationHandler:sme}=pT();async function ime(e){e.decorate("hdbCore",{preValidation:[sme,nme],request:a(t=>YK(KK(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>YK(KK(t,r,!0)),"requestWithoutAuthentication")})}a(ime,"hdbCore");async function YK(e){if(e=await e,e?.[Symbol.asyncIterator]&&!e[Symbol.iterator]){let t=[];for await(let r of e)t.push(r);return t}return e}a(YK,"convertAsyncIterators");WK.exports=rme(ime)});var QK=w((Bve,jK)=>{"use strict";var xve=require("fs"),hT=ae();hT.initSync();var{CONFIG_PARAMS:GI}=(H(),C(q)),ome=1024*1024*1024;function ame(e){let t=hT.get(GI.HTTP_TIMEOUT),r=hT.get(GI.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:ome,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:hT.get(GI.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(ame,"getServerOptions");jK.exports=ame});var ZK=w((kve,XK)=>{"use strict";var qI=ae();qI.initSync();var{CONFIG_PARAMS:JK}=(H(),C(q));function cme(){let e=qI.get(JK.HTTP_CORSACCESSLIST),t=qI.get(JK.HTTP_CORS),r;return t&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},e&&e.length>0&&e[0]!==null&&e[0]!=="*"&&(r.origin=(n,s)=>s(null,e.indexOf(n)!==-1))),r}a(cme,"getCORSOptions");XK.exports=cme});var rY=w((Gve,tY)=>{"use strict";var eY=ae();eY.initSync();var lme=(H(),C(q));function ume(){return eY.get(lme.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(ume,"getHeaderTimeoutConfig");tY.exports=ume});var VI={};ve(VI,{customFunctionsServer:()=>_me,ready:()=>mY,start:()=>fme});function fme(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Vo||(Vo=hY(t),Ye.http((await Vo).server));let o=await Vo,c=(0,$I.dirname)(s),l=(0,$I.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!nY.has(c)){nY.add(c);try{o.register(hme(c,l))}catch(u){if(u.message==="Root plugin has already booted")ht.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:mY}}async function _me(){try{ht.info("In Custom Functions Fastify server"+process.cwd()),ht.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ht.debug(`Custom Functions server process ${process.pid} starting up.`),await pme();let e=lY.get(B.HTTP_SECUREPORT)>0,t;try{t=Vo=await hY(e)}catch(r){throw ht.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw ht.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){ht.error(`Custom Functions ${process.pid} Error: ${e}`),ht.error(e),process.exit(1)}}async function pme(){try{ht.info("Custom Functions starting configuration."),await uY.setUsersWithRolesCache(),ht.info("Custom Functions completed configuration.")}catch(e){ht.error(e)}}function hme(e,t){return async function(r){try{ht.info("Custom Functions starting buildRoutes"),ht.trace("Loading fastify routes folder "+e),(0,sY.existsSync)(e)&&r.register(cY.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:ht.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?ht.error(s.message):s&&ht.error(s),o()})}catch(n){ht.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function hY(e){ht.info("Custom Functions starting buildServer.");let t=(0,dY.default)(e),r=(0,iY.default)(t);r.server.headersTimeout=(0,_Y.default)(),r.setErrorHandler(pY.serverErrorHandler);let n=(0,fY.default)();return n&&r.register(oY.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(aY.default),await r.register(dme),await r.after(),jf(r),ht.info("Custom Functions completed buildServer."),r}function mY(){if(Vo)return Vo.then?Vo.then(e=>e.ready()):Vo.ready()}var $I,sY,iY,oY,aY,cY,lY,ht,dme,uY,dY,fY,_Y,pY,Vo,nY,EY=be(()=>{$I=require("path"),sY=require("fs"),iY=M(require("fastify")),oY=M(require("@fastify/cors")),aY=M(TO()),cY=M(require("@fastify/autoload")),lY=M(ae());H();ht=M(z()),dme=M(zK()),uY=M(An()),dY=M(QK()),fY=M(ZK()),_Y=M(rY()),pY=M(pT());uo();Vr();nY=new Set;a(fme,"start");a(_me,"customFunctionsServer");a(pme,"setUp");a(hme,"buildRouteFolder");a(hY,"buildServer");a(mY,"ready")});var KI={};ve(KI,{start:()=>mme});function mme(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,RY.default)(r,e);return e.server.http(async(s,i)=>{if(!s.isWebSocket)return new Promise(o=>n(s._nodeRequest,s._nodeResponse,()=>{o(i(s))}))}),!0}},handleFile(t,r,n){SY||(SY=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=gY.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,TY.default)(s,(0,AY.realpathSync)(o))}}return i(s)},{runFirst:!0})),gY.set(r,n)}}}var TY,AY,RY,gY,SY,yY=be(()=>{TY=M(require("send")),AY=require("fs"),RY=M(require("serve-static")),gY=new Map;a(mme,"start")});var YI={};ve(YI,{start:()=>Eme});function Eme({override:e}){return{handleFile:a((t,r,n)=>{mT.default.debug(`Loading env file: ${n}`);for(let[s,i]of Object.entries((0,bY.parse)(t))){if(process.env[s]!==void 0)if(mT.default.warn(`Environment variable conflict: ${s} from ${n} is already set on process.env`),e)mT.default.debug(`override option enabled. overriding environment variable: ${s}`);else continue;process.env[s]=i}},"handleFile")}}var bY,mT,OY=be(()=>{bY=require("dotenv"),mT=M(z());a(Eme,"start")});var wY={};ve(wY,{Request:()=>WI,createReuseportFd:()=>ET});var NY,WI,zI,jI,ET,QI=be(()=>{NY=require("os"),WI=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new jI(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new zI(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},zI=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},jI=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,NY.platform)()!="win32"&&(ET=require("node-unix-socket").createReuseportFd)});var XI=w((Qve,IY)=>{"use strict";var uh=ae();uh.initSync();var qd=require("fs-extra"),JI=require("path"),$d=(H(),C(q)),gme=require("crypto"),Sme=require("uuid").v4;IY.exports=Tme;function Tme(){if(uh.getHdbBasePath()!==void 0){let e=JI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=JI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=JI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PASSPHRASE_NAME);try{qd.accessSync(r),qd.accessSync(e),qd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=Sme(),i=gme.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});qd.writeFileSync(r,s),qd.writeFileSync(e,i.privateKey),qd.writeFileSync(t,i.publicKey)}else throw n}}}a(Tme,"checkJWTTokenExist")});var PY=w((Xve,CY)=>{"use strict";var ZI=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};CY.exports={HdbInfoInsertObject:ZI}});var MY=w((eUe,LY)=>{"use strict";var DY=(H(),C(q)),eC=class{static{a(this,"UpgradeObject")}constructor(t,r){this[DY.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[DY.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};LY.exports={UpgradeObject:eC}});var gT=w((rUe,UY)=>{"use strict";var xs=require("prompt"),Vd=require("chalk"),vY=z(),Ei=require("os"),tC=da(),rC=["yes","y"];async function Ame(e){let t=`${Ei.EOL}`+Vd.bold.green("Your current HarperDB version requires that we complete an update process.")+`${Ei.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${Ei.EOL}${Ei.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${Ei.EOL}`;xs.override=tC(["CONFIRM_UPGRADE"]),xs.start(),xs.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Vd.magenta(`${Ei.EOL}[CONFIRM_UPGRADE] Do you want to upgrade your HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n;try{n=await xs.get([r])}catch(s){return vY.error("There was an error when prompting user about an upgrade."),vY.error(s),!1}return rC.includes(n.CONFIRM_UPGRADE)}a(Ame,"forceUpdatePrompt");async function Rme(e){let t=`${Ei.EOL}`+Vd.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${Ei.EOL}`);xs.override=tC(["CONFIRM_DOWNGRADE"]),xs.start(),xs.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Vd.magenta(`${Ei.EOL}[CONFIRM_DOWNGRADE] Do you want to proceed with using your downgraded HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n=await xs.get([r]);return rC.includes(n.CONFIRM_DOWNGRADE)}a(Rme,"forceDowngradePrompt");async function yme(){let e=`${Ei.EOL}`+Vd.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");xs.override=tC(["GENERATE_CERTS"]),xs.start(),xs.message=e;let t={properties:{GENERATE_CERTS:{description:Vd.magenta(`${Ei.EOL}[GENERATE_CERTS] Do you want HarperDB to generate all new certificates? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"yes",required:!0}}},r=await xs.get([t]);return rC.includes(r.GENERATE_CERTS)}a(yme,"upgradeCertsPrompt");UY.exports={forceUpdatePrompt:Ame,forceDowngradePrompt:Rme,upgradeCertsPrompt:yme}});var sC=w((sUe,xY)=>{"use strict";var nC=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};xY.exports=nC});var HY=w((uUe,BY)=>{"use strict";var bme=se(),Ome=yt(),oUe=z(),aUe=require("path"),cUe=require("fs"),lUe=(H(),C(q));BY.exports={getOldPropsValue:Nme};function Nme(e,t,r=!1){let n=t.getRaw(e);return bme.isNotEmptyAndHasValue(n)?n:r?Ome.getDefaultConfig(e):""}a(Nme,"getOldPropsValue")});var qY=w((fUe,GY)=>{"use strict";var Za=require("path"),ec=require("fs-extra"),wme=require("properties-reader"),Ime=sC(),_r=z(),{getOldPropsValue:mt}=HY(),{HDB_SETTINGS_NAMES:ge,CONFIG_PARAMS:Hl}=(H(),C(q)),kl=yt(),ST=ae(),kY=se(),ji=(H(),C(q)),iC=new Ime("3.1.0"),FY=[];function Cme(){let e=wme(ST.get(ge.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),_r.info(t);let r=` ;Settings for the HarperDB process.
|
|
37
|
+
`+u):await Oe.outputFile(l,u);let f="";if(await Oe.pathExists(ko)||(await Oe.writeFile(ko,""),await Oe.chmod(ko,"0600")),i=="github.com"&&!(await Oe.readFile(ko,"utf8")).includes("github.com"))try{let S=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let g of S)Oe.appendFile(ko,"github.com "+g+`
|
|
38
|
+
`)}catch{f=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Oe.appendFile(ko,o);let d=await fi(e);return d.message=`Added ssh key: ${r}${f}`,d}a(Ffe,"addSSHKey");async function Gfe(e){let t=Cn.updateSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r,key:n}=e;Bt.trace("updating ssh key",r);let s=we.join(Qa,r+".key");if(!await Oe.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Oe.outputFile(s,n);let i=await fi(e);return i.message=`Updated ssh key: ${r}`,i}a(Gfe,"updateSSHKey");async function qfe(e){let t=Cn.deleteSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r}=e;Bt.trace("deleting ssh key",r);let n=we.join(Qa,r+".key"),s=we.join(Qa,"config");if(!await Oe.pathExists(n))throw new Error("Key does not exist");let i=await Oe.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Oe.outputFile(s,i),Oe.removeSync(n);let c=await fi(e);return c.message=`Deleted ssh key: ${r}`,c}a(qfe,"deleteSSHKey");async function $fe(e){let t=[];return await Oe.pathExists(Qa)&&(await Oe.readdir(Qa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a($fe,"listSSHKeys");async function Vfe(e){let t=Cn.setSSHKnownHostsValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{known_hosts:r}=e;await Oe.outputFile(ko,r);let n=await fi(e);return n.message="Known hosts successfully set",n}a(Vfe,"setSSHKnownHosts");async function Kfe(e){return await Oe.pathExists(ko)?{known_hosts:await Oe.readFile(ko,"utf8")}:{known_hosts:null}}a(Kfe,"getSSHKnownHosts");Object.assign(xV,{customFunctionsStatus:Nfe,getCustomFunctions:wfe,getCustomFunction:Ife,setCustomFunction:Cfe,dropCustomFunction:Pfe,addComponent:Dfe,dropCustomFunctionProject:Lfe,packageComponent:Mfe,deployComponent:vfe,getComponents:xfe,getComponentFile:Bfe,setComponentFile:Hfe,dropComponent:kfe,addSSHKey:Ffe,updateSSHKey:Gfe,deleteSSHKey:qfe,listSSHKeys:$fe,setSSHKnownHosts:Vfe,getSSHKnownHosts:Kfe})});var Jw=w((xMe,HV)=>{"use strict";var Ps=require("joi"),BV=ot();HV.exports={readTransactionLogValidator:Yfe,deleteTransactionLogsBeforeValidator:Wfe};function Yfe(e){let t=Ps.object({schema:Ps.string(),database:Ps.string(),table:Ps.string().required(),from:Ps.date().timestamp(),to:Ps.date().timestamp(),limit:Ps.number().min(1)});return BV.validateBySchema(e,t)}a(Yfe,"readTransactionLogValidator");function Wfe(e){let t=Ps.object({schema:Ps.string(),database:Ps.string(),table:Ps.string().required(),timestamp:Ps.date().timestamp().required()});return BV.validateBySchema(e,t)}a(Wfe,"deleteTransactionLogsBeforeValidator")});var qS=w((HMe,VV)=>{"use strict";var Qw=(H(),C(G)),Jp=ir(),kV=ie(),FV=ae(),GV=Eo(),qV=z(),{handleHDBError:FS,hdb_errors:zfe}=pe(),{HTTP_STATUS_CODES:GS}=zfe,{readTransactionLogValidator:jfe,deleteTransactionLogsBeforeValidator:Jfe}=Jw(),$V=Vn(),Qfe="Logs successfully deleted from transaction log.",Xfe="All logs successfully deleted from transaction log.";VV.exports={readTransactionLog:Zfe,deleteTransactionLogsBefore:t_e};async function Zfe(e){let t=jfe(e);if(t)throw FS(t,t.message,GS.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=kV.checkSchemaTableExist(e.database,e.table);if(r)throw FS(new Error,r,GS.NOT_FOUND,void 0,void 0,!0);return FV.get(Qw.CONFIG_PARAMS.CLUSTERING_ENABLED)?await e_e(e):(qV.info("Reading HarperDB logs used by Plexus"),(e.from||e.to)&&(e.search_type="timestamp",e.search_values=[e.from??0],e.to&&(e.search_values[1]=e.to)),$V.readAuditLog(e))}a(Zfe,"readTransactionLog");async function*e_e(e){let t=GV.createNatsTableStreamName(e.database,e.table),r=await Jp.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===Qw.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(e_e,"readTransactionLogNats");async function t_e(e){let t=Jfe(e);if(t)throw FS(t,t.message,GS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!FV.get(Qw.CONFIG_PARAMS.CLUSTERING_ENABLED))return qV.info("Delete transaction logs called for Plexus"),$V.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=kV.checkSchemaTableExist(r,n);if(i)throw FS(new Error,i,GS.NOT_FOUND,void 0,void 0,!0);let o=GV.createNatsTableStreamName(r,n),{jsm:c}=await Jp.getNATSReferences(),l=await Jp.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let f=Qfe,d,p=new Date(l.state.last_ts).getTime();return s>p?(d=l.state.last_seq+1,f=Xfe):d=(await Jp.viewStream(o,parseInt(s),1))[0].nats_sequence,await Jp.purgeTableStream(r,n,{seq:d}),f}a(t_e,"deleteTransactionLogsBefore")});var YV=w((FMe,KV)=>{"use strict";var Xw=class{static{a(this,"PermissionTableResponseObject")}constructor(t,r,n=[],s=[]){this.schema=t,this.table=r,this.required_table_permissions=n,this.required_attribute_permissions=s}};KV.exports=Xw});var zV=w((qMe,WV)=>{"use strict";var Zw=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};WV.exports=Zw});var tI=w((VMe,JV)=>{"use strict";var jV=YV(),r_e=zV(),{HDB_ERROR_MSGS:n_e}=xn(),eI=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=n_e.OP_AUTH_PERMS_ERROR,this.unauthorized_access={},this.invalid_schema_items=[]}handleUnauthorizedItem(t){return this.invalid_schema_items=[],this.unauthorized_access=[t],this}handleInvalidItem(t){return this.invalid_schema_items=[t],this.unauthorized_access=[],this}addInvalidItem(t,r,n){if(r&&n){let s=`${r}_${n}`;if(this.unauthorized_access[s])return}this.invalid_schema_items.push(t)}addUnauthorizedTable(t,r,n){let s=new jV(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new r_e(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new jV(r,n,[],i);this.unauthorized_access[o]=c}}getPermsResponse(){let t=Object.values(this.unauthorized_access);return t.length>0||this.invalid_schema_items.length>0?(this.unauthorized_access=t,this):null}};JV.exports=eI});var YS=w((zMe,_1)=>{"use strict";var rI=yn(),$S=Yr(),Ds=Kg(),Zp=go(),nI=zc(),s_e=ON(),i_e=fG(),eh=Rn(),VS=F_(),Tr=z(),o_e=PN(),a_e=Sd(),c_e=tw(),l_e=sS(),u_e=sw(),d_e=iw(),f_e=cS(),__e=uS(),sI=dS(),Fo=ie(),p_e=Vq(),iI=mS(),ZV=za(),rn=(H(),C(G)),e1=sV(),h_e=Po(),t1=(Ju(),C(X_)),r1=(vS(),C(Gp)),n1=yt(),ur=zw(),m_e=require("alasql"),s1=qS(),i1=Kp(),Bd=Zn(),o1=(bl(),C(yl)),a1=tI(),{handleHDBError:Pn,hdb_errors:c1}=pe(),{addNodeBack:YMe,removeNodeBack:WMe}=(bl(),C(yl)),{HDB_ERROR_MSGS:xr,HTTP_STATUS_CODES:Qp}=c1,X=new Map,l1="delete",Xa="insert",Go="read",xl="update",Xp="describe",QV=Zp.describeSchema.name,XV=Zp.describeTable.name,u1={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},E_e={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},g_e="catchup",S_e="handleGetJob",T_e="handleGetJobsByStartDate",KS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},A_e=[Ds.createTable.name,Ds.createAttribute.name,Ds.dropTable.name,Ds.dropAttribute.name],d1={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},re=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};X.set(rI.insert.name,new re(!1,[Xa]));X.set(rI.update.name,new re(!1,[xl]));X.set(rI.upsert.name,new re(!1,[Xa,xl]));X.set($S.searchByConditions.name,new re(!1,[Go]));X.set($S.searchByHash.name,new re(!1,[Go]));X.set($S.searchByValue.name,new re(!1,[Go]));X.set($S.search.name,new re(!1,[Go]));X.set(Ds.createSchema.name,new re(!0,[]));X.set(Ds.createTable.name,new re(!0,[]));X.set(Ds.createAttribute.name,new re(!1,[Xa]));X.set(Ds.dropSchema.name,new re(!0,[]));X.set(Ds.dropTable.name,new re(!0,[]));X.set(Ds.dropAttribute.name,new re(!0,[]));X.set(Zp.describeSchema.name,new re(!1,[Go]));X.set(Zp.describeTable.name,new re(!1,[Go]));X.set(nI.deleteRecord.name,new re(!1,[l1]));X.set(eh.addUser.name,new re(!0,[]));X.set(eh.alterUser.name,new re(!0,[]));X.set(eh.dropUser.name,new re(!0,[]));X.set(eh.listUsersExternal.name,new re(!0,[]));X.set(VS.listRoles.name,new re(!0,[]));X.set(VS.addRole.name,new re(!0,[]));X.set(VS.alterRole.name,new re(!0,[]));X.set(VS.dropRole.name,new re(!0,[]));X.set(o_e.name,new re(!0,[]));X.set(a_e.name,new re(!0,[]));X.set(c_e.name,new re(!0,[]));X.set(l_e.name,new re(!0,[]));X.set(u_e.name,new re(!0,[]));X.set(d_e.name,new re(!0,[]));X.set(sI.setRoutes.name,new re(!0,[]));X.set(sI.getRoutes.name,new re(!0,[]));X.set(sI.deleteRoutes.name,new re(!0,[]));X.set(n1.setConfiguration.name,new re(!0,[]));X.set(f_e.clusterStatus.name,new re(!0,[]));X.set(__e.name,new re(!0,[]));X.set(iI.getFingerprint.name,new re(!0,[]));X.set(iI.setLicense.name,new re(!0,[]));X.set(nI.deleteFilesBefore.name,new re(!0,[]));X.set(nI.deleteAuditLogsBefore.name,new re(!0,[]));X.set(ZV.restart.name,new re(!0,[]));X.set(ZV.restartService.name,new re(!0,[]));X.set(s_e.name,new re(!0,[]));X.set(i_e.name,new re(!0,[Go]));X.set(h_e.systemInformation.name,new re(!0,[]));X.set(n1.getConfiguration.name,new re(!0,[]));X.set(s1.readTransactionLog.name,new re(!0,[]));X.set(s1.deleteTransactionLogsBefore.name,new re(!0,[]));X.set(i1.installModules.name,new re(!0,[]));X.set(i1.auditModules.name,new re(!0,[]));X.set(Bd.createCsr.name,new re(!0,[]));X.set(Bd.signCertificate.name,new re(!0,[]));X.set(Bd.listCertificates.name,new re(!0,[]));X.set(Bd.addCertificate.name,new re(!0,[]));X.set(Bd.removeCertificate.name,new re(!0,[]));X.set(Bd.getKey.name,new re(!0,[]));X.set(o1.addNodeBack.name,new re(!0,[]));X.set(o1.removeNodeBack.name,new re(!0,[]));X.set(t1.createTokens.name,new re(!1,[]));X.set(t1.refreshOperationToken.name,new re(!1,[]));X.set(r1.login.name,new re(!1,[]));X.set(r1.logout.name,new re(!1,[]));X.set(ur.customFunctionsStatus.name,new re(!0,[]));X.set(ur.getCustomFunctions.name,new re(!0,[]));X.set(ur.getComponents.name,new re(!0,[]));X.set(ur.getComponentFile.name,new re(!0,[]));X.set(ur.setComponentFile.name,new re(!0,[]));X.set(ur.dropComponent.name,new re(!0,[]));X.set(ur.getCustomFunction.name,new re(!0,[]));X.set(ur.setCustomFunction.name,new re(!0,[]));X.set(ur.dropCustomFunction.name,new re(!0,[]));X.set(ur.addComponent.name,new re(!0,[]));X.set(ur.dropCustomFunctionProject.name,new re(!0,[]));X.set(ur.packageComponent.name,new re(!0,[]));X.set(ur.deployComponent.name,new re(!0,[]));X.set(ur.addSSHKey.name,new re(!0,[]));X.set(ur.updateSSHKey.name,new re(!0,[]));X.set(ur.deleteSSHKey.name,new re(!0,[]));X.set(ur.listSSHKeys.name,new re(!0,[]));X.set(ur.setSSHKnownHosts.name,new re(!0,[]));X.set(ur.getSSHKnownHosts.name,new re(!0,[]));X.set(iI.getRegistrationInfo.name,new re(!1,[]));X.set(eh.userInfo.name,new re(!1,[]));X.set(Zp.describeAll.name,new re(!1,[]));X.set(S_e,new re(!1,[]));X.set(T_e,new re(!0,[]));X.set(g_e,new re(!0,[]));X.set(KS.CSV_DATA_LOAD,new re(!1,[Xa,xl]));X.set(KS.CSV_URL_LOAD,new re(!1,[Xa,xl]));X.set(KS.CSV_FILE_LOAD,new re(!1,[Xa,xl]));X.set(KS.IMPORT_FROM_S3,new re(!1,[Xa,xl]));X.set(d1.EXPORT_TO_S3,new re(!0,[]));X.set(d1.EXPORT_LOCAL,new re(!0,[]));X.set(rn.VALID_SQL_OPS_ENUM.DELETE,new re(!1,[l1]));X.set(rn.VALID_SQL_OPS_ENUM.SELECT,new re(!1,[Go]));X.set(rn.VALID_SQL_OPS_ENUM.INSERT,new re(!1,[Xa]));X.set(rn.VALID_SQL_OPS_ENUM.UPDATE,new re(!1,[xl]));_1.exports={verifyPerms:y_e,verifyPermsAst:R_e,verifyBulkLoadAttributePerms:O_e};function R_e(e,t,r){if(Fo.isEmptyOrZeroLength(e))throw Tr.info("verify_perms_ast has an empty user parameter"),Pn(new Error);if(Fo.isEmptyOrZeroLength(t))throw Tr.info("verify_perms_ast has an empty user parameter"),Pn(new Error);if(Fo.isEmptyOrZeroLength(r))throw Tr.info("verify_perms_ast has a null operation parameter"),Pn(new Error);try{let n=new a1,s=new p_e(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Tr.info("No schemas defined in verifyPermsAst(), will not continue."),Pn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&u1[r])throw Pn(new Error,xr.DROP_SYSTEM,Qp.FORBIDDEN);if(c&&!l)return null;let u=e1.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof m_e.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let d=0;d<i.length;d++){let p=s.getTablesBySchemaName(i[d]);p&&o.set(i[d],p)}let f=f1(t,r,o,n);return f||(o.forEach((d,p)=>{for(let _=0;_<d.length;_++){let h=s.getAttributesBySchemaTableName(p,d[_]),S=aI(t.role.permission,p,d[_]);oI(h,S,r,d[_],p,n)}}),n.getPermsResponse())}catch(n){throw Pn(n)}}a(R_e,"verifyPermsAst");function y_e(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Tr.info("null required parameter in verifyPerms"),Pn(new Error,xr.DEFAULT_INVALID_REQUEST,Qp.BAD_REQUEST);let r;t instanceof Function?r=t.name:r=t;let n=e.action,s=e.schema??e.database,i=e.table,o=new Map;s&&i&&o.set(s,[i]);let c=new a1;if(Fo.isEmptyOrZeroLength(e.hdb_user?.role)||Fo.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return Tr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(xr.USER_HAS_NO_PERMS(e.hdb_user?.username));let l=!!e.hdb_user?.role?.permission?.super_user,u=e.hdb_user?.role?.permission?.structure_user,f=o.has(rn.SYSTEM_SCHEMA_NAME)||s===rn.SYSTEM_SCHEMA_NAME;if(l&&f&&E_e[e.operation]&&(i===rn.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===rn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===rn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(f&&u1[r])throw Pn(new Error,xr.DROP_SYSTEM,Qp.FORBIDDEN);if(l&&!f||u===!0&&(r===Ds.createSchema.name||r===Ds.dropSchema.name))return null;if(A_e.indexOf(r)>=0&&(u===!0||Array.isArray(u)))return u===!0||u.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let d=e1.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=d),(r===QV||r===XV)&&!d.super_user){if(s===rn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(xr.SCHEMA_PERM_ERROR(s));if(r===QV&&(!d[s]||!d[s][Xp]))return c.handleInvalidItem(xr.SCHEMA_NOT_FOUND(s));if(r===XV&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Xp]))return c.handleInvalidItem(xr.TABLE_NOT_FOUND(s,i))}let p=f1(e.hdb_user,r,o,c,n);if(p)return p;if(X.get(r)&&X.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&rn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let S=[],g=d[s].tables[i];g[rn.PERMS_CRUD_ENUM.READ]&&(g.attribute_permissions.length>0?g.attribute_permissions.filter(E=>E[rn.PERMS_CRUD_ENUM.READ]).forEach(E=>{S.push(E.attribute_name)}):S=global.hdb_schema[s][i].attributes.map(R=>R.attribute),e.get_attributes=S)}let _=b_e(e),h=aI(e.hdb_user?.role?.permission,s,i);return oI(_,h,r,i,s,c,n),c.getPermsResponse()}a(y_e,"verifyPerms");function f1(e,t,r,n,s){if(Fo.arrayHasEmptyValues([e,t,r]))throw Tr.info("hasPermissions has an invalid parameter"),Pn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||X.get(t).requires_su))return null;if(!X.get(t))throw Tr.info(`operation ${t} not found.`),Pn(new Error,xr.OP_NOT_FOUND(t),Qp.BAD_REQUEST);if(X.get(t)&&X.get(t).requires_su)return Tr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(xr.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Xp]===!1){n.addInvalidItem(xr.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(xr.SCHEMA_NOT_FOUND(l));continue}let u=r.get(l);for(let f of u){let d=o[l].tables[f];if(!d||d[Xp]===!1)n.addInvalidItem(xr.TABLE_NOT_FOUND(l,f));else try{let p=[],_=X.get(t).perms;!Fo.isEmpty(s)&&_.includes(s)&&(_=[s]);for(let h=0;h<_.length;h++){let S=_[h],g=d[S];(g==null||g===!1)&&(Tr.info(`Required ${S} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),p.push(S))}p.length>0&&n.addUnauthorizedTable(l,f,p)}catch(p){let _=xr.UNKNOWN_OP_AUTH_ERROR(t,l,f);throw Tr.error(_),Tr.error(p),Pn(c1.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(f1,"hasPermissions");function oI(e,t,r,n,s,i,o){if(!e||!t)throw Tr.info("no attributes specified in checkAttributePerms."),Pn(new Error);let c=X.get(r).perms;if(!c||c==="")throw Tr.info(`no permissions found for ${r} in checkAttributePerms().`),Pn(new Error);if(Fo.isEmptyOrZeroLength(t))return Tr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let f of e){let d=t.get(f);if(d){if(d[Xp]===!1){i.addInvalidItem(xr.ATTR_NOT_FOUND(s,n,f),s,n);continue}if(c)for(let p of c){if(rn.TIME_STAMP_NAMES.includes(d.attribute_name)&&p!==Go)throw Pn(new Error,xr.SYSTEM_TIMESTAMP_PERMS_ERR,Qp.FORBIDDEN);d[p]===!1&&(l[d.attribute_name]?l[d.attribute_name].push(p):l[d.attribute_name]=[p])}}else i.addInvalidItem(xr.ATTR_NOT_FOUND(s,n,f),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(oI,"checkAttributePerms");function b_e(e){let t=new Set;try{if(e.action)return t;if(e.operation===rn.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){Tr.info(r)}return t}a(b_e,"getRecordAttributes");function aI(e,t,r){let n=new Map;if(Fo.isEmpty(e))return Tr.info("no hdb_user specified in getAttributePermissions"),n;if(e.super_user||!t||!r)return n;try{e[t].tables[r].attribute_permissions.forEach(s=>{n.has(s.attribute_name)||n.set(s.attribute_name,s)})}catch{Tr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(aI,"getAttributePermissions");function O_e(e,t,r,n,s,i,o){let c=new Set(i),l=aI(e,n,s);oI(c,l,t,s,n,o,r)}a(O_e,"verifyBulkLoadAttributePerms")});var zS=w((JMe,g1)=>{"use strict";g1.exports={evaluateSQL:H_e,processAST:E1,convertSQLToAST:m1,checkASTPermissions:h1};var N_e=yn(),p1=require("util"),w_e=p1.callbackify(N_e.insert),I_e=Yr().search,C_e=rk().update,P_e=p1.callbackify(C_e),D_e=sk().convertDelete,Za=require("alasql"),L_e=YS(),WS=z(),M_e=aE(),v_e=ie(),th=(H(),C(G)),{hdb_errors:U_e,handleHDBError:cI}=pe(),{HTTP_STATUS_CODES:lI}=U_e;M_e(Za);var x_e=403,B_e="There was a problem performing this insert. Please check the logs and try again.",uI=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function H_e(e,t){let r=e.parsed_sql_object;if(!r){r=m1(e.sql);let n,s=r.ast.statements[0];if(s instanceof Za.yy.Insert?n=s.into.databaseid:s instanceof Za.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Za.yy.Update||s instanceof Za.yy.Delete?n=s.table.databaseid:WS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Za.yy.Select)&&v_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}E1(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(H_e,"evaluateSQL");function h1(e,t){let r;try{r=L_e.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(h1,"checkASTPermissions");function m1(e){let t=new uI;if(!e)throw cI(new Error,"The 'sql' parameter is missing from the request body",lI.BAD_REQUEST);try{let r=e.trim(),n=Za.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
39
|
+
`);throw n[1]?cI(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,lI.BAD_REQUEST):cI(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",lI.BAD_REQUEST)}return t}a(m1,"convertSQLToAST");function E1(e,t,r){try{let n=k_e;if(!e.bypass_auth&&!t.permissions_checked){let i=h1(e,t);if(i&&i.length>0)return r(x_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case th.VALID_SQL_OPS_ENUM.SELECT:n=I_e,s=t.ast.statements[0];break;case th.VALID_SQL_OPS_ENUM.INSERT:n=F_e;break;case th.VALID_SQL_OPS_ENUM.UPDATE:n=P_e;break;case th.VALID_SQL_OPS_ENUM.DELETE:n=D_e;break;default:throw new Error(`unsupported SQL type ${t.variant} in SQL: ${e}`)}n(s,(i,o)=>{if(i){r(i);return}r(null,o)})}catch(n){return r(n)}}a(E1,"processAST");function k_e(e,t){WS.info(e),t("unknown sql statement")}a(k_e,"nullFunction");function F_e({statement:e,hdb_user:t},r){let n=e.into,s={schema:n.databaseid,table:n.tableid,operation:"insert",hdb_user:t},i=e.columns.map(o=>o.columnid);try{s.records=G_e(i,e.values)}catch(o){return r(o)}w_e(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){WS.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(F_e,"convertInsert");function G_e(e,t){try{return t.map(r=>{if(e.length!==r.length)throw"number of values do not match number of columns in insert";let n={};return r.forEach((s,i)=>{if(s.columnid)throw"cannot use a column in insert value";"value"in s?n[e[i]]=s.value:n[e[i]]=Za.compile(`SELECT ${s.toString()} AS [${th.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw WS.error(r),new Error(B_e)}}a(G_e,"createDataObjects")});var mI=w((eve,R1)=>{var XS=require("clone"),ZS=ot(),q_e=ie(),JS=(H(),C(G)),XMe=z(),dI=require("fs"),_I=require("joi"),{string:QS}=_I.types(),{hdb_errors:$_e,handleHDBError:jS}=pe(),{HDB_ERROR_MSGS:ZMe,HTTP_STATUS_CODES:fI}=$_e,{common_validators:Hd}=Di(),S1=" is required",V_e=["insert","update","upsert"],pI={database:{presence:!1,format:Hd.schema_format,length:Hd.schema_length},schema:{presence:!1,format:Hd.schema_format,length:Hd.schema_length},table:{presence:!0,format:Hd.schema_format,length:Hd.schema_length},action:{inclusion:{within:V_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},K_e={schema:QS.required(),table:QS.required(),action:QS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:Y_e,AWS_SECRET:W_e,AWS_BUCKET:z_e,AWS_FILE_KEY:j_e,REGION:J_e}=JS.S3_BUCKET_AUTH_KEYS,Q_e={s3:{presence:!0},[`s3.${Y_e}`]:{presence:!0,type:"String"},[`s3.${W_e}`]:{presence:!0,type:"String"},[`s3.${z_e}`]:{presence:!0,type:"String"},[`s3.${j_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${J_e}`]:{presence:!0,type:"String"}},T1=XS(pI);T1.data.presence={message:S1};var A1=XS(pI);A1.file_path.presence={message:S1};var X_e=Object.assign(XS(pI),Q_e),hI=XS(K_e);hI.csv_url=QS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();hI.passthrough_headers=_I.object();function Z_e(e){let t=ZS.validateObject(e,T1);return eT(e,t)}a(Z_e,"dataObject");function epe(e){let t=ZS.validateBySchema(e,_I.object(hI));return eT(e,t)}a(epe,"urlObject");function tpe(e){let t=ZS.validateObject(e,A1);return eT(e,t)}a(tpe,"fileObject");function rpe(e){let t=ZS.validateObject(e,X_e);return eT(e,t)}a(rpe,"s3FileObject");function eT(e,t){if(!t){let r=q_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return jS(new Error,r,fI.BAD_REQUEST);if(e.operation===JS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{dI.accessSync(e.file_path,dI.constants.R_OK|dI.constants.F_OK)}catch(n){return n.code===JS.NODE_ERROR_CODES.ENOENT?jS(n,`No such file or directory ${n.path}`,fI.BAD_REQUEST):n.code===JS.NODE_ERROR_CODES.EACCES?jS(n,`Permission denied ${n.path}`,fI.BAD_REQUEST):jS(n)}}return t}a(eT,"postValidateChecks");R1.exports={dataObject:Z_e,urlObject:epe,fileObject:tpe,s3FileObject:rpe}});var EI=w((rve,y1)=>{"use strict";var rh=z(),tT=(H(),C(G));async function npe(e,t,r,n=void 0){if(!e||typeof e!="function")throw new Error("Invalid function parameter");let s;try{return s=await e(t),r&&await r(t,s,n),t.operation===tT.OPERATIONS_ENUM.INSERT||t.operation===tT.OPERATIONS_ENUM.UPDATE||t.operation===tT.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===tT.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(rh.info(i.message),i):i.http_resp_msg?(rh.error(`Error calling operation: ${e.name}`),rh.error(i.http_resp_msg),i):(rh.error(`Error calling operation: ${e.name}`),rh.error(i),i)}}a(npe,"callOperationFunctionAsAwait");y1.exports={callOperationFunctionAsAwait:npe}});var gI=w((sve,O1)=>{"use strict";var{S3:spe,GetObjectCommand:ipe}=require("@aws-sdk/client-s3");O1.exports={getFileStreamFromS3:ope,getS3AuthObj:b1};async function ope(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await b1(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new ipe(r))).Body}a(ope,"getFileStreamFromS3");function b1(e,t,r){return new spe({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(b1,"getS3AuthObj")});var w1=w((ove,N1)=>{"use strict";var SI=class{static{a(this,"BulkLoadFileObject")}constructor(t,r,n,s,i,o,c=null){this.op=t,this.action=r,this.schema=n,this.table=s,this.file_path=i,this.file_type=o,this.role_perms=c}},TI=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};N1.exports={BulkLoadFileObject:SI,BulkLoadDataObject:TI}});var C1=w((cve,I1)=>{"use strict";var AI=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};I1.exports=AI});var wI=w((pve,Y1)=>{"use strict";var rT=yn(),sT=mI(),ape=require("needle"),_i=(H(),C(G)),uve=Tt(),kd=ie(),{handleHDBError:Ft,hdb_errors:H1}=pe(),{HTTP_STATUS_CODES:Br,HDB_ERROR_MSGS:Ar,CHECK_LOGS_WRAPPER:Hl}=H1,Fd=z(),RI=require("papaparse");kd.promisifyPapaParse();var pi=require("fs-extra"),cpe=require("path"),{chain:P1}=require("stream-chain"),D1=require("stream-json/streamers/StreamArray"),L1=require("stream-json/utils/Batch"),M1=require("stream-chain/utils/comp"),{finished:v1}=require("stream"),lpe=ae(),k1=EI(),upe=gI(),{BulkLoadFileObject:bI,BulkLoadDataObject:dpe}=w1(),OI=tI(),{verifyBulkLoadAttributePerms:F1}=YS(),dve=C1(),fve=ir(),_ve=Eo(),{databases:fpe}=(De(),C(nt)),{coerceType:_pe}=(qf(),C(II)),U1="No records parsed from csv file.",Bl=`${lpe.get("HDB_ROOT")}/tmp`,{schema_regex:ppe}=Di(),x1=1024*1024*2,B1=5e3,hpe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};Y1.exports={csvDataLoad:mpe,csvURLLoad:Epe,csvFileLoad:gpe,importFromS3:Spe};async function mpe(e,t){let r=sT.dataObject(e);if(r)throw Ft(r,r.message,Br.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=$1(e.schema,e.table),i=RI.parse(e.data,{header:!0,skipEmptyLines:!0,transform:yI.bind(null,s),dynamicTyping:!1}),o=new OI;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&F1(e.hdb_user?.role?.permission,this.job_operation_function.name,e.action,e.schema,e.table,i.meta.fields,o);let c=o.getPermsResponse();if(c)throw Ft(new Error,c,Br.BAD_REQUEST,void 0,void 0,!0);let l=new dpe(e.action,e.schema,e.table,i.data);return n=await k1.callOperationFunctionAsAwait(V1,l,null),n.message===U1?U1:K1(n.records,n.number_written)}catch(s){throw kl(s)}}a(mpe,"csvDataLoad");async function Epe(e){let t=sT.urlObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Bl}/${r}`;try{await Tpe(e,r)}catch(s){throw Fd.error(Ar.DOWNLOAD_FILE_ERR(r)+" - "+s),Ft(s,Hl(Ar.DOWNLOAD_FILE_ERR(r)))}try{let s=new bI(this.job_operation_function.name,e.action,e.schema,e.table,n,_i.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await NI(s);return await nT(n),i}catch(s){throw await nT(n),kl(s)}}a(Epe,"csvURLLoad");async function gpe(e){let t=sT.fileObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=new bI(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,_i.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await NI(r)}catch(n){throw kl(n)}}a(gpe,"csvFileLoad");async function Spe(e){let t=sT.s3FileObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=cpe.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Bl}/${s}`;let i=new bI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Ape(s,e);let o=await NI(i);return await nT(r),o}catch(n){throw await nT(r),kl(n)}}a(Spe,"importFromS3");async function Tpe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await ape("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw Ft(n,s,n.statusCode,_i.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}ype(r,e.csv_url),await Rpe(t,r.raw)}a(Tpe,"downloadCSVFile");async function Ape(e,t){try{let r=`${Bl}/${e}`;await pi.mkdirp(Bl),await pi.writeFile(`${Bl}/${e}`,"",{flag:"a+"});let n=await pi.createWriteStream(r),s=await upe.getFileStreamFromS3(t);await new Promise((i,o)=>{s.on("error",function(c){o(c)}),s.pipe(n).on("error",function(c){o(c)}).on("close",function(){Fd.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Fd.error(Ar.S3_DOWNLOAD_ERR+" - "+r),Ft(r,Hl(Ar.S3_DOWNLOAD_ERR))}}a(Ape,"downloadFileFromS3");async function Rpe(e,t){try{await pi.mkdirp(Bl),await pi.writeFile(`${Bl}/${e}`,t)}catch(r){throw Fd.error(Ar.WRITE_TEMP_FILE_ERR),Ft(r,Hl(Ar.DEFAULT_BULK_LOAD_ERR))}}a(Rpe,"writeFileToTempFolder");async function nT(e){if(e)try{await pi.access(e),await pi.unlink(e)}catch{Fd.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(nT,"deleteTempFile");function ype(e,t){if(e.statusCode!==H1.HTTP_STATUS_CODES.OK)throw Ft(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Br.BAD_REQUEST);if(!hpe[e.headers["content-type"]])throw Ft(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Br.BAD_REQUEST);if(!e.raw)throw Ft(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Br.BAD_REQUEST)}a(ype,"validateURLResponse");async function NI(e){try{let t;switch(e.file_type){case _i.VALID_S3_FILE_TYPES.CSV:t=await bpe(e);break;case _i.VALID_S3_FILE_TYPES.JSON:t=await Ope(e);break;default:throw Ft(new Error,Ar.DEFAULT_BULK_LOAD_ERR,Br.BAD_REQUEST,_i.LOG_LEVELS.ERROR,Ar.INVALID_FILE_EXT_ERR(e))}return K1(t.records,t.number_written)}catch(t){throw kl(t)}}a(NI,"fileLoad");async function G1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;s&&s.pause();let o={operation:e.action,schema:e.schema,table:e.table,records:i};try{let{attributes:c}=await rT.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&F1(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=Ft(c);r(l)}}a(G1,"validateChunk");async function q1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;kd.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!kd.isEmpty(c)&&!kd.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(u=>c.add(u))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await k1.callOperationFunctionAsAwait(V1,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=Ft(c,Hl(Ar.INSERT_CSV_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.INSERT_CSV_ERR+" - "+c);r(l)}}a(q1,"insertChunk");async function bpe(e){let t={records:0,number_written:0},r=$1(e.schema,e.table);try{let n=new OI,s=pi.createReadStream(e.file_path,{highWaterMark:x1});s.setEncoding("utf8"),await RI.parsePromise(s,G1.bind(null,e,n),yI.bind(null,r));let i=n.getPermsResponse();if(i)throw Ft(new Error,i,Br.BAD_REQUEST);return s=pi.createReadStream(e.file_path,{highWaterMark:x1}),s.setEncoding("utf8"),await RI.parsePromise(s,q1.bind(null,e,t),yI.bind(null,r)),s.destroy(),t}catch(n){throw Ft(n,Hl(Ar.PAPA_PARSE_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.PAPA_PARSE_ERR+n)}}a(bpe,"callPapaParse");function $1(e,t){let r=fpe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>_pe(i,s));return n}a($1,"createTransformMap");function yI(e,t,r){let n=e.get(r);return n?n(t):kd.autoCast(t)}a(yI,"typeFunction");async function Ope(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new OI,s=P1([pi.createReadStream(e.file_path,{encoding:"utf-8"}),D1.withParser(),c=>c.value,new L1({batchSize:B1}),M1(async c=>{await G1(e,n,r,c)})]);await new Promise((c,l)=>{v1(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw Ft(new Error,i,Br.BAD_REQUEST);let o=P1([pi.createReadStream(e.file_path,{encoding:"utf-8"}),D1.withParser(),c=>c.value,new L1({batchSize:B1}),M1(async c=>{await q1(e,t,r,c)})]);return await new Promise((c,l)=>{v1(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw Ft(n,Hl(Ar.INSERT_JSON_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.INSERT_JSON_ERR+n)}}a(Ope,"insertJson");async function V1(e){let t={};try{e.data&&e.data.length>0&&Npe(e.data[0])?t=await wpe(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Fd.info(t.message))}catch(r){throw kl(r)}return t}a(V1,"callBulkFileLoad");function Npe(e){let t=Object.keys(e);for(let r of t)if(!ppe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(Npe,"validateColumnNames");async function wpe(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=rT.insert;break;case"update":i=rT.update;break;case"upsert":i=rT.upsert;break;default:throw Ft(new Error,Ar.INVALID_ACTION_PARAM_ERR(n),Br.BAD_REQUEST,_i.LOG_LEVELS.ERROR,Ar.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let f=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][f])>=0&&e.splice(d,1)}let l=kd.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw kl(o)}}a(wpe,"bulkFileLoad");function K1(e,t){return`successfully loaded ${t} of ${e} records`}a(K1,"buildResponseMsg");function kl(e){return Ft(e,Hl(Ar.DEFAULT_BULK_LOAD_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(kl,"buildTopLevelErrMsg")});var DI=w((mve,eK)=>{"use strict";var PI=Yr(),Ipe=gI(),{AsyncParser:Cpe}=require("json2csv"),iT=require("stream"),is=ie(),CI=require("fs-extra"),Ppe=require("path"),Ls=z(),{promisify:j1}=require("util"),nh=ie(),{handleHDBError:dr,hdb_errors:Dpe}=pe(),{HDB_ERROR_MSGS:Dn,HTTP_STATUS_CODES:fr}=Dpe,{streamAsJSON:Lpe}=(OR(),C(KL)),{Upload:Mpe}=require("@aws-sdk/lib-storage"),{toCsvStream:vpe}=(ao(),C(dM)),W1=["search_by_value","search_by_hash","sql","search_by_conditions"],z1=["json","csv"],J1="json",Q1="csv",Upe="Successfully exported JSON locally.",xpe="Successfully exported CSV locally.",Bpe=1e3,Hpe=PI.searchByHash,kpe=PI.searchByValue,Fpe=j1(iT.finished);eK.exports={export_to_s3:Vpe,export_local:Gpe};async function Gpe(e){Ls.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=X1(e);if(!is.isEmpty(t))throw Ls.error(t),dr(new Error,t,fr.BAD_REQUEST,void 0,void 0,!0);if(is.isEmpty(e.path))throw Ls.error(Dn.MISSING_VALUE("path")),dr(new Error,Dn.MISSING_VALUE("path"),fr.BAD_REQUEST,void 0,void 0,!0);let r=(is.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Ppe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=is.buildFolderPath(e.path,r);await qpe(e.path);let s=await Z1(e);return await $pe(n,e.format,s)}a(Gpe,"export_local");async function qpe(e){if(Ls.trace("in confirmPath"),is.isEmptyOrZeroLength(e))throw dr(new Error,`Invalid path: ${e}`,fr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await CI.stat(e)}catch(r){let n;throw r.code==="ENOENT"?n=`path '${e}' does not exist`:r.code==="EACCES"?n=`access to path '${e}' is denied`:n=r.message,Ls.error(n),dr(new Error,n,fr.BAD_REQUEST,void 0,void 0,!0)}if(!t.isDirectory()){let r=`path '${e}' is not a directory, please supply a valid folder path`;throw Ls.error(r),dr(new Error,r,fr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(qpe,"confirmPath");async function $pe(e,t,r){if(Ls.trace("in saveToLocal"),nh.isEmptyOrZeroLength(e))throw dr(new Error,Dn.INVALID_VALUE("file_path"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmptyOrZeroLength(t))throw dr(new Error,Dn.INVALID_VALUE("Source format"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmpty(r))throw dr(new Error,Dn.NOT_FOUND("Data"),fr.BAD_REQUEST,void 0,void 0,!0);if(t===J1){let n=CI.createWriteStream(e);return Lpe(r).pipe(n),await Fpe(n),{message:Upe,path:e}}else if(t===Q1){let n=CI.createWriteStream(e),s=iT.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(f=>({label:f,value:f})));let c={objectMode:!0};return await new Cpe(i,c).fromInput(s).toOutput(n).promise(!1),{message:xpe,path:e}}throw dr(new Error,Dn.INVALID_VALUE("format"),fr.BAD_REQUEST)}a($pe,"saveToLocal");async function Vpe(e){if(!e.s3||Object.keys(e.s3).length===0)throw dr(new Error,Dn.MISSING_VALUE("S3 object"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw dr(new Error,Dn.MISSING_VALUE("aws_access_key_id"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw dr(new Error,Dn.MISSING_VALUE("aws_secret_access_key"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.bucket))throw dr(new Error,Dn.MISSING_VALUE("bucket"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.key))throw dr(new Error,Dn.MISSING_VALUE("key"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.region))throw dr(new Error,Dn.MISSING_VALUE("region"),fr.BAD_REQUEST);let t=X1(e);if(!is.isEmpty(t))throw dr(new Error,t,fr.BAD_REQUEST);Ls.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await Z1(e)}catch(l){throw Ls.error(l),l}let n,s=await Ipe.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new iT.PassThrough;if(e.format===Q1){i=e.s3.key+".csv";let l=vpe(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===J1){i=e.s3.key+".json";let l=new iT.Readable;l.pipe(o),l.on("error",d=>{throw d}),l.push("[");let u=r.length,f="";for(let[d,p]of r.entries()){let _=d===u-1?JSON.stringify(p):JSON.stringify(p)+",";f+=_,d!==0&&d%Bpe===0&&(l.push(f),f="")}f.length!==0&&l.push(f),l.push("]"),l.push(null)}else throw dr(new Error,Dn.INVALID_VALUE("format"),fr.BAD_REQUEST);return new Mpe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(Vpe,"export_to_s3");function X1(e){if(Ls.trace("in exportCoreValidation"),is.isEmpty(e.format))return"format missing";if(z1.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${z1.join(", ")}`;let t=e.search_operation.operation;if(is.isEmpty(t))return"search_operation.operation missing";if(W1.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${W1.join(", ")}`}a(X1,"exportCoreValidation");async function Z1(e){Ls.trace("in getRecords");let t,r;if(nh.isEmpty(e.search_operation)||nh.isEmptyOrZeroLength(e.search_operation.operation))throw dr(new Error,Dn.INVALID_VALUE("Search operation"),fr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=kpe;break;case"search_by_hash":t=Hpe;break;case"search_by_conditions":t=PI.searchByConditions;break;case"sql":{let n=zS();t=j1(n.evaluateSQL);break}default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,Ls.error(r),dr(new Error,r,fr.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(Z1,"getRecords")});var rK=w((gve,tK)=>{"use strict";var LI=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};tK.exports=LI});var iK=w((Tve,sK)=>{"use strict";var Kpe=(H(),C(G)),nK=require("moment"),Ype=require("uuid").v4,MI=class{static{a(this,"JobObject")}constructor(){this.id=Ype(),this.type=void 0,this.start_datetime=nK().valueOf(),this.created_datetime=nK().valueOf(),this.end_datetime=void 0,this.status=Kpe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};sK.exports=MI});var vI=w((Rve,_K)=>{"use strict";var Wpe=require("uuid").v4,uK=yn(),dK=Yr(),zpe=ni(),jpe=Fu(),Jpe=rK(),Ot=(H(),C(G)),Qpe=iK(),Xpe=ng(),hi=z(),Zpe=Uf(),Gd=ie(),{promisify:ehe}=require("util"),Fl=require("moment"),the=zS(),oT=mI(),oK=Py(),{deleteTransactionLogsBeforeValidator:rhe}=Jw(),{handleHDBError:aK,hdb_errors:nhe,ClientError:she}=pe(),{HTTP_STATUS_CODES:cK}=nhe,lK=dK.searchByValue,ihe=dK.searchByHash,ohe=uK.insert,ahe=ehe(the.evaluateSQL),che=uK.update;_K.exports={addJob:dhe,updateJob:_he,handleGetJob:lhe,handleGetJobsByStartDate:uhe,getJobById:fK};async function lhe(e){if(e.id===void 0)throw new she("'id' is required");let t=await fK(e.id);return Gd.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}a(lhe,"handleGetJob");async function uhe(e){try{let t=await fhe(e);if(hi.trace(`Searching for jobs from ${e.from_date} to ${e.to_date}`),t&&t.length>0)for(let r of t)r.start_datetime&&(r.start_datetime_converted=Fl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Fl(r.end_datetime)),r.request!==void 0&&delete r.request,delete r.__createdtime__,delete r.__updatedtime__;return t}catch(t){let r=`There was an error searching jobs by date: ${t}`;throw hi.error(r),new Error(r)}}a(uhe,"handleGetJobsByStartDate");async function dhe(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Gd.isEmptyOrZeroLength(e.operation)){let f="job parameter is invalid";return hi.info(f),t.error=f,t}if(!Ot.JOB_TYPE_ENUM[e.operation])return hi.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case Ot.OPERATIONS_ENUM.CSV_FILE_LOAD:n=oT.fileObject(e);break;case Ot.OPERATIONS_ENUM.CSV_URL_LOAD:n=oT.urlObject(e);break;case Ot.OPERATIONS_ENUM.CSV_DATA_LOAD:n=oT.dataObject(e);break;case Ot.OPERATIONS_ENUM.IMPORT_FROM_S3:n=oT.s3FileObject(e);break;case Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=oK(e,"date");break;case Ot.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=oK(e,"timestamp");break;case Ot.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=rhe(e);break;case Ot.OPERATIONS_ENUM.RESTART_SERVICE:if(Ot.HDB_PROCESS_SERVICES[e.service]===void 0)throw aK(new Error,"Invalid service",cK.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw aK(n,n.message,cK.BAD_REQUEST,void 0,void 0,!0);let s=new Qpe;s.type=e.operation===Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new zpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await lK(i))}catch(f){let d=`There was an error inserting a new job: ${f}`;return hi.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Wpe();try{o=await lK(i)}catch(f){let d=`There was an error inserting a new job: ${f}`;return hi.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return hi.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Zpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await ohe(l)}catch(f){return hi.error(`There was an error inserting a job for job type: ${e.operation} -- ${f}`),t.success=!1,t}if(u.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let f=`Created a job with type ${s.type} and id ${s.id}`;t.message=f,t.createdJob=s,t.success=!0,hi.trace(f)}return t}a(dhe,"addJob");async function fhe(e){let t=Fl(e.from_date,Fl.ISO_8601),r=Fl(e.to_date,Fl.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new Jpe(n,e.hdb_user);try{return await ahe(s)}catch(i){throw hi.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(fhe,"getJobsInDateRange");async function fK(e){if(Gd.isEmptyOrZeroLength(e))return Gd.errorizeMessage("Invalid job ID specified.");let t=new jpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await ihe(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return hi.error(n),Gd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(fK,"getJobById");async function _he(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Gd.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===Ot.JOB_STATUS_ENUM.COMPLETE||e.status===Ot.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Fl().valueOf());let t=new Xpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await che(t),r}a(_he,"updateJob")});var AK=w((bve,TK)=>{"use strict";var pK=ie(),Rr=(H(),C(G)),phe=require("moment"),aT=wI(),sh=z(),hK=vI(),mK=DI(),EK=zc(),gK=rt(),hhe=qS(),mhe=za(),{parentPort:Ehe,isMainThread:SK}=require("worker_threads"),{onMessageByType:ghe}=rt(),UI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function She(e){if(!e||Object.keys(e).length===0)throw new Error("Empty runner passed to parseMessage");if(!e.json||Object.keys(e.json).length===0)throw new Error("Empty JSON passed to parseMessage");if(!e.job||Object.keys(e.job).length===0)throw new Error("Empty job passed to parseMessage");if(pK.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(pK.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Rr.JOB_TYPE_ENUM.csv_file_load:await Ki(e,aT.csvFileLoad);break;case Rr.JOB_TYPE_ENUM.csv_url_load:await Ki(e,aT.csvURLLoad);break;case Rr.JOB_TYPE_ENUM.csv_data_load:await Ki(e,aT.csvDataLoad);break;case Rr.JOB_TYPE_ENUM.import_from_s3:await Ki(e,aT.importFromS3);break;case Rr.JOB_TYPE_ENUM.empty_trash:break;case Rr.JOB_TYPE_ENUM.export_local:await Ki(e,mK.export_local);break;case Rr.JOB_TYPE_ENUM.export_to_s3:await Ki(e,mK.export_to_s3);break;case Rr.JOB_TYPE_ENUM.delete_files_before:case Rr.JOB_TYPE_ENUM.delete_records_before:await Ki(e,EK.deleteFilesBefore);break;case Rr.JOB_TYPE_ENUM.delete_audit_logs_before:await Ki(e,EK.deleteAuditLogsBefore);break;case Rr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Ki(e,hhe.deleteTransactionLogsBefore);break;case Rr.JOB_TYPE_ENUM.restart_service:return await Ki(e,mhe.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(She,"parseMessage");async function Ki(e,t){try{e.job.status=Rr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=phe().valueOf(),await hK.updateJob(e.job),await The(e.job.id)}catch(r){let n=r.message!==void 0?r.message:r;typeof n=="string"?(n=`There was an error running ${t.name} job with id ${e.job.id} - ${n}`,r.message=n):sh.error(`There was an error running ${t.name} job with id ${e.job.id}`),sh.error(n),e.job.message=n,e.job.status=Rr.JOB_STATUS_ENUM.ERROR;try{await hK.updateJob(e.job)}catch(s){throw sh.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Ki,"runJob");async function The(e){sh.trace("launching job thread:",e),SK?gK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):Ehe.postMessage({type:Rr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(The,"launchJobThread");SK&&ghe(Rr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{gK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){sh.error(r)}});TK.exports={parseMessage:She,RunnerMessage:UI}});var yK=w((Nve,RK)=>{"use strict";var xI=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};RK.exports=xI});var jw=w((Cve,qI)=>{"use strict";var fT=Yr(),kI=zS(),cT=wI(),qo=Kg(),lT=go(),oh=zc(),Ahe=ON(),ih=Rn(),uT=F_(),Pt=zw(),dT=z(),Rhe=PN(),yhe=Sd(),bK=tw(),bhe=sS(),Ohe=sw(),Nhe=iw(),whe=cS(),Ihe=uS(),BI=dS(),OK=DI(),Che=YS(),FI=vI(),K=(H(),C(G)),{hdb_errors:ch,handleHDBError:ah}=pe(),{HTTP_STATUS_CODES:NK}=ch,HI=mS(),wK=za(),BK=require("util"),$d=yn(),Phe=As(),Dhe=Po(),IK=AK(),CK=(Ju(),C(X_)),PK=(vS(),C(Gp)),DK=yt(),LK=qS(),MK=Kp(),{setServerUtilities:Lhe}=(qf(),C(II)),{CONTEXT:Ive}=(Ea(),C(gR)),{_assignPackageExport:Mhe}=Ti(),{transformReq:vhe}=ie(),{server:Uhe}=(Vr(),C(Au)),nn=dT.loggerWithTag("operation"),qd=Zn(),vK=(bl(),C(yl)),xhe=EI(),UK=fT.searchByHash,Bhe=fT.searchByValue,Hhe=BK.promisify(fT.search),khe=BK.promisify(kI.evaluateSQL),Fhe={[K.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[K.OPERATIONS_ENUM.CREATE_TABLE]:!0,[K.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[K.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[K.OPERATIONS_ENUM.DROP_TABLE]:!0,[K.OPERATIONS_ENUM.DROP_SCHEMA]:!0},ee=yK();async function HK(e,t){try{if(e.body.operation!=="read_log"&&(dT.log_level===K.LOG_LEVELS.INFO||dT.log_level===K.LOG_LEVELS.DEBUG||dT.log_level===K.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;nn.info(c)}}catch(n){nn.error(n)}let r=await xhe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Fhe[e.body.operation]&&Phe.setSchemaDataToGlobal(n=>{n&&nn.error(n)}),r}a(HK,"processLocalTransaction");var xK=qhe();qI.exports={chooseOperation:kK,getOperationFunction:FK,operation:GI,processLocalTransaction:HK,executeJob:Ms};Lhe(qI.exports);Uhe.operation=GI;function kK(e){let t;try{t=FK(e)}catch(s){throw nn.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=kI.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=kI.checkASTPermissions(e,i);if(o)throw nn.error(`${NK.FORBIDDEN} from operation ${e.operation}`),nn.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==K.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==K.OPERATIONS_ENUM.LOGIN&&e.operation!==K.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=Che.verifyPerms(i,s);if(o)throw nn.error(`${NK.FORBIDDEN} from operation ${e.operation}`),nn.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw ah(s,"There was an error when trying to choose an operation path")}return r}a(kK,"chooseOperation");function FK(e){if(nn.trace(`getOperationFunction with operation: ${e.operation}`),xK.has(e.operation))return xK.get(e.operation);throw ah(new Error,ch.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),ch.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(FK,"getOperationFunction");Mhe("operation",GI);function GI(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=kK(e);return HK({body:e},n)}a(GI,"operation");async function Ghe(e){nn.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[K.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case K.OPERATIONS_ENUM.INSERT:o=await $d.insert(i);break;case K.OPERATIONS_ENUM.UPDATE:o=await $d.update(i);break;case K.OPERATIONS_ENUM.UPSERT:o=await $d.upsert(i);break;case K.OPERATIONS_ENUM.DELETE:o=await oh.deleteRecord(i);break;default:nn.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){nn.info("Invalid operation in transaction"),nn.error(o)}}a(Ghe,"catchup");async function Ms(e){vhe(e);let t,r;try{r=await FI.addJob(e),t=r.createdJob,nn.info("addJob result",r);let n=new IK.RunnerMessage(t,e);return{message:await IK.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw nn.error(s),ah(n,s)}}a(Ms,"executeJob");function qhe(){let e=new Map;return e.set(K.OPERATIONS_ENUM.INSERT,new ee($d.insert)),e.set(K.OPERATIONS_ENUM.UPDATE,new ee($d.update)),e.set(K.OPERATIONS_ENUM.UPSERT,new ee($d.upsert)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new ee(fT.searchByConditions)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_HASH,new ee(UK)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_ID,new ee(UK)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_VALUE,new ee(Bhe)),e.set(K.OPERATIONS_ENUM.SEARCH,new ee(Hhe)),e.set(K.OPERATIONS_ENUM.SQL,new ee(khe)),e.set(K.OPERATIONS_ENUM.CSV_DATA_LOAD,new ee(Ms,cT.csvDataLoad)),e.set(K.OPERATIONS_ENUM.CSV_FILE_LOAD,new ee(Ms,cT.csvFileLoad)),e.set(K.OPERATIONS_ENUM.CSV_URL_LOAD,new ee(Ms,cT.csvURLLoad)),e.set(K.OPERATIONS_ENUM.IMPORT_FROM_S3,new ee(Ms,cT.importFromS3)),e.set(K.OPERATIONS_ENUM.CREATE_SCHEMA,new ee(qo.createSchema)),e.set(K.OPERATIONS_ENUM.CREATE_DATABASE,new ee(qo.createSchema)),e.set(K.OPERATIONS_ENUM.CREATE_TABLE,new ee(qo.createTable)),e.set(K.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new ee(qo.createAttribute)),e.set(K.OPERATIONS_ENUM.DROP_SCHEMA,new ee(qo.dropSchema)),e.set(K.OPERATIONS_ENUM.DROP_DATABASE,new ee(qo.dropSchema)),e.set(K.OPERATIONS_ENUM.DROP_TABLE,new ee(qo.dropTable)),e.set(K.OPERATIONS_ENUM.DROP_ATTRIBUTE,new ee(qo.dropAttribute)),e.set(K.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new ee(lT.describeSchema)),e.set(K.OPERATIONS_ENUM.DESCRIBE_DATABASE,new ee(lT.describeSchema)),e.set(K.OPERATIONS_ENUM.DESCRIBE_TABLE,new ee(lT.describeTable)),e.set(K.OPERATIONS_ENUM.DESCRIBE_ALL,new ee(lT.describeAll)),e.set(K.OPERATIONS_ENUM.DELETE,new ee(oh.deleteRecord)),e.set(K.OPERATIONS_ENUM.ADD_USER,new ee(ih.addUser)),e.set(K.OPERATIONS_ENUM.ALTER_USER,new ee(ih.alterUser)),e.set(K.OPERATIONS_ENUM.DROP_USER,new ee(ih.dropUser)),e.set(K.OPERATIONS_ENUM.LIST_USERS,new ee(ih.listUsersExternal)),e.set(K.OPERATIONS_ENUM.LIST_ROLES,new ee(uT.listRoles)),e.set(K.OPERATIONS_ENUM.ADD_ROLE,new ee(uT.addRole)),e.set(K.OPERATIONS_ENUM.ALTER_ROLE,new ee(uT.alterRole)),e.set(K.OPERATIONS_ENUM.DROP_ROLE,new ee(uT.dropRole)),e.set(K.OPERATIONS_ENUM.USER_INFO,new ee(ih.userInfo)),e.set(K.OPERATIONS_ENUM.READ_LOG,new ee(Rhe)),e.set(K.OPERATIONS_ENUM.ADD_NODE,new ee(yhe)),e.set(K.OPERATIONS_ENUM.UPDATE_NODE,new ee(bK)),e.set(K.OPERATIONS_ENUM.SET_NODE_REPLICATION,new ee(bK)),e.set(K.OPERATIONS_ENUM.REMOVE_NODE,new ee(bhe)),e.set(K.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new ee(Ohe)),e.set(K.OPERATIONS_ENUM.PURGE_STREAM,new ee(Nhe)),e.set(K.OPERATIONS_ENUM.SET_CONFIGURATION,new ee(DK.setConfiguration)),e.set(K.OPERATIONS_ENUM.CLUSTER_STATUS,new ee(whe.clusterStatus)),e.set(K.OPERATIONS_ENUM.CLUSTER_NETWORK,new ee(Ihe)),e.set(K.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new ee(BI.setRoutes)),e.set(K.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new ee(BI.getRoutes)),e.set(K.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new ee(BI.deleteRoutes)),e.set(K.OPERATIONS_ENUM.EXPORT_TO_S3,new ee(Ms,OK.export_to_s3)),e.set(K.OPERATIONS_ENUM.CREATE_CSR,new ee(qd.createCsr)),e.set(K.OPERATIONS_ENUM.SIGN_CERTIFICATE,new ee(qd.signCertificate)),e.set(K.OPERATIONS_ENUM.LIST_CERTIFICATES,new ee(qd.listCertificates)),e.set(K.OPERATIONS_ENUM.ADD_CERTIFICATES,new ee(qd.addCertificate)),e.set(K.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new ee(qd.removeCertificate)),e.set(K.OPERATIONS_ENUM.GET_KEY,new ee(qd.getKey)),e.set(K.OPERATIONS_ENUM.ADD_NODE_BACK,new ee(vK.addNodeBack)),e.set(K.OPERATIONS_ENUM.REMOVE_NODE_BACK,new ee(vK.removeNodeBack)),e.set(K.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new ee(Ms,oh.deleteFilesBefore)),e.set(K.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new ee(Ms,oh.deleteFilesBefore)),e.set(K.OPERATIONS_ENUM.EXPORT_LOCAL,new ee(Ms,OK.export_local)),e.set(K.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new ee(FI.handleGetJobsByStartDate)),e.set(K.OPERATIONS_ENUM.GET_JOB,new ee(FI.handleGetJob)),e.set(K.OPERATIONS_ENUM.GET_FINGERPRINT,new ee(HI.getFingerprint)),e.set(K.OPERATIONS_ENUM.SET_LICENSE,new ee(HI.setLicense)),e.set(K.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new ee(HI.getRegistrationInfo)),e.set(K.OPERATIONS_ENUM.RESTART,new ee(wK.restart)),e.set(K.OPERATIONS_ENUM.RESTART_SERVICE,new ee(Ms,wK.restartService)),e.set(K.OPERATIONS_ENUM.CATCHUP,new ee(Ghe)),e.set(K.OPERATIONS_ENUM.SYSTEM_INFORMATION,new ee(Dhe.systemInformation)),e.set(K.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new ee(Ms,oh.deleteAuditLogsBefore)),e.set(K.OPERATIONS_ENUM.READ_AUDIT_LOG,new ee(Ahe)),e.set(K.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new ee(CK.createTokens)),e.set(K.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new ee(CK.refreshOperationToken)),e.set(K.OPERATIONS_ENUM.LOGIN,new ee(PK.login)),e.set(K.OPERATIONS_ENUM.LOGOUT,new ee(PK.logout)),e.set(K.OPERATIONS_ENUM.GET_CONFIGURATION,new ee(DK.getConfiguration)),e.set(K.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new ee(Pt.customFunctionsStatus)),e.set(K.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new ee(Pt.getCustomFunctions)),e.set(K.OPERATIONS_ENUM.GET_COMPONENT_FILE,new ee(Pt.getComponentFile)),e.set(K.OPERATIONS_ENUM.GET_COMPONENTS,new ee(Pt.getComponents)),e.set(K.OPERATIONS_ENUM.SET_COMPONENT_FILE,new ee(Pt.setComponentFile)),e.set(K.OPERATIONS_ENUM.DROP_COMPONENT,new ee(Pt.dropComponent)),e.set(K.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new ee(Pt.getCustomFunction)),e.set(K.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new ee(Pt.setCustomFunction)),e.set(K.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new ee(Pt.dropCustomFunction)),e.set(K.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new ee(Pt.addComponent)),e.set(K.OPERATIONS_ENUM.ADD_COMPONENT,new ee(Pt.addComponent)),e.set(K.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new ee(Pt.dropCustomFunctionProject)),e.set(K.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new ee(Pt.packageComponent)),e.set(K.OPERATIONS_ENUM.PACKAGE_COMPONENT,new ee(Pt.packageComponent)),e.set(K.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new ee(Pt.deployComponent)),e.set(K.OPERATIONS_ENUM.DEPLOY_COMPONENT,new ee(Pt.deployComponent)),e.set(K.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new ee(LK.readTransactionLog)),e.set(K.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new ee(Ms,LK.deleteTransactionLogsBefore)),e.set(K.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new ee(MK.installModules)),e.set(K.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new ee(MK.auditModules)),e.set(K.OPERATIONS_ENUM.GET_BACKUP,new ee(qo.getBackup)),e.set(K.OPERATIONS_ENUM.ADD_SSH_KEY,new ee(Pt.addSSHKey)),e.set(K.OPERATIONS_ENUM.UPDATE_SSH_KEY,new ee(Pt.updateSSHKey)),e.set(K.OPERATIONS_ENUM.DELETE_SSH_KEY,new ee(Pt.deleteSSHKey)),e.set(K.OPERATIONS_ENUM.LIST_SSH_KEYS,new ee(Pt.listSSHKeys)),e.set(K.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new ee(Pt.setSSHKnownHosts)),e.set(K.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new ee(Pt.getSSHKnownHosts)),e}a(qhe,"initializeOperationFunctionMap")});var hT=w((Dve,$K)=>{"use strict";var _T=(H(),C(G)),$he=ie(),lh=z(),{handleHDBError:$I,hdb_errors:pT}=pe(),{isMainThread:Vhe}=require("worker_threads"),{Readable:Khe}=require("stream"),GK=require("os"),Yhe=require("util"),Whe=wO(),zhe=Yhe.promisify(Whe.authorize),qK=jw(),{createGzip:jhe,constants:Jhe}=require("zlib"),Qhe=[_T.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,_T.OPERATIONS_ENUM.LOGIN,_T.OPERATIONS_ENUM.LOGOUT];function Xhe(e){let t=`Found an uncaught exception with message: ${e.message}. ${GK.EOL}Stack: ${e.stack} ${GK.EOL}Terminating ${Vhe?"HDB":"thread"}.`;console.error(t),lh.fatal(t),process.exit(1)}a(Xhe,"handleServerUncaughtException");function Zhe(e,t,r){if(lh[e.logLevel||"error"](e),e.statusCode)return typeof e.http_resp_msg!="object"?r.code(e.statusCode).send({error:e.http_resp_msg||e.message}):r.code(e.statusCode).send(e.http_resp_msg);let n=e.statusCode?e.statusCode:pT.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR;return typeof e=="string"?r.code(n).send({error:e}):r.code(n).send(e.message?{error:e.message}:e)}a(Zhe,"serverErrorHandler");function eme(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=$I(new Error,"Invalid JSON.",pT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if($he.isEmpty(e.body.operation)){let n=$I(new Error,"Request body must include an 'operation' property.",pT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(eme,"reqBodyValidationHandler");function tme(e,t,r){let n;!Qhe.includes(e.body.operation)||e.body.operation===_T.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&!e.body.username&&!e.body.password?zhe(e,t).then(i=>{n=i,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(i=>{lh.warn(i),lh.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${i.stack}"`);let o=typeof i=="string"?{error:i}:{error:i.message};r($I(i,o,pT.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.hdb_auth_header=e.headers.authorization,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(tme,"authHandler");async function rme(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=qK.chooseOperation(e.body);let s=await qK.processLocalTransaction(e,n);if(s instanceof Khe&&s.headers){for(let[i,o]of s.headers)t.header(i,o);e.headers["accept-encoding"]?.includes("gzip")&&(t.header("content-encoding","gzip"),s=s.pipe(jhe({level:Jhe.Z_BEST_SPEED})))}return s}catch(s){throw lh.error(s),s}}a(rme,"handlePostRequest");$K.exports={authHandler:tme,handlePostRequest:rme,handleServerUncaughtException:Xhe,serverErrorHandler:Zhe,reqBodyValidationHandler:eme}});var WK=w((Mve,YK)=>{"use strict";var nme=require("fastify-plugin"),{handlePostRequest:VK,authHandler:sme,reqBodyValidationHandler:ime}=hT();async function ome(e){e.decorate("hdbCore",{preValidation:[ime,sme],request:a(t=>KK(VK(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>KK(VK(t,r,!0)),"requestWithoutAuthentication")})}a(ome,"hdbCore");async function KK(e){if(e=await e,e?.[Symbol.asyncIterator]&&!e[Symbol.iterator]){let t=[];for await(let r of e)t.push(r);return t}return e}a(KK,"convertAsyncIterators");YK.exports=nme(ome)});var jK=w((xve,zK)=>{"use strict";var Uve=require("fs"),mT=ae();mT.initSync();var{CONFIG_PARAMS:VI}=(H(),C(G)),ame=1024*1024*1024;function cme(e){let t=mT.get(VI.HTTP_TIMEOUT),r=mT.get(VI.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:ame,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:mT.get(VI.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(cme,"getServerOptions");zK.exports=cme});var XK=w((Hve,QK)=>{"use strict";var KI=ae();KI.initSync();var{CONFIG_PARAMS:JK}=(H(),C(G));function lme(){let e=KI.get(JK.HTTP_CORSACCESSLIST),t=KI.get(JK.HTTP_CORS),r;return t&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},e&&e.length>0&&e[0]!==null&&e[0]!=="*"&&(r.origin=(n,s)=>s(null,e.indexOf(n)!==-1))),r}a(lme,"getCORSOptions");QK.exports=lme});var tY=w((Fve,eY)=>{"use strict";var ZK=ae();ZK.initSync();var ume=(H(),C(G));function dme(){return ZK.get(ume.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(dme,"getHeaderTimeoutConfig");eY.exports=dme});var WI={};ve(WI,{customFunctionsServer:()=>pme,ready:()=>hY,start:()=>_me});function _me(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){$o||($o=pY(t),We.http((await $o).server));let o=await $o,c=(0,YI.dirname)(s),l=(0,YI.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!rY.has(c)){rY.add(c);try{o.register(mme(c,l))}catch(u){if(u.message==="Root plugin has already booted")ht.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:hY}}async function pme(){try{ht.info("In Custom Functions Fastify server"+process.cwd()),ht.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ht.debug(`Custom Functions server process ${process.pid} starting up.`),await hme();let e=cY.get(x.HTTP_SECUREPORT)>0,t;try{t=$o=await pY(e)}catch(r){throw ht.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw ht.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){ht.error(`Custom Functions ${process.pid} Error: ${e}`),ht.error(e),process.exit(1)}}async function hme(){try{ht.info("Custom Functions starting configuration."),await lY.setUsersWithRolesCache(),ht.info("Custom Functions completed configuration.")}catch(e){ht.error(e)}}function mme(e,t){return async function(r){try{ht.info("Custom Functions starting buildRoutes"),ht.trace("Loading fastify routes folder "+e),(0,nY.existsSync)(e)&&r.register(aY.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:ht.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?ht.error(s.message):s&&ht.error(s),o()})}catch(n){ht.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function pY(e){ht.info("Custom Functions starting buildServer.");let t=(0,uY.default)(e),r=(0,sY.default)(t);r.server.headersTimeout=(0,fY.default)(),r.setErrorHandler(_Y.serverErrorHandler);let n=(0,dY.default)();return n&&r.register(iY.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(oY.default),await r.register(fme),await r.after(),jf(r),ht.info("Custom Functions completed buildServer."),r}function hY(){if($o)return $o.then?$o.then(e=>e.ready()):$o.ready()}var YI,nY,sY,iY,oY,aY,cY,ht,fme,lY,uY,dY,fY,_Y,$o,rY,mY=be(()=>{YI=require("path"),nY=require("fs"),sY=M(require("fastify")),iY=M(require("@fastify/cors")),oY=M(RO()),aY=M(require("@fastify/autoload")),cY=M(ae());H();ht=M(z()),fme=M(WK()),lY=M(Rn()),uY=M(jK()),dY=M(XK()),fY=M(tY()),_Y=M(hT());ao();Vr();rY=new Set;a(_me,"start");a(pme,"customFunctionsServer");a(hme,"setUp");a(mme,"buildRouteFolder");a(pY,"buildServer");a(hY,"ready")});var zI={};ve(zI,{start:()=>Eme});function Eme(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,AY.default)(r,e);return e.server.http(async(s,i)=>{if(!s.isWebSocket)return new Promise(o=>n(s._nodeRequest,s._nodeResponse,()=>{o(i(s))}))}),!0}},handleFile(t,r,n){gY||(gY=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=EY.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,SY.default)(s,(0,TY.realpathSync)(o))}}return i(s)},{runFirst:!0})),EY.set(r,n)}}}var SY,TY,AY,EY,gY,RY=be(()=>{SY=M(require("send")),TY=require("fs"),AY=M(require("serve-static")),EY=new Map;a(Eme,"start")});var jI={};ve(jI,{start:()=>gme});function gme({override:e}){return{handleFile:a((t,r,n)=>{ET.default.debug(`Loading env file: ${n}`);for(let[s,i]of Object.entries((0,yY.parse)(t))){if(process.env[s]!==void 0)if(ET.default.warn(`Environment variable conflict: ${s} from ${n} is already set on process.env`),e)ET.default.debug(`override option enabled. overriding environment variable: ${s}`);else continue;process.env[s]=i}},"handleFile")}}var yY,ET,bY=be(()=>{yY=require("dotenv"),ET=M(z());a(gme,"start")});var NY={};ve(NY,{Request:()=>JI,createReuseportFd:()=>gT});var OY,JI,QI,XI,gT,ZI=be(()=>{OY=require("os"),JI=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new XI(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new QI(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},QI=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},XI=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,OY.platform)()!="win32"&&(gT=require("node-unix-socket").createReuseportFd)});var tC=w((jve,wY)=>{"use strict";var uh=ae();uh.initSync();var Vd=require("fs-extra"),eC=require("path"),Kd=(H(),C(G)),Sme=require("crypto"),Tme=require("uuid").v4;wY.exports=Ame;function Ame(){if(uh.getHdbBasePath()!==void 0){let e=eC.join(uh.getHdbBasePath(),Kd.LICENSE_KEY_DIR_NAME,Kd.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=eC.join(uh.getHdbBasePath(),Kd.LICENSE_KEY_DIR_NAME,Kd.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=eC.join(uh.getHdbBasePath(),Kd.LICENSE_KEY_DIR_NAME,Kd.JWT_ENUM.JWT_PASSPHRASE_NAME);try{Vd.accessSync(r),Vd.accessSync(e),Vd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=Tme(),i=Sme.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});Vd.writeFileSync(r,s),Vd.writeFileSync(e,i.privateKey),Vd.writeFileSync(t,i.publicKey)}else throw n}}}a(Ame,"checkJWTTokenExist")});var CY=w((Qve,IY)=>{"use strict";var rC=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};IY.exports={HdbInfoInsertObject:rC}});var LY=w((Zve,DY)=>{"use strict";var PY=(H(),C(G)),nC=class{static{a(this,"UpgradeObject")}constructor(t,r){this[PY.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[PY.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};DY.exports={UpgradeObject:nC}});var ST=w((tUe,vY)=>{"use strict";var vs=require("prompt"),Yd=require("chalk"),MY=z(),mi=require("os"),sC=ua(),iC=["yes","y"];async function Rme(e){let t=`${mi.EOL}`+Yd.bold.green("Your current HarperDB version requires that we complete an update process.")+`${mi.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${mi.EOL}${mi.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${mi.EOL}`;vs.override=sC(["CONFIRM_UPGRADE"]),vs.start(),vs.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Yd.magenta(`${mi.EOL}[CONFIRM_UPGRADE] Do you want to upgrade your HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n;try{n=await vs.get([r])}catch(s){return MY.error("There was an error when prompting user about an upgrade."),MY.error(s),!1}return iC.includes(n.CONFIRM_UPGRADE)}a(Rme,"forceUpdatePrompt");async function yme(e){let t=`${mi.EOL}`+Yd.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${mi.EOL}`);vs.override=sC(["CONFIRM_DOWNGRADE"]),vs.start(),vs.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Yd.magenta(`${mi.EOL}[CONFIRM_DOWNGRADE] Do you want to proceed with using your downgraded HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n=await vs.get([r]);return iC.includes(n.CONFIRM_DOWNGRADE)}a(yme,"forceDowngradePrompt");async function bme(){let e=`${mi.EOL}`+Yd.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");vs.override=sC(["GENERATE_CERTS"]),vs.start(),vs.message=e;let t={properties:{GENERATE_CERTS:{description:Yd.magenta(`${mi.EOL}[GENERATE_CERTS] Do you want HarperDB to generate all new certificates? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"yes",required:!0}}},r=await vs.get([t]);return iC.includes(r.GENERATE_CERTS)}a(bme,"upgradeCertsPrompt");vY.exports={forceUpdatePrompt:Rme,forceDowngradePrompt:yme,upgradeCertsPrompt:bme}});var aC=w((nUe,UY)=>{"use strict";var oC=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};UY.exports=oC});var BY=w((lUe,xY)=>{"use strict";var Ome=ie(),Nme=yt(),iUe=z(),oUe=require("path"),aUe=require("fs"),cUe=(H(),C(G));xY.exports={getOldPropsValue:wme};function wme(e,t,r=!1){let n=t.getRaw(e);return Ome.isNotEmptyAndHasValue(n)?n:r?Nme.getDefaultConfig(e):""}a(wme,"getOldPropsValue")});var GY=w((dUe,FY)=>{"use strict";var ec=require("path"),tc=require("fs-extra"),Ime=require("properties-reader"),Cme=aC(),_r=z(),{getOldPropsValue:mt}=BY(),{HDB_SETTINGS_NAMES:Te,CONFIG_PARAMS:Gl}=(H(),C(G)),ql=yt(),TT=ae(),HY=ie(),Yi=(H(),C(G)),cC=new Cme("3.1.0"),kY=[];function Pme(){let e=Ime(TT.get(Te.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),_r.info(t);let r=` ;Settings for the HarperDB process.
|
|
42
40
|
|
|
43
41
|
;The directory selected during install where the database files reside.
|
|
44
|
-
${
|
|
42
|
+
${Te.HDB_ROOT_KEY} = ${mt(Te.HDB_ROOT_KEY,e)}
|
|
45
43
|
;The port the HarperDB REST interface will listen on.
|
|
46
|
-
${
|
|
44
|
+
${Te.SERVER_PORT_KEY} = ${mt(Te.SERVER_PORT_KEY,e)}
|
|
47
45
|
;Set to true to enable HTTPS on the HarperDB REST endpoint. Requires a valid certificate and key.
|
|
48
|
-
${
|
|
46
|
+
${Te.HTTP_SECURE_ENABLED_KEY} = ${mt(Te.HTTP_SECURE_ENABLED_KEY,e)}
|
|
49
47
|
;The path to the SSL certificate used when running with HTTPS enabled.
|
|
50
|
-
${
|
|
48
|
+
${Te.CERT_KEY} = ${mt(Te.CERT_KEY,e)}
|
|
51
49
|
;The path to the SSL private key used when running with HTTPS enabled.
|
|
52
|
-
${
|
|
50
|
+
${Te.PRIVATE_KEY_KEY} = ${mt(Te.PRIVATE_KEY_KEY,e)}
|
|
53
51
|
;Set to true to enable Cross Origin Resource Sharing, which allows requests across a domain.
|
|
54
|
-
${
|
|
52
|
+
${Te.CORS_ENABLED_KEY} = ${mt(Te.CORS_ENABLED_KEY,e)}
|
|
55
53
|
;Allows for setting allowable domains with CORS. Comma separated list.
|
|
56
|
-
${
|
|
54
|
+
${Te.CORS_WHITELIST_KEY} = ${mt(Te.CORS_WHITELIST_KEY,e)}
|
|
57
55
|
;Length of time in milliseconds after which a request will timeout. Defaults to 120,000 ms (2 minutes).
|
|
58
|
-
${
|
|
56
|
+
${Te.SERVER_TIMEOUT_KEY} = ${mt(Te.SERVER_TIMEOUT_KEY,e,!0)}
|
|
59
57
|
;The number of milliseconds of inactivity a server needs to wait for additional incoming data, after it has finished writing the last response. Defaults to 5,000 ms (5 seconds).
|
|
60
|
-
${
|
|
58
|
+
${Te.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${mt(Te.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0)}
|
|
61
59
|
;Limit the amount of time the parser will wait to receive the complete HTTP headers.. Defaults to 60,000 ms (1 minute).
|
|
62
|
-
${
|
|
60
|
+
${Te.SERVER_HEADERS_TIMEOUT_KEY} = ${mt(Te.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
|
|
63
61
|
;Define whether to log to file or not.
|
|
64
|
-
${
|
|
62
|
+
${Te.LOG_TO_FILE} = ${ql.getDefaultConfig(Gl.LOGGING_FILE)}
|
|
65
63
|
;Define whether to log to stdout/stderr or not. NOTE HarperDB must run in foreground in order to receive the std stream from HarperDB.
|
|
66
|
-
${
|
|
64
|
+
${Te.LOG_TO_STDSTREAMS} = ${ql.getDefaultConfig(Gl.LOGGING_STDSTREAMS)}
|
|
67
65
|
;Set to control amount of logging generated. Accepted levels are trace, debug, warn, error, fatal.
|
|
68
|
-
${
|
|
66
|
+
${Te.LOG_LEVEL_KEY} = ${mt(Te.LOG_LEVEL_KEY,e)}
|
|
69
67
|
;The path where log files will be written. If there is no file name included in the path, the log file will be created by default as 'hdb_log.log'
|
|
70
|
-
${
|
|
68
|
+
${Te.LOG_PATH_KEY} = ${mt(Te.LOG_PATH_KEY,e)}
|
|
71
69
|
;Set to true to enable daily log file rotations - each log file name will be prepended with YYYY-MM-DD.
|
|
72
|
-
${
|
|
70
|
+
${Te.LOG_DAILY_ROTATE_KEY} = ${mt(Te.LOG_DAILY_ROTATE_KEY,e)}
|
|
73
71
|
;Set the number of daily log files to maintain when LOG_DAILY_ROTATE is enabled. If no integer value is set, no limit will be set for
|
|
74
72
|
;daily log files which may consume a large amount of storage depending on your log settings.
|
|
75
|
-
${
|
|
73
|
+
${Te.LOG_MAX_DAILY_FILES_KEY} = ${mt(Te.LOG_MAX_DAILY_FILES_KEY,e)}
|
|
76
74
|
;The environment used by NodeJS. Setting to production will be the most performant, settings to development will generate more logging.
|
|
77
|
-
${
|
|
75
|
+
${Te.PROPS_ENV_KEY} = ${mt(Te.PROPS_ENV_KEY,e)}
|
|
78
76
|
;This allows self signed certificates to be used in clustering. This is a security risk
|
|
79
77
|
;as clustering will not validate the cert, so should only be used internally.
|
|
80
78
|
;The HDB install creates a self signed certificate, if you use that cert this must be set to true.
|
|
81
|
-
${
|
|
79
|
+
${Te.ALLOW_SELF_SIGNED_SSL_CERTS} = ${mt(Te.ALLOW_SELF_SIGNED_SSL_CERTS,e,!0)}
|
|
82
80
|
;Set the max number of processes HarperDB will start. This can also be limited by number of cores and licenses.
|
|
83
|
-
${
|
|
81
|
+
${Te.MAX_HDB_PROCESSES} = ${mt(Te.MAX_HDB_PROCESSES,e)}
|
|
84
82
|
;Set to true to enable clustering. Requires a valid enterprise license.
|
|
85
|
-
${
|
|
83
|
+
${Te.CLUSTERING_ENABLED_KEY} = ${mt(Te.CLUSTERING_ENABLED_KEY,e,!0)}
|
|
86
84
|
;The port that will be used for HarperDB clustering.
|
|
87
|
-
${
|
|
85
|
+
${Te.CLUSTERING_PORT_KEY} = ${mt(Te.CLUSTERING_PORT_KEY,e)}
|
|
88
86
|
;The name of this node in your HarperDB cluster topology. This must be a value unique from the rest of your cluster node names.
|
|
89
|
-
${
|
|
87
|
+
${Te.CLUSTERING_NODE_NAME_KEY} = ${mt(Te.CLUSTERING_NODE_NAME_KEY,e)}
|
|
90
88
|
;The user used to connect to other instances of HarperDB, this user must have a role of cluster_user.
|
|
91
|
-
${
|
|
89
|
+
${Te.CLUSTERING_USER_KEY} = ${mt(Te.CLUSTERING_USER_KEY,e)}
|
|
92
90
|
;Defines if this instance does not record transactions. Note, if Clustering is enabled and Transaction Log is disabled your nodes will not catch up.
|
|
93
|
-
${
|
|
91
|
+
${Te.DISABLE_TRANSACTION_LOG_KEY} = ${mt(Te.DISABLE_TRANSACTION_LOG_KEY,e,!0)}
|
|
94
92
|
;Defines the length of time an operation token will be valid until it expires. Example values: https://github.com/vercel/ms
|
|
95
|
-
${
|
|
93
|
+
${Te.OPERATION_TOKEN_TIMEOUT_KEY} = ${mt(Te.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
|
|
96
94
|
;Defines the length of time a refresh token will be valid until it expires. Example values: https://github.com/vercel/ms
|
|
97
|
-
${
|
|
95
|
+
${Te.REFRESH_TOKEN_TIMEOUT_KEY} = ${mt(Te.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
|
|
98
96
|
;The port the IPC server will run on.
|
|
99
|
-
${
|
|
97
|
+
${Te.IPC_SERVER_PORT} = ${ql.getDefaultConfig(Gl.IPC_NETWORK_PORT)}
|
|
100
98
|
;Run HDB in the foreground.
|
|
101
|
-
${
|
|
99
|
+
${Te.RUN_IN_FOREGROUND} = ${ql.getDefaultConfig(Gl.OPERATIONSAPI_FOREGROUND)}
|
|
102
100
|
;Set to true to enable custom API endpoints. Requires a valid enterprise license.
|
|
103
|
-
${
|
|
101
|
+
${Te.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${ql.getDefaultConfig(Gl.CUSTOMFUNCTIONS_ENABLED)}
|
|
104
102
|
;The port used to access the custom functions server.
|
|
105
|
-
${
|
|
103
|
+
${Te.CUSTOM_FUNCTIONS_PORT_KEY} = ${ql.getDefaultConfig(Gl.HTTP_PORT)}
|
|
106
104
|
;The path to the folder containing HarperDB custom function files.
|
|
107
|
-
${
|
|
105
|
+
${Te.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${ec.join(mt(Te.HDB_ROOT_KEY,e),"custom_functions")}
|
|
108
106
|
;Set the max number of processes HarperDB will start for the Custom Functions server
|
|
109
|
-
${
|
|
110
|
-
`,n=
|
|
107
|
+
${Te.MAX_CUSTOM_FUNCTION_PROCESSES} = ${ql.getDefaultConfig(Gl.HTTP_THREADS)}
|
|
108
|
+
`,n=TT.get("settings_path"),s=ec.dirname(n),i=ec.join(s,"3_1_0_upgrade_settings.bak");try{_r.info(`Backing up old settings file to: ${i}`),tc.copySync(n,i)}catch(c){throw _r.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{_r.info("New settings file values for 3.1.0 upgrade:",r),_r.info(`Creating new/upgraded settings file at '${n}'`),tc.writeFileSync(n,r),_r.info("Updating env variables with new settings values")}catch(c){throw console.error("There was a problem writing the new settings file. Please check the log for details."),_r.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),_r.error(c),tc.copySync(i,n),c}TT.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),_r.info(o),o}a(Pme,"updateSettingsFile_3_1_0");function Dme(){let e=ec.join(HY.getHomeDir(),Yi.HDB_HOME_DIR_NAME,Yi.LICENSE_KEY_DIR_NAME,Yi.LICENSE_FILE_NAME),t=ec.join(HY.getHomeDir(),Yi.HDB_HOME_DIR_NAME,Yi.LICENSE_KEY_DIR_NAME,Yi.REG_KEY_FILE_NAME),r=ec.join(TT.getHdbBasePath(),Yi.LICENSE_KEY_DIR_NAME,Yi.LICENSE_FILE_NAME),n=ec.join(r,Yi.LICENSE_FILE_NAME),s=ec.join(r,Yi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),_r.info(i);let o="Creating .license directory";console.log(o),_r.info(o),tc.mkdirpSync(r);try{tc.accessSync(e);try{let c="Moving licence file";console.log(c),_r.info(c),tc.moveSync(e,n);let l="License file successfully moved.";console.log(l),_r.info(l)}catch{let l="moving license file failed";console.error(l),_r.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),_r.warn(l)}try{tc.accessSync(t);try{let c="Moving registration file";console.log(c),_r.info(c),tc.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),_r.info(l)}catch{let l="moving registration file failed";console.error(l),_r.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),_r.warn(l)}}a(Dme,"moveLicenseFiles");cC.sync_functions.push(Pme);cC.sync_functions.push(Dme);kY.push(cC);FY.exports=kY});var YY=w((_Ue,KY)=>{"use strict";var os=_t(),{insertRecords:Lme}=qc(),Mme=_n(),rc=xt(),vme=ie(),Vo=z(),Ume=ie(),Wi=require("fs-extra"),Ko=require("path"),xme=require("cli-progress"),dh=require("assert"),Bme=require("pino"),Hme=ae();KY.exports=kme;var AT,qY,RT,lC,sn,fh=!1;async function kme(e=!0){return AT=Hme.getHdbBasePath(),qY=Ko.join(AT,"schema"),RT=Ko.join(AT,"4_0_0_upgrade_tmp"),lC=Ko.join(AT,"transactions"),console.info("Reindexing upgrade started for schemas"),Vo.notify("Reindexing upgrade started for schemas"),await $Y(qY,!1,e),await Wi.pathExists(lC)&&(console.info(`
|
|
111
109
|
|
|
112
|
-
Reindexing upgrade started for transaction logs`),
|
|
113
|
-
install_user = ${l}`;try{rc.writeFileSync(o,u)}catch(d){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),d}try{aC.initSync(!0)}catch(d){throw console.error("Unable to initialize new properties. Please check the log for details."),d}let f="New settings file for 4.0.0 upgrade successfully created.";try{rc.removeSync(r),console.log(f),Fl.info(f)}catch(d){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),d}}a(sEe,"updateSettingsFile_4_0_0");hh.async_functions.push(sEe);hh.async_functions.push(rEe);hh.async_functions.push(eEe);hh.async_functions.push(nEe);QY.push(hh);JY.exports=QY});var cC=w((SUe,rW)=>{"use strict";var Gl=se(),iEe=(H(),C(q)),ZY=z(),{DATA_VERSION:oEe,UPGRADE_VERSION:aEe}=iEe.UPGRADE_JSON_FIELD_NAMES_ENUM,eW=qY(),bT=XY(),ql=new Map;eW&&eW.forEach(e=>{ql.set(e.version,e)});bT&&bT.forEach(e=>{ql.set(e.version,e)});bT&&bT.forEach(e=>{ql.set(e.version,e)});function cEe(){return[...ql.keys()].sort(Gl.compareVersions)}a(cEe,"getSortedVersions");function tW(e){let t=e[oEe],r=e[aEe];return Gl.isEmptyOrZeroLength(t)||Gl.isEmptyOrZeroLength(r)?(ZY.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),ZY.error("There was an error when trying to evaluate the version information for your instance. Trying to start the server anyways but it may fail. If you continue to have this problem, please contact support@harperdb.io."),[]):[...ql.keys()].sort(Gl.compareVersions).filter(function(n){return Gl.compareVersions(n,t)>0&&Gl.compareVersions(n,r)<=0})}a(tW,"getVersionsForUpgrade");function lEe(e){return tW(e).length>0}a(lEe,"hasUpgradesRequired");function uEe(e){return Gl.isEmptyOrZeroLength(e)?null:ql.has(e)?ql.get(e):null}a(uEe,"getDirectiveByVersion");rW.exports={getSortedVersions:cEe,getDirectiveByVersion:uEe,getVersionsForUpgrade:tW,hasUpgradesRequired:lEe}});var mh=w((AUe,aW)=>{"use strict";var dEe=require("util"),lC=require("chalk"),fEe=require("os"),sW=Rn(),_Ee=Yr(),ls=(H(),C(q)),iW=PY(),dC=My(),{UpgradeObject:nW}=MY(),{forceDowngradePrompt:pEe}=gT(),{packageJson:hEe}=st(),OT=z(),Kd=se(),fC=ys(),mEe=(Pe(),C(tt)),EEe=cC(),gEe=dEe.promisify(fC.setSchemaDataToGlobal),SEe=_Ee.searchByValue,TEe="info_id",AEe="2.9.9",REe="3.0.0";async function yEe(e){let t=new iW.HdbInfoInsertObject(1,e,e),r=new dC.InsertObject(ls.OPERATIONS_ENUM.INSERT,ls.SYSTEM_SCHEMA_NAME,ls.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,ls.INFO_TABLE_HASH_ATTRIBUTE,[t]);return fC.setSchemaDataToGlobal(),sW.insert(r)}a(yEe,"insertHdbInstallInfo");async function uC(e){let t,r=await oW(),n=new Map([[0,{}]]);for(let c of r)n.set(c.info_id,c);let i=Math.max.apply(null,[...n.keys()])+1;t=new iW.HdbInfoInsertObject(i,e,e);let o=new dC.InsertObject(ls.OPERATIONS_ENUM.INSERT,ls.SYSTEM_SCHEMA_NAME,ls.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,ls.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await gEe(),sW.insert(o)}a(uC,"insertHdbUpgradeInfo");async function oW(){let e=new dC.NoSQLSeachObject(ls.SYSTEM_SCHEMA_NAME,ls.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,TEe,ls.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await SEe(e))}catch(r){console.error(r)}return t}a(oW,"getAllHdbInfoRecords");async function bEe(){let e=await oW();if(e.length===0)return;let t,r=new Map;for(let s of e)r.set(s.info_id,s);let n=Math.max.apply(null,[...r.keys()]);return t=r.get(n),t}a(bEe,"getLatestHdbInfoRecord");async function OEe(){OT.info("Checking if HDB software has been updated");try{let e=hEe.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await bEe(),r;if(Kd.isEmpty(t))r=AEe;else if(r=t.data_version_num,Kd.compareVersions(r.toString(),e.toString())>0){if(!Kd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(lC.yellow(`This instance's data was last run on version ${r}`)),console.error(lC.red(`You have installed a version lower than the version that your data was created on or was upgraded to. This may cause issues and is currently not supported.${fEe.EOL}${ls.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Kd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(lC.yellow(`This instance's data was last run on version ${r}`)),await pEe(new nW(r,e))?await uC(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(fC.setSchemaDataToGlobal(),NEe(r),e.toString()===r.toString())return;let n=new nW(r,e);if(EEe.hasUpgradesRequired(n))return n;Kd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await uC(n.upgrade_version),OT.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw OT.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),OT.fatal(e),e}}a(OEe,"getVersionUpdateInfo");function NEe(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${ls.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in mEe.databases.system))throw console.log(t),new Error(t);if(!Kd.isEmpty(e)&&e<REe)throw console.log(t),new Error(t)}a(NEe,"checkIfInstallIsSupported");aW.exports={insertHdbInstallInfo:yEe,insertHdbUpgradeInfo:uC,getVersionUpdateInfo:OEe}});var dW=w((yUe,uW)=>{"use strict";var NT=require("joi"),{boolean:wEe,string:_C,number:IEe}=NT.types(),cW=require("fs-extra"),Eh=(H(),C(q)),lW=require("path"),CEe=ft();uW.exports=PEe;function PEe(e){let t=_C.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=NT.object({[Eh.INSTALL_PROMPTS.ROOTPATH]:NT.custom(DEe),[Eh.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:NT.alternatives([IEe.min(0),_C]).allow("null",null),[Eh.INSTALL_PROMPTS.TC_AGREEMENT]:_C.valid("yes","YES","Yes"),[Eh.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[Eh.INSTALL_PROMPTS.CLUSTERING_ENABLED]:wEe});return CEe.validateBySchema(e,r)}a(PEe,"installValidator");function DEe(e,t){if(cW.existsSync(lW.join(e,"system/hdb_user/data.mdb"))||cW.existsSync(lW.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(DEe,"validateRootAvailable")});var mC=w((OUe,fW)=>{"use strict";var{mkdirpSync:LEe,copySync:MEe}=require("fs-extra"),nc=require("path"),gh=(H(),C(q)),{PACKAGE_ROOT:vEe}=st(),hC=z(),UEe=Yn(),pC=Eo(),xEe=gt();fW.exports=BEe;async function BEe(e){hC.trace("Mounting HarperDB"),$l(e),$l(nc.join(e,"backup")),$l(nc.join(e,"keys")),$l(nc.join(e,"keys",gh.LICENSE_FILE_NAME)),$l(nc.join(e,"log")),$l(nc.join(e,"database")),$l(nc.join(e,"components")),MEe(nc.resolve(vEe,"./utility/install/README.md"),nc.join(e,"README.md")),await HEe()}a(BEe,"mountHdb");async function HEe(){let e=x_(),t=Object.keys(pC);for(let r=0;r<t.length;r++){let n=t[r],s=pC[n].hash_attribute;try{xEe.initSystemSchemaPaths(gh.SYSTEM_SCHEMA_NAME,n);let i=new e(gh.SYSTEM_SCHEMA_NAME,n,s);i.attributes=pC[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await UEe.createTable(n,i)}catch(i){throw hC.error(`issue creating environment for ${gh.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(HEe,"createLMDBTables");function $l(e){LEe(e,{mode:gh.HDB_FILE_PERMISSIONS}),hC.info(`Directory ${e} created`)}a($l,"makeDirectory")});var CT=w((CUe,OW)=>{"use strict";var gC=require("os"),EW=require("inquirer"),Hs=require("fs-extra"),kEe=require("properties-reader"),Kl=require("chalk"),Xi=require("path"),FEe=require("human-readable-ids").hri,GEe=require("ora"),qEe=require("yaml"),pr=z(),sc=ae(),Sh=se(),IT=da(),gW=mh(),{packageJson:SW}=st(),de=(H(),C(q)),{CONFIG_PARAM_MAP:wUe,CONFIG_PARAMS:Pt}=de,$Ee=dW(),VEe=mC(),SC=yt(),KEe=An(),YEe=q_(),WEe=XI(),zEe=ys(),jEe=require("util").promisify,QEe=jEe(zEe.setSchemaDataToGlobal),_W=ts(),Vl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),Hr=a(e=>Kl.magenta.bold(e),"HDB_PROMPT_MSG"),JEe="https://harperdb.io/legal/end-user-license-agreement",ic=gC.EOL,Wo="",XEe="yes",pW="Starting HarperDB install...",hW="HarperDB installation was successful.",mW="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",ZEe="An out of date version of HarperDB is already installed.",EC="It appears that HarperDB is already installed. Exiting install...",ege="Aborting install",IUe=new RegExp(/^([0-9]{1,4}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5])$/),tge=new RegExp(/^[^\s.,*>]+$/),rge=gC.homedir(),nge=Xi.join(rge,de.HDB_ROOT_DIR_NAME),sge="HDB_ADMIN",ige="CLUSTER_USER",oge="dev",age="localhost",wT={[Pt.HTTP_CORS]:!0,[Pt.HTTP_CORSACCESSLIST]:["*"],[Pt.HTTP_PORT]:9926,[Pt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Pt.THREADS_COUNT]:1,[Pt.THREADS_DEBUG]:!0,[Pt.LOGGING_STDSTREAMS]:!0,[Pt.LOGGING_LEVEL]:"info",[Pt.OPERATIONSAPI_NETWORK_PORT]:9925,[Pt.LOCALSTUDIO_ENABLED]:!0},Br={DESTINATION:"Please enter a destination for HarperDB:",HDB_USERNAME:"Please enter a username for the administrative user:",HDB_PASS:"Please enter a password for the administrative user:",NODE_NAME:"Please enter a unique name for this node:",CLUSTER_USERNAME:"Please enter a username for the CLUSTER_USER:",CLUSTER_PASS:"Please enter a password for the CLUSTER_USER:",DEFAULTS_MODE:"Default Config - dev (easy access/debugging) or prod (security/performance): (dev/prod)",REPLICATION_HOSTNAME:"Please enter the hostname for this server:"},oc=IT([de.INSTALL_PROMPTS.HDB_CONFIG]),Ji,TW=!1,TC=!1,AW=!1;OW.exports={install:RW,updateConfigEnv:gge,setIgnoreExisting:Sge};RW.createSuperUser=bW;async function RW(){console.log(Hr(ic+pW+ic)),pr.notify(pW);let e;oc[de.INSTALL_PROMPTS.HDB_CONFIG]&&(e=cge());let t=uge();Object.assign(t,e),t[de.INSTALL_PROMPTS.TC_AGREEMENT]&&t[de.INSTALL_PROMPTS.ROOTPATH]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[de.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(AW=!0,t[de.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=$Ee(t);if(r)throw r.message;await dge(),await fge(t);let n=await lge(t);Ji=n[de.INSTALL_PROMPTS.ROOTPATH],oc[de.INSTALL_PROMPTS.HDB_CONFIG]&&Xi.dirname(oc[de.INSTALL_PROMPTS.HDB_CONFIG])===Ji&&(TW=!0),!TC&&!oc[de.INSTALL_PROMPTS.HDB_CONFIG]&&await Hs.pathExists(Xi.join(Ji,de.HDB_CONFIG_FILE))&&(console.error(EC),process.exit());let s=GEe({prefixText:Hr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),Sh.isEmpty(Ji))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");sc.setHdbBasePath(Ji),await VEe(Ji),await _ge(),await pge(n),pr.initLogSettings(!0),await bW(n),await mge(n),await _W.updateConfigCert(),await _W.generateCertsKeys(),await Ege(),WEe(),s.stop(),console.log(Hr(ic+hW+ic)),pr.notify(hW)}a(RW,"install");function cge(){let e=qEe.parseDocument(Hs.readFileSync(oc[de.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=SC.flattenConfig(e.toJSON());return t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(cge,"getConfigFromFile");async function lge(e){pr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:Vl,when:zo(e[de.INSTALL_PROMPTS.ROOTPATH],Br.DESTINATION),name:de.INSTALL_PROMPTS.ROOTPATH,prefix:Wo,default:nge,validate:a(async s=>Bs(s)?Bs(s):await Hs.pathExists(Xi.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:Hr(Br.DESTINATION)},{type:"input",transformer:Vl,when:zo(e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Br.HDB_USERNAME),name:de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Wo,default:sge,validate:a(s=>Bs(s)?Bs(s):(t=s,!0),"validate"),message:Hr(Br.HDB_USERNAME)},{type:"password",when:zo(e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Br.HDB_PASS),name:de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Wo,validate:a(s=>Bs(s)?Bs(s):!0,"validate"),message:Hr(Br.HDB_PASS)},{type:"input",transformer:Vl,when:zo(e[de.INSTALL_PROMPTS.DEFAULTS_MODE],Br.DEFAULTS_MODE),name:de.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Wo,default:oge,validate:a(s=>Bs(s)?Bs(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:Hr(Br.DEFAULTS_MODE)}];if(AW||r.push({type:"input",name:de.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:Vl,when:zo(e[de.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Br.REPLICATION_HOSTNAME),prefix:Wo,default:age,message:Hr(Br.REPLICATION_HOSTNAME)}),Sh.autoCastBoolean(e[de.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:Vl,when:zo(e[de.INSTALL_PROMPTS.CLUSTERING_NODENAME],Br.NODE_NAME),name:de.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Wo,default:FEe.random(),validate:a(i=>tge.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:Hr(Br.NODE_NAME)},{type:"input",transformer:Vl,when:zo(e[de.INSTALL_PROMPTS.CLUSTERING_USER],Br.CLUSTER_USERNAME),name:de.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Wo,default:ige,validate:a(i=>Bs(i)?Bs(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:Hr(Br.CLUSTER_USERNAME)},{type:"password",when:zo(e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Br.CLUSTER_PASS),name:de.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Wo,validate:a(i=>Bs(i)?Bs(i):!0,"validate"),message:Hr(Br.CLUSTER_PASS)}];r.push(...s)}let n=await EW.prompt(r);if(Object.keys(n).length===0)return e;for(let s in n)e[s]===void 0&&(e[s]=n[s]);return e}a(lge,"installPrompts");function zo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${Hr(t)} ${Kl.gray("[hidden]")}`),pr.trace(`${Hr(t)} [hidden]`)):(console.log(`${Hr(t)} ${e}`),pr.trace(`${Hr(t)} ${e}`)),!1):!0}a(zo,"displayCmdEnvVar");function Bs(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(Bs,"checkForEmptyValue");function uge(){let e=Object.keys(de.INSTALL_PROMPTS),t=IT(e),r=IT(Object.keys(de.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=de.CONFIG_PARAM_MAP[s.toLowerCase()];t[s]?i===void 0?n[s]=t[s]:n[i.toUpperCase()]=t[s]:i!==void 0&&r[i.toLowerCase()]&&(n[s]=r[i.toLowerCase()])}return n}a(uge,"checkForPromptOverride");async function dge(){pr.trace("Checking for existing install.");let e=Sh.getPropsFilePath(),t=await Hs.pathExists(e),r;if(t){pr.trace(`Install found an existing boot prop file at:${e}`);let n=kEe(e),s=SC.getConfigValue(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Hs.pathExists(s)}if(!t&&Sh.noBootFile()&&(r=!0),r&&!TC){if(pr.trace(`Install found existing HDB config at:${e}`),await gW.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${SW.version}. Exiting install...`;console.log(ic+Kl.magenta.bold(ZEe)),console.log(Kl.magenta.bold(s)),pr.error(s)}else console.log(ic+Kl.magenta.bold(EC)),pr.error(EC);process.exit(0)}}a(dge,"checkForExistingInstall");async function fge(e){pr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${JEe}${ic}and can be viewed by typing or copying and pasting the URL into your web browser.${ic}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Wo,transformer:Vl,when:zo(e[de.INSTALL_PROMPTS.TC_AGREEMENT],t),name:de.INSTALL_PROMPTS.TC_AGREEMENT,message:Hr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:Kl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await EW.prompt([r]);n[de.INSTALL_PROMPTS.TC_AGREEMENT]&&n[de.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==XEe&&(console.log(Kl.yellow(mW)),pr.error(mW),process.exit(0))}a(fge,"termsAgreement");async function _ge(){let e=Xi.join(Ji,de.HDB_CONFIG_FILE),t;try{t=gC.userInfo().username}catch{t=process.env.USERNAME||process.env.USER||process.env.LOGNAME||process.env.LNAME||process.env.SUDO_USER}if(t){let r=`settings_path = ${e}
|
|
114
|
-
install_user = ${t}`,n=Sh.getHomeDir(),s=Xi.join(n,de.HDB_HOME_DIR_NAME),i=Xi.join(s,de.LICENSE_KEY_DIR_NAME);try{Hs.mkdirpSync(s,{mode:de.HDB_FILE_PERMISSIONS}),Hs.mkdirpSync(i,{mode:de.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${de.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Xi.join(s,de.BOOT_PROPS_FILE_NAME);try{await Hs.writeFile(o,r)}catch(c){throw pr.error(`There was an error creating the boot file at path: ${o}`),c}sc.setProperty(de.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),sc.setProperty(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),sc.setProperty(sc.BOOT_PROPS_FILE_PATH,o)}}a(_ge,"createBootPropertiesFile");async function pge(e){pr.trace("Creating HarperDB config file");let t=IT(Object.keys(de.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[de.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in wT){if(r===Pt.HTTP_PORT&&t[Pt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??wT[r],t[Pt.HTTP_SECUREPORT]=null;continue}else if(r===Pt.HTTP_PORT)continue;if(r===Pt.OPERATIONSAPI_NETWORK_PORT&&t[Pt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??wT[r],t[Pt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Pt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=wT[r])}}else t[Pt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Pt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Pt.HTTP_PORT.toLowerCase()]&&(t[Pt.HTTP_SECUREPORT]=null);try{oc[de.INSTALL_PROMPTS.HDB_CONFIG]||SC.createConfigFile(t),sc.initSync()}catch(r){hge(r)}}a(pge,"createConfigFile");function hge(e){pr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(ege);let t=Xi.resolve(sc.get(sc.BOOT_PROPS_FILE_PATH),"../");t&&Hs.removeSync(t),Ji&&(TW?Hs.readdirSync(Ji,{withFileTypes:!0}).forEach(n=>{let s=Xi.join(n.path,n.name);s!==oc[de.INSTALL_PROMPTS.HDB_CONFIG]&&Hs.removeSync(s)}):Hs.removeSync(Ji)),process.exit(1)}a(hge,"rollbackInstall");async function yW(e,t){pr.trace("Creating admin user"),await QEe();let r;try{r=await YEe.addRole(e)}catch(n){if(n.message.includes("already exists"))t=void 0;else throw n.message+="Error creating role",n}if(t)try{t.role=r.role,await KEe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(yW,"createAdminUser");async function bW(e){pr.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await yW(t,r),delete e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(bW,"createSuperUser");async function mge(e){pr.trace("Creating Cluster user.");let t;e[de.INSTALL_PROMPTS.CLUSTERING_USER]&&e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[de.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await yW({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[de.INSTALL_PROMPTS.CLUSTERING_USER],delete e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(mge,"createClusterUser");async function Ege(){let e=SW.version;if(e)await gW.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(Ege,"insertHdbVersionInfo");function gge(e){oc[de.INSTALL_PROMPTS.HDB_CONFIG]=e}a(gge,"updateConfigEnv");function Sge(e){TC=e}a(Sge,"setIgnoreExisting")});var IW=w((DUe,wW)=>{"use strict";var AC=se(),us=z(),NW=cC();wW.exports={processDirectives:Tge};async function Tge(e){console.log("Starting upgrade process...");let t=NW.getVersionsForUpgrade(e),r=yge(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;us.notify(c),console.log(c);let l=[],u=[];try{l=Age(o.sync_functions)}catch(f){throw us.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await Rge(o.async_functions)}catch(f){throw us.error(`Error while running an upgrade script for ${o.version}`),f}n.push(...l,...u)}return n}a(Tge,"processDirectives");function Age(e){if(AC.isEmptyOrZeroLength(e))return us.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return us.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(us.info(`Running function ${r.name}`),!(r instanceof Function)){us.info("Variable being processed is not a function");continue}let n=r();us.info(n),t.push(n)}return t}a(Age,"runSyncFunctions");async function Rge(e){if(AC.isEmptyOrZeroLength(e))return us.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return us.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(us.info(`Running function ${s.name}`),!(s instanceof Function)){us.info("Variable being processed is not a function");continue}let i=await s();us.info(i),t.push(i)}return t}a(Rge,"runAsyncFunctions");function yge(e){if(AC.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=NW.getDirectiveByVersion(r);n&&t.push(n)}return t}a(yge,"getUpgradeDirectivesToInstall")});var OC=w((MUe,vW)=>{"use strict";var PT=ae();PT.initSync();var LW=require("chalk"),CW=require("fs-extra"),Qo=z(),jo=(H(),C(q)),bge=IW(),RC=se(),MW=mh(),Oge=gT(),PW=nR(),Nge=ys(),{packageJson:DW}=st(),wge=require("util").promisify,Ige=wge(Nge.setSchemaDataToGlobal),yC,{UPGRADE_VERSION:bC}=jo.UPGRADE_JSON_FIELD_NAMES_ENUM;vW.exports={upgrade:Cge};async function Cge(e){await Ige(),yC===void 0&&(yC=Id()),CW.existsSync(PT.get(PT.BOOT_PROPS_FILE_PATH))||(Th("The hdb_boot_properties file was not found. Please install HDB.",jo.LOG_LEVELS.ERROR),process.exit(1)),CW.existsSync(PT.get(jo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(Th("The hdb settings file was not found. Please make sure HDB is installed.",jo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await MW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),Th(`This version of HarperDB is ${DW.version}`,jo.LOG_LEVELS.INFO);let r=t[bC]??DW.version;r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${jo.HDB_SUPPORT_ADDRESS}`),Qo.notify("Missing new version field from upgrade info object"),process.exit(1)),await Pge();let n,s=0;try{n=await Oge.forceUpdatePrompt(t)}catch(i){Qo.error("There was an error when prompting user about upgrade."),Qo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),Qo.info(`Starting upgrade to version ${r}`),await Dge(t),Th(`HarperDB was successfully upgraded to version ${t[bC]}`,jo.LOG_LEVELS.INFO)}a(Cge,"upgrade");async function Pge(){let e=!1,t=await PW.findPs(jo.HDB_PROC_NAME);if(RC.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await PW.findPs("hdb_express");RC.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await yC.list();RC.isEmptyOrZeroLength(r)||(e=!0)}if(e){let r="HarperDB is running, please stop all HarperDB services with 'harperdb stop' and run the upgrade command again.";console.log(LW.red(r)),Qo.error(r),process.exit(1)}}a(Pge,"checkIfRunning");async function Dge(e){try{await bge.processDirectives(e)}catch(t){throw Th("There was an error during the data upgrade. Please check the logs.",jo.LOG_LEVELS.ERROR),t}try{await MW.insertHdbUpgradeInfo(e[bC])}catch(t){Qo.error("Error updating the 'hdb_info' system table."),Qo.error(t)}}a(Dge,"runUpgrade");function Th(e,t=void 0){t||(t=Qo.info),Qo[t](e),console.log(LW.magenta(e))}a(Th,"printToLogAndConsole")});var kW={};ve(kW,{onStorageReclamation:()=>Ah,runReclamationHandlers:()=>CC,setAvailableSpaceRatioGetter:()=>Mge});function Ah(e,t,r){(r||(0,LT.getWorkerIndex)()===(0,LT.getWorkerCount)()-1)&&(DT.has(e)||DT.set(e,[]),DT.get(e).push({priority:0,handler:t}),IC||(IC=setTimeout(CC,xW).unref()))}async function CC(){for(let[e,t]of DT)try{let r=await HW(e),n=Lge/r;for(let s of t){let{priority:i,handler:o}=s;if(s.priority=n,n>1||i>1){let c=o(n>1?n:0);c&&(wC.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){wC.default.error?.("Error running storage reclamation handlers",r)}IC=setTimeout(CC,xW).unref()}function Mge(e){HW=e??BW}var NC,LT,wC,MT,UW,DT,Lge,xW,IC,BW,HW,vT=be(()=>{NC=require("node:fs/promises"),LT=M(et()),wC=M(Ii());H();MT=M(ae()),UW=M(se());MT.default.initSync();DT=new Map,Lge=MT.default.get(B.STORAGE_RECLAMATION_THRESHOLD)??.4,xW=(0,UW.convertToMS)(MT.default.get(B.STORAGE_RECLAMATION_INTERVAL))||36e5;a(Ah,"onStorageReclamation");BW=a(async e=>{if(NC.statfs){let t=await(0,NC.statfs)(e);return t.bavail/t.blocks}else return new Promise((t,r)=>{import("hdd-space").then(n=>{n.default(s=>{for(let i of s.parts)if(e.startsWith(i.place))return t(i.free/i.size);return t(1)})})})},"defaultGetAvailableSpaceRatio"),HW=BW;a(CC,"runReclamationHandlers");a(Mge,"setAvailableSpaceRatioGetter")});var VW=w((BUe,$W)=>{"use strict";var{promises:Yd,createReadStream:vge,createWriteStream:Uge}=require("fs"),{createGzip:xge}=require("zlib"),{promisify:Bge}=require("util"),{pipeline:Hge}=require("stream"),kge=Bge(Hge),DC=require("path"),cc=ae();cc.initSync();var ac=z(),{CONFIG_PARAMS:Wd,ITC_EVENT_TYPES:Fge}=(H(),C(q)),{onMessageFromWorkers:Gge}=et(),{convertToMS:qge}=se(),{onStorageReclamation:$ge}=(vT(),C(kW)),Vge=6e4,Kge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Yge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",PC,GW;$W.exports=qW;Gge(e=>{e.type===Fge.RESTART&&(cc.initSync(!0),clearInterval(GW),cc.get(Wd.LOGGING_ROTATION_ENABLED)&&qW())});async function qW(){try{let e=ac.getLogFilePath(),t=cc.get(Wd.LOGGING_ROTATION_MAXSIZE),r=cc.get(Wd.LOGGING_ROTATION_INTERVAL),n=cc.get(Wd.LOGGING_ROTATION_RETENTION),s=0;if($ge(e,l=>{s=l},!0),!t&&!r){ac.error(Kge);return}let i=cc.get(Wd.LOGGING_ROTATION_PATH);if(!i){ac.error(Yge);return}let o;if(t){let l=t.slice(-1),u=t.slice(0,-1);l==="G"?o=u*1e9:l==="M"?o=u*1e6:o=u*1e3}let c;if(r){let l=r.slice(-1),u=r.slice(0,-1);l==="D"?c=u*1440:l==="H"?c=u*60:c=u}PC=Date.now()/6e4,ac.trace("Log rotate enabled, maxSize:",t,"interval:",r),GW=setInterval(async()=>{if(o){let l;l=await Yd.stat(e),l.size>=o&&await FW(e,i)}if(c&&Date.now()/6e4-PC>=c&&(await FW(e,i),PC=Date.now()/6e4),n||s){let l=qge(n??"1M")/(1+s);s=0;let u=await Yd.readdir(i);for(let f of u)try{let d=await Yd.stat(DC.join(i,f));Date.now()-d.mtimeMs>l&&await Yd.unlink(DC.join(i,f))}catch(d){ac.error("Error trying to remove log",f,d)}}},Vge).unref()}catch(e){ac.error(e)}}a(qW,"logRotator");async function FW(e,t){let r=cc.get(Wd.LOGGING_ROTATION_COMPRESS),n=DC.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);await Yd.rename(e,n),r&&(e=n,n+=".gz",await kge(vge(e),xge(),Uge(n)),await Yd.unlink(e)),ac.closeLogFile(),ac.notify(`hdb.log rotated, old log moved to ${n}`)}a(FW,"moveLogFile")});var jd=w(JW=>{"use strict";var Se=ae();Se.initSync();za();var kt=(H(),C(q)),{CONFIG_PARAMS:Ie}=kt,ds=z(),Jo=require("fs-extra"),Xo=require("path"),Wge=XI(),{install:zge}=CT(),LC=require("chalk"),{packageJson:jge,PACKAGE_ROOT:Qge}=st(),Zo=se(),MC=yt(),YW=da(),KW=SS(),Jge=OC(),Xge=VW(),{compactOnStart:Zge}=(wS(),C(NS)),eSe=require("minimist"),tSe=ts(),{startHTTPThreads:rSe}=(vC(),C(XW)),nSe=mh(),{isMainThread:sSe}=require("worker_threads"),kUe=Eo(),FUe=Ao(),GUe=Ib(),qUe=x_(),UT=(H(),C(q)),Zi,zd,WW=!1,iSe="Upgrade complete. Starting HarperDB.",oSe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",aSe="HarperDB not found, starting install process.",cSe="There was an error during install, check install_log.log for more details. Exiting.",lSe="HarperDB successfully started.";function uSe(){if(!WW){let e=a(()=>{Jo.removeSync(Xo.join(Se.get(kt.CONFIG_PARAMS.ROOTPATH),kt.HDB_PID_FILE)),process.exit(0)},"remove_hdb_pid");process.on("exit",()=>{e()}),process.on("SIGINT",()=>{e()}),process.on("SIGQUIT",()=>{e()}),process.on("SIGTERM",()=>{e()})}}a(uSe,"addExitListeners");async function zW(e=!1,t=!1){if(console.log(LC.magenta("Starting HarperDB...")),ds.suppressLogging?.(()=>{console.log(LC.magenta(""+Jo.readFileSync(Xo.join(Qge,"utility/install/ascii_logo.txt"))))}),await QW()===!1){console.log(aSe);try{await zge()}catch(l){console.error(cSe,l),ds.error(l),process.exit(1)}}if(!e){let l=YW(Object.keys(kt.CONFIG_PARAM_MAP),!0);!Zo.isEmpty(l)&&!Zo.isEmptyOrZeroLength(Object.keys(l))&&MC.updateConfigValue(void 0,void 0,l,!0,!0)}let r,n=zd?.service==="clustering";zd?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));let s=Xo.join(Se.get(kt.CONFIG_PARAMS.ROOTPATH),kt.HDB_PID_FILE),i=hSe(s);i&&i!==1&&mSe(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),Zi===void 0&&(Zi=Id()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),Se.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await KW.generateNatsConfig(),await Zi.startClusteringProcesses(!0),process.exit()),uSe(),await Jo.writeFile(Xo.join(Se.get(UT.CONFIG_PARAMS.ROOTPATH),UT.HDB_PID_FILE),`${process.pid}`),ds.info("HarperDB PID",process.pid);let o;try{let l=await nSe.getVersionUpdateInfo();l!==void 0&&(o=l[kt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Jge.upgrade(l),console.log(iSe))}catch(l){o?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${o}. Exiting HarperDB.`,l),ds.error(l)):(console.error(oSe,l),ds.error(l)),process.exit(1)}Wge(),_Se(),await tSe.reviewSelfSignedCert(),Zo.autoCastBoolean(Se.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&sSe&&await KW.generateNatsConfig(t)}a(zW,"initialize");async function dSe(e=!1){try{zd=eSe(process.argv),zd.ROOTPATH&&MC.updateConfigObject("settings_path",Xo.join(zd.ROOTPATH,kt.HDB_CONFIG_FILE)),await zW(e,!0),Se.get(kt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Zge();let t=process.env.IS_SCRIPTED_SERVICE&&!zd.service;Zo.autoCastBoolean(Se.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Zi.startClusteringProcesses(),await Zi.startClusteringThreads()),await rSe(process.env.DEV_MODE?1:Se.get(UT.CONFIG_PARAMS.THREADS_COUNT)??Se.get(UT.CONFIG_PARAMS.THREADS)),Se.get(kt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Xge(),t||jW()}catch(t){console.error(t),ds.error(t),process.exit(1)}}a(dSe,"main");function jW(){ds.suppressLogging(()=>{console.log(LC.magenta(`HarperDB ${jge.version} successfully started`))}),ds.notify(lSe)}a(jW,"started");async function fSe(e=!0){WW=!e;try{Zi===void 0&&(Zi=Id()),Zi.enterPM2Mode(),await zW(),Zo.autoCastBoolean(Se.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Zi.startClusteringProcesses(),await Zi.startService(kt.PROCESS_DESCRIPTORS.HDB),jW(),e&&process.exit(0)}catch(t){console.error(t),ds.error(t),process.exit(1)}}a(fSe,"launch");function _Se(){let e=Xo.join(Se.get(kt.CONFIG_PARAMS.ROOTPATH),kt.LICENSE_KEY_DIR_NAME,kt.LICENSE_FILE_NAME),t=Xo.join(e,kt.LICENSE_FILE_NAME),r=Xo.join(e,kt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=YW(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Zo.isEmpty(n)||Zo.isEmpty(s))return;Jo.mkdirpSync(e),Jo.writeFileSync(r,n),Jo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),ds.error(s)}}a(_Se,"writeLicenseFromVars");Object.assign(JW,{launch:fSe,main:dSe,isHdbInstalled:QW,startupLog:pSe});async function QW(){try{await Jo.stat(Zo.getPropsFilePath()),await Jo.stat(Se.get(kt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Zo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw ds.error(`Error checking for HDB install - ${e}`),e}return!0}a(QW,"isHdbInstalled");function pSe(e){let r=a(_=>_.padEnd(20),"pad"),n=`
|
|
115
|
-
`;
|
|
116
|
-
`),
|
|
117
|
-
`),n+=`${r("Worker Threads:")}${
|
|
118
|
-
`,n+=`${r("Root Path:")}${
|
|
119
|
-
`,
|
|
110
|
+
Reindexing upgrade started for transaction logs`),Vo.notify("Reindexing upgrade started for transaction logs"),await $Y(lC,!0,e)),Vo.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(fh?", but errors occurred":"")}a(kme,"reindexUpgrade");async function $Y(e,t,r){let n=await Wi.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Ko.join(e,o.toString());if(o===".DS_Store")continue;let l=await Wi.readdir(c),u=l.length;for(let f=0;f<u;f++){let d=l[f];if(d!==".DS_Store"&&Wi.statSync(Ko.join(c,d)).isDirectory())try{await Fme(o,d,t),sn.info(`Reindexing started for ${o}.${d}`),Vo.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${d}`),await qme(o,d,c,t,r),sn.info(`Reindexing completed for ${o}.${d}`),Vo.notify(`Reindexing completed for ${o}.${d}`)}catch(p){fh=!0,p.schema_path=c,p.table_name=d,Vo.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Vo.error(p),sn.error(p),console.error(p)}}}if(!fh)try{await Wi.rm(RT,{recursive:!0})}catch{}}a($Y,"processTables");async function Fme(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Ko.join(RT,s);await Wi.ensureDir(RT),await Wi.writeFile(i,""),sn=Bme({level:"debug",formatters:{bindings(){}}},i)}a(Fme,"initPinoLogger");var Gme=20;async function qme(e,t,r,n,s){let i;try{i=await os.openEnvironment(r,t,n)}catch(E){if(E.message==="MDB_INVALID: File is not an LMDB file"){Vo.notify(`${e}.${t} file is not from the old environment and has been skipped`),console.info(`${e}.${t} file is not from the old environment and has been skipped`),sn.error(E);return}throw E}let o=Kme(i.dbis),c=os.openDBI(i,o),l=Object.keys(i.dbis),u=os.statDBI(i,o);sn.info(`Old environment stats: ${JSON.stringify(u)}`);let f=new xme.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});f.start(u.entryCount,0,{});let d=await os.createEnvironment(r,t,!1);os.createDBI(d,o,!1,!0);let p=[];try{for(let E of c.getRange({start:!1}))E.value={...E.value},p.push(E),n||e==="system"&&(t==="hdb_schema"&&(E.key=E.key.toString(),E.value.name=E.value.name.toString()),t==="hdb_table"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.name=E.value.name.toString()),t==="hdb_attribute"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.table=E.value.table.toString(),E.value.attribute=E.value.attribute.toString())),p.length>Gme&&await _();await _()}catch(E){throw fh=!0,sn.error(E),E}async function _(){let E,T=p.map(({value:v})=>v);n?E=await Promise.all(T.map(v=>$me(d,v))):E=await Lme(d,o,l.filter(v=>v!=="__blob__"),T,!1);for(let v=0,F=p.length;v<F;v++){let{key:q,value:Y}=p[v];sn.info(`Record hash value: ${q} hash: ${o}`);let Z;n?Z=E[v]:Z=E.written_hashes.indexOf(q)>-1,dh(Z,!0),Vme(d,o,Y[o],n),sn.info(`Insert success, written hashes: ${E.written_hashes}`),f.increment()}p=[],f.value/f.total*100%10===0&&Vo.notify(`${e}.${t} ${f.value}/${f.total} records inserted`),sn.info(`${f.value}/${f.total} records inserted`)}a(_,"finishOutstanding"),f.stop();let h=os.statDBI(i,o),S=os.statDBI(d,o);if(sn.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${S.entryCount}`),dh.deepStrictEqual(h.entryCount,S.entryCount),await os.closeEnvironment(i),await os.closeEnvironment(d),delete global.lmdb_map[`${e}.${t}`],s){let E=Ko.join(r,t),T=Ko.join(E,"data.mdb"),b=Ko.join(E,"lock.mdb");await Wi.unlink(T),await Wi.unlink(b),await Wi.rmdir(E),sn.info(`Deleted old environment files from schema folder: ${T}, ${b}`)}let g=await os.openEnvironment(r,t),R=os.statDBI(g,o);sn.info(`New stats: ${JSON.stringify(S)}. New stats after move: ${JSON.stringify(R)}`),dh.deepStrictEqual(R.entryCount,S.entryCount),await os.closeEnvironment(g),delete global.lmdb_map[`${e}.${t}`]}a(qme,"processTable");async function $me(e,t){os.initializeDBIs(e,rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,rc.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),Ume.isEmpty(t.user_name)||e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a($me,"insertTransaction");function Vme(e,t,r,n){let i=e.dbis[t].get(r);dh.deepStrictEqual(typeof i,"object");let o;if(n){let c={[rc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[rc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE]:i.hash_values};o=Object.entries(c)}else o=Object.entries(i);for(let[c,l]of o)if(c!==t&&e.dbis[c]!==void 0&&!vme.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let u=0,f=l.length;u<f;u++){let d=l[u];VY(e,c,d,r)}else VY(e,c,l,r)}a(Vme,"validateIndices");function VY(e,t,r,n){try{let s=!1,i=Mme.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||sn.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),dh.deepStrictEqual(s,!0)}catch(s){fh=!0,sn.error(s),console.error(s)}}a(VY,"validateIndex");function Kme(e){let t;for(let[r,n]of Object.entries(e))if(n.__dbi_defintion__.is_hash_attribute===!0){t=r;break}return t}a(Kme,"getHashDBI")});var QY=w((mUe,JY)=>{"use strict";var yT=require("path"),nc=require("fs-extra"),Yme=aC(),$l=z(),WY=yt(),uC=ae(),Ei=(H(),C(G)),bT=ie(),Wme=require("properties-reader"),zme=ni(),jme=ng(),Jme=Yr(),hUe=require("util"),Qme=Jme.searchByValue,Xme=yn(),Zme=dS(),eEe=Tt(),tEe=YY(),zY=Zn(),rEe=ST(),hh=new Yme("4.0.0"),jY=[],_h,ph;async function nEe(){try{if(await rEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),_h){let t=bT.changeExtension(_h,".bak");await nc.move(_h,t)}if(ph){let t=bT.changeExtension(ph,".bak");await nc.move(ph,t)}await zY.generateKeys()}else console.log("Using existing certificates."),zY.updateConfigCert(_h,ph,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(nEe,"generateNewKeys");async function sEe(){console.log("Updating HarperDB nodes."),$l.info("Updating HarperDB nodes.");let e=[];try{let t=new zme(Ei.SYSTEM_SCHEMA_NAME,Ei.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await Qme(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!eEe.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let f=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(f),f}let l={host:c.host,port:c.port};e.push(l);let u=[];for(let f=0,d=c.subscriptions.length;f<d;f++){let p=c.subscriptions[f],_=p.channel.split(":");u.push({schema:_[0],table:_[1],publish:p.publish,subscribe:p.subscribe})}n.push({name:c.name,subscriptions:u,system_info:{hdb_version:Ei.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(bT.isEmptyOrZeroLength(n))return;let s=new jme(Ei.SYSTEM_SCHEMA_NAME,Ei.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await Xme.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{Zme.setRoutes({server:"hub",routes:e})}catch(t){throw console.error("There was a problem setting the clustering routes. Please check the log for details."),t}}a(sEe,"updateNodes");async function iEe(){let e=uC.get(Ei.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(yT.join("config","settings.js"))){$l.info("pre 4.0.0 settings.js file not found, skipping settings file update");return}let t="Updating settings file for version 4.0.0";console.log(t),$l.info(t);let r=yT.dirname(e),n=uC.get(Ei.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=yT.join(n,"backup","4_0_0_upgrade_settings.bak"),i=yT.join(n,Ei.HDB_CONFIG_FILE);try{$l.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),nc.copySync(e,s)}catch(d){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),d}try{$l.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),$l.info("Updating env variables with new settings values");let d=WY.initOldConfig(e);_h=d[Ei.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],ph=d[Ei.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],WY.createConfigFile(d)}catch(d){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),d}let o=bT.getPropsFilePath();nc.accessSync(o,nc.constants.F_OK|nc.constants.R_OK);let l=Wme(o).get(Ei.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
|
|
111
|
+
install_user = ${l}`;try{nc.writeFileSync(o,u)}catch(d){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),d}try{uC.initSync(!0)}catch(d){throw console.error("Unable to initialize new properties. Please check the log for details."),d}let f="New settings file for 4.0.0 upgrade successfully created.";try{nc.removeSync(r),console.log(f),$l.info(f)}catch(d){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),d}}a(iEe,"updateSettingsFile_4_0_0");hh.async_functions.push(iEe);hh.async_functions.push(nEe);hh.async_functions.push(tEe);hh.async_functions.push(sEe);jY.push(hh);JY.exports=jY});var dC=w((gUe,tW)=>{"use strict";var Vl=ie(),oEe=(H(),C(G)),XY=z(),{DATA_VERSION:aEe,UPGRADE_VERSION:cEe}=oEe.UPGRADE_JSON_FIELD_NAMES_ENUM,ZY=GY(),OT=QY(),Kl=new Map;ZY&&ZY.forEach(e=>{Kl.set(e.version,e)});OT&&OT.forEach(e=>{Kl.set(e.version,e)});OT&&OT.forEach(e=>{Kl.set(e.version,e)});function lEe(){return[...Kl.keys()].sort(Vl.compareVersions)}a(lEe,"getSortedVersions");function eW(e){let t=e[aEe],r=e[cEe];return Vl.isEmptyOrZeroLength(t)||Vl.isEmptyOrZeroLength(r)?(XY.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),XY.error("There was an error when trying to evaluate the version information for your instance. Trying to start the server anyways but it may fail. If you continue to have this problem, please contact support@harperdb.io."),[]):[...Kl.keys()].sort(Vl.compareVersions).filter(function(n){return Vl.compareVersions(n,t)>0&&Vl.compareVersions(n,r)<=0})}a(eW,"getVersionsForUpgrade");function uEe(e){return eW(e).length>0}a(uEe,"hasUpgradesRequired");function dEe(e){return Vl.isEmptyOrZeroLength(e)?null:Kl.has(e)?Kl.get(e):null}a(dEe,"getDirectiveByVersion");tW.exports={getSortedVersions:lEe,getDirectiveByVersion:dEe,getVersionsForUpgrade:eW,hasUpgradesRequired:uEe}});var mh=w((TUe,oW)=>{"use strict";var fEe=require("util"),fC=require("chalk"),_Ee=require("os"),nW=yn(),pEe=Yr(),as=(H(),C(G)),sW=CY(),pC=Uy(),{UpgradeObject:rW}=LY(),{forceDowngradePrompt:hEe}=ST(),{packageJson:mEe}=it(),NT=z(),Wd=ie(),hC=As(),EEe=(De(),C(nt)),gEe=dC(),SEe=fEe.promisify(hC.setSchemaDataToGlobal),TEe=pEe.searchByValue,AEe="info_id",REe="2.9.9",yEe="3.0.0";async function bEe(e){let t=new sW.HdbInfoInsertObject(1,e,e),r=new pC.InsertObject(as.OPERATIONS_ENUM.INSERT,as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,as.INFO_TABLE_HASH_ATTRIBUTE,[t]);return hC.setSchemaDataToGlobal(),nW.insert(r)}a(bEe,"insertHdbInstallInfo");async function _C(e){let t,r=await iW(),n=new Map([[0,{}]]);for(let c of r)n.set(c.info_id,c);let i=Math.max.apply(null,[...n.keys()])+1;t=new sW.HdbInfoInsertObject(i,e,e);let o=new pC.InsertObject(as.OPERATIONS_ENUM.INSERT,as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,as.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await SEe(),nW.insert(o)}a(_C,"insertHdbUpgradeInfo");async function iW(){let e=new pC.NoSQLSeachObject(as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,AEe,as.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await TEe(e))}catch(r){console.error(r)}return t}a(iW,"getAllHdbInfoRecords");async function OEe(){let e=await iW();if(e.length===0)return;let t,r=new Map;for(let s of e)r.set(s.info_id,s);let n=Math.max.apply(null,[...r.keys()]);return t=r.get(n),t}a(OEe,"getLatestHdbInfoRecord");async function NEe(){NT.info("Checking if HDB software has been updated");try{let e=mEe.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await OEe(),r;if(Wd.isEmpty(t))r=REe;else if(r=t.data_version_num,Wd.compareVersions(r.toString(),e.toString())>0){if(!Wd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(fC.yellow(`This instance's data was last run on version ${r}`)),console.error(fC.red(`You have installed a version lower than the version that your data was created on or was upgraded to. This may cause issues and is currently not supported.${_Ee.EOL}${as.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Wd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(fC.yellow(`This instance's data was last run on version ${r}`)),await hEe(new rW(r,e))?await _C(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(hC.setSchemaDataToGlobal(),wEe(r),e.toString()===r.toString())return;let n=new rW(r,e);if(gEe.hasUpgradesRequired(n))return n;Wd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await _C(n.upgrade_version),NT.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw NT.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),NT.fatal(e),e}}a(NEe,"getVersionUpdateInfo");function wEe(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${as.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in EEe.databases.system))throw console.log(t),new Error(t);if(!Wd.isEmpty(e)&&e<yEe)throw console.log(t),new Error(t)}a(wEe,"checkIfInstallIsSupported");oW.exports={insertHdbInstallInfo:bEe,insertHdbUpgradeInfo:_C,getVersionUpdateInfo:NEe}});var uW=w((RUe,lW)=>{"use strict";var wT=require("joi"),{boolean:IEe,string:mC,number:CEe}=wT.types(),aW=require("fs-extra"),Eh=(H(),C(G)),cW=require("path"),PEe=ot();lW.exports=DEe;function DEe(e){let t=mC.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=wT.object({[Eh.INSTALL_PROMPTS.ROOTPATH]:wT.custom(LEe),[Eh.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:wT.alternatives([CEe.min(0),mC]).allow("null",null),[Eh.INSTALL_PROMPTS.TC_AGREEMENT]:mC.valid("yes","YES","Yes"),[Eh.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[Eh.INSTALL_PROMPTS.CLUSTERING_ENABLED]:IEe});return PEe.validateBySchema(e,r)}a(DEe,"installValidator");function LEe(e,t){if(aW.existsSync(cW.join(e,"system/hdb_user/data.mdb"))||aW.existsSync(cW.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(LEe,"validateRootAvailable")});var SC=w((bUe,dW)=>{"use strict";var{mkdirpSync:MEe,copySync:vEe}=require("fs-extra"),sc=require("path"),gh=(H(),C(G)),{PACKAGE_ROOT:UEe}=it(),gC=z(),xEe=Vn(),EC=po(),BEe=gt();dW.exports=HEe;async function HEe(e){gC.trace("Mounting HarperDB"),Yl(e),Yl(sc.join(e,"backup")),Yl(sc.join(e,"keys")),Yl(sc.join(e,"keys",gh.LICENSE_FILE_NAME)),Yl(sc.join(e,"log")),Yl(sc.join(e,"database")),Yl(sc.join(e,"components")),vEe(sc.resolve(UEe,"./utility/install/README.md"),sc.join(e,"README.md")),await kEe()}a(HEe,"mountHdb");async function kEe(){let e=v_(),t=Object.keys(EC);for(let r=0;r<t.length;r++){let n=t[r],s=EC[n].hash_attribute;try{BEe.initSystemSchemaPaths(gh.SYSTEM_SCHEMA_NAME,n);let i=new e(gh.SYSTEM_SCHEMA_NAME,n,s);i.attributes=EC[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await xEe.createTable(n,i)}catch(i){throw gC.error(`issue creating environment for ${gh.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(kEe,"createLMDBTables");function Yl(e){MEe(e,{mode:gh.HDB_FILE_PERMISSIONS}),gC.info(`Directory ${e} created`)}a(Yl,"makeDirectory")});var PT=w((IUe,bW)=>{"use strict";var AC=require("os"),mW=require("inquirer"),xs=require("fs-extra"),FEe=require("properties-reader"),zl=require("chalk"),ji=require("path"),GEe=require("human-readable-ids").hri,qEe=require("ora"),$Ee=require("yaml"),pr=z(),ic=ae(),Sh=ie(),CT=ua(),EW=mh(),{packageJson:gW}=it(),de=(H(),C(G)),{CONFIG_PARAM_MAP:NUe,CONFIG_PARAMS:Dt}=de,VEe=uW(),KEe=SC(),RC=yt(),YEe=Rn(),WEe=F_(),zEe=tC(),jEe=As(),JEe=require("util").promisify,QEe=JEe(jEe.setSchemaDataToGlobal),fW=Zn(),Wl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),kr=a(e=>zl.magenta.bold(e),"HDB_PROMPT_MSG"),XEe="https://harperdb.io/legal/end-user-license-agreement",oc=AC.EOL,Yo="",ZEe="yes",_W="Starting HarperDB install...",pW="HarperDB installation was successful.",hW="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",ege="An out of date version of HarperDB is already installed.",TC="It appears that HarperDB is already installed. Exiting install...",tge="Aborting install",wUe=new RegExp(/^([0-9]{1,4}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5])$/),rge=new RegExp(/^[^\s.,*>]+$/),nge=AC.homedir(),sge=ji.join(nge,de.HDB_ROOT_DIR_NAME),ige="HDB_ADMIN",oge="CLUSTER_USER",age="dev",cge="localhost",IT={[Dt.HTTP_CORS]:!0,[Dt.HTTP_CORSACCESSLIST]:["*"],[Dt.HTTP_PORT]:9926,[Dt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Dt.THREADS_COUNT]:1,[Dt.THREADS_DEBUG]:!0,[Dt.LOGGING_STDSTREAMS]:!0,[Dt.LOGGING_LEVEL]:"info",[Dt.OPERATIONSAPI_NETWORK_PORT]:9925,[Dt.LOCALSTUDIO_ENABLED]:!0},Hr={DESTINATION:"Please enter a destination for HarperDB:",HDB_USERNAME:"Please enter a username for the administrative user:",HDB_PASS:"Please enter a password for the administrative user:",NODE_NAME:"Please enter a unique name for this node:",CLUSTER_USERNAME:"Please enter a username for the CLUSTER_USER:",CLUSTER_PASS:"Please enter a password for the CLUSTER_USER:",DEFAULTS_MODE:"Default Config - dev (easy access/debugging) or prod (security/performance): (dev/prod)",REPLICATION_HOSTNAME:"Please enter the hostname for this server:"},ac=CT([de.INSTALL_PROMPTS.HDB_CONFIG]),zi,SW=!1,yC=!1,TW=!1;bW.exports={install:AW,updateConfigEnv:Sge,setIgnoreExisting:Tge};AW.createSuperUser=yW;async function AW(){console.log(kr(oc+_W+oc)),pr.notify(_W);let e;ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&(e=lge());let t=dge();Object.assign(t,e),t[de.INSTALL_PROMPTS.TC_AGREEMENT]&&t[de.INSTALL_PROMPTS.ROOTPATH]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[de.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(TW=!0,t[de.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=VEe(t);if(r)throw r.message;await fge(),await _ge(t);let n=await uge(t);zi=n[de.INSTALL_PROMPTS.ROOTPATH],ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&ji.dirname(ac[de.INSTALL_PROMPTS.HDB_CONFIG])===zi&&(SW=!0),!yC&&!ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&await xs.pathExists(ji.join(zi,de.HDB_CONFIG_FILE))&&(console.error(TC),process.exit());let s=qEe({prefixText:kr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),Sh.isEmpty(zi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");ic.setHdbBasePath(zi),await KEe(zi),await pge(),await hge(n),pr.initLogSettings(!0),await yW(n),await Ege(n),await fW.updateConfigCert(),await fW.generateCertsKeys(),await gge(),zEe(),s.stop(),console.log(kr(oc+pW+oc)),pr.notify(pW)}a(AW,"install");function lge(){let e=$Ee.parseDocument(xs.readFileSync(ac[de.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=RC.flattenConfig(e.toJSON());return t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(lge,"getConfigFromFile");async function uge(e){pr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:de.INSTALL_PROMPTS.ROOTPATH,prefix:Yo,default:sge,validate:a(async s=>Us(s)?Us(s):await xs.pathExists(ji.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:kr(Hr.DESTINATION)},{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Yo,default:ige,validate:a(s=>Us(s)?Us(s):(t=s,!0),"validate"),message:kr(Hr.HDB_USERNAME)},{type:"password",when:Wo(e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Hr.HDB_PASS),name:de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Yo,validate:a(s=>Us(s)?Us(s):!0,"validate"),message:kr(Hr.HDB_PASS)},{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:de.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Yo,default:age,validate:a(s=>Us(s)?Us(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:kr(Hr.DEFAULTS_MODE)}];if(TW||r.push({type:"input",name:de.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Yo,default:cge,message:kr(Hr.REPLICATION_HOSTNAME)}),Sh.autoCastBoolean(e[de.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:de.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Yo,default:GEe.random(),validate:a(i=>rge.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:kr(Hr.NODE_NAME)},{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:de.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Yo,default:oge,validate:a(i=>Us(i)?Us(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:kr(Hr.CLUSTER_USERNAME)},{type:"password",when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Hr.CLUSTER_PASS),name:de.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Yo,validate:a(i=>Us(i)?Us(i):!0,"validate"),message:kr(Hr.CLUSTER_PASS)}];r.push(...s)}let n=await mW.prompt(r);if(Object.keys(n).length===0)return e;for(let s in n)e[s]===void 0&&(e[s]=n[s]);return e}a(uge,"installPrompts");function Wo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${kr(t)} ${zl.gray("[hidden]")}`),pr.trace(`${kr(t)} [hidden]`)):(console.log(`${kr(t)} ${e}`),pr.trace(`${kr(t)} ${e}`)),!1):!0}a(Wo,"displayCmdEnvVar");function Us(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(Us,"checkForEmptyValue");function dge(){let e=Object.keys(de.INSTALL_PROMPTS),t=CT(e),r=CT(Object.keys(de.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=de.CONFIG_PARAM_MAP[s.toLowerCase()];t[s]?i===void 0?n[s]=t[s]:n[i.toUpperCase()]=t[s]:i!==void 0&&r[i.toLowerCase()]&&(n[s]=r[i.toLowerCase()])}return n}a(dge,"checkForPromptOverride");async function fge(){pr.trace("Checking for existing install.");let e=Sh.getPropsFilePath(),t=await xs.pathExists(e),r;if(t){pr.trace(`Install found an existing boot prop file at:${e}`);let n=FEe(e),s=RC.getConfigValue(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await xs.pathExists(s)}if(!t&&Sh.noBootFile()&&(r=!0),r&&!yC){if(pr.trace(`Install found existing HDB config at:${e}`),await EW.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${gW.version}. Exiting install...`;console.log(oc+zl.magenta.bold(ege)),console.log(zl.magenta.bold(s)),pr.error(s)}else console.log(oc+zl.magenta.bold(TC)),pr.error(TC);process.exit(0)}}a(fge,"checkForExistingInstall");async function _ge(e){pr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${XEe}${oc}and can be viewed by typing or copying and pasting the URL into your web browser.${oc}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Yo,transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.TC_AGREEMENT],t),name:de.INSTALL_PROMPTS.TC_AGREEMENT,message:kr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:zl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await mW.prompt([r]);n[de.INSTALL_PROMPTS.TC_AGREEMENT]&&n[de.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==ZEe&&(console.log(zl.yellow(hW)),pr.error(hW),process.exit(0))}a(_ge,"termsAgreement");async function pge(){let e=ji.join(zi,de.HDB_CONFIG_FILE),t;try{t=AC.userInfo().username}catch{t=process.env.USERNAME||process.env.USER||process.env.LOGNAME||process.env.LNAME||process.env.SUDO_USER}if(t){let r=`settings_path = ${e}
|
|
112
|
+
install_user = ${t}`,n=Sh.getHomeDir(),s=ji.join(n,de.HDB_HOME_DIR_NAME),i=ji.join(s,de.LICENSE_KEY_DIR_NAME);try{xs.mkdirpSync(s,{mode:de.HDB_FILE_PERMISSIONS}),xs.mkdirpSync(i,{mode:de.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${de.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=ji.join(s,de.BOOT_PROPS_FILE_NAME);try{await xs.writeFile(o,r)}catch(c){throw pr.error(`There was an error creating the boot file at path: ${o}`),c}ic.setProperty(de.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),ic.setProperty(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),ic.setProperty(ic.BOOT_PROPS_FILE_PATH,o)}}a(pge,"createBootPropertiesFile");async function hge(e){pr.trace("Creating HarperDB config file");let t=CT(Object.keys(de.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[de.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in IT){if(r===Dt.HTTP_PORT&&t[Dt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??IT[r],t[Dt.HTTP_SECUREPORT]=null;continue}else if(r===Dt.HTTP_PORT)continue;if(r===Dt.OPERATIONSAPI_NETWORK_PORT&&t[Dt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??IT[r],t[Dt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Dt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=IT[r])}}else t[Dt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Dt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Dt.HTTP_PORT.toLowerCase()]&&(t[Dt.HTTP_SECUREPORT]=null);try{ac[de.INSTALL_PROMPTS.HDB_CONFIG]||RC.createConfigFile(t),ic.initSync()}catch(r){mge(r)}}a(hge,"createConfigFile");function mge(e){pr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(tge);let t=ji.resolve(ic.get(ic.BOOT_PROPS_FILE_PATH),"../");t&&xs.removeSync(t),zi&&(SW?xs.readdirSync(zi,{withFileTypes:!0}).forEach(n=>{let s=ji.join(n.path,n.name);s!==ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&xs.removeSync(s)}):xs.removeSync(zi)),process.exit(1)}a(mge,"rollbackInstall");async function RW(e,t){pr.trace("Creating admin user"),await QEe();let r;try{r=await WEe.addRole(e)}catch(n){if(n.message.includes("already exists"))t=void 0;else throw n.message+="Error creating role",n}if(t)try{t.role=r.role,await YEe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(RW,"createAdminUser");async function yW(e){pr.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await RW(t,r),delete e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(yW,"createSuperUser");async function Ege(e){pr.trace("Creating Cluster user.");let t;e[de.INSTALL_PROMPTS.CLUSTERING_USER]&&e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[de.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await RW({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[de.INSTALL_PROMPTS.CLUSTERING_USER],delete e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(Ege,"createClusterUser");async function gge(){let e=gW.version;if(e)await EW.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(gge,"insertHdbVersionInfo");function Sge(e){ac[de.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Sge,"updateConfigEnv");function Tge(e){yC=e}a(Tge,"setIgnoreExisting")});var wW=w((PUe,NW)=>{"use strict";var bC=ie(),cs=z(),OW=dC();NW.exports={processDirectives:Age};async function Age(e){console.log("Starting upgrade process...");let t=OW.getVersionsForUpgrade(e),r=bge(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;cs.notify(c),console.log(c);let l=[],u=[];try{l=Rge(o.sync_functions)}catch(f){throw cs.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await yge(o.async_functions)}catch(f){throw cs.error(`Error while running an upgrade script for ${o.version}`),f}n.push(...l,...u)}return n}a(Age,"processDirectives");function Rge(e){if(bC.isEmptyOrZeroLength(e))return cs.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return cs.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(cs.info(`Running function ${r.name}`),!(r instanceof Function)){cs.info("Variable being processed is not a function");continue}let n=r();cs.info(n),t.push(n)}return t}a(Rge,"runSyncFunctions");async function yge(e){if(bC.isEmptyOrZeroLength(e))return cs.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return cs.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(cs.info(`Running function ${s.name}`),!(s instanceof Function)){cs.info("Variable being processed is not a function");continue}let i=await s();cs.info(i),t.push(i)}return t}a(yge,"runAsyncFunctions");function bge(e){if(bC.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=OW.getDirectiveByVersion(r);n&&t.push(n)}return t}a(bge,"getUpgradeDirectivesToInstall")});var IC=w((LUe,MW)=>{"use strict";var DT=ae();DT.initSync();var DW=require("chalk"),IW=require("fs-extra"),jo=z(),zo=(H(),C(G)),Oge=wW(),OC=ie(),LW=mh(),Nge=ST(),CW=iR(),wge=As(),{packageJson:PW}=it(),Ige=require("util").promisify,Cge=Ige(wge.setSchemaDataToGlobal),NC,{UPGRADE_VERSION:wC}=zo.UPGRADE_JSON_FIELD_NAMES_ENUM;MW.exports={upgrade:Pge};async function Pge(e){await Cge(),NC===void 0&&(NC=Pd()),IW.existsSync(DT.get(DT.BOOT_PROPS_FILE_PATH))||(Th("The hdb_boot_properties file was not found. Please install HDB.",zo.LOG_LEVELS.ERROR),process.exit(1)),IW.existsSync(DT.get(zo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(Th("The hdb settings file was not found. Please make sure HDB is installed.",zo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await LW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),Th(`This version of HarperDB is ${PW.version}`,zo.LOG_LEVELS.INFO);let r=t[wC]??PW.version;r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${zo.HDB_SUPPORT_ADDRESS}`),jo.notify("Missing new version field from upgrade info object"),process.exit(1)),await Dge();let n,s=0;try{n=await Nge.forceUpdatePrompt(t)}catch(i){jo.error("There was an error when prompting user about upgrade."),jo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),jo.info(`Starting upgrade to version ${r}`),await Lge(t),Th(`HarperDB was successfully upgraded to version ${t[wC]}`,zo.LOG_LEVELS.INFO)}a(Pge,"upgrade");async function Dge(){let e=!1,t=await CW.findPs(zo.HDB_PROC_NAME);if(OC.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await CW.findPs("hdb_express");OC.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await NC.list();OC.isEmptyOrZeroLength(r)||(e=!0)}if(e){let r="HarperDB is running, please stop all HarperDB services with 'harperdb stop' and run the upgrade command again.";console.log(DW.red(r)),jo.error(r),process.exit(1)}}a(Dge,"checkIfRunning");async function Lge(e){try{await Oge.processDirectives(e)}catch(t){throw Th("There was an error during the data upgrade. Please check the logs.",zo.LOG_LEVELS.ERROR),t}try{await LW.insertHdbUpgradeInfo(e[wC])}catch(t){jo.error("Error updating the 'hdb_info' system table."),jo.error(t)}}a(Lge,"runUpgrade");function Th(e,t=void 0){t||(t=jo.info),jo[t](e),console.log(DW.magenta(e))}a(Th,"printToLogAndConsole")});var HW={};ve(HW,{onStorageReclamation:()=>Ah,runReclamationHandlers:()=>LC,setAvailableSpaceRatioGetter:()=>vge});function Ah(e,t,r){(r||(0,MT.getWorkerIndex)()===(0,MT.getWorkerCount)()-1)&&(LT.has(e)||LT.set(e,[]),LT.get(e).push({priority:0,handler:t}),DC||(DC=setTimeout(LC,UW).unref()))}async function LC(){for(let[e,t]of LT)try{let r=await BW(e),n=Mge/r;for(let s of t){let{priority:i,handler:o}=s;if(s.priority=n,n>1||i>1){let c=o(n>1?n:0);c&&(PC.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){PC.default.error?.("Error running storage reclamation handlers",r)}DC=setTimeout(LC,UW).unref()}function vge(e){BW=e??xW}var CC,MT,PC,vT,vW,LT,Mge,UW,DC,xW,BW,UT=be(()=>{CC=require("node:fs/promises"),MT=M(rt()),PC=M(Ni());H();vT=M(ae()),vW=M(ie());vT.default.initSync();LT=new Map,Mge=vT.default.get(x.STORAGE_RECLAMATION_THRESHOLD)??.4,UW=(0,vW.convertToMS)(vT.default.get(x.STORAGE_RECLAMATION_INTERVAL))||36e5;a(Ah,"onStorageReclamation");xW=a(async e=>{if(CC.statfs){let t=await(0,CC.statfs)(e);return t.bavail/t.blocks}else return new Promise((t,r)=>{import("hdd-space").then(n=>{n.default(s=>{for(let i of s.parts)if(e.startsWith(i.place))return t(i.free/i.size);return t(1)})})})},"defaultGetAvailableSpaceRatio"),BW=xW;a(LC,"runReclamationHandlers");a(vge,"setAvailableSpaceRatioGetter")});var $W=w((xUe,qW)=>{"use strict";var{promises:zd,createReadStream:Uge,createWriteStream:xge}=require("fs"),{createGzip:Bge}=require("zlib"),{promisify:Hge}=require("util"),{pipeline:kge}=require("stream"),Fge=Hge(kge),vC=require("path"),lc=ae();lc.initSync();var cc=z(),{CONFIG_PARAMS:jd,ITC_EVENT_TYPES:Gge}=(H(),C(G)),{onMessageFromWorkers:qge}=rt(),{convertToMS:$ge}=ie(),{onStorageReclamation:Vge}=(UT(),C(HW)),Kge=6e4,Yge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Wge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",MC,FW;qW.exports=GW;qge(e=>{e.type===Gge.RESTART&&(lc.initSync(!0),clearInterval(FW),lc.get(jd.LOGGING_ROTATION_ENABLED)&&GW())});async function GW(){try{let e=cc.getLogFilePath(),t=lc.get(jd.LOGGING_ROTATION_MAXSIZE),r=lc.get(jd.LOGGING_ROTATION_INTERVAL),n=lc.get(jd.LOGGING_ROTATION_RETENTION),s=0;if(Vge(e,l=>{s=l},!0),!t&&!r){cc.error(Yge);return}let i=lc.get(jd.LOGGING_ROTATION_PATH);if(!i){cc.error(Wge);return}let o;if(t){let l=t.slice(-1),u=t.slice(0,-1);l==="G"?o=u*1e9:l==="M"?o=u*1e6:o=u*1e3}let c;if(r){let l=r.slice(-1),u=r.slice(0,-1);l==="D"?c=u*1440:l==="H"?c=u*60:c=u}MC=Date.now()/6e4,cc.trace("Log rotate enabled, maxSize:",t,"interval:",r),FW=setInterval(async()=>{if(o){let l;l=await zd.stat(e),l.size>=o&&await kW(e,i)}if(c&&Date.now()/6e4-MC>=c&&(await kW(e,i),MC=Date.now()/6e4),n||s){let l=$ge(n??"1M")/(1+s);s=0;let u=await zd.readdir(i);for(let f of u)try{let d=await zd.stat(vC.join(i,f));Date.now()-d.mtimeMs>l&&await zd.unlink(vC.join(i,f))}catch(d){cc.error("Error trying to remove log",f,d)}}},Kge).unref()}catch(e){cc.error(e)}}a(GW,"logRotator");async function kW(e,t){let r=lc.get(jd.LOGGING_ROTATION_COMPRESS),n=vC.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);await zd.rename(e,n),r&&(e=n,n+=".gz",await Fge(Uge(e),Bge(),xge(n)),await zd.unlink(e)),cc.closeLogFile(),cc.notify(`hdb.log rotated, old log moved to ${n}`)}a(kW,"moveLogFile")});var Qd=w(JW=>{"use strict";var Ae=ae();Ae.initSync();za();var Gt=(H(),C(G)),{CONFIG_PARAMS:Ce}=Gt,ls=z(),Jo=require("fs-extra"),Qo=require("path"),zge=tC(),{install:jge}=PT(),UC=require("chalk"),{packageJson:Jge,PACKAGE_ROOT:Qge}=it(),Xo=ie(),xC=yt(),KW=ua(),VW=TS(),Xge=IC(),Zge=$W(),{compactOnStart:eSe}=(IS(),C(wS)),tSe=require("minimist"),rSe=Zn(),{startHTTPThreads:nSe}=(BC(),C(QW)),sSe=mh(),{isMainThread:iSe}=require("worker_threads"),HUe=po(),kUe=go(),FUe=Pb(),GUe=v_(),xT=(H(),C(G)),Ji,Jd,YW=!1,oSe="Upgrade complete. Starting HarperDB.",aSe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",cSe="HarperDB not found, starting install process.",lSe="There was an error during install, check install_log.log for more details. Exiting.",uSe="HarperDB successfully started.";function dSe(){if(!YW){let e=a(()=>{Jo.removeSync(Qo.join(Ae.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.HDB_PID_FILE)),process.exit(0)},"remove_hdb_pid");process.on("exit",()=>{e()}),process.on("SIGINT",()=>{e()}),process.on("SIGQUIT",()=>{e()}),process.on("SIGTERM",()=>{e()})}}a(dSe,"addExitListeners");async function WW(e=!1,t=!1){if(console.log(UC.magenta("Starting HarperDB...")),ls.suppressLogging?.(()=>{console.log(UC.magenta(""+Jo.readFileSync(Qo.join(Qge,"utility/install/ascii_logo.txt"))))}),await jW()===!1){console.log(cSe);try{await jge()}catch(l){console.error(lSe,l),ls.error(l),process.exit(1)}}if(!e){let l=KW(Object.keys(Gt.CONFIG_PARAM_MAP),!0);!Xo.isEmpty(l)&&!Xo.isEmptyOrZeroLength(Object.keys(l))&&xC.updateConfigValue(void 0,void 0,l,!0,!0)}let r,n=Jd?.service==="clustering";Jd?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));let s=Qo.join(Ae.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.HDB_PID_FILE),i=mSe(s);i&&i!==1&&ESe(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),Ji===void 0&&(Ji=Pd()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await VW.generateNatsConfig(),await Ji.startClusteringProcesses(!0),process.exit()),dSe(),await Jo.writeFile(Qo.join(Ae.get(xT.CONFIG_PARAMS.ROOTPATH),xT.HDB_PID_FILE),`${process.pid}`),ls.info("HarperDB PID",process.pid);let o;try{let l=await sSe.getVersionUpdateInfo();l!==void 0&&(o=l[Gt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Xge.upgrade(l),console.log(oSe))}catch(l){o?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${o}. Exiting HarperDB.`,l),ls.error(l)):(console.error(aSe,l),ls.error(l)),process.exit(1)}zge(),pSe(),await rSe.reviewSelfSignedCert(),Xo.autoCastBoolean(Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&iSe&&await VW.generateNatsConfig(t)}a(WW,"initialize");async function fSe(e=!1){try{Jd=tSe(process.argv),Jd.ROOTPATH&&xC.updateConfigObject("settings_path",Qo.join(Jd.ROOTPATH,Gt.HDB_CONFIG_FILE)),await WW(e,!0),Ae.get(Gt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await eSe();let t=process.env.IS_SCRIPTED_SERVICE&&!Jd.service;Xo.autoCastBoolean(Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Ji.startClusteringProcesses(),await Ji.startClusteringThreads()),await nSe(process.env.DEV_MODE?1:Ae.get(xT.CONFIG_PARAMS.THREADS_COUNT)??Ae.get(xT.CONFIG_PARAMS.THREADS)),Ae.get(Gt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Zge(),t||zW()}catch(t){console.error(t),ls.error(t),process.exit(1)}}a(fSe,"main");function zW(){ls.suppressLogging(()=>{console.log(UC.magenta(`HarperDB ${Jge.version} successfully started`))}),ls.notify(uSe)}a(zW,"started");async function _Se(e=!0){YW=!e;try{Ji===void 0&&(Ji=Pd()),Ji.enterPM2Mode(),await WW(),Xo.autoCastBoolean(Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Ji.startClusteringProcesses(),await Ji.startService(Gt.PROCESS_DESCRIPTORS.HDB),zW(),e&&process.exit(0)}catch(t){console.error(t),ls.error(t),process.exit(1)}}a(_Se,"launch");function pSe(){let e=Qo.join(Ae.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.LICENSE_KEY_DIR_NAME,Gt.LICENSE_FILE_NAME),t=Qo.join(e,Gt.LICENSE_FILE_NAME),r=Qo.join(e,Gt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=KW(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Xo.isEmpty(n)||Xo.isEmpty(s))return;Jo.mkdirpSync(e),Jo.writeFileSync(r,n),Jo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),ls.error(s)}}a(pSe,"writeLicenseFromVars");Object.assign(JW,{launch:_Se,main:fSe,isHdbInstalled:jW,startupLog:hSe});async function jW(){try{await Jo.stat(Xo.getPropsFilePath()),await Jo.stat(Ae.get(Gt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Xo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw ls.error(`Error checking for HDB install - ${e}`),e}return!0}a(jW,"isHdbInstalled");function hSe(e){let r=a(_=>_.padEnd(20),"pad"),n=`
|
|
113
|
+
`;Ae.get(Ce.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${Ae.get(Ce.REPLICATION_HOSTNAME)}
|
|
114
|
+
`),Ae.get(Ce.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${Ae.get(Ce.REPLICATION_URL)}
|
|
115
|
+
`),n+=`${r("Worker Threads:")}${Ae.get(Ce.THREADS_COUNT)}
|
|
116
|
+
`,n+=`${r("Root Path:")}${Ae.get(Ce.ROOTPATH)}
|
|
117
|
+
`,Ae.get(Ce.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=Ae.get(Ce.THREADS_DEBUG_PORT)?`, TCP: ${Ae.get(Ce.THREADS_DEBUG_PORT)}
|
|
120
118
|
`:`
|
|
121
|
-
`);let s=
|
|
122
|
-
`,n+=r("Default:"),n+=
|
|
123
|
-
`,n+=r("Operations API:"),n+=
|
|
124
|
-
`,n+=r("MQTT:"),n+=
|
|
119
|
+
`);let s=Qo.join(Ae.get(Ce.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${Ae.get(Ce.LOGGING_LEVEL)}, location: ${s+(Ae.get(Ce.LOGGING_STDSTREAMS)?", stdout/err":"")}
|
|
120
|
+
`,n+=r("Default:"),n+=Ae.get(Ce.HTTP_PORT)?`HTTP (and WS): ${Ae.get(Ce.HTTP_PORT)}, `:"",n+=Ae.get(Ce.HTTP_SECUREPORT)?`HTTPS (and WS): ${Ae.get(Ce.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${Ae.get(Ce.HTTP_CORS)?`enabled for ${Ae.get(Ce.HTTP_CORSACCESSLIST)}`:"disabled"}
|
|
121
|
+
`,n+=r("Operations API:"),n+=Ae.get(Ce.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=Ae.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${Ae.get(Ce.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
|
|
122
|
+
`,n+=r("MQTT:"),n+=Ae.get(Ce.MQTT_NETWORK_PORT)?`TCP: ${Ae.get(Ce.MQTT_NETWORK_PORT)}, `:"",n+=Ae.get(Ce.MQTT_NETWORK_SECUREPORT)?`TLS: ${Ae.get(Ce.MQTT_NETWORK_SECUREPORT)}`:"",n+=Ae.get(Ce.MQTT_WEBSOCKET)&&Ae.get(Ce.HTTP_PORT)?`, WS: ${Ae.get(Ce.HTTP_PORT)}`:"",n+=Ae.get(Ce.MQTT_WEBSOCKET)&&Ae.get(Ce.HTTP_SECUREPORT)?`, WSS: ${Ae.get(Ce.HTTP_SECUREPORT)}
|
|
125
123
|
`:`
|
|
126
|
-
`;let i=
|
|
127
|
-
`;let l=[],u=
|
|
128
|
-
`);let p=
|
|
124
|
+
`;let i=Ae.get(Ce.REPLICATION_PORT)??Ae.get(Ce.OPERATIONSAPI_NETWORK_PORT),o=Ae.get(Ce.REPLICATION_SECUREPORT)??Ae.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT),c=r("Replication:");c+=i?`WS: ${i}, `:"",c+=o?`WSS: ${o} `:"",n+=`${c.slice(0,-2)}
|
|
125
|
+
`;let l=[],u=xC.getConfigObj();for(let _ in u)u[_].package&&l.push(_);let f={},d=`${r("REST:")}`;for(let[_,h]of e)for(let S of h){let g=S.name;g==="rest"&&(d+=`${S.protocol_name}: ${_}, `),l.includes(g)&&(f[g]?f[g]+=`${S.protocol_name}: ${_}, `:f[g]=`${S.protocol_name}: ${_}, `)}d.length>21&&(d=d.slice(0,-2),n+=`${d}
|
|
126
|
+
`);let p=Ae.get(Ce.HTTP_PORT)?`HTTP: ${Ae.get(Ce.HTTP_PORT)}, `:"";p+=Ae.get(Ce.HTTP_SECUREPORT)?`HTTPS: ${Ae.get(Ce.HTTP_SECUREPORT)}, `:"",p.length>21&&(p=p.slice(0,-2));for(let _ of l)f[_]?n+=`${r(_+": ")}${f[_].slice(0,-2)}
|
|
129
127
|
`:n+=`${r(_+": ")}${p}
|
|
130
|
-
`;console.log(n),
|
|
128
|
+
`;console.log(n),Ae.get(Ce.LOGGING_STDSTREAMS)&&ls.logsAtLevel("info")&&ls.suppressLogging(()=>{console.log(`Note that log messages are being sent to the console (stdout and stderr) in addition to the log file ${s}. This can be disabled by setting logging.stdStreams to false, and the log file can be directly monitored/tailed.`)})}a(hSe,"startupLog");function mSe(e){try{return Number.parseInt(Jo.readFileSync(e,"utf8"),10)}catch{return null}}a(mSe,"readPidFile");function ESe(e){try{return process.kill(e,0),!0}catch(t){return t.code==="EPERM"}}a(ESe,"isProcessRunning")});var WC=w(Zo=>{"use strict";nm();var{isMainThread:HC,parentPort:Oh,threadId:HT,workerData:gSe}=require("node:worker_threads"),{Socket:SSe,createServer:TSe}=require("node:net"),{createServer:ASe,IncomingMessage:RSe}=require("node:http"),{createServer:ySe}=require("node:https"),{createSecureServer:bSe}=require("node:http2"),{Blob:OSe}=(gs(),C(Gm)),{unlinkSync:iz,existsSync:NSe}=require("fs"),Ln=z(),Et=ae(),Xt=(H(),C(G)),{server:Nh}=(Vr(),C(Au)),{WebSocketServer:wSe}=require("ws"),{createServer:ISe}=require("node:tls"),{getTicketKeys:CSe,restartNumber:PSe,getWorkerIndex:Xd}=rt(),{Headers:kC,appendHeader:DSe}=(z_(),C(wH)),{recordAction:Rh,recordActionBinary:XW}=(ki(),C(W_)),{Request:oz,createReuseportFd:bh}=(ZI(),C(NY)),{checkMemoryLimit:LSe}=Od(),{createTLSSelector:az}=Zn(),{resolvePath:cz}=yt(),{startupLog:MSe}=Qd(),{Readable:ZW}=require("node:stream"),vSe=Ti(),lz=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG);if(lz){let e;if(HC)e=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Ln.info("Could not close debugger",t)}});else{let t=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&Xd()>=0&&(e=t+Xd())}if(e){let t=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Ln.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&HC)try{require("inspector").open(9229)}catch(e){PSe<=1&&Ln.trace("Could not start debugging on port 9229, you may already be debugging:",e.message)}process.on("uncaughtException",e=>{e.isHandled||e.code==="ECONNRESET"||e.code==="ECONNREFUSED"||e.message!=="write EIO"&&console.error("uncaughtException",e)});var{HDB_SETTINGS_NAMES:VUe,CONFIG_PARAMS:USe}=Xt;Et.initSync();var xSe=Et.get(USe.HTTP_SESSIONAFFINITY),Qi={},FC=new Map;Zo.registerServer=VC;Zo.httpServer=YC;Zo.deliverSocket=$C;Zo.startServers=uz;Zo.listenOnPorts=dz;Zo.globals=vSe;Zo.when_components_loaded=null;Nh.http=YC;Nh.request=HSe;Nh.socket=kSe;Nh.ws=FSe;Nh.upgrade=pz;var yh={},BT={},kT={},GC=[];function uz(){return Zo.when_components_loaded=$T().loadRootComponents(!0).then(()=>{Oh?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)$C(n,r,s);else if(t.requestId)BSe(t);else if(t.type===Xt.ITC_EVENT_TYPES.SHUTDOWN){Ln.trace("received shutdown request",HT);for(let i in Qi){let o=Qi[i],c;if(o.closeIdleConnections){let u=Object.getOwnPropertySymbols(o).find(p=>p.description.includes("connections")),f=0,d=setInterval(()=>{f++;let p=f>=100,_=o[u][p?"all":"idle"]();if(_.length===0){p&&clearInterval(d);return}f===1?Ln.info(`Closing ${_.length} idle connections`):p&&Ln.warn(`Forcefully closing ${_.length} active connections`);for(let h=0,S=_.length;h<S;h++){let g=_[h].socket;g._httpMessage&&!g._httpMessage.finished&&!p||(p?g.destroySoon():g.end(`HTTP/1.1 408 Request Timeout\r
|
|
131
129
|
Connection: close\r
|
|
132
130
|
\r
|
|
133
|
-
`))}},25).unref()}o.close?.(()=>{if(Et.get(
|
|
134
|
-
`)}a(iz,"defaultNotFound")});var XW={};ve(XW,{startHTTPThreads:()=>GSe,startSocketServer:()=>jC,updateWorkerIdleness:()=>bz});async function GSe(e=2,t){try{if(t)WC(0,1,!0);else{let{loadRootComponents:r}=qT();if(e===0)return(0,ks.setMainIsWorker)(!0),await VC().startServers(),Promise.resolve([]);await r()}yz();for(let r=0;r<e;r++)WC(r,e);return Promise.all(Rz)}finally{(0,ks.threadsHaveStarted)()}}function yz(){let e=(0,Sz.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),YC=setInterval(()=>{KT.notify(e)},FSe).unref())}function WC(e,t=1,r){if(KC++,(0,ks.startWorker)("server/threads/threadServer.js",{name:JA.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===zA.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Rz.push(s),await s,Jd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=VT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Jd.indexOf(n);o>-1&&Jd.splice(o,1)}if(a(i,"removeWorker"),Xd){let o=Xd;Xd=[];for(let c of o)Az[c.localPort](null,c)}}}),r){let n=setInterval(()=>{zC?zC=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,ks.shutdownWorkers)(),KC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function jC(e=0,t){if(typeof e=="string")try{(0,YT.existsSync)(e)&&(0,YT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=qSe:r=$Se(t):r=QC;let n=(0,Zd.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);return n._handle&&(n._handle.onconnection=Az[e]=function(s,i){r.readsData||(i.reading=!1,i.readStop()),zC=!0,r(i,(o,c)=>{if(!o){if(mz){let u=i._socket||new Zd.Socket({handle:i,writable:!0,readable:!0});mz.deliverSocket(u,e,c),u.resume()}else KC>0?(Xd.length===0&&setTimeout(()=>{Xd.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),i.localPort=e,Xd.push(i)):(console.log("start up a dynamic thread to handle request"),WC(0));ir(!1,"socket-routed");return}o.requests++;let l=i.fd;if(l>=0)o.postMessage({port:e,fd:l,data:c});else{let u=i._socket||new Zd.Socket({handle:i,writable:!0,readable:!0});YSe(u,o,e)}ir(!0,"socket-routed")})},KT.info(`HarperDB ${Tz.packageJson.version} Server running on port ${e}`)),n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function QC(e,t){let r,n=0;for(let s of Jd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=$T)return $T=i,t(r);n=i}$T=0,t(r)}function qSe(e,t){let r={};e.getpeername(r);let n=r.address,s=ef.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);QC(e,o=>{ef.set(n,{worker:o,lastUsed:i}),t(o)})}function $Se(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new Zd.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],u=ef.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);QC(n,d=>{ef.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function bz(){$T=0;for(let e of Jd)e.expectedIdle=e.recentELU.idle+VSe,e.requests=1;Jd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function YSe(e,t,r){let n=KSe++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),VT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),VT.delete(n)),s.event=="destroy"&&(e.destroy(),VT.delete(n))})}var ks,Zd,KT,YT,gz,Sz,Tz,Jd,Xd,Az,mz,KC,Rz,YC,FSe,zC,$T,Ez,ef,VSe,VT,KSe,vC=be(()=>{ks=M(et()),Zd=require("net");H();KT=M(z()),YT=require("fs");qi();gz=require("worker_threads"),Sz=M(yd()),Tz=M(st()),Jd=[],Xd=[],Az=[],KC=0,Rz=[];gz.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,ks.onMessageFromWorkers)(e=>{e.type===QA.RESTART&&YC&&(clearInterval(YC),yz())}));FSe=6e5;a(GSe,"startHTTPThreads");a(yz,"licenseWarning");a(WC,"startHTTPWorker");a(jC,"startSocketServer");$T=0;a(QC,"findMostIdleWorker");Ez=36e5,ef=new Map;a(qSe,"findByRemoteAddressAffinity");a($Se,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of ef)r.lastUsed+Ez<e&&ef.delete(t)},Ez).unref();VSe=1e3;a(bz,"updateWorkerIdleness");(0,ks.setMonitorListener)(bz);VT=new Map,KSe=1;a(YSe,"proxySocket")});var kz=w((ZUe,Hz)=>{var Nz=M(require("cluster")),lc=M(ae());H();var to=M(z()),wz=M(require("fastify")),Iz=M(require("@fastify/cors")),Cz=M(require("@fastify/compress")),Pz=M(require("@fastify/static")),Dz=M(TO()),Lz=M(require("path")),Mz=M(st()),vz=M(ys()),Uz=M(se()),xz=M(An()),Bz=M(yd());Vr();var uc=M(pT());uo();lc.default.initSync();var WSe=6e4,zSe=1024*1024*1024,jSe="TRUE",{CONFIG_PARAMS:wh}=q,tf;Hz.exports={hdbServer:Oz,start:Oz};async function Oz(e){try{to.default.debug("In Fastify server"+process.cwd()),to.default.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),to.default.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=Nz.default.isMaster,await QSe();let t=e.securePort>0;tf=JSe(t),await tf.ready(),e||(e={}),e.isOperationsServer=!0;try{Ye.http(tf.server,e),tf.server.closeIdleConnections||await tf.listen({port:0,host:"::"})}catch(r){throw tf.close(),to.default.error(r),to.default.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),to.default.fatal(t),process.exit(1)}}a(Oz,"operationsServer");async function QSe(){to.default.trace("Configuring HarperDB process."),vz.default.setSchemaDataToGlobal(),await xz.default.setUsersWithRolesCache(),await Bz.default.getLicense()}a(QSe,"setUp");function JSe(e){to.default.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=XSe(e),r=(0,wz.default)(t);r.server.headersTimeout=eTe(),r.setErrorHandler(uc.serverErrorHandler);let n=ZSe();n&&r.register(Iz.default,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(Dz.default),r.register(Cz.default),r.register(Pz.default,{root:Lz.default.join(Mz.PACKAGE_ROOT,"studio/build-local")}),jf(r);let s=lc.default.get(WA.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Uz.default.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[uc.reqBodyValidationHandler,uc.authHandler],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),(0,uc.handlePostRequest)(i,o)}),r.get("/health",()=>"HarperDB is running."),to.default.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(JSe,"buildServer");function XSe(e){let t=lc.default.get(wh.OPERATIONSAPI_NETWORK_TIMEOUT),r=lc.default.get(wh.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:zSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(XSe,"getServerOptions");function ZSe(){let e=lc.default.get(wh.OPERATIONSAPI_NETWORK_CORS),t=lc.default.get(wh.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===jSe)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(ZSe,"getCORSOpts");function eTe(){return lc.default.get(wh.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??WSe}a(eTe,"getHeaderTimeoutConfig")});var rP={};ve(rP,{disableNATS:()=>rTe,publishToStream:()=>jT,setNATSReplicator:()=>JC,setPublishToStream:()=>nTe,setSubscription:()=>tP,start:()=>tTe});function tTe(){Ih.default.get(B.CLUSTERING_ENABLED)&&iTe()}function rTe(e=!0){Vz=e}function nTe(e,t){jT=e,tP=t}function iTe(){if(Vz||process.env._DISABLE_NATS)return;let e=Je(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];JC(s,r,i)}}ml((r,n)=>{JC(r.tableName,r.databaseName,r),n&&Yz(r)}),!Fz&&(Fz=!0)}function JC(e,t,r){if(t==="system"&&oTe.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends $r{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this.getId(),record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this.getId()})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this.getId(),record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this.getId(),record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this.getId()})}static defineSchema(i){Yz(i)}static subscribe(){let i=new Hn;return tP(t,e,i),i}static subscribeOnThisThread(i){return i<(Ih.default.get(B.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??sTe)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new WT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=Kz;return i}a(n,"getNATSTransaction")}function Yz(e){let t=Ih.default.get(B.CLUSTERING_NODENAME);jT(`${ZC.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,eP.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var Gz,ZC,eP,qz,$z,Ih,zT,Vz,jT,tP,sTe,Kz,Fz,oTe,WT,XC,Wz=be(()=>{Pe();ga();Gz=M(or()),ZC=M(Tt()),eP=M(To());_u();qz=M(vO()),$z=M(_n()),Ih=M(ae());H();zT=M(z());a(tTe,"start");a(rTe,"disableNATS");jT=Gz.publishToStream,tP=qz.setSubscription;a(nTe,"setPublishToStream");sTe=2;a(iTe,"assignReplicationSource");oTe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(JC,"setNATSReplicator");a(Yz,"publishSchema");WT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=Ih.default.get(B.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let f of i){let d=f.table,p=f.operation=="put"?"upsert":f.operation;l||(zT.trace(`Sending transaction event ${p}`),u=l={operation:p,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,p!=="delete"&&p!=="invalidate"&&(l.records=o)),l.table===d&&l.operation===p?(o.push(f.record),c.push(f.id)):u=u.next={operation:p,table:d,id:f.id,record:f.record},f.expiresAt&&(u.expiresAt=f.expiresAt)}l&&n.push(jT(`${ZC.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,eP.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(f=>{throw zT.error("An error has occurred trying to replicate transaction",l,f),f.statusCode=504,f}))}return Promise.all(n)}},XC=class extends WT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,$z.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};Kz=new XC});async function Xz({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await nP.get(e,{returnNonexistent:!0});i=new oP(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await nP.get(e);o&&o.delete()}i=new JT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ch.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function sP(){return QT++,QT>65500&&(QT=1),QT}function iP(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=wi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Nt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var jz,dc,Qz,Jz,zz,nP,Ch,QT,JT,oP,Zz=be(()=>{Pe();Su();jz=M(_n()),dc=M(z());Oc();Qz=M(et()),Jz=M(VC());Vr();zz=100,nP=dt({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),Ch=dt({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,Qz.getWorkerIndex)()===0&&(async()=>{await Jz.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of Ch.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await Ye.getUser(r.user.username));try{await iP(r,t,r)}catch{(0,dc.warn)("Failed to publish will",t)}Ch.delete(e.id)}})();a(Xz,"getSession");QT=1;a(sP,"getNextMessageId");JT=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let f=this.subscriptions.find(R=>R.topic===s),d;f?(d=i>0,f.end(),this.subscriptions.splice(this.subscriptions.indexOf(f),1)):d=i===2;let p={search:l,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,dc.trace)("Resuming subscription from",s,"from",o);let _=wi.getMatch(u,"mqtt");if(!_){let R=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw R.statusCode=404,R}if(p.url=_.relativeURL,p.url.indexOf("+")>-1||p.url.indexOf("#")>-1){let R=p.url.slice(1);if(R.indexOf("#")>-1&&R.indexOf("#")!==R.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(p.isCollection=!0,R.indexOf("+")===R.length-1)p.onlyChildren=!0,p.url="/"+R.slice(0,R.length-1);else{let E=R.split("/"),A;for(let F=0;F<E.length;F++)if(E[F].indexOf("+")>-1)if(E[F]==="+")A=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&A)throw new Error("Filters can not be combined");let O=!0;E[E.length-1]==="#"&&(E.length--,O=!1),A&&(n=a(F=>{let G=F.id;if(!Array.isArray(G))if(G?.indexOf?.("/")>-1)G=G.split("/");else return!1;if(O&&G.length!==E.length)return!1;for(let Y=0;Y<E.length;Y++)if(E[Y]!=="+"&&E[Y]!==G[Y])return!1;return!0},"filter"));let v=E.indexOf("+");p.url="/"+(v>-1?E.slice(0,v):E).concat("").join("/")}}let h=_.path,S=_.Resource,g=await Nt(p,async()=>{let R=this.createContext();R.topic=s,R.retainHandling=i;let E=await S.subscribe(p,R);if(!E)return;if(!E[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let A=(async()=>{for await(let O of E)try{let v;if(O.type&&O.type!=="put"&&O.type!=="delete"&&O.type!=="message"&&O.type!=="patch"||n&&!n(O))continue;r?(O.topic=s,v=this.needsAcknowledge(O)):(O.acknowledge?.(),v=sP());let F=O.id;if(Array.isArray(F)&&(F=gu(F)),F==null&&(F=""),await this.listener(h+"/"+F,O.value,v,t)===!1)break;this.awaitingAcks?.size>zz?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-zz)):await new Promise(setImmediate)}catch(v){(0,dc.warn)(v)}})();return E});if(g)return g.topic=s,g.qos=t.qos,this.subscriptions.push(g),g}resume(){}needsAcknowledge(t){let r=sP();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return iP(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Nt(r,async()=>{try{if(!t){let n=await Ch.get(this.sessionId);n?.doesExist()&&await iP(n,n.data,r)}}finally{await Ch.delete(this.sessionId)}}).catch(n=>{(0,dc.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(iP,"publish");oP=class extends JT{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=sP(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,dc.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,jz.getNextMonotonicTime)()),(0,dc.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),nP.put(this.sessionRecord)}}});var cP={};ve(cP,{bypassAuth:()=>aTe,start:()=>cTe});function aTe(){sj=!0}function cTe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new nj.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,f,d,p)=>{if(f.headers.get("sec-websocket-protocol")!=="mqtt")return p(u,f,d);o.events.emit("connection",u),hr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:_,onClose:h}=tj(u,S=>{u.send(S)},f,Promise.resolve(d).then(()=>f?.user),o);u.on("message",_),u.on("close",h),u.on("error",S=>{hr.info?.("WebSocket error",S)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let f;if(o.events.emit("connection",u),hr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let _=l.user;if(_!==null){(_===void 0||_==="Common Name"||_==="CN")&&(_=u.getPeerCertificate().subject.CN);try{f=await e.getUser(_,null,null),(0,rf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:f?.username,status:Ws.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,rf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.error?.({username:_,status:Ws.FAILURE,type:ua.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else hr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(_){o.events.emit("error",_,u),hr.error?.(_)}else if(l.required)return hr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!f&&sj&&u.remoteAddress.includes("127.0.0.1")&&(f=await(0,rj.getSuperUser)(),hr.debug?.("Auto-authorizing local connection",f?.username));let{onMessage:d,onClose:p}=tj(u,_=>u.write(_),null,f,o);u.on("data",d),u.on("close",p),u.on("error",_=>{hr.info?.("Socket error",_)})},{port:t,securePort:s,mtls:l})),c}function tj(e,t,r,n,s){ej||(ej=!0,z_(d=>{XT>0&&d.push({metric:"mqtt-connections",connections:XT,byThread:!0})}));let i;XT++;let o,c={protocolVersion:4},l=(0,eA.parser)({protocolVersion:5});function u(d){l.parse(d)}a(u,"onMessage");function f(){XT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Zn(!1,"connection","mqtt","disconnect"),hr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(f,"onClose"),l.on("packet",async d=>{n?.then&&(n=await n);let p=d.cmd;if(o)o.then&&await o;else if(p!=="connect"){hr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let _=d.topic,h=_?.indexOf("/",1),S=h>0?_.slice(0,h):_;ir(d.length,"bytes-received",S,R(d),"mqtt");try{switch(o?.receivedPacket?.(),p){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await Ye.getUser(d.username,d.password.toString(),r),(0,rf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:n?.username,status:Ws.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(ie){return(0,rf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.error?.({username:d.username,status:Ws.FAILURE,type:ua.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,ie),Zn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Zn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let ie=e.deserialize||(e.deserialize=po(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?ie(d.will.payload):void 0,delete d.will.payload}o=Xz({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(ie){return hr.error?.(ie),s.events.emit("auth-failed",d,e,ie),Zn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:ie.code||5,returnCode:ie.code||128})}s.events.emit("connected",o,e),Zn(!0,"connection","mqtt","connect"),g({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0});let A=a(async(ie,X,ne,Q)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",ie);let he=ie.indexOf("/",1),Re=he>0?ie.slice(0,he):ie;g({cmd:"publish",topic:ie,payload:await E(X),messageId:ne||Math.floor(Math.random()*1e8),qos:Q.qos},Re);let Ce=e._socket??e;return Ce.writableNeedDrain?new Promise(me=>Ce.once("drain",me)):!Ce.closed}catch(he){return hr.error?.(he),o?.disconnect(),s.sessions.delete(o),!1}},"listener");o.setListener(A),o.sessionWasPresent&&await o.resume();break;case"subscribe":let O=[];for(let ie of d.subscriptions){let X;try{let ne=await o.addSubscription(ie,ie.qos>=1);X=ne?ne.qos||0:c.protocolVersion<5?128:143}catch(ne){s.events.emit("error",ne,e,ie,o),ne.statusCode?ne.statusCode===500?hr.warn?.(ne):hr.info?.(ne):hr.error?.(ne),X=c.protocolVersion<5?128:ne.statusCode===403?135:ne.statusCode===404?143:128}O.push(X)}await o.committed,g({cmd:"suback",granted:O,messageId:d.messageId});break;case"unsubscribe":{let ie=[];for(let X of d.unsubscriptions)ie.push(o.removeSubscription(X)?0:17);g({cmd:"unsuback",granted:ie,messageId:d.messageId});break}case"pubrel":g({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let v=d.qos===2?"pubrec":"puback",F=e.deserialize||(e.deserialize=po(r?.headers.get?.("content-type"))),Y=(d.payload?.length||0)>0?F(d.payload):void 0,te;try{te=await o.publish(d,Y)}catch(ie){s.events.emit("error",ie,e,d,o),hr.warn?.(ie),d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:te===!1?144:0},d.topic);break;case"pubrec":g({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":g({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),Zn(!0,"connection","mqtt","disconnect"),hr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(A){s.events.emit("error",A,e,d,o),hr.error?.(A),g({cmd:"disconnect"})}function g(A,O){let v=(0,eA.generate)(A,c);t(v),ir(v.length,"bytes-sent",O,R(A),"mqtt")}a(g,"sendPacket");function R(A){return A.qos>0?A.cmd+",qos="+A.qos:A.cmd}a(R,"packetMethodName");function E(A){return Ra(A,r)}a(E,"serialize")}),l.on("error",d=>{hr.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:f}}var eA,rj,rf,aP,nj,ZT,hr,sj,ej,XT,ij=be(()=>{eA=require("mqtt-packet");Zz();rj=M(An());uo();qi();Vr();rf=M(ae());H();aP=M(Ii()),nj=require("events"),ZT=(0,aP.loggerWithTag)("auth-event"),hr=(0,aP.loggerWithTag)("mqtt"),sj=(0,rf.get)(B.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(aTe,"bypassAuth");a(cTe,"start");XT=0;a(tj,"onSocket")});var zp={};ve(zp,{component_errors:()=>sf,getComponentName:()=>_Te,loadComponent:()=>nA,loadComponentDirectories:()=>uj,setErrorReporter:()=>fTe});function uj(e,t){t&&(uP=t),e&&(pP=e);let r=[];if((0,ct.existsSync)(lP)){let s=(0,ct.readdirSync)(lP,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,St.join)(lP,o);r.push(nA(c,uP,$A,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(nA(n,uP,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{lj=!0})}function fTe(e){Ph=e}async function nA(e,t,r,n,s,i){let o=(0,ct.realpathSync)(e);if(tA.has(o))return tA.get(o);tA.set(o,!0),s&&(pP=s);try{let c;n&&(sf=new Map);let l=(0,St.join)(e,"harperdb-config.yaml");(0,ct.existsSync)(l)?c=n?(0,sA.getConfigObj)():(0,dP.parseDocument)((0,ct.readFileSync)(l,"utf8")).toJSON():!n&&(0,ct.existsSync)(l=(0,St.join)(e,"config.yaml"))?c=(0,dP.parseDocument)((0,ct.readFileSync)(l,"utf8")).toJSON():c=hP;let u=(0,St.join)(e,"node_modules","harperdb");try{Yl.isMainThread&&(n||((0,ct.existsSync)(u)||!e.startsWith((0,_P.getHdbBasePath)()))&&(!(0,ct.existsSync)(u)||(0,ct.realpathSync)(fP.PACKAGE_ROOT)!==(0,ct.realpathSync)(u)))&&((0,ct.rmSync)(u,{recursive:!0,force:!0}),(0,ct.existsSync)((0,St.join)(e,"node_modules"))||(0,ct.mkdirSync)((0,St.join)(e,"node_modules")),(0,ct.symlinkSync)(fP.PACKAGE_ROOT,u,"dir"))}catch(p){nf.default.error("Error symlinking harperdb module",p)}let f=rA,d=n;for(let p in c){rA=p;let _=c[p];if(sf.set(n?p:(0,St.basename)(e),!1),!_)continue;let h,S=_.package;try{if(S){let O=e,v;for(;!(0,ct.existsSync)(v=(0,St.join)(O,"node_modules",p));)if(O=(0,St.dirname)(O),O.length<(0,_P.getHdbBasePath)().length){v=null;break}if(v)h=await nA(v,t,r,!1),d=!0;else throw new Error(`Unable to find package ${p}:${S}`)}else h=dTe[p];if(!h)continue;let g=a(O=>(O.origin=r,dt(O)),"ensureTable"),R=_.network||(_.port||_.securePort)&&_,E=R?.securePort||R?.https&&R.port,A=!R?.https&&R?.port;if(Yl.isMainThread&&(h=await h.startOnMainThread?.({server:Ye,ensureTable:g,port:A,securePort:E,resources:t,..._})||h,n&&R))for(let O of[A,E])try{if(+O&&!oj.includes(O)){let v=mP.get(B.HTTP_SESSIONAFFINITY);v&&nf.default.warn("Session affinity is not recommended and may cause memory leaks"),(v||!ET)&&(oj.push(O),jC(O,v))}}catch(v){console.error("Error listening on socket",O,v,p)}if(t.isWorker&&(h=await h.start?.({server:Ye,ensureTable:g,port:A,securePort:E,resources:t,..._})||h),pP.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&_.files!=null){if(_.files.includes(".."))throw(0,cj.handleHDBError)("Can not reference parent directories");let O=(0,St.join)(e,_.files).replace(/\\/g,"/"),v=O.indexOf("/*");if(v>-1&&_.files!==hP[p]?.files&&!(0,ct.existsSync)(O.slice(0,v)))throw new Error(`The path '${O.slice(0,v)}' does not exist and cannot be used as the base of the resolved 'files' path value '${_.files}'`);let F=(0,St.basename)(e),G=_.path||"/";G=G.startsWith("/")?G:G.startsWith("./")?"/"+F+G.slice(2):G==="."?"/"+F:"/"+F+"/"+G;let Y,te,ie;if(_.root){let ne=_.root;ne.startsWith("/")&&(ne=ne.slice(1)),ne.endsWith("/")&&(ne=ne.slice(0,-1)),ne+="/",te=(0,St.join)(e,ne)}else(ie=O.indexOf("/*"))>-1?(te=O.slice(0,ie+1),Y=(0,St.relative)(e,te)):_.files.indexOf("/")>-1&&(te=O.slice(0,O.lastIndexOf("/")+1),Y=(0,St.relative)(e,te));let X=!1;if(Yl.isMainThread&&h.setupDirectory&&(X=await h.setupDirectory?.(G,te,t)),t.isWorker&&h.handleDirectory&&(X=await h.handleDirectory?.(G,te,t)),X){d=!0;continue}for(let ne of await(0,aj.default)(O,{onlyFiles:!1,objectMode:!0})){let{path:Q,dirent:he}=ne;d=!0;let Re=(0,St.relative)(e,Q).replace(/\\/g,"/");if(Y)if(Re.startsWith(Y))Re=Re.slice(Y.length+1);else throw new Error(`The root path '${_.root}' does not reference a valid part of the file path '${Re}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ce=G+(G.endsWith("/")?"":"/")+Re;try{if(he.isFile()){let me=await uTe(Q);Yl.isMainThread&&await h.setupFile?.(me,Ce,Q,t),t.isWorker&&await h.handleFile?.(me,Ce,Q,t)}else Yl.isMainThread&&await h.setupDirectory?.(Ce,Q,t),t.isWorker&&await h.handleDirectory?.(Ce,Q,t)}catch(me){me.message=`Could not load ${he.isFile()?"file":"directory"} '${Q}'${_.module?" using '"+_.module+"'":""} for application '${e}' due to: ${me.message}`,Ph?.(me),((0,of.getWorkerIndex)()===0?console:nf.default).error(me),t.set(_.path||"/",new Sa(me)),sf.set(n?p:(0,St.basename)(e),me.message)}}}}catch(g){g.message=`Could not load component '${p}' for application '${(0,St.basename)(e)}' due to: ${g.message}`,Ph?.(g),((0,of.getWorkerIndex)()===0?console:nf.default).error(g),t.set(_.path||"/",new Sa(g),null,!0),sf.set(n?p:(0,St.basename)(e),g.message)}}if(rA=f,Yl.isMainThread&&!lj&&i&&(0,of.watchDir)(e,async()=>uj()),c.extensionModule){let p=await jE((0,St.join)(e,c.extensionModule));return tA.set(o,p),p}if(!d&&t.isWorker){let p=`${e} did not load any modules, resources, or files, is this a valid component?`;Ph?.(new Error(p)),((0,of.getWorkerIndex)()===0?console:nf.default).error(p),sf.set((0,St.basename)(e),p)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Ph?.(c),t.set("",new Sa(c))}}var ct,St,Yl,dP,mP,fP,aj,of,nf,cj,_P,lTe,sA,uTe,lP,pP,lj,uP,sf,dTe,hP,oj,tA,Ph,rA,_Te,jp=be(()=>{ct=require("fs"),St=require("path"),Yl=require("worker_threads"),dP=require("yaml"),mP=M(ae()),fP=M(st());H();UL();gM();jB();ZB();eH();xH();EY();yY();OY();aj=M(require("fast-glob")),of=M(et()),nf=M(z());sO();Vr();cj=M(pe());Pe();vC();_P=M(ae()),lTe=M(kz());MS();Wz();es();ij();sA=M(yt());QI();ER();({readFile:uTe}=ct.promises),lP=(0,sA.resolvePath)(mP.get(B.COMPONENTSROOT)),pP=new Map,sf=new Map;a(uj,"loadComponentDirectories");dTe={REST:tg,rest:tg,graphql:xR,graphqlSchema:TR,roles:nO,jsResource:oO,fastifyRoutes:VI,login:cO,static:KI,operationsApi:lTe,customFunctions:{},http:{},clustering:rP,replication:Po,authentication:Gp,mqtt:cP,loadEnv:YI},hP={rest:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(hP,"static",{value:{files:"web/**"}});oj=[],tA=new Map;a(fTe,"setErrorReporter");_Te=a(()=>rA,"getComponentName");a(nA,"loadComponent")});var qT=w((C0e,fj)=>{var{isMainThread:dj}=require("worker_threads"),{getTables:pTe,getDatabases:w0e,table:I0e}=(Pe(),C(tt)),{loadComponentDirectories:hTe,loadComponent:mTe}=(jp(),C(zp)),{resetResources:ETe}=(Su(),C(DL)),gTe=Fw(),STe=yt(),{dirname:TTe}=require("path"),{getConnection:ATe}=or(),RTe=ae(),{CONFIG_PARAMS:yTe}=(H(),C(q)),{loadCertificates:bTe}=ts(),EP=new Map;async function OTe(e=!1){!dj&&RTe.get(yTe.CLUSTERING_ENABLED)&&ATe();try{dj&&await gTe()}catch(n){console.error(n)}let t=ETe();pTe(),t.isWorker=e,await bTe(),await mTe(TTe(STe.getConfigFilePath()),t,"hdb",!0,EP),await hTe(EP,t);let r=[];for(let[n]of EP)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(OTe,"loadRootComponents");fj.exports.loadRootComponents=OTe});var et=w((D0e,Ti)=>{"use strict";rm();var{Worker:NTe,MessageChannel:wTe,parentPort:ro,isMainThread:RP,threadId:ITe,workerData:no}=require("worker_threads"),{PACKAGE_ROOT:CTe}=st(),{join:mj,isAbsolute:PTe,extname:DTe}=require("path"),{server:Ej}=(Vr(),C(Tu)),{watch:LTe,readdir:MTe}=require("fs/promises"),{totalmem:_j}=require("os"),af=(H(),C(q)),gj=ae(),Si=z(),{randomBytes:vTe}=require("crypto"),{_assignPackageExport:UTe}=Ri(),pj=1024*1024,fc=[],Fs=[],xTe=50,yP=1e4,BTe="restart",Sj="request_thread_info",Tj="resource_report",Aj="thread_info",Rj="added-port",HTe="ack",gP;UTe("threads",Fs);Ti.exports={startWorker:SP,restartWorkers:OP,shutdownWorkers:$Te,workers:fc,setMonitorListener:JTe,onMessageFromWorkers:VTe,onMessageByType:Cj,broadcast:YTe,broadcastWithAcknowledgement:zTe,setChildListenerByType:qTe,getWorkerIndex:yj,getWorkerCount:bj,getTicketKeys:Nj,setMainIsWorker:FTe,setTerminateTimeout:kTe,restartNumber:no?.restartNumber||1};Fs.onMessageByType=Cj;Fs.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Fs.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Ti.exports.whenThreadsStarted=new Promise(e=>{Ti.exports.threadsHaveStarted=e});var bP;function kTe(e){yP=e}a(kTe,"setTerminateTimeout");function yj(){return no?no.workerIndex:bP?0:void 0}a(yj,"getWorkerIndex");function bj(){return no?no.workerCount:bP?1:void 0}a(bj,"getWorkerCount");function FTe(e){bP=e,Ti.exports.threadsHaveStarted()}a(FTe,"setMainIsWorker");var Oj=1,iA;function Nj(){return iA||(iA=RP?vTe(48):no.ticketKeys,iA)}a(Nj,"getTicketKeys");Object.defineProperty(Ej,"workerIndex",{get(){return yj()}});Object.defineProperty(Ej,"workerCount",{get(){return bj()}});var wj={[Sj](e,t){jTe(t)},[Tj](e,t){QTe(t,e)}};function SP(e,t={}){let r=process.constrainedMemory?.()||_j();r=Math.min(r,_j(),2e4*pj);let n=gj.get(af.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/pj/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Fs){let u=new wTe;u.existingPort=l,i.push(u),o.push(u.port2)}DTe(e)||(e+=".js");let c=new NTe(PTe(e)?e:mj(CTe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:Oj=t.threadCount,name:t.name,restartNumber:Ti.exports.restartNumber,ticketKeys:Nj()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:Rj,port:l,threadId:c.threadId},[l]);return aA(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>SP(e,t),c.on("error",l=>{Si.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{fc.splice(fc.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<xTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,SP(e,t)):Si.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{wj[l.type]?.(l,c)}),fc.push(c),ZTe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(SP,"startWorker");var GTe=[af.THREAD_TYPES.HTTP];async function OP(e=null,t=Math.max(Oj>3,1),r=!0){if(RP){try{process.chdir(process.cwd())}catch(o){Si.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=qT();await o()}Ti.exports.restartNumber++,t<1&&(t=t*fc.length);let n=[],s=[];for(let o of fc.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Si.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ti.exports.restartNumber,type:af.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=GTe.indexOf(o.name)>-1,l=new Promise(u=>{let f=setTimeout(()=>{Si.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},yP*2).unref();o.on("exit",()=>{clearTimeout(f),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),f=new Promise(d=>{let p=a(_=>{_.type===af.ITC_EVENT_TYPES.CHILD_STARTED&&(Si.trace("Worker has started",u.threadId),d(),s.splice(s.indexOf(f)),u.off("message",p))},"startListener");Si.trace("Waiting for worker to start",u.threadId),u.on("message",p)});s.push(f),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=za();r&&(e==="http"||!e)&&gj.get(af.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else ro.postMessage({type:BTe,workerType:e})}a(OP,"restartWorkers");function qTe(e,t){wj[e]=t}a(qTe,"setChildListenerByType");function $Te(e){return OP(e,1/0,!1)}a($Te,"shutdownWorkers");var Ij=[];function VTe(e){Ij.push(e)}a(VTe,"onMessageFromWorkers");var TP=new Map;function Cj(e,t){let r=TP.get(e);r||TP.set(e,r=[]),r.push(t)}a(Cj,"onMessageByType");var KTe=10;async function YTe(e,t){let r=0;for(let n of Fs)try{n.postMessage(e),r++>KTe&&(r=0,await new Promise(setImmediate))}catch(s){Si.error("Unable to send message to worker",s)}t&&Dj(e,null)}a(YTe,"broadcast");var oA=new Map,WTe=1;function zTe(e){return new Promise(t=>{let r=0;for(let n of Fs)try{let s=WTe++,i=a(()=>{oA.delete(s),--r===0&&t(),n!==ro&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,oA.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of oA)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Si.error("Unable to send message to worker",s)}r===0&&t()})}a(zTe,"broadcastWithAcknowledgement");function jTe(e){e.postMessage({type:Aj,workers:Pj()})}a(jTe,"sendThreadInfo");function Pj(){let e=Date.now();return fc.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(Pj,"getChildWorkerInfo");function QTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(QTe,"recordResourceReport");var AP;function JTe(e){AP=e}a(JTe,"setMonitorListener");var XTe=1e3,hj=!1;function ZTe(){hj||(hj=!0,setInterval(()=>{for(let e of fc){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}AP&&AP()},XTe).unref())}a(ZTe,"startMonitoring");var eAe=1e3;if(ro&&no?.addPorts){aA(ro);for(let e=0,t=no.addPorts.length;e<t;e++){let r=no.addPorts[e];r.threadId=no.addThreadIds[e],aA(r)}setInterval(()=>{let e=process.memoryUsage();ro.postMessage({type:Tj,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},eAe).unref(),gP=a(()=>new Promise((e,t)=>{ro.on("message",r),ro.postMessage({type:Sj});function r(n){n.type===Aj&&(ro.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else gP=Pj;Ti.exports.getThreadInfo=gP;function aA(e,t){Fs.push(e),e.on("message",r=>{if(r.type===Rj)r.port.threadId=r.threadId,aA(r.port);else if(r.type===HTe){let n=oA.get(r.id);n&&n()}else Dj(r,e)}).on("close",()=>{Fs.splice(Fs.indexOf(e),1)}).on("exit",()=>{Fs.splice(Fs.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(aA,"addPort");function Dj(e,t){for(let n of Ij)n(e,t);let r=TP.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Si.error(s)}}a(Dj,"notifyMessageListeners");if(RP){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await MTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(mj(s,o.name));try{for await(let{filename:o}of LTe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await OP(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");Ti.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else ro.on("message",async e=>{let{type:t}=e;t===af.ITC_EVENT_TYPES.SHUTDOWN&&(Ti.exports.restartNumber=e.restartNumber,ro.unref(),setTimeout(()=>{Si.warn("Thread did not voluntarily terminate",ITe),process.exit(0)},yP).unref())})});var pB={};ve(pB,{ACTION_32_BIT:()=>Wm,ACTION_64_BIT:()=>nAe,AUDIT_STORE_OPTIONS:()=>xp,Decoder:()=>hl,HAS_BLOBS:()=>qn,HAS_CURRENT_RESIDENCY_ID:()=>xc,HAS_EXPIRATION_EXTENDED_TYPE:()=>n_,HAS_ORIGINATING_OPERATION:()=>r_,HAS_PREVIOUS_RESIDENCY_ID:()=>Bc,REMOTE_SEQUENCE_UPDATE:()=>vg,createAuditEntry:()=>bu,getLastRemoved:()=>gN,openAuditStore:()=>uA,readAuditEntry:()=>wt,removeAuditEntry:()=>dA,setAuditRetention:()=>rAe,transactionKeyEncoder:()=>Fj});function uA(e){let t=e.auditStore=e.openDB(NP.AUDIT_STORE_NAME,{create:!1,...xp});t||(t=e.auditStore=e.openDB(NP.AUDIT_STORE_NAME,xp),Mj(t,1)),t.rootStore=e,t.tableStores=[];let r=[];t.addDeleteRemovalCallback=function(l,u,f){return r[l]=f,t.tableStores[l]=u,t.deleteCallbacks=r,{remove(){delete r[l]}}};let n=null,s,i=0,o=IP;Ah(t.env.path,l=>{if(i=l,l)return c(100)});function c(l){l&&(o=l),clearTimeout(n);let u=new Promise(f=>{n=setTimeout(async()=>{if(await s,s=u,t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let d=0,p,_;try{for(let{key:h,value:S}of t.getRange({start:1,snapshot:!1,end:Date.now()-wP/(1+i*i)})){try{p=dA(t,h,S)}catch(g){cf.warn("Error removing audit entry",g)}if(_=h,await new Promise(setImmediate),++d>=tAe){o=10;break}}await p}finally{d===0?o=Math.min(o<<1,wP/10):(Mj(t,_),o>100&&(o=o>>1)),f(void 0),c()}},o).unref()});return u}if(a(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,Lh.getWorkerIndex)()===(0,Lh.getWorkerCount)()-1&&c(),(0,Lh.getWorkerIndex)()===0&&!Lj)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Lj=!0,cf.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function dA(e,t,r){let n=sAe(r),s;if(n&qn){s=wt(r);let i=e.tableStores[s.tableId],o=i.getEntry(s.recordId);(!o||o.version!==s.version||!o.value)&&Dc(()=>Aa(s.getValue(i)),i.rootStore)}if((n&15)===CP){s=s||wt(r);let i=s.tableId;e.tableStores[s.tableId].getEntry(s.recordId).version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function Mj(e,t){PP[0]=t,e.put(Symbol.for("last-removed"),Gj)}function gN(e){let t=e.get(Symbol.for("last-removed"));if(t)return Gj.set(t),PP[0]}function rAe(e,t=IP){wP=e,IP=t}function bu(e,t,r,n,s,i,o,c,l,u,f,d,p){let _=qj[o];if(!_)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?_c.setFloat64(0,n):Gs.set(YR),h=9),l){if(l&255)throw new Error("Illegal extended type");h+=3}R(s),R(t),g(r),_c.setFloat64(h,e),h+=8,l&xc&&R(u),l&Bc&&R(f),l&n_&&(_c.setFloat64(h,d),h+=8),l&r_&&R($j[p]),i?g(i):Gs[h++]=0,l?_c.setUint32(n?8:0,_|l|3221225472):Gs[n?8:0]=_;let S=Gs.subarray(0,h);if(c)return Buffer.concat([S,c]);return S;function g(E){let A=h;h+=1,h=(0,Wl.writeKey)(E,Gs,h);let O=h-A-1;O>127?O>16383?(cf.error("Key or username was too large for audit entry",E),h=A+1,Gs[A]=0):(Gs.copyWithin(A+2,A+1,h),_c.setUint16(A,O|32768),h++):Gs[A]=O}function R(E){E<128?Gs[h++]=E:E<16384?(_c.setUint16(h,E|32768),h+=2):E<1056964608?(_c.setUint32(h,E|3221225472),h+=4):(Gs[h]=255,_c.setUint32(h+1,E),h+=5)}}function sAe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new hl(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function wt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new hl(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,f=n.position+=l,d=n.readFloat64(),p,_,h,S;if(i&xc&&(p=n.readInt()),i&Bc&&(_=n.readInt()),i&n_&&(h=n.readFloat64()),i&r_){let A=n.readInt();S=$j[A]}l=n.readInt();let g=n.position,R=n.position+=l,E;return{type:qj[i&7],tableId:c,nodeId:o,get recordId(){return(0,Wl.readKey)(e,u,f)},getBinaryRecordId(){return e.subarray(u,f)},version:d,previousLocalTime:s,get user(){return R>g?(0,Wl.readKey)(e,g,R):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(A,O,v){if(i&cA||i&Dh&&!O)return E||(E=Dc(()=>A.decoder.decode(e.subarray(n.position,r)),A.rootStore)),E;if(i&Dh&&v)return qb(A.getEntry(this.recordId),v,A)},getBinaryValue(){return i&(cA|Dh)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:p,previousResidencyId:_,expiresAt:h,originatingOperation:S}}catch(n){return cf.error("Reading audit entry error",n,e),{}}}var Wl,lA,NP,Lh,kj,cf,Gs,_c,Fj,xp,wP,tAe,PP,Gj,IP,Lj,cA,Dh,vj,CP,Uj,xj,Bj,Hj,Wm,nAe,vg,xc,Bc,r_,n_,qn,qj,$j,hl,ho=be(()=>{Wl=require("ordered-binary"),lA=M(ae()),NP=M(vt());H();Lh=M(et()),kj=M(se());Ou();cf=M(z());xE();Ts();vT();(0,lA.initSync)();Gs=Buffer.alloc(2816),_c=new DataView(Gs.buffer,Gs.byteOffset,2816),Fj={writeKey(e,t,r){return e===t_?(t.set(t_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Wl.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Wl.readKey)(e,t,r)}},xp={encoding:"binary",keyEncoder:Fj},wP=(0,kj.convertToMS)((0,lA.get)(B.LOGGING_AUDITRETENTION))||86400*3,tAe=1e3,PP=new Float64Array(1),Gj=new Uint8Array(PP.buffer),IP=1e4,Lj=!1;a(uA,"openAuditStore");a(dA,"removeAuditEntry");a(Mj,"updateLastRemoved");a(gN,"getLastRemoved");a(rAe,"setAuditRetention");cA=16,Dh=32,vj=1,CP=2,Uj=3,xj=4,Bj=5,Hj=6,Wm=14,nAe=15,vg=11,xc=512,Bc=1024,r_=2048,n_=4096,qn=8192,qj={put:vj|cA,[vj]:"put",delete:CP,[CP]:"delete",message:Uj|cA,[Uj]:"message",invalidate:xj|Dh,[xj]:"invalidate",patch:Bj|Dh,[Bj]:"patch",relocate:Hj,[Hj]:"relocate"},$j={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(bu,"createAuditEntry");a(sAe,"readAction");a(wt,"readAuditEntry");hl=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});function MP(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Kj,iAe(e.primaryStore,e.auditStore)):(c=Vj,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{Yj(Vj[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=gu(t);let f=new LP(r);f.startTime=n;let d=u.get(t);return d?d.push(f):(u.set(t,d=[f]),d.tables=u,d.key=t),f.subscriptions=d,f}function Yj(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),Wj(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=wt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=gu(c),u=0;do{let f=o.get(l);if(f){for(let p of f)if(!(u>0&&!(p.includeDescendants&&!(p.onlyChildren&&u>1)))){if(p.startTime>=n){(0,DP.info)("omitting",c,p.startTime,n);continue}try{let _;p.supportsTransactions&&p.txnInProgress!==i.version&&(_=!0,p.txnInProgress||(r?r.push(p):r=[p]),p.txnInProgress=i.version),p.listener(c,i,n,_)}catch(_){console.error(_),(0,DP.info)(_)}}}if(l==null)break;let d=l.lastIndexOf?.("/",l.length-2);d!==l.length-1&&u++,d>-1?l=l.slice(0,d+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function iAe(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=Kj[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{Yj(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function Wj(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function BF(e){return e.nextTransaction||(MP({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),Wj(e)),e.nextTransaction}var DP,Vj,Kj,LP,SN=be(()=>{DP=M(z());_u();Su();ho();Vj=Object.create(null),Kj=Object.create(null);a(MP,"addSubscription");LP=class extends Hn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(Yj,"notifyFromTransactionData");a(iAe,"listenToCommits");a(Wj,"nextTransaction");a(BF,"whenNextTransaction")});var OI={};ve(OI,{EVICTED:()=>Ea,INVALIDATED:()=>kn,coerceType:()=>pA,makeTable:()=>mA,setServerUtilities:()=>_Ae});function mA(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:f,sealed:d,splitSegments:p,replicate:_}=e,{expirationMS:h,evictionMS:S,audit:g,trackDeletes:R}=e;S??=0;let{attributes:E}=e;E||(E=[]);let A=jR(i,n,l),O,v,F={},G=Promise.resolve(),Y,te,ie;for(let K of E)(K.assignCreatedTime||K.name==="__createdtime__")&&(Y=K),(K.assignUpdatedTime||K.name==="__updatedtime__")&&(te=K),K.expiresAt&&(ie=K),K.isPrimaryKey&&(F=K);let X,ne=[],Q=[],he=1,Re=2,Ce={},me={},Zt=864e5,lt=0,yr,Es,xn,nu=!1,su,xA=new Map,BA=new Map,Lt,mf,jh=jl.get(B.REPLICATION_DATABASES);if(Array.isArray(jh)){for(let K of jh)if(K.name===c&&K.replicateTo>=0){mf=K.replicateTo;break}}let Qh=i.getRange({start:!1,end:!1}).constructor,Ef=10,Jh=6;g&&Tf(),Ah(i.env.path,K=>{if(v)return ca(K)});class De extends $r{#e;#t;#n;#r;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=o;static databaseName=c;static attributes=E;static replicate=_;static sealed=d;static splitSegments=p??!0;static createdTimeProperty=Y;static updatedTimeProperty=te;static propertyResolvers;static userResolvers={};static sources=[];static getResidencyById;static get expirationMS(){return h}static dbisDB=f;static schemaDefined=u;static sourcedFrom(m,T){if(T&&(this.sourceOptions=T,(T.expiration||T.eviction||T.scanInterval)&&this.setTTLExpiration(T)),T?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(N=>!N.intermediateSource)){if(this.sources.some(N=>N.name===m.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(m)}v=v||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),O=O||m.load;let I=a(N=>{let L=this.sources;if(L=L.filter(k=>k.intermediateSource&&k[N]&&(!k[N].reliesOnPrototype||k.prototype[N])),L.length>0)if(L.length===1){let k=L[0];return(D,x,$)=>{if(D?.source!==k)return k[N](x,$,D)}}else return(k,D,x)=>{let $=[];for(let j of L){if(k?.source===j)break;$.push(j[N](D,x,k))}return Promise.all($)}},"getApplyToIntermediateSource"),y=this.sources[this.sources.length-1];y.intermediateSource&&(y={});let b=a(N=>{if(y[N]&&(!y[N].reliesOnPrototype||y.prototype[N]))return(L,k,D)=>{if(!L?.source)return y[N](k,D,L)}},"getApplyToCanonicalSource");Ce={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},me={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish"),invalidate:I("invalidate")};let P=y.shouldRevalidateEvents;return(async()=>{let N=!1,L,k=a(async(D,x)=>{let $=D.value,j=D.table?qe[c][D.table]:De;if(c===yf&&(D.table===du.ROLE_TABLE_NAME||D.table===du.USER_TABLE_NAME)&&(N=!0),D.id===void 0&&(D.id=$[j.primaryKey],D.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(D));D.source=m;let oe={residencyId:uu(D.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:D.nodeId},U=await j.getResource(D.id,x,oe);switch(D.finished&&await D.finished,D.type){case"put":return P?U._writeInvalidate($,oe):U._writeUpdate($,!0,oe);case"patch":return P?U._writeInvalidate($,oe):U._writeUpdate($,!1,oe);case"delete":return U._writeDelete(oe);case"publish":return U._writePublish($,oe);case"invalidate":return U._writeInvalidate($,oe);case"relocate":return U._writeRelocate(oe);default:xe.default.error?.("Unknown operation",D.type,D.id)}},"writeUpdate");try{let D=m.subscribe;D&&R==null&&(R=!0);let x={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},$=m.subscribeOnThisThread?m.subscribeOnThisThread((0,zl.getWorkerIndex)(),x):(0,zl.getWorkerIndex)()===0,j=D&&$&&await m.subscribe?.(x);if(j){let oe;for await(let U of j)try{if(!(U.type==="transaction"?U.writes[0]:U)){xe.default.error?.("Bad subscription event",U);continue}if(U.source=m,U.type==="end_txn"){if(oe?.resolve(),U.localTime&&L!==U.localTime){if(U.remoteNodeIds?.length>0){let fe=[Symbol.for("seq"),U.remoteNodeIds[0]],ee=f.get(fe),W=ee?.nodes;W||(W=[]);for(let Ae of U.remoteNodeIds.slice(1)){let ye=W.find(ut=>ut.id===Ae);W=W.filter(ut=>ut.id!==Ae||ut===ye),ye||(ye={id:Ae,seqId:0},W.push(ye)),ye.seqId=Math.max(ee?.seqId??1,U.localTime),Ae===oe?.nodeId&&(ye.lastTxnTime=U.timestamp)}let _e=Math.max(ee?.seqId??1,U.localTime);xe.default.trace?.("Received txn",c,new Date(_e),new Date(U.localTime),U.remoteNodeIds),f.put(fe,{seqId:_e,nodes:W})}L=U.localTime}U.onCommit&&oe?.committed.then(U.onCommit);continue}if(oe)if(U.beginTxn)oe.resolve();else{oe.write_promises.push(k(U,oe));continue}!U.timestamp&&U.version&&(U.timestamp=U.version);let ce=Nt(U,()=>{if(U.type==="transaction"){let fe=[];for(let ee of U.writes)try{fe.push(k(ee,U))}catch(W){throw W.message+=" writing "+JSON.stringify(ee)+" of event "+JSON.stringify(U),W}return Promise.all(fe)}else if(U.type==="define_schema"){let fe=this.attributes.slice(0),ee;for(let W of U.attributes)fe.find(_e=>_e.name===W.name)||(fe.push(W),ee=!0);ee&&(dt({table:s,database:c,attributes:fe,origin:"cluster"}),vh.signalSchemaChange(new Uh.SchemaEventMsg(process.pid,Vt.CREATE_TABLE,c,s)))}else return U.beginTxn?(oe=U,oe.write_promises=[k(U,U)],new Promise(fe=>{oe.resolve=()=>fe(Promise.all(oe.write_promises))})):k(U,U)});oe&&(oe.committed=ce),N&&ce&&!ce?.waitingForUserChange&&(ce.then(()=>vh.signalUserChange(new Uh.UserEventMsg(process.pid))),ce.waitingForUserChange=!0),U.onCommit&&(ce?ce.then(U.onCommit):U.onCommit())}catch(ue){xe.default.error?.("error in subscription handler",ue)}}}catch(D){xe.default.error?.(D)}})(),this}static get isCaching(){return v}static get shouldRevalidateEvents(){return this.prototype.get!==De.prototype.get}static getResource(m,T,I){let y=super.getResource(m,T,I);if(m!=null){Ir(m);try{if(y.getRecord?.())return y;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let b=!I?.async||i.cache?.get?.(m),P=Fr(T),N=P.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return iu(m,T,{transaction:N,ensureLoaded:I?.ensureLoaded},b,L=>{if(L?De._updateResource(y,L):y.#e=null,T.onlyIfCached&&T.noCacheStore){if(!y.doesExist())throw new wr.ServerError("Entry is not cached",504)}else if(I?.ensureLoaded){let k=un(m,L,T,y);if(k)return P?.disregardReadTxn(),y.#i=!0,UP(k,D=>(De._updateResource(y,D),y))}return y})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(m)),b}}return y}static _updateResource(m,T){m.#r=T,m.#e=T?.value??null,m.#n=T?.version}ensureLoaded(){let m=un(this.getId(),this.#r,this.getContext());if(m)return this.#i=!0,UP(m,T=>{this.#r=T,this.#e=T.value,this.#n=T.version})}static getNewId(){let m=F?.type;if(m==="String"||m==="ID")return super.getNewId();if(!Lt){let b=i.getEntry(Symbol.for("id_allocation")),P=b?.value,N;if(P&&P.nodeName===server.hostname&&(!hAe(i)||P.pid===process.pid)){let L=P.start,k=P.end;N=L;for(let D of i.getKeys({start:k,end:L,limit:1,reverse:!0}))N=D}else P=y(b?.version??null),N=P.start;Lt=new BigInt64Array([BigInt(N)+1n]),Lt=new BigInt64Array(i.getUserSharedBuffer("id",Lt.buffer)),Lt.maxSafeId=P.end}let T=Number(Atomics.add(Lt,0,1n)),I=m==="Int"?512:1048576;if(T+I>=Lt.maxSafeId){let b=a(P=>{Lt.maxSafeId=T+(m==="Int"?1023:4194303);let N=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,L=P?void 0:i.useReadTransaction(),k=Number(Lt[0]);for(let $ of i.getKeys({start:k+1,end:N,limit:1,transaction:L}))N=$;L?.done();let{value:D,version:x}=i.getEntry(Symbol.for("id_allocation"));if(Lt.maxSafeId<N){if(D.end>Lt.maxSafeId-100)return;xe.default.info?.("New id allocation",T,Lt.maxSafeId,x),i.put(Symbol.for("id_allocation"),{start:D.start,end:Lt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),x)}else{xe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${Lt.maxSafeId}, but id of ${N} detected`);let $=y(x);$.alreadyUpdated||Atomics.store(Lt,0,BigInt($.start+1)),Lt.maxSafeId=$.end}},"updateEnd");T+I===Lt.maxSafeId?setImmediate(b):T+100>=Lt.maxSafeId&&(xe.default.warn?.(`Synchronous id allocation required on table ${s}${m=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>b(!0)))}return T;function y(b){let P=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,N=P/4,L,k,D=!1,x,$;do{x=Math.floor(Math.random()*P),$={start:x,end:x+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},L=0;for(let j of i.getKeys({start:x,limit:1,reverse:!0}))L=j;k=P;for(let j of i.getKeys({start:x+1,end:P,limit:1}))k=j;N*=.875,N<1e3&&!D&&(D=!0,xe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${m==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,x,L,k,N))}while(!(N<k-x&&(N<x-L||L===0)));return i.transactionSync(()=>{let j=i.getEntry(Symbol.for("id_allocation"));return(j?.version??null)==b?(xe.default.info?.("Allocated new id range",$),i.put(Symbol.for("id_allocation"),$,Date.now()),$):(xe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...j.value})})}}static setTTLExpiration(m){if(typeof m=="number")h=m*1e3,S||(S=0);else if(m&&typeof m=="object")h=m.expiration*1e3,S=(m.eviction||0)*1e3,Zt=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Zt=Zt||(h+S)/4,ca()}static getResidencyRecord(m){return f.get([Symbol.for("residency_by_id"),m])}static setResidency(m){De.getResidency=m}static setResidencyById(m){De.getResidencyById=m}static getResidency(m,T){if(De.getResidencyById)return De.getResidencyById(m[t]);let I=mf;if(T.replicateTo!=null){if(Array.isArray(T.replicateTo))return T.replicateTo.includes(server.hostname)?T.replicateTo:[server.hostname,...T.replicateTo];T.replicateTo>=0&&(I=T.replicateTo)}if(I>=0&&server.nodes){let y=[server.hostname];if(T.previousResidency)y.push(...T.previousResidency.slice(0,I));else{let b=server.nodes.map(L=>L.name),P=Math.floor(b.length*Math.random());y.push(...b.slice(P,P+I));let N=P+I-b.length;N>0&&y.push(...b.slice(0,N))}return y}}static enableAuditing(m=!0){g=m,m&&Tf(),De.audit=m}static coerceId(m){return m===""?null:pA(m,F)}static async dropTable(){delete qe[c][s];for(let m of i.getRange({versions:!0,snapshot:!1,lazy:!0}))m.metadataFlags&qn&&m.value&&Aa(m.value);if(c===o){for(let m of E)f.remove(De.tableName+"/"+m.name),r[m.name]?.drop();f.remove(De.tableName+"/"),i.drop(),await f.committed}else console.log("legacy dropTable"),await i.close(),await _A.default.remove(data_path),await _A.default.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));vh.signalSchemaChange(new Uh.SchemaEventMsg(process.pid,Vt.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this.isCollection)return this.search(m);if(this.getId()===null)return m?.conditions?this.search(m):{records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:E};if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(m,T){let I=Sf(m);if(I?.read){if(I.isSuperUser)return!0;let y=I.attribute_permissions,b=T?.select;if(y?.length>0||nu&&b){if(T||(T={}),b){let P=y?.length>0&&vP(y,"read");T.select=b.map(N=>{let L=N.name||N;if(!P||P[L]){let k=xn[L]?.definition?.tableClass;if(k){if(N.name||(N={name:N}),!k.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else T.select=y.filter(P=>P.read&&!xn[P.attribute_name]).map(P=>P.attribute_name);return T}else return!0}}allowUpdate(m,T){let I=Sf(m);if(I?.update){let y=I.attribute_permissions;if(y?.length>0){let b=vP(y,"update");for(let P in T)if(!b[P])return!1;for(let P of y){let N=P.attribute_name;!P.update&&!(N in T)&&(T[N]=this.getProperty(N))}}return aa(this.getContext())}}allowCreate(m,T){if(this.isCollection){let I=Sf(m);if(I?.insert){let y=I.attribute_permissions;if(y?.length>0){let b=vP(y,"insert");for(let P in T)if(!b[P])return!1;return aa(this.getContext())}else return aa(this.getContext())}}else return this.allowUpdate(m,{})}allowDelete(m){return Sf(m)?.delete&&aa(this.getContext())}update(m,T){if(!Fr(this.getContext()))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let y;return typeof m=="object"&&m&&(T?(Object.isFrozen(m)&&(m={...m}),this.#e={},this.#t=m):(y=this.#t,y&&(m=Object.assign(y,m)),this.#t=m)),this._writeUpdate(this.#t,T),this}addTo(m,T){if(typeof T=="number"||typeof T=="bigint")this.#s===jj?this.set(m,(+this.getProperty(m)||0)+T):(this.#s||this.update(),this.set(m,new kE(T)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,T){if(typeof T=="number")return this.addTo(m,-T);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#r}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(m){this.#t=m}setRecord(m){this.#e=m}invalidate(){this._writeInvalidate()}_writeInvalidate(m,T){let I=this.getContext(),y=this.getId();Ir(y),Fr(this.getContext()).addWrite({key:y,store:i,invalidated:!0,entry:this.#r,before:Ce.invalidate?.bind(this,I,y),beforeIntermediate:me.invalidate?.bind(this,I,y),commit:a((P,N)=>{if(!(oa(P,N,T?.nodeId)<=0)){m??=null;for(let L in r)m||(m={}),m[L]===void 0&&(m[L]=this.getProperty(L));xe.default.trace?.(`Invalidating entry id: ${y}, timestamp: ${new Date(P).toISOString()}`),A(y,m,this.#r,P,kn,g,{user:I?.user,residencyId:T?.residencyId,nodeId:T?.nodeId},"invalidate")}},"commit")})}_writeRelocate(m){let T=this.getContext(),I=this.getId();Ir(I),Fr(this.getContext()).addWrite({key:I,store:i,invalidated:!0,entry:this.#r,before:Ce.relocate?.bind(this,T,I),beforeIntermediate:me.relocate?.bind(this,T,I),commit:a((b,P)=>{if(oa(b,P,m?.nodeId)<=0)return;let N=De.getResidencyRecord(m.residencyId),L=0,k=null,D=P?.value;if(N&&!N.includes(server.hostname)){for(let x in r)k||(k={}),k[x]=D(x);L=kn}else k=D;xe.default.trace?.(`Relocating entry id: ${I}, timestamp: ${new Date(b).toISOString()}`),A(I,k,this.#r,b,L,g,{user:T.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(m,T){let I={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},y=lu(this.getResidency(T.value,I)),b;if(y){if(!y.includes(server.hostname))return;b=uu(y)}let N=A(m.key,T.value,m,m.version,0,!0,{residencyId:b,expiresAt:T.expiresAt},"relocate",!1,null)}static evict(m,T,I){let y=this.Source,b;if(!((v||g)&&(!T||(b=i.getEntry(m),!b||!T)||b.version!==I))){if(v){if(i.hasLock(m,b.version))return;let P;for(let N in r)P||(P={}),P[N]=T[N];if(P)return A(m,P,b,I,Ea,null,null,null,!0)}if(i.ifVersion(m,I,()=>{ln(m,T,null)}),g)return A(m,null,b,I,Ea,null,null,null,!0);Uc(i,b??i.getEntry(m),I)}}lock(){throw new Error("Not yet implemented")}static operation(m,T){return m.table||=s,m.schema||=c,nQ.operation(m,T)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,T,I){let y=this.getContext(),b=Fr(y),P=this.getId();Ir(P);let N=this.#r;this.#s=T?jj:uAe;let L={key:P,store:i,entry:N,nodeName:y?.nodeName,validate:a(k=>{m||(m=this.#t),T||m&&BE(this.#t===m?this:m)?y?.source||(b.checkOverloaded(),this.validate(m,!T),te&&(m[te.name]=te.type==="Date"?new Date(k):te.type==="String"?new Date(k).toISOString():k),T&&(t&&m[t]!==P&&(m[t]=P),Y&&(N?.value?m[Y.name]=N?.value[Y.name]:m[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),m=el(m))):b.removeWrite(L)},"validate"),before:T?Ce.put?()=>Ce.put(y,P,m):null:Ce.patch?()=>Ce.patch(y,P,m):Ce.put?()=>Ce.put(y,P,el(this)):null,beforeIntermediate:T?me.put?()=>me.put(y,P,m):null:me.patch?()=>me.patch(y,P,m):me.put?()=>me.put(y,P,el(this)):null,commit:a((k,D,x)=>{if(x){if(y&&D?.version>(y.lastModified||0)&&(y.lastModified=D.version),this.#r=D,D?.value&&D.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");T||(this.#e=D?.value??null)}this.#t=void 0,this.#n=k;let $=D?.value,j=m;this.#s=0;let oe=!1,U=oa(k,D,I?.nodeId),ue;if(U<=0)if(g){let _e=D.localTime,Ae=D.version;xe.default.trace?.("Applying CRDT update to record with id: ",P,"applying later update:",Ae);let ye=[];for(;_e>k||Ae>=k&&_e>0;){let ut=l.get(_e);if(!ut)break;let rt=wt(ut);if(Ae=rt.version,Ae>=k){if(Ae===k){if(U=oa(k,{version:Ae,localTime:_e},I?.nodeId),U===0)return;if(U>0)continue}if(rt.type==="patch")ye.push(rt),ue=m;else if(rt.type==="put"||rt.type==="delete")return}_e=rt.previousLocalTime}ye.sort((ut,rt)=>ut.version-rt.version);for(let ut of ye){let rt=ut.getValue(i);if(j=UE(j,rt,T),xe.default.debug?.("Rebuilding update with future patch:",j),!j)return}}else{if(T)return;j=UE(j,$,T),xe.default.debug?.("Rebuilding update without audit:",j)}let ce;if(T?ce=j:(this.#e=$,ce=el(this,j)),this.#e=ce,ce&&ce.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let fe;if(I?.residencyId!=null)fe=I.residencyId;else{N?.residencyId&&(y.previousResidency=De.getResidencyRecord(N.residencyId));let _e=lu(De.getResidency(ce,y));if(_e&&!_e.includes(server.hostname))if(ue??=ce,oe=!0,De.getResidencyById)ce=void 0;else{ce=null;for(let Ae in r)ce||(ce={}),ce[Ae]=ue[Ae]}fe=uu(_e)}T||(ue=m);let ee=y?.expiresAt??(h?h+Date.now():-1);xe.default.trace?.(`Saving record with id: ${P}, timestamp: ${new Date(k).toISOString()}${ee?", expires at: "+new Date(ee).toISOString():""}${D?", replaces entry from: "+new Date(D.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(ce).slice(0,100)}catch{return""}})()),ln(P,$,ce);let W=T?"put":"patch";A(P,ce,D,k,oe?kn:0,g,{omitLocalRecord:oe,user:y?.user,residencyId:fe,expiresAt:ee,nodeId:I?.nodeId,originatingOperation:y?.originatingOperation},W,!1,ue),y.expiresAt&&ca()},"commit")};b.addWrite(L)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this.isCollection){for await(let T of this.search(m))(await De.getResource(T[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this.#e?this._writeDelete(m):!1}_writeDelete(m){let T=Fr(this.getContext()),I=this.getId();Ir(I);let y=this.getContext();return T.addWrite({key:I,store:i,entry:this.#r,nodeName:y?.nodeName,before:Ce.delete?.bind(this,y,I),beforeIntermediate:me.delete?.bind(this,y,I),commit:a((b,P,N)=>{let L=P?.value;N&&(y&&P?.version>(y.lastModified||0)&&(y.lastModified=P.version),De._updateResource(this,P)),!(oa(b,P,m?.nodeId)<=0)&&(ln(this.getId(),L),xe.default.trace?.(`Deleting record with id: ${I}, txn timestamp: ${new Date(b).toISOString()}`),g||R?(A(I,null,this.#r,b,0,g,{user:y?.user,nodeId:m?.nodeId},"delete"),g||ca()):Uc(i,P))},"commit")}),!0}search(m){let T=this.getContext(),I=Fr(T);if(!m)throw new Error("No query provided");let y=m.conditions;y?y.length===void 0&&(y=y[Symbol.iterator]?Array.from(y):[y]):y=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this.getId()&&(y=[{attribute:null,comparator:Array.isArray(this.getId())?"prefix":"starts_with",value:this.getId()}].concat(y));let b,P={};function N(W,_e){let Ae;switch(_e){case"and":case void 0:if(W.length<1)throw new Error('An "and" operator requires at least one condition');Ae=!0;break;case"or":if(W.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+_e)}for(let ye of W){if(ye.conditions){ye.conditions=N(ye.conditions,ye.operator);continue}let ut=ye[0]??ye.attribute,rt=ut==null?F:Ni(E,ut);if(rt)(rt.type||fR[ye.comparator])&&(ye[1]===void 0?ye.value=k(ye.value,rt):ye[1]=k(ye[1],rt));else if(ut!=null)throw(0,wr.handleHDBError)(new Error,`${ut} is not a defined attribute`,404);if(ye.chainedConditions)if(ye.chainedConditions.length===1&&(!ye.operator||ye.operator=="and")){let Gr=ye.chainedConditions[0],Ee,Qe;if(Gr.comparator==="gt"||Gr.comparator==="greater_than"||Gr.comparator==="ge"||Gr.comparator==="greater_than_equal"?(Ee=ye,Qe=Gr):(Ee=Gr,Qe=ye),Ee.comparator!=="lt"&&Ee.comparator!=="less_than"&&Ee.comparator!=="le"&&Ee.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let nt=Qe.comparator==="ge"||Qe.comparator==="greater_than_equal",qt=Ee.comparator==="le"||Ee.comparator==="less_than_equal";ye.comparator=(nt?"ge":"gt")+(qt?"le":"lt"),ye.value=[Qe.value,Ee.value]}else throw new Error("Multiple chained conditions are not currently supported")}return W}a(N,"prepareConditions");function L(W,_e){if(m.enforceExecutionOrder)return W;for(let Ae of W)Ae.conditions&&(Ae.conditions=L(Ae.conditions,Ae.operator));return W.length>1&&_e!=="or"?(0,tQ.sortBy)(W,ym(De)):W}a(L,"orderConditions");function k(W,_e){return Array.isArray(W)?W.map(Ae=>pA(Ae,_e)):pA(W,_e)}a(k,"coerceTypedValues");let D=m.operator;(y.length>0||D)&&(y=N(y,D));let x=typeof m.sort=="object"&&m.sort,$;if(x&&D!=="or"){let W=x.attribute;if(W==null)throw new wr.ClientError("Sort requires an attribute");if(b=y.find(_e=>Eu(_e.attribute)===Eu(W)),!b){let _e=Ni(E,W);if(!_e)throw(0,wr.handleHDBError)(new Error,`${Array.isArray(W)?W.join("."):W} is not a defined attribute`,404);if(_e.indexed)b={attribute:W,comparator:"sort"},y.push(b);else if(y.length===0&&!m.allowFullScan)throw(0,wr.handleHDBError)(new Error,`${Array.isArray(W)?W.join("."):W} is not indexed and not combined with any other conditions`,404)}b&&(b.descending=!!x.descending)}y=L(y,D),x&&(b&&y[0]===b?x.next&&($={dbOrderedAttribute:x.attribute,attribute:x.next.attribute,descending:x.next.descending,next:x.next.next}):(b&&y.splice(y.indexOf(b),1),$=x));let j=m.select;if(y.length===0&&(y=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:y,operator:D,postOrdering:$,selectApplied:!!j};let oe=I.useReadTxn(),U=_R(y,D,De,oe,m,T,(W,_e)=>au(W,j,T,oe,_e),P),ue=m.ensureLoaded!==!1;$||(U=ee(U));let ce=De.transformEntryForSelect(j,T,oe,P,ue,!0),fe=De.transformToOrderedSelect(U,j,$,oe,T,ce);function ee(W){return m.offset||m.limit!==void 0?W.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):W}return a(ee,"applyOffset"),$&&(fe=ee(fe)),fe.onDone=()=>{fe.onDone=null,I.doneReadTxn()},fe.selectApplied=!0,fe.getColumns=()=>{if(j){let W=[];for(let _e of j)_e==="*"?W.push(...E.map(Ae=>Ae.name)):W.push(_e.name||_e);return W}return E.filter(W=>!W.computed&&!W.relationship).map(W=>W.name)},fe}static transformToOrderedSelect(m,T,I,y,b,P){let N=new Qh;if(I){m=au(m,T,y,b,null);let L;N.iterate=function(){let D,x=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),$,j=I.dbOrderedAttribute,oe,U,ue=!0;function ce(ee){let W=ee.next&&ce(ee.next),_e=ee.descending;return(Ae,ye)=>{let ut=ou(Ae,ee.attribute,y),rt=ou(ye,ee.attribute,y),Gr=_e?(0,Ql.compareKeys)(rt,ut):(0,Ql.compareKeys)(ut,rt);return Gr===0?W?.(Ae,ye)||0:Gr}}a(ce,"createComparator");let fe=ce(I);return{async next(){let ee;if(D)if(ee=D.next(),ee.done){if($)return N.onDone&&N.onDone(),ee}else return{value:await P.call(this,ee.value)};L=[],oe&&L.push(oe);do if(ee=await x.next(),ee.done){if($=!0,L.length)break;return N.onDone&&N.onDone(),ee}else{let W=ee.value;if(W?.then&&(W=await W),j){let _e=ou(W,j,y);if(ue)ue=!1,U=_e;else if(_e!==U){U=_e,oe=W;break}}L.push(W)}while(!0);return I.isGrouped,L.sort(fe),D=L[Symbol.iterator](),ee=D.next(),ee.done?(N.onDone&&N.onDone(),ee):{value:await P.call(this,ee.value)}},return(){N.onDone&&N.onDone(),x.return()},throw(){N.onDone&&N.onDone(),x.throw()}}};let k=a(D=>{if(typeof T=="object"&&Array.isArray(D.attribute))for(let x=0;x<T.length;x++){let $=T[x],j;if($.name===D.attribute[0]){for(j=$.sort||($.sort={});j.next;)j=j.next;j.attribute=D.attribute.slice(1),j.descending=D.descending}else $===D.attribute[0]&&(T[x]=j={name:$,sort:{attribute:D.attribute.slice(1),descending:D.descending}})}D.next&&k(D.next)},"applySortingOnSelect");k(I)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(function(L){try{let k=P.call(this,L);return typeof k?.catch=="function"?k.catch(D=>{throw D.partialObject={[t]:L.key},D}):k}catch(k){throw k.partialObject={[t]:L.key},k}});return N}static transformEntryForSelect(m,T,I,y,b,P){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let D=a(x=>(T?.transaction?.stale&&(T.transaction.stale=!1),x?.key??x),"transform");return m===t?D:m.asArray?x=>[D(x)]:x=>({[t]:D(x)})}let N;b&&v&&!(typeof m=="string"?[m]:m)?.every(D=>{let x;return typeof D=="object"?x=D.name:x=D,r[x]||x===t})&&(N=!0);let L,k=a(function(D){let x;if(T?.transaction?.stale&&(T.transaction.stale=!1),D!=null){if(x=D.value||D.deref?.()?.value,!x&&(D.key===void 0||D.deref)||D.metadataFlags&kn){if(D.metadataFlags&kn&&T.replicateFrom===!1&&P&&D.residencyId)return hc.SKIP;if(D=iu(D.key??D,T,{transaction:I,lazy:m?.length<4,ensureLoaded:b},this?.isSync,$=>$),D?.then)return D.then(k.bind(this));x=D?.value}if(N&&D?.metadataFlags&(kn|Ea)||D?.expiresAt!=null&&D?.expiresAt<Date.now()){if(T.onlyIfCached&&T.noCacheStore)return{[t]:D.key,message:"This entry has expired"};let $=un(D.key??D,D,T);if($?.then)return $.then(k)}}if(x==null)return P?hc.SKIP:x;if(m&&!(m[0]==="*"&&m.length===1)){let $,j=a((U,ue)=>{let ce;typeof U=="object"?ce=U.name:ce=U;let fe=xn?.[ce],ee;if(fe){let W=y?.[ce];if(W)if(W.hasMappings){let Ae=fe.from?x[fe.from]:Eu(D.key);ee=W.get(Ae),ee||(ee=[])}else ee=W.fromRecord?.(x);else ee=fe(x,T,D);let _e=a(Ae=>{if(Ae&&typeof Ae=="object"){let ye=fe.definition?.tableClass||De;L||(L={});let ut=L[ce]||(L[ce]=ye.transformEntryForSelect(ce===U?null:U.select||(Array.isArray(U)?U:null),T,I,W,b));if(Array.isArray(Ae)){let rt=[],Gr=ye.transformToOrderedSelect(Ae,U.select,typeof U.sort=="object"&&U.sort,T,I,ut)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Ee=a(nt=>{for(;!nt.done;){if(nt?.then)return nt.then(Ee);rt.push(nt.value),nt=Gr.next()}ue(rt,ce)},"nextValue"),Qe=Ee(Gr.next());Qe&&($||($=[]),$.push(Qe));return}else if(Ae=ut.call(this,Ae),Ae?.then){$||($=[]),$.push(Ae.then(rt=>ue(rt,ce)));return}}ue(Ae,ce)},"handleResolvedValue");ee?.then?($||($=[]),$.push(ee.then(_e))):_e(ee);return}else ee=x[ce],ee&&typeof ee=="object"&&ce!==U&&(ee=De.transformEntryForSelect(U.select||U,T,I,null)({value:ee}));ue(ee,ce)},"selectAttribute"),oe;if(typeof m=="string")j(m,U=>{oe=U});else if(Array.isArray(m))if(m.asArray)oe=[],m.forEach((U,ue)=>{U==="*"?m[ue]=x:j(U,ce=>oe[ue]=ce)});else{oe={};let U=m.forceNulls;for(let ue of m)if(ue==="*")for(let ce in x)oe[ce]=x[ce];else j(ue,(ce,fe)=>{ce===void 0&&U&&(ce=null),oe[fe]=ce})}else throw new wr.ClientError("Invalid select"+m);return $?Promise.all($).then(()=>oe):oe}return x},"transform");return k}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||dt({table:s,database:c,schemaDefined:u,attributes:E,audit:!0}),m||(m={});let T=!m.rawEvents,I=[],y=this,b=MP(De,this.getId()??null,function(N,L,k,D){try{let x=L.getValue?.(i,T),$=L.type;if(!x&&$==="patch"&&T){let oe=i.getEntry(N);oe?.version===L.version?x=oe.value:x=L.getValue?.(i,!0,k),$="put"}let j={id:N,localTime:k,value:x,version:L.version,type:$,beginTxn:D};I?I.push(j):this.send(j)}catch(x){xe.default.error?.(x)}},m.startTime||0,m),P=(async()=>{this.isCollection&&(b.includeDescendants=!0,m.onlyChildren&&(b.onlyChildren=!0)),m.supportsTransactions&&(b.supportsTransactions=!0);let N=this.getId(),L=m.previousCount;L>1e3&&(L=1e3);let k=m.startTime;if(this.isCollection){if(k){if(L)throw new wr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:D,value:x}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let $=wt(x);if($.tableId!==n)continue;let j=$.recordId;if(N==null||Zj(N,j)){let oe=$.getValue(i,T,D);if(b.send({id:j,localTime:D,value:oe,version:$.version,type:$.type}),b.queue?.length>Jj&&await b.waitForDrain()===!1)return}b.startTime=D}}else if(L){let D=[];for(let{key:x,value:$}of l.getRange({start:"z",end:!1,reverse:!0}))try{let j=wt($);if(j.tableId!==n)continue;let oe=j.recordId;if(N==null||Zj(N,oe)){let U=j.getValue(i,T,x);if(D.push({id:oe,localTime:x,value:U,version:j.version,type:j.type}),--L<=0)break}}catch(j){xe.default.error("Error getting history entry",x,j)}for(let x=D.length;x>0;)b.send(D[--x]);D[0]&&(b.startTime=D[0].localTime)}else if(!m.omitCurrent){for(let{key:D,value:x,version:$,localTime:j}of i.getRange({start:N??!1,end:N==null?void 0:[N,Ql.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(x&&(b.send({id:D,localTime:j,value:x,version:$,type:"put"}),b.queue?.length>Jj&&await b.waitForDrain()===!1))return}}else{L&&!k&&(k=0);let D=this.#r?.localTime;if(D===zR&&(i.cache?.delete(N),this.#r=i.getEntry(N),xe.default.trace?.("re-retrieved record",D,this.#r?.localTime),D=this.#r?.localTime),xe.default.trace?.("Subscription from",k,"from",N,D),k<D){let x=[],$=D;do{let j=l.get($);if(j){m.omitCurrent=!0;let oe=wt(j),U=oe.getValue(i,T,$);T&&(oe.type="put"),x.push({id:N,value:U,localTime:$,...oe}),$=oe.previousLocalTime}else break;L&&L--}while($>k&&L!==0);for(let j=x.length;j>0;)b.send(x[--j]);b.startTime=D}!m.omitCurrent&&this.doesExist()&&b.send({id:N,localTime:D,value:this.#e,version:this.#n,type:"put"})}for(let D of I)b.send(D);I=null})();return m.listener&&b.on("data",m.listener),b}static subscribeOnThisThread(m,T){return m===0||T?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(m,T){this._writePublish(m,T)}_writePublish(m,T){let I=Fr(this.getContext()),y=this.getId()||null;y!=null&&Ir(y);let b=this.getContext();I.addWrite({key:y,store:i,entry:this.#r,nodeName:b?.nodeName,validate:a(()=>{b?.source||(I.checkOverloaded(),this.validate(m))},"validate"),before:Ce.publish?.bind(this,b,y,m),beforeIntermediate:me.publish?.bind(this,b,y,m),commit:a((P,N,L)=>{N===void 0&&R&&!g&&ca(),xe.default.trace?.(`Publishing message to id: ${y}, timestamp: ${new Date(P).toISOString()}`),A(y,N?.value??null,N,N?.version||P,0,!0,{user:b?.user,residencyId:T?.residencyId,expiresAt:b?.expiresAt,nodeId:T?.nodeId},"message",!1,m)},"commit")})}validate(m,T){let I,y=a((b,P,N)=>{if(P.type&&b!=null)if(T&&b.__op__&&(b=b.value),P.properties){typeof b!="object"&&(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be an object${P.type?" ("+P.type+")":""}`);let L=P.properties;for(let k=0,D=L.length;k<D;k++){let x=L[k],$=y(b[x.name],x,N+"."+x.name);$&&(b[x.name]=$)}if(P.sealed&&b!=null&&typeof b=="object")for(let k in b)L.find(D=>D.name===k)||(I||(I=[])).push(`Property ${k} is not allowed within object in property ${N}`)}else switch(P.type){case"Int":(typeof b!="number"||b>>0!==b)&&(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(L=>typeof L=="string")||(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a string`);break;case"Boolean":typeof b!="boolean"&&(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a bigint`)}break;case"Bytes":if(!(b instanceof Uint8Array)){if(typeof b=="string")return Buffer.from(b);(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(b instanceof Ci)){if(typeof b=="string"&&(b=Buffer.from(b)),b instanceof Buffer)return createBlob(b,{type:"text/plain"});(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be a Blob`)}break;case"array":if(Array.isArray(b)){if(P.elements)for(let L=0,k=b.length;L<k;L++){let D=b[L],x=y(D,P.elements,N+"[*]");x&&(b[L]=x)}}else(I||(I=[])).push(`Value ${qs(b)} in property ${N} must be an Array`);break}P.nullable===!1&&b==null&&(I||(I=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let b=0,P=E.length;b<P;b++){let N=E[b];if(!(N.relationship||N.computed)&&(!T||N.name in m)){let L=y(m[N.name],N,N.name);L&&(m[N.name]=L)}}if(d)for(let b in m)E.find(P=>P.name===b)||(I||(I=[])).push(`Property ${b} is not allowed`);if(I)throw new wr.ClientError(I.join(". "))}getUpdatedTime(){return this.#n}wasLoadedFromSource(){return v?!!this.#i:void 0}static async addAttributes(m){let T=E.slice(0);for(let I of m){if(!I.name)throw new wr.ClientError("Attribute name is required");if(I.name.match(/[`/]/))throw new wr.ClientError("Attribute names cannot include backticks or forward slashes");(0,rQ.validateAttribute)(I.name),T.push(I)}return dt({table:s,database:c,schemaDefined:u,attributes:T}),De.indexingOperation}static async removeAttributes(m){let T=E.filter(I=>!m.includes(I.name));return dt({table:s,database:c,schemaDefined:u,attributes:T}),De.indexingOperation}static getSize(){let m=i.getStats();return(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getAuditSize(){let m=l?.getStats();return m&&(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getStorageStats(){let m=i.env.path,T=_A.default.statfsSync?.(m)??{};return{available:T.bavail*T.bsize,free:T.bfree*T.bsize,size:T.blocks*T.bsize}}static async getRecordCount(m){let T=i.getStats().entryCount,I=1e3/2,y=performance.now(),b=Math.floor(T/2),P=m?.exactCount,N=0,L=0,k;for(let{value:D}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(D!=null&&N++,L++,await pc(),!P&&L<b&&performance.now()-y>I){k=L;break}if(k){let D=N;N=0;for(let{value:ee}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k,snapshot:!1}))ee!=null&&N++,await pc();let x=k*2,$=(N+D)/x,j=Math.pow((N-D+1)/k/2,2)+$*(1-$)/x,oe=Math.max(Math.sqrt(j)*T,1),U=Math.round($*T),ue=Math.max(U-1.96*oe,N+D),ce=Math.min(U+1.96*oe,T),fe=Math.pow(10,Math.round(Math.log10(oe)));return fe>U&&(fe=fe/10),N=Math.round(U/fe)*fe,{recordCount:N,estimatedRange:[Math.round(ue),Math.round(ce)]}}return{recordCount:N}}static updatedAttributes(){xn=this.propertyResolvers={$id:a((m,T,I)=>({value:I.key}),"$id"),$updatedtime:a((m,T,I)=>I.version,"$updatedtime"),$record:a((m,T,I)=>I?{value:m}:m,"$record")};for(let m of this.attributes){m.resolve=null;let T=m.relationship,I=m.computed;if(T)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),I&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),nu=!0,T.to)m.elements?.definition?(xn[m.name]=m.resolve=(y,b,P)=>{let N=y[T.from?T.from:t],L=m.elements.definition.tableClass;return P?mu({attribute:T.to,value:N},Fr(b).getReadTxn(),!1,L,!1).asArray:L.search([{attribute:T.to,value:N}],b).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,T.from&&(m.resolve.from=T.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(T.from){let y=m.definition||m.elements?.definition;y?(xn[m.name]=m.resolve=(b,P,N)=>{let L=b[T.from];if(L!==void 0){if(m.elements){let k,D=L?.map(x=>{let $=N?y.tableClass.primaryStore.getEntry(x,{transaction:Fr(P).getReadTxn()}):y.tableClass.get(x,P);return $?.then&&(k=!0),$});return T.filterMissing?k?Promise.all(D).then(x=>x.filter(eQ)):D.filter(eQ):k?Promise.all(D):D}return N?y.tableClass.primaryStore.getEntry(L,{transaction:Fr(P).getReadTxn()}):y.tableClass.get(L,P)}},m.set=(b,P)=>{if(Array.isArray(P)){let N=P.map(L=>L.getId?.()||L[y.tableClass.primaryKey]);b[T.from]=N}else{let N=P.getId?.()||P[y.tableClass.primaryKey];b[T.from]=N}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=T.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else I&&(typeof I.from=="function"&&this.setComputedAttribute(m.name,I.from),xn[m.name]=m.resolve=(y,b,P)=>{let N=typeof I.from=="string"?y[I.from]:y,L=this.userResolvers[m.name];if(L)return L(N,b,P);xe.default.warn(`Computed attribute "${m.name}" does not have a function assigned to it. Please use setComputedAttribute('${m.name}', resolver) to assign a resolver function.`),this.userResolvers[m.name]=()=>{}})}FE(this,this)}static setComputedAttribute(m,T){let I=Ni(E,m);if(!I){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!I.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=T}static async deleteHistory(m=0,T=!1){let I;for(let{key:y,value:b}of l.getRange({start:0,end:m}))await pc(),wt(b).tableId===n&&(I=dA(l,y,b));if(T)for(let y of i.getRange({start:0,versions:!0})){let{key:b,value:P,localTime:N}=y;await pc(),P===null&&N<m&&(I=Uc(i,y))}await I}static async*getHistory(m=0,T=1/0){for(let{key:I,value:y}of l.getRange({start:m||1,end:T})){await pc();let b=wt(y);b.tableId===n&&(yield{id:b.recordId,localTime:I,version:b.version,type:b.type,value:b.getValue(i,!0,I),user:b.user,operation:b.originatingOperation})}}static async getHistoryOfRecord(m){let T=[];if(m==null)throw new Error("An id is required");let I=i.getEntry(m);if(!I)return T;let y=I.localTime;if(!y)throw new Error("The entry does not have a local audit time");let b=0;do{await pc();let P=l.get(y);if(P){let N=wt(P);T.push({id:N.recordId,localTime:y,version:N.version,type:N.type,value:N.getValue(i,!0,y),user:N.user}),y=N.previousLocalTime}else break}while(b<1e3&&y);return T.reverse()}static cleanup(){X?.remove()}}De.updatedAttributes();let gf=De.prototype;return h&&De.setTTLExpiration(h/1e3),ie&&cu(),De;function ln(K,m,T){let I;for(let y in r){let b=r[y],P=b.isIndexing,N=xn[y],L=T&&(N?N(T):T[y]),k=m&&(N?N(m):m[y]);if(L===k&&!P)continue;I=!0;let D=b.indexNulls,x=(0,Mh.getIndexedValues)(L,D),$=(0,Mh.getIndexedValues)(k,D);if($?.length>0){let j=new Set($);if(x=x?x.filter(oe=>{if(j.has(oe))j.delete(oe);else return!0}):[],$=Array.from(j),($.length>0||x.length>0)&&zj){let oe=$.concat(x).map(U=>({key:U,value:K}));b.prefetch(oe,Xj)}for(let oe=0,U=$.length;oe<U;oe++)b.remove($[oe],K)}else x?.length>0&&zj&&b.prefetch(x.map(j=>({key:j,value:K})),Xj);if(x)for(let j=0,oe=x.length;j<oe;j++)b.put(x[j],K)}return I}a(ln,"updateIndices");function Ir(K){switch(typeof K){case"number":return!0;case"string":if(K.length<659)return!0;if(K.length>Qj)throw new Error("Primary key size is too large: "+K.length);break;case"object":if(K===null)throw new Error("Invalid primary key of null");break;case"bigint":if(K<2n**64n&&K>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof K)}if((0,Ql.writeKey)(K,dAe,0)>Qj)throw new Error("Primary key size is too large: "+K.length);return!0}a(Ir,"checkValidId");function iu(K,m,T,I,y){if(De.getResidencyById&&T.ensureLoaded&&m?.replicateFrom!==!1){let P=lu(De.getResidencyById(K));if(P&&!P.includes(server.hostname)&&O)return O({key:K,residency:P}).then(y)}let b=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),T.transaction?.isDone)return y(null,K);let P=i.getEntry(K,T);return P?.residencyId&&P.metadataFlags&kn&&O&&T.ensureLoaded&&m?.replicateFrom!==!1?O(P).then(N=>y(N,K),N=>(xe.default.error?.("Error loading remote record",K,P,T,N),y(null,K))):(P&&m&&(P?.version>(m.lastModified||0)&&(m.lastModified=P.version),P?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=P.localTime)),y(P,K))},"whenPrefetched");return I?b():he>0?(he--,b()):new Promise((P,N)=>{he===0?(he--,i.prefetch([K],()=>{L(),k()})):(ne.push(K),Q.push(k),ne.length>Jh&&(he--,L()));function L(){if(ne.length>0){let D=Q;i.prefetch(ne,()=>{he===-1?L():he++;for(let x of D)x()}),ne=[],Q=[],Re>2&&Re--}else he=Re,Re<Ef&&Re++}a(L,"prefetch");function k(){try{P(b())}catch(D){N(D)}}a(k,"load")})}a(iu,"loadLocalRecord");function Sf(K){if(!K?.role)return;let m=K.role.permission;if(m.super_user)return fAe;let T=m[c],I,y=T?.tables;if(y)return y[s];if(c==="data"&&(I=m[s])&&!I.tables)return I}a(Sf,"getTablePermissions");function un(K,m,T,I){if(v){let y=!1;if(T.noCache?y=!0:(m?(!m.value||m.metadataFlags&(kn|Ea)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(y=!0):y=!0,Zn(!y,"cache-hit",s)),y){let b=Xh(K,m,T).then(P=>(P?.value&&P?.value.getRecord?.()&&xe.default.error?.("Can not assign a record that is already a resource"),T&&(P?.version>(T.lastModified||0)&&(T.lastModified=P.version),T.lastRefreshed=Date.now()),P));if(T?.onlyIfCached||m?.value&&I?.allowStaleWhileRevalidate?.(m,K)){if(b.catch(P=>xe.default.warn?.(P)),T?.onlyIfCached&&!I.doesExist())throw new wr.ServerError("Entry is not cached",504);return}else return b}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return De.evict(m.key,m.value,m.version),m.value=null,{then(y){return y(m)}}}a(un,"ensureLoadedFromSource");function Fr(K){let m=K?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let T=m.next;if(!T)return m=m.next=new bc,m.lmdbDb=i,m;m=T}while(!0)}else return new Tm}a(Fr,"txnForContext");function ou(K,m,T){if(!K)return;let I=K.value||i.getEntry(K.key)?.value;if(typeof m=="object"){let b=xn,P=I;for(let N=0,L=m.length;N<L;N++){let k=m[N],D=b?.[k];P=D&&P?D(P,T,!0)?.value:P?.[k],b=D?.definition?.tableClass?.propertyResolvers}return P}let y=xn[m];return y?y(I,T):I[m]}a(ou,"getAttributeValue");function au(K,m,T,I,y){let b=y?.length,P={transaction:I,lazy:b>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function L(k,D){let x=k?.value;if(!x)return hc.SKIP;for(let $=0;$<b;$++)if(!N?.includes($)&&!y[$](x,k))return hc.SKIP;return D!==void 0&&(k.key=D),k}if(a(L,"processEntry"),b>0||!K.hasEntries){let k=K.map(D=>{if(N=null,typeof D=="object"&&D?.key!==void 0)return b>0?L(D):D;if(D==null)return hc.SKIP;for(let x=0;x<b;x++){let j=y[x].idFilter;if(j){if(!j(D))return hc.SKIP;N||(N=[]),N.push(x)}}return iu(D,T,P,!1,L)});return Array.isArray(K)&&(k=k.filter(D=>D!==hc.SKIP)),k.hasEntries=!0,k}return K}a(au,"transformToEntries");function oa(K,m,T=server.replication?.getThisNodeId(l)){if(K<=m?.version){if(m?.version===K&&T!==void 0){let I=server.replication?.exportIdMapping(l),y=m.localTime,b=y&&l.get(y);if(b){let P,N,L=wt(b);for(let k in I)I[k]===T&&(P=k),I[k]===L.nodeId&&(N=k);if(P>N)return 1;if(P===N)return 0}}return-1}return 1}a(oa,"precedesExistingVersion");async function Xh(K,m,T){let I=m?.metadataFlags,y=m?.version,b,P;if(!i.attemptLock(K,y,()=>{clearTimeout(P);let D=i.getEntry(K);!D||!D.value||D.metadataFlags&(kn|Ea)?b(Xh(K,i.getEntry(K),T)):b(D)}))return new Promise(D=>{b=D,P=setTimeout(()=>{i.unlock(K,y)},lAe)});let N=m?.value,L={requestContext:T,replacingRecord:N,replacingEntry:m,replacingVersion:y,noCacheStore:!1,source:null,resourceCache:T?.resourceCache},k=T?.responseHeaders;return new Promise((D,x)=>{let $;UP(Nt(L,async j=>{let oe=performance.now(),U,ue,ce;try{for(let _e of De.sources)if(_e.get&&(!_e.get.reliesOnPrototype||_e.prototype.get)){if(_e.available?.(m)===!1)continue;if(L.source=_e,U=await _e.get(K,L),U)break}ce=I&kn;let ee=L.lastModified||ce&&y;ue=ce||ee>y||!N,ee||(ee=(0,Mh.getNextMonotonicTime)());let W=performance.now()-oe;if(ir(W,"cache-resolution",s,null,"success"),k&&ZE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),j.timestamp=ee,h&&L.expiresAt==null&&(L.expiresAt=Date.now()+h),U){if(typeof U!="object")throw new Error("Only objects can be cached and stored in tables");if(U.status>0&&U.headers)if(U.status>=300)if(U.status===304)U=N,ee=y;else throw new wr.ServerError(U.body||"Error from source",U.status);else U=U.body;typeof U.toJSON=="function"&&(U=U.toJSON()),t&&U[t]!==K&&(U[t]=K)}$=!0,D({key:K,version:ee,value:U})}catch(ee){ee.message+=` while resolving record ${K} for ${s}`,N&&((ee.code==="ECONNRESET"||ee.code==="ECONNREFUSED"||ee.code==="EAI_AGAIN")&&!T?.mustRevalidate||T?.staleIfError&&(ee.statusCode===500||ee.statusCode===502||ee.statusCode===503||ee.statusCode===504))?(D({key:K,version:y,value:N}),xe.default.trace?.(ee.message,"(returned stale record)")):x(ee);let W=performance.now()-oe;ir(W,"cache-resolution",s,null,"fail"),k&&ZE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),L.transaction.abort();return}if(T?.noCacheStore||L.noCacheStore){L.transaction.abort();return}Fr(L).addWrite({key:K,store:i,entry:m,nodeName:"source",commit:a((ee,W)=>{if(W?.version!==y)return;let _e=ln(K,N,U);U?(me.put?.(L,K,U),xe.default.trace?.(`Writing resolved record from source with id: ${K}, timestamp: ${new Date(ee).toISOString()}`),A(K,U,W,ee,0,g&&ue||null,{user:L?.user,expiresAt:L.expiresAt},"put",!!ce)):W&&(me.delete?.(L,K),xe.default.trace?.(`Deleting resolved record from source with id: ${K}, timestamp: ${new Date(ee).toISOString()}`),g||R?A(K,null,W,ee,0,g&&ue||null,{user:L?.user},"delete",!!ce):Uc(i,W,y))},"commit")})}),()=>{i.unlock(K,y)},j=>{i.unlock(K,y),$&&xe.default.error?.("Error committing cache update",j)})})}a(Xh,"getFromSource");function aa(K){if(!K||K.user?.role?.permission?.super_user)return!0;if(K.replicateTo)throw new wr.ClientError("Can not specify replication parameters without super user permissions",403);if(K.replicatedConfirmation)throw new wr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(aa,"checkContextPermissions");function ca(K){let m=!1;if(K&&(K-lt>1&&(m=!0),lt=K),!(Zt===yr&&!m)&&(yr=Zt,(0,zl.getWorkerIndex)()===(0,zl.getWorkerCount)()-1))return Es&&clearTimeout(Es),Zt?new Promise(T=>{let I=new Date;I.setMonth(0),I.setDate(1),I.setHours(0),I.setMinutes(0),I.setSeconds(0);let y=Zt/(1+lt),b=m?Date.now():Math.ceil((Date.now()-I.getTime())/y)*y+I.getTime(),P=a(N=>{xe.default.trace?.(`Scheduled next cleanup scan at ${new Date(N)}`),Es=setTimeout(()=>G=G.then(async()=>{if(P(Math.max(N+Zt,Date.now())),i.rootStore.status!=="open"){clearTimeout(Es);return}let L=50,k=new Array(L),D=0,x=Math.pow(lt,8)*(jl.get(B.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),$=S/Math.pow(Math.max(lt,1),4);xe.default.info?.(`Starting cleanup scan for ${s}, evict threshold ${x}, adjusted eviction ${$}ms`);function j(oe,U,ue,ce){let fe=oe+$-Date.now();if(fe<0)return!0;if(lt){let ee=i.lastSize;return ue&qn&&Yf(ce,W=>{W.size&&(ee+=W.size)}),xe.default.trace?.(`shouldEvict adjusted ${fe} ${ee}, ${fe*(oe-U)/ee} < ${x}`),fe*(oe-U)/ee<x}return!1}a(j,"shouldEvict");try{let oe=0;for(let U of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:ue,value:ce,version:fe,expiresAt:ee,metadataFlags:W}=U,_e;ce===null&&!g&&fe+cAe<Date.now()?_e=Uc(i,U,fe):ee!=null&&j(ee,fe,W,ce)&&(_e=De.evict(ue,ce,fe),oe++),_e&&(await k[D],k[D]=_e.catch(Ae=>{xe.default.error?.("Cleanup error",Ae)}),++D>=L&&(D=0)),await pc()}xe.default.info?.(`Finished cleanup scan for ${s}, evicted ${oe} entries`)}catch(oe){xe.default.warn?.(`Error in cleanup scan for ${s}:`,oe)}T(void 0),lt=0}),Math.min(N-Date.now(),2147483647)).unref()},"startNextTimer");P(b)}):void 0}a(ca,"scheduleCleanup");function Tf(){X=l?.addDeleteRemovalCallback(n,i,(K,m)=>{i.remove(K,m)})}a(Tf,"addDeleteRemoval");function cu(){(0,zl.getWorkerIndex)()===0&&setInterval(async()=>{if(!su){su=!0;try{let K=ie.name,m=r[K];if(!m)throw new Error(`expiresAt attribute ${ie} must be indexed`);for(let T of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let I of m.getValues(T)){let y=i.getEntry(I);y?.value?y.value[K]<Date.now()&&De.evict(I,y.value,y.version):i.ifVersion(I,y?.version,()=>m.remove(T,I))}await pc()}}catch(K){xe.default.error?.("Error in evicting old records",K)}finally{su=!1}}},aAe).unref()}a(cu,"runRecordExpirationEviction");function lu(K){if(K!=null){if(Array.isArray(K))return K;if(typeof K=="number"){if(K>=65536)throw new Error(`Shard id ${K} must be below 65536`);let m=server.shards.get?.(K);if(m)return m.map(T=>T.name);throw new Error(`Shard ${K} is not defined`)}throw new Error(`Shard or residency list ${K} is not a valid type, must be a shard number or residency list of node hostnames`)}}a(lu,"residencyFromFunction");function uu(K){if(K){let m=K.join(","),T=f.get([Symbol.for("residency_by_set"),m]);return T||(f.put([Symbol.for("residency_by_set"),m],T=Math.floor(Math.random()*2147418112)+65535),f.put([Symbol.for("residency_by_id"),T],K),T)}}a(uu,"getResidencyId")}function vP(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function Xj(){}function _Ae(e){nQ=e}function pA(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return fA(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return fA(+e);case"Float":return e==="null"?null:fA(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;pAe.test(e)||(e+="Z");let n=new Date(e);return fA(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,hA.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function fA(e){if(isNaN(e))throw new SyntaxError;return e}function Zj(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function UP(e,t,r){return e?.then?e.then(t,r):t(e)}function eQ(e){return e!=null}function qs(e){try{return JSON.stringify(e)}catch{return e}}function hAe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var hc,Mh,tQ,rQ,jl,wr,vh,Uh,xe,Ql,zl,hA,_A,oAe,nQ,aAe,cAe,zj,lAe,jj,uAe,kn,Ea,dAe,Qj,Jj,fAe,cxe,pAe,pc,Gf=be(()=>{H();hc=require("lmdb"),Mh=M(_n()),tQ=require("lodash"),rQ=M(Uf());ga();Am();jl=M(ae());SN();wr=M(pe()),vh=M(yo()),Uh=M(ni());Pe();Ff();xe=M(Ii());Kb();Oc();Ql=require("ordered-binary"),zl=M(et());ho();hA=M(se());Ou();qi();xE();Q_();_A=M(require("node:fs"));Ts();vT();oAe=new Uint8Array(9);oAe[8]=192;aAe=6e4,cAe=864e5;jl.initSync();zj=jl.get(B.STORAGE_PREFETCHWRITES),lAe=1e4,jj=1,uAe=2,kn=1,Ea=8,dAe=Buffer.allocUnsafeSlow(8192),Qj=1978,Jj=100,fAe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},cxe=(0,hA.convertToMS)(jl.get(B.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(mA,"makeTable");a(vP,"attributesAsObject");a(Xj,"noop");a(_Ae,"setServerUtilities");pAe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(pA,"coerceType");a(fA,"rejectNaN");a(Zj,"isDescendantId");pc=a(()=>new Promise(setImmediate),"rest");a(UP,"when");a(eQ,"exists");a(qs,"stringify");a(hAe,"hasOtherProcesses")});var tt={};ve(tt,{database:()=>Fu,database_envs:()=>ta,databases:()=>qe,dropDatabase:()=>Qb,dropTableMeta:()=>TAe,getDatabases:()=>Je,getDefaultCompression:()=>IS,getTables:()=>mAe,onRemovedDB:()=>mp,onUpdatedTable:()=>ml,readMetaDb:()=>xh,resetDatabases:()=>Cd,table:()=>dt,tables:()=>Xn});function mAe(){return TA||Je(),Xn||{}}function Je(){if(TA)return qe;TA=!0,df=new Map;let e=(0,Jt.getHdbBasePath)()&&(0,Dt.join)((0,Jt.getHdbBasePath)(),yc),t=(0,Jt.get)(B.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Jt.get)(B.STORAGE_PATH)||e&&((0,fs.existsSync)(e)?e:(0,Dt.join)((0,Jt.getHdbBasePath)(),im)),!e)return;if((0,fs.existsSync)(e))for(let n of(0,fs.readdirSync)(e,{withFileTypes:!0})){let s=(0,Dt.basename)(n.name,".mdb");n.isFile()&&(0,Dt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&xh((0,Dt.join)(e,n.name),null,s)}if((0,fs.existsSync)((0,uf.getBaseSchemaPath)())){for(let n of(0,fs.readdirSync)((0,uf.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Dt.join)((0,uf.getBaseSchemaPath)(),n.name),i=(0,Dt.join)((0,uf.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,fs.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Dt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Dt.join)(i,o.name);xh((0,Dt.join)(s,o.name),(0,Dt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,fs.existsSync)(i))for(let c of(0,fs.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Dt.extname)(c.name).toLowerCase()===".mdb"&&xh((0,Dt.join)(i,c.name),(0,Dt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Dt.join)(l.path,(0,Dt.basename)(c+".mdb"));(0,fs.existsSync)(u)&&xh(u,c,n,null,!0)}}for(let n in qe){let s=df.get(n);if(s){let i=qe[n];n.includes("delete")&&Ft.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Ft.trace(`delete table class ${o}`),delete i[o])}else if(delete qe[n],n==="data"){for(let i in Xn)delete Xn[i];delete Xn[AA]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(qe.system)for(let n of r)qe.system[n]&&(qe.system[n].replicate=!1);return df=null,qe}function Cd(){TA=!1;for(let[,e]of ta)e.needsDeletion=!0;Je();for(let[e,t]of ta)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),ta.delete(e),delete qe[t.databaseName],Hh.forEach(r=>r(t.databaseName)));return qe}function xh(e,t,r=HP,n,s){let i=new xP.default(e,!1);try{let o=ta.get(e);o?o.needsDeletion=!1:(o=(0,ff.open)(i),ta.set(e,o));let c=new Jl.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(EA.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,fs.existsSync)(n)&&(i.path=n,u=(0,ff.open)(i),u.isLegacy=!0):u=uA(o));let f=aQ(r),d=f[AA],p=new Map;for(let{key:_,value:h}of l.getRange({start:!1})){let[S,g]=_.toString().split("/");g===""?g=h.name:g||(g=S,S=t,h.name||(h.name=g,h.indexed=!h.is_hash_attribute)),d?.add(S);let R=p.get(S);R||p.set(S,R={attributes:[]}),(g==null||h.is_hash_attribute)&&(R.primary=h),g!=null&&R.attributes.push(h),Object.defineProperty(h,"key",{value:_,configurable:!0})}for(let[_,h]of p){let{attributes:S,primary:g}=h;if(!g){for(let Q of S)if(Q.is_hash_attribute||Q.isPrimaryKey){g=Q;break}if(!g){Ft.warn(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(S)}`);continue}}let R=f[_],E={},A=[],O,v,F=typeof g.audit=="boolean"?g.audit:(0,Jt.get)(B.LOGGING_AUDITLOG),G=g.trackDeletes,Y=g.expiration,te=g.eviction,ie=g.sealed,X=g.splitSegments,ne=g.replicate;if(R)E=R.indices,A=R.attributes,R.schemaVersion++;else{O=g.tableId,O?O>=(l.get(lf)||0)&&(l.putSync(lf,O+1),Ft.info(`Updating next table id (it was out of sync) to ${O+1} for ${_}`)):(g.tableId=O=l.get(lf),O||(O=1),Ft.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(lf,O+1),l.putSync(g.key,g));let Q=new Jl.default(!g.is_hash_attribute,g.is_hash_attribute);if(Q.compression=g.compression,Q.compression){let he=(0,Jt.get)(B.STORAGE_COMPRESSION_THRESHOLD)||oQ;Q.compression.threshold=he}v=jm(o.openDB(g.key,Q),o),o.databaseName=r,v.tableId=O}for(let Q of S){Q.attribute=Q.name;try{if(!Q.is_hash_attribute&&(Q.indexed||Q.attribute&&!Q.name)){if(!E[Q.name]){let Re=new Jl.default(!Q.is_hash_attribute,Q.is_hash_attribute);E[Q.name]=o.openDB(Q.key,Re),E[Q.name].indexNulls=Q.indexNulls}let he=A.find(Re=>Re.name===Q.name);he?A.splice(A.indexOf(he),1,Q):A.push(Q)}}catch(he){Ft.error("Error trying to update attribute",Q,A,E,he)}}if(!R){R=cQ(f,_,mA({primaryStore:v,auditStore:u,audit:F,sealed:ie,splitSegments:X,replicate:ne,expirationMS:Y&&Y*1e3,evictionMS:te&&te*1e3,trackDeletes:G,tableName:_,tableId:O,primaryKey:g.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:E,attributes:S,schemaDefined:g.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let Q of Bh)Q(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function aQ(e){let t=qe[e];if(t||(e==="data"?t=qe[e]=Xn:e==="system"?Object.defineProperty(qe,"system",{value:t=Object.create(null),configurable:!0}):t=qe[e]=Object.create(null)),df&&!df.has(e)){let r=new Set;t[AA]=r,df.set(e,r)}return t}function cQ(e,t,r){return e[t]=r,r}function Fu({database:e,table:t}){e||(e=HP),Je();let r=aQ(e),n=(0,Dt.join)((0,Jt.getHdbBasePath)(),yc),s=(0,Jt.get)(B.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Jt.get)(B.STORAGE_PATH)||((0,fs.existsSync)(n)?n:(0,Dt.join)((0,Jt.getHdbBasePath)(),im));let o=(0,Dt.join)(n,(i?t:e)+".mdb"),c=ta.get(o);if(!c||c.status==="closed"){let l=new xP.default(o,!1);c=(0,ff.open)(l),ta.set(o,c)}return c.auditStore||(c.auditStore=uA(c)),c}async function Qb(e){if(!qe[e])throw new Error("Schema does not exist");let t=qe[e],r;for(let n in t)r=t[n].primaryStore.rootStore,ta.delete(r.path),r.status==="open"&&(await r.close(),await kh.remove(r.path));if(r||(r=Fu({database:e,table:null}),r.status==="open"&&(await r.close(),await kh.remove(r.path))),e==="data"){for(let n in Xn)delete Xn[n];delete Xn[AA]}delete qe[e],Hh.forEach(n=>n(e)),await NR(r)}function dt(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,schemaDefined:p,origin:_}=e;r||(r=HP);let h=Fu({database:r,table:t}),S=qe[r];Ft.trace(`Defining ${t} in ${r}`);let g=S?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let R,E,A;p==null&&(p=!0);let O=new Jl.default(!1);for(let X of o)X.attribute&&!X.name?(X.name=X.attribute,X.indexed=!0):X.attribute=X.name,X.expiresAt&&(X.indexed=!0);let v,F;if(g){if(R=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...o)}else{let X=h.auditStore;E=o.find(Re=>Re.isPrimaryKey)||{},R=E.name,E.is_hash_attribute=E.isPrimaryKey=!0,E.schemaDefined=p,E.compression=IS(),d&&(E.trackDeletes=!0),c=E.audit=typeof c=="boolean"?c:(0,Jt.get)(B.LOGGING_AUDITLOG),n&&(E.expiration=n),s&&(E.eviction=s),u??=!1,E.splitSegments=u,typeof l=="boolean"&&(E.sealed=l),typeof f=="boolean"&&(E.replicate=f),_&&(E.origins?E.origins.includes(_)||E.origins.push(_):E.origins=[_]),Ft.trace(`${t} table loading, opening primary store`);let ne=new Jl.default(!1,!0);ne.compression=E.compression;let Q=t+"/";if(A=h.dbisDb=h.openDB(EA.INTERNAL_DBIS_NAME,O),ie(),A.get(Q))return F&&F(),Cd(),dt(e);let he=jm(h.openDB(Q,ne),h);h.databaseName=r,he.tableId=A.get(lf),Ft.trace(`Assigning new table id ${he.tableId} for ${t}`),he.tableId||(he.tableId=1),A.put(lf,he.tableId+1),E.tableId=he.tableId,g=cQ(S,t,mA({primaryStore:he,auditStore:X,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:R,tableName:t,tableId:he.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:p,dbisDB:A})),g.schemaVersion=1,v=!0,A.put(Q,E)}let G=g.indices;A=A||(h.dbisDb=h.openDB(EA.INTERNAL_DBIS_NAME,O)),g.dbisDB=A;let Y=[];for(let{key:X,value:ne}of A.getRange({start:!0})){let[Q,he]=X.toString().split("/");if(he===""&&(he=ne.name),he){if(Q!==t)continue}else continue;let Re=o.find(me=>me.name===he),Ce=!Re?.indexed&&ne.indexed&&!ne.isPrimaryKey;if((!Re||Ce)&&(ie(),v=!0,Re||A.remove(X),Ce)){let me=g.indices[Q];me&&Y.push(me)}}let te=[];try{for(let X of o||[]){if((X.relationship||X.computed)&&(v=!0,X.relationship))continue;let ne=t+"/"+(X.name||"");Object.defineProperty(X,"key",{value:ne,configurable:!0});let Q=A.get(ne);if(X.isPrimaryKey){if(Q=Q||A.get(ne=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||f!==void 0&&f!==g.replicate||(+n||void 0)!==(+Q.expiration||void 0)||(+s||void 0)!==(+Q.eviction||void 0)){let Re={...Q};typeof c=="boolean"&&(c&&g.enableAuditing(c),Re.audit=c),n&&(Re.expiration=+n),s&&(Re.eviction=+s),l!==void 0&&(Re.sealed=l),f!==void 0&&(Re.replicate=f),v=!0,ie(),A.put(ne,Re)}continue}Q?.attribute&&!Q.name&&(Q.indexed=!0);let he=!Q||Q.type!==X.type||Q.indexed!==X.indexed||Q.nullable!==X.nullable||Q.version!==X.version||JSON.stringify(Q.properties)!==JSON.stringify(X.properties)||JSON.stringify(Q.elements)!==JSON.stringify(X.elements);if(X.indexed){let Re=new Jl.default(!0,!1),Ce=h.openDB(ne,Re);(he||Q.indexingPID&&Q.indexingPID!==process.pid||Q.restartNumber<Fh.workerData?.restartNumber)&&(v=!0,ie(),Q=A.get(ne),(he||Q.indexingPID&&Q.indexingPID!==process.pid||Q.restartNumber<Fh.workerData?.restartNumber)&&(v=!0,X.indexNulls===void 0&&(X.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(X.lastIndexedKey=Q?.lastIndexedKey??void 0,X.indexingPID=process.pid,Ce.isIndexing=!0,Object.defineProperty(X,"dbi",{value:Ce}),te.push(X))),A.put(ne,X)),Q?.indexNulls&&X.indexNulls===void 0&&(X.indexNulls=!0),Ce.indexNulls=X.indexNulls,G[X.name]=Ce}else he&&(v=!0,ie(),A.put(ne,X))}}finally{F&&F()}if(v&&(g.schemaVersion++,g.updatedAttributes()),Ft.trace(`${t} table loading, running index`),te.length>0||Y.length>0?g.indexingOperation=SAe(g,te,Y):v&&gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,v)for(let X of Bh)X(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Ft.trace(`${t} table loaded`),g;function ie(){F||h.transactionSync(()=>({then(X){F=X}}))}a(ie,"startTxn")}async function SAe(e,t,r){try{Ft.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let d of t)(0,ff.compareKeys)(d.lastIndexedKey,u)<0&&(u=d.lastIndexedKey),d.lastIndexedKey==null&&d.dbi.clearAsync();let f=0;for(let{key:d,value:p,version:_}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(p){if(f++,s=e.primaryStore.ifVersion(d,_,()=>{for(let h=0;h<l;h++){let S=t[h],g=S.name;try{let R=S.resolve,E=p&&(R?R(p):p[g]),A=(0,sQ.getIndexedValues)(E);if(A)for(let O=0,v=A.length;O<v;O++)S.dbi.put(A[O],d)}catch(R){o[g]||(o[g]=!0,Ft.error(`Error indexing attribute ${g}`,R))}}}),s.then(()=>f--,h=>{f--,Ft.error(h)}),Fh.workerData&&Fh.workerData.restartNumber!==iQ.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=d,e.dbisDB.put(h.key,h);if(i)return}f>EAe?await s:f>gAe&&await new Promise(h=>setImmediate(h))}for(let d of t)delete d.lastIndexedKey,delete d.indexingPID,d.dbi.isIndexing=!1,s=e.dbisDB.put(d.key,d)}await s,await gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Ft.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Ft.error("Error in indexing",n)}}function TAe({table:e,database:t}){let r=Fu({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function ml(e){return Bh.push(e),{remove(){let t=Bh.indexOf(e);t>-1&&Bh.splice(t,1)}}}function mp(e){return Hh.push(e),{remove(){let t=Hh.indexOf(e);t>-1&&Hh.splice(t,1)}}}function IS(){let e=(0,Jt.get)(B.STORAGE_COMPRESSION),t=(0,Jt.get)(B.STORAGE_COMPRESSION_DICTIONARY),r=(0,Jt.get)(B.STORAGE_COMPRESSION_THRESHOLD)||oQ,n={startingOffset:32};return t&&(n.dictionary=kh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Jt,EA,ff,Dt,fs,uf,Jl,xP,kh,BP,sQ,gA,SA,Fh,Ft,iQ,HP,AA,oQ,Xn,qe,lf,Bh,Hh,TA,ta,df,EAe,gAe,Pe=be(()=>{Jt=M(ae()),EA=M(vt()),ff=require("lmdb"),Dt=require("path"),fs=require("fs"),uf=M(gt());Gf();Jl=M(s_()),xP=M(i_());H();kh=M(require("fs-extra")),BP=M(Ri()),sQ=M(_n()),gA=M(yo()),SA=M(ni()),Fh=require("worker_threads"),Ft=M(z()),iQ=M(et());ho();Ou();Ts();HP="data",AA=Symbol("defined-tables"),oQ=((0,Jt.get)(B.STORAGE_PAGESIZE)||4096)-60;(0,Jt.initSync)();Xn=Object.create(null),qe=Object.create(null);(0,BP._assignPackageExport)("databases",qe);(0,BP._assignPackageExport)("tables",Xn);lf=Symbol.for("next-table-id"),Bh=[],Hh=[],ta=new Map;a(mAe,"getTables");a(Je,"getDatabases");a(Cd,"resetDatabases");a(xh,"readMetaDb");a(aQ,"ensureDB");a(cQ,"setTable");a(Fu,"database");a(Qb,"dropDatabase");a(dt,"table");EAe=1e3,gAe=10;a(SAe,"runIndexing");a(TAe,"dropTableMeta");a(ml,"onUpdatedTable");a(mp,"onRemovedDB");a(IS,"getDefaultCompression")});var se=w((Sxe,RQ)=>{"use strict";var mc=require("path"),_Q=require("fs-extra"),vn=z(),lQ=require("fs-extra"),RA=require("os"),AAe=require("net"),RAe=require("recursive-iterator"),Rr=(H(),C(q)),{PACKAGE_ROOT:yAe}=st(),bAe=nR(),uQ=require("papaparse"),yA=require("moment"),{inspect:OAe}=require("util"),dQ=require("is-number"),gxe=require("lodash"),NAe=require("minimist"),wAe=require("https"),IAe=require("http"),{hdb_errors:bA}=pe(),CAe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,pQ=require("util").promisify(setTimeout),PAe=100,DAe=5,LAe="",MAe=4,fQ={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};RQ.exports={isEmpty:_s,isEmptyOrZeroLength:so,arrayHasEmptyValues:xAe,arrayHasEmptyOrZeroLengthValues:BAe,buildFolderPath:HAe,isBoolean:hQ,errorizeMessage:vAe,stripFileExtension:FAe,autoCast:GAe,autoCastJSON:mQ,autoCastJSONDeep:FP,removeDir:qAe,compareVersions:$Ae,isCompatibleDataVersion:VAe,escapeRawValue:KAe,unescapeValue:YAe,stringifyProps:WAe,timeoutPromise:jAe,isClusterOperation:JAe,getClusterUser:ZAe,checkGlobalSchemaTable:XAe,getHomeDir:gQ,getPropsFilePath:zAe,promisifyPapaParse:eRe,removeBOM:SQ,createEventPromise:tRe,checkProcessRunning:rRe,checkSchemaTableExist:nRe,checkSchemaExists:TQ,checkTableExists:AQ,getStartOfTomorrowInSeconds:sRe,getLimitKey:iRe,isObject:kAe,isNotEmptyAndHasValue:UAe,autoCasterIsNumberCheck:EQ,backtickASTSchemaItems:oRe,isPortTaken:QAe,createForkArgs:aRe,autoCastBoolean:cRe,async_set_timeout:pQ,getTableHashAttribute:lRe,doesSchemaExist:uRe,doesTableExist:dRe,stringifyObj:fRe,ms_to_time:_Re,changeExtension:pRe,getEnvCliRootPath:GP,noBootFile:hRe,httpRequest:mRe,transformReq:ERe,convertToMS:gRe,PACKAGE_ROOT:yAe};function vAe(e){return e instanceof Error?e:new Error(e)}a(vAe,"errorizeMessage");function _s(e){return e==null}a(_s,"isEmpty");function UAe(e){return!_s(e)&&(e||e===0||e===""||hQ(e))}a(UAe,"isNotEmptyAndHasValue");function so(e){return _s(e)||e.length===0||e.size===0}a(so,"isEmptyOrZeroLength");function xAe(e){if(_s(e))return!0;for(let t=0;t<e.length;t++)if(_s(e[t]))return!0;return!1}a(xAe,"arrayHasEmptyValues");function BAe(e){if(so(e))return!0;for(let t=0;t<e.length;t++)if(so(e[t]))return!0;return!1}a(BAe,"arrayHasEmptyOrZeroLengthValues");function HAe(...e){try{return e.join(mc.sep)}catch{console.error(e)}}a(HAe,"buildFolderPath");function hQ(e){return _s(e)?!1:e===!0||e===!1}a(hQ,"isBoolean");function kAe(e){return _s(e)?!1:typeof e=="object"}a(kAe,"isObject");function FAe(e){return so(e)?LAe:e.slice(0,-MAe)}a(FAe,"stripFileExtension");function GAe(e){return _s(e)||e===""||typeof e!="string"?e:fQ[e]!==void 0?fQ[e]:EQ(e)===!0?Number(e):CAe.test(e)?new Date(e):e}a(GAe,"autoCast");function mQ(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(mQ,"autoCastJSON");function FP(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=FP(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=FP(r);n!==r&&(e[t]=n)}return e}else return mQ(e)}a(FP,"autoCastJSONDeep");function EQ(e){if(e.startsWith("0.")&&dQ(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&dQ(e))}a(EQ,"autoCasterIsNumberCheck");async function qAe(e){if(so(e))throw new Error(`Directory path: ${e} does not exist`);try{await lQ.emptyDir(e),await lQ.remove(e)}catch(t){throw vn.error(`Error removing files in ${e} -- ${t}`),t}}a(qAe,"removeDir");function $Ae(e,t){if(so(e)){vn.info("Invalid current version sent as parameter.");return}if(so(t)){vn.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a($Ae,"compareVersions");function VAe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(VAe,"isCompatibleDataVersion");function KAe(e){if(_s(e))return e;let t=String(e);return t==="."?Rr.UNICODE_PERIOD:t===".."?Rr.UNICODE_PERIOD+Rr.UNICODE_PERIOD:t.replace(Rr.FORWARD_SLASH_REGEX,Rr.UNICODE_FORWARD_SLASH)}a(KAe,"escapeRawValue");function YAe(e){if(_s(e))return e;let t=String(e);return t===Rr.UNICODE_PERIOD?".":t===Rr.UNICODE_PERIOD+Rr.UNICODE_PERIOD?"..":String(e).replace(Rr.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(YAe,"unescapeValue");function WAe(e,t){if(_s(e))return vn.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+RA.EOL}!so(n)&&n[0]===";"?r+=" "+n+s+RA.EOL:so(n)||(r+=n+"="+s+RA.EOL)}catch{vn.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(WAe,"stringifyProps");function gQ(){let e;try{e=RA.homedir()}catch{e=process.env.HOME}return e}a(gQ,"getHomeDir");function zAe(){let e=mc.join(gQ(),Rr.HDB_HOME_DIR_NAME,Rr.BOOT_PROPS_FILE_NAME);return _Q.existsSync(e)||(e=mc.join(__dirname,"../","hdb_boot_properties.file")),e}a(zAe,"getPropsFilePath");function jAe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(jAe,"timeoutPromise");async function QAe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=AAe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(QAe,"isPortTaken");function JAe(e){try{return Rr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){vn.error(`Error checking operation against cluster ops ${t}`)}return!1}a(JAe,"isClusterOperation");function XAe(e,t){let r=(Pe(),C(tt)).getDatabases();if(!r[e])return bA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return bA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(XAe,"checkGlobalSchemaTable");function ZAe(e,t){if(_s(t)){vn.warn("No CLUSTERING_USER defined, clustering disabled");return}if(_s(e)||so(e)){vn.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){vn.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){vn.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(ZAe,"getClusterUser");function eRe(){uQ.parsePromise=function(e,t,r){return new Promise(function(n,s){uQ.parse(e,{header:!0,transformHeader:SQ,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(eRe,"promisifyPapaParse");function SQ(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(SQ,"removeBOM");function tRe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;vn.info(`Got cluster status event response: ${OAe(s)}`);try{i.cancel()}catch{vn.error("Error trying to cancel timeout.")}n(s)})})}a(tRe,"createEventPromise");async function rRe(e){let t=!0,r=0;do await pQ(PAe*r++),(await bAe.findPs(e)).length>0&&(t=!1);while(t&&r<DAe);if(t)throw new Error(`process ${e} was not started`)}a(rRe,"checkProcessRunning");function nRe(e,t){let r=TQ(e);if(r)return r;let n=AQ(e,t);if(n)return n}a(nRe,"checkSchemaTableExist");function TQ(e){let{getDatabases:t}=(Pe(),C(tt));if(!t()[e])return bA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(TQ,"checkSchemaExists");function AQ(e,t){let{getDatabases:r}=(Pe(),C(tt));if(!r()[e][t])return bA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(AQ,"checkTableExists");function sRe(){let e=yA().utc().add(1,"d").startOf("d").unix(),t=yA().utc().unix();return e-t}a(sRe,"getStartOfTomorrowInSeconds");function iRe(){return yA().utc().format("DD-MM-YYYY")}a(iRe,"getLimitKey");function oRe(e){try{let t=new RAe(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){vn.error("Got an error back ticking items."),vn.error(t)}}a(oRe,"backtickASTSchemaItems");function aRe(e){return[e]}a(aRe,"createForkArgs");function cRe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(cRe,"autoCastBoolean");function lRe(e,t){let{getDatabases:r}=(Pe(),C(tt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(lRe,"getTableHashAttribute");function uRe(e){let{getDatabases:t}=(Pe(),C(tt));return t()[e]!==void 0}a(uRe,"doesSchemaExist");function dRe(e,t){let{getDatabases:r}=(Pe(),C(tt));return r()[e]?.[t]!==void 0}a(dRe,"doesTableExist");function fRe(e){try{return JSON.stringify(e)}catch{return e}}a(fRe,"stringifyObj");function _Re(e){let t=yA.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(_Re,"ms_to_time");function pRe(e,t){let r=mc.basename(e,mc.extname(e));return mc.join(mc.dirname(e),r+t)}a(pRe,"changeExtension");function GP(){if(process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=NAe(process.argv);if(e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(GP,"getEnvCliRootPath");var kP;function hRe(){if(kP)return kP;let e=GP();if(GP()&&_Q.pathExistsSync(mc.join(e,Rr.HDB_CONFIG_FILE)))return kP=!0,!0}a(hRe,"noBootFile");function mRe(e,t){let r;return e.protocol==="http:"?r=IAe:r=wAe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(mRe,"httpRequest");function ERe(e){if(!e.schema&&!e.database){e.schema=Rr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(ERe,"transformReq");function gRe(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(gRe,"convertToMS")});var ae=w((wQ,IQ)=>{"use strict";var qP=require("fs-extra"),Xl=require("path"),yQ=require("os"),SRe=require("properties-reader"),qh=z(),Gh=se(),Me=(H(),C(q)),OA=yt(),TRe="Error initializing environment manager",NA="BOOT_PROPS_FILE_PATH",bQ=!1,ARe={[Me.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ra={};Object.assign(wQ,IQ.exports={BOOT_PROPS_FILE_PATH:NA,getHdbBasePath:RRe,setHdbBasePath:yRe,get:OQ,initSync:ORe,setProperty:Ke,initTestEnvironment:wRe,setCloneVar:NRe});function RRe(){return ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(RRe,"getHdbBasePath");function yRe(e){ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(yRe,"setHdbBasePath");function OQ(e){let t=OA.getConfigValue(e);return t===void 0?ra[e]:t}a(OQ,"get");function Ke(e,t){ARe[e]&&(ra[e]=t),OA.updateConfigObject(e,t)}a(Ke,"setProperty");function bRe(){let e;try{e=Gh.getPropsFilePath(),qP.accessSync(e,qP.constants.F_OK|qP.constants.R_OK),bQ=!0;let t=SRe(e);return ra[Me.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Me.HDB_SETTINGS_NAMES.INSTALL_USER),ra[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ra[NA]=e,!0}catch{return qh.trace(`Environment manager found no properties file at ${e}`),!1}}a(bRe,"doesPropFileExist");function ORe(e=!1){try{((bQ||bRe()||Gh.noBootFile())&&!NQ||e)&&(OA.initConfig(e),ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=OA.getConfigValue(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){qh.error(TRe),qh.error(t),console.error(t),process.exit(1)}}a(ORe,"initSync");var NQ=!1;function NRe(e){NQ=e}a(NRe,"setCloneVar");function wRe(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=Xl.join(__dirname,"../../","unitTests");ra[NA]=Xl.join(l,"hdb_boot_properties.file"),Ke(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Xl.join(l,"settings.test")),Ke(Me.HDB_SETTINGS_NAMES.INSTALL_USER,yQ.userInfo()?yQ.userInfo().username:void 0),Ke(Me.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ke(Me.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Xl.join(l,"envDir","log")),Ke(Me.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ke(Me.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ke(Me.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ke(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Xl.join(l,"envDir")),Ke(Me.CONFIG_PARAMS.STORAGE_PATH,Xl.join(l,"envDir")),s&&(Ke(Me.CONFIG_PARAMS.HTTP_SECUREPORT,OQ(Me.CONFIG_PARAMS.HTTP_PORT)),Ke(Me.CONFIG_PARAMS.HTTP_PORT,null)),Ke(Me.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ke(Me.CONFIG_PARAMS.HTTP_PORT,9926),Ke(Me.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ke(Me.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Ke(Me.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Gh.isEmpty(i)?!1:i),Ke(Me.CONFIG_PARAMS.HTTP_CORS,Gh.isEmpty(i)?!1:i),Ke(Me.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ke(Me.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Xl.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ke(Me.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Gh.isEmpty(c)?!1:c),o&&(Ke("CORS_ACCESSLIST",o),Ke(Me.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ke(Me.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ke(Me.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ke(Me.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${NA}. Please check your boot props and settings files`;qh.fatal(r),qh.error(t)}}a(wRe,"initTestEnvironment")});var MQ=w((Rxe,LQ)=>{"use strict";var IA=ae();IA.initSync();var wA=(H(),C(q)),{httpRequest:IRe}=se(),DQ=require("path"),CQ=require("fs-extra"),CRe=require("yaml"),{packageDirectory:PRe}=(qw(),C(Gw)),{encode:DRe}=require("cbor-x"),LRe=["describe_table","describe_all","describe_database","list_users","list_roles","drop_role","add_user","alter_user","drop_user","restart_service","restart","create_database","drop_database","create_table","drop_table","create_attribute","drop_attribute","search_by_id","insert","update","upsert","delete","search_by_value","csv_file_load","csv_url_load","cluster_get_routes","cluster_network","cluster_status","remove_node","add_component","deploy_component","package_component","drop_component","get_components","get_component_file","set_component_file","registration_info","get_fingerprint","set_license","get_job","search_jobs_by_start_date","read_log","read_transaction_log","read_audit_log","delete_transaction_logs_before","purge_stream","delete_records_before","install_node_modules","set_configuration","get_configuration","create_authentication_tokens","refresh_operation_token","system_information","sql","create_csr","sign_certificate","list_certificates","add_certificate","remove_certificate","add_ssh_key","update_ssh_key","delete_ssh_key","list_ssh_keys","set_ssh_known_hosts","get_ssh_known_hosts"],PQ={deploy:"deploy_component",package:"package_component"};LQ.exports={cliOperations:URe,buildRequest:vRe};var MRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await PRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=DQ.basename(t))},"deploy_component")};function vRe(){let e={};for(let t of process.argv.slice(2))if(LRe.includes(t))e.operation=t;else if(PQ.hasOwnProperty(t))e.operation=PQ[t];else if(t.includes("=")){let[r,...n]=t.split("=");n=n.join("=");try{n=JSON.parse(n)}catch{}e[r]=n}return e}a(vRe,"buildRequest");async function URe(e){e.target||(e.target=process.env.CLI_TARGET);let t;if(e.target){try{t=new URL(e.target)}catch(r){try{t=new URL(`https://${e.target}:9925`)}catch{throw r}}t={protocol:t.protocol,hostname:t.hostname,port:t.port,username:e.username||t.username||process.env.CLI_TARGET_USERNAME,password:e.password||t.password||process.env.CLI_TARGET_PASSWORD,rejectUnauthorized:e.rejectUnauthorized}}else CQ.existsSync(DQ.join(IA.get(wA.CONFIG_PARAMS.ROOTPATH),wA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),CQ.existsSync(IA.get(wA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await MRe[e.operation]?.(e);try{let r=t??{protocol:"http:",socketPath:IA.get(wA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)};r.method="POST",r.headers={"Content-Type":"application/json"},t?.username&&(r.headers.Authorization=`Basic ${Buffer.from(`${t.username}:${t.password}`).toString("base64")}`),e.cborEncode&&(r.headers["Content-Type"]="application/cbor",e=DRe(e));let n=await IRe(r,e),s;try{s=JSON.parse(n.body)}catch{s={status:n.statusCode+" "+(n.statusMessage||"Unknown"),body:n.body}}e.json?console.log(JSON.stringify(s,null,2)):console.log(CRe.stringify(s).trim())}catch(r){let n="Error: ";if(r?.response?.data?.error)n+=r.response.data.error;else if(r?.response?.data)n+=r?.response?.data;else return console.error(r);console.error(n)}}a(URe,"cliOperations")});var xQ=w((bxe,UQ)=>{"use strict";var vQ=require("semver/functions/major"),{packageJson:xRe}=st(),$P=process.versions&&process.versions.node?process.versions.node:void 0;UQ.exports=BRe;function BRe(){let e=xRe.engines["minimum-node"];if($P&&vQ($P)<vQ(e))return{error:`The minimum version of Node.js HarperDB supports is: ${e}, the currently installed Node.js version is: ${$P}. Please install a version of Node.js that is withing the defined range.`}}a(BRe,"checkNodeVersion")});var QP=w((wxe,sJ)=>{"use strict";var BQ=require("os"),CA=require("https"),HQ=require("http"),Xt=require("fs-extra"),kQ=require("yaml"),{pipeline:FQ}=require("stream/promises"),{createWriteStream:PA,ensureDir:$h,writeFileSync:GQ}=require("fs-extra"),{join:Ai}=require("path"),KQ=require("lodash"),HRe=require("minimist"),na=require("path"),kRe=require("node:crypto"),FRe=require("properties-reader"),Vs=ae(),GRe=Do(),WP=z(),DA=yt(),{restart:qRe}=za(),LA=se(),$Re=da(),VRe=ys(),{main:MA,launch:KRe}=jd(),{install:YQ,updateConfigEnv:YRe,setIgnoreExisting:vA}=CT(),WQ=mC(),an=(H(),C(q)),{packageJson:WRe}=st(),zRe=mh(),{sendOperationToNode:YP}=(es(),C(Po)),{updateConfigCert:jRe}=ts(),{restartWorkers:QRe}=et(),{databases:JRe}=(Pe(),C(tt)),{SYSTEM_TABLE_NAMES:VP,SYSTEM_SCHEMA_NAME:Nxe,CONFIG_PARAMS:Vh,OPERATIONS_ENUM:ms}=an,XRe=1e4,ZRe="clone-node-config.yaml",zQ=[VP.ROLE_TABLE_NAME,VP.USER_TABLE_NAME,VP.NODE_TABLE_NAME],eye={clustering_nodename:!0,clustering_leafserver_streams_path:!0,clustering_tls_certificate:!0,clustering_tls_privatekey:!0,clustering_tls_certificateauthority:!0,logging_file:!0,logging_root:!0,logging_rotation_path:!0,operationsapi_network_domainsocket:!0,operationsapi_tls_certificate:!0,operationsapi_tls_privatekey:!0,operationsapi_tls_certificateauthority:!0,rootpath:!0,storage_path:!0,storage_audit_path:!0,databases:!0,mqtt_network_mtls_certificateauthority:!0,componentsroot:!0,tls_certificate:!0,tls_privatekey:!0,tls_certificateauthority:!0,replication_hostname:!0,replication_url:!0,cloned:!0},kr={HDB_LEADER_USERNAME:"HDB_LEADER_USERNAME",HDB_LEADER_PASSWORD:"HDB_LEADER_PASSWORD",HDB_LEADER_URL:"HDB_LEADER_URL",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",HDB_CLONE_OVERTOP:"HDB_CLONE_OVERTOP",CLONE_KEYS:"CLONE_KEYS",CLONE_USING_WS:"CLONE_USING_WS",NO_START:"NO_START"},ia=HRe(process.argv),_f=ia[kr.HDB_LEADER_USERNAME]??process.env[kr.HDB_LEADER_USERNAME],pf=ia[kr.HDB_LEADER_PASSWORD]??process.env[kr.HDB_LEADER_PASSWORD],eu=ia[kr.HDB_LEADER_URL]??process.env[kr.HDB_LEADER_URL],sa=ia[kr.REPLICATION_HOSTNAME]??process.env[kr.REPLICATION_HOSTNAME],jQ,QQ;sa&&([jQ,QQ]=sa.split(":"));var zP=(ia[kr.HDB_CLONE_OVERTOP]??process.env[kr.HDB_CLONE_OVERTOP])==="true",JQ=ia[Vh.CLONED.toUpperCase()]??process.env[Vh.CLONED.toUpperCase()],tye=ia[kr.CLONE_KEYS]!=="false"&&process.env[kr.CLONE_KEYS]!=="false",XQ=(ia[kr.CLONE_USING_WS]??process.env[kr.CLONE_USING_WS])==="true",ZQ=(ia[kr.NO_START]??process.env[kr.NO_START])==="true",hs,Ec={},qQ,$Q,Zl={},on,Gt,$s,io,tu=!1,jP=!1,ps,hf;sJ.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${eu}`),delete process.env.HDB_LEADER_URL,Gt=LA.getEnvCliRootPath(),!Gt)try{let i=Ai(BQ.homedir(),an.HDB_HOME_DIR_NAME,an.BOOT_PROPS_FILE_NAME);if(await Xt.pathExists(i)){let o=FRe(i);Gt=na.parse(o.get(an.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)).dir}}catch{throw new Error("There was an error setting the clone default root path. Please set ROOTPATH using an environment or CLI variable.")}Gt?await Xt.pathExists(Gt)?console.log(`Existing HarperDB install found at ${Gt}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Gt} starting fresh clone`),tu=!0):(console.log("No HarperDB install found, starting fresh clone"),tu=!0),Gt||(Gt=Ai(BQ.homedir(),an.HDB_ROOT_DIR_NAME),console.log("Using default root path",Gt));let n;try{n=Ai(Gt,ZRe),hs=kQ.parseDocument(await Xt.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=Ai(Gt,an.HDB_CONFIG_FILE);if(await Xt.pathExists(s))try{qQ=kQ.parseDocument(await Xt.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),Ec=DA.flattenConfig(qQ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(sa){let i=new URL(eu);hf=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${QQ||9933}`}if(XQ){await rye();return}if(Ec?.cloned&&JQ!=="false")return console.log("Instance marked as cloned, clone will not run"),Vs.setCloneVar(!1),Vs.initSync(),MA();on=await eJ({operation:ms.DESCRIBE_ALL}),await rJ(),Vs.setCloneVar(!1),Vs.setHdbBasePath(Gt),Xt.ensureDir(Vs.get(an.CONFIG_PARAMS.LOGGING_ROOT)),WP.initLogSettings(),await nye(),jP||await sye(),await aye(t,r),sa&&(await lye(),await tJ()),console.info(`
|
|
135
|
-
Successfully cloned node: `+eu),(t||ZQ)&&process.exit()},"cloneNode");async function rye(){if(Ec?.cloned&&JQ!=="false")return console.log("Instance marked as cloned, clone will not run"),Vs.setCloneVar(!1),Vs.initSync(),MA();console.log("Cloning using WebSockets");let e=gc("system"),t=Ai(e,"system.mdb"),r=Xt.existsSync(t);tu||!r||zP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Gt,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=kRe.randomBytes(10).toString("base64").slice(0,10),vA(!0),await YQ()):(Vs.setCloneVar(!1),Vs.initSync()),await MA(),await rJ(!0),await jRe(),r||await JRe.system.hdb_user.delete({username:"clone-temp-admin"}),await QRe(),console.log("Adding node to the cluster");let s=await Ed()({operation:ms.ADD_NODE,url:hf});console.log("Add node response: ",s),await tJ(),console.log(`Successfully cloned node: ${eu} using WebSockets`),DA.updateConfigValue(Vh.CLONED,!0),ZQ&&process.exit()}a(rye,"cloneUsingWS");async function eJ(e){return XQ?YP({url:hf},e,{rejectUnauthorized:!1}):JSON.parse((await uye(e)).body)}a(eJ,"leaderReq");async function tJ(){try{if(tye!==!1){console.log("Cloning JWT keys");let e=na.join(Gt,an.LICENSE_KEY_DIR_NAME),t=await YP({url:hf},{operation:ms.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});GQ(na.join(e,an.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await YP({url:hf},{operation:ms.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});GQ(na.join(e,an.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r.message)}}catch(e){console.error("Error cloning JWT keys",e)}}a(tJ,"cloneKeys");async function rJ(e=!1){console.info("Cloning configuration"),$Q=await eJ({operation:ms.GET_CONFIGURATION}),Zl=DA.flattenConfig($Q);let t=hs?.componentConfig?.exclude,r={rootpath:Gt};sa&&(r.replication_hostname=jQ);for(let i in Zl)if(!(Zl[i]!==null&&typeof Zl[i]=="object"&&!(Zl[i]instanceof Array)||eye[i])){if(i.includes("_package")||i.includes("_port")){if(Zl[i]?.includes?.("hdb/components"))continue;if(t){let o=!1;for(let c of t)if(i.includes(c.name)){o=!0;break}if(o)continue}}Ec[i]||(r[i]=Zl[i])}for(let i in Ec)i!=="databases"&&typeof Ec[i]=="object"&&!(Ec[i]instanceof Array)||(r[i]=Ec[i]);let n={};if(hs?.databaseConfig?.excludeDatabases&&hs.databaseConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),hs?.clusteringConfig?.excludeDatabases&&hs.clusteringConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),Object.keys(n).length>0){r.replication_databases=[],n.system||r.replication_databases.push("system");for(let i in on)n[i]||r.replication_databases.push(i)}let s=$Re(Object.keys(an.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),DA.createConfigFile(r,!0)}a(rJ,"cloneConfig");async function nye(){process.env.HDB_FETCH==="true"?(await oye(),process.env.NODE_TLS_REJECT_UNAUTHORIZED&&delete process.env.NODE_TLS_REJECT_UNAUTHORIZED):await iye()}a(nye,"cloneDatabases");async function sye(){if(console.info("Clone node installing HarperDB."),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Gt,!_f)throw new Error("HDB_LEADER_USERNAME is undefined.");if(process.env.HDB_ADMIN_USERNAME=_f,!pf)throw new Error("HDB_LEADER_PASSWORD is undefined.");process.env.HDB_ADMIN_PASSWORD=pf,process.env.OPERATIONSAPI_NETWORK_PORT=Vs.get(Vh.OPERATIONSAPI_NETWORK_PORT),YRe(na.join(Gt,an.HDB_CONFIG_FILE)),vA(!0),await YQ()}a(sye,"installHDB");function gc(e){return Vs.get(an.CONFIG_PARAMS.DATABASES)?.[e]?.path||Vs.get(Vh.STORAGE_PATH)||na.join(Gt,an.DATABASES_DIR_NAME)}a(gc,"getDBPath");async function iye(){let e=gc("system"),t=Ai(e,"system.mdb");if(await $h(e),tu||!await Xt.exists(t)||zP){if(!sa){console.info("Cloning system database"),await $h(e);let r=PA(t,{overwrite:!0}),n={operation:ms.GET_BACKUP,database:"system",tables:zQ},s=await VQ(n,r),i=new Date(s.date);(!ps||i<ps)&&(ps=i),await Xt.utimes(t,Date.now(),i)}tu||(await WQ(Gt),await nJ(),vA(!0))}else jP=!0,console.log("Not cloning system database due to it already existing on clone");$s=hs?.databaseConfig?.excludeDatabases,$s=$s?$s.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await Xt.exists(na.join(gc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),$s[r]=!0);io=hs?.databaseConfig?.excludeTables,io=io?io.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if($s[r]){on[r]="excluded";continue}if(KQ.isEmpty(on[r]))continue;let n=[],s=!1;for(let d in on[r])io[r+d]?(s=!0,on[r][d]="excluded"):n.push(on[r][d]);if(n.length===0)continue;if(sa){WP.debug("Setting up tables for #{db}");let d=(Pe(),C(tt)).table;for(let p of n){for(let _ of p.attributes)(_.is_hash_attribute||_.is_primary_key)&&(_.isPrimaryKey=!0);d({database:r,table:p.name,attributes:p.attributes})}continue}n=n.map(d=>d.name);let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i={operation:ms.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:ms.GET_BACKUP,database:r});let o=gc(r);await $h(o);let c=Ai(o,r+".mdb"),l=PA(c,{overwrite:!0}),u=await VQ(i,l),f=new Date(u.date);(!ps||f<ps)&&(ps=f),await Xt.utimes(c,Date.now(),f)}}a(iye,"cloneTablesHttp");async function oye(){let e=gc("system"),t=Ai(e,"system.mdb");if(tu||!await Xt.exists(t)||zP){if(!sa){console.info("Cloning system database using fetch");let r={operation:ms.GET_BACKUP,database:"system",tables:zQ},n=await KP(r,!0),s=gc("system");await $h(s);let i=Ai(s,"system.mdb");await FQ(n.body,PA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!ps||o<ps)&&(ps=o),await Xt.utimes(i,Date.now(),new Date(n.headers.get("date")))}tu||(await WQ(Gt),await nJ(),vA(!0))}else jP=!0,console.log("Not cloning system database due to it already existing on clone");if(sa){WP.info("Replication hostname set, not using backup to clone databases, replication will clone");return}$s=hs?.databaseConfig?.excludeDatabases,$s=$s?$s.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await Xt.exists(na.join(gc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),$s[r]=!0);io=hs?.databaseConfig?.excludeTables,io=io?io.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if($s[r]){on[r]="excluded";continue}if(KQ.isEmpty(on[r]))continue;let n=[],s=!1;for(let f in on[r])io[r+f]?(s=!0,on[r][f]="excluded"):n.push(f);if(n.length===0)return;let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i=await KP({operation:ms.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await KP({operation:ms.GET_BACKUP,database:r},!0));let o=gc(r);await $h(o);let c=new Date(i.headers.get("date")),l=Ai(o,`${c.getTime()}-${r}.mdb`);await FQ(i.body,PA(l,{overwrite:!0}));let u=Ai(o,r+".mdb");await Xt.rename(l,u),(!ps||c<ps)&&(ps=c),await Xt.utimes(u,Date.now(),c)}}a(oye,"cloneTablesFetch");async function KP(e,t=!1){let r=hs?.httpsRejectUnauthorized??!1,n=new CA.Agent({rejectUnauthorized:r});r||(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0");let i={Authorization:"Basic "+Buffer.from(_f+":"+pf).toString("base64"),"Content-Type":"application/json"};t&&(i["Accept-Encoding"]="gzip");let o=await fetch(eu,{method:"POST",headers:i,body:JSON.stringify(e),agent:n,compress:!0});if(o.ok)return o;throw console.error(`HTTP Error Response: ${o.status} ${o.statusText}`),new Error(await o.text())}a(KP,"leaderHttpReqFetch");async function aye(e,t=!1){let r=await GRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await KRe(!1):(t&&await cye(),await MA()):(console.info(await qRe({operation:ms.RESTART})),await LA.async_set_timeout(XRe)),e&&await LA.async_set_timeout(2e3)}a(aye,"startHDB");async function cye(){let e=process.argv[3];e&&e[0]!=="-"&&(await Xt.exists(e)||console.error(`The folder ${e} does not exist`),Xt.statSync(e).isDirectory()||console.error(`The path ${e} is not a folder`),e=await Xt.realpath(e),await Xt.exists(na.join(e,an.HDB_CONFIG_FILE))?process.env.ROOTPATH=e:process.env.RUN_HDB_APP=e)}a(cye,"setAppPath");async function lye(){console.info("Setting up replication"),await VRe.setSchemaDataToGlobalAsync();let t=await Ed()({operation:ms.ADD_NODE,verify_tls:!1,url:hf,start_time:ps,authorization:{username:_f,password:pf}},!0);console.log("Add node response: ",t)}a(lye,"setupReplication");async function uye(e){let t=new CA.Agent({rejectUnauthorized:hs?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(_f+":"+pf).toString("base64"),"Content-Type":"application/json"},s=new URL(eu),i={protocol:s.protocol,host:s.hostname,method:"POST",headers:n};return s.protocol==="https:"&&(i.agent=t),s.port&&(i.port=s.port),await LA.httpRequest(i,e)}a(uye,"leaderHttpReq");async function VQ(e,t){let r=new CA.Agent({rejectUnauthorized:hs?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(_f+":"+pf).toString("base64"),"Content-Type":"application/json"},i=new URL(eu),o={protocol:i.protocol,host:i.hostname,method:"POST",headers:s};return i.protocol==="https:"&&(o.agent=r,HQ=CA),i.port&&(o.port=i.port),new Promise((c,l)=>{let u=HQ.request(o,f=>{f.statusCode!==200&&l("Request to leader node failed with code: "+f.statusCode),f.pipe(t),f.on("end",()=>{t.close(),c(f.headers)})});u.on("error",f=>{l(f)}),u.write(JSON.stringify(e)),u.end()})}a(VQ,"leaderHttpStream");async function nJ(){let e=WRe.version;if(e)await zRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(nJ,"insertHdbVersionInfo")});var oJ=w((Cxe,iJ)=>{var dye=CT(),fye=z();iJ.exports=_ye;async function _ye(){try{await dye.install()}catch(e){console.error("There was an error during the install."),console.error(e),fye.error(e),process.exit(1)}}a(_ye,"install")});var lJ=w((Dxe,cJ)=>{"use strict";var pye=hS(),hye=z(),aJ="Registration failed.";async function mye(){let e;try{e=await pye.register()}catch(t){return hye.error(`Registration error ${t}`),aJ}return e||aJ}a(mye,"register");cJ.exports={register:mye}});var _J=w((Mxe,fJ)=>{"use strict";var Eye=z(),gye=(H(),C(q)),Sye=require("util"),Tye=require("child_process"),uJ=Sye.promisify(Tye.exec),Aye=Do(),Kh=Id(),dJ="Stopping HarperDB.";fJ.exports=Rye;async function Rye(){if(console.log(dJ),Eye.notify(dJ),await Kh.isServiceRegistered(gye.PROCESS_DESCRIPTORS.HDB)){Kh.enterPM2Mode();let r=await Kh.getUniqueServicesList();for(let n in r)await Kh.stop(n)}await Kh.kill();let t=await Aye.getHDBProcessInfo();t.clustering.forEach(r=>{uJ(`kill ${r.pid}`)}),t.core.forEach(r=>{uJ(`kill ${r.pid}`)})}a(Rye,"stop")});var mJ=w((Uxe,hJ)=>{"use strict";var XP=require("fs-extra"),ZP=require("path"),JP=require("yaml"),Yh=or(),Sc=(H(),C(q)),pJ=Tt(),eD=z(),yye=An(),bye=lS(),Oye=aS(),Nye=Do(),Wh=ae(),wye=jd(),Iye=se();Wh.initSync();var Ks={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},Un={LEAF:"leaf server",HUB:"hub server"},UA;hJ.exports=Cye;async function Cye(){let e={harperdb:{status:Ks.STOPPED}};if(!await wye.isHdbInstalled()){e.harperdb.status=Ks.NOT_INSTALLED,console.log(JP.stringify(e));return}UA=Wh.get(Sc.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await XP.readFile(ZP.join(UA,Sc.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Sc.NODE_ERROR_CODES.ENOENT){eD.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Ks.STOPPED,console.log(JP.stringify(e));return}throw n}let r=await Nye.getHDBProcessInfo();for(let n of r.core)if(n.pid===t){e.harperdb.status=Ks.RUNNING,e.harperdb.pid=t;break}if((Wh.get(Sc.CONFIG_PARAMS.REPLICATION_URL)||Wh.get(Sc.CONFIG_PARAMS.REPLICATION_HOSTNAME))&&(e.replication=await Dye()),e.clustering=await Pye(r),e.clustering[Un.HUB].status===Ks.RUNNING&&e.clustering[Un.LEAF].status===Ks.RUNNING){let n=[],s=await bye({});for(let o of s.nodes){let c={};for(let l in o)c[l.replace("_"," ")]=o[l];n.push(c)}e.clustering.network=n;let i=await Oye.clusterStatus();e.clustering.replication={"node name":i.node_name,"is enabled":i.is_enabled,connections:[]};for(let o of i.connections){let c={};c["node name"]=o?.node_name,c.status=o?.status,c.ports={clustering:o?.ports?.clustering,"operations api":o?.ports?.operations_api},c["latency ms"]=o?.latency_ms,c.uptime=o?.uptime,c.subscriptions=o?.subscriptions,c["system info"]={"hdb version":o?.system_info?.hdb_version,"node version":o?.system_info?.node_version,platform:o?.system_info?.platform},e.clustering.replication.connections.push(c)}await Yh.closeConnection()}console.log(JP.stringify(e)),process.exit()}a(Cye,"status");async function Pye(e){let t={[Un.HUB]:{},[Un.LEAF]:{}};if(e.clustering.length===0)return t[Un.HUB].status=Ks.STOPPED,t[Un.LEAF].status=Ks.STOPPED,t;let{port:r}=Yh.getServerConfig(Sc.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await yye.getClusterUser();try{(await Yh.createConnection(r,n,s,!1)).close(),t[Un.HUB].status=Ks.RUNNING}catch{t[Un.HUB].status=Ks.ERRORED}let{port:i}=Yh.getServerConfig(Sc.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await Yh.createConnection(i,n,s,!1)).close(),t[Un.LEAF].status=Ks.RUNNING}catch{t[Un.LEAF].status=Ks.ERRORED}try{t[Un.HUB].pid=Number.parseInt(await XP.readFile(ZP.join(UA,"clustering",pJ.PID_FILES.HUB),"utf8"))}catch(o){eD.error(o),t[Un.HUB].pid=void 0}try{t[Un.LEAF].pid=Number.parseInt(await XP.readFile(ZP.join(UA,"clustering",pJ.PID_FILES.LEAF),"utf8"))}catch(o){eD.error(o),t[Un.LEAF].pid=void 0}return t}a(Pye,"getHubLeafStatus");async function Dye(){let e=await Iye.httpRequest({method:"POST",protocol:"http:",socketPath:Wh.get(Sc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),headers:{"Content-Type":"application/json"}},{operation:"cluster_status"});e=JSON.parse(e.body);let t={"node name":e.node_name,"is enabled":e.is_enabled,connections:[]};for(let r of e.connections)t.connections.push({"node name":r.name,url:r.url,subscriptions:r.subscriptions,replicates:r.replicates,"database sockets":r.database_sockets.map(n=>({database:n.database,connected:n.connected,latency:n.latency,"catching up from":n.catching_up_from,"thread id":n.thread_id,nodes:n.nodes}))});return t}a(Dye,"getReplicationStatus")});rm();var tD=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");tD&&ae().setCloneVar(!0);var zh=require("node:fs"),EJ=require("node:path"),ru=z(),gJ=MQ(),{packageJson:Lye,PACKAGE_ROOT:SJ}=st(),Mye=xQ(),rD=(H(),C(q)),{SERVICE_ACTIONS_ENUM:cn}=rD,vye=`
|
|
131
|
+
`))}},25).unref()}o.close?.(()=>{if(Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Xd()==0)try{iz(cz(Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,HT),o.cantCleanupProperly||Ln.warn("Had to forcefully exit the thread",HT),process.exit(0)},5e3).unref()})}if(lz||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Ln.info("Could not close debugger",i)}}}).ref();let e;bh&&!xSe&&(e=dz()),Promise.resolve(e).then(()=>{if(Xd()===0)try{MSe(FC)}catch(t){console.error("Error displaying start-up log",t)}Oh?.postMessage({type:Xt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(uz,"startServers");function dz(){let e=[];for(let t in Qi){let r=Qi[t];if(t.includes?.("/")&&Xd()==0){NSe(t)&&iz(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Ln.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=Et.get(Xt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=Xd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?bh?n={fd:bh(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:bh?n={fd:bh(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Ln.trace("Listening on port "+t,HT)}).on("error",c)}))}return Promise.all(e)}a(dz,"listenOnPorts");!HC&&!gSe?.noServerStart&&uz();function $C(e,t,r){let n=e?.read?e:new SSe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=Qi[t];if(s.isSecure&&(n.startTime=performance.now()),s)typeof s=="function"?s(n):s.emit("connection",n),r&&n.emit("data",r);else{let i=a(o=>{setTimeout(()=>{let c=Qi[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Ln.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a($C,"deliverSocket");var ez=new Map;function BSe(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=ez.get(s),r){case"connection":i=$C(void 0,t),ez.set(s,i),i.write=(c,l,u)=>(Oh.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(Oh.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Oh.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(BSe,"proxyRequest");var{getComponentName:FT}=(jp(),C(zp));function VC(e,t,r=!0){t||(t=Et.get(Xt.CONFIG_PARAMS.HTTP_PORT));let n=Qi[t];if(n){let s=n.lastServer||n;if(s===e)throw new Error(`Can not register the same server twice for the same port ${t}`);if(r&&!!s.sessionIdContext!=!!e.sessionIdContext&&+t)throw new Error(`Can not mix secure HTTPS and insecure HTTP on the same port ${t}`);s.off("unhandled",sz),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else Qi[t]=e;e.on("unhandled",sz)}a(VC,"registerServer");function KC(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],Et.get(Xt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:Et.get(Xt.CONFIG_PARAMS.HTTP_PORT),secure:Et.get(Xt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),Et.get(Xt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:Et.get(Xt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:cz(Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(KC,"getPorts");function YC(e,t){let r=[];for(let{port:n,secure:s}of KC(t))r.push(fz(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?GC[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,VC(e,n,!1)),kT[n]=qT(GC,n);return r}a(YC,"httpServer");function GT(e,t){let r=FC.get(e)??[];FC.set(e,[...r,t])}a(GT,"setPortServerMap");function fz(e,t,r,n){if(GT(e,{protocol_name:t?"HTTPS":"HTTP",name:FT()}),!BT[e]){let s=r?"operationsApi_network":"http",i=Et.get(s+"_keepAliveTimeout"),o=Et.get(s+"_timeout"),c=Et.get(s+"_headersTimeout"),l={keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:Et.get(Xt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=Et.get(s+"_mtls"),f=Et.get(s+"_mtls_required"),d;t&&(d=Et.get(s+"_http2"),Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!f,requestCert:!!(u||n),ticketKeys:CSe(),SNICallback:az(r?"operations-api":"server",u)}));let p=LSe(),_=BT[e]=(t?d?bSe:ySe:ASe)(l,async(h,S)=>{try{let R=performance.now(),E=new oz(h,S);r&&(E.isOperationsServer=!0);let T=await kT[e](E);if(!T){if(E._nodeResponse.statusCode)return;T=_z(E)}if(T.headers?.set||(T.headers=new kC(T.headers)),p?T.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):T.headers?.set?.("Server","HarperDB"),T.status===-1){for(let ne of T.headers||[])S.setHeader(ne[0],ne[1]);return h.baseRequest=E,S.baseResponse=T,BT[e].emit("unhandled",h,S)}let b=T.status||200,v=performance.now(),F=v-R,q=T.body,Y,Z=!1;if(!T.handlesHeaders){let ne=T.headers||new kC;q?q.length>=0?(typeof q=="string"?ne.set("Content-Length",Buffer.byteLength(q)):ne.set("Content-Length",q.length),Y=!0):q instanceof OSe&&(q.size?ne.set("Content-Length",q.size):q.on&&(Z=!0,q.on("size",me=>{S.headersSent||S.setHeader("Content-Length",me)})),q=q.stream()):(ne.set("Content-Length","0"),Y=!0);let J=`hdb;dur=${F.toFixed(2)}`;if(T.wasCacheMiss&&(J+=", miss"),DSe(ne,"Server-Timing",J,!0),!S.headersSent)if(Z){if(S.statusCode=b,ne)if(ne[Symbol.iterator])for(let[me,ye]of ne)S.setHeader(me,ye);else for(let me in ne)S.setHeader(me,ne[me])}else S.writeHead(b,ne&&(ne[Symbol.iterator]?Array.from(ne):ne));Y&&S.end(q)}let se=E.handlerPath,Q=E.method;if(Rh(F,"duration",se,Q,T.wasCacheMiss==null?void 0:T.wasCacheMiss?"cache-miss":"cache-hit"),XW(b<400,"success",se,Q),XW(1,"response_"+b,se,Q),!Y)if(q instanceof ReadableStream&&(q=ZW.fromWeb(q)),(q[Symbol.iterator]||q[Symbol.asyncIterator])&&(q=ZW.from(q)),q?.pipe){q.pipe(S),q.destroy&&S.on("close",()=>{q.destroy()});let ne=0;q.on("data",J=>{ne+=J.length}),q.on("end",()=>{Rh(performance.now()-v,"transfer",se,Q),Rh(ne,"bytes-sent",se,Q)})}else q?.then?q.then(ne=>{S.end(ne)},g):S.end(q)}catch(R){g(R)}function g(R){let E=R.headers;S.writeHead(R.statusCode||500,E&&(E[Symbol.iterator]?Array.from(E):E)),S.end(R.toString()),R.statusCode?R.statusCode===500?Ln.warn(R):Ln.info(R):Ln.error(R)}a(g,"onError")});i>=0&&(_.keepAliveTimeout=i),c>=0&&(_.headersTimeout=c),t&&(_.ports||(_.ports=[]),_.ports.push(e),l.SNICallback.initialize(_),u&&(_.mtlsConfig=u),_.on("secureConnection",h=>{h._parent.startTime&&Rh(performance.now()-h._parent.startTime,"tls-handshake",e),Rh(h.isSessionReused(),"tls-reused",e)}),_.isSecure=!0),VC(_,e)}return BT[e]}a(fz,"getHTTPServer");function qT(e,t){let r=_z;for(let n=e.length;n>0;){let{listener:s,port:i}=e[--n];if(i===t||i==="all"){let o=r;r=a((...c)=>s(...c,o),"next_callback")}}return r}a(qT,"makeCallbackChain");function _z(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new kC}}a(_z,"unhandled");function HSe(e,t){YC(e,{requestOnly:!0,...t})}a(HSe,"onRequest");function kSe(e,t){let r;if(t.securePort){GT(t.securePort,{protocol_name:"TLS",name:FT()});let n=az("server",t.mtls);r=ISe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),Qi[t.securePort]=r}return t.port&&(GT(t.port,{protocol_name:"TCP",name:FT()}),r=TSe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),Qi[t.port]=r),r}a(kSe,"onSocket");Object.defineProperty(RSe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.toLowerCase().includes("upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var tz=[],qC={};function pz(e,t){for(let{port:r}of KC(t))tz[t?.runFirst?"unshift":"push"]({listener:e,port:r}),qC[r]=qT(tz,r)}a(pz,"onUpgrade");var rz=[],nz={};function FSe(e,t){let r=[];for(let{port:n,secure:s}of KC(t)){GT(n,{protocol_name:s?"WSS":"WS",name:FT()});let i=fz(n,s,t?.isOperationsServer,t?.mtls);yh[n]||(yh[n]=new wSe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),yh[n].on("connection",(o,c)=>{let l=new oz(c);l.isWebSocket=!0;let u=kT[n](l);nz[n](o,l,u)}),pz((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):yh[n].handleUpgrade(o,c,l,f=>{o.__harperdb_request_upgraded=!0,u(o,c,l),yh[n].emit("connection",f,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{qC[n]&&qC[n](o,c,l)})),r.push(i),rz[t?.runFirst?"unshift":"push"]({listener:e,port:n}),nz[n]=qT(rz,n),kT[n]=qT(GC,n)}return r}a(FSe,"onWebSocket");function sz(e,t){t.writeHead(404),t.end(`Not found
|
|
132
|
+
`)}a(sz,"defaultNotFound")});var QW={};ve(QW,{startHTTPThreads:()=>qSe,startSocketServer:()=>XC,updateWorkerIdleness:()=>yz});async function qSe(e=2,t){try{if(t)JC(0,1,!0);else{let{loadRootComponents:r}=$T();if(e===0)return(0,Bs.setMainIsWorker)(!0),await WC().startServers(),Promise.resolve([]);await r()}Rz();for(let r=0;r<e;r++)JC(r,e);return Promise.all(Az)}finally{(0,Bs.threadsHaveStarted)()}}function Rz(){let e=(0,gz.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),jC=setInterval(()=>{YT.notify(e)},GSe).unref())}function JC(e,t=1,r){if(zC++,(0,Bs.startWorker)("server/threads/threadServer.js",{name:ZA.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===JA.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Az.push(s),await s,Zd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=KT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Zd.indexOf(n);o>-1&&Zd.splice(o,1)}if(a(i,"removeWorker"),ef){let o=ef;ef=[];for(let c of o)Tz[c.localPort](null,c)}}}),r){let n=setInterval(()=>{QC?QC=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Bs.shutdownWorkers)(),zC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function XC(e=0,t){if(typeof e=="string")try{(0,WT.existsSync)(e)&&(0,WT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=$Se:r=VSe(t):r=ZC;let n=(0,tf.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);return n._handle&&(n._handle.onconnection=Tz[e]=function(s,i){r.readsData||(i.reading=!1,i.readStop()),QC=!0,r(i,(o,c)=>{if(!o){if(hz){let u=i._socket||new tf.Socket({handle:i,writable:!0,readable:!0});hz.deliverSocket(u,e,c),u.resume()}else zC>0?(ef.length===0&&setTimeout(()=>{ef.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),i.localPort=e,ef.push(i)):(console.log("start up a dynamic thread to handle request"),JC(0));sr(!1,"socket-routed");return}o.requests++;let l=i.fd;if(l>=0)o.postMessage({port:e,fd:l,data:c});else{let u=i._socket||new tf.Socket({handle:i,writable:!0,readable:!0});WSe(u,o,e)}sr(!0,"socket-routed")})},YT.info(`HarperDB ${Sz.packageJson.version} Server running on port ${e}`)),n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function ZC(e,t){let r,n=0;for(let s of Zd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=VT)return VT=i,t(r);n=i}VT=0,t(r)}function $Se(e,t){let r={};e.getpeername(r);let n=r.address,s=rf.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);ZC(e,o=>{rf.set(n,{worker:o,lastUsed:i}),t(o)})}function VSe(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new tf.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],u=rf.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);ZC(n,d=>{rf.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function yz(){VT=0;for(let e of Zd)e.expectedIdle=e.recentELU.idle+KSe,e.requests=1;Zd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function WSe(e,t,r){let n=YSe++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),KT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),KT.delete(n)),s.event=="destroy"&&(e.destroy(),KT.delete(n))})}var Bs,tf,YT,WT,Ez,gz,Sz,Zd,ef,Tz,hz,zC,Az,jC,GSe,QC,VT,mz,rf,KSe,KT,YSe,BC=be(()=>{Bs=M(rt()),tf=require("net");H();YT=M(z()),WT=require("fs");ki();Ez=require("worker_threads"),gz=M(Od()),Sz=M(it()),Zd=[],ef=[],Tz=[],zC=0,Az=[];Ez.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Bs.onMessageFromWorkers)(e=>{e.type===XA.RESTART&&jC&&(clearInterval(jC),Rz())}));GSe=6e5;a(qSe,"startHTTPThreads");a(Rz,"licenseWarning");a(JC,"startHTTPWorker");a(XC,"startSocketServer");VT=0;a(ZC,"findMostIdleWorker");mz=36e5,rf=new Map;a($Se,"findByRemoteAddressAffinity");a(VSe,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of rf)r.lastUsed+mz<e&&rf.delete(t)},mz).unref();KSe=1e3;a(yz,"updateWorkerIdleness");(0,Bs.setMonitorListener)(yz);KT=new Map,YSe=1;a(WSe,"proxySocket")});var Hz=w((XUe,Bz)=>{var Oz=M(require("cluster")),uc=M(ae());H();var Xi=M(z()),Nz=M(require("fastify")),wz=M(require("@fastify/cors")),Iz=M(require("@fastify/compress")),Cz=M(require("@fastify/static")),Pz=M(RO()),Dz=M(require("path")),Lz=M(it()),Mz=M(As()),vz=M(ie()),Uz=M(Rn()),xz=M(Od());Vr();var dc=M(hT());ao();uc.default.initSync();var zSe=6e4,jSe=1024*1024*1024,JSe="TRUE",{CONFIG_PARAMS:wh}=G,nf;Bz.exports={hdbServer:bz,start:bz};async function bz(e){try{Xi.default.debug("In Fastify server"+process.cwd()),Xi.default.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Xi.default.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=Oz.default.isMaster,await QSe();let t=e.securePort>0;nf=XSe(t),await nf.ready(),e||(e={}),e.isOperationsServer=!0;try{We.http(nf.server,e),nf.server.closeIdleConnections||await nf.listen({port:0,host:"::"})}catch(r){throw nf.close(),Xi.default.error(r),Xi.default.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Xi.default.fatal(t),process.exit(1)}}a(bz,"operationsServer");async function QSe(){Xi.default.trace("Configuring HarperDB process."),Mz.default.setSchemaDataToGlobal(),await Uz.default.setUsersWithRolesCache(),await xz.default.getLicense()}a(QSe,"setUp");function XSe(e){Xi.default.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=ZSe(e),r=(0,Nz.default)(t);r.server.headersTimeout=tTe(),r.setErrorHandler(dc.serverErrorHandler);let n=eTe();n&&r.register(wz.default,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(Pz.default),r.register(Iz.default),r.register(Cz.default,{root:Dz.default.join(Lz.PACKAGE_ROOT,"studio/build-local")}),jf(r);let s=uc.default.get(jA.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!vz.default.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[dc.reqBodyValidationHandler,dc.authHandler],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),(0,dc.handlePostRequest)(i,o)}),r.get("/health",()=>"HarperDB is running."),Xi.default.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(XSe,"buildServer");function ZSe(e){let t=uc.default.get(wh.OPERATIONSAPI_NETWORK_TIMEOUT),r=uc.default.get(wh.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:jSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(ZSe,"getServerOptions");function eTe(){let e=uc.default.get(wh.OPERATIONSAPI_NETWORK_CORS),t=uc.default.get(wh.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===JSe)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(eTe,"getCORSOpts");function tTe(){return uc.default.get(wh.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??zSe}a(tTe,"getHeaderTimeoutConfig")});var iP={};ve(iP,{disableNATS:()=>nTe,publishToStream:()=>JT,setNATSReplicator:()=>eP,setPublishToStream:()=>sTe,setSubscription:()=>sP,start:()=>rTe});function rTe(){Ih.default.get(x.CLUSTERING_ENABLED)&&oTe()}function nTe(e=!0){$z=e}function sTe(e,t){JT=e,sP=t}function oTe(){if($z||process.env._DISABLE_NATS)return;let e=Xe(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];eP(s,r,i)}}Tl((r,n)=>{eP(r.tableName,r.databaseName,r),n&&Kz(r)}),!kz&&(kz=!0)}function eP(e,t,r){if(t==="system"&&aTe.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends $r{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this.getId(),record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this.getId()})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this.getId(),record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this.getId(),record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this.getId()})}static defineSchema(i){Kz(i)}static subscribe(){let i=new Bn;return sP(t,e,i),i}static subscribeOnThisThread(i){return i<(Ih.default.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??iTe)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new zT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=Vz;return i}a(n,"getNATSTransaction")}function Kz(e){let t=Ih.default.get(x.CLUSTERING_NODENAME);JT(`${rP.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,nP.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var Fz,rP,nP,Gz,qz,Ih,jT,$z,JT,sP,iTe,Vz,kz,aTe,zT,tP,Yz=be(()=>{De();Ea();Fz=M(ir()),rP=M(Tt()),nP=M(Eo());pu();Gz=M(xO()),qz=M(_n()),Ih=M(ae());H();jT=M(z());a(rTe,"start");a(nTe,"disableNATS");JT=Fz.publishToStream,sP=Gz.setSubscription;a(sTe,"setPublishToStream");iTe=2;a(oTe,"assignReplicationSource");aTe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(eP,"setNATSReplicator");a(Kz,"publishSchema");zT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=Ih.default.get(x.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let f of i){let d=f.table,p=f.operation=="put"?"upsert":f.operation;l||(jT.trace(`Sending transaction event ${p}`),u=l={operation:p,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,p!=="delete"&&p!=="invalidate"&&(l.records=o)),l.table===d&&l.operation===p?(o.push(f.record),c.push(f.id)):u=u.next={operation:p,table:d,id:f.id,record:f.record},f.expiresAt&&(u.expiresAt=f.expiresAt)}l&&n.push(JT(`${rP.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,nP.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(f=>{throw jT.error("An error has occurred trying to replicate transaction",l,f),f.statusCode=504,f}))}return Promise.all(n)}},tP=class extends zT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,qz.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};Vz=new tP});async function Qz({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await oP.get(e,{returnNonexistent:!0});i=new lP(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await oP.get(e);o&&o.delete()}i=new XT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ch.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function aP(){return QT++,QT>65500&&(QT=1),QT}function cP(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Oi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return wt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var zz,fc,jz,Jz,Wz,oP,Ch,QT,XT,lP,Xz=be(()=>{De();Tu();zz=M(_n()),fc=M(z());Ic();jz=M(rt()),Jz=M(WC());Vr();Wz=100,oP=ft({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),Ch=ft({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,jz.getWorkerIndex)()===0&&(async()=>{await Jz.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of Ch.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await We.getUser(r.user.username));try{await cP(r,t,r)}catch{(0,fc.warn)("Failed to publish will",t)}Ch.delete(e.id)}})();a(Qz,"getSession");QT=1;a(aP,"getNextMessageId");XT=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let f=this.subscriptions.find(R=>R.topic===s),d;f?(d=i>0,f.end(),this.subscriptions.splice(this.subscriptions.indexOf(f),1)):d=i===2;let p={search:l,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,fc.trace)("Resuming subscription from",s,"from",o);let _=Oi.getMatch(u,"mqtt");if(!_){let R=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw R.statusCode=404,R}if(p.url=_.relativeURL,p.url.indexOf("+")>-1||p.url.indexOf("#")>-1){let R=p.url.slice(1);if(R.indexOf("#")>-1&&R.indexOf("#")!==R.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(p.isCollection=!0,R.indexOf("+")===R.length-1)p.onlyChildren=!0,p.url="/"+R.slice(0,R.length-1);else{let E=R.split("/"),T;for(let F=0;F<E.length;F++)if(E[F].indexOf("+")>-1)if(E[F]==="+")T=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&T)throw new Error("Filters can not be combined");let b=!0;E[E.length-1]==="#"&&(E.length--,b=!1),T&&(n=a(F=>{let q=F.id;if(!Array.isArray(q))if(q?.indexOf?.("/")>-1)q=q.split("/");else return!1;if(b&&q.length!==E.length)return!1;for(let Y=0;Y<E.length;Y++)if(E[Y]!=="+"&&E[Y]!==q[Y])return!1;return!0},"filter"));let v=E.indexOf("+");p.url="/"+(v>-1?E.slice(0,v):E).concat("").join("/")}}let h=_.path,S=_.Resource,g=await wt(p,async()=>{let R=this.createContext();R.topic=s,R.retainHandling=i;let E=await S.subscribe(p,R);if(!E)return;if(!E[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let T=(async()=>{for await(let b of E)try{let v;if(b.type&&b.type!=="put"&&b.type!=="delete"&&b.type!=="message"&&b.type!=="patch"||n&&!n(b))continue;r?(b.topic=s,v=this.needsAcknowledge(b)):(b.acknowledge?.(),v=aP());let F=b.id;if(Array.isArray(F)&&(F=Su(F)),F==null&&(F=""),await this.listener(h+"/"+F,b.value,v,t)===!1)break;this.awaitingAcks?.size>Wz?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-Wz)):await new Promise(setImmediate)}catch(v){(0,fc.warn)(v)}})();return E});if(g)return g.topic=s,g.qos=t.qos,this.subscriptions.push(g),g}resume(){}needsAcknowledge(t){let r=aP();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return cP(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();wt(r,async()=>{try{if(!t){let n=await Ch.get(this.sessionId);n?.doesExist()&&await cP(n,n.data,r)}}finally{await Ch.delete(this.sessionId)}}).catch(n=>{(0,fc.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(cP,"publish");lP=class extends XT{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=aP(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,fc.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,zz.getNextMonotonicTime)()),(0,fc.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),oP.put(this.sessionRecord)}}});var dP={};ve(dP,{bypassAuth:()=>cTe,start:()=>lTe});function cTe(){nj=!0}function lTe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new rj.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,f,d,p)=>{if(f.headers.get("sec-websocket-protocol")!=="mqtt")return p(u,f,d);o.events.emit("connection",u),hr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:_,onClose:h}=ej(u,S=>{u.send(S)},f,Promise.resolve(d).then(()=>f?.user),o);u.on("message",_),u.on("close",h),u.on("error",S=>{hr.info?.("WebSocket error",S)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let f;if(o.events.emit("connection",u),hr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let _=l.user;if(_!==null){(_===void 0||_==="Common Name"||_==="CN")&&(_=u.getPeerCertificate().subject.CN);try{f=await e.getUser(_,null,null),(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&eA.notify?.({username:f?.username,status:Ys.SUCCESS,type:la.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&eA.error?.({username:_,status:Ys.FAILURE,type:la.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else hr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(_){o.events.emit("error",_,u),hr.error?.(_)}else if(l.required)return hr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!f&&nj&&u.remoteAddress.includes("127.0.0.1")&&(f=await(0,tj.getSuperUser)(),hr.debug?.("Auto-authorizing local connection",f?.username));let{onMessage:d,onClose:p}=ej(u,_=>u.write(_),null,f,o);u.on("data",d),u.on("close",p),u.on("error",_=>{hr.info?.("Socket error",_)})},{port:t,securePort:s,mtls:l})),c}function ej(e,t,r,n,s){Zz||(Zz=!0,Y_(d=>{ZT>0&&d.push({metric:"mqtt-connections",connections:ZT,byThread:!0})}));let i;ZT++;let o,c={protocolVersion:4},l=(0,tA.parser)({protocolVersion:5});function u(d){l.parse(d)}a(u,"onMessage");function f(){ZT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qn(!1,"connection","mqtt","disconnect"),hr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(f,"onClose"),l.on("packet",async d=>{n?.then&&(n=await n);let p=d.cmd;if(o)o.then&&await o;else if(p!=="connect"){hr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let _=d.topic,h=_?.indexOf("/",1),S=h>0?_.slice(0,h):_;sr(d.length,"bytes-received",S,R(d),"mqtt");try{switch(o?.receivedPacket?.(),p){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await We.getUser(d.username,d.password.toString(),r),(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&eA.notify?.({username:n?.username,status:Ys.SUCCESS,type:la.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(se){return(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&eA.error?.({username:d.username,status:Ys.FAILURE,type:la.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,se),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let se=e.deserialize||(e.deserialize=uo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?se(d.will.payload):void 0,delete d.will.payload}o=Qz({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(se){return hr.error?.(se),s.events.emit("auth-failed",d,e,se),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:se.code||5,returnCode:se.code||128})}s.events.emit("connected",o,e),Qn(!0,"connection","mqtt","connect"),g({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0});let T=a(async(se,Q,ne,J)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",se);let me=se.indexOf("/",1),ye=me>0?se.slice(0,me):se;g({cmd:"publish",topic:se,payload:await E(Q),messageId:ne||Math.floor(Math.random()*1e8),qos:J.qos},ye);let Pe=e._socket??e;return Pe.writableNeedDrain?new Promise(he=>Pe.once("drain",he)):!Pe.closed}catch(me){return hr.error?.(me),o?.disconnect(),s.sessions.delete(o),!1}},"listener");o.setListener(T),o.sessionWasPresent&&await o.resume();break;case"subscribe":let b=[];for(let se of d.subscriptions){let Q;try{let ne=await o.addSubscription(se,se.qos>=1);Q=ne?ne.qos||0:c.protocolVersion<5?128:143}catch(ne){s.events.emit("error",ne,e,se,o),ne.statusCode?ne.statusCode===500?hr.warn?.(ne):hr.info?.(ne):hr.error?.(ne),Q=c.protocolVersion<5?128:ne.statusCode===403?135:ne.statusCode===404?143:128}b.push(Q)}await o.committed,g({cmd:"suback",granted:b,messageId:d.messageId});break;case"unsubscribe":{let se=[];for(let Q of d.unsubscriptions)se.push(o.removeSubscription(Q)?0:17);g({cmd:"unsuback",granted:se,messageId:d.messageId});break}case"pubrel":g({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let v=d.qos===2?"pubrec":"puback",F=e.deserialize||(e.deserialize=uo(r?.headers.get?.("content-type"))),Y=(d.payload?.length||0)>0?F(d.payload):void 0,Z;try{Z=await o.publish(d,Y)}catch(se){s.events.emit("error",se,e,d,o),hr.warn?.(se),d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:Z===!1?144:0},d.topic);break;case"pubrec":g({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":g({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qn(!0,"connection","mqtt","disconnect"),hr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(T){s.events.emit("error",T,e,d,o),hr.error?.(T),g({cmd:"disconnect"})}function g(T,b){let v=(0,tA.generate)(T,c);t(v),sr(v.length,"bytes-sent",b,R(T),"mqtt")}a(g,"sendPacket");function R(T){return T.qos>0?T.cmd+",qos="+T.qos:T.cmd}a(R,"packetMethodName");function E(T){return Aa(T,r)}a(E,"serialize")}),l.on("error",d=>{hr.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:f}}var tA,tj,sf,uP,rj,eA,hr,nj,Zz,ZT,sj=be(()=>{tA=require("mqtt-packet");Xz();tj=M(Rn());ao();ki();Vr();sf=M(ae());H();uP=M(Ni()),rj=require("events"),eA=(0,uP.loggerWithTag)("auth-event"),hr=(0,uP.loggerWithTag)("mqtt"),nj=(0,sf.get)(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(cTe,"bypassAuth");a(lTe,"start");ZT=0;a(ej,"onSocket")});var zp={};ve(zp,{component_errors:()=>af,getComponentName:()=>pTe,loadComponent:()=>sA,loadComponentDirectories:()=>lj,setErrorReporter:()=>_Te});function lj(e,t){t&&(_P=t),e&&(EP=e);let r=[];if((0,ut.existsSync)(fP)){let s=(0,ut.readdirSync)(fP,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,St.join)(fP,o);r.push(sA(c,_P,KA,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(sA(n,_P,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{cj=!0})}function _Te(e){Ph=e}async function sA(e,t,r,n,s,i){let o=(0,ut.realpathSync)(e);if(rA.has(o))return rA.get(o);rA.set(o,!0),s&&(EP=s);try{let c;n&&(af=new Map);let l=(0,St.join)(e,"harperdb-config.yaml");(0,ut.existsSync)(l)?c=n?(0,iA.getConfigObj)():(0,pP.parseDocument)((0,ut.readFileSync)(l,"utf8")).toJSON():!n&&(0,ut.existsSync)(l=(0,St.join)(e,"config.yaml"))?c=(0,pP.parseDocument)((0,ut.readFileSync)(l,"utf8")).toJSON():c=gP;let u=(0,St.join)(e,"node_modules","harperdb");try{jl.isMainThread&&(n||((0,ut.existsSync)(u)||!e.startsWith((0,mP.getHdbBasePath)()))&&(!(0,ut.existsSync)(u)||(0,ut.realpathSync)(hP.PACKAGE_ROOT)!==(0,ut.realpathSync)(u)))&&((0,ut.rmSync)(u,{recursive:!0,force:!0}),(0,ut.existsSync)((0,St.join)(e,"node_modules"))||(0,ut.mkdirSync)((0,St.join)(e,"node_modules")),(0,ut.symlinkSync)(hP.PACKAGE_ROOT,u,"dir"))}catch(p){of.default.error("Error symlinking harperdb module",p)}let f=nA,d=n;for(let p in c){nA=p;let _=c[p];if(af.set(n?p:(0,St.basename)(e),!1),!_)continue;let h,S=_.package;try{if(S){let b=e,v;for(;!(0,ut.existsSync)(v=(0,St.join)(b,"node_modules",p));)if(b=(0,St.dirname)(b),b.length<(0,mP.getHdbBasePath)().length){v=null;break}if(v)h=await sA(v,t,r,!1),d=!0;else throw new Error(`Unable to find package ${p}:${S}`)}else h=fTe[p];if(!h)continue;let g=a(b=>(b.origin=r,ft(b)),"ensureTable"),R=_.network||(_.port||_.securePort)&&_,E=R?.securePort||R?.https&&R.port,T=!R?.https&&R?.port;if(jl.isMainThread&&(h=await h.startOnMainThread?.({server:We,ensureTable:g,port:T,securePort:E,resources:t,..._})||h,n&&R))for(let b of[T,E])try{if(+b&&!ij.includes(b)){let v=SP.get(x.HTTP_SESSIONAFFINITY);v&&of.default.warn("Session affinity is not recommended and may cause memory leaks"),(v||!gT)&&(ij.push(b),XC(b,v))}}catch(v){console.error("Error listening on socket",b,v,p)}if(t.isWorker&&(h=await h.start?.({server:We,ensureTable:g,port:T,securePort:E,resources:t,..._})||h),EP.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&_.files!=null){if(_.files.includes(".."))throw(0,aj.handleHDBError)("Can not reference parent directories");let b=(0,St.join)(e,_.files).replace(/\\/g,"/"),v=b.indexOf("/*");if(v>-1&&_.files!==gP[p]?.files&&!(0,ut.existsSync)(b.slice(0,v)))throw new Error(`The path '${b.slice(0,v)}' does not exist and cannot be used as the base of the resolved 'files' path value '${_.files}'`);let F=(0,St.basename)(e),q=_.path||"/";q=q.startsWith("/")?q:q.startsWith("./")?"/"+F+q.slice(2):q==="."?"/"+F:"/"+F+"/"+q;let Y,Z,se;if(_.root){let ne=_.root;ne.startsWith("/")&&(ne=ne.slice(1)),ne.endsWith("/")&&(ne=ne.slice(0,-1)),ne+="/",Z=(0,St.join)(e,ne)}else(se=b.indexOf("/*"))>-1?(Z=b.slice(0,se+1),Y=(0,St.relative)(e,Z)):_.files.indexOf("/")>-1&&(Z=b.slice(0,b.lastIndexOf("/")+1),Y=(0,St.relative)(e,Z));let Q=!1;if(jl.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(q,Z,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(q,Z,t)),Q){d=!0;continue}for(let ne of await(0,oj.default)(b,{onlyFiles:!1,objectMode:!0})){let{path:J,dirent:me}=ne;d=!0;let ye=(0,St.relative)(e,J).replace(/\\/g,"/");if(Y)if(ye.startsWith(Y))ye=ye.slice(Y.length+1);else throw new Error(`The root path '${_.root}' does not reference a valid part of the file path '${ye}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Pe=q+(q.endsWith("/")?"":"/")+ye;try{if(me.isFile()){let he=await dTe(J);jl.isMainThread&&await h.setupFile?.(he,Pe,J,t),t.isWorker&&await h.handleFile?.(he,Pe,J,t)}else jl.isMainThread&&await h.setupDirectory?.(Pe,J,t),t.isWorker&&await h.handleDirectory?.(Pe,J,t)}catch(he){let Nt=`Could not load ${me.isFile()?"file":"directory"} '${J}'${_.module?` using '${_.module}'`:""} for application '${e}' due to:
|
|
133
|
+
`;he.message=`${Nt}${he.message}`,he.stack=`${Nt}${he.stack}`,Ph?.(he),of.default.error(he),t.set(_.path||"/",new ga(he)),af.set(n?p:(0,St.basename)(e),he.message)}}}}catch(g){g.message=`Could not load component '${p}' for application '${(0,St.basename)(e)}' due to: ${g.message}`,Ph?.(g),((0,Dh.getWorkerIndex)()===0?console:of.default).error(g),t.set(_.path||"/",new ga(g),null,!0),af.set(n?p:(0,St.basename)(e),g.message)}}if(nA=f,jl.isMainThread&&!cj&&i&&(0,Dh.watchDir)(e,async()=>lj()),c.extensionModule){let p=await jE((0,St.join)(e,c.extensionModule));return rA.set(o,p),p}if(!d&&t.isWorker){let p=`${e} did not load any modules, resources, or files, is this a valid component?`;Ph?.(new Error(p)),((0,Dh.getWorkerIndex)()===0?console:of.default).error(p),af.set((0,St.basename)(e),p)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Ph?.(c),t.set("",new ga(c))}}var ut,St,jl,pP,SP,hP,oj,Dh,of,aj,mP,uTe,iA,dTe,fP,EP,cj,_P,af,fTe,gP,ij,rA,Ph,nA,pTe,jp=be(()=>{ut=require("fs"),St=require("path"),jl=require("worker_threads"),pP=require("yaml"),SP=M(ae()),hP=M(it());H();HL();AM();JB();eH();tH();BH();mY();RY();bY();oj=M(require("fast-glob")),Dh=M(rt()),of=M(z());oO();Vr();aj=M(pe());De();BC();mP=M(ae()),uTe=M(Hz());vS();Yz();Xn();sj();iA=M(yt());ZI();SR();({readFile:dTe}=ut.promises),fP=(0,iA.resolvePath)(SP.get(x.COMPONENTSROOT)),EP=new Map,af=new Map;a(lj,"loadComponentDirectories");fTe={REST:tg,rest:tg,graphql:HR,graphqlSchema:RR,roles:iO,jsResource:cO,fastifyRoutes:WI,login:uO,static:zI,operationsApi:uTe,customFunctions:{},http:{},clustering:iP,replication:wo,authentication:Gp,mqtt:dP,loadEnv:jI},gP={rest:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(gP,"static",{value:{files:"web/**"}});ij=[],rA=new Map;a(_Te,"setErrorReporter");pTe=a(()=>nA,"getComponentName");a(sA,"loadComponent")});var $T=w((I0e,dj)=>{var{isMainThread:uj}=require("worker_threads"),{getTables:hTe,getDatabases:N0e,table:w0e}=(De(),C(nt)),{loadComponentDirectories:mTe,loadComponent:ETe}=(jp(),C(zp)),{resetResources:gTe}=(Tu(),C(vL)),STe=$w(),TTe=yt(),{dirname:ATe}=require("path"),{getConnection:RTe}=ir(),yTe=ae(),{CONFIG_PARAMS:bTe}=(H(),C(G)),{loadCertificates:OTe}=Zn(),TP=new Map;async function NTe(e=!1){!uj&&yTe.get(bTe.CLUSTERING_ENABLED)&&RTe();try{uj&&await STe()}catch(n){console.error(n)}let t=gTe();hTe(),t.isWorker=e,await OTe(),await ETe(ATe(TTe.getConfigFilePath()),t,"hdb",!0,TP),await mTe(TP,t);let r=[];for(let[n]of TP)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(NTe,"loadRootComponents");dj.exports.loadRootComponents=NTe});var rt=w((P0e,Si)=>{"use strict";nm();var{Worker:wTe,MessageChannel:ITe,parentPort:Zi,isMainThread:OP,threadId:CTe,workerData:eo}=require("worker_threads"),{PACKAGE_ROOT:PTe}=it(),{join:hj,isAbsolute:DTe,extname:LTe}=require("path"),{server:mj}=(Vr(),C(Au)),{watch:MTe,readdir:vTe}=require("fs/promises"),{totalmem:fj}=require("os"),cf=(H(),C(G)),Ej=ae(),gi=z(),{randomBytes:UTe}=require("crypto"),{_assignPackageExport:xTe}=Ti(),_j=1024*1024,_c=[],Hs=[],BTe=50,NP=1e4,HTe="restart",gj="request_thread_info",Sj="resource_report",Tj="thread_info",Aj="added-port",kTe="ack",AP;xTe("threads",Hs);Si.exports={startWorker:RP,restartWorkers:IP,shutdownWorkers:VTe,workers:_c,setMonitorListener:XTe,onMessageFromWorkers:KTe,onMessageByType:Ij,broadcast:WTe,broadcastWithAcknowledgement:jTe,setChildListenerByType:$Te,getWorkerIndex:Rj,getWorkerCount:yj,getTicketKeys:Oj,setMainIsWorker:GTe,setTerminateTimeout:FTe,restartNumber:eo?.restartNumber||1};Hs.onMessageByType=Ij;Hs.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Hs.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Si.exports.whenThreadsStarted=new Promise(e=>{Si.exports.threadsHaveStarted=e});var wP;function FTe(e){NP=e}a(FTe,"setTerminateTimeout");function Rj(){return eo?eo.workerIndex:wP?0:void 0}a(Rj,"getWorkerIndex");function yj(){return eo?eo.workerCount:wP?1:void 0}a(yj,"getWorkerCount");function GTe(e){wP=e,Si.exports.threadsHaveStarted()}a(GTe,"setMainIsWorker");var bj=1,oA;function Oj(){return oA||(oA=OP?UTe(48):eo.ticketKeys,oA)}a(Oj,"getTicketKeys");Object.defineProperty(mj,"workerIndex",{get(){return Rj()}});Object.defineProperty(mj,"workerCount",{get(){return yj()}});var Nj={[gj](e,t){JTe(t)},[Sj](e,t){QTe(t,e)}};function RP(e,t={}){let r=process.constrainedMemory?.()||fj();r=Math.min(r,fj(),2e4*_j);let n=Ej.get(cf.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/_j/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Hs){let u=new ITe;u.existingPort=l,i.push(u),o.push(u.port2)}LTe(e)||(e+=".js");let c=new wTe(DTe(e)?e:hj(PTe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps","--expose-internals"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:bj=t.threadCount,name:t.name,restartNumber:Si.exports.restartNumber,ticketKeys:Oj()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:Aj,port:l,threadId:c.threadId},[l]);return cA(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>RP(e,t),c.on("error",l=>{gi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{_c.splice(_c.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<BTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,RP(e,t)):gi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{Nj[l.type]?.(l,c)}),_c.push(c),eAe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(RP,"startWorker");var qTe=[cf.THREAD_TYPES.HTTP];async function IP(e=null,t=Math.max(bj>3,1),r=!0){if(OP){try{process.chdir(process.cwd())}catch(o){gi.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=$T();await o()}Si.exports.restartNumber++,t<1&&(t=t*_c.length);let n=[],s=[];for(let o of _c.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;gi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Si.exports.restartNumber,type:cf.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=qTe.indexOf(o.name)>-1,l=new Promise(u=>{let f=setTimeout(()=>{gi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},NP*2).unref();o.on("exit",()=>{clearTimeout(f),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),f=new Promise(d=>{let p=a(_=>{_.type===cf.ITC_EVENT_TYPES.CHILD_STARTED&&(gi.trace("Worker has started",u.threadId),d(),s.splice(s.indexOf(f)),u.off("message",p))},"startListener");gi.trace("Waiting for worker to start",u.threadId),u.on("message",p)});s.push(f),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=za();r&&(e==="http"||!e)&&Ej.get(cf.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Zi.postMessage({type:HTe,workerType:e})}a(IP,"restartWorkers");function $Te(e,t){Nj[e]=t}a($Te,"setChildListenerByType");function VTe(e){return IP(e,1/0,!1)}a(VTe,"shutdownWorkers");var wj=[];function KTe(e){wj.push(e)}a(KTe,"onMessageFromWorkers");var yP=new Map;function Ij(e,t){let r=yP.get(e);r||yP.set(e,r=[]),r.push(t)}a(Ij,"onMessageByType");var YTe=10;async function WTe(e,t){let r=0;for(let n of Hs)try{n.postMessage(e),r++>YTe&&(r=0,await new Promise(setImmediate))}catch(s){gi.error("Unable to send message to worker",s)}t&&Pj(e,null)}a(WTe,"broadcast");var aA=new Map,zTe=1;function jTe(e){return new Promise(t=>{let r=0;for(let n of Hs)try{let s=zTe++,i=a(()=>{aA.delete(s),--r===0&&t(),n!==Zi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,aA.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of aA)o.port===n&&o()})),n.postMessage(e),r++}catch(s){gi.error("Unable to send message to worker",s)}r===0&&t()})}a(jTe,"broadcastWithAcknowledgement");function JTe(e){e.postMessage({type:Tj,workers:Cj()})}a(JTe,"sendThreadInfo");function Cj(){let e=Date.now();return _c.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(Cj,"getChildWorkerInfo");function QTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(QTe,"recordResourceReport");var bP;function XTe(e){bP=e}a(XTe,"setMonitorListener");var ZTe=1e3,pj=!1;function eAe(){pj||(pj=!0,setInterval(()=>{for(let e of _c){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}bP&&bP()},ZTe).unref())}a(eAe,"startMonitoring");var tAe=1e3;if(Zi&&eo?.addPorts){cA(Zi);for(let e=0,t=eo.addPorts.length;e<t;e++){let r=eo.addPorts[e];r.threadId=eo.addThreadIds[e],cA(r)}setInterval(()=>{let e=process.memoryUsage();Zi.postMessage({type:Sj,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},tAe).unref(),AP=a(()=>new Promise((e,t)=>{Zi.on("message",r),Zi.postMessage({type:gj});function r(n){n.type===Tj&&(Zi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else AP=Cj;Si.exports.getThreadInfo=AP;function cA(e,t){Hs.push(e),e.on("message",r=>{if(r.type===Aj)r.port.threadId=r.threadId,cA(r.port);else if(r.type===kTe){let n=aA.get(r.id);n&&n()}else Pj(r,e)}).on("close",()=>{Hs.splice(Hs.indexOf(e),1)}).on("exit",()=>{Hs.splice(Hs.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(cA,"addPort");function Pj(e,t){for(let n of wj)n(e,t);let r=yP.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){gi.error(s)}}a(Pj,"notifyMessageListeners");if(OP){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await vTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(hj(s,o.name));try{for await(let{filename:o}of MTe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await IP(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");Si.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Zi.on("message",async e=>{let{type:t}=e;t===cf.ITC_EVENT_TYPES.SHUTDOWN&&(Si.exports.restartNumber=e.restartNumber,Zi.unref(),setTimeout(()=>{gi.warn("Thread did not voluntarily terminate",CTe),process.exit(0)},NP).unref())})});var hB={};ve(hB,{ACTION_32_BIT:()=>zm,ACTION_64_BIT:()=>sAe,AUDIT_STORE_OPTIONS:()=>xp,Decoder:()=>Sl,HAS_BLOBS:()=>Fn,HAS_CURRENT_RESIDENCY_ID:()=>kc,HAS_EXPIRATION_EXTENDED_TYPE:()=>n_,HAS_ORIGINATING_OPERATION:()=>r_,HAS_PREVIOUS_RESIDENCY_ID:()=>Fc,REMOTE_SEQUENCE_UPDATE:()=>vg,createAuditEntry:()=>Nu,getLastRemoved:()=>TN,openAuditStore:()=>dA,readAuditEntry:()=>It,removeAuditEntry:()=>fA,setAuditRetention:()=>nAe,transactionKeyEncoder:()=>kj});function dA(e){let t=e.auditStore=e.openDB(CP.AUDIT_STORE_NAME,{create:!1,...xp});t||(t=e.auditStore=e.openDB(CP.AUDIT_STORE_NAME,xp),Lj(t,1)),t.rootStore=e,t.tableStores=[];let r=[];t.addDeleteRemovalCallback=function(l,u,f){return r[l]=f,t.tableStores[l]=u,t.deleteCallbacks=r,{remove(){delete r[l]}}};let n=null,s,i=0,o=DP;Ah(t.env.path,l=>{if(i=l,l)return c(100)});function c(l){l&&(o=l),clearTimeout(n);let u=new Promise(f=>{n=setTimeout(async()=>{if(await s,s=u,t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let d=0,p,_;try{for(let{key:h,value:S}of t.getRange({start:1,snapshot:!1,end:Date.now()-PP/(1+i*i)})){try{p=fA(t,h,S)}catch(g){lf.warn("Error removing audit entry",g)}if(_=h,await new Promise(setImmediate),++d>=rAe){o=10;break}}await p}finally{d===0?o=Math.min(o<<1,PP/10):(Lj(t,_),o>100&&(o=o>>1)),f(void 0),c()}},o).unref()});return u}if(a(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,Mh.getWorkerIndex)()===(0,Mh.getWorkerCount)()-1&&c(),(0,Mh.getWorkerIndex)()===0&&!Dj)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Dj=!0,lf.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function fA(e,t,r){let n=iAe(r),s;if(n&Fn){s=It(r);let i=e.tableStores[s.tableId],o=i?.getEntry(s.recordId);(!o||o.version!==s.version||!o.value)&&vc(()=>Ta(s.getValue(i)),i.rootStore)}if((n&15)===LP){s=s||It(r);let i=s.tableId;e.tableStores[s.tableId]?.getEntry(s.recordId).version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function Lj(e,t){MP[0]=t,e.put(Symbol.for("last-removed"),Fj)}function TN(e){let t=e.get(Symbol.for("last-removed"));if(t)return Fj.set(t),MP[0]}function nAe(e,t=DP){PP=e,DP=t}function Nu(e,t,r,n,s,i,o,c,l,u,f,d,p){let _=Gj[o];if(!_)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?pc.setFloat64(0,n):ks.set(zR),h=9),l){if(l&255)throw new Error("Illegal extended type");h+=3}R(s),R(t),g(r),pc.setFloat64(h,e),h+=8,l&kc&&R(u),l&Fc&&R(f),l&n_&&(pc.setFloat64(h,d),h+=8),l&r_&&R(qj[p]),i?g(i):ks[h++]=0,l?pc.setUint32(n?8:0,_|l|3221225472):ks[n?8:0]=_;let S=ks.subarray(0,h);if(c)return Buffer.concat([S,c]);return S;function g(E){let T=h;h+=1,h=(0,Jl.writeKey)(E,ks,h);let b=h-T-1;b>127?b>16383?(lf.error("Key or username was too large for audit entry",E),h=T+1,ks[T]=0):(ks.copyWithin(T+2,T+1,h),pc.setUint16(T,b|32768),h++):ks[T]=b}function R(E){E<128?ks[h++]=E:E<16384?(pc.setUint16(h,E|32768),h+=2):E<1056964608?(pc.setUint32(h,E|3221225472),h+=4):(ks[h]=255,pc.setUint32(h+1,E),h+=5)}}function iAe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Sl(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function It(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Sl(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,f=n.position+=l,d=n.readFloat64(),p,_,h,S;if(i&kc&&(p=n.readInt()),i&Fc&&(_=n.readInt()),i&n_&&(h=n.readFloat64()),i&r_){let T=n.readInt();S=qj[T]}l=n.readInt();let g=n.position,R=n.position+=l,E;return{type:Gj[i&7],tableId:c,nodeId:o,get recordId(){return(0,Jl.readKey)(e,u,f)},getBinaryRecordId(){return e.subarray(u,f)},version:d,previousLocalTime:s,get user(){return R>g?(0,Jl.readKey)(e,g,R):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(T,b,v){if(i&lA||i&Lh&&!b)return E||(E=vc(()=>T.decoder.decode(e.subarray(n.position,r)),T.rootStore)),E;if(i&Lh&&v)return Vb(T.getEntry(this.recordId),v,T)},getBinaryValue(){return i&(lA|Lh)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:p,previousResidencyId:_,expiresAt:h,originatingOperation:S}}catch(n){return lf.error("Reading audit entry error",n,e),{}}}var Jl,uA,CP,Mh,Hj,lf,ks,pc,kj,xp,PP,rAe,MP,Fj,DP,Dj,lA,Lh,Mj,LP,vj,Uj,xj,Bj,zm,sAe,vg,kc,Fc,r_,n_,Fn,Gj,qj,Sl,fo=be(()=>{Jl=require("ordered-binary"),uA=M(ae()),CP=M(xt());H();Mh=M(rt()),Hj=M(ie());wu();lf=M(z());xE();gs();UT();(0,uA.initSync)();ks=Buffer.alloc(2816),pc=new DataView(ks.buffer,ks.byteOffset,2816),kj={writeKey(e,t,r){return e===t_?(t.set(t_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Jl.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Jl.readKey)(e,t,r)}},xp={encoding:"binary",keyEncoder:kj},PP=(0,Hj.convertToMS)((0,uA.get)(x.LOGGING_AUDITRETENTION))||86400*3,rAe=1e3,MP=new Float64Array(1),Fj=new Uint8Array(MP.buffer),DP=1e4,Dj=!1;a(dA,"openAuditStore");a(fA,"removeAuditEntry");a(Lj,"updateLastRemoved");a(TN,"getLastRemoved");a(nAe,"setAuditRetention");lA=16,Lh=32,Mj=1,LP=2,vj=3,Uj=4,xj=5,Bj=6,zm=14,sAe=15,vg=11,kc=512,Fc=1024,r_=2048,n_=4096,Fn=8192,Gj={put:Mj|lA,[Mj]:"put",delete:LP,[LP]:"delete",message:vj|lA,[vj]:"message",invalidate:Uj|Lh,[Uj]:"invalidate",patch:xj|Lh,[xj]:"patch",relocate:Bj,[Bj]:"relocate"},qj={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Nu,"createAuditEntry");a(iAe,"readAction");a(It,"readAuditEntry");Sl=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});function xP(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Vj,oAe(e.primaryStore,e.auditStore)):(c=$j,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{Kj($j[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=Su(t);let f=new UP(r);f.startTime=n;let d=u.get(t);return d?d.push(f):(u.set(t,d=[f]),d.tables=u,d.key=t),f.subscriptions=d,f}function Kj(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),Yj(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=It(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Su(c),u=0;do{let f=o.get(l);if(f){for(let p of f)if(!(u>0&&!(p.includeDescendants&&!(p.onlyChildren&&u>1)))){if(p.startTime>=n){(0,vP.info)("omitting",c,p.startTime,n);continue}try{let _;p.supportsTransactions&&p.txnInProgress!==i.version&&(_=!0,p.txnInProgress||(r?r.push(p):r=[p]),p.txnInProgress=i.version),p.listener(c,i,n,_)}catch(_){console.error(_),(0,vP.info)(_)}}}if(l==null)break;let d=l.lastIndexOf?.("/",l.length-2);d!==l.length-1&&u++,d>-1?l=l.slice(0,d+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function oAe(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=Vj[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{Kj(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function Yj(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function HF(e){return e.nextTransaction||(xP({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),Yj(e)),e.nextTransaction}var vP,$j,Vj,UP,AN=be(()=>{vP=M(z());pu();Tu();fo();$j=Object.create(null),Vj=Object.create(null);a(xP,"addSubscription");UP=class extends Bn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(Kj,"notifyFromTransactionData");a(oAe,"listenToCommits");a(Yj,"nextTransaction");a(HF,"whenNextTransaction")});var II={};ve(II,{EVICTED:()=>ma,INVALIDATED:()=>mn,coerceType:()=>hA,makeTable:()=>EA,setServerUtilities:()=>pAe});function EA(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:f,sealed:d,splitSegments:p,replicate:_}=e,{expirationMS:h,evictionMS:S,audit:g,trackDeletes:R}=e;S??=0;let{attributes:E}=e;E||(E=[]);let T=QR(i,n,l),b,v,F={},q=Promise.resolve(),Y,Z,se;for(let V of E)(V.assignCreatedTime||V.name==="__createdtime__")&&(Y=V),(V.assignUpdatedTime||V.name==="__updatedtime__")&&(Z=V),V.expiresAt&&(se=V),V.isPrimaryKey&&(F=V);let Q,ne=[],J=[],me=1,ye=2,Pe={},he={},Nt=864e5,dt=0,br,hs,Un,ou=!1,au,HA=new Map,kA=new Map,vt,Ef,Jh=Xl.get(x.REPLICATION_DATABASES);if(Array.isArray(Jh)){for(let V of Jh)if(V.name===c&&V.replicateTo>=0){Ef=V.replicateTo;break}}let Qh=i.getRange({start:!1,end:!1}).constructor,gf=10,Xh=6;g&&Af(),Ah(i.env.path,V=>{if(v)return aa(V)});class Ie extends $r{#e;#t;#n;#r;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=o;static databaseName=c;static attributes=E;static replicate=_;static sealed=d;static splitSegments=p??!0;static createdTimeProperty=Y;static updatedTimeProperty=Z;static propertyResolvers;static userResolvers={};static sources=[];static getResidencyById;static get expirationMS(){return h}static dbisDB=f;static schemaDefined=u;static sourcedFrom(m,A){if(A&&(this.sourceOptions=A,(A.expiration||A.eviction||A.scanInterval)&&this.setTTLExpiration(A)),A?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(N=>!N.intermediateSource)){if(this.sources.some(N=>N.name===m.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(m)}v=v||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),b=b||m.load;let I=a(N=>{let L=this.sources;if(L=L.filter(k=>k.intermediateSource&&k[N]&&(!k[N].reliesOnPrototype||k.prototype[N])),L.length>0)if(L.length===1){let k=L[0];return(D,B,$)=>{if(D?.source!==k)return k[N](B,$,D)}}else return(k,D,B)=>{let $=[];for(let j of L){if(k?.source===j)break;$.push(j[N](D,B,k))}return Promise.all($)}},"getApplyToIntermediateSource"),y=this.sources[this.sources.length-1];y.intermediateSource&&(y={});let O=a(N=>{if(y[N]&&(!y[N].reliesOnPrototype||y.prototype[N]))return(L,k,D)=>{if(!L?.source)return y[N](k,D,L)}},"getApplyToCanonicalSource");Pe={put:O("put"),patch:O("patch"),delete:O("delete"),publish:O("publish")},he={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish"),invalidate:I("invalidate")};let P=y.shouldRevalidateEvents;return(async()=>{let N=!1,L,k=a(async(D,B)=>{let $=D.value,j=D.table?qe[c][D.table]:Ie;if(c===bf&&(D.table===fu.ROLE_TABLE_NAME||D.table===fu.USER_TABLE_NAME)&&(N=!0),D.id===void 0&&(D.id=$[j.primaryKey],D.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(D));D.source=m;let oe={residencyId:Rc(D.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:D.nodeId},U=await j.getResource(D.id,B,oe);switch(D.finished&&await D.finished,D.type){case"put":return P?U._writeInvalidate($,oe):U._writeUpdate($,!0,oe);case"patch":return P?U._writeInvalidate($,oe):U._writeUpdate($,!1,oe);case"delete":return U._writeDelete(oe);case"publish":return U._writePublish($,oe);case"invalidate":return U._writeInvalidate($,oe);case"relocate":return U._writeRelocate(oe);default:Ue.default.error?.("Unknown operation",D.type,D.id)}},"writeUpdate");try{let D=m.subscribe;D&&R==null&&(R=!0);let B={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},$=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Ql.getWorkerIndex)(),B):(0,Ql.getWorkerIndex)()===0,j=D&&$&&await m.subscribe?.(B);if(j){let oe;for await(let U of j)try{if(!(U.type==="transaction"?U.writes[0]:U)){Ue.default.error?.("Bad subscription event",U);continue}if(U.source=m,U.type==="end_txn"){if(oe?.resolve(),U.localTime&&L!==U.localTime){if(U.remoteNodeIds?.length>0){let fe=[Symbol.for("seq"),U.remoteNodeIds[0]],te=f.get(fe),W=te?.nodes;W||(W=[]);for(let Ee of U.remoteNodeIds.slice(1)){let Se=W.find(tt=>tt.id===Ee);W=W.filter(tt=>tt.id!==Ee||tt===Se),Se||(Se={id:Ee,seqId:0},W.push(Se)),Se.seqId=Math.max(te?.seqId??1,U.localTime),Ee===oe?.nodeId&&(Se.lastTxnTime=U.timestamp)}let _e=Math.max(te?.seqId??1,U.localTime);Ue.default.trace?.("Received txn",c,new Date(_e),new Date(U.localTime),U.remoteNodeIds),f.put(fe,{seqId:_e,nodes:W})}L=U.localTime}U.onCommit&&oe?.committed.then(U.onCommit);continue}if(oe)if(U.beginTxn)oe.resolve();else{oe.write_promises.push(k(U,oe));continue}!U.timestamp&&U.version&&(U.timestamp=U.version);let ce=wt(U,()=>{if(U.type==="transaction"){let fe=[];for(let te of U.writes)try{fe.push(k(te,U))}catch(W){throw W.message+=" writing "+JSON.stringify(te)+" of event "+JSON.stringify(U),W}return Promise.all(fe)}else if(U.type==="define_schema"){let fe=this.attributes.slice(0),te;for(let W of U.attributes)fe.find(_e=>_e.name===W.name)||(fe.push(W),te=!0);te&&(ft({table:s,database:c,attributes:fe,origin:"cluster"}),Uh.signalSchemaChange(new xh.SchemaEventMsg(process.pid,Yt.CREATE_TABLE,c,s)))}else return U.beginTxn?(oe=U,oe.write_promises=[k(U,U)],new Promise(fe=>{oe.resolve=()=>fe(Promise.all(oe.write_promises))})):k(U,U)});oe&&(oe.committed=ce),N&&ce&&!ce?.waitingForUserChange&&(ce.then(()=>Uh.signalUserChange(new xh.UserEventMsg(process.pid))),ce.waitingForUserChange=!0),U.onCommit&&(ce?ce.then(U.onCommit):U.onCommit())}catch(ue){Ue.default.error?.("error in subscription handler",ue)}}}catch(D){Ue.default.error?.(D)}})(),this}static get isCaching(){return v}static get shouldRevalidateEvents(){return this.prototype.get!==Ie.prototype.get}static getResource(m,A,I){let y=super.getResource(m,A,I);if(m!=null){Cr(m);try{if(y.getRecord?.())return y;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let O=!I?.async||i.cache?.get?.(m),P=Gr(A),N=P.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return cu(m,A,{transaction:N,ensureLoaded:I?.ensureLoaded},O,L=>{if(L?Ie._updateResource(y,L):y.#e=null,A.onlyIfCached&&A.noCacheStore){if(!y.doesExist())throw new Ir.ServerError("Entry is not cached",504)}else if(I?.ensureLoaded){let k=un(m,L,A,y);if(k)return P?.disregardReadTxn(),y.#i=!0,HP(k,D=>(Ie._updateResource(y,D),y))}return y})}catch(O){throw O.message.includes("Unable to serialize object")&&(O.message+=": "+JSON.stringify(m)),O}}return y}static _updateResource(m,A){m.#r=A,m.#e=A?.value??null,m.#n=A?.version}ensureLoaded(){let m=un(this.getId(),this.#r,this.getContext());if(m)return this.#i=!0,HP(m,A=>{this.#r=A,this.#e=A.value,this.#n=A.version})}static getNewId(){let m=F?.type;if(m==="String"||m==="ID")return super.getNewId();if(!vt){let O=i.getEntry(Symbol.for("id_allocation")),P=O?.value,N;if(P&&P.nodeName===server.hostname&&(!mAe(i)||P.pid===process.pid)){let L=P.start,k=P.end;N=L;for(let D of i.getKeys({start:k,end:L,limit:1,reverse:!0}))N=D}else P=y(O?.version??null),N=P.start;vt=new BigInt64Array([BigInt(N)+1n]),vt=new BigInt64Array(i.getUserSharedBuffer("id",vt.buffer)),vt.maxSafeId=P.end}let A=Number(Atomics.add(vt,0,1n)),I=m==="Int"?512:1048576;if(A+I>=vt.maxSafeId){let O=a(P=>{vt.maxSafeId=A+(m==="Int"?1023:4194303);let N=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,L=P?void 0:i.useReadTransaction(),k=Number(vt[0]);for(let $ of i.getKeys({start:k+1,end:N,limit:1,transaction:L}))N=$;L?.done();let{value:D,version:B}=i.getEntry(Symbol.for("id_allocation"));if(vt.maxSafeId<N){if(D.end>vt.maxSafeId-100)return;Ue.default.info?.("New id allocation",A,vt.maxSafeId,B),i.put(Symbol.for("id_allocation"),{start:D.start,end:vt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),B)}else{Ue.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${vt.maxSafeId}, but id of ${N} detected`);let $=y(B);$.alreadyUpdated||Atomics.store(vt,0,BigInt($.start+1)),vt.maxSafeId=$.end}},"updateEnd");A+I===vt.maxSafeId?setImmediate(O):A+100>=vt.maxSafeId&&(Ue.default.warn?.(`Synchronous id allocation required on table ${s}${m=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>O(!0)))}return A;function y(O){let P=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,N=P/4,L,k,D=!1,B,$;do{B=Math.floor(Math.random()*P),$={start:B,end:B+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},L=0;for(let j of i.getKeys({start:B,limit:1,reverse:!0}))L=j;k=P;for(let j of i.getKeys({start:B+1,end:P,limit:1}))k=j;N*=.875,N<1e3&&!D&&(D=!0,Ue.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${m==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,B,L,k,N))}while(!(N<k-B&&(N<B-L||L===0)));return i.transactionSync(()=>{let j=i.getEntry(Symbol.for("id_allocation"));return(j?.version??null)==O?(Ue.default.info?.("Allocated new id range",$),i.put(Symbol.for("id_allocation"),$,Date.now()),$):(Ue.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...j.value})})}}static setTTLExpiration(m){if(typeof m=="number")h=m*1e3,S||(S=0);else if(m&&typeof m=="object")h=m.expiration*1e3,S=(m.eviction||0)*1e3,Nt=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Nt=Nt||(h+S)/4,aa()}static getResidencyRecord(m){return f.get([Symbol.for("residency_by_id"),m])}static setResidency(m){Ie.getResidency=m}static setResidencyById(m){Ie.getResidencyById=m}static getResidency(m,A){if(Ie.getResidencyById)return Ie.getResidencyById(m[t]);let I=Ef;if(A.replicateTo!=null){if(Array.isArray(A.replicateTo))return A.replicateTo.includes(server.hostname)?A.replicateTo:[server.hostname,...A.replicateTo];A.replicateTo>=0&&(I=A.replicateTo)}if(I>=0&&server.nodes){let y=[server.hostname];if(A.previousResidency)y.push(...A.previousResidency.slice(0,I));else{let O=server.nodes.map(L=>L.name),P=Math.floor(O.length*Math.random());y.push(...O.slice(P,P+I));let N=P+I-O.length;N>0&&y.push(...O.slice(0,N))}return y}}static enableAuditing(m=!0){g=m,m&&Af(),Ie.audit=m}static coerceId(m){return m===""?null:hA(m,F)}static async dropTable(){delete qe[c][s];for(let m of i.getRange({versions:!0,snapshot:!1,lazy:!0}))m.metadataFlags&Fn&&m.value&&Ta(m.value);if(c===o){for(let m of E)f.remove(Ie.tableName+"/"+m.name),r[m.name]?.drop();f.remove(Ie.tableName+"/"),i.drop(),await f.committed}else console.log("legacy dropTable"),await i.close(),await pA.default.remove(data_path),await pA.default.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));Uh.signalSchemaChange(new xh.SchemaEventMsg(process.pid,Yt.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this.isCollection)return this.search(m);if(this.getId()===null)return m?.conditions?this.search(m):{records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:E};if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(m,A){let I=Tf(m);if(I?.read){if(I.isSuperUser)return!0;let y=I.attribute_permissions,O=A?.select;if(y?.length>0||ou&&O){if(A||(A={}),O){let P=y?.length>0&&BP(y,"read");A.select=O.map(N=>{let L=N.name||N;if(!P||P[L]){let k=Un[L]?.definition?.tableClass;if(k){if(N.name||(N={name:N}),!k.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else A.select=y.filter(P=>P.read&&!Un[P.attribute_name]).map(P=>P.attribute_name);return A}else return!0}}allowUpdate(m,A){let I=Tf(m);if(I?.update){let y=I.attribute_permissions;if(y?.length>0){let O=BP(y,"update");for(let P in A)if(!O[P])return!1;for(let P of y){let N=P.attribute_name;!P.update&&!(N in A)&&(A[N]=this.getProperty(N))}}return oa(this.getContext())}}allowCreate(m,A){if(this.isCollection){let I=Tf(m);if(I?.insert){let y=I.attribute_permissions;if(y?.length>0){let O=BP(y,"insert");for(let P in A)if(!O[P])return!1;return oa(this.getContext())}else return oa(this.getContext())}}else return this.allowUpdate(m,{})}allowDelete(m){return Tf(m)?.delete&&oa(this.getContext())}update(m,A){if(!Gr(this.getContext()))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let y;return typeof m=="object"&&m&&(A?(Object.isFrozen(m)&&(m={...m}),this.#e={},this.#t=m):(y=this.#t,y&&(m=Object.assign(y,m)),this.#t=m)),this._writeUpdate(this.#t,A),this}addTo(m,A){if(typeof A=="number"||typeof A=="bigint")this.#s===zj?this.set(m,(+this.getProperty(m)||0)+A):(this.#s||this.update(),this.set(m,new kE(A)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,A){if(typeof A=="number")return this.addTo(m,-A);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#r}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(m){this.#t=m}setRecord(m){this.#e=m}invalidate(){this._writeInvalidate()}_writeInvalidate(m,A){let I=this.getContext(),y=this.getId();Cr(y),Gr(this.getContext()).addWrite({key:y,store:i,invalidated:!0,entry:this.#r,before:Pe.invalidate?.bind(this,I,y),beforeIntermediate:he.invalidate?.bind(this,I,y),commit:a((P,N)=>{if(!(ia(P,N,A?.nodeId)<=0)){m??=null;for(let L in r)m||(m={}),m[L]===void 0&&(m[L]=this.getProperty(L));Ue.default.trace?.(`Invalidating entry id: ${y}, timestamp: ${new Date(P).toISOString()}`),T(y,m,this.#r,P,mn,g,{user:I?.user,residencyId:A?.residencyId,nodeId:A?.nodeId},"invalidate")}},"commit")})}_writeRelocate(m){let A=this.getContext(),I=this.getId();Cr(I),Gr(this.getContext()).addWrite({key:I,store:i,invalidated:!0,entry:this.#r,before:Pe.relocate?.bind(this,A,I),beforeIntermediate:he.relocate?.bind(this,A,I),commit:a((O,P)=>{if(ia(O,P,m?.nodeId)<=0)return;let N=Ie.getResidencyRecord(m.residencyId),L=0,k=null,D=P?.value;if(N&&!N.includes(server.hostname)){for(let B in r)k||(k={}),k[B]=D(B);L=mn}else k=D;Ue.default.trace?.(`Relocating entry id: ${I}, timestamp: ${new Date(O).toISOString()}`),T(I,k,this.#r,O,L,g,{user:A.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(m,A){let I={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},y=Ac(this.getResidency(A.value,I)),O;if(y){if(!y.includes(server.hostname))return;O=Rc(y)}let N=T(m.key,A.value,m,m.version,0,!0,{residencyId:O,expiresAt:A.expiresAt},"relocate",!1,null)}static evict(m,A,I){let y=this.Source,O;if(!((v||g)&&(!A||(O=i.getEntry(m),!O||!A)||O.version!==I))){if(v){if(i.hasLock(m,O.version))return;let P;for(let N in r)P||(P={}),P[N]=A[N];if(P)return T(m,P,O,I,ma,null,null,null,!0)}if(i.ifVersion(m,I,()=>{ln(m,A,null)}),g)return T(m,null,O,I,ma,null,null,null,!0);Hc(i,O??i.getEntry(m),I)}}lock(){throw new Error("Not yet implemented")}static operation(m,A){return m.table||=s,m.schema||=c,rJ.operation(m,A)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,A,I){let y=this.getContext(),O=Gr(y),P=this.getId();Cr(P);let N=this.#r;this.#s=A?zj:dAe;let L={key:P,store:i,entry:N,nodeName:y?.nodeName,validate:a(k=>{m||(m=this.#t),A||m&&BE(this.#t===m?this:m)?y?.source||(O.checkOverloaded(),this.validate(m,!A),Z&&(m[Z.name]=Z.type==="Date"?new Date(k):Z.type==="String"?new Date(k).toISOString():k),A&&(t&&m[t]!==P&&(m[t]=P),Y&&(N?.value?m[Y.name]=N?.value[Y.name]:m[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),m=sl(m))):O.removeWrite(L)},"validate"),before:A?Pe.put?()=>Pe.put(y,P,m):null:Pe.patch?()=>Pe.patch(y,P,m):Pe.put?()=>Pe.put(y,P,sl(this)):null,beforeIntermediate:A?he.put?()=>he.put(y,P,m):null:he.patch?()=>he.patch(y,P,m):he.put?()=>he.put(y,P,sl(this)):null,commit:a((k,D,B)=>{if(B){if(y&&D?.version>(y.lastModified||0)&&(y.lastModified=D.version),this.#r=D,D?.value&&D.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");A||(this.#e=D?.value??null)}this.#t=void 0,this.#n=k;let $=D?.value,j=m;this.#s=0;let oe=!1,U=ia(k,D,I?.nodeId),ue;if(U<=0)if(g){let _e=D.localTime,Ee=D.version;Ue.default.trace?.("Applying CRDT update to record with id: ",P,"applying later update:",Ee);let Se=[];for(;_e>k||Ee>=k&&_e>0;){let tt=l.get(_e);if(!tt)break;let Ye=It(tt);if(Ee=Ye.version,Ee>=k){if(Ee===k){if(U=ia(k,{version:Ee,localTime:_e},I?.nodeId),U===0)return;if(U>0)continue}if(Ye.type==="patch")Se.push(Ye),ue=m;else if(Ye.type==="put"||Ye.type==="delete")return}_e=Ye.previousLocalTime}Se.sort((tt,Ye)=>tt.version-Ye.version);for(let tt of Se){let Ye=tt.getValue(i);if(j=UE(j,Ye,A),Ue.default.debug?.("Rebuilding update with future patch:",j),!j)return}}else{if(A)return;j=UE(j,$,A),Ue.default.debug?.("Rebuilding update without audit:",j)}let ce;if(A?ce=j:(this.#e=$,ce=sl(this,j)),this.#e=ce,ce&&ce.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let fe;if(I?.residencyId!=null)fe=I.residencyId;else{N?.residencyId&&(y.previousResidency=Ie.getResidencyRecord(N.residencyId));let _e=Ac(Ie.getResidency(ce,y));if(_e&&!_e.includes(server.hostname))if(ue??=ce,oe=!0,Ie.getResidencyById)ce=void 0;else{ce=null;for(let Ee in r)ce||(ce={}),ce[Ee]=ue[Ee]}fe=Rc(_e)}A||(ue=m);let te=y?.expiresAt??(h?h+Date.now():-1);Ue.default.trace?.(`Saving record with id: ${P}, timestamp: ${new Date(k).toISOString()}${te?", expires at: "+new Date(te).toISOString():""}${D?", replaces entry from: "+new Date(D.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(ce).slice(0,100)}catch{return""}})()),ln(P,$,ce);let W=A?"put":"patch";T(P,ce,D,k,oe?mn:0,g,{omitLocalRecord:oe,user:y?.user,residencyId:fe,expiresAt:te,nodeId:I?.nodeId,originatingOperation:y?.originatingOperation},W,!1,ue),y.expiresAt&&aa()},"commit")};O.addWrite(L)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this.isCollection){for await(let A of this.search(m))(await Ie.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this.#e?this._writeDelete(m):!1}_writeDelete(m){let A=Gr(this.getContext()),I=this.getId();Cr(I);let y=this.getContext();return A.addWrite({key:I,store:i,entry:this.#r,nodeName:y?.nodeName,before:Pe.delete?.bind(this,y,I),beforeIntermediate:he.delete?.bind(this,y,I),commit:a((O,P,N)=>{let L=P?.value;N&&(y&&P?.version>(y.lastModified||0)&&(y.lastModified=P.version),Ie._updateResource(this,P)),!(ia(O,P,m?.nodeId)<=0)&&(ln(this.getId(),L),Ue.default.trace?.(`Deleting record with id: ${I}, txn timestamp: ${new Date(O).toISOString()}`),g||R?(T(I,null,this.#r,O,0,g,{user:y?.user,nodeId:m?.nodeId},"delete"),g||aa()):Hc(i,P))},"commit")}),!0}search(m){let A=this.getContext(),I=Gr(A);if(!m)throw new Error("No query provided");let y=m.conditions;y?y.length===void 0&&(y=y[Symbol.iterator]?Array.from(y):[y]):y=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this.getId()&&(y=[{attribute:null,comparator:Array.isArray(this.getId())?"prefix":"starts_with",value:this.getId()}].concat(y));let O,P={};function N(W,_e){let Ee;switch(_e){case"and":case void 0:if(W.length<1)throw new Error('An "and" operator requires at least one condition');Ee=!0;break;case"or":if(W.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+_e)}for(let Se of W){if(Se.conditions){Se.conditions=N(Se.conditions,Se.operator);continue}let tt=Se[0]??Se.attribute,Ye=tt==null?F:bi(E,tt);if(Ye)(Ye.type||pR[Se.comparator])&&(Se[1]===void 0?Se.value=k(Se.value,Ye):Se[1]=k(Se[1],Ye));else if(tt!=null)throw(0,Ir.handleHDBError)(new Error,`${tt} is not a defined attribute`,404);if(Se.chainedConditions)if(Se.chainedConditions.length===1&&(!Se.operator||Se.operator=="and")){let mr=Se.chainedConditions[0],ge,Qe;if(mr.comparator==="gt"||mr.comparator==="greater_than"||mr.comparator==="ge"||mr.comparator==="greater_than_equal"?(ge=Se,Qe=mr):(ge=mr,Qe=Se),ge.comparator!=="lt"&&ge.comparator!=="less_than"&&ge.comparator!=="le"&&ge.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let st=Qe.comparator==="ge"||Qe.comparator==="greater_than_equal",Vt=ge.comparator==="le"||ge.comparator==="less_than_equal";Se.comparator=(st?"ge":"gt")+(Vt?"le":"lt"),Se.value=[Qe.value,ge.value]}else throw new Error("Multiple chained conditions are not currently supported")}return W}a(N,"prepareConditions");function L(W,_e){if(m.enforceExecutionOrder)return W;for(let Ee of W)Ee.conditions&&(Ee.conditions=L(Ee.conditions,Ee.operator));return W.length>1&&_e!=="or"?(0,eJ.sortBy)(W,bm(Ie)):W}a(L,"orderConditions");function k(W,_e){return Array.isArray(W)?W.map(Ee=>hA(Ee,_e)):hA(W,_e)}a(k,"coerceTypedValues");let D=m.operator;(y.length>0||D)&&(y=N(y,D));let B=typeof m.sort=="object"&&m.sort,$;if(B&&D!=="or"){let W=B.attribute;if(W==null)throw new Ir.ClientError("Sort requires an attribute");if(O=y.find(_e=>gu(_e.attribute)===gu(W)),!O){let _e=bi(E,W);if(!_e)throw(0,Ir.handleHDBError)(new Error,`${Array.isArray(W)?W.join("."):W} is not a defined attribute`,404);if(_e.indexed)O={attribute:W,comparator:"sort"},y.push(O);else if(y.length===0&&!m.allowFullScan)throw(0,Ir.handleHDBError)(new Error,`${Array.isArray(W)?W.join("."):W} is not indexed and not combined with any other conditions`,404)}O&&(O.descending=!!B.descending)}y=L(y,D),B&&(O&&y[0]===O?B.next&&($={dbOrderedAttribute:B.attribute,attribute:B.next.attribute,descending:B.next.descending,next:B.next.next}):(O&&y.splice(y.indexOf(O),1),$=B));let j=m.select;if(y.length===0&&(y=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:y,operator:D,postOrdering:$,selectApplied:!!j};let oe=I.useReadTxn(),U=hR(y,D,Ie,oe,m,A,(W,_e)=>uu(W,j,A,oe,_e),P),ue=m.ensureLoaded!==!1;$||(U=te(U));let ce=Ie.transformEntryForSelect(j,A,oe,P,ue,!0),fe=Ie.transformToOrderedSelect(U,j,$,oe,A,ce);function te(W){return m.offset||m.limit!==void 0?W.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):W}return a(te,"applyOffset"),$&&(fe=te(fe)),fe.onDone=()=>{fe.onDone=null,I.doneReadTxn()},fe.selectApplied=!0,fe.getColumns=()=>{if(j){let W=[];for(let _e of j)_e==="*"?W.push(...E.map(Ee=>Ee.name)):W.push(_e.name||_e);return W}return E.filter(W=>!W.computed&&!W.relationship).map(W=>W.name)},fe}static transformToOrderedSelect(m,A,I,y,O,P){let N=new Qh;if(I){m=uu(m,A,y,O,null);let L;N.iterate=function(){let D,B=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),$,j=I.dbOrderedAttribute,oe,U,ue=!0;function ce(te){let W=te.next&&ce(te.next),_e=te.descending;return(Ee,Se)=>{let tt=lu(Ee,te.attribute,y),Ye=lu(Se,te.attribute,y),mr=_e?(0,Zl.compareKeys)(Ye,tt):(0,Zl.compareKeys)(tt,Ye);return mr===0?W?.(Ee,Se)||0:mr}}a(ce,"createComparator");let fe=ce(I);return{async next(){let te;if(D)if(te=D.next(),te.done){if($)return N.onDone&&N.onDone(),te}else return{value:await P.call(this,te.value)};L=[],oe&&L.push(oe);do if(te=await B.next(),te.done){if($=!0,L.length)break;return N.onDone&&N.onDone(),te}else{let W=te.value;if(W?.then&&(W=await W),j){let _e=lu(W,j,y);if(ue)ue=!1,U=_e;else if(_e!==U){U=_e,oe=W;break}}L.push(W)}while(!0);return I.isGrouped,L.sort(fe),D=L[Symbol.iterator](),te=D.next(),te.done?(N.onDone&&N.onDone(),te):{value:await P.call(this,te.value)}},return(){N.onDone&&N.onDone(),B.return()},throw(){N.onDone&&N.onDone(),B.throw()}}};let k=a(D=>{if(typeof A=="object"&&Array.isArray(D.attribute))for(let B=0;B<A.length;B++){let $=A[B],j;if($.name===D.attribute[0]){for(j=$.sort||($.sort={});j.next;)j=j.next;j.attribute=D.attribute.slice(1),j.descending=D.descending}else $===D.attribute[0]&&(A[B]=j={name:$,sort:{attribute:D.attribute.slice(1),descending:D.descending}})}D.next&&k(D.next)},"applySortingOnSelect");k(I)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(function(L){try{let k=P.call(this,L);return typeof k?.catch=="function"?k.catch(D=>{throw D.partialObject={[t]:L.key},D}):k}catch(k){throw k.partialObject={[t]:L.key},k}});return N}static transformEntryForSelect(m,A,I,y,O,P){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let D=a(B=>(A?.transaction?.stale&&(A.transaction.stale=!1),B?.key??B),"transform");return m===t?D:m.asArray?B=>[D(B)]:B=>({[t]:D(B)})}let N;O&&v&&!(typeof m=="string"?[m]:m)?.every(D=>{let B;return typeof D=="object"?B=D.name:B=D,r[B]||B===t})&&(N=!0);let L,k=a(function(D){let B;if(A?.transaction?.stale&&(A.transaction.stale=!1),D!=null){if(B=D.value||D.deref?.()?.value,!B&&(D.key===void 0||D.deref)||D.metadataFlags&mn){if(D.metadataFlags&mn&&A.replicateFrom===!1&&P&&D.residencyId)return mc.SKIP;if(D=cu(D.key??D,A,{transaction:I,lazy:m?.length<4,ensureLoaded:O},this?.isSync,$=>$),D?.then)return D.then(k.bind(this));B=D?.value}if(N&&D?.metadataFlags&(mn|ma)||D?.expiresAt!=null&&D?.expiresAt<Date.now()){if(A.onlyIfCached&&A.noCacheStore)return{[t]:D.key,message:"This entry has expired"};let $=un(D.key??D,D,A);if($?.then)return $.then(k)}}if(B==null)return P?mc.SKIP:B;if(m&&!(m[0]==="*"&&m.length===1)){let $,j=a((U,ue)=>{let ce;typeof U=="object"?ce=U.name:ce=U;let fe=Un?.[ce],te;if(fe){let W=y?.[ce];if(W)if(W.hasMappings){let Ee=fe.from?B[fe.from]:gu(D.key);te=W.get(Ee),te||(te=[])}else te=W.fromRecord?.(B);else te=fe(B,A,D);let _e=a(Ee=>{if(Ee&&typeof Ee=="object"){let Se=fe.definition?.tableClass||Ie;L||(L={});let tt=L[ce]||(L[ce]=Se.transformEntryForSelect(ce===U?null:U.select||(Array.isArray(U)?U:null),A,I,W,O));if(Array.isArray(Ee)){let Ye=[],mr=Se.transformToOrderedSelect(Ee,U.select,typeof U.sort=="object"&&U.sort,A,I,tt)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),ge=a(st=>{for(;!st.done;){if(st?.then)return st.then(ge);Ye.push(st.value),st=mr.next()}ue(Ye,ce)},"nextValue"),Qe=ge(mr.next());Qe&&($||($=[]),$.push(Qe));return}else if(Ee=tt.call(this,Ee),Ee?.then){$||($=[]),$.push(Ee.then(Ye=>ue(Ye,ce)));return}}ue(Ee,ce)},"handleResolvedValue");te?.then?($||($=[]),$.push(te.then(_e))):_e(te);return}else te=B[ce],te&&typeof te=="object"&&ce!==U&&(te=Ie.transformEntryForSelect(U.select||U,A,I,null)({value:te}));ue(te,ce)},"selectAttribute"),oe;if(typeof m=="string")j(m,U=>{oe=U});else if(Array.isArray(m))if(m.asArray)oe=[],m.forEach((U,ue)=>{U==="*"?m[ue]=B:j(U,ce=>oe[ue]=ce)});else{oe={};let U=m.forceNulls;for(let ue of m)if(ue==="*")for(let ce in B)oe[ce]=B[ce];else j(ue,(ce,fe)=>{ce===void 0&&U&&(ce=null),oe[fe]=ce})}else throw new Ir.ClientError("Invalid select"+m);return $?Promise.all($).then(()=>oe):oe}return B},"transform");return k}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||ft({table:s,database:c,schemaDefined:u,attributes:E,audit:!0}),m||(m={});let A=!m.rawEvents,I=[],y=this,O=xP(Ie,this.getId()??null,function(N,L,k,D){try{let B=L.getValue?.(i,A),$=L.type;if(!B&&$==="patch"&&A){let oe=i.getEntry(N);oe?.version===L.version?B=oe.value:B=L.getValue?.(i,!0,k),$="put"}let j={id:N,localTime:k,value:B,version:L.version,type:$,beginTxn:D};I?I.push(j):this.send(j)}catch(B){Ue.default.error?.(B)}},m.startTime||0,m),P=(async()=>{this.isCollection&&(O.includeDescendants=!0,m.onlyChildren&&(O.onlyChildren=!0)),m.supportsTransactions&&(O.supportsTransactions=!0);let N=this.getId(),L=m.previousCount;L>1e3&&(L=1e3);let k=m.startTime;if(this.isCollection){if(k){if(L)throw new Ir.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:D,value:B}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let $=It(B);if($.tableId!==n)continue;let j=$.recordId;if(N==null||Xj(N,j)){let oe=$.getValue(i,A,D);if(O.send({id:j,localTime:D,value:oe,version:$.version,type:$.type}),O.queue?.length>Jj&&await O.waitForDrain()===!1)return}O.startTime=D}}else if(L){let D=[];for(let{key:B,value:$}of l.getRange({start:"z",end:!1,reverse:!0}))try{let j=It($);if(j.tableId!==n)continue;let oe=j.recordId;if(N==null||Xj(N,oe)){let U=j.getValue(i,A,B);if(D.push({id:oe,localTime:B,value:U,version:j.version,type:j.type}),--L<=0)break}}catch(j){Ue.default.error("Error getting history entry",B,j)}for(let B=D.length;B>0;)O.send(D[--B]);D[0]&&(O.startTime=D[0].localTime)}else if(!m.omitCurrent){for(let{key:D,value:B,version:$,localTime:j}of i.getRange({start:N??!1,end:N==null?void 0:[N,Zl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(B&&(O.send({id:D,localTime:j,value:B,version:$,type:"put"}),O.queue?.length>Jj&&await O.waitForDrain()===!1))return}}else{L&&!k&&(k=0);let D=this.#r?.localTime;if(D===JR&&(i.cache?.delete(N),this.#r=i.getEntry(N),Ue.default.trace?.("re-retrieved record",D,this.#r?.localTime),D=this.#r?.localTime),Ue.default.trace?.("Subscription from",k,"from",N,D),k<D){let B=[],$=D;do{let j=l.get($);if(j){m.omitCurrent=!0;let oe=It(j),U=oe.getValue(i,A,$);A&&(oe.type="put"),B.push({id:N,value:U,localTime:$,...oe}),$=oe.previousLocalTime}else break;L&&L--}while($>k&&L!==0);for(let j=B.length;j>0;)O.send(B[--j]);O.startTime=D}!m.omitCurrent&&this.doesExist()&&O.send({id:N,localTime:D,value:this.#e,version:this.#n,type:"put"})}for(let D of I)O.send(D);I=null})();return m.listener&&O.on("data",m.listener),O}static subscribeOnThisThread(m,A){return m===0||A?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(m,A){this._writePublish(m,A)}_writePublish(m,A){let I=Gr(this.getContext()),y=this.getId()||null;y!=null&&Cr(y);let O=this.getContext();I.addWrite({key:y,store:i,entry:this.#r,nodeName:O?.nodeName,validate:a(()=>{O?.source||(I.checkOverloaded(),this.validate(m))},"validate"),before:Pe.publish?.bind(this,O,y,m),beforeIntermediate:he.publish?.bind(this,O,y,m),commit:a((P,N,L)=>{N===void 0&&R&&!g&&aa(),Ue.default.trace?.(`Publishing message to id: ${y}, timestamp: ${new Date(P).toISOString()}`),T(y,N?.value??null,N,N?.version||P,0,!0,{user:O?.user,residencyId:A?.residencyId,expiresAt:O?.expiresAt,nodeId:A?.nodeId},"message",!1,m)},"commit")})}validate(m,A){let I,y=a((O,P,N)=>{if(P.type&&O!=null)if(A&&O.__op__&&(O=O.value),P.properties){typeof O!="object"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an object${P.type?" ("+P.type+")":""}`);let L=P.properties;for(let k=0,D=L.length;k<D;k++){let B=L[k],$=y(O[B.name],B,N+"."+B.name);$&&(O[B.name]=$)}if(P.sealed&&O!=null&&typeof O=="object")for(let k in O)L.find(D=>D.name===k)||(I||(I=[])).push(`Property ${k} is not allowed within object in property ${N}`)}else switch(P.type){case"Int":(typeof O!="number"||O>>0!==O)&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof O!="number"||!(Math.floor(O)===O&&Math.abs(O)<=9007199254740992))&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof O!="number"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a number`);break;case"ID":typeof O=="string"||O?.length>0&&O.every?.(L=>typeof L=="string")||(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof O!="string"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a string`);break;case"Boolean":typeof O!="boolean"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a boolean`);break;case"Date":if(!(O instanceof Date)){if(typeof O=="string"||typeof O=="number")return new Date(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof O!="bigint"){if(typeof O=="string"||typeof O=="number")return BigInt(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a bigint`)}break;case"Bytes":if(!(O instanceof Uint8Array)){if(typeof O=="string")return Buffer.from(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(O instanceof wi)){if(typeof O=="string"&&(O=Buffer.from(O)),O instanceof Buffer)return createBlob(O,{type:"text/plain"});(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Blob`)}break;case"array":if(Array.isArray(O)){if(P.elements)for(let L=0,k=O.length;L<k;L++){let D=O[L],B=y(D,P.elements,N+"[*]");B&&(O[L]=B)}}else(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an Array`);break}P.nullable===!1&&O==null&&(I||(I=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let O=0,P=E.length;O<P;O++){let N=E[O];if(!(N.relationship||N.computed)&&(!A||N.name in m)){let L=y(m[N.name],N,N.name);L&&(m[N.name]=L)}}if(d)for(let O in m)E.find(P=>P.name===O)||(I||(I=[])).push(`Property ${O} is not allowed`);if(I)throw new Ir.ClientError(I.join(". "))}getUpdatedTime(){return this.#n}wasLoadedFromSource(){return v?!!this.#i:void 0}static async addAttributes(m){let A=E.slice(0);for(let I of m){if(!I.name)throw new Ir.ClientError("Attribute name is required");if(I.name.match(/[`/]/))throw new Ir.ClientError("Attribute names cannot include backticks or forward slashes");(0,tJ.validateAttribute)(I.name),A.push(I)}return ft({table:s,database:c,schemaDefined:u,attributes:A}),Ie.indexingOperation}static async removeAttributes(m){let A=E.filter(I=>!m.includes(I.name));return ft({table:s,database:c,schemaDefined:u,attributes:A}),Ie.indexingOperation}static getSize(){let m=i.getStats();return(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getAuditSize(){let m=l?.getStats();return m&&(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getStorageStats(){let m=i.env.path,A=pA.default.statfsSync?.(m)??{};return{available:A.bavail*A.bsize,free:A.bfree*A.bsize,size:A.blocks*A.bsize}}static async getRecordCount(m){let A=i.getStats().entryCount,I=1e3/2,y=performance.now(),O=Math.floor(A/2),P=m?.exactCount,N=0,L=0,k;for(let{value:D}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(D!=null&&N++,L++,await hc(),!P&&L<O&&performance.now()-y>I){k=L;break}if(k){let D=N;N=0;for(let{value:te}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k,snapshot:!1}))te!=null&&N++,await hc();let B=k*2,$=(N+D)/B,j=Math.pow((N-D+1)/k/2,2)+$*(1-$)/B,oe=Math.max(Math.sqrt(j)*A,1),U=Math.round($*A),ue=Math.max(U-1.96*oe,N+D),ce=Math.min(U+1.96*oe,A),fe=Math.pow(10,Math.round(Math.log10(oe)));return fe>U&&(fe=fe/10),N=Math.round(U/fe)*fe,{recordCount:N,estimatedRange:[Math.round(ue),Math.round(ce)]}}return{recordCount:N}}static updatedAttributes(){Un=this.propertyResolvers={$id:a((m,A,I)=>({value:I.key}),"$id"),$updatedtime:a((m,A,I)=>I.version,"$updatedtime"),$record:a((m,A,I)=>I?{value:m}:m,"$record")};for(let m of this.attributes){m.resolve=null;let A=m.relationship,I=m.computed;if(A)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),I&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),ou=!0,A.to)m.elements?.definition?(Un[m.name]=m.resolve=(y,O,P)=>{let N=y[A.from?A.from:t],L=m.elements.definition.tableClass;return P?Eu({attribute:A.to,value:N},Gr(O).getReadTxn(),!1,L,!1).asArray:L.search([{attribute:A.to,value:N}],O).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,A.from&&(m.resolve.from=A.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(A.from){let y=m.definition||m.elements?.definition;y?(Un[m.name]=m.resolve=(O,P,N)=>{let L=O[A.from];if(L!==void 0){if(m.elements){let k,D=L?.map(B=>{let $=N?y.tableClass.primaryStore.getEntry(B,{transaction:Gr(P).getReadTxn()}):y.tableClass.get(B,P);return $?.then&&(k=!0),$});return A.filterMissing?k?Promise.all(D).then(B=>B.filter(Zj)):D.filter(Zj):k?Promise.all(D):D}return N?y.tableClass.primaryStore.getEntry(L,{transaction:Gr(P).getReadTxn()}):y.tableClass.get(L,P)}},m.set=(O,P)=>{if(Array.isArray(P)){let N=P.map(L=>L.getId?.()||L[y.tableClass.primaryKey]);O[A.from]=N}else{let N=P.getId?.()||P[y.tableClass.primaryKey];O[A.from]=N}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=A.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else I&&(typeof I.from=="function"&&this.setComputedAttribute(m.name,I.from),Un[m.name]=m.resolve=(y,O,P)=>{let N=typeof I.from=="string"?y[I.from]:y,L=this.userResolvers[m.name];if(L)return L(N,O,P);Ue.default.warn(`Computed attribute "${m.name}" does not have a function assigned to it. Please use setComputedAttribute('${m.name}', resolver) to assign a resolver function.`),this.userResolvers[m.name]=()=>{}})}FE(this,this)}static setComputedAttribute(m,A){let I=bi(E,m);if(!I){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!I.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=A}static async deleteHistory(m=0,A=!1){let I;for(let{key:y,value:O}of l.getRange({start:0,end:m}))await hc(),It(O).tableId===n&&(I=fA(l,y,O));if(A)for(let y of i.getRange({start:0,versions:!0})){let{key:O,value:P,localTime:N}=y;await hc(),P===null&&N<m&&(I=Hc(i,y))}await I}static async*getHistory(m=0,A=1/0){for(let{key:I,value:y}of l.getRange({start:m||1,end:A})){await hc();let O=It(y);O.tableId===n&&(yield{id:O.recordId,localTime:I,version:O.version,type:O.type,value:O.getValue(i,!0,I),user:O.user,operation:O.originatingOperation})}}static async getHistoryOfRecord(m){let A=[];if(m==null)throw new Error("An id is required");let I=i.getEntry(m);if(!I)return A;let y=I.localTime;if(!y)throw new Error("The entry does not have a local audit time");let O=0;do{await hc();let P=l.get(y);if(P){let N=It(P);A.push({id:N.recordId,localTime:y,version:N.version,type:N.type,value:N.getValue(i,!0,y),user:N.user}),y=N.previousLocalTime}else break}while(O<1e3&&y);return A.reverse()}static cleanup(){Q?.remove()}}Ie.updatedAttributes();let Sf=Ie.prototype;return h&&Ie.setTTLExpiration(h/1e3),se&&du(),Ie;function ln(V,m,A){let I;for(let y in r){let O=r[y],P=O.isIndexing,N=Un[y],L=A&&(N?N(A):A[y]),k=m&&(N?N(m):m[y]);if(L===k&&!P)continue;I=!0;let D=O.indexNulls,B=(0,vh.getIndexedValues)(L,D),$=(0,vh.getIndexedValues)(k,D);if($?.length>0){let j=new Set($);if(B=B?B.filter(oe=>{if(j.has(oe))j.delete(oe);else return!0}):[],$=Array.from(j),($.length>0||B.length>0)&&Wj){let oe=$.concat(B).map(U=>({key:U,value:V}));O.prefetch(oe,Qj)}for(let oe=0,U=$.length;oe<U;oe++)O.remove($[oe],V)}else B?.length>0&&Wj&&O.prefetch(B.map(j=>({key:j,value:V})),Qj);if(B)for(let j=0,oe=B.length;j<oe;j++)O.put(B[j],V)}return I}a(ln,"updateIndices");function Cr(V){switch(typeof V){case"number":return!0;case"string":if(V.length<659)return!0;if(V.length>jj)throw new Error("Primary key size is too large: "+V.length);break;case"object":if(V===null)throw new Error("Invalid primary key of null");break;case"bigint":if(V<2n**64n&&V>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof V)}if((0,Zl.writeKey)(V,fAe,0)>jj)throw new Error("Primary key size is too large: "+V.length);return!0}a(Cr,"checkValidId");function cu(V,m,A,I,y){if(Ie.getResidencyById&&A.ensureLoaded&&m?.replicateFrom!==!1){let P=Ac(Ie.getResidencyById(V));if(P&&!P.includes(server.hostname)&&b)return b({key:V,residency:P}).then(y)}let O=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),A.transaction?.isDone)return y(null,V);let P=i.getEntry(V,A);return P?.residencyId&&P.metadataFlags&mn&&b&&A.ensureLoaded&&m?.replicateFrom!==!1?b(P).then(N=>y(N,V),N=>(Ue.default.error?.("Error loading remote record",V,P,A,N),y(null,V))):(P&&m&&(P?.version>(m.lastModified||0)&&(m.lastModified=P.version),P?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=P.localTime)),y(P,V))},"whenPrefetched");return I?O():me>0?(me--,O()):new Promise((P,N)=>{me===0?(me--,i.prefetch([V],()=>{L(),k()})):(ne.push(V),J.push(k),ne.length>Xh&&(me--,L()));function L(){if(ne.length>0){let D=J;i.prefetch(ne,()=>{me===-1?L():me++;for(let B of D)B()}),ne=[],J=[],ye>2&&ye--}else me=ye,ye<gf&&ye++}a(L,"prefetch");function k(){try{P(O())}catch(D){N(D)}}a(k,"load")})}a(cu,"loadLocalRecord");function Tf(V){if(!V?.role)return;let m=V.role.permission;if(m.super_user)return _Ae;let A=m[c],I,y=A?.tables;if(y)return y[s];if(c==="data"&&(I=m[s])&&!I.tables)return I}a(Tf,"getTablePermissions");function un(V,m,A,I){if(v){let y=!1;if(A.noCache?y=!0:(m?(!m.value||m.metadataFlags&(mn|ma)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(y=!0):y=!0,Qn(!y,"cache-hit",s)),y){let O=Zh(V,m,A).then(P=>(P?.value&&P?.value.getRecord?.()&&Ue.default.error?.("Can not assign a record that is already a resource"),A&&(P?.version>(A.lastModified||0)&&(A.lastModified=P.version),A.lastRefreshed=Date.now()),P));if(A?.onlyIfCached||m?.value&&I?.allowStaleWhileRevalidate?.(m,V)){if(O.catch(P=>Ue.default.warn?.(P)),A?.onlyIfCached&&!I.doesExist())throw new Ir.ServerError("Entry is not cached",504);return}else return O}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return Ie.evict(m.key,m.value,m.version),m.value=null,{then(y){return y(m)}}}a(un,"ensureLoadedFromSource");function Gr(V){let m=V?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let A=m.next;if(!A)return m=m.next=new wc,m.lmdbDb=i,m;m=A}while(!0)}else return new Am}a(Gr,"txnForContext");function lu(V,m,A){if(!V)return;let I=V.value||i.getEntry(V.key)?.value;if(typeof m=="object"){let O=Un,P=I;for(let N=0,L=m.length;N<L;N++){let k=m[N],D=O?.[k];P=D&&P?D(P,A,!0)?.value:P?.[k],O=D?.definition?.tableClass?.propertyResolvers}return P}let y=Un[m];return y?y(I,A):I[m]}a(lu,"getAttributeValue");function uu(V,m,A,I,y){let O=y?.length,P={transaction:I,lazy:O>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function L(k,D){let B=k?.value;if(!B)return mc.SKIP;for(let $=0;$<O;$++)if(!N?.includes($)&&!y[$](B,k))return mc.SKIP;return D!==void 0&&(k.key=D),k}if(a(L,"processEntry"),O>0||!V.hasEntries){let k=V.map(D=>{if(N=null,typeof D=="object"&&D?.key!==void 0)return O>0?L(D):D;if(D==null)return mc.SKIP;for(let B=0;B<O;B++){let j=y[B].idFilter;if(j){if(!j(D))return mc.SKIP;N||(N=[]),N.push(B)}}return cu(D,A,P,!1,L)});return Array.isArray(V)&&(k=k.filter(D=>D!==mc.SKIP)),k.hasEntries=!0,k}return V}a(uu,"transformToEntries");function ia(V,m,A=server.replication?.getThisNodeId(l)){if(V<=m?.version){if(m?.version===V&&A!==void 0){let I=server.replication?.exportIdMapping(l),y=m.localTime,O=y&&l.get(y);if(O){let P,N,L=It(O);for(let k in I)I[k]===A&&(P=k),I[k]===L.nodeId&&(N=k);if(P>N)return 1;if(P===N)return 0}}return-1}return 1}a(ia,"precedesExistingVersion");async function Zh(V,m,A){let I=m?.metadataFlags,y=m?.version,O,P;if(!i.attemptLock(V,y,()=>{clearTimeout(P);let D=i.getEntry(V);!D||!D.value||D.metadataFlags&(mn|ma)?O(Zh(V,i.getEntry(V),A)):O(D)}))return new Promise(D=>{O=D,P=setTimeout(()=>{i.unlock(V,y)},uAe)});let N=m?.value,L={requestContext:A,replacingRecord:N,replacingEntry:m,replacingVersion:y,noCacheStore:!1,source:null,resourceCache:A?.resourceCache},k=A?.responseHeaders;return new Promise((D,B)=>{let $;HP(wt(L,async j=>{let oe=performance.now(),U,ue,ce;try{for(let _e of Ie.sources)if(_e.get&&(!_e.get.reliesOnPrototype||_e.prototype.get)){if(_e.available?.(m)===!1)continue;if(L.source=_e,U=await _e.get(V,L),U)break}ce=I&mn;let te=L.lastModified||ce&&y;ue=ce||te>y||!N,te||(te=(0,vh.getNextMonotonicTime)());let W=performance.now()-oe;if(sr(W,"cache-resolution",s,null,"success"),k&&ZE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),j.timestamp=te,h&&L.expiresAt==null&&(L.expiresAt=Date.now()+h),U){if(typeof U!="object")throw new Error("Only objects can be cached and stored in tables");if(U.status>0&&U.headers)if(U.status>=300)if(U.status===304)U=N,te=y;else throw new Ir.ServerError(U.body||"Error from source",U.status);else U=U.body;typeof U.toJSON=="function"&&(U=U.toJSON()),t&&U[t]!==V&&(U[t]=V)}$=!0,D({key:V,version:te,value:U})}catch(te){te.message+=` while resolving record ${V} for ${s}`,N&&((te.code==="ECONNRESET"||te.code==="ECONNREFUSED"||te.code==="EAI_AGAIN")&&!A?.mustRevalidate||A?.staleIfError&&(te.statusCode===500||te.statusCode===502||te.statusCode===503||te.statusCode===504))?(D({key:V,version:y,value:N}),Ue.default.trace?.(te.message,"(returned stale record)")):B(te);let W=performance.now()-oe;sr(W,"cache-resolution",s,null,"fail"),k&&ZE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),L.transaction.abort();return}if(A?.noCacheStore||L.noCacheStore){L.transaction.abort();return}Gr(L).addWrite({key:V,store:i,entry:m,nodeName:"source",commit:a((te,W)=>{if(W?.version!==y)return;let _e=ln(V,N,U);if(U){he.put?.(L,V,U),W&&(A.previousResidency=Ie.getResidencyRecord(W.residencyId));let Ee,Se=!1,tt,Ye=Ac(Ie.getResidency(U,A));if(Ye){if(!Ye.includes(server.hostname))if(Ee=U,Se=!0,Ie.getResidencyById)U=void 0;else{U=null;for(let mr in r)U||(U={}),U[mr]=Ee[mr]}tt=Rc(Ye)}Ue.default.trace?.(`Writing resolved record from source with id: ${V}, timestamp: ${new Date(te).toISOString()}`),T(V,U,W,te,Se?mn:0,g&&(ue||Se)||null,{user:L?.user,expiresAt:L.expiresAt,residencyId:tt},"put",!!ce,Ee)}else W&&(he.delete?.(L,V),Ue.default.trace?.(`Deleting resolved record from source with id: ${V}, timestamp: ${new Date(te).toISOString()}`),g||R?T(V,null,W,te,0,g&&ue||null,{user:L?.user},"delete",!!ce):Hc(i,W,y))},"commit")})}),()=>{i.unlock(V,y)},j=>{i.unlock(V,y),$&&Ue.default.error?.("Error committing cache update",j)})})}a(Zh,"getFromSource");function oa(V){if(!V||V.user?.role?.permission?.super_user)return!0;if(V.replicateTo)throw new Ir.ClientError("Can not specify replication parameters without super user permissions",403);if(V.replicatedConfirmation)throw new Ir.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(oa,"checkContextPermissions");function aa(V){let m=!1;if(V&&(V-dt>1&&(m=!0),dt=V),!(Nt===br&&!m)&&(br=Nt,(0,Ql.getWorkerIndex)()===(0,Ql.getWorkerCount)()-1))return hs&&clearTimeout(hs),Nt?new Promise(A=>{let I=new Date;I.setMonth(0),I.setDate(1),I.setHours(0),I.setMinutes(0),I.setSeconds(0);let y=Nt/(1+dt),O=m?Date.now():Math.ceil((Date.now()-I.getTime())/y)*y+I.getTime(),P=a(N=>{Ue.default.trace?.(`Scheduled next cleanup scan at ${new Date(N)}`),hs=setTimeout(()=>q=q.then(async()=>{if(P(Math.max(N+Nt,Date.now())),i.rootStore.status!=="open"){clearTimeout(hs);return}let L=50,k=new Array(L),D=0,B=Math.pow(dt,8)*(Xl.get(x.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),$=S/Math.pow(Math.max(dt,1),4);Ue.default.info?.(`Starting cleanup scan for ${s}, evict threshold ${B}, adjusted eviction ${$}ms`);function j(oe,U,ue,ce){let fe=oe+$-Date.now();if(fe<0)return!0;if(dt){let te=i.lastSize;return ue&Fn&&yu(ce,W=>{W.size&&(te+=W.size)}),Ue.default.trace?.(`shouldEvict adjusted ${fe} ${te}, ${fe*(oe-U)/te} < ${B}`),fe*(oe-U)/te<B}return!1}a(j,"shouldEvict");try{let oe=0;for(let U of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:ue,value:ce,version:fe,expiresAt:te,metadataFlags:W}=U,_e;ce===null&&!g&&fe+lAe<Date.now()?_e=Hc(i,U,fe):te!=null&&j(te,fe,W,ce)&&(_e=Ie.evict(ue,ce,fe),oe++),_e&&(await k[D],k[D]=_e.catch(Ee=>{Ue.default.error?.("Cleanup error",Ee)}),++D>=L&&(D=0)),await hc()}Ue.default.info?.(`Finished cleanup scan for ${s}, evicted ${oe} entries`)}catch(oe){Ue.default.warn?.(`Error in cleanup scan for ${s}:`,oe)}A(void 0),dt=0}),Math.min(N-Date.now(),2147483647)).unref()},"startNextTimer");P(O)}):void 0}a(aa,"scheduleCleanup");function Af(){Q=l?.addDeleteRemovalCallback(n,i,(V,m)=>{i.remove(V,m)})}a(Af,"addDeleteRemoval");function du(){(0,Ql.getWorkerIndex)()===0&&setInterval(async()=>{if(!au){au=!0;try{let V=se.name,m=r[V];if(!m)throw new Error(`expiresAt attribute ${se} must be indexed`);for(let A of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let I of m.getValues(A)){let y=i.getEntry(I);y?.value?y.value[V]<Date.now()&&Ie.evict(I,y.value,y.version):i.ifVersion(I,y?.version,()=>m.remove(A,I))}await hc()}}catch(V){Ue.default.error?.("Error in evicting old records",V)}finally{au=!1}}},cAe).unref()}a(du,"runRecordExpirationEviction");function Ac(V){if(V!=null){if(Array.isArray(V))return V;if(typeof V=="number"){if(V>=65536)throw new Error(`Shard id ${V} must be below 65536`);let m=server.shards?.get?.(V);if(m)return Ue.default.trace?.(`Shard ${V} mapped to ${m.map(A=>A.name).join(", ")}`),m.map(A=>A.name);throw new Error(`Shard ${V} is not defined`)}throw new Error(`Shard or residency list ${V} is not a valid type, must be a shard number or residency list of node hostnames`)}}a(Ac,"residencyFromFunction");function Rc(V){if(V){let m=V.join(","),A=f.get([Symbol.for("residency_by_set"),m]);return A||(f.put([Symbol.for("residency_by_set"),m],A=Math.floor(Math.random()*2147418112)+65535),f.put([Symbol.for("residency_by_id"),A],V),A)}}a(Rc,"getResidencyId")}function BP(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function Qj(){}function pAe(e){rJ=e}function hA(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return _A(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return _A(+e);case"Float":return e==="null"?null:_A(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;hAe.test(e)||(e+="Z");let n=new Date(e);return _A(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,mA.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function _A(e){if(isNaN(e))throw new SyntaxError;return e}function Xj(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function HP(e,t,r){return e?.then?e.then(t,r):t(e)}function Zj(e){return e!=null}function Fs(e){try{return JSON.stringify(e)}catch{return e}}function mAe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var mc,vh,eJ,tJ,Xl,Ir,Uh,xh,Ue,Zl,Ql,mA,pA,aAe,rJ,cAe,lAe,Wj,uAe,zj,dAe,mn,ma,fAe,jj,Jj,_Ae,axe,hAe,hc,qf=be(()=>{H();mc=require("lmdb"),vh=M(_n()),eJ=require("lodash"),tJ=M(xf());Ea();Rm();Xl=M(ae());AN();Ir=M(pe()),Uh=M(To()),xh=M(ri());De();Gf();Ue=M(Ni());Wb();Ic();Zl=require("ordered-binary"),Ql=M(rt());fo();mA=M(ie());wu();ki();xE();z_();pA=M(require("node:fs"));gs();UT();aAe=new Uint8Array(9);aAe[8]=192;cAe=6e4,lAe=864e5;Xl.initSync();Wj=Xl.get(x.STORAGE_PREFETCHWRITES),uAe=1e4,zj=1,dAe=2,mn=1,ma=8,fAe=Buffer.allocUnsafeSlow(8192),jj=1978,Jj=100,_Ae={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},axe=(0,mA.convertToMS)(Xl.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(EA,"makeTable");a(BP,"attributesAsObject");a(Qj,"noop");a(pAe,"setServerUtilities");hAe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(hA,"coerceType");a(_A,"rejectNaN");a(Xj,"isDescendantId");hc=a(()=>new Promise(setImmediate),"rest");a(HP,"when");a(Zj,"exists");a(Fs,"stringify");a(mAe,"hasOtherProcesses")});var nt={};ve(nt,{database:()=>qu,database_envs:()=>ea,databases:()=>qe,dropDatabase:()=>Xb,dropTableMeta:()=>AAe,getDatabases:()=>Xe,getDefaultCompression:()=>CS,getTables:()=>EAe,onRemovedDB:()=>pp,onUpdatedTable:()=>Tl,readMetaDb:()=>Bh,resetDatabases:()=>Dd,table:()=>ft,tables:()=>Jn});function EAe(){return AA||Xe(),Jn||{}}function Xe(){if(AA)return qe;AA=!0,ff=new Map;let e=(0,Zt.getHdbBasePath)()&&(0,Lt.join)((0,Zt.getHdbBasePath)(),Nc),t=(0,Zt.get)(x.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Zt.get)(x.STORAGE_PATH)||e&&((0,us.existsSync)(e)?e:(0,Lt.join)((0,Zt.getHdbBasePath)(),om)),!e)return;if((0,us.existsSync)(e))for(let n of(0,us.readdirSync)(e,{withFileTypes:!0})){let s=(0,Lt.basename)(n.name,".mdb");n.isFile()&&(0,Lt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&Bh((0,Lt.join)(e,n.name),null,s)}if((0,us.existsSync)((0,df.getBaseSchemaPath)())){for(let n of(0,us.readdirSync)((0,df.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Lt.join)((0,df.getBaseSchemaPath)(),n.name),i=(0,Lt.join)((0,df.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,us.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Lt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Lt.join)(i,o.name);Bh((0,Lt.join)(s,o.name),(0,Lt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,us.existsSync)(i))for(let c of(0,us.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Lt.extname)(c.name).toLowerCase()===".mdb"&&Bh((0,Lt.join)(i,c.name),(0,Lt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Lt.join)(l.path,(0,Lt.basename)(c+".mdb"));(0,us.existsSync)(u)&&Bh(u,c,n,null,!0)}}for(let n in qe){let s=ff.get(n);if(s){let i=qe[n];n.includes("delete")&&qt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(qt.trace(`delete table class ${o}`),delete i[o])}else if(delete qe[n],n==="data"){for(let i in Jn)delete Jn[i];delete Jn[RA]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(qe.system)for(let n of r)qe.system[n]&&(qe.system[n].replicate=!1);return ff=null,qe}function Dd(){AA=!1;for(let[,e]of ea)e.needsDeletion=!0;Xe();for(let[e,t]of ea)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),ea.delete(e),delete qe[t.databaseName],kh.forEach(r=>r(t.databaseName)));return qe}function Bh(e,t,r=GP,n,s){let i=new kP.default(e,!1);try{let o=ea.get(e);o?o.needsDeletion=!1:(o=(0,_f.open)(i),ea.set(e,o));let c=new eu.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(gA.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,us.existsSync)(n)&&(i.path=n,u=(0,_f.open)(i),u.isLegacy=!0):u=dA(o));let f=oJ(r),d=f[RA],p=new Map;for(let{key:_,value:h}of l.getRange({start:!1})){let[S,g]=_.toString().split("/");g===""?g=h.name:g||(g=S,S=t,h.name||(h.name=g,h.indexed=!h.is_hash_attribute)),d?.add(S);let R=p.get(S);R||p.set(S,R={attributes:[]}),(g==null||h.is_hash_attribute)&&(R.primary=h),g!=null&&R.attributes.push(h),Object.defineProperty(h,"key",{value:_,configurable:!0})}for(let[_,h]of p){let{attributes:S,primary:g}=h;if(!g){for(let J of S)if(J.is_hash_attribute||J.isPrimaryKey){g=J;break}if(!g){qt.warn(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(S)}`);continue}}let R=f[_],E={},T=[],b,v,F=typeof g.audit=="boolean"?g.audit:(0,Zt.get)(x.LOGGING_AUDITLOG),q=g.trackDeletes,Y=g.expiration,Z=g.eviction,se=g.sealed,Q=g.splitSegments,ne=g.replicate;if(R)E=R.indices,T=R.attributes,R.schemaVersion++;else{b=g.tableId,b?b>=(l.get(uf)||0)&&(l.putSync(uf,b+1),qt.info(`Updating next table id (it was out of sync) to ${b+1} for ${_}`)):(g.tableId=b=l.get(uf),b||(b=1),qt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(uf,b+1),l.putSync(g.key,g));let J=new eu.default(!g.is_hash_attribute,g.is_hash_attribute);if(J.compression=g.compression,J.compression){let me=(0,Zt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iJ;J.compression.threshold=me}v=Jm(o.openDB(g.key,J),o),o.databaseName=r,v.tableId=b}for(let J of S){J.attribute=J.name;try{if(!J.is_hash_attribute&&(J.indexed||J.attribute&&!J.name)){if(!E[J.name]){let ye=new eu.default(!J.is_hash_attribute,J.is_hash_attribute);E[J.name]=o.openDB(J.key,ye),E[J.name].indexNulls=J.indexNulls}let me=T.find(ye=>ye.name===J.name);me?T.splice(T.indexOf(me),1,J):T.push(J)}}catch(me){qt.error("Error trying to update attribute",J,T,E,me)}}if(!R){R=aJ(f,_,EA({primaryStore:v,auditStore:u,audit:F,sealed:se,splitSegments:Q,replicate:ne,expirationMS:Y&&Y*1e3,evictionMS:Z&&Z*1e3,trackDeletes:q,tableName:_,tableId:b,primaryKey:g.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:E,attributes:S,schemaDefined:g.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let J of Hh)J(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function oJ(e){let t=qe[e];if(t||(e==="data"?t=qe[e]=Jn:e==="system"?Object.defineProperty(qe,"system",{value:t=Object.create(null),configurable:!0}):t=qe[e]=Object.create(null)),ff&&!ff.has(e)){let r=new Set;t[RA]=r,ff.set(e,r)}return t}function aJ(e,t,r){return e[t]=r,r}function qu({database:e,table:t}){e||(e=GP),Xe();let r=oJ(e),n=(0,Lt.join)((0,Zt.getHdbBasePath)(),Nc),s=(0,Zt.get)(x.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Zt.get)(x.STORAGE_PATH)||((0,us.existsSync)(n)?n:(0,Lt.join)((0,Zt.getHdbBasePath)(),om));let o=(0,Lt.join)(n,(i?t:e)+".mdb"),c=ea.get(o);if(!c||c.status==="closed"){let l=new kP.default(o,!1);c=(0,_f.open)(l),ea.set(o,c)}return c.auditStore||(c.auditStore=dA(c)),c}async function Xb(e){if(!qe[e])throw new Error("Schema does not exist");let t=qe[e],r;for(let n in t)r=t[n].primaryStore.rootStore,ea.delete(r.path),r.status==="open"&&(await r.close(),await Fh.remove(r.path));if(r||(r=qu({database:e,table:null}),r.status==="open"&&(await r.close(),await Fh.remove(r.path))),e==="data"){for(let n in Jn)delete Jn[n];delete Jn[RA]}delete qe[e],kh.forEach(n=>n(e)),await IR(r)}function ft(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,schemaDefined:p,origin:_}=e;r||(r=GP);let h=qu({database:r,table:t}),S=qe[r];qt.trace(`Defining ${t} in ${r}`);let g=S?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let R,E,T;p==null&&(p=!0);let b=new eu.default(!1);for(let Q of o)Q.attribute&&!Q.name?(Q.name=Q.attribute,Q.indexed=!0):Q.attribute=Q.name,Q.expiresAt&&(Q.indexed=!0);let v,F;if(g){if(R=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...o)}else{let Q=h.auditStore;E=o.find(ye=>ye.isPrimaryKey)||{},R=E.name,E.is_hash_attribute=E.isPrimaryKey=!0,E.schemaDefined=p,E.compression=CS(),d&&(E.trackDeletes=!0),c=E.audit=typeof c=="boolean"?c:(0,Zt.get)(x.LOGGING_AUDITLOG),n&&(E.expiration=n),s&&(E.eviction=s),u??=!1,E.splitSegments=u,typeof l=="boolean"&&(E.sealed=l),typeof f=="boolean"&&(E.replicate=f),_&&(E.origins?E.origins.includes(_)||E.origins.push(_):E.origins=[_]),qt.trace(`${t} table loading, opening primary store`);let ne=new eu.default(!1,!0);ne.compression=E.compression;let J=t+"/";if(T=h.dbisDb=h.openDB(gA.INTERNAL_DBIS_NAME,b),se(),T.get(J))return F&&F(),Dd(),ft(e);let me=Jm(h.openDB(J,ne),h);h.databaseName=r,me.tableId=T.get(uf),qt.trace(`Assigning new table id ${me.tableId} for ${t}`),me.tableId||(me.tableId=1),T.put(uf,me.tableId+1),E.tableId=me.tableId,g=aJ(S,t,EA({primaryStore:me,auditStore:Q,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:R,tableName:t,tableId:me.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:p,dbisDB:T})),g.schemaVersion=1,v=!0,T.put(J,E)}let q=g.indices;T=T||(h.dbisDb=h.openDB(gA.INTERNAL_DBIS_NAME,b)),g.dbisDB=T;let Y=[];for(let{key:Q,value:ne}of T.getRange({start:!0})){let[J,me]=Q.toString().split("/");if(me===""&&(me=ne.name),me){if(J!==t)continue}else continue;let ye=o.find(he=>he.name===me),Pe=!ye?.indexed&&ne.indexed&&!ne.isPrimaryKey;if((!ye||Pe)&&(se(),v=!0,ye||T.remove(Q),Pe)){let he=g.indices[J];he&&Y.push(he)}}let Z=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(v=!0,Q.relationship))continue;let ne=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:ne,configurable:!0});let J=T.get(ne);if(Q.isPrimaryKey){if(J=J||T.get(ne=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||f!==void 0&&f!==g.replicate||(+n||void 0)!==(+J.expiration||void 0)||(+s||void 0)!==(+J.eviction||void 0)){let ye={...J};typeof c=="boolean"&&(c&&g.enableAuditing(c),ye.audit=c),n&&(ye.expiration=+n),s&&(ye.eviction=+s),l!==void 0&&(ye.sealed=l),f!==void 0&&(ye.replicate=f),v=!0,se(),T.put(ne,ye)}continue}J?.attribute&&!J.name&&(J.indexed=!0);let me=!J||J.type!==Q.type||J.indexed!==Q.indexed||J.nullable!==Q.nullable||J.version!==Q.version||JSON.stringify(J.properties)!==JSON.stringify(Q.properties)||JSON.stringify(J.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let ye=new eu.default(!0,!1),Pe=h.openDB(ne,ye);(me||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Gh.workerData?.restartNumber)&&(v=!0,se(),J=T.get(ne),(me||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Gh.workerData?.restartNumber)&&(v=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=J?.lastIndexedKey??void 0,Q.indexingPID=process.pid,Pe.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:Pe}),Z.push(Q))),T.put(ne,Q)),J?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),Pe.indexNulls=Q.indexNulls,q[Q.name]=Pe}else me&&(v=!0,se(),T.put(ne,Q))}}finally{F&&F()}if(v&&(g.schemaVersion++,g.updatedAttributes()),qt.trace(`${t} table loading, running index`),Z.length>0||Y.length>0?g.indexingOperation=TAe(g,Z,Y):v&&SA.signalSchemaChange(new TA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,v)for(let Q of Hh)Q(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),qt.trace(`${t} table loaded`),g;function se(){F||h.transactionSync(()=>({then(Q){F=Q}}))}a(se,"startTxn")}async function TAe(e,t,r){try{qt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await SA.signalSchemaChange(new TA.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let d of t)(0,_f.compareKeys)(d.lastIndexedKey,u)<0&&(u=d.lastIndexedKey),d.lastIndexedKey==null&&d.dbi.clearAsync();let f=0;for(let{key:d,value:p,version:_}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(p){if(f++,s=e.primaryStore.ifVersion(d,_,()=>{for(let h=0;h<l;h++){let S=t[h],g=S.name;try{let R=S.resolve,E=p&&(R?R(p):p[g]),T=(0,nJ.getIndexedValues)(E);if(T)for(let b=0,v=T.length;b<v;b++)S.dbi.put(T[b],d)}catch(R){o[g]||(o[g]=!0,qt.error(`Error indexing attribute ${g}`,R))}}}),s.then(()=>f--,h=>{f--,qt.error(h)}),Gh.workerData&&Gh.workerData.restartNumber!==sJ.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=d,e.dbisDB.put(h.key,h);if(i)return}f>gAe?await s:f>SAe&&await new Promise(h=>setImmediate(h))}for(let d of t)delete d.lastIndexedKey,delete d.indexingPID,d.dbi.isIndexing=!1,s=e.dbisDB.put(d.key,d)}await s,await SA.signalSchemaChange(new TA.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),qt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){qt.error("Error in indexing",n)}}function AAe({table:e,database:t}){let r=qu({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Tl(e){return Hh.push(e),{remove(){let t=Hh.indexOf(e);t>-1&&Hh.splice(t,1)}}}function pp(e){return kh.push(e),{remove(){let t=kh.indexOf(e);t>-1&&kh.splice(t,1)}}}function CS(){let e=(0,Zt.get)(x.STORAGE_COMPRESSION),t=(0,Zt.get)(x.STORAGE_COMPRESSION_DICTIONARY),r=(0,Zt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iJ,n={startingOffset:32};return t&&(n.dictionary=Fh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Zt,gA,_f,Lt,us,df,eu,kP,Fh,FP,nJ,SA,TA,Gh,qt,sJ,GP,RA,iJ,Jn,qe,uf,Hh,kh,AA,ea,ff,gAe,SAe,De=be(()=>{Zt=M(ae()),gA=M(xt()),_f=require("lmdb"),Lt=require("path"),us=require("fs"),df=M(gt());qf();eu=M(s_()),kP=M(i_());H();Fh=M(require("fs-extra")),FP=M(Ti()),nJ=M(_n()),SA=M(To()),TA=M(ri()),Gh=require("worker_threads"),qt=M(z()),sJ=M(rt());fo();wu();gs();GP="data",RA=Symbol("defined-tables"),iJ=((0,Zt.get)(x.STORAGE_PAGESIZE)||4096)-60;(0,Zt.initSync)();Jn=Object.create(null),qe=Object.create(null);(0,FP._assignPackageExport)("databases",qe);(0,FP._assignPackageExport)("tables",Jn);uf=Symbol.for("next-table-id"),Hh=[],kh=[],ea=new Map;a(EAe,"getTables");a(Xe,"getDatabases");a(Dd,"resetDatabases");a(Bh,"readMetaDb");a(oJ,"ensureDB");a(aJ,"setTable");a(qu,"database");a(Xb,"dropDatabase");a(ft,"table");gAe=1e3,SAe=10;a(TAe,"runIndexing");a(AAe,"dropTableMeta");a(Tl,"onUpdatedTable");a(pp,"onRemovedDB");a(CS,"getDefaultCompression")});var ie=w((gxe,AJ)=>{"use strict";var Ec=require("path"),fJ=require("fs-extra"),Mn=z(),cJ=require("fs-extra"),yA=require("os"),RAe=require("net"),yAe=require("recursive-iterator"),yr=(H(),C(G)),{PACKAGE_ROOT:bAe}=it(),OAe=iR(),lJ=require("papaparse"),bA=require("moment"),{inspect:NAe}=require("util"),uJ=require("is-number"),Exe=require("lodash"),wAe=require("minimist"),IAe=require("https"),CAe=require("http"),{hdb_errors:OA}=pe(),PAe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,_J=require("util").promisify(setTimeout),DAe=100,LAe=5,MAe="",vAe=4,dJ={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};AJ.exports={isEmpty:ds,isEmptyOrZeroLength:to,arrayHasEmptyValues:BAe,arrayHasEmptyOrZeroLengthValues:HAe,buildFolderPath:kAe,isBoolean:pJ,errorizeMessage:UAe,stripFileExtension:GAe,autoCast:qAe,autoCastJSON:hJ,autoCastJSONDeep:$P,removeDir:$Ae,compareVersions:VAe,isCompatibleDataVersion:KAe,escapeRawValue:YAe,unescapeValue:WAe,stringifyProps:zAe,timeoutPromise:JAe,isClusterOperation:XAe,getClusterUser:eRe,checkGlobalSchemaTable:ZAe,getHomeDir:EJ,getPropsFilePath:jAe,promisifyPapaParse:tRe,removeBOM:gJ,createEventPromise:rRe,checkProcessRunning:nRe,checkSchemaTableExist:sRe,checkSchemaExists:SJ,checkTableExists:TJ,getStartOfTomorrowInSeconds:iRe,getLimitKey:oRe,isObject:FAe,isNotEmptyAndHasValue:xAe,autoCasterIsNumberCheck:mJ,backtickASTSchemaItems:aRe,isPortTaken:QAe,createForkArgs:cRe,autoCastBoolean:lRe,async_set_timeout:_J,getTableHashAttribute:uRe,doesSchemaExist:dRe,doesTableExist:fRe,stringifyObj:_Re,ms_to_time:pRe,changeExtension:hRe,getEnvCliRootPath:VP,noBootFile:mRe,httpRequest:ERe,transformReq:gRe,convertToMS:SRe,PACKAGE_ROOT:bAe};function UAe(e){return e instanceof Error?e:new Error(e)}a(UAe,"errorizeMessage");function ds(e){return e==null}a(ds,"isEmpty");function xAe(e){return!ds(e)&&(e||e===0||e===""||pJ(e))}a(xAe,"isNotEmptyAndHasValue");function to(e){return ds(e)||e.length===0||e.size===0}a(to,"isEmptyOrZeroLength");function BAe(e){if(ds(e))return!0;for(let t=0;t<e.length;t++)if(ds(e[t]))return!0;return!1}a(BAe,"arrayHasEmptyValues");function HAe(e){if(to(e))return!0;for(let t=0;t<e.length;t++)if(to(e[t]))return!0;return!1}a(HAe,"arrayHasEmptyOrZeroLengthValues");function kAe(...e){try{return e.join(Ec.sep)}catch{console.error(e)}}a(kAe,"buildFolderPath");function pJ(e){return ds(e)?!1:e===!0||e===!1}a(pJ,"isBoolean");function FAe(e){return ds(e)?!1:typeof e=="object"}a(FAe,"isObject");function GAe(e){return to(e)?MAe:e.slice(0,-vAe)}a(GAe,"stripFileExtension");function qAe(e){return ds(e)||e===""||typeof e!="string"?e:dJ[e]!==void 0?dJ[e]:mJ(e)===!0?Number(e):PAe.test(e)?new Date(e):e}a(qAe,"autoCast");function hJ(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(hJ,"autoCastJSON");function $P(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=$P(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=$P(r);n!==r&&(e[t]=n)}return e}else return hJ(e)}a($P,"autoCastJSONDeep");function mJ(e){if(e.startsWith("0.")&&uJ(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&uJ(e))}a(mJ,"autoCasterIsNumberCheck");async function $Ae(e){if(to(e))throw new Error(`Directory path: ${e} does not exist`);try{await cJ.emptyDir(e),await cJ.remove(e)}catch(t){throw Mn.error(`Error removing files in ${e} -- ${t}`),t}}a($Ae,"removeDir");function VAe(e,t){if(to(e)){Mn.info("Invalid current version sent as parameter.");return}if(to(t)){Mn.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(VAe,"compareVersions");function KAe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(KAe,"isCompatibleDataVersion");function YAe(e){if(ds(e))return e;let t=String(e);return t==="."?yr.UNICODE_PERIOD:t===".."?yr.UNICODE_PERIOD+yr.UNICODE_PERIOD:t.replace(yr.FORWARD_SLASH_REGEX,yr.UNICODE_FORWARD_SLASH)}a(YAe,"escapeRawValue");function WAe(e){if(ds(e))return e;let t=String(e);return t===yr.UNICODE_PERIOD?".":t===yr.UNICODE_PERIOD+yr.UNICODE_PERIOD?"..":String(e).replace(yr.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(WAe,"unescapeValue");function zAe(e,t){if(ds(e))return Mn.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+yA.EOL}!to(n)&&n[0]===";"?r+=" "+n+s+yA.EOL:to(n)||(r+=n+"="+s+yA.EOL)}catch{Mn.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(zAe,"stringifyProps");function EJ(){let e;try{e=yA.homedir()}catch{e=process.env.HOME}return e}a(EJ,"getHomeDir");function jAe(){let e=Ec.join(EJ(),yr.HDB_HOME_DIR_NAME,yr.BOOT_PROPS_FILE_NAME);return fJ.existsSync(e)||(e=Ec.join(__dirname,"../","hdb_boot_properties.file")),e}a(jAe,"getPropsFilePath");function JAe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(JAe,"timeoutPromise");async function QAe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=RAe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(QAe,"isPortTaken");function XAe(e){try{return yr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Mn.error(`Error checking operation against cluster ops ${t}`)}return!1}a(XAe,"isClusterOperation");function ZAe(e,t){let r=(De(),C(nt)).getDatabases();if(!r[e])return OA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return OA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(ZAe,"checkGlobalSchemaTable");function eRe(e,t){if(ds(t)){Mn.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ds(e)||to(e)){Mn.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){Mn.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Mn.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(eRe,"getClusterUser");function tRe(){lJ.parsePromise=function(e,t,r){return new Promise(function(n,s){lJ.parse(e,{header:!0,transformHeader:gJ,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(tRe,"promisifyPapaParse");function gJ(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(gJ,"removeBOM");function rRe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Mn.info(`Got cluster status event response: ${NAe(s)}`);try{i.cancel()}catch{Mn.error("Error trying to cancel timeout.")}n(s)})})}a(rRe,"createEventPromise");async function nRe(e){let t=!0,r=0;do await _J(DAe*r++),(await OAe.findPs(e)).length>0&&(t=!1);while(t&&r<LAe);if(t)throw new Error(`process ${e} was not started`)}a(nRe,"checkProcessRunning");function sRe(e,t){let r=SJ(e);if(r)return r;let n=TJ(e,t);if(n)return n}a(sRe,"checkSchemaTableExist");function SJ(e){let{getDatabases:t}=(De(),C(nt));if(!t()[e])return OA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(SJ,"checkSchemaExists");function TJ(e,t){let{getDatabases:r}=(De(),C(nt));if(!r()[e][t])return OA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(TJ,"checkTableExists");function iRe(){let e=bA().utc().add(1,"d").startOf("d").unix(),t=bA().utc().unix();return e-t}a(iRe,"getStartOfTomorrowInSeconds");function oRe(){return bA().utc().format("DD-MM-YYYY")}a(oRe,"getLimitKey");function aRe(e){try{let t=new yAe(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){Mn.error("Got an error back ticking items."),Mn.error(t)}}a(aRe,"backtickASTSchemaItems");function cRe(e){return[e]}a(cRe,"createForkArgs");function lRe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(lRe,"autoCastBoolean");function uRe(e,t){let{getDatabases:r}=(De(),C(nt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(uRe,"getTableHashAttribute");function dRe(e){let{getDatabases:t}=(De(),C(nt));return t()[e]!==void 0}a(dRe,"doesSchemaExist");function fRe(e,t){let{getDatabases:r}=(De(),C(nt));return r()[e]?.[t]!==void 0}a(fRe,"doesTableExist");function _Re(e){try{return JSON.stringify(e)}catch{return e}}a(_Re,"stringifyObj");function pRe(e){let t=bA.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(pRe,"ms_to_time");function hRe(e,t){let r=Ec.basename(e,Ec.extname(e));return Ec.join(Ec.dirname(e),r+t)}a(hRe,"changeExtension");function VP(){if(process.env[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=wAe(process.argv);if(e[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(VP,"getEnvCliRootPath");var qP;function mRe(){if(qP)return qP;let e=VP();if(VP()&&fJ.pathExistsSync(Ec.join(e,yr.HDB_CONFIG_FILE)))return qP=!0,!0}a(mRe,"noBootFile");function ERe(e,t){let r;return e.protocol==="http:"?r=CAe:r=IAe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(ERe,"httpRequest");function gRe(e){if(!e.schema&&!e.database){e.schema=yr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(gRe,"transformReq");function SRe(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(SRe,"convertToMS")});var ae=w((NJ,wJ)=>{"use strict";var KP=require("fs-extra"),tu=require("path"),RJ=require("os"),TRe=require("properties-reader"),$h=z(),qh=ie(),Me=(H(),C(G)),NA=yt(),ARe="Error initializing environment manager",wA="BOOT_PROPS_FILE_PATH",yJ=!1,RRe={[Me.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ta={};Object.assign(NJ,wJ.exports={BOOT_PROPS_FILE_PATH:wA,getHdbBasePath:yRe,setHdbBasePath:bRe,get:bJ,initSync:NRe,setProperty:Ke,initTestEnvironment:IRe,setCloneVar:wRe});function yRe(){return ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(yRe,"getHdbBasePath");function bRe(e){ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(bRe,"setHdbBasePath");function bJ(e){let t=NA.getConfigValue(e);return t===void 0?ta[e]:t}a(bJ,"get");function Ke(e,t){RRe[e]&&(ta[e]=t),NA.updateConfigObject(e,t)}a(Ke,"setProperty");function ORe(){let e;try{e=qh.getPropsFilePath(),KP.accessSync(e,KP.constants.F_OK|KP.constants.R_OK),yJ=!0;let t=TRe(e);return ta[Me.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Me.HDB_SETTINGS_NAMES.INSTALL_USER),ta[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ta[wA]=e,!0}catch{return $h.trace(`Environment manager found no properties file at ${e}`),!1}}a(ORe,"doesPropFileExist");function NRe(e=!1){try{((yJ||ORe()||qh.noBootFile())&&!OJ||e)&&(NA.initConfig(e),ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=NA.getConfigValue(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){$h.error(ARe),$h.error(t),console.error(t),process.exit(1)}}a(NRe,"initSync");var OJ=!1;function wRe(e){OJ=e}a(wRe,"setCloneVar");function IRe(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=tu.join(__dirname,"../../","unitTests");ta[wA]=tu.join(l,"hdb_boot_properties.file"),Ke(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,tu.join(l,"settings.test")),Ke(Me.HDB_SETTINGS_NAMES.INSTALL_USER,RJ.userInfo()?RJ.userInfo().username:void 0),Ke(Me.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ke(Me.HDB_SETTINGS_NAMES.LOG_PATH_KEY,tu.join(l,"envDir","log")),Ke(Me.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ke(Me.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ke(Me.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ke(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,tu.join(l,"envDir")),Ke(Me.CONFIG_PARAMS.STORAGE_PATH,tu.join(l,"envDir")),s&&(Ke(Me.CONFIG_PARAMS.HTTP_SECUREPORT,bJ(Me.CONFIG_PARAMS.HTTP_PORT)),Ke(Me.CONFIG_PARAMS.HTTP_PORT,null)),Ke(Me.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ke(Me.CONFIG_PARAMS.HTTP_PORT,9926),Ke(Me.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ke(Me.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Ke(Me.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,qh.isEmpty(i)?!1:i),Ke(Me.CONFIG_PARAMS.HTTP_CORS,qh.isEmpty(i)?!1:i),Ke(Me.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ke(Me.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,tu.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ke(Me.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,qh.isEmpty(c)?!1:c),o&&(Ke("CORS_ACCESSLIST",o),Ke(Me.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ke(Me.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ke(Me.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ke(Me.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${wA}. Please check your boot props and settings files`;$h.fatal(r),$h.error(t)}}a(IRe,"initTestEnvironment")});var LJ=w((Axe,DJ)=>{"use strict";var CA=ae();CA.initSync();var IA=(H(),C(G)),{httpRequest:CRe}=ie(),PJ=require("path"),IJ=require("fs-extra"),PRe=require("yaml"),{packageDirectory:DRe}=(Kw(),C(Vw)),{encode:LRe}=require("cbor-x"),MRe=["describe_table","describe_all","describe_database","list_users","list_roles","drop_role","add_user","alter_user","drop_user","restart_service","restart","create_database","drop_database","create_table","drop_table","create_attribute","drop_attribute","search_by_id","insert","update","upsert","delete","search_by_value","csv_file_load","csv_url_load","cluster_get_routes","cluster_network","cluster_status","remove_node","add_component","deploy_component","package_component","drop_component","get_components","get_component_file","set_component_file","registration_info","get_fingerprint","set_license","get_job","search_jobs_by_start_date","read_log","read_transaction_log","read_audit_log","delete_transaction_logs_before","purge_stream","delete_records_before","install_node_modules","set_configuration","get_configuration","create_authentication_tokens","refresh_operation_token","system_information","sql","create_csr","sign_certificate","list_certificates","add_certificate","remove_certificate","add_ssh_key","update_ssh_key","delete_ssh_key","list_ssh_keys","set_ssh_known_hosts","get_ssh_known_hosts"],CJ={deploy:"deploy_component",package:"package_component"};DJ.exports={cliOperations:xRe,buildRequest:URe};var vRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await DRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=PJ.basename(t))},"deploy_component")};function URe(){let e={};for(let t of process.argv.slice(2))if(MRe.includes(t))e.operation=t;else if(CJ.hasOwnProperty(t))e.operation=CJ[t];else if(t.includes("=")){let[r,...n]=t.split("=");n=n.join("=");try{n=JSON.parse(n)}catch{}e[r]=n}return e}a(URe,"buildRequest");async function xRe(e){e.target||(e.target=process.env.CLI_TARGET);let t;if(e.target){try{t=new URL(e.target)}catch(r){try{t=new URL(`https://${e.target}:9925`)}catch{throw r}}t={protocol:t.protocol,hostname:t.hostname,port:t.port,username:e.username||t.username||process.env.CLI_TARGET_USERNAME,password:e.password||t.password||process.env.CLI_TARGET_PASSWORD,rejectUnauthorized:e.rejectUnauthorized}}else IJ.existsSync(PJ.join(CA.get(IA.CONFIG_PARAMS.ROOTPATH),IA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),IJ.existsSync(CA.get(IA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await vRe[e.operation]?.(e);try{let r=t??{protocol:"http:",socketPath:CA.get(IA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)};r.method="POST",r.headers={"Content-Type":"application/json"},t?.username&&(r.headers.Authorization=`Basic ${Buffer.from(`${t.username}:${t.password}`).toString("base64")}`),e.cborEncode&&(r.headers["Content-Type"]="application/cbor",e=LRe(e));let n=await CRe(r,e),s;try{s=JSON.parse(n.body)}catch{s={status:n.statusCode+" "+(n.statusMessage||"Unknown"),body:n.body}}e.json?console.log(JSON.stringify(s,null,2)):console.log(PRe.stringify(s).trim())}catch(r){let n="Error: ";if(r?.response?.data?.error)n+=r.response.data.error;else if(r?.response?.data)n+=r?.response?.data;else return console.error(r);console.error(n)}}a(xRe,"cliOperations")});var UJ=w((yxe,vJ)=>{"use strict";var MJ=require("semver/functions/major"),{packageJson:BRe}=it(),YP=process.versions&&process.versions.node?process.versions.node:void 0;vJ.exports=HRe;function HRe(){let e=BRe.engines["minimum-node"];if(YP&&MJ(YP)<MJ(e))return{error:`The minimum version of Node.js HarperDB supports is: ${e}, the currently installed Node.js version is: ${YP}. Please install a version of Node.js that is withing the defined range.`}}a(HRe,"checkNodeVersion")});var ZP=w((Nxe,r2)=>{"use strict";var xJ=require("os"),PA=require("https"),BJ=require("http"),$t=require("fs-extra"),HJ=require("yaml"),{pipeline:kJ}=require("stream/promises"),{createWriteStream:DA,ensureDir:Vh,writeFileSync:FJ}=require("fs-extra"),{join:$s}=require("path"),VJ=require("lodash"),kRe=require("minimist"),ra=require("path"),FRe=require("node:crypto"),GRe=require("properties-reader"),qs=ae(),qRe=Po(),JP=z(),LA=yt(),{restart:$Re}=za(),MA=ie(),VRe=ua(),KRe=As(),{main:vA,launch:YRe}=Qd(),{install:KJ,updateConfigEnv:WRe,setIgnoreExisting:xA}=PT(),YJ=SC(),an=(H(),C(G)),{packageJson:zRe}=it(),jRe=mh(),{sendOperationToNode:jP}=(Xn(),C(wo)),{updateConfigCert:JRe}=Zn(),{restartWorkers:QRe}=rt(),{databases:XRe}=(De(),C(nt)),{SYSTEM_TABLE_NAMES:WP,SYSTEM_SCHEMA_NAME:Oxe,CONFIG_PARAMS:Kh,OPERATIONS_ENUM:ps}=an,ZRe=1e4,eye="clone-node-config.yaml",WJ=[WP.ROLE_TABLE_NAME,WP.USER_TABLE_NAME,WP.NODE_TABLE_NAME],tye={clustering_nodename:!0,clustering_leafserver_streams_path:!0,clustering_tls_certificate:!0,clustering_tls_privatekey:!0,clustering_tls_certificateauthority:!0,logging_file:!0,logging_root:!0,logging_rotation_path:!0,operationsapi_network_domainsocket:!0,operationsapi_tls_certificate:!0,operationsapi_tls_privatekey:!0,operationsapi_tls_certificateauthority:!0,rootpath:!0,storage_path:!0,storage_audit_path:!0,databases:!0,mqtt_network_mtls_certificateauthority:!0,componentsroot:!0,tls_certificate:!0,tls_privatekey:!0,tls_certificateauthority:!0,replication_hostname:!0,replication_url:!0,cloned:!0},Fr={HDB_LEADER_USERNAME:"HDB_LEADER_USERNAME",HDB_LEADER_PASSWORD:"HDB_LEADER_PASSWORD",HDB_LEADER_URL:"HDB_LEADER_URL",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",HDB_CLONE_OVERTOP:"HDB_CLONE_OVERTOP",CLONE_KEYS:"CLONE_KEYS",CLONE_USING_WS:"CLONE_USING_WS",NO_START:"NO_START"},sa=kRe(process.argv),pf=sa[Fr.HDB_LEADER_USERNAME]??process.env[Fr.HDB_LEADER_USERNAME],hf=sa[Fr.HDB_LEADER_PASSWORD]??process.env[Fr.HDB_LEADER_PASSWORD],nu=sa[Fr.HDB_LEADER_URL]??process.env[Fr.HDB_LEADER_URL],na=sa[Fr.REPLICATION_HOSTNAME]??process.env[Fr.REPLICATION_HOSTNAME],zJ,jJ;na&&([zJ,jJ]=na.split(":"));var QP=(sa[Fr.HDB_CLONE_OVERTOP]??process.env[Fr.HDB_CLONE_OVERTOP])==="true",JJ=sa[Kh.CLONED.toUpperCase()]??process.env[Kh.CLONED.toUpperCase()],rye=sa[Fr.CLONE_KEYS]!=="false"&&process.env[Fr.CLONE_KEYS]!=="false",QJ=(sa[Fr.CLONE_USING_WS]??process.env[Fr.CLONE_USING_WS])==="true",XJ=(sa[Fr.NO_START]??process.env[Fr.NO_START])==="true",_s,gc={},GJ,qJ,ru={},on,Mt,Gs,ro,su=!1,XP=!1,fs,mf;r2.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${nu}`),delete process.env.HDB_LEADER_URL,Mt=MA.getEnvCliRootPath(),!Mt)try{let i=$s(xJ.homedir(),an.HDB_HOME_DIR_NAME,an.BOOT_PROPS_FILE_NAME);if(await $t.pathExists(i)){let o=GRe(i);Mt=ra.parse(o.get(an.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)).dir}}catch{throw new Error("There was an error setting the clone default root path. Please set ROOTPATH using an environment or CLI variable.")}Mt?await $t.pathExists(Mt)?console.log(`Existing HarperDB install found at ${Mt}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Mt} starting fresh clone`),su=!0):(console.log("No HarperDB install found, starting fresh clone"),su=!0),Mt||(Mt=$s(xJ.homedir(),an.HDB_ROOT_DIR_NAME),console.log("Using default root path",Mt));let n;try{n=$s(Mt,eye),_s=HJ.parseDocument(await $t.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=$s(Mt,an.HDB_CONFIG_FILE);if(await $t.pathExists(s))try{GJ=HJ.parseDocument(await $t.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),gc=LA.flattenConfig(GJ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(na){let i=new URL(nu);mf=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${jJ||9933}`}if(QJ){await nye();return}if(gc?.cloned&&JJ!=="false")return console.log("Instance marked as cloned, clone will not run"),qs.setCloneVar(!1),qs.initSync(),vA();on=await UA({operation:ps.DESCRIBE_ALL}),await e2(),qs.setCloneVar(!1),qs.setHdbBasePath(Mt),$t.ensureDir(qs.get(an.CONFIG_PARAMS.LOGGING_ROOT)),JP.initLogSettings(),await iye(),XP||await oye(),await lye(t,r),na&&(await dye(),await ZJ()),console.info(`
|
|
134
|
+
Successfully cloned node: `+nu),(t||XJ)&&process.exit()},"cloneNode");async function nye(){if(gc?.cloned&&JJ!=="false")return console.log("Instance marked as cloned, clone will not run"),qs.setCloneVar(!1),qs.initSync(),vA();console.log("Cloning using WebSockets");let e=Sc("system"),t=$s(e,"system.mdb"),r=$t.existsSync(t);su||!r||QP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Mt,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=FRe.randomBytes(10).toString("base64").slice(0,10),xA(!0),await KJ()):(qs.setCloneVar(!1),qs.initSync()),await vA(),await e2(!0),await JRe(),r||await XRe.system.hdb_user.delete({username:"clone-temp-admin"}),await QRe(),await sye(),console.log("Adding node to the cluster");let s=await Sd()({operation:ps.ADD_NODE,url:mf});console.log("Add node response: ",s),await ZJ(),console.log(`Successfully cloned node: ${nu} using WebSockets`),LA.updateConfigValue(Kh.CLONED,!0),XJ&&process.exit()}a(nye,"cloneUsingWS");async function sye(){let e=a(i=>{let o=0;for(let c in i){let l=i[c];typeof l=="object"&&l.last_updated_record>o&&(o=l.last_updated_record)}return o},"findMostRecentTimestamp");console.log("Getting last updated record timestamp for all database");let t={},r=await UA({operation:"describe_database",database:"system"});t.system=e(r);let n=await UA({operation:"describe_all"});for(let i in n)typeof n[i]=="object"&&(t[i]=e(n[i]));let s=$s(Mt,"tmp","lastUpdated.json");console.log("Writing last updated database timestamps to:",s),await $t.outputJson(s,t)}a(sye,"getLastUpdatedRecord");async function UA(e){return QJ?jP({url:mf},e,{rejectUnauthorized:!1}):JSON.parse((await fye(e)).body)}a(UA,"leaderReq");async function ZJ(){try{if(rye!==!1){console.log("Cloning JWT keys");let e=ra.join(Mt,an.LICENSE_KEY_DIR_NAME),t=await jP({url:mf},{operation:ps.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});FJ(ra.join(e,an.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await jP({url:mf},{operation:ps.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});FJ(ra.join(e,an.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r.message)}}catch(e){console.error("Error cloning JWT keys",e)}}a(ZJ,"cloneKeys");async function e2(e=!1){console.info("Cloning configuration"),qJ=await UA({operation:ps.GET_CONFIGURATION}),ru=LA.flattenConfig(qJ);let t=_s?.componentConfig?.exclude,r={rootpath:Mt};na&&(r.replication_hostname=zJ);for(let i in ru)if(!(ru[i]!==null&&typeof ru[i]=="object"&&!(ru[i]instanceof Array)||tye[i])){if(i.includes("_package")||i.includes("_port")){if(ru[i]?.includes?.("hdb/components"))continue;if(t){let o=!1;for(let c of t)if(i.includes(c.name)){o=!0;break}if(o)continue}}gc[i]||(r[i]=ru[i])}for(let i in gc)i!=="databases"&&typeof gc[i]=="object"&&!(gc[i]instanceof Array)||(r[i]=gc[i]);let n={};if(_s?.databaseConfig?.excludeDatabases&&_s.databaseConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),_s?.clusteringConfig?.excludeDatabases&&_s.clusteringConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),Object.keys(n).length>0){r.replication_databases=[],n.system||r.replication_databases.push("system");for(let i in on)n[i]||r.replication_databases.push(i)}let s=VRe(Object.keys(an.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),LA.createConfigFile(r,!0)}a(e2,"cloneConfig");async function iye(){process.env.HDB_FETCH==="true"?(await cye(),process.env.NODE_TLS_REJECT_UNAUTHORIZED&&delete process.env.NODE_TLS_REJECT_UNAUTHORIZED):await aye()}a(iye,"cloneDatabases");async function oye(){if(console.info("Clone node installing HarperDB."),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Mt,!pf)throw new Error("HDB_LEADER_USERNAME is undefined.");if(process.env.HDB_ADMIN_USERNAME=pf,!hf)throw new Error("HDB_LEADER_PASSWORD is undefined.");process.env.HDB_ADMIN_PASSWORD=hf,process.env.OPERATIONSAPI_NETWORK_PORT=qs.get(Kh.OPERATIONSAPI_NETWORK_PORT),WRe(ra.join(Mt,an.HDB_CONFIG_FILE)),xA(!0),await KJ()}a(oye,"installHDB");function Sc(e){return qs.get(an.CONFIG_PARAMS.DATABASES)?.[e]?.path||qs.get(Kh.STORAGE_PATH)||ra.join(Mt,an.DATABASES_DIR_NAME)}a(Sc,"getDBPath");async function aye(){let e=Sc("system"),t=$s(e,"system.mdb");if(await Vh(e),su||!await $t.exists(t)||QP){if(!na){console.info("Cloning system database"),await Vh(e);let r=DA(t,{overwrite:!0}),n={operation:ps.GET_BACKUP,database:"system",tables:WJ},s=await $J(n,r),i=new Date(s.date);(!fs||i<fs)&&(fs=i),await $t.utimes(t,Date.now(),i)}su||(await YJ(Mt),await t2(),xA(!0))}else XP=!0,console.log("Not cloning system database due to it already existing on clone");Gs=_s?.databaseConfig?.excludeDatabases,Gs=Gs?Gs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await $t.exists(ra.join(Sc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Gs[r]=!0);ro=_s?.databaseConfig?.excludeTables,ro=ro?ro.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if(Gs[r]){on[r]="excluded";continue}if(VJ.isEmpty(on[r]))continue;let n=[],s=!1;for(let d in on[r])ro[r+d]?(s=!0,on[r][d]="excluded"):n.push(on[r][d]);if(n.length===0)continue;if(na){JP.debug("Setting up tables for #{db}");let d=(De(),C(nt)).table;for(let p of n){for(let _ of p.attributes)(_.is_hash_attribute||_.is_primary_key)&&(_.isPrimaryKey=!0);d({database:r,table:p.name,attributes:p.attributes})}continue}n=n.map(d=>d.name);let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i={operation:ps.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:ps.GET_BACKUP,database:r});let o=Sc(r);await Vh(o);let c=$s(o,r+".mdb"),l=DA(c,{overwrite:!0}),u=await $J(i,l),f=new Date(u.date);(!fs||f<fs)&&(fs=f),await $t.utimes(c,Date.now(),f)}}a(aye,"cloneTablesHttp");async function cye(){let e=Sc("system"),t=$s(e,"system.mdb");if(su||!await $t.exists(t)||QP){if(!na){console.info("Cloning system database using fetch");let r={operation:ps.GET_BACKUP,database:"system",tables:WJ},n=await zP(r,!0),s=Sc("system");await Vh(s);let i=$s(s,"system.mdb");await kJ(n.body,DA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!fs||o<fs)&&(fs=o),await $t.utimes(i,Date.now(),new Date(n.headers.get("date")))}su||(await YJ(Mt),await t2(),xA(!0))}else XP=!0,console.log("Not cloning system database due to it already existing on clone");if(na){JP.info("Replication hostname set, not using backup to clone databases, replication will clone");return}Gs=_s?.databaseConfig?.excludeDatabases,Gs=Gs?Gs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await $t.exists(ra.join(Sc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Gs[r]=!0);ro=_s?.databaseConfig?.excludeTables,ro=ro?ro.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if(Gs[r]){on[r]="excluded";continue}if(VJ.isEmpty(on[r]))continue;let n=[],s=!1;for(let f in on[r])ro[r+f]?(s=!0,on[r][f]="excluded"):n.push(f);if(n.length===0)return;let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i=await zP({operation:ps.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await zP({operation:ps.GET_BACKUP,database:r},!0));let o=Sc(r);await Vh(o);let c=new Date(i.headers.get("date")),l=$s(o,`${c.getTime()}-${r}.mdb`);await kJ(i.body,DA(l,{overwrite:!0}));let u=$s(o,r+".mdb");await $t.rename(l,u),(!fs||c<fs)&&(fs=c),await $t.utimes(u,Date.now(),c)}}a(cye,"cloneTablesFetch");async function zP(e,t=!1){let r=_s?.httpsRejectUnauthorized??!1,n=new PA.Agent({rejectUnauthorized:r});r||(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0");let i={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"};t&&(i["Accept-Encoding"]="gzip");let o=await fetch(nu,{method:"POST",headers:i,body:JSON.stringify(e),agent:n,compress:!0});if(o.ok)return o;throw console.error(`HTTP Error Response: ${o.status} ${o.statusText}`),new Error(await o.text())}a(zP,"leaderHttpReqFetch");async function lye(e,t=!1){let r=await qRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await YRe(!1):(t&&await uye(),await vA()):(console.info(await $Re({operation:ps.RESTART})),await MA.async_set_timeout(ZRe)),e&&await MA.async_set_timeout(2e3)}a(lye,"startHDB");async function uye(){let e=process.argv[3];e&&e[0]!=="-"&&(await $t.exists(e)||console.error(`The folder ${e} does not exist`),$t.statSync(e).isDirectory()||console.error(`The path ${e} is not a folder`),e=await $t.realpath(e),await $t.exists(ra.join(e,an.HDB_CONFIG_FILE))?process.env.ROOTPATH=e:process.env.RUN_HDB_APP=e)}a(uye,"setAppPath");async function dye(){console.info("Setting up replication"),await KRe.setSchemaDataToGlobalAsync();let t=await Sd()({operation:ps.ADD_NODE,verify_tls:!1,url:mf,start_time:fs,authorization:{username:pf,password:hf}},!0);console.log("Add node response: ",t)}a(dye,"setupReplication");async function fye(e){let t=new PA.Agent({rejectUnauthorized:_s?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"},s=new URL(nu),i={protocol:s.protocol,host:s.hostname,method:"POST",headers:n};return s.protocol==="https:"&&(i.agent=t),s.port&&(i.port=s.port),await MA.httpRequest(i,e)}a(fye,"leaderHttpReq");async function $J(e,t){let r=new PA.Agent({rejectUnauthorized:_s?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"},i=new URL(nu),o={protocol:i.protocol,host:i.hostname,method:"POST",headers:s};return i.protocol==="https:"&&(o.agent=r,BJ=PA),i.port&&(o.port=i.port),new Promise((c,l)=>{let u=BJ.request(o,f=>{f.statusCode!==200&&l("Request to leader node failed with code: "+f.statusCode),f.pipe(t),f.on("end",()=>{t.close(),c(f.headers)})});u.on("error",f=>{l(f)}),u.write(JSON.stringify(e)),u.end()})}a($J,"leaderHttpStream");async function t2(){let e=zRe.version;if(e)await jRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(t2,"insertHdbVersionInfo")});var s2=w((Ixe,n2)=>{var _ye=PT(),pye=z();n2.exports=hye;async function hye(){try{await _ye.install()}catch(e){console.error("There was an error during the install."),console.error(e),pye.error(e),process.exit(1)}}a(hye,"install")});var a2=w((Pxe,o2)=>{"use strict";var mye=mS(),Eye=z(),i2="Registration failed.";async function gye(){let e;try{e=await mye.register()}catch(t){return Eye.error(`Registration error ${t}`),i2}return e||i2}a(gye,"register");o2.exports={register:gye}});var d2=w((Lxe,u2)=>{"use strict";var Sye=z(),Tye=(H(),C(G)),Aye=require("util"),Rye=require("child_process"),c2=Aye.promisify(Rye.exec),yye=Po(),Yh=Pd(),l2="Stopping HarperDB.";u2.exports=bye;async function bye(){if(console.log(l2),Sye.notify(l2),await Yh.isServiceRegistered(Tye.PROCESS_DESCRIPTORS.HDB)){Yh.enterPM2Mode();let r=await Yh.getUniqueServicesList();for(let n in r)await Yh.stop(n)}await Yh.kill();let t=await yye.getHDBProcessInfo();t.clustering.forEach(r=>{c2(`kill ${r.pid}`)}),t.core.forEach(r=>{c2(`kill ${r.pid}`)})}a(bye,"stop")});var p2=w((vxe,_2)=>{"use strict";var tD=require("fs-extra"),rD=require("path"),eD=require("yaml"),Wh=ir(),Tc=(H(),C(G)),f2=Tt(),nD=z(),Oye=Rn(),Nye=uS(),wye=cS(),Iye=Po(),zh=ae(),Cye=Qd(),Pye=ie();zh.initSync();var Vs={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},vn={LEAF:"leaf server",HUB:"hub server"},BA;_2.exports=Dye;async function Dye(){let e={harperdb:{status:Vs.STOPPED}};if(!await Cye.isHdbInstalled()){e.harperdb.status=Vs.NOT_INSTALLED,console.log(eD.stringify(e));return}BA=zh.get(Tc.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await tD.readFile(rD.join(BA,Tc.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Tc.NODE_ERROR_CODES.ENOENT){nD.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Vs.STOPPED,console.log(eD.stringify(e));return}throw n}let r=await Iye.getHDBProcessInfo();for(let n of r.core)if(n.pid===t){e.harperdb.status=Vs.RUNNING,e.harperdb.pid=t;break}if((zh.get(Tc.CONFIG_PARAMS.REPLICATION_URL)||zh.get(Tc.CONFIG_PARAMS.REPLICATION_HOSTNAME))&&(e.replication=await Mye()),e.clustering=await Lye(r),e.clustering[vn.HUB].status===Vs.RUNNING&&e.clustering[vn.LEAF].status===Vs.RUNNING){let n=[],s=await Nye({});for(let o of s.nodes){let c={};for(let l in o)c[l.replace("_"," ")]=o[l];n.push(c)}e.clustering.network=n;let i=await wye.clusterStatus();e.clustering.replication={"node name":i.node_name,"is enabled":i.is_enabled,connections:[]};for(let o of i.connections){let c={};c["node name"]=o?.node_name,c.status=o?.status,c.ports={clustering:o?.ports?.clustering,"operations api":o?.ports?.operations_api},c["latency ms"]=o?.latency_ms,c.uptime=o?.uptime,c.subscriptions=o?.subscriptions,c["system info"]={"hdb version":o?.system_info?.hdb_version,"node version":o?.system_info?.node_version,platform:o?.system_info?.platform},e.clustering.replication.connections.push(c)}await Wh.closeConnection()}console.log(eD.stringify(e)),process.exit()}a(Dye,"status");async function Lye(e){let t={[vn.HUB]:{},[vn.LEAF]:{}};if(e.clustering.length===0)return t[vn.HUB].status=Vs.STOPPED,t[vn.LEAF].status=Vs.STOPPED,t;let{port:r}=Wh.getServerConfig(Tc.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await Oye.getClusterUser();try{(await Wh.createConnection(r,n,s,!1)).close(),t[vn.HUB].status=Vs.RUNNING}catch{t[vn.HUB].status=Vs.ERRORED}let{port:i}=Wh.getServerConfig(Tc.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await Wh.createConnection(i,n,s,!1)).close(),t[vn.LEAF].status=Vs.RUNNING}catch{t[vn.LEAF].status=Vs.ERRORED}try{t[vn.HUB].pid=Number.parseInt(await tD.readFile(rD.join(BA,"clustering",f2.PID_FILES.HUB),"utf8"))}catch(o){nD.error(o),t[vn.HUB].pid=void 0}try{t[vn.LEAF].pid=Number.parseInt(await tD.readFile(rD.join(BA,"clustering",f2.PID_FILES.LEAF),"utf8"))}catch(o){nD.error(o),t[vn.LEAF].pid=void 0}return t}a(Lye,"getHubLeafStatus");async function Mye(){let e=await Pye.httpRequest({method:"POST",protocol:"http:",socketPath:zh.get(Tc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),headers:{"Content-Type":"application/json"}},{operation:"cluster_status"});e=JSON.parse(e.body);let t={"node name":e.node_name,"is enabled":e.is_enabled,connections:[]};for(let r of e.connections)t.connections.push({"node name":r.name,url:r.url,subscriptions:r.subscriptions,replicates:r.replicates,"database sockets":r.database_sockets.map(n=>({database:n.database,connected:n.connected,latency:n.latency,"catching up from":n.catching_up_from,"thread id":n.thread_id,nodes:n.nodes}))});return t}a(Mye,"getReplicationStatus")});nm();var sD=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");sD&&ae().setCloneVar(!0);var jh=require("node:fs"),h2=require("node:path"),iu=z(),m2=LJ(),{packageJson:vye,PACKAGE_ROOT:E2}=it(),Uye=UJ(),iD=(H(),C(G)),{SERVICE_ACTIONS_ENUM:cn}=iD,xye=`
|
|
136
135
|
Usage: harperdb [command]
|
|
137
136
|
|
|
138
137
|
With no command, harperdb will simply run HarperDB (in the foreground)
|
|
@@ -154,4 +153,4 @@ stop - Stop the harperdb background process
|
|
|
154
153
|
help - Display this output
|
|
155
154
|
upgrade - Upgrade harperdb
|
|
156
155
|
version - Print the version
|
|
157
|
-
`;async function
|
|
156
|
+
`;async function Bye(){let e=Uye();if(e)if(e.error){console.error(e.error),iu.error(e.error);return}else e.warn&&(console.warn(e.warn),iu.warn(e.warn));let t;jh.existsSync(h2.join(E2,"bin"))||(iu.error(`Missing \`bin\` directory at ${E2}`),process.exit(0)),process.argv&&process.argv[2]&&!process.argv[2].startsWith("-")&&(t=process.argv[2].toLowerCase());let r=m2.buildRequest();switch(r.operation&&(t=cn.OPERATION),t){case cn.OPERATION:return iu.trace("calling cli operations with:",r),m2.cliOperations(r);case cn.START:return sD?ZP()(!0):Qd().launch();case cn.INSTALL:return s2()();case cn.REGISTER:return a2().register();case cn.STOP:return d2()().then(()=>{process.exit(0)});case cn.RESTART:return za().restart({});case cn.VERSION:return vye.version;case cn.UPGRADE:return iu.setLogLevel(iD.LOG_LEVELS.INFO),IC().upgrade(null).then(()=>"Your instance of HarperDB is up to date!");case cn.STATUS:return p2()();case cn.RENEWCERTS:return Zn().renewSelfSigned().then(()=>"Successfully renewed self-signed certificates");case cn.COPYDB:{let n=process.argv[3],s=process.argv[4];return(IS(),C(wS)).copyDb(n,s)}case cn.DEV:process.env.DEV_MODE=!0;case cn.RUN:{let n=process.argv[3];if(n&&n[0]!=="-"){if(!jh.existsSync(n))throw new Error(`The folder ${n} does not exist`);if(!jh.statSync(n).isDirectory())throw new Error(`The path ${n} is not a folder`);n=jh.realpathSync(n),jh.existsSync(h2.join(n,iD.HDB_CONFIG_FILE))?process.env.ROOTPATH=n:process.env.RUN_HDB_APP=n}}case void 0:return sD?ZP()():Qd().main();default:console.warn(`The "${t}" command is not understood.`);case cn.HELP:return xye}}a(Bye,"harperdb");Bye().then(e=>{e&&(console.log(e),iu.notify(e))}).catch(e=>{e&&(console.error(e),iu.error(e)),process.exit(1)});
|