harperdb 4.5.0 → 4.5.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bin/harperdb.js +75 -76
- package/bin/lite.js +74 -75
- package/launchServiceScripts/launchInstallNATSServer.js +2 -2
- package/launchServiceScripts/launchNatsIngestService.js +74 -75
- package/launchServiceScripts/launchNatsReplyService.js +73 -74
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +74 -75
- package/npm-shrinkwrap.json +245 -245
- package/package.json +1 -1
- package/server/jobs/jobProcess.js +74 -75
- package/server/threads/threadServer.js +74 -75
- package/studio/build-local/asset-manifest.json +34 -34
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/164.f552d832.chunk.js +1 -0
- package/studio/build-local/static/js/{873.55a21fe5.chunk.js → 708.1805e937.chunk.js} +2 -2
- package/studio/build-local/static/js/{833.22ea9ecd.chunk.js → 833.5847bc85.chunk.js} +1 -1
- package/studio/build-local/static/js/{browse-csvupload.1345356f.chunk.js → browse-csvupload.97e20c4a.chunk.js} +1 -1
- package/studio/build-local/static/js/{browse-datatable.8d180288.chunk.js → browse-datatable.339fb83c.chunk.js} +1 -1
- package/studio/build-local/static/js/{browse-entitymanager.3f0871ba.chunk.js → browse-entitymanager.fd37a083.chunk.js} +1 -1
- package/studio/build-local/static/js/{browse-jsonviewer.7ef3cb49.chunk.js → browse-jsonviewer.f57cc39c.chunk.js} +1 -1
- package/studio/build-local/static/js/{custom-functions.d7869749.chunk.js → custom-functions.f682aa33.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-cluster.ded77459.chunk.js → instance-cluster.e2dba73f.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-config.f3087710.chunk.js → instance-config.4e2c4644.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-logs.fb150c6f.chunk.js → instance-logs.bcec2256.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-roles.32b7be24.chunk.js → instance-roles.1ad69c74.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-status.d7ddf38a.chunk.js → instance-status.4e190908.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-users-datatable.68cb8e34.chunk.js → instance-users-datatable.4a2c57e4.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-users-edit.8de84af8.chunk.js → instance-users-edit.ecf717d1.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-users.ff289f79.chunk.js → instance-users.967796d9.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance.127e14b8.chunk.js → instance.809ece1e.chunk.js} +1 -1
- package/studio/build-local/static/js/{instances.1dd2b960.chunk.js → instances.2eb16b86.chunk.js} +1 -1
- package/studio/build-local/static/js/{main.ea494c13.js → main.2384076c.js} +2 -2
- package/studio/build-local/static/js/{offline-app.029491be.chunk.js → offline-app.86377447.chunk.js} +1 -1
- package/studio/build-local/static/js/{online-app.80d24598.chunk.js → online-app.e65f9ef3.chunk.js} +1 -1
- package/studio/build-local/static/js/{organization-billing.586a6019.chunk.js → organization-billing.1c318ac1.chunk.js} +1 -1
- package/studio/build-local/static/js/{organization-users.0facdb34.chunk.js → organization-users.36a2ed5a.chunk.js} +1 -1
- package/studio/build-local/static/js/{organization.4e2c7ae6.chunk.js → organization.9a81d022.chunk.js} +1 -1
- package/studio/build-local/static/js/{organizations.c8c00251.chunk.js → organizations.af48c8e8.chunk.js} +1 -1
- package/studio/build-local/static/js/{profile.a5fbf515.chunk.js → profile.190afea3.chunk.js} +1 -1
- package/studio/build-local/static/js/{resetPassword.9ad8cde1.chunk.js → resetPassword.50fa5b91.chunk.js} +1 -1
- package/studio/build-local/static/js/{roles-jsonviewer.ad6e2622.chunk.js → roles-jsonviewer.b5d5a908.chunk.js} +1 -1
- package/studio/build-local/static/js/{signIn.3d65d81a.chunk.js → signIn.8fbf4021.chunk.js} +1 -1
- package/studio/build-local/static/js/{signUp.eaa5b3f0.chunk.js → signUp.459d42df.chunk.js} +1 -1
- package/studio/build-local/static/js/{structure-reloader.8c8f5e18.chunk.js → structure-reloader.ceaf6675.chunk.js} +1 -1
- package/studio/build-local/static/js/{topnav.73def1f2.chunk.js → topnav.79dbd3ab.chunk.js} +1 -1
- package/studio/build-local/static/js/{updatePassword.e0a672ee.chunk.js → updatePassword.b05821cb.chunk.js} +1 -1
- package/utility/hdbTerms.d.ts +1 -0
- package/utility/scripts/restartHdb.js +74 -75
- package/studio/build-local/static/js/164.05df362d.chunk.js +0 -1
- /package/studio/build-local/static/js/{873.55a21fe5.chunk.js.LICENSE.txt → 708.1805e937.chunk.js.LICENSE.txt} +0 -0
- /package/studio/build-local/static/js/{main.ea494c13.js.LICENSE.txt → main.2384076c.js.LICENSE.txt} +0 -0
package/bin/harperdb.js
CHANGED
|
@@ -1,138 +1,137 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var T2=Object.create;var yf=Object.defineProperty;var A2=Object.getOwnPropertyDescriptor;var R2=Object.getOwnPropertyNames;var y2=Object.getPrototypeOf,b2=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})},oD=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of R2(t))!b2.call(e,s)&&s!==r&&yf(e,s,{get:()=>t[s],enumerable:!(n=A2(t,s))||n.enumerable});return e};var M=(e,t,r)=>(r=e!=null?T2(y2(e)):{},oD(t||!e||!e.__esModule?yf(r,"default",{value:e,enumerable:!0}):r,e)),C=e=>oD(yf({},"__esModule",{value:!0}),e);var st=w((Bye,lD)=>{var{join:O2,dirname:aD}=require("node:path"),{existsSync:N2,readFileSync:w2}=require("node:fs");function I2(){let t=__dirname,r,n=0;for(;!N2(r=O2(t,"package.json"));)if(t===(t=aD(t))||n++>10)throw new Error("Could not find package root");return r}a(I2,"findPackageJson");var cD=I2(),C2=JSON.parse(w2(cD,"utf8")),P2=aD(cD);lD.exports={packageJson:C2,PACKAGE_ROOT:P2}});var rm=w((kye,uD)=>{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 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=uD.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:()=>tQ,BOOT_PROP_PARAMS:()=>_D,CLUSTERING_FLAG:()=>wQ,CLUSTERING_PROCESSES:()=>F2,CLUSTER_MESSAGE_TYPE_ENUM:()=>jA,CLUSTER_OPERATIONS:()=>EQ,CONFIG_PARAMS:()=>B,CONFIG_PARAM_MAP:()=>pD,DATABASES_DIR_NAME:()=>Rc,DATABASES_PARAM_CONFIG:()=>AQ,DEFAULT_DATABASE_NAME:()=>q2,ESCAPED_FORWARD_SLASH_REGEX:()=>X2,FORWARD_SLASH_REGEX:()=>J2,FUNC_VAL:()=>MQ,GEO_CONVERSION_ENUM:()=>SQ,HDB_COMPONENT_CONFIG_FILE:()=>M2,HDB_CONFIG_FILE:()=>D2,HDB_DEFAULT_CONFIG_FILE:()=>L2,HDB_FILE_PERMISSIONS:()=>nQ,HDB_HOME_DIR_NAME:()=>eQ,HDB_PID_FILE:()=>G2,HDB_PROCESS_SERVICES:()=>k2,HDB_PROC_NAME:()=>v2,HDB_RESTART_SCRIPT:()=>U2,HDB_ROOT_DIR_NAME:()=>VA,HDB_SETTINGS_NAMES:()=>zA,HDB_SUPPORT_ADDRESS:()=>fD,INFO_TABLE_HASH_ATTRIBUTE:()=>lQ,INSERT_MAX_CHARACTER_SIZE:()=>aQ,INSTALL_PROMPTS:()=>oQ,ITC_EVENT_TYPES:()=>QA,JOB_STATUS_ENUM:()=>_Q,JOB_TYPE_ENUM:()=>RQ,JWT_ENUM:()=>Of,LAUNCH_SERVICE_SCRIPTS:()=>K2,LEGACY_CONFIG_PARAMS:()=>TQ,LEGACY_DATABASES_DIR_NAME:()=>im,LICENSE_FILE_NAME:()=>fQ,LICENSE_KEY_DIR_NAME:()=>WA,LICENSE_VALUES:()=>yQ,LOG_LEVELS:()=>V2,LOG_NAMES:()=>$2,MEM_SETTING_KEY:()=>Z2,METADATA_PROPERTY:()=>NQ,NODE_ERROR_CODES:()=>OQ,OPERATIONS_ENUM:()=>Kt,PERMS_CRUD_ENUM:()=>DQ,PERMS_UPDATE_RELEASE_TIMESTAMP:()=>PQ,PRE_4_0_0_VERSION:()=>vQ,PROCESS_DESCRIPTORS:()=>H2,PROCESS_NAME_ENV_PROP:()=>iQ,RAM_ALLOCATION_ENUM:()=>bQ,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:()=>am,REG_KEY_FILE_NAME:()=>dQ,RESTART_TIMEOUT_MS:()=>rQ,ROLE_TYPES_ENUM:()=>Y2,S3_BUCKET_AUTH_KEYS:()=>hQ,SEARCH_NOT_FOUND_MESSAGE:()=>z2,SEARCH_WILDCARDS:()=>LQ,SERVICE_ACTIONS_ENUM:()=>gQ,SUPPORT_HELP_MSG:()=>W2,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:()=>uQ,SYSTEM_SCHEMA_NAME:()=>bf,SYSTEM_TABLE_NAMES:()=>du,THREAD_TYPES:()=>XA,TIME_STAMP_NAMES:()=>CQ,TIME_STAMP_NAMES_ENUM:()=>IQ,TRANSACTIONS_DIR_NAME:()=>sQ,UNICODE_FORWARD_SLASH:()=>Q2,UNICODE_PERIOD:()=>j2,UPGRADE_JSON_FIELD_NAMES_ENUM:()=>cQ,VALID_S3_FILE_TYPES:()=>pQ,VALID_SQL_OPS_ENUM:()=>mQ,VALUE_SEARCH_COMPARATORS:()=>om,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>JA});var nm,sm,D2,L2,VA,M2,v2,U2,dD,$A,KA,YA,x2,B2,H2,k2,F2,G2,q2,$2,V2,K2,Y2,fD,W2,z2,j2,J2,Q2,X2,Z2,bf,eQ,WA,tQ,rQ,nQ,Rc,im,sQ,iQ,_D,oQ,aQ,cQ,du,lQ,uQ,dQ,fQ,_Q,Kt,pQ,hQ,mQ,EQ,gQ,SQ,zA,TQ,B,pD,AQ,RQ,jA,yQ,bQ,OQ,NQ,wQ,hD,mD,IQ,CQ,PQ,om,JA,DQ,LQ,MQ,am,Of,QA,XA,vQ,Ys,la,H=be(()=>{nm=require("node:path"),sm=M(st()),D2="harperdb-config.yaml",L2="defaultConfig.yaml",VA="hdb",M2="config.yaml",v2="harperdb.js",U2="restartHdb.js",dD="HarperDB",$A="Custom Functions",KA="Clustering Hub",YA="Clustering Leaf",x2="Clustering Ingest Service",B2="Clustering Reply Service",H2={HDB:dD,CLUSTERING_HUB:KA,CLUSTERING_LEAF:YA,CLUSTERING_INGEST_SERVICE:x2,CLUSTERING_REPLY_SERVICE:B2,CUSTOM_FUNCTIONS:$A,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"},k2={harperdb:dD,"clustering hub":KA,"clustering leaf":YA,"custom functions":$A,custom_functions:$A,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},F2={CLUSTERING_HUB_PROC_DESCRIPTOR:KA,CLUSTERING_LEAF_PROC_DESCRIPTOR:YA},G2="hdb.pid",q2="data",$2={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},V2={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},K2={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")},Y2={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},fD="support@harperdb.io",W2=`For support, please submit a request at https://harperdbhelp.zendesk.com/hc/en-us/requests/new or contact ${fD}`,z2="None of the specified records were found.",j2="U+002E",J2=/\//g,Q2="U+002F",X2=/U\+002F/g,Z2="--max-old-space-size=",bf="system",eQ=".harperdb",WA="keys",tQ="hdb_boot_properties.file",rQ=6e4,nQ=448,Rc="database",im="schema",sQ="transactions",iQ="PROCESS_NAME",_D={SETTINGS_PATH_KEY:"settings_path"},oQ={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"},aQ=250,cQ={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"},lQ="info_id",uQ={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"},dQ="060493.ks",fQ=".license",_Q={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},Kt={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"},pQ={CSV:".csv",JSON:".json"},hQ={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},mQ={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},EQ={[Kt.INSERT]:Kt.INSERT,[Kt.UPDATE]:Kt.UPDATE,[Kt.UPSERT]:Kt.UPSERT,[Kt.DELETE]:Kt.DELETE},gQ={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"},SQ={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},zA={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"},TQ={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"},pD={settings_path:_D.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];pD[t.toLowerCase()]=t}AQ={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},RQ={csv_file_load:"csv_file_load",csv_data_load:Kt.CSV_DATA_LOAD,csv_url_load:Kt.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"},yQ={VERSION_DEFAULT:"2.2.0"},bQ={DEVELOPMENT:8192,DEFAULT:512},OQ={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},NQ=Symbol("metadata"),wQ="__clustering__",hD="__createdtime__",mD="__updatedtime__",IQ={CREATED_TIME:hD,UPDATED_TIME:mD},CQ=[hD,mD],PQ=15984864e5,om={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},JA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},DQ={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},LQ=["*","%"],MQ="func_val",am={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"},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"},XA={HTTP:"http"},vQ="3.x.x",Ys={SUCCESS:"success",FAILURE:"failure"},la={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var ua=w((Fye,SD)=>{"use strict";var ED=require("minimist");SD.exports=UQ;function UQ(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=gD(process.env),n=gD(ED(process.argv))):(r=process.env,n=ED(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(UQ,"assignCMDENVVariables");function gD(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(gD,"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((vD,UD)=>{"use strict";var no=require("fs-extra"),{workerData:xQ,threadId:BQ,isMainThread:HQ}=require("worker_threads"),Ri=require("path"),yD=require("yaml"),bD=require("properties-reader"),Yt=(H(),C(G)),TD=ua(),kQ=require("os"),{PACKAGE_ROOT:rR}=st(),{_assignPackageExport:FQ}=Ti(),AD=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),mr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},OD={STDOUT:"stdOut",STDERR:"stdErr"},GQ=Ri.join(rR,"logs"),qQ=Ri.join(rR,"config/yaml/",Yt.HDB_DEFAULT_CONFIG_FILE),$Q=1e4,ZA,Ai,ms,Cr,cm,Nf,lm,da,wf;wf===void 0&&ND();Object.assign(vD,{notify:DD,fatal:LD,error:um,warn:MD,info:ID,debug:PD,trace:CD,setLogLevel:QQ,log_level:Cr,loggerWithTag:YQ,suppressLogging:WQ,initLogSettings:ND,logCustomLevel:jQ,closeLogFile:nR,logsAtLevel:VQ,getLogFilePath:a(()=>lm,"getLogFilePath"),OUTPUTS:OD,AuthAuditLog:e4});FQ("logger",UD.exports);var eR;function VQ(e){return mr[Cr]<=mr[e]}a(VQ,"logsAtLevel");function ND(e=!1){try{if(wf===void 0||e){nR();let t=JQ(),r=TD(["ROOTPATH"]);try{wf=bD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!no.pathExistsSync(Ri.join(r.ROOTPATH,Yt.HDB_CONFIG_FILE)))throw n}if({level:Cr,config_log_path:Nf,to_file:Ai,to_stream:ms}=XQ(r.ROOTPATH?Ri.join(r.ROOTPATH,Yt.HDB_CONFIG_FILE):wf.get("settings_path")),cm=Yt.LOG_NAMES.HDB,lm=Ri.join(Nf,cm),HQ)try{require("segfault-handler").registerHandler(Ri.join(Nf,"crash.log"))}catch{}}}catch(t){if(wf=void 0,t.code===Yt.NODE_ERROR_CODES.ENOENT||t.code===Yt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=TD(Object.keys(Yt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Yt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Yt.CONFIG_PARAMS.LOGGING_LEVEL){Cr=l;continue}if(c===Yt.CONFIG_PARAMS.LOGGING_STDSTREAMS){ms=l;continue}c===Yt.CONFIG_PARAMS.LOGGING_FILE&&(Ai=c),c===Yt.CONFIG_PARAMS.LOGGING_CONSOLE&&(ZA=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=ZQ();Ai=Ai===void 0?s:Ai,Ai=RD(Ai),ms=ms===void 0?i:ms,ms=RD(ms),Cr=Cr===void 0?n:Cr,Nf=GQ,cm=Yt.LOG_NAMES.INSTALL,lm=Ri.join(Nf,cm);return}throw um("Error initializing log settings"),um(t),t}process.env.DEV_MODE&&(ms=!0),KQ()}a(ND,"initLogSettings");var fa=!0;function KQ(){Ai&&(process.stdout.write=function(e){return typeof e=="string"&&fa&&ZA!==!1&&(tR(),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 bf=Object.defineProperty;var T2=Object.getOwnPropertyDescriptor;var A2=Object.getOwnPropertyNames;var R2=Object.getPrototypeOf,y2=Object.prototype.hasOwnProperty;var a=(e,t)=>bf(e,"name",{value:t,configurable:!0});var be=(e,t)=>()=>(e&&(t=e(e=0)),t);var I=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Ue=(e,t)=>{for(var r in t)bf(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&&bf(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?bf(r,"default",{value:e,enumerable:!0}):r,e)),P=e=>aD(bf({},"__esModule",{value:!0}),e);var st=I((Hye,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 sm=I((Fye,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}=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,N=0;try{A=i(n(d,E)).mtimeMs-5e3,N=i(n(d,_,E.replace(/.ts$/,".js"))).mtimeMs}catch{}return A>N}):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"),N=!1;if(s(A))try{process.kill(+o(A,"utf8"),0),N=!0}catch{}if(!N){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=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 A=r(d,R[0]),N;A.startsWith(_)?N=n(d,r(_,A)):N=n(d,_,A);let v=n(N,g),F=v+".js";if(s(F))return F;if(v.includes(".")&&s(v))return v}return S(g,R,E)}}});var G={};Ue(G,{AUTH_AUDIT_STATUS:()=>Ws,AUTH_AUDIT_TYPES:()=>ua,BOOT_PROPS_FILE_NAME:()=>eQ,BOOT_PROP_PARAMS:()=>pD,CLUSTERING_FLAG:()=>NQ,CLUSTERING_PROCESSES:()=>k2,CLUSTER_MESSAGE_TYPE_ENUM:()=>QA,CLUSTER_OPERATIONS:()=>mQ,CONFIG_PARAMS:()=>x,CONFIG_PARAM_MAP:()=>hD,DATABASES_DIR_NAME:()=>wc,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:()=>YA,HDB_SETTINGS_NAMES:()=>JA,HDB_SUPPORT_ADDRESS:()=>_D,INFO_TABLE_HASH_ATTRIBUTE:()=>cQ,INSERT_MAX_CHARACTER_SIZE:()=>oQ,INSTALL_PROMPTS:()=>iQ,ITC_EVENT_TYPES:()=>ZA,JOB_STATUS_ENUM:()=>fQ,JOB_TYPE_ENUM:()=>AQ,JWT_ENUM:()=>Nf,LAUNCH_SERVICE_SCRIPTS:()=>V2,LEGACY_CONFIG_PARAMS:()=>SQ,LEGACY_DATABASES_DIR_NAME:()=>am,LICENSE_FILE_NAME:()=>dQ,LICENSE_KEY_DIR_NAME:()=>jA,LICENSE_VALUES:()=>RQ,LOG_LEVELS:()=>$2,LOG_NAMES:()=>q2,MEM_SETTING_KEY:()=>X2,METADATA_PROPERTY:()=>OQ,NODE_ERROR_CODES:()=>bQ,OPERATIONS_ENUM:()=>Kt,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:()=>lm,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:()=>Of,SYSTEM_TABLE_NAMES:()=>_u,THREAD_TYPES:()=>eR,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:()=>cm,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>XA});var im,om,P2,D2,YA,L2,M2,v2,fD,KA,WA,zA,U2,x2,B2,H2,k2,F2,G2,q2,$2,V2,K2,_D,Y2,W2,z2,j2,J2,Q2,X2,Of,Z2,jA,eQ,tQ,rQ,wc,am,nQ,sQ,pD,iQ,oQ,aQ,_u,cQ,lQ,uQ,dQ,fQ,Kt,_Q,pQ,hQ,mQ,EQ,gQ,JA,SQ,x,hD,TQ,AQ,QA,RQ,yQ,bQ,OQ,NQ,mD,ED,wQ,IQ,CQ,cm,XA,PQ,DQ,LQ,lm,Nf,ZA,eR,MQ,Ws,ua,H=be(()=>{im=require("node:path"),om=M(st()),P2="harperdb-config.yaml",D2="defaultConfig.yaml",YA="hdb",L2="config.yaml",M2="harperdb.js",v2="restartHdb.js",fD="HarperDB",KA="Custom Functions",WA="Clustering Hub",zA="Clustering Leaf",U2="Clustering Ingest Service",x2="Clustering Reply Service",B2={HDB:fD,CLUSTERING_HUB:WA,CLUSTERING_LEAF:zA,CLUSTERING_INGEST_SERVICE:U2,CLUSTERING_REPLY_SERVICE:x2,CUSTOM_FUNCTIONS:KA,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":WA,"clustering leaf":zA,"custom functions":KA,custom_functions:KA,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},k2={CLUSTERING_HUB_PROC_DESCRIPTOR:WA,CLUSTERING_LEAF_PROC_DESCRIPTOR:zA},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,im.join)(om.PACKAGE_ROOT,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:(0,im.join)(om.PACKAGE_ROOT,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:(0,im.join)(om.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=",Of="system",Z2=".harperdb",jA="keys",eQ="hdb_boot_properties.file",tQ=6e4,rQ=448,wc="database",am="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"},_u={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"},Kt={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={[Kt.INSERT]:Kt.INSERT,[Kt.UPDATE]:Kt.UPDATE,[Kt.UPSERT]:Kt.UPSERT,[Kt.DELETE]:Kt.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:Kt.CSV_DATA_LOAD,csv_url_load:Kt.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"},QA={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,cm={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},XA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},PQ={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},DQ=["*","%"],LQ="func_val",lm={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},Nf={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},ZA={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"},eR={HTTP:"http"},MQ="3.x.x",Ws={SUCCESS:"success",FAILURE:"failure"},ua={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var da=I((Gye,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 Ai=I(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 W=I((UD,xD)=>{"use strict";var so=require("fs-extra"),{workerData:UQ,threadId:xQ,isMainThread:BQ}=require("worker_threads"),yi=require("path"),bD=require("yaml"),OD=require("properties-reader"),Yt=(H(),P(G)),AD=da(),HQ=require("os"),{PACKAGE_ROOT:sR}=st(),{_assignPackageExport:kQ}=Ai(),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=yi.join(sR,"logs"),GQ=yi.join(sR,"config/yaml/",Yt.HDB_DEFAULT_CONFIG_FILE),qQ=1e4,tR,Ri,Es,Pr,um,wf,dm,fa,If;If===void 0&&wD();Object.assign(UD,{notify:LD,fatal:MD,error:fm,warn:vD,info:CD,debug:DD,trace:PD,setLogLevel:JQ,log_level:Pr,loggerWithTag:KQ,suppressLogging:YQ,initLogSettings:wD,logCustomLevel:zQ,closeLogFile:iR,logsAtLevel:$Q,getLogFilePath:a(()=>dm,"getLogFilePath"),OUTPUTS:ND,AuthAuditLog:ZQ});kQ("logger",xD.exports);var rR;function $Q(e){return Er[Pr]<=Er[e]}a($Q,"logsAtLevel");function wD(e=!1){try{if(If===void 0||e){iR();let t=jQ(),r=AD(["ROOTPATH"]);try{If=OD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!so.pathExistsSync(yi.join(r.ROOTPATH,Yt.HDB_CONFIG_FILE)))throw n}if({level:Pr,config_log_path:wf,to_file:Ri,to_stream:Es}=QQ(r.ROOTPATH?yi.join(r.ROOTPATH,Yt.HDB_CONFIG_FILE):If.get("settings_path")),um=Yt.LOG_NAMES.HDB,dm=yi.join(wf,um),BQ)try{require("segfault-handler").registerHandler(yi.join(wf,"crash.log"))}catch{}}}catch(t){if(If=void 0,t.code===Yt.NODE_ERROR_CODES.ENOENT||t.code===Yt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=AD(Object.keys(Yt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Yt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Yt.CONFIG_PARAMS.LOGGING_LEVEL){Pr=l;continue}if(c===Yt.CONFIG_PARAMS.LOGGING_STDSTREAMS){Es=l;continue}c===Yt.CONFIG_PARAMS.LOGGING_FILE&&(Ri=c),c===Yt.CONFIG_PARAMS.LOGGING_CONSOLE&&(tR=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=XQ();Ri=Ri===void 0?s:Ri,Ri=yD(Ri),Es=Es===void 0?i:Es,Es=yD(Es),Pr=Pr===void 0?n:Pr,wf=FQ,um=Yt.LOG_NAMES.INSTALL,dm=yi.join(wf,um);return}throw fm("Error initializing log settings"),fm(t),t}process.env.DEV_MODE&&(Es=!0),VQ()}a(wD,"initLogSettings");var _a=!0;function VQ(){Ri&&(process.stdout.write=function(e){return typeof e=="string"&&_a&&tR!==!1&&(nR(),e=e.toString(),e[e.length-1]===`
|
|
3
|
+
`&&(e=e.slice(0,-1)),so.appendFileSync(fa,js("stdout",[e]))),RD.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&_a&&tR!==!1&&(nR(),e[e.length-1]===`
|
|
4
|
+
`&&(e=e.slice(0,-1)),so.appendFileSync(fa,js("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(fm,"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{_a=!1,e()}finally{_a=!0}}a(YQ,"suppressLogging");var WQ=UQ?.name?.replace(/ /g,"-")||"main";function js(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:r4.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(o4,"findPs")});var Ut=w((Yye,HD)=>{"use strict";var a4="__dbis__",c4="__txns__",l4="__environment_name__",u4="__dbi_defintion__",d4={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"},f4=["__createdtime__","__updatedtime__"],_4="\uFFFF",BD={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},p4=Object.values(BD);HD.exports={AUDIT_STORE_NAME:c4,INTERNAL_DBIS_NAME:a4,DBI_DEFINITION_NAME:u4,SEARCH_TYPES:d4,TIMESTAMP_NAMES:f4,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:l4,TRANSACTIONS_DBI_NAMES_ENUM:BD,TRANSACTIONS_DBIS:p4,OVERFLOW_MARKER:_4}});var Un=w((Wye,WD)=>{"use strict";var kD=(H(),C(G)),FD=Ut(),GD={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},qD=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),$D={500:qD("There was an error processing your request."),400:"Invalid request"},h4=$D[GD.INTERNAL_SERVER_ERROR],m4={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")},E4={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},g4={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"},S4={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 ${FD.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${FD.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"},T4={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${kD.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 ${kD.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"},VD={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"},A4={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."},R4={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")},y4={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"},b4={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},O4={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")},KD={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")},YD={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")},N4={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"},w4={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},I4={...VD,...g4,...m4,...A4,...R4,...y4,...b4,...O4,...T4,...KD,...YD,...N4,...w4,...E4};WD.exports={CHECK_LOGS_WRAPPER:qD,HDB_ERROR_MSGS:I4,DEFAULT_ERROR_MSGS:$D,DEFAULT_ERROR_RESP:h4,HTTP_STATUS_CODES:GD,LMDB_ERRORS_ENUM:S4,AUTHENTICATION_ERROR_MSGS:VD,VALIDATION_ERROR_MSGS:KD,ITC_ERRORS:YD}});var pe=w((jye,JD)=>{"use strict";var fu=Un(),C4=z(),P4=(H(),C(G)),fm=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,zD),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&&C4[s](i)}},iR=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}},oR=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function zD(e,t,r,n=P4.LOG_LEVELS.ERROR,s=null,i=!1){if(jD(e))return e;let o=new fm(e,t,r,n,s);return i&&delete o.stack,o}a(zD,"handleHDBError");function jD(e){return e.__proto__.constructor.name===fm.name}a(jD,"isHDBError");JD.exports={isHDBError:jD,handleHDBError:zD,ClientError:iR,ServerError:oR,hdb_errors:fu}});var gt=w((Qye,nL)=>{"use strict";var Mf=(H(),C(G)),D4=ie(),fn=ae(),vf=require("path"),L4=require("minimist"),QD=require("fs-extra"),XD=require("lodash");fn.initSync();var{CONFIG_PARAMS:_a,DATABASES_PARAM_CONFIG:Cf,SYSTEM_SCHEMA_NAME:_m}=Mf,Pf,Df,Lf;function ZD(){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(ZD,"getBaseSchemaPath");function eL(){if(Df!==void 0)return Df;if(fn.getHdbBasePath()!==void 0)return Df=rL(_m),Df}a(eL,"getSystemSchemaPath");function tL(){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(tL,"getTransactionAuditStoreBasePath");function M4(e,t){let r=fn.get(_a.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||vf.join(tL(),e.toString())}a(M4,"getTransactionAuditStorePath");function rL(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(ZD(),e)}a(rL,"getSchemaPath");function v4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,L4(process.argv));let n=r[_a.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!D4.isObject(n))throw o;i=n}for(let o of i){let c=o[_m];if(!c)continue;let l=fn.get(_a.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Cf.PATH];if(u)return XD.set(l,[_m,Cf.TABLES,t,Cf.PATH],u),fn.setProperty(_a.DATABASES,l),u;let f=c?.[Cf.PATH];if(f)return XD.set(l,[_m,Cf.PATH],f),fn.setProperty(_a.DATABASES,l),f}}let s=r[_a.STORAGE_PATH.toUpperCase()];if(s){if(!QD.pathExistsSync(s))throw new Error(s+" does not exist");let i=vf.join(s,e);return QD.mkdirsSync(i),fn.setProperty(_a.STORAGE_PATH,s),i}return eL()}a(v4,"initSystemSchemaPaths");function U4(){Pf=void 0,Df=void 0,Lf=void 0}a(U4,"resetPaths");nL.exports={getBaseSchemaPath:ZD,getSystemSchemaPath:eL,getTransactionAuditStorePath:M4,getTransactionAuditStoreBasePath:tL,getSchemaPath:rL,initSystemSchemaPaths:v4,resetPaths:U4}});var _n=w((tbe,cL)=>{"use strict";var x4=Un().LMDB_ERRORS_ENUM,Zye=require("lmdb"),B4=Ut(),ebe=require("buffer").Buffer,{OVERFLOW_MARKER:sL,MAX_SEARCH_KEY_LENGTH:pm}=B4,iL=["number","string","symbol","boolean","bigint"];function H4(e){if(e=e?.primaryStore||e,!e)throw new Error(x4.ENV_REQUIRED)}a(H4,"validateEnv");function k4(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(k4,"stringifyData");function F4(e){return e instanceof Date?e.valueOf():e}a(F4,"convertKeyValueToWrite");function G4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(iL.includes(typeof e))return e.length>pm?[e.slice(0,pm)+sL]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(iL.includes(typeof i))i.length>pm?r.push(i.slice(0,pm)+sL):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(G4,"getIndexedValues");var hm=0,oL=0;function aL(){oL=Date.now()-performance.now()}a(aL,"adjustStartTime");aL();var q4=6e4;setInterval(aL,q4).unref();function $4(){let e=performance.now()+oL;return e>hm?(hm=e,e):(hm+=488e-6,hm)}a($4,"getNextMonotonicTime");cL.exports={validateEnv:H4,stringifyData:k4,convertKeyValueToWrite:F4,getNextMonotonicTime:$4,getIndexedValues:G4}});var Uf=w((nbe,lL)=>{"use strict";var V4=(H(),C(G)).OPERATIONS_ENUM,aR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=V4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};lL.exports=aR});var xf=w((obe,_L)=>{"use strict";var ibe=Uf(),mm=(H(),C(G)),cR=ie(),uL=z(),K4=require("uuid"),{handleHDBError:Em,hdb_errors:Y4}=pe(),{HDB_ERROR_MSGS:gm,HTTP_STATUS_CODES:Sm}=Y4;_L.exports=dL;function dL(e,t,r){for(let s=0;s<t.length;s++)fL(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];W4(i,r,e.operation)}}a(dL,"processRows");dL.validateAttribute=fL;function fL(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(cR.isEmptyOrZeroLength(e)||cR.isEmpty(e.trim()))throw Em(new Error,gm.ATTR_NAME_NULLISH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(fL,"validateAttribute");function W4(e,t,r){if(!e.hasOwnProperty(t)||cR.isEmptyOrZeroLength(e[t])){if(r===mm.OPERATIONS_ENUM.INSERT||r===mm.OPERATIONS_ENUM.UPSERT){e[t]=K4.v4();return}throw uL.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 uL.error(e),Em(new Error,gm.HASH_VAL_LENGTH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(W4,"validateHash")});var pL,xn,lR,_u=be(()=>{pL=require("events"),xn=class extends pL.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new lR;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)}},lR=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 AL(e){dR=e}function Q4(){J4=setInterval(function(){for(let e of uR)if(e.stale){let t=e.getContext()?.url;gL.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},j4).unref()}var fR,EL,gL,SL,TL,hL,uR,z4,Bf,mL,dR,yc,Tm,j4,J4,Am=be(()=>{fR=M(_n()),EL=M(pe()),gL=M(z()),SL=M(ae());H();TL=M(ie()),hL=100,uR=new Set,z4=(0,TL.convertToMS)(SL.get(B.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(AL,"replicationConfirmation");yc=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),uR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn?.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(uR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(Bf&&!this.overloadChecked&&performance.now()-mL>z4)throw new EL.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,fR.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)<hL>>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,mL=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];dR&&_&&i.push(dR(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)+hL/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 yc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,fR.getNextMonotonicTime)())}getReadTxn(){}},j4=3e4;a(Q4,"startMonitoringTxns");Q4()});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 yc;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 RL,bc=be(()=>{RL=M(Ti());Am();a(Nt,"transaction");(0,RL._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 pR(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?pR(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",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&&_&&(_=o3(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],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=mu({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=r3(F,T,b.primaryStore,q,v)}if(T.relationship.from){let q=a(Y=>(Y?.key!==void 0&&(Y=Y.key),mu({attribute:T.relationship.from,value:Y},t,r,n,s,v)),"searchEntry");T.elements?(i[o[0]]=v,F=n3(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(hR[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&(Bn|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 r3(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 n3(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()),hR[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&&ym(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=mu(e,r.transaction.getReadTxn(),!1,t).map(Eu),F=new Set(v);R.idFilter=q=>F.has(Eu(q)),R.idFilter.idSet=F}return b}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/so(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=hR[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=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*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=e3*so(e.primaryStore)+1:n==="between"?r.estimated_count=Z4*so(e.primaryStore)+1:n==="sort"?r.estimated_count=so(e.primaryStore)+1:r.estimated_count=X4*so(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(ha=e,pu.lastIndex=0,s3.test(e))try{let t=Hf(new hu,"");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=pu,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=yL}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=t3[d],l=_R[i]?yL: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"&&bL(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(kf(f)),s=void 0;break;case"(":pu.lastIndex=pn;let _=Hf(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=OL(_);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");pu.lastIndex=pn,p=Hf([],"}"),p.name=f,e.push(p),ha[pn]===","?r.lastIndex=++pn:o=!0;break;case"[":pu.lastIndex=pn,f?(p=Hf(new hu,"]"),p.name=f):p=Hf(e.conditions?new hu:[],"]"),e.conditions?(Rm(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"&&bL(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(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?i3:pu,r.lastIndex=pn),pn===ha.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 kf(e){return e.indexOf(".")>-1?e.split(".").map(kf):decodeURIComponent(e)}function yL(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 bL(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 OL(e){let t=NL(e[0]);return e.length>1&&(t.next=OL(e.slice(1))),t}function NL(e){if(Array.isArray(e)){let t=NL(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 so(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function o3(e,t,r){return t*r/so(e)}var hn,Es,yi,pa,X4,Z4,e3,t3,_R,hR,s3,pu,i3,pn,ha,hu,Oc,Gf=be(()=>{hn=M(pe()),Es=M(Ut()),yi=require("ordered-binary"),pa=require("lmdb");qf();X4=.3,Z4=.1,e3=.05,t3={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},_R={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(pR,"executeConditions");a(mu,"searchByIndex");a(bi,"findAttribute");a(r3,"joinTo");a(n3,"joinFrom");hR={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(ym,"estimateCondition");s3=/[()[\]|!<>.]|(=\w*=)/,pu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,i3=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(bm,"parseQuery");a(Hf,"parseBlock");a(Rm,"assignOperator");a(kf,"decodeProperty");a(yL,"typedDecoding");a(bL,"wildcardDecoding");a(OL,"toSortObject");a(NL,"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(so,"estimatedEntryCount");a(o3,"intersectionEstimate");Oc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var ER={};ve(ER,{MultiPartId:()=>Nm,Resource:()=>$r,snake_case:()=>c3,transformForSelect:()=>wm});function c3(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function wL(e,t){if(Nc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Nc=!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){Nc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Nc=!0,null;e[e.length-1]==="/"&&(Nc=!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 Oc(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 kn(e,t){let r=new PL.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 mR(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):mR(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(mR(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(mR(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 IL,CL,PL,a3,$r,Om,Nc,Nm,Ea=be(()=>{IL=require("crypto");_u();CL=M(Ti()),PL=M(pe());bc();Gf();a3={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=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=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,IL.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):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=wm(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 bm(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1),c=r?.headers&&a3[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:wL(t,this),isCollection:Nc}}let i=wL(t,this);return Nc?{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 xn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new xn}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,CL._assignPackageExport)("Resource",$r);a(c3,"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(wL,"pathToId");Nm=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(Hn,"transactional");a(kn,"missingMethod");a(mR,"selectFromObject");a(wm,"transformForSelect")});var ga,gR=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 ML={};ve(ML,{Resources:()=>Im,keyArrayToString:()=>gu,resetResources:()=>l3,resources:()=>Oi});function l3(){return Oi=new Im}function gu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var DL,LL,Im,Oi,Su=be(()=>{bc();gR();DL=M(z()),LL=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 LL.ServerError(`Conflicting paths for ${t}`);DL.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 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(l3,"resetResources");a(gu,"keyArrayToString")});var Tu={};ve(Tu,{server:()=>Ye});var vL,Ye,Vr=be(()=>{vL=M(Ti()),Ye={};(0,vL._assignPackageExport)("server",Ye)});var AR={};ve(AR,{loadGQLSchema:()=>f3,start:()=>TR,startOnMainThread:()=>d3});function TR({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):u3.includes(R.type)||(0,xL.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,SR.dirname)(n),R.tableClass):i.set((0,SR.dirname)(n)+"/"+(R.export.name||R.type),R.tableClass,R.export));function g(R,E,T){return new UL.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 SR,UL,xL,u3,d3,f3,BL=be(()=>{SR=require("path"),UL=require("node:vm");Pe();xL=M(et()),u3=["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(TR,"start");d3=TR,f3=TR({ensureTable:ft}).handleFile});var VL={};ve(VL,{parse:()=>yR,streamAsJSON:()=>$f,stringify:()=>wc});function $f(e){return new RR({value:e})}function HL(e){return console.error(e),JSON.stringify(e.toString())}function kL(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function wc(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===qL)return $L(e);if(t.resolution)return t.resolution.then(()=>wc(e));throw t}}function $L(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+=$L(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+wc(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function yR(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),h3.test(e)?_3.parse(e):JSON.parse(e)):null}var FL,GL,_3,p3,qL,RR,h3,bR=be(()=>{FL=require("stream"),GL=M(require("json-bigint-fixes")),_3=(0,GL.default)({useNativeBigInt:!0}),p3=1e4,qL={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw qL};a($f,"streamAsJSON");RR=class extends FL.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),HL)}catch(s){yield HL(s)}else yield wc(t)}else yield wc(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);kL(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>p3?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 kL(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(HL,"handleError");a(kL,"when");a(wc,"stringify");a($L,"jsStringify");h3=/[[,:]\s*-?\d{16,}/;a(yR,"parse")});var Ni=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:()=>wi,blobsWereEncoded:()=>Cc,databasePaths:()=>Mm,decodeBlobsWithWrites:()=>IR,decodeFromDatabase:()=>Pc,decodeWithBlobCallback:()=>CR,deleteBlob:()=>ZL,deleteBlobsInObject:()=>Ta,deleteRootBlobPathsForDB:()=>wR,encodeBlobsAsBuffers:()=>O3,encodeBlobsWithFilePath:()=>km,findBlobsInObject:()=>Ru,getFileId:()=>Bm,getFilePathForBlob:()=>tM,getRootBlobPathsForDB:()=>Hm,setDeletionDelay:()=>S3});function QL(){}function ZL(e){let t=tM(e);t&&setTimeout(()=>{(0,je.unlink)(t,r=>{r&&Sa.default.debug?.("Error trying to remove blob file",r)})},XL)}function S3(e){XL=e}function eM(e){let t=mn.get(e);if(!t)t={storageIndex:0,fileId:null,store:js},mn.set(e,t);else{if(t.saving)return t;t.store=js}return A3(t),t.source?OR(e,t.source,t):t.contentBuffer?T3(e,t):OR(e,Kf.Readable.from(e.stream()),t),t}function OR(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(E3),_=(0,Um.createDeflate)(),t.pipe(_).pipe(d)):(p||d.write(m3),t.pipe(d)),t.on("error",S);function h(g){let R=BigInt(g),E=new Uint8Array(Er),T=new DataView(E.buffer);return R|=BigInt(o?NR:JL)<<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-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 tM(e){let t=mn.get(e);return t?.fileId&&Yf(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,oo.join)(n,e.databaseName)):t=[(0,oo.join)((0,xm.getHdbBasePath)(),"blobs",e.databaseName)],Mm.set(e,t)}return t}async function wR(e){let t=Mm.get(e);t&&await Promise.all(t.map(r=>rM(r)))}async function rM(e){for(let t of await(0,Js.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await rM((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=Hm(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 T3(e,t){let r=t.contentBuffer,n=r.length;if(!(n<jL))return e.size=n,OR(e,Kf.Readable.from([r]),t)}function A3(e){let t=Hm(e.store),r=R3(),n=t?.length>1?y3(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,zL.ensureDirSync)(o),e.filePath=i}function R3(){let e=WL.get(js);if(!e){let t=0,r=Hm(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)),WL.set(js,e)}return Number(Atomics.add(e,0,1n))}function y3(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,b3(e)),e.frequencyTable[t%vm]}async function b3(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,js=r,Cc=!1;try{return e()}finally{Au=void 0,js=void 0}}function O3(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 IR(e,t){try{Pr=[],Ic=t,e()}catch(n){throw Ic=void 0,Pr=void 0,n}Ic=void 0;let r=Pr.length<2?Pr[0]:Promise.all(Pr);return Pr=void 0,r}function CR(e,t){try{return Ic=t,e()}finally{Ic=void 0}}function Pc(e,t){return js=t,e()}function Ta(e){Ru(e,t=>{ZL(t)})}function Ru(e,t){if(e instanceof wi)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&Ru(r,t);else if(e.constructor===Object)for(let r in e){let n=e[r];typeof n=="object"&&n&&Ru(e[r],t)}}function N3(){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,Um,Kf,zL,xm,oo,Sa,jL,Er,JL,NR,KL,m3,E3,YL,mn,Ic,wi,Au,Pr,js,Cc,Vf,Dm,g3,Lm,XL,Mm,WL,vm,gs=be(()=>{io=require("msgpackr"),Js=require("node:fs/promises"),je=require("node:fs"),Um=require("node:zlib"),Kf=require("node:stream"),zL=require("fs-extra"),xm=M(ae());H();oo=require("path"),Sa=M(Ni());ao();jL=8192,Er=8,JL=0,NR=1,KL=255,m3=new Uint8Array([0,JL,255,255,255,255,255,255]),E3=new Uint8Array([0,NR,255,255,255,255,255,255]),YL=0xffffffffffff,mn=new WeakMap,wi=global.Blob||N3(),Cc=!1,Vf=new Uint8Array(8),Dm=new DataView(Vf.buffer),g3=6e4;a(QL,"InstanceOfBlobWithNoConstructor");QL.prototype=wi.prototype;Lm=class e extends QL{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):(DR()&&PR(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=Yf(t),o,c=a(async()=>{let l,u=Er;try{if(l=await(0,Js.readFile)(i),l.length>=Er){l.copy(Vf,0,0,Er);let d=Dm.getBigUint64(0);if(Number(d>>48n)===KL)throw new Error("Error in blob: "+buffer.subarray(Er));if(u=Number(d&0xffffffffffffn),u<n&&(u=n),u<YL&&(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]===NR?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(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<Er){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,Er);let se=Dm.getBigUint64(0);if(Number(se>>48n)===KL)return v(new Error("Error in blob: "+Z.subarray(Er)));if(g=Number(se&0xffffffffffffn),g<YL&&_.size!==g&&(_.size=g,_.#t))for(let Q of _.#t)Q(g);Z=Z.subarray(Er,Y),l-=Er}else if(Y===0){let se=Buffer.allocUnsafe(8);return(0,je.read)(o,se,0,Er,0,Q=>{if(Q)return v(Q);if(Vf.set(se),g=Number(Dm.getBigUint64(0)&0xffffffffffffn),g>l){h()?u?f=setTimeout(()=>{v(new Error("File read timed out"))},g3).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=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 eM(this).saving??Promise.resolve()}},XL=500;a(ZL,"deleteBlob");a(S3,"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 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(eM,"saveBlob");a(OR,"writeBlobWithStream");a(Bm,"getFileId");a(tM,"getFilePathForBlob");Mm=new Map;a(Hm,"getRootBlobPathsForDB");a(wR,"deleteRootBlobPathsForDB");a(rM,"rimrafSteadily");a(Yf,"getFilePath");a(T3,"writeBlobWithBuffer");a(A3,"generateFilePath");WL=new Map;a(R3,"getNextFileId");vm=128;a(y3,"getNextStorageIndex");a(b3,"createFrequencyTableForStoragePaths");a(km,"encodeBlobsWithFilePath");a(O3,"encodeBlobsAsBuffers");a(IR,"decodeBlobsWithWrites");a(CR,"decodeWithBlobCallback");a(Pc,"decodeFromDatabase");a(Ta,"deleteBlobsInObject");a(Ru,"findBlobsInObject");(0,io.addExtension)({Class:wi,type:11,unpack:a(function(e){let t=(0,io.unpack)(e),r=new Lm;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(mn.set(r,{storageIndex:t[1],fileId:t[2],store:js}),Ic)return Ic(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&&(Cc=!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<jL)return r.size=t.contentBuffer.length,(0,io.pack)([r,t.contentBuffer])}if(Au!==void 0){if(t=eM(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Au,(0,io.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,je.readFileSync)(Yf(t));if(n.length>=Er&&(n.copy(Vf,0,0,Er),Number(Dm.getBigUint64(0)&0xffffffffffffn)===n.length-Er))return Buffer.concat([(0,io.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,io.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(N3,"polyfillBlob")});var uM={};ve(uM,{asyncSerialization:()=>PR,contentTypes:()=>UR,findBestSerializer:()=>qm,getDeserializer:()=>uo,hasAsyncSerialization:()=>DR,registerContentHandlers:()=>jf,serialize:()=>Jf,serializeMessage:()=>Aa,toCsvStream:()=>Gm});function I3(e){try{return e?.[0]===123?vR(e):e}catch{return e}}function jf(e){e.register(P3,{serializers:[{regex:/^application\/json$/,serializer:$f},{regex:/^application\/cbor$/,serializer:a(function(t){return new Dc.EncoderStream(zf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Lc.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"'),Gm(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,Dc.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 iM.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=sM&&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=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}),MR.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>sM?(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=qm(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 PR(e){if(co)co.push(e);else throw new Error("Unable to serialize asynchronously")}function DR(){return!!co}function D3(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 M3(e){return L3.includes(e)}function v3(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=v3(e),n=r.type&&Kr.get(r.type)?.deserialize||U3(r);return t?s=>D3(s).then(n):n}function U3(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!M3(e.parameters.charset)&&MR.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 vR(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function x3(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=Lc.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 w3(n,s);return r.pipe(i)}var Ii,Dc,lo,iM,Lc,oM,LR,aM,MR,w3,cM,Wf,vR,zf,Kr,UR,nM,lM,C3,P3,sM,co,L3,ao=be(()=>{bR();Ii=require("msgpackr"),Dc=require("cbor-x"),lo=require("zlib"),iM=M(pe()),Lc=M(require("stream"));Vr();oM=M(Ti()),LR=M(ae());H();aM=M(require("yaml")),MR=M(Ni());gs();({Transform:w3}=require("json2csv")),cM=LR.default.get(B.SERIALIZATION_BIGINT)!==!1,Wf=cM?wc:JSON.stringify,vR=cM?yR:JSON.parse,zf={useRecords:!1,useToJSON:!0},Kr=new Map,UR=Kr;Ye.contentTypes=UR;(0,oM._assignPackageExport)("contentTypes",UR);Kr.set("application/json",{serializeStream:$f,serialize:Wf,deserialize(e){return vR(e)},q:.8});nM=new Dc.Encoder(zf);Kr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Dc.EncoderStream(zf).end(e)},serialize:nM.encode,deserialize:nM.decode,q:1});Kr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Lc.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"'),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 Lc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Kr.set("text/yaml",{serialize(e){return aM.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Kr.set("text/event-stream",{serializeStream:a(function(e){return Lc.Readable.from(x3(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
|
-
`),e.data){let r=e.data;typeof r=="object"&&(r=
|
|
7
|
+
`}a(js,"createLogRecord");function Cf(e){if(Ri){if(ID(e),Es){_a=!1;try{process.stdout.write(e)}finally{_a=!0}}}else Es&&process.stdout.write(e)}a(Cf,"logStdOut");function _m(e){if(Ri){if(ID(e),Es){_a=!1;try{process.stderr.write(e)}finally{_a=!0}}}else Es&&process.stderr.write(e)}a(_m,"logStdErr");function ID(e){nR(),fa?so.appendFileSync(fa,e):rR||console.log(e)}a(ID,"logToFile");function iR(){try{so.closeSync(fa)}catch{}fa=null}a(iR,"closeLogFile");function nR(){if(!fa){try{fa=so.openSync(dm,"a")}catch(e){rR||(rR=!0,console.error(e))}setTimeout(()=>{iR()},qQ).unref()}}a(nR,"openLogFile");function CD(...e){Er[Pr]<=Er.info&&Cf(js("info",e))}a(CD,"info");function PD(...e){Er[Pr]<=Er.trace&&Cf(js("trace",e))}a(PD,"trace");function fm(...e){Er[Pr]<=Er.error&&_m(js("error",e))}a(fm,"error");function DD(...e){Er[Pr]<=Er.debug&&Cf(js("debug",e))}a(DD,"debug");function LD(...e){Er[Pr]<=Er.notify&&Cf(js("notify",e))}a(LD,"notify");function MD(...e){Er[Pr]<=Er.fatal&&_m(js("fatal",e))}a(MD,"fatal");function vD(...e){Er[Pr]<=Er.warn&&_m(js("warn",e))}a(vD,"warn");function zQ(e,t,...r){t===ND.STDERR?_m(js(e,r)):Cf(js(e,r))}a(zQ,"logCustomLevel");function jQ(){let e;try{e=HQ.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=yi.join(e,Yt.HDB_HOME_DIR_NAME,Yt.BOOT_PROPS_FILE_NAME);return so.existsSync(t)||(t=yi.join(sR,"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(Yt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:yi.dirname(o.get(Yt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Yt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Yt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=bD.parseDocument(so.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===Yt.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(so.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 oR=I((Kye,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=I((Wye,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 Bn=I((zye,zD)=>{"use strict";var FD=(H(),P(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=I((Jye,QD)=>{"use strict";var pu=Bn(),I4=W(),C4=(H(),P(G)),pm=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,jD),this.statusCode=n||pu.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(pu.DEFAULT_ERROR_MSGS[n]?pu.DEFAULT_ERROR_MSGS[n]:pu.DEFAULT_ERROR_MSGS[pu.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)}},aR=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}},cR=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 pm(e,t,r,n,s);return i&&delete o.stack,o}a(jD,"handleHDBError");function JD(e){return e.__proto__.constructor.name===pm.name}a(JD,"isHDBError");QD.exports={isHDBError:JD,handleHDBError:jD,ClientError:aR,ServerError:cR,hdb_errors:pu}});var Et=I((Xye,sL)=>{"use strict";var vf=(H(),P(G)),P4=ae(),_n=ce(),Uf=require("path"),D4=require("minimist"),XD=require("fs-extra"),ZD=require("lodash");_n.initSync();var{CONFIG_PARAMS:pa,DATABASES_PARAM_CONFIG:Pf,SYSTEM_SCHEMA_NAME:hm}=vf,Df,Lf,Mf;function eL(){if(Df!==void 0)return Df;if(_n.getHdbBasePath()!==void 0)return Df=_n.get(pa.STORAGE_PATH)||Uf.join(_n.getHdbBasePath(),vf.DATABASES_DIR_NAME),Df}a(eL,"getBaseSchemaPath");function tL(){if(Lf!==void 0)return Lf;if(_n.getHdbBasePath()!==void 0)return Lf=nL(hm),Lf}a(tL,"getSystemSchemaPath");function rL(){if(Mf!==void 0)return Mf;if(_n.getHdbBasePath()!==void 0)return Mf=_n.get(vf.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Uf.join(_n.getHdbBasePath(),vf.TRANSACTIONS_DIR_NAME),Mf}a(rL,"getTransactionAuditStoreBasePath");function L4(e,t){let r=_n.get(pa.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Uf.join(rL(),e.toString())}a(L4,"getTransactionAuditStorePath");function nL(e,t){e=e.toString(),t=t&&t.toString();let r=_n.get(vf.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Uf.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[pa.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[hm];if(!c)continue;let l=_n.get(pa.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Pf.PATH];if(u)return ZD.set(l,[hm,Pf.TABLES,t,Pf.PATH],u),_n.setProperty(pa.DATABASES,l),u;let f=c?.[Pf.PATH];if(f)return ZD.set(l,[hm,Pf.PATH],f),_n.setProperty(pa.DATABASES,l),f}}let s=r[pa.STORAGE_PATH.toUpperCase()];if(s){if(!XD.pathExistsSync(s))throw new Error(s+" does not exist");let i=Uf.join(s,e);return XD.mkdirsSync(i),_n.setProperty(pa.STORAGE_PATH,s),i}return tL()}a(M4,"initSystemSchemaPaths");function v4(){Df=void 0,Lf=void 0,Mf=void 0}a(v4,"resetPaths");sL.exports={getBaseSchemaPath:eL,getSystemSchemaPath:tL,getTransactionAuditStorePath:L4,getTransactionAuditStoreBasePath:rL,getSchemaPath:nL,initSystemSchemaPaths:M4,resetPaths:v4}});var pn=I((rbe,lL)=>{"use strict";var U4=Bn().LMDB_ERRORS_ENUM,ebe=require("lmdb"),x4=xt(),tbe=require("buffer").Buffer,{OVERFLOW_MARKER:iL,MAX_SEARCH_KEY_LENGTH:mm}=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>mm?[e.slice(0,mm)+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>mm?r.push(i.slice(0,mm)+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 Em=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>Em?(Em=e,e):(Em+=488e-6,Em)}a(q4,"getNextMonotonicTime");lL.exports={validateEnv:B4,stringifyData:H4,convertKeyValueToWrite:k4,getNextMonotonicTime:q4,getIndexedValues:F4}});var xf=I((sbe,uL)=>{"use strict";var $4=(H(),P(G)).OPERATIONS_ENUM,lR=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=lR});var Bf=I((abe,pL)=>{"use strict";var obe=xf(),gm=(H(),P(G)),uR=ae(),dL=W(),V4=require("uuid"),{handleHDBError:Sm,hdb_errors:K4}=pe(),{HDB_ERROR_MSGS:Tm,HTTP_STATUS_CODES:Am}=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))>gm.INSERT_MAX_CHARACTER_SIZE)throw Sm(new Error,Tm.ATTR_NAME_LENGTH_ERR(e),Am.BAD_REQUEST,void 0,void 0,!0);if(uR.isEmptyOrZeroLength(e)||uR.isEmpty(e.trim()))throw Sm(new Error,Tm.ATTR_NAME_NULLISH_ERR,Am.BAD_REQUEST,void 0,void 0,!0)}a(_L,"validateAttribute");function Y4(e,t,r){if(!e.hasOwnProperty(t)||uR.isEmptyOrZeroLength(e[t])){if(r===gm.OPERATIONS_ENUM.INSERT||r===gm.OPERATIONS_ENUM.UPSERT){e[t]=V4.v4();return}throw dL.error("Update transaction aborted due to record with no hash value:",e),Sm(new Error,Tm.RECORD_MISSING_HASH_ERR,Am.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>gm.INSERT_MAX_CHARACTER_SIZE)throw dL.error(e),Sm(new Error,Tm.HASH_VAL_LENGTH_ERR,Am.BAD_REQUEST,void 0,void 0,!0)}a(Y4,"validateHash")});var hL,Hn,dR,hu=be(()=>{hL=require("events"),Hn=class extends hL.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new dR;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)}},dR=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){_R=e}function J4(){j4=setInterval(function(){for(let e of fR)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 pR,gL,SL,TL,AL,mL,fR,W4,Hf,EL,_R,Ic,Rm,z4,j4,ym=be(()=>{pR=M(pn()),gL=M(pe()),SL=M(W()),TL=M(ce());H();AL=M(ae()),mL=100,fR=new Set,W4=(0,AL.convertToMS)(TL.get(x.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(RL,"replicationConfirmation");Ic=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),fR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn?.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(fR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(Hf&&!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,pR.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 Hf||(Hf=s,EL=performance.now(),Hf.then(()=>{Hf=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];_R&&_&&i.push(_R(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}},Rm=class extends Ic{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,pR.getNextMonotonicTime)())}getReadTxn(){}},z4=3e4;a(J4,"startMonitoringTxns");J4()});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 Ic;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,Cc=be(()=>{yL=M(Ai());ym();a(Nt,"transaction");(0,yL._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 mR(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?mR(d.conditions,d.operator,r,n,s,i,o,c):gu(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?(N,v)=>A.some(F=>F(N,v)):(N,v)=>A.every(F=>F(N,v))}let g=(h.attribute||h[0])===r.primaryKey,R=Gf(h,r,i,c,g,_);return p&&S<d.length-1&&_&&(_=i3(r.primaryStore,h.estimated_count,_)),R}).filter(Boolean)}a(f,"mapConditionsToFilters")}function gu(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 mn.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let E=o[0],A=Oi(n.attributes,E);if(A.relationship){if(o.length<2)throw new mn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let N=A.definition?.tableClass||A.elements?.definition?.tableClass,v=new Map,F=gu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,N,s,v);if(A.relationship.to){i[o[0]]=v;let $=!!Oi(N.attributes,A.relationship.to)?.elements;F=t3(F,A,N.primaryStore,$,v)}if(A.relationship.from){let $=a(Y=>(Y?.key!==void 0&&(Y=Y.key),gu({attribute:A.relationship.from,value:Y},t,r,n,s,v)),"searchEntry");A.elements?(i[o[0]]=v,F=r3(F,A,N.primaryStore,v,$)):F=F.flatMap($)}return F}else if(o.length===1)o=o[0];else throw new mn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,f,d,p;c instanceof Date&&(c=c.getTime());let _;switch(ER[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]=bi.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 mn.ClientError(`Unknown query comparator "${l}"`)}let h,S=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>gs.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,gs.MAX_SEARCH_KEY_LENGTH)+gs.OVERFLOW_MARKER,p=!1,h=Gf(e,n,null,i,S)),typeof f=="string"&&f.length>gs.MAX_SEARCH_KEY_LENGTH&&(f=f.slice(0,gs.MAX_SEARCH_KEY_LENGTH)+gs.OVERFLOW_MARKER,d=!0,h=h??Gf(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 mn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&_)throw new mn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(g?.isIndexing)throw new mn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&g&&!g.indexNulls)throw new mn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??Gf(e,n,null,i,S),!h)throw new mn.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:N}){return this?.isSync?N&&h(N)?A:ha.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(N&&h(N)?A:ha.SKIP)}catch($){F($)}}))}:A=>A.value==null&&!(A.metadataFlags&(En|Ea))?ha.SKIP:A);return E.hasEntries=!0,E}else return g?g.getRange(R).map(h?function({key:E,value:A}){let N;return typeof E=="string"&&E.length>gs.MAX_SEARCH_KEY_LENGTH?N=n.primaryStore.get(A):N={[o]:E},this.isSync?h(N)?A:ha.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(h(N)?A:ha.SKIP)}catch($){F($)}}))}:({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((N,v)=>setImmediate(()=>{try{N(A&&h(A)?E:ha.SKIP)}catch(F){v(F)}}))})}function Oi(e,t){if(Array.isArray(t))if(t.length>1){let r=Oi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Oi(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 Gf(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=Oi(t.attributes,f),p=d.definition?.tableClass||d.elements.definition?.tableClass,_=n?.[f],h=Gf({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 N,v;if(S){if(S.from&&h.idFilter){if(!g)if(h.idFilter.idSet?.size===1){for(let $ of h.idFilter.idSet)e={attribute:S.from,value:$};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),N=v?.value}else N=E[f];return N?Array.isArray(N)?N.some(h):h(N,v):!1},"recordFilter");return R}}switch(l instanceof Date&&(l=l.getTime()),ER[o]||o){case gs.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,bi.compareKeys)(f,l[0])>=0&&(0,bi.compareKeys)(f,l[1])<=0,!0);case"gt":return u(c,f=>(0,bi.compareKeys)(f,l)>0);case"ge":return u(c,f=>(0,bi.compareKeys)(f,l)>=0);case"lt":return u(c,f=>(0,bi.compareKeys)(f,l)<0);case"le":return u(c,f=>(0,bi.compareKeys)(f,l)<=0);case"ne":return u(c,f=>(0,bi.compareKeys)(f,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new mn.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&&Om(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],N;if(typeof A!="object"||!A||_?N=d(A):Array.isArray(A)?N=A.some(d):A instanceof Date&&(N=d(A.getTime())),p&&(g++,!N&&!R.idFilter&&++S/g*(i-g)>h)){let v=gu(e,r.transaction.getReadTxn(),!1,t).map(Su),F=new Set(v);R.idFilter=$=>F.has(Su($)),R.idFilter.idSet=F}return N}return a(R,"recordFilter"),s&&(R.idFilter=d),R}a(u,"attributeComparator")}function Om(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/io(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=ER[n]||n,n===gs.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=Oi(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=Om(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*io(e.indices[i.relationship.from])/(io(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=io(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=Z4*io(e.primaryStore)+1:n==="between"?r.estimated_count=X4*io(e.primaryStore)+1:n==="sort"?r.estimated_count=io(e.primaryStore)+1:r.estimated_count=Q4*io(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function Nm(e){if(e)if(ma=e,mu.lastIndex=0,n3.test(e))try{let t=kf(new Eu,"");if(hn!==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 ${hn} in '${ma}'`,t}else return new URLSearchParams(e)}function kf(e,t){let r=mu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ma);){hn=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=Ff(f)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=e3[d],l=hR[i]?bL:decodeURIComponent,!f)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=Ff(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 bm(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(Ff(f)),s=void 0;break;case"(":mu.lastIndex=hn;let _=kf(f?[]:new Eu,")");switch(f){case"":bm(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}`)}ma[hn]===","?r.lastIndex=++hn: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");mu.lastIndex=hn,p=kf([],"}"),p.name=f,e.push(p),ma[hn]===","?r.lastIndex=++hn:o=!0;break;case"[":mu.lastIndex=hn,f?(p=kf(new Eu,"]"),p.name=f):p=kf(e.conditions?new Eu:[],"]"),e.conditions?(bm(e,u),e.conditions.push(p),s=null):e.push(p),ma[hn]===","?r.lastIndex=++hn: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),bm(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(Ff(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:mu,r.lastIndex=hn),hn===ma.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function bm(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 Ff(e){return e.indexOf(".")>-1?e.split(".").map(Ff):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 mn.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 mn.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 Su(e){return Array.isArray(e)?e.join("\0"):e}function io(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/io(e)}var mn,gs,bi,ha,Q4,X4,Z4,e3,hR,ER,n3,mu,s3,hn,ma,Eu,Pc,qf=be(()=>{mn=M(pe()),gs=M(xt()),bi=require("ordered-binary"),ha=require("lmdb");$f();Q4=.3,X4=.1,Z4=.05,e3={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},hR={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(mR,"executeConditions");a(gu,"searchByIndex");a(Oi,"findAttribute");a(t3,"joinTo");a(r3,"joinFrom");ER={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(Gf,"filterByType");a(Om,"estimateCondition");n3=/[()[\]|!<>.]|(=\w*=)/,mu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,s3=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(Nm,"parseQuery");a(kf,"parseBlock");a(bm,"assignOperator");a(Ff,"decodeProperty");a(bL,"typedDecoding");a(OL,"wildcardDecoding");a(NL,"toSortObject");a(wL,"toSortEntry");Eu=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(Su,"flattenKey");a(io,"estimatedEntryCount");a(i3,"intersectionEstimate");Pc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var SR={};Ue(SR,{MultiPartId:()=>Im,Resource:()=>Vr,snake_case:()=>a3,transformForSelect:()=>Cm});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(Dc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Dc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new Im;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Dc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Dc=!0,null;e[e.length-1]==="/"&&(Dc=!0)}return t.coerceId(decodeURIComponent(e))}function kn(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 Pc(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 wm(o.user);return typeof f?.then=="function"?f.then(g=>e(_,l,o,g)):e(_,l,o,f)});if(!h)throw new wm(o.user)}return typeof f?.then=="function"?f.then(h=>e(_,l,o,h)):e(_,l,o,f)}a(p,"authorizeActionOnResource")}}function Fn(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 gR(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 Cm(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):gR(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(gR(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(gR(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]=Cm(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,Vr,wm,Dc,Im,ga=be(()=>{CL=require("crypto");hu();PL=M(Ai()),DL=M(pe());Cc();qf();o3={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Vr=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=kn(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=Cm(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=kn(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):Fn(t,"put")},{hasContent:!0,type:"update"});static patch=kn(function(t,r,n,s){return t.patch?t.patch(s,r):Fn(t,"patch")},{hasContent:!0,type:"update"});static delete=kn(function(t,r,n,s){return t.delete?t.delete(r):Fn(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={}),Nt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):Fn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=kn(function(t,r,n,s){return t.invalidate?t.invalidate(r):Fn(t,"delete")},{hasContent:!1,type:"update"});static post=kn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=kn(function(t,r,n,s){return t.connect?t.connect(s,r):Fn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=kn(function(t,r,n,s){return t.subscribe?t.subscribe(r):Fn(t,"subscribe")},{type:"read"});static publish=kn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.publish(s,r):Fn(t,"publish")},{hasContent:!0,type:"create"});static search=kn(function(t,r,n,s){let i=t.search?t.search(r):Fn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=Cm(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=kn(function(t,r,n,s){return t.search?t.search(s,r):Fn(t,"search")},{hasContent:!0,type:"read"});static copy=kn(function(t,r,n,s){return t.copy?t.copy(s,r):Fn(t,"copy")},{hasContent:!0,type:"create"});static move=kn(function(t,r,n,s){return t.move?t.move(s,r):Fn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#n)return(await this.constructor.create(this.#e,t,this.#t)).#e;Fn(this,"post")}static isCollection(t){return t&&t.#n}get isCollection(){return this.#n}static coerceId(t){return t}static parseQuery(t){return Nm(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:Dc}}let i=IL(t,this);return Dc?{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,PL._assignPackageExport)("Resource",Vr);a(a3,"snake_case");wm=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");Im=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(kn,"transactional");a(Fn,"missingMethod");a(gR,"selectFromObject");a(Cm,"transformForSelect")});var Sa,TR=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 vL={};Ue(vL,{Resources:()=>Pm,keyArrayToString:()=>Tu,resetResources:()=>c3,resources:()=>Ni});function c3(){return Ni=new Pm}function Tu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var LL,ML,Pm,Ni,Au=be(()=>{Cc();TR();LL=M(W()),ML=M(pe()),Pm=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 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(c3,"resetResources");a(Tu,"keyArrayToString")});var Ru={};Ue(Ru,{server:()=>We});var UL,We,Kr=be(()=>{UL=M(Ai()),We={};(0,UL._assignPackageExport)("server",We)});var yR={};Ue(yR,{loadGQLSchema:()=>d3,start:()=>RR,startOnMainThread:()=>u3});function RR({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 j=F(Y.type);return j.nullable=!1,j}if(Y.kind==="ListType")return{type:"array",elements:F(Y.type)};let oe={type:Y.name?.value};return Object.defineProperty(oe,"location",{value:Y.loc.startToken}),oe};a(F,"getProperty");let E=R.name.value,A=[],N={table:null,database:null,properties:A};p.set(E,N);for(let Y of R.directives){if(Y.name.value==="table"){for(let oe of Y.arguments)N[oe.name.value]=oe.value.value;N.schema&&(N.database=N.schema),N.table||(N.table=E),N.audit&&(N.audit=N.audit!=="false"),N.attributes=N.properties,_.push(N)}if(Y.name.value==="sealed"&&(N.sealed=!0),Y.name.value==="splitSegments"&&(N.splitSegments=!0),Y.name.value==="replicate"&&(N.replicate=!0),Y.name.value==="export"){N.export=!0;for(let oe of Y.arguments)typeof N.export!="object"&&(N.export={}),N.export[oe.name.value]=oe.value.value}}let v=!1,$={};for(let Y of R.fields){let ee=F(Y.type);ee.name=Y.name.value,A.push(ee),$[ee.name]=void 0;for(let oe of Y.directives){let j=oe.name.value;if(j==="primaryKey")v?console.warn("Can not define two attributes as a primary key at",oe.loc):(ee.isPrimaryKey=!0,v=!0);else if(j==="indexed")ee.indexed=!0;else if(j==="computed"){for(let se of oe.arguments||[])if(se.name.value==="from"){let z=se.value.value;ee.computed={from:g(z,se,$)},ee.version==null&&(ee.version=z)}else se.name.value==="version"&&(ee.version=se.value.value);ee.computed=ee.computed||!0}else if(j==="relationship"){let se={};for(let z of oe.arguments)se[z.name.value]=z.value.value;ee.relationship=se}else if(j==="createdTime")ee.assignCreatedTime=!0;else if(j==="updatedTime")ee.assignUpdatedTime=!0;else if(j==="expiresAt")ee.expiresAt=!0;else if(j==="allow"){let se=ee.authorizedRoles=[];for(let z of oe.arguments)z.name.value==="role"&&se.push(z.value.value)}else server.knownGraphQLDirectives.includes(j)&&console.warn(`@${j} is an unknown directive, at`,oe.loc)}}N.type=E,E==="Query"&&(h=N)}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,AR.dirname)(n),R.tableClass):i.set((0,AR.dirname)(n)+"/"+(R.export.name||R.type),R.tableClass,R.export));function g(R,E,A){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()(A)}a(g,"createComputedFrom")}}var AR,xL,BL,l3,u3,d3,HL=be(()=>{AR=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(RR,"start");u3=RR,d3=RR({ensureTable:dt}).handleFile});var KL={};Ue(KL,{parse:()=>OR,streamAsJSON:()=>Vf,stringify:()=>Lc});function Vf(e){return new bR({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 Lc(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===$L)return VL(e);if(t.resolution)return t.resolution.then(()=>Lc(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)+":"+Lc(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function OR(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,bR,p3,NR=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(Vf,"streamAsJSON");bR=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 Lc(t)}else yield Lc(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(Lc,"stringify");a(VL,"jsStringify");p3=/[[,:]\s*-?\d{16,}/;a(OR,"parse")});var wi=I(Lm=>{var Dm=W();for(let e of["trace","debug","info","warn","error","fatal","notify"])Dm.logsAtLevel(e)&&(Lm[e]=Dm[e]);Lm.loggerWithTag=e=>Dm.loggerWithTag(e,!0);Lm.setLogLevel=Dm.setLogLevel});var qm={};Ue(qm,{Blob:()=>Ii,blobsWereEncoded:()=>vc,databasePaths:()=>Um,decodeBlobsWithWrites:()=>PR,decodeFromDatabase:()=>Uc,decodeWithBlobCallback:()=>DR,deleteBlob:()=>eM,deleteBlobsInObject:()=>Aa,deleteRootBlobPathsForDB:()=>CR,encodeBlobsAsBuffers:()=>b3,encodeBlobsWithFilePath:()=>Gm,findBlobsInObject:()=>bu,getFileId:()=>km,getFilePathForBlob:()=>rM,getRootBlobPathsForDB:()=>Fm,setDeletionDelay:()=>g3});function XL(){}function eM(e){let t=rM(e);t&&setTimeout(()=>{(0,Qe.unlink)(t,r=>{r&&Ta.default.debug?.("Error trying to remove blob file",r)})},ZL)}function g3(e){ZL=e}function tM(e){let t=gn.get(e);if(!t)t={storageIndex:0,fileId:null,store:Js},gn.set(e,t);else{if(t.saving)return t;t.store=Js}return T3(t),t.source?wR(e,t.source,t):t.contentBuffer?S3(e,t):wR(e,Yf.Readable.from(e.stream()),t),t}function wR(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,Qe.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,Bm.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),A=new DataView(E.buffer);return R|=BigInt(o?IR:QL)<<48n,A.setBigInt64(0,R),E}a(h,"createHeader");function S(g){i.unlock(f,0);let R=d.fd;g?(R&&(0,Qe.close)(R),u(g)):c?(0,Qe.fdatasync)(R,E=>{E&&u(E),l(),(0,Qe.close)(R)}):(l(),(0,Qe.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,Qe.write)(d.fd,h(g),0,gr,0,S)}})}),e}function km(e){return gn.get(e)?.fileId}function rM(e){let t=gn.get(e);return t?.fileId&&Wf(t)}function Fm(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=Um.get(e);if(!t){if(!e.databaseName)throw new Error("No database name specified, can not determine blob storage path");let r=(0,Hm.get)(x.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,ao.join)(n,e.databaseName)):t=[(0,ao.join)((0,Hm.getHdbBasePath)(),"blobs",e.databaseName)],Um.set(e,t)}return t}async function CR(e){let t=Um.get(e);t&&await Promise.all(t.map(r=>nM(r)))}async function nM(e){for(let t of await(0,Qs.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await nM((0,ao.join)(e,t.name));else try{await(0,Qs.unlink)((0,ao.join)(e,t.name))}catch(r){Ta.default.warn?.("Error deleting file",r)}try{await(0,Qs.rmdir)(e)}catch(t){Ta.default.warn?.("Error deleting directory",t)}}function Wf({storageIndex:e,fileId:t,store:r}){let n=Fm(r);return(0,ao.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,wR(e,Yf.Readable.from([r]),t)}function T3(e){let t=Fm(e.store),r=A3(),n=t?.length>1?R3(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=Wf(e),o=(0,ao.dirname)(i);(0,Qe.existsSync)(o)||(0,jL.ensureDirSync)(o),e.filePath=i}function A3(){let e=zL.get(Js);if(!e){let t=0,r=Fm(Js);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let o=0;if((0,Qe.existsSync)(n))for(let c of(0,Qe.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,ao.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(xm);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%xm]}async function y3(e){if(!Qs.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let o=await(0,Qs.statfs)(s),c=o.bavail*o.bsize;return Math.pow(c,.8)})),r=new Array(xm),n=t.map(s=>1/s);for(let s=0;s<xm;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 Gm(e,t,r){yu=t,Js=r,vc=!1;try{return e()}finally{yu=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 PR(e,t){try{Dr=[],Mc=t,e()}catch(n){throw Mc=void 0,Dr=void 0,n}Mc=void 0;let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r}function DR(e,t){try{return Mc=t,e()}finally{Mc=void 0}}function Uc(e,t){return Js=t,e()}function Aa(e){bu(e,t=>{eM(t)})}function bu(e,t){if(e instanceof Ii)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&bu(r,t);else if(e.constructor===Object)for(let r in e){let n=e[r];typeof n=="object"&&n&&bu(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 oo,Qs,Qe,Bm,Yf,jL,Hm,ao,Ta,JL,gr,QL,IR,YL,h3,m3,WL,gn,Mc,Ii,yu,Dr,Js,vc,Kf,Mm,E3,vm,ZL,Um,zL,xm,Ss=be(()=>{oo=require("msgpackr"),Qs=require("node:fs/promises"),Qe=require("node:fs"),Bm=require("node:zlib"),Yf=require("node:stream"),jL=require("fs-extra"),Hm=M(ce());H();ao=require("path"),Ta=M(wi());co();JL=8192,gr=8,QL=0,IR=1,YL=255,h3=new Uint8Array([0,QL,255,255,255,255,255,255]),m3=new Uint8Array([0,IR,255,255,255,255,255,255]),WL=0xffffffffffff,gn=new WeakMap,Ii=global.Blob||O3(),vc=!1,Kf=new Uint8Array(8),Mm=new DataView(Kf.buffer),E3=6e4;a(XL,"InstanceOfBlobWithNoConstructor");XL.prototype=Ii.prototype;vm=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=gn.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):(MR()&&LR(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=gn.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=Wf(t),o,c=a(async()=>{let l,u=gr;try{if(l=await(0,Qs.readFile)(i),l.length>=gr){l.copy(Kf,0,0,gr);let d=Mm.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]===IR?new Promise((d,p)=>{(0,Bm.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=gn.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=Wf(t),o,c=0,l=0,u,f,d,p=!1,_=this;return new ReadableStream({start(){let S=1e3,g=a((R,E)=>{(0,Qe.open)(i,"r",(A,N)=>{if(A){if(A.code==="ENOENT"&&d!==!1&&(Ta.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(A),_.#e?.forEach(v=>v(A))}else o=N,R(N)})},"openFile");return new Promise(g)},pull:a(S=>{let g=0,R=100;return new Promise(a(function E(A,N){function v($){(0,Qe.close)(o),clearTimeout(f),u&&u.close(),N($),_.#e?.forEach(Y=>Y($))}a(v,"onError");let F=Buffer.allocUnsafe(262144);(0,Qe.read)(o,F,0,F.length,c,($,Y,ee)=>{if(l+=Y,$)return v($);if(c===0){if(Y<gr){R-- >0&&d!==!1?(h(),Ta.default.debug?.("File was empty, waiting for data to be written",i,R),setTimeout(()=>E(A,N),20).unref()):(Ta.default.debug?.("File was empty, throwing error",i,R),N(new Error(`Blob ${t.fileId} was empty`)));return}ee.copy(Kf,0,0,gr);let oe=Mm.getBigUint64(0);if(Number(oe>>48n)===YL)return v(new Error("Error in blob: "+ee.subarray(gr)));if(g=Number(oe&0xffffffffffffn),g<WL&&_.size!==g&&(_.size=g,_.#t))for(let j of _.#t)j(g);ee=ee.subarray(gr,Y),l-=gr}else if(Y===0){let oe=Buffer.allocUnsafe(8);return(0,Qe.read)(o,oe,0,gr,0,j=>{if(j)return v(j);if(Kf.set(oe),g=Number(Mm.getBigUint64(0)&0xffffffffffffn),g>l){h()?u?f=setTimeout(()=>{v(new Error("File read timed out"))},E3).unref():(u=(0,Qe.watch)(i,{persistent:!1},()=>{u.close(),u=null,f&&(clearTimeout(f),f=null,E(A,N))}),E(A,N)):p?v(new Error("Blob is incomplete")):(p=!0,E(A,N));return}(0,Qe.close)(o),S.close(),A()})}else ee=ee.subarray(0,Y);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=Y,E(A,N);s&&l>=s&&(l>s&&(ee=ee.subarray(0,s-c)),l=g=s),n&&n>c&&(ee=ee.subarray(n-c))}c+=Y;try{S.enqueue(ee)}catch(oe){return Ta.default.debug?.("Error enqueuing chunk",oe),A()}l===g&&((0,Qe.close)(o),S.close()),A()})},"readMore"))},"pull"),cancel(){(0,Qe.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=gn.get(this),i=new e(n&&{type:n});if(s?.fileId){let o={...s,start:t,end:r};gn.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)};gn.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 vm(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(gn.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Yf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Yf.Readable.from(e);else throw new Error("Invalid source type");return r};a(tM,"saveBlob");a(wR,"writeBlobWithStream");a(km,"getFileId");a(rM,"getFilePathForBlob");Um=new Map;a(Fm,"getRootBlobPathsForDB");a(CR,"deleteRootBlobPathsForDB");a(nM,"rimrafSteadily");a(Wf,"getFilePath");a(S3,"writeBlobWithBuffer");a(T3,"generateFilePath");zL=new Map;a(A3,"getNextFileId");xm=128;a(R3,"getNextStorageIndex");a(y3,"createFrequencyTableForStoragePaths");a(Gm,"encodeBlobsWithFilePath");a(b3,"encodeBlobsAsBuffers");a(PR,"decodeBlobsWithWrites");a(DR,"decodeWithBlobCallback");a(Uc,"decodeFromDatabase");a(Aa,"deleteBlobsInObject");a(bu,"findBlobsInObject");(0,oo.addExtension)({Class:Ii,type:11,unpack:a(function(e){let t=(0,oo.unpack)(e),r=new vm;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(gn.set(r,{storageIndex:t[1],fileId:t[2],store:Js}),Mc)return Mc(r)??r}else gn.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=gn.get(e);if(yu!==void 0&&(vc=!0,t?.recordId!==void 0&&t.recordId!==yu))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,oo.pack)([r,t.contentBuffer])}if(yu!==void 0){if(t=tM(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=yu,(0,oo.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Qe.readFileSync)(Wf(t));if(n.length>=gr&&(n.copy(Kf,0,0,gr),Number(Mm.getBigUint64(0)&0xffffffffffffn)===n.length-gr))return Buffer.concat([(0,oo.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,oo.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(O3,"polyfillBlob")});var dM={};Ue(dM,{asyncSerialization:()=>LR,contentTypes:()=>BR,findBestSerializer:()=>Vm,getDeserializer:()=>fo,hasAsyncSerialization:()=>MR,registerContentHandlers:()=>Jf,serialize:()=>Qf,serializeMessage:()=>Ra,toCsvStream:()=>$m});function w3(e){try{return e?.[0]===123?xR(e):e}catch{return e}}function Jf(e){e.register(C3,{serializers:[{regex:/^application\/json$/,serializer:Vf},{regex:/^application\/cbor$/,serializer:a(function(t){return new xc.EncoderStream(jf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Bc.Readable.from((0,Ci.encodeIter)(t,jf)):(0,Ci.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),$m(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Ci.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,xc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function Vm(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 _=Yr.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(Yr.keys()).join(", "),406);n=Yr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Qf(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 Ii)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=Vm(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}),UR.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,uo.createBrotliCompress)({params:{[uo.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?uo.constants.BROTLI_MODE_TEXT:uo.constants.BROTLI_MODE_GENERIC,[uo.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,uo.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;lo=r?void 0:[];try{let n;if(t){let s=t.serialize;if(s)n=s(e);else{let i=Vm(t);s=t.serialize=i.serializer.serialize,n=s(e)}}else n=zf(e);return lo?.length>0?(lo.length===1?lo[0]:Promise.all(lo)).then(()=>Ra(e,t,!0)):n}finally{lo=void 0}}function LR(e){if(lo)lo.push(e);else throw new Error("Unable to serialize asynchronously")}function MR(){return!!lo}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 fo(e="",t=!1){let r=M3(e),n=r.type&&Yr.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)&&UR.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 xR(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 $m(e,t){let r=Bc.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 Ci,xc,uo,oM,Bc,aM,vR,cM,UR,N3,lM,zf,xR,jf,Yr,BR,sM,uM,I3,C3,iM,lo,D3,co=be(()=>{NR();Ci=require("msgpackr"),xc=require("cbor-x"),uo=require("zlib"),oM=M(pe()),Bc=M(require("stream"));Kr();aM=M(Ai()),vR=M(ce());H();cM=M(require("yaml")),UR=M(wi());Ss();({Transform:N3}=require("json2csv")),lM=vR.default.get(x.SERIALIZATION_BIGINT)!==!1,zf=lM?Lc:JSON.stringify,xR=lM?OR:JSON.parse,jf={useRecords:!1,useToJSON:!0},Yr=new Map,BR=Yr;We.contentTypes=BR;(0,aM._assignPackageExport)("contentTypes",BR);Yr.set("application/json",{serializeStream:Vf,serialize:zf,deserialize(e){return xR(e)},q:.8});sM=new xc.Encoder(jf);Yr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new xc.EncoderStream(jf).end(e)},serialize:sM.encode,deserialize:sM.decode,q:1});Yr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Bc.Readable.from((0,Ci.encodeIter)(e,jf)):(0,Ci.pack)(e)},serialize:Ci.pack,deserialize:Ci.unpack,q:.9});Yr.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),$m(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]),$m(e,e?.getColumns?.())},q:.1});Yr.set("text/plain",{serialize(e){return e.toString()},serializeStream(e){return Bc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Yr.set("text/yaml",{serialize(e){return cM.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Yr.set("text/event-stream",{serializeStream:a(function(e){return Bc.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
|
+
`),e.data){let r=e.data;typeof r=="object"&&(r=zf(r)),t+="data: "+r+`
|
|
10
10
|
`}return e.id&&(t+="id: "+e.id+`
|
|
11
11
|
`),e.retry&&(t+="retry: "+e.retry+`
|
|
12
12
|
`),t+`
|
|
13
|
-
`}else return typeof e=="object"?`data: ${
|
|
13
|
+
`}else return typeof e=="object"?`data: ${zf(e)}
|
|
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()}});lM={type:"application/json",serializeStream:$f,serialize:Wf,deserialize:I3,q:.5};Kr.set("*/*",lM);Kr.set("",lM);a(I3,"tryJSONParse");a(jf,"registerContentHandlers");C3=require("fastify-plugin"),P3=C3(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");sM=LR.default.get(B.HTTP_COMPRESSIONTHRESHOLD);a(Jf,"serialize");a(Aa,"serializeMessage");a(PR,"asyncSerialization");a(DR,"hasAsyncSerialization");a(D3,"streamToBuffer");L3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(M3,"isBufferEncoding");a(v3,"parseContentType");a(uo,"getDeserializer");a(U3,"deserializerUnknownType");a(x3,"transformIterable");a(Gm,"toCsvStream")});var BR={};ve(BR,{start:()=>K3});function B3(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 dM(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 xR(e){return parseInt(e.value,10)}function _M(e){return parseFloat(e.value)}function pM(e,t,r){let n=r.get(e.name.value);return hM(n)?mM(n,t):{attribute:t,value:n}}function hM(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function mM(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],hM(n)?mM(n,t):{attribute:t,value:n}))}function H3(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:xR(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:_M(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return pM(e.value,t,r);case Le.Kind.OBJECT:return EM(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 EM(e,t,r){return e.fields.flatMap(n=>H3(n,t,r))}function k3(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:xR(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:_M(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return pM(e.value,e.name.value,t);case Le.Kind.OBJECT:return EM(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 F3(e,t){return e.flatMap(r=>k3(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 gM(e,t){return $m(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:gM(r.selectionSet,t)}:r.name.value)}async function G3(e,t,r,n){let s=Oi.getMatch(e.name.value,"graphql");if(s===void 0)throw new br(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:gM(e.selectionSet,r),conditions:F3(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 SM(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return xR(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]:SM(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new br(`Value type, ${e.kind}, is not supported.`)}}function q3(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=SM(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 $3(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=q3(e.variableDefinitions,t),i=await Promise.all($m(e.selectionSet,r).map(c=>G3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function fM({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(B3(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 $3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function V3(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 dM(r),fM(r,e)}case"POST":{let r=await uo(e.headers.get("content-type"),!0)(e._nodeRequest);return dM(r),fM(r,e)}default:throw new Ci("Method Not Allowed",405,{Allow:"GET, POST"})}}function K3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await V3(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 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 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 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,Ci,TM=be(()=>{Le=M(require("graphql"));ao();Su();a(B3,"assertExecutableDefinitionNode");a(dM,"assertRequestParams");a(xR,"processIntValueNode");a(_M,"processFloatValueNode");a(pM,"processVariableNode");a(hM,"isObject");a(mM,"transformObjectIntoQueryCondition");a(H3,"processObjectFieldNode");a(EM,"processObjectValueNode");a(k3,"processArgumentNode");a(F3,"buildConditionsQuery");a($m,"fillInFragments");a(gM,"buildSelectQuery");a(G3,"processFieldNode");a(SM,"processConstValueNode");a(q3,"resolveVariables");a($3,"executeOperation");a(fM,"resolver");br=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(V3,"graphqlQueryingHandler");a(K3,"start")});var Di=w((Ybe,yM)=>{"use strict";var RM=ie(),AM=(H(),C(G)),yu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Pi=require("joi"),Ra={schema_format:{pattern:yu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},Y3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(yu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number(),Pi.array()).required(),W3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(yu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number()),z3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(yu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number()).required();function j3(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`:yu.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(j3,"checkValidTable");function J3(e,t){return RM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(J3,"validateSchemaExists");function Q3(e,t){let r=t.state.ancestors[0].schema;return RM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(Q3,"validateTableExists");function X3(e,t){return e.toLowerCase()===AM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${AM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(X3,"validateSchemaName");yM.exports={common_validators:Ra,schema_regex:yu,hdb_schema_table:Y3,validateSchemaExists:J3,validateTableExists:Q3,validateSchemaName:X3,checkValidTable:j3,hdb_database:W3,hdb_table:z3}});var it=w((zbe,bM)=>{"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};bM.exports={validateObject:Z3,validateObjectAsync:eX,validateBySchema:tX};function Z3(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(Z3,"validateObject");async function eX(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(eX,"validateObjectAsync");function tX(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(tX,"validateBySchema")});var kR=w((Jbe,NM)=>{var{hdb_table:rX,hdb_database:OM}=Di(),nX=it(),HR=require("joi"),sX={undefined:"undefined",null:"null"},iX=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||sX[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"),oX=HR.object({database:OM,schema:OM,table:rX,records:HR.array().items(HR.object().custom(iX)).required()});NM.exports=function(e){return nX.validateBySchema(e,oX)}});var IM=w((Xbe,wM)=>{"use strict";var FR=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")}};wM.exports=FR});var PM=w((eOe,CM)=>{"use strict";var GR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};CM.exports=GR});var UM={};ve(UM,{HAS_EXPIRATION:()=>Ym,HAS_RESIDENCY_ID:()=>zR,HAS_STRUCTURE_UPDATE:()=>zm,LAST_TIMESTAMP_PLACEHOLDER:()=>t_,LOCAL_TIMESTAMP:()=>aX,METADATA:()=>Qf,NEW_TIMESTAMP_PLACEHOLDER:()=>LM,NO_TIMESTAMP:()=>qR,PENDING_LOCAL_TIME:()=>jR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>WR,RecordEncoder:()=>YR,TIMESTAMP_ASSIGN_LAST:()=>lX,TIMESTAMP_ASSIGN_NEW:()=>MM,TIMESTAMP_ASSIGN_PREVIOUS:()=>vM,TIMESTAMP_PLACEHOLDER:()=>Vm,TIMESTAMP_RECORD_PREVIOUS:()=>$R,handleLocalTimeForGets:()=>jm,recordUpdater:()=>JR,removeEntry:()=>vc});function dX(){return e_[0]=e_[0]^64,cX.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,Mc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Mc.length;u++){let f=Mc[u].deref();(!f||f.isDone||f.isCommitted)&&Mc.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?bu=i?.localTime?$R|vM:qR:bu=l?i?.localTime?$R|16384:MM|16384:qR;let _=u?.expiresAt;if(_>=0&&(c|=Ym),Zf=c,VR=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:bu>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(KR=E,Zf|=zR,g|=Uc),R!==E&&(g|=xc,R||(R=0)),c&Ym&&(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=km(()=>e.put(n,s,h),n,e.rootStore),Cc&&(g|=Fn)),l){let b=u?.user?.username;if(p&&(km(()=>e.encoder.encode(p),n,e.rootStore),Cc&&(g|=Fn)),e.encoder.hasStructureUpdate&&(g|=zm,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,F=r.get(v);if(F){let q=wt(F).previousLocalTime;return T=r.put(v,Ou(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?LM:t_,Ou(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 vc(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 DM,Km,Vm,t_,WR,LM,aX,Qf,e_,cX,qR,MM,lX,vM,$R,Ym,zR,jR,zm,uX,Xf,bu,Zf,VR,KR,YR,Mc,Nu=be(()=>{DM=require("msgpackr");fo();Km=M(z());gs();gs();Vm=new Uint8Array([1,1,1,1,4,64,0,0]),t_=new Uint8Array([1,1,1,1,1,0,0,0]),WR=new Uint8Array([1,1,1,1,3,64,0,0]),LM=new Uint8Array([1,1,1,1,0,64,0,0]),aX=Symbol("local-timestamp"),Qf=Symbol("metadata"),e_=new Uint8Array(8),cX=new DataView(e_.buffer,0,8),qR=0,MM=0,lX=1,vM=3,$R=4,Ym=16,zR=32,jR=1,zm=256,bu=0,Zf=-1,VR=-1,KR=0,YR=class extends DM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(bu||Zf>=0){let o=0,c=bu;c&&(o+=8,bu=0);let l=Zf,u=VR,f=KR;l>=0&&(o+=4,Zf=-1,u>=0&&(o+=8,VR=-1),f&&(o+=4,KR=0));let d=uX=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),Cc&&(l|=Fn),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=dX(),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&zR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=Pc(()=>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:Pc(()=>super.decode(t,r),this.rootStore)}catch(c){return Km.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(dX,"getTimestamp");a(jm,"handleLocalTimeForGets");Mc=[];setInterval(()=>{for(let e=0;e<Mc.length;e++){let t=Mc[e].deref();!t||t.isDone||t.isCommitted?Mc.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(vc,"removeEntry")});var s_=w((oOe,BM)=>{"use strict";var xM=ae(),fX=(H(),C(G)),{RecordEncoder:_X}=(Nu(),C(UM));xM.initSync();var pX=xM.get(fX.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=pX&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:_X})}};BM.exports=QR});var i_=w((cOe,HM)=>{"use strict";var Gn=ae(),Ss=(H(),C(G));Gn.initSync();var Jm=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)}};HM.exports=Jm;Jm.MAX_DBS=1e4});var _t=w((uOe,zM)=>{"use strict";var ZR=require("lmdb"),Qs=require("fs-extra"),qn=require("path"),Qm=_n(),GM=z(),gn=Un().LMDB_ERRORS_ENUM,Xm=PM(),ey=s_(),qM=i_(),ya=Ut(),kM=(H(),C(G)),{table:hX,resetDatabases:mX}=(Pe(),C(tt)),FM=ae(),Xs=ya.INTERNAL_DBIS_NAME,$M=ya.DBI_DEFINITION_NAME,EX="data.mdb",gX="lock.mdb",o_=".mdb",SX="-lock",XR=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 ZR.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 ty(e,t,r=!0){try{await Qs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(gn.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,EX),Qs.constants.R_OK|Qs.constants.F_OK),qn.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(ty,"validateEnvironmentPath");function eE(e,t){if(Qm.validateEnv(e),t===void 0)throw new Error(gn.DBI_NAME_REQUIRED)}a(eE,"validateEnvDBIName");async function TX(e,t,r=!1,n=!1){Zm(e,t);let s=qn.basename(e);t=t.toString();let i=FM.get(kM.CONFIG_PARAMS.DATABASES);i||FM.setProperty(kM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ty(e,t,n),VM(e,t,r)}catch(o){if(o.message===gn.INVALID_ENVIRONMENT){let c=qn.join(e,t);await Qs.mkdirp(n?c:e);let l=new qM(n?c:c+o_,!1),u=ZR.open(l);u.dbis=Object.create(null);let f=new ey(!1);u.openDB(Xs,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=ry(e,t,r);return u[ya.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(TX,"createEnvironment");async function AX(e,t,r,n=!0){Zm(e,t),t=t.toString();let s=qn.join(e,t);return hX({table:t,database:qn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(AX,"copyEnvironment");async function VM(e,t,r=!1){Zm(e,t),t=t.toString();let n=ry(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 ty(e,t),i=qn.join(e,t+o_),o=s!=i,c=new qM(s,o),l=ZR.open(c);l.dbis=Object.create(null);let u=YM(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(VM,"openEnvironment");async function RX(e,t,r=!1){Zm(e,t),t=t.toString();let n=qn.join(e,t+o_),s=await ty(e,t);if(global.lmdb_map!==void 0){let i=ry(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await KM(o),delete global.lmdb_map[i]}}await Qs.remove(s),await Qs.remove(s===n?s+SX:qn.join(qn.dirname(s),gX))}a(RX,"deleteEnvironment");async function KM(e){Qm.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(KM,"closeEnvironment");function ry(e,t,r=!1){let s=`${qn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(ry,"getCachedEnvironmentName");function yX(e){Qm.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 Xm,s)}catch{GM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(yX,"listDBIDefinitions");function YM(e){Qm.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(YM,"listDBIs");function bX(e,t){let n=Ts(e,Xs).getEntry(t),s=new Xm;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{GM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(bX,"getDBIDefinition");function WM(e,t,r,n=!r){if(eE(e,t),t=t.toString(),t===Xs)throw new Error(gn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Ts(e,t)}catch(s){if(s.message===gn.DBI_DOES_NOT_EXIST){let i=new ey(r,n===!0),o=e.openDB(t,i),c=new Xm(r===!0,n);return o[$M]=c,Ts(e,Xs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(WM,"createDBI");function Ts(e,t){if(eE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Xs?r=bX(e,t):r=new Xm,r===void 0)throw new Error(gn.DBI_DOES_NOT_EXIST);let n;try{let s=new ey(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[$M]=r,e.dbis[t]=n,n}a(Ts,"openDBI");function OX(e,t){eE(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(OX,"statDBI");async function NX(e,t){try{let r=qn.join(e,t+o_);return(await Qs.stat(r)).size}catch{throw new Error(gn.INVALID_ENVIRONMENT)}}a(NX,"environmentDataSize");function wX(e,t){if(eE(e,t),t=t.toString(),t===Xs)throw new Error(gn.CANNOT_DROP_INTERNAL_DBIS_NAME);Ts(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Ts(e,Xs).removeSync(t)}a(wX,"dropDBI");function IX(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===gn.DBI_DOES_NOT_EXIST)WM(e,i,i!==t,i===t),n=!0;else throw o}}n&&mX()}a(IX,"initializeDBIs");zM.exports={openDBI:Ts,openEnvironment:VM,createEnvironment:TX,listDBIs:YM,listDBIDefinitions:yX,createDBI:WM,dropDBI:wX,statDBI:OX,deleteEnvironment:RX,initializeDBIs:IX,TransactionCursor:XR,environmentDataSize:NX,copyEnvironment:AX,closeEnvironment:KM}});var JM=w((fOe,jM)=>{"use strict";var ny=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=ny});var XM=w((pOe,QM)=>{"use strict";var sy=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}};QM.exports=sy});var ev=w((mOe,ZM)=>{"use strict";var iy=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};ZM.exports=iy});var Hc=w((AOe,nv)=>{"use strict";var CX=_t(),PX=JM(),DX=XM(),LX=ev(),Li=_n(),a_=Un().LMDB_ERRORS_ENUM,MX=Ut(),_o=(H(),C(G)),vX=ie(),UX=require("uuid"),gOe=require("lmdb"),{handleHDBError:xX,hdb_errors:BX}=pe(),{OVERFLOW_MARKER:SOe,MAX_SEARCH_KEY_LENGTH:TOe}=MX,tv=ae();tv.initSync();var tE=tv.get(_o.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),oy=_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Bc=_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function HX(e,t,r,n,s=Li.getNextMonotonicTime()){uy(e,t,r,n),ay(e,t,r);let i=new PX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];rv(u,!0,s);let f=kX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return cy(o,c,n,i,s)}a(HX,"insertRecords");function kX(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){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[Bc])})}a(kX,"insertRecord");function FX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(FX,"removeSkippedRecords");function rv(e,t,r){let n=r>0;(n||!Number.isInteger(e[Bc]))&&(e[Bc]=r||(r=Li.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[oy]))&&(e[oy]=r||Li.getNextMonotonicTime()):delete e[oy]}a(rv,"setTimestamps");function ay(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),CX.initializeDBIs(e,t,r)}a(ay,"initializeTransaction");async function GX(e,t,r,n,s=Li.getNextMonotonicTime()){uy(e,t,r,n),ay(e,t,r);let i=new DX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],p;try{p=ly(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(p),l.push(d)}return cy(c,l,n,i,s,o)}a(GX,"updateRecords");async function qX(e,t,r,n,s=Li.getNextMonotonicTime()){try{uy(e,t,r,n)}catch(l){throw xX(l,l.message,BX.HTTP_STATUS_CODES.BAD_REQUEST)}ay(e,t,r);let i=new LX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;vX.isEmpty(u[t])?(f=UX.v4(),u[t]=f):f=u[t];let d=ly(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return cy(o,c,n,i,s)}a(qX,"upsertRecords");async function cy(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(),FX(r,i),n}a(cy,"finalizeWrite");function ly(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(rv(r,!f,o),Number.isInteger(r[Bc])&&u[Bc]>r[Bc])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){tE&&g.prefetch(E.map(T=>({key:T,value:n})),rE);for(let T=0,b=E.length;T<b;T++)g.remove(E[T],n)}if(E=Li.getIndexedValues(S),E){tE&&g.prefetch(E.map(T=>({key:T,value:n})),rE);for(let T=0,b=E.length;T<b;T++)g.put(E[T],n)}}let _={...u,...r};c.put(n,_,_[Bc])},"do_put");return l?d=c.ifVersion(n,l.version,p):d=c.ifNoExists(n,p),d.then(_=>_?!0:ly(e,t,r,n,s,i,o))}a(ly,"updateUpsertRecord");function $X(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($X,"validateBasic");function uy(e,t,r,n){if($X(e,t,r),!Array.isArray(n))throw n===void 0?new Error(a_.RECORDS_REQUIRED):new Error(a_.RECORDS_MUST_BE_ARRAY)}a(uy,"validateWrite");function rE(){}a(rE,"noop");nv.exports={insertRecords:HX,updateRecords:GX,upsertRecords:qX}});var po=w((yOe,VX)=>{VX.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 iv=w((bOe,sv)=>{"use strict";var KX=require("uuid"),dy=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||KX.v4(),this.schema_table=`${this.schema}.${this.table}`}};sv.exports=dy});var nE=w((NOe,ov)=>{"use strict";var YX=iv(),fy=class extends YX{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}};ov.exports=fy});var cv=w((IOe,av)=>{"use strict";av.exports=zX;var WX="inserted";function zX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===WX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(zX,"returnObject")});var sE=w((DOe,uv)=>{"use strict";var jX=(H(),C(G)),_y=_t(),JX=Hc(),{getSystemSchemaPath:QX,getSchemaPath:XX}=gt(),POe=po(),{validateBySchema:ZX}=it(),c_=require("joi"),e6=nE(),t6=cv(),{handleHDBError:r6,hdb_errors:n6,ClientError:s6}=pe(),lv=ie(),{HTTP_STATUS_CODES:i6}=n6,o6="inserted";uv.exports=a6;async function a6(e){let t=ZX(e,c_.object({database:c_.string(),schema:c_.string(),table:c_.string().required(),attribute:c_.string().required()}));if(t)throw new s6(t.message);let r=!e.skip_table_check&&lv.checkGlobalSchemaTable(e.schema,e.table);if(r)throw r6(new Error,r,i6.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 e6(e.schema,e.table,e.attribute,e.id);try{let i=await _y.openEnvironment(XX(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}`);_y.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await _y.openEnvironment(QX(),jX.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 t6(o6,c,{records:[s]},l)}catch(i){throw i}}a(a6,"lmdbCreateAttribute")});var l_=w((vOe,fv)=>{"use strict";var ho=ie(),dv=z(),MOe=kR(),{getDatabases:c6}=(Pe(),C(tt)),{ClientError:kc}=pe();fv.exports=l6;function l6(e){if(ho.isEmpty(e))throw new kc("invalid update parameters defined.");if(ho.isEmptyOrZeroLength(e.schema))throw new kc("invalid schema specified.");if(ho.isEmptyOrZeroLength(e.table))throw new kc("invalid table specified.");if(!Array.isArray(e.records))throw new kc("records must be an array");let t=c6()[e.schema]?.[e.table];if(ho.isEmpty(t))throw new kc(`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 dv.error("a valid hash attribute must be provided with update record:",o),new kc("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 dv.error(`a valid hash value must be provided with ${e.operation} record:`,o),new kc(`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(l6,"insertUpdateValidate")});var pv=w((xOe,_v)=>{"use strict";var py=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};_v.exports=py});var Ev=w((HOe,mv)=>{"use strict";var hy=_t(),u6=z(),hv=Un().LMDB_ERRORS_ENUM;mv.exports=d6;async function d6(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 hy.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==hv.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await hy.closeEnvironment(global.lmdb_map[n]),await hy.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==hv.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){u6.error(t)}}a(d6,"cleanLMDBMap")});var Pv=w((GOe,Cv)=>{"use strict";var my=require("recursive-iterator"),f6=require("alasql"),Ey=require("clone"),gv=ie(),{handleHDBError:Sv,hdb_errors:_6}=pe(),{HDB_ERROR_MSGS:Tv,HTTP_STATUS_CODES:Av}=_6,{getDatabases:p6}=(Pe(),C(tt)),h6=["DISTINCT_ARRAY"],Rv=Symbol("validateTables"),gy=Symbol("validateTable"),FOe=Symbol("getAllColumns"),yv=Symbol("validateAllColumns"),iE=Symbol("findColumn"),bv=Symbol("validateOrderBy"),u_=Symbol("validateSegment"),Sy=Symbol("validateColumn"),Ov=Symbol("setColumnsForTable"),Nv=Symbol("checkColumnsForAsterisk"),wv=Symbol("validateGroupBy"),Iv=Symbol("hasColumns"),Ty=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[Rv](),this[Nv](),this[yv]()}[Rv](){if(this[Iv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[gy](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[gy](t.table)})}}[Iv](){let t=!1,r=new my(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[gy](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=p6();if(!r[t.databaseid])throw Sv(new Error,Tv.SCHEMA_NOT_FOUND(t.databaseid),Av.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Sv(new Error,Tv.TABLE_NOT_FOUND(t.databaseid,t.tableid),Av.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Ey(s);i.table=Ey(t),this.attributes.push(i)})}[iE](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)}[Nv](){let t=new my(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[Ov](r.tableid)}[Ov](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new f6.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[yv](){this[u_](this.statement.columns,!1),this[u_](this.statement.joins,!1),this[u_](this.statement.where,!1),this[wv](this.statement.group,!1),this[u_](this.statement.order,!0)}[u_](t,r){if(!t)return;let n=new my(t),s=[];for(let{node:i,path:o}of n)!gv.isEmpty(i)&&!gv.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[bv](i):s.push(this[Sy](i)));return s}[wv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&h6.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Ey(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[iE](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[iE](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`}[bv](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[Sy](t)}[Sy](t){let r=this[iE](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]}};Cv.exports=Ty});var vv=w(($Oe,Mv)=>{"use strict";var Dv=require("lodash"),d_=require("mathjs"),m6=require("jsonata"),Lv=ie();Mv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Dv.uniqWith(e,Dv.isEqual):e,"distinct_array"),searchJSON:E6,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 E6(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(Lv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Lv.isEmpty(this.__ala__.res[r])){let n=m6(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(E6,"searchJSON")});var xv=w((KOe,Uv)=>{"use strict";var er=require("moment"),Ay="YYYY-MM-DDTHH:mm:ss.SSSZZ";er.suppressDeprecationWarnings=!0;Uv.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(Ay),"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(Ay),"get_server_time"),offset_utc:a((e,t)=>er(e).utc().utcOffset(t).format(Ay),"offset_utc")}});var Fv=w((WOe,kv)=>{"use strict";var g6=require("@turf/area"),S6=require("@turf/length"),T6=require("@turf/circle"),A6=require("@turf/difference"),R6=require("@turf/distance"),y6=require("@turf/boolean-contains"),b6=require("@turf/boolean-equal"),O6=require("@turf/boolean-disjoint"),N6=require("@turf/helpers"),Bv=(H(),C(G)),Ge=ie(),mo=z();kv.exports={geoArea:w6,geoLength:I6,geoCircle:C6,geoDifference:P6,geoDistance:Hv,geoNear:D6,geoContains:L6,geoEqual:M6,geoCrosses:v6,geoConvert:U6};function w6(e){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return g6.default(e)}catch(t){return mo.trace(t,e),NaN}}a(w6,"geoArea");function I6(e,t){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return S6.default(e,{units:t||"kilometers"})}catch(r){return mo.trace(r,e),NaN}}a(I6,"geoLength");function C6(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return T6.default(e,t,{units:r||"kilometers"})}catch(n){return mo.trace(n,e,t),NaN}}a(C6,"geoCircle");function P6(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 A6(e,t)}catch(r){return mo.trace(r,e,t),NaN}}a(P6,"geoDifference");function Hv(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 R6.default(e,t,{units:r||"kilometers"})}catch(n){return mo.trace(n,e,t),NaN}}a(Hv,"geoDistance");function D6(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 Hv(e,t,n)<=r}catch(s){return mo.trace(s,e,t),!1}}a(D6,"geoNear");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,"geoContains");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,"geoEqual");function v6(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!O6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(v6,"geoCrosses");function U6(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(Bv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Bv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ge.autoCastJSON(e)),N6[t](e,r)}a(U6,"geoConvert")});var oE=w((jOe,Gv)=>{var Fc=vv(),$n=xv(),Mi=Fv();Gv.exports=e=>{e.aggr.mad=e.aggr.MAD=Fc.mad,e.aggr.mean=e.aggr.MEAN=Fc.mean,e.aggr.mode=e.aggr.MODE=Fc.mode,e.aggr.prod=e.aggr.PROD=Fc.prod,e.aggr.median=e.aggr.MEDIAN=Fc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Fc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Fc.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 Kv=w((JOe,Vv)=>{"use strict";var __=require("lodash"),Sn=require("alasql");Sn.options.cache=!1;var x6=oE(),qv=require("clone"),aE=require("recursive-iterator"),Ue=z(),We=ie(),wu=Vn(),B6=(H(),C(G)),{hdb_errors:H6}=pe(),{getDatabases:$v}=(Pe(),C(tt)),k6="IS NULL",Zs="There was a problem performing this search. Please check the logs and try again.";x6(Sn);var Ry=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(Zs)}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(Zs)}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(Zs)}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(Zs)}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(Zs)}}_getColumns(){let t=new aE(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(qv(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=$v()[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 aE(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 aE(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!We.isEmpty(B6.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&&__.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(qv(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(k6)>-1&&this.tables.forEach(s=>{let i={columnid:$v()[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),!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 wu.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(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 wu.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(Zs)}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 wu.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(Zs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await wu.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(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 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=__.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 aE(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=__.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(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 wu.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(H6.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 wu.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(Zs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Vv.exports=Ry});var Yr=w((XOe,Yv)=>{"use strict";var F6=Pv();Yv.exports={searchByConditions:q6,searchByHash:$6,searchByValue:V6,search:K6};var yy=Vn(),{transformReq:by}=ie(),G6=Kv();async function q6(e){return by(e),yy.searchByConditions(e)}a(q6,"searchByConditions");async function $6(e){by(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of yy.searchByHash(e))r&&t.push(r);return t}a($6,"searchByHash");async function V6(e){by(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of yy.searchByValue(e))t.push(r);return t}a(V6,"searchByValue");function K6(e,t){try{let r=new F6(e);r.validate(),new G6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(K6,"search")});var Eo=w((eNe,Jv)=>{"use strict";var p_=require("crypto"),Y6=ae(),{CONFIG_PARAMS:W6}=(H(),C(G)),zv="aes-256-cbc",z6=32,j6=16,Oy=64,jv=32,J6=Oy+jv,Wv=new Map;Jv.exports={encrypt:Q6,decrypt:X6,createNatsTableStreamName:Z6};function Q6(e){let t=p_.randomBytes(z6),r=p_.randomBytes(j6),n=p_.createCipheriv(zv,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(Q6,"encrypt");function X6(e){let t=e.substr(0,Oy),r=e.substr(Oy,jv),n=e.substr(J6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=p_.createDecipheriv(zv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(X6,"decrypt");function Z6(e,t){let r=Y6.get(W6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Wv.get(r);return n||(n=p_.createHash("md5").update(r).digest("hex"),Wv.set(r,n)),n}a(Z6,"createNatsTableStreamName")});var go=w((nNe,eU)=>{"use strict";var rNe=Yr(),h_=z(),{validateBySchema:Qv}=it(),Gc=require("joi"),eZ=Eo(),cE=ie(),{handleHDBError:lE,hdb_errors:tZ,ClientError:Xv}=pe(),{HDB_ERROR_MSGS:uE,HTTP_STATUS_CODES:Ny}=tZ,Zv=ae();Zv.initSync();var{getDatabases:wy}=(Pe(),C(tt)),rZ=require("fs-extra"),nZ=(H(),C(G));eU.exports={describeAll:sZ,describeTable:dE,describeSchema:iZ};async function sZ(e={}){try{let t=cE.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=wy(),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 dE({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 dE({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),lE(new Error,uE.DESCRIBE_ALL_ERR)}}a(sZ,"describeAll");async function dE(e,t){cE.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=Qv(e,Gc.object({database:Gc.string(),table:Gc.string().required(),exact_count:Gc.boolean().strict()}));if(i)throw new Xv(i.message);let c=wy()[r];if(!c)throw lE(new Error,uE.SCHEMA_NOT_FOUND(e.schema),Ny.NOT_FOUND);let l=c[n];if(!l)throw lE(new Error,uE.TABLE_NOT_FOUND(e.schema,e.table),Ny.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 rZ.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")),Zv.get(nZ.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(p.clustering_stream_name=eZ.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(dE,"descTable");async function iZ(e){cE.transformReq(e);let t=Qv(e,Gc.object({database:Gc.string(),exact_count:Gc.boolean().strict()}));if(t)throw new Xv(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=wy()[n];if(!i)throw lE(new Error,uE.SCHEMA_NOT_FOUND(e.schema),Ny.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),cE.isEmpty(l)||l.describe){let u=await dE({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(iZ,"describeSchema")});var As=w((aNe,iU)=>{var oZ=po(),{callbackify:rU,promisify:aZ}=require("util"),{getDatabases:nU}=(Pe(),C(tt));iU.exports={setSchemaDataToGlobal:tU,getTableSchema:cZ,getSystemSchema:lZ,setSchemaDataToGlobalAsync:aZ(tU)};var sU=go(),iNe=rU(sU.describeAll),oNe=rU(sU.describeTable);function tU(e){global.hdb_schema=nU(),e&&e()}a(tU,"setSchemaDataToGlobal");function cZ(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(cZ,"getTableSchema");function lZ(){return oZ}a(lZ,"getSystemSchema")});var Cy=w((lNe,cU)=>{var uZ=it(),Iy=require("joi"),{hdb_table:dZ,hdb_database:oU}=Di(),aU={schema:oU,database:oU,table:dZ},fZ={date:Iy.date().iso().required()},_Z={timestamp:Iy.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};cU.exports=function(e,t){let r=t==="timestamp"?{...aU,..._Z}:{...aU,...fZ},n=Iy.object(r);return uZ.validateBySchema(e,n)}});var dU=w((uNe,uU)=>{var pZ=it(),Py=require("joi"),{hdb_table:hZ,hdb_database:lU}=Di(),mZ=Py.object({schema:lU,database:lU,table:hZ,hash_values:Py.array().required(),ids:Py.array()});uU.exports=function(e){return pZ.validateBySchema(e,mZ)}});var vy=w((dNe,fU)=>{"use strict";var Dy=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}},Ly=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}},My=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};fU.exports={InsertObject:Dy,NoSQLSeachObject:Ly,DeleteResponseObject:My}});var Vc=w((_Ne,EU)=>{"use strict";var pU=Cy(),EZ=dU(),qc=ie(),_U=require("moment"),hU=z(),{promisify:gZ,callbackify:SZ}=require("util"),$c=(H(),C(G)),TZ=As(),Uy=gZ(TZ.getTableSchema),xy=Vn(),{DeleteResponseObject:AZ}=vy(),{handleHDBError:ba,hdb_errors:RZ}=pe(),{HDB_ERROR_MSGS:fE,HTTP_STATUS_CODES:Oa}=RZ,yZ="records successfully deleted",bZ=SZ(mU);EU.exports={delete:bZ,deleteRecord:mU,deleteFilesBefore:OZ,deleteAuditLogsBefore:NZ};async function OZ(e){let t=pU(e,"date");if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),!_U(e.date,_U.ISO_8601).isValid())throw ba(new Error,fE.INVALID_DATE,Oa.BAD_REQUEST,$c.LOG_LEVELS.ERROR,fE.INVALID_DATE,!0);let n=qc.checkSchemaTableExist(e.schema,e.table);if(n)throw ba(new Error,n,Oa.NOT_FOUND,$c.LOG_LEVELS.ERROR,n,!0);let s=await xy.deleteRecordsBefore(e);if(await Uy(e.schema,e.table),hU.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(OZ,"deleteFilesBefore");async function NZ(e){let t=pU(e,"timestamp");if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),isNaN(e.timestamp))throw ba(new Error,fE.INVALID_VALUE("Timestamp"),Oa.BAD_REQUEST,$c.LOG_LEVELS.ERROR,fE.INVALID_VALUE("Timestamp"),!0);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw ba(new Error,r,Oa.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);let n=await xy.deleteAuditLogsBefore(e);return await Uy(e.schema,e.table),hU.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(NZ,"deleteAuditLogsBefore");async function mU(e){e.ids&&(e.hash_values=e.ids);let t=EZ(e);if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);qc.transformReq(e);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw ba(new Error,r,Oa.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);try{await Uy(e.schema,e.table);let n=await xy.deleteRecords(e);return qc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${yZ}`),n}catch(n){if(n.message===$c.SEARCH_NOT_FOUND_MESSAGE){let s=new AZ;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 _E={};ve(_E,{HASH_FUNCTION:()=>g_,hash:()=>ky,validate:()=>Fy});function By(e=E_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(m_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function ky(e,t=g_[SU?.toUpperCase()]??"sha256"){return Hy[t](e)}function Fy(e,t,r=g_[SU?.toUpperCase()]??"sha256"){return e?wZ[r](e,t):!1}var m_,Iu,gU,SU,E_,TU,g_,Hy,wZ,pE=be(()=>{m_=M(require("node:crypto")),Iu=M(require("argon2")),gU=M(ae());H();SU=(0,gU.get)(B.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),E_=16,TU=9,g_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(g_||{});a(By,"generateSalt");Hy={md5:a((e,t=void 0)=>{t=t??By(TU);let r=m_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??By(E_);let r=m_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=By(E_),r=await Iu.hash(e,{type:Iu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},wZ={md5:a((e,t)=>{let r=e.slice(0,TU);return e===Hy.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,E_);return e===Hy.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await Iu.verify(e.slice(E_),t),"argon2id")};a(ky,"hash");a(Fy,"validate")});var RU=w((ENe,AU)=>{var Gy=it(),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 IZ(e){return Wr.password.presence=!0,Wr.username.presence=!0,Wr.role.presence=!0,Wr.active.presence=!0,Gy.validateObject(e,Wr)}a(IZ,"addUserValidation");function CZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,Gy.validateObject(e,Wr)}a(CZ,"alterUserValidation");function PZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,Gy.validateObject(e,Wr)}a(PZ,"dropUserValidation");AU.exports={addUserValidation:IZ,alterUserValidation:CZ,dropUserValidation:PZ}});var Tt=w((TNe,bU)=>{"use strict";var{platform:SNe}=require("os"),DZ="nats-server.zip",qy="nats-server",LZ=process.platform==="win32"?`${qy}.exe`:qy,MZ=/^[^\s.,*>]+$/,yU="__request__",vZ=a(e=>`${e}.${yU}`,"REQUEST_SUBJECT"),UZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},xZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},BZ={HUB:"hub.pid",LEAF:"leaf.pid"},HZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},kZ={SUCCESS:"success",ERROR:"error"},FZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},GZ={TXN:"txn",MSGID:"msgid"},Cu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},qZ={[Cu.ERR]:1,[Cu.WRN]:2,[Cu.INF]:3,[Cu.DBG]:4,[Cu.TRC]:5},$Z={debug:"-D",trace:"-DVV"};bU.exports={NATS_SERVER_ZIP:DZ,NATS_SERVER_NAME:qy,NATS_BINARY_NAME:LZ,PID_FILES:BZ,NATS_CONFIG_FILES:xZ,SERVER_SUFFIX:HZ,NATS_TERM_CONSTRAINTS_RX:MZ,REQUEST_SUFFIX:yU,UPDATE_REMOTE_RESPONSE_STATUSES:kZ,CLUSTER_STATUS_STATUSES:FZ,REQUEST_SUBJECT:vZ,SUBJECT_PREFIXES:GZ,MSG_HEADERS:UZ,LOG_LEVELS:Cu,LOG_LEVEL_FLAGS:$Z,LOG_LEVEL_HIERARCHY:qZ}});var $y=w(OU=>{"use strict";var VZ={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});Yr.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:Vf,serialize:zf,deserialize:w3,q:.5};Yr.set("*/*",uM);Yr.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}=Vm(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(Vm,"findBestSerializer");iM=vR.default.get(x.HTTP_COMPRESSIONTHRESHOLD);a(Qf,"serialize");a(Ra,"serializeMessage");a(LR,"asyncSerialization");a(MR,"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(fo,"getDeserializer");a(v3,"deserializerUnknownType");a(U3,"transformIterable");a($m,"toCsvStream")});var kR={};Ue(kR,{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 Pi("Request body must be an object.");if(!("query"in e))throw new Pi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Pi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Pi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Pi("Request body `operationName` field must be a string.")}function HR(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:HR(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:HR(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 Km(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 Km(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return Km(r.selectionSet,t)}})}function SM(e,t){return Km(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=Ni.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 HR(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(Km(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 fo(e.headers.get("content-type"),!0)(e._nodeRequest);return fM(r),_M(r,e)}default:throw new Pi("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 Pi)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 Pi)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,Pi,AM=be(()=>{Le=M(require("graphql"));co();Au();a(x3,"assertExecutableDefinitionNode");a(fM,"assertRequestParams");a(HR,"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(Km,"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")}},Pi=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 Li=I((Wbe,bM)=>{"use strict";var yM=ae(),RM=(H(),P(G)),Ou=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Di=require("joi"),ya={schema_format:{pattern:Ou,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},K3=Di.alternatives(Di.string().min(1).max(ya.schema_length.maximum).pattern(Ou).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Di.number(),Di.array()).required(),Y3=Di.alternatives(Di.string().min(1).max(ya.schema_length.maximum).pattern(Ou).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Di.number()),W3=Di.alternatives(Di.string().min(1).max(ya.schema_length.maximum).pattern(Ou).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Di.number()).required();function z3(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`:Ou.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:ya,schema_regex:Ou,hdb_schema_table:K3,validateSchemaExists:j3,validateTableExists:J3,validateSchemaName:Q3,checkValidTable:z3,hdb_database:Y3,hdb_table:W3}});var it=I((jbe,OM)=>{"use strict";var Sn=require("validate.js");Sn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||Sn.validators.type.checks[t](e)?null:` must be a '${t}' value`};Sn.validators.type.checks={Object:a(function(e){return Sn.isObject(e)&&!Sn.isArray(e)},"Object"),Array:Sn.isArray,Integer:Sn.isInteger,Number:Sn.isNumber,String:Sn.isString,Date:Sn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};Sn.validators.hasValidFileExt=function(e,t){return Sn.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=Sn(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 Sn.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 GR=I((Qbe,wM)=>{var{hdb_table:tX,hdb_database:NM}=Li(),rX=it(),FR=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=FR.object({database:NM,schema:NM,table:tX,records:FR.array().items(FR.object().custom(sX)).required()});wM.exports=function(e){return rX.validateBySchema(e,iX)}});var CM=I((Zbe,IM)=>{"use strict";var qR=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=qR});var DM=I((tOe,PM)=>{"use strict";var $R=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};PM.exports=$R});var xM={};Ue(xM,{HAS_EXPIRATION:()=>zm,HAS_RESIDENCY_ID:()=>JR,HAS_STRUCTURE_UPDATE:()=>Jm,LAST_TIMESTAMP_PLACEHOLDER:()=>r_,LOCAL_TIMESTAMP:()=>oX,METADATA:()=>Xf,NEW_TIMESTAMP_PLACEHOLDER:()=>MM,NO_TIMESTAMP:()=>VR,PENDING_LOCAL_TIME:()=>QR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>jR,RecordEncoder:()=>zR,TIMESTAMP_ASSIGN_LAST:()=>cX,TIMESTAMP_ASSIGN_NEW:()=>vM,TIMESTAMP_ASSIGN_PREVIOUS:()=>UM,TIMESTAMP_PLACEHOLDER:()=>Ym,TIMESTAMP_RECORD_PREVIOUS:()=>KR,handleLocalTimeForGets:()=>Qm,recordUpdater:()=>XR,removeEntry:()=>kc});function uX(){return t_[0]=t_[0]^64,aX.getFloat64(0)}function Qm(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?.[Xf];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?.[Xf]>=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[Xf];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,Hc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Hc.length;u++){let f=Hc[u].deref();(!f||f.isDone||f.isCommitted)&&Hc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function XR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,p){d||l==null?Nu=i?.localTime?KR|UM:VR:Nu=l?i?.localTime?KR|16384:vM|16384:VR;let _=u?.expiresAt;if(_>=0&&(c|=zm),e_=c,YR=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Nu>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(WR=E,e_|=JR,g|=Fc),R!==E&&(g|=Gc,R||(R=0)),c&zm&&(g|=s_),u?.originatingOperation&&(g|=n_),d&&(h.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&Gn&&(r.getBinaryFast(i.localTime)||Aa(i.value));let A;if(s!==void 0&&(A=Gm(()=>e.put(n,s,h),n,e.rootStore),vc&&(g|=Gn)),l){let N=u?.user?.username;if(p&&(Gm(()=>e.encoder.encode(p),n,e.rootStore),vc&&(g|=Gn)),e.encoder.hasStructureUpdate&&(g|=Jm,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,F=r.get(v);if(F){let $=wt(F).previousLocalTime;return A=r.put(v,wu(o,t,n,$,u?.nodeId??server.replication.getThisNodeId(r)??0,N,f,Zf,g,E,R,_),{ifVersion:S}),A}}A=r.put(s===void 0?MM:r_,wu(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,Zf,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 kc(e,t,r){if(t)return t.value&&t.metadataFlags&Gn&&!e.auditStore.getBinaryFast(t.localTime)&&Aa(t.value),e.remove(t.key,r)}var LM,Wm,Ym,r_,jR,MM,oX,Xf,t_,aX,VR,vM,cX,UM,KR,zm,JR,QR,Jm,lX,Zf,Nu,e_,YR,WR,zR,Hc,Iu=be(()=>{LM=require("msgpackr");_o();Wm=M(W());Ss();Ss();Ym=new Uint8Array([1,1,1,1,4,64,0,0]),r_=new Uint8Array([1,1,1,1,1,0,0,0]),jR=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"),Xf=Symbol("metadata"),t_=new Uint8Array(8),aX=new DataView(t_.buffer,0,8),VR=0,vM=0,cX=1,UM=3,KR=4,zm=16,JR=32,QR=1,Jm=256,Nu=0,e_=-1,YR=-1,WR=0,zR=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(Nu||e_>=0){let o=0,c=Nu;c&&(o+=8,Nu=0);let l=e_,u=YR,f=WR;l>=0&&(o+=4,e_=-1,u>=0&&(o+=8,YR=-1),f&&(o+=4,WR=0));let d=lX=r.call(this,s,i|2048|o);Zf=d.subarray((d.start||0)+o,d.end);let p=d.start||0;return c&&(Ym[4]=c,Ym[5]=c>>8,d.set(Ym,p),p+=8),vc&&(l|=Gn),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,l|jm<<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 Zf=r.call(this,s,i),Zf};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(t_,0,c),c+=8;else for(let p=0;p<8;p++)t_[p]=t[c++];l=uX(),i=t[c]}let u,f;i<32&&(i===jm?(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&zm&&(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=Uc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Xf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:Uc(()=>super.decode(t,r),this.rootStore)}catch(c){return Wm.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(uX,"getTimestamp");a(Qm,"handleLocalTimeForGets");Hc=[];setInterval(()=>{for(let e=0;e<Hc.length;e++){let t=Hc[e].deref();!t||t.isDone||t.isCommitted?Hc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Wm.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Wm.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(XR,"recordUpdater");a(kc,"removeEntry")});var i_=I((aOe,HM)=>{"use strict";var BM=ce(),dX=(H(),P(G)),{RecordEncoder:fX}=(Iu(),P(xM));BM.initSync();var _X=BM.get(dX.CONFIG_PARAMS.STORAGE_CACHING)!==!1,ZR=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=ZR});var o_=I((lOe,kM)=>{"use strict";var qn=ce(),Ts=(H(),P(G));qn.initSync();var Xm=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=qn.get(Ts.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||qn.get(Ts.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||qn.get(Ts.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",qn.get(Ts.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=qn.get(Ts.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),qn.get(Ts.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=qn.get(Ts.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),qn.get(Ts.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=qn.get(Ts.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),qn.get(Ts.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=qn.get(Ts.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=qn.get(Ts.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};kM.exports=Xm;Xm.MAX_DBS=1e4});var ft=I((dOe,jM)=>{"use strict";var ty=require("lmdb"),Xs=require("fs-extra"),$n=require("path"),Zm=pn(),qM=W(),Tn=Bn().LMDB_ERRORS_ENUM,eE=DM(),ry=i_(),$M=o_(),ba=xt(),FM=(H(),P(G)),{table:pX,resetDatabases:hX}=(De(),P(nt)),GM=ce(),Zs=ba.INTERNAL_DBIS_NAME,VM=ba.DBI_DEFINITION_NAME,mX="data.mdb",EX="lock.mdb",a_=".mdb",gX="-lock",ey=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=As(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 ty.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function tE(e,t){if(e===void 0)throw new Error(Tn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Tn.ENV_NAME_REQUIRED)}a(tE,"pathEnvNameValidation");async function ny(e,t,r=!0){try{await Xs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Tn.INVALID_BASE_PATH):n}try{let n=$n.join(e,t+a_);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($n.join(e,t,mX),Xs.constants.R_OK|Xs.constants.F_OK),$n.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Tn.INVALID_ENVIRONMENT)}else throw new Error(Tn.INVALID_ENVIRONMENT);throw n}}a(ny,"validateEnvironmentPath");function rE(e,t){if(Zm.validateEnv(e),t===void 0)throw new Error(Tn.DBI_NAME_REQUIRED)}a(rE,"validateEnvDBIName");async function SX(e,t,r=!1,n=!1){tE(e,t);let s=$n.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 ny(e,t,n),KM(e,t,r)}catch(o){if(o.message===Tn.INVALID_ENVIRONMENT){let c=$n.join(e,t);await Xs.mkdirp(n?c:e);let l=new $M(n?c:c+a_,!1),u=ty.open(l);u.dbis=Object.create(null);let f=new ry(!1);u.openDB(Zs,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=sy(e,t,r);return u[ba.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(SX,"createEnvironment");async function TX(e,t,r,n=!0){tE(e,t),t=t.toString();let s=$n.join(e,t);return pX({table:t,database:$n.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(TX,"copyEnvironment");async function KM(e,t,r=!1){tE(e,t),t=t.toString();let n=sy(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 ny(e,t),i=$n.join(e,t+a_),o=s!=i,c=new $M(s,o),l=ty.open(c);l.dbis=Object.create(null);let u=WM(l);for(let f=0;f<u.length;f++)As(l,u[f]);return l[ba.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(KM,"openEnvironment");async function AX(e,t,r=!1){tE(e,t),t=t.toString();let n=$n.join(e,t+a_),s=await ny(e,t);if(global.lmdb_map!==void 0){let i=sy(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await YM(o),delete global.lmdb_map[i]}}await Xs.remove(s),await Xs.remove(s===n?s+gX:$n.join($n.dirname(s),EX))}a(AX,"deleteEnvironment");async function YM(e){Zm.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(YM,"closeEnvironment");function sy(e,t,r=!1){let s=`${$n.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(sy,"getCachedEnvironmentName");function RX(e){Zm.validateEnv(e);let t=Object.create(null),r=As(e,Zs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Zs)try{t[n]=Object.assign(new eE,s)}catch{qM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(RX,"listDBIDefinitions");function WM(e){Zm.validateEnv(e);let t=[],r=As(e,Zs);for(let{key:n}of r.getRange({start:!1}))n!==Zs&&t.push(n);return t}a(WM,"listDBIs");function yX(e,t){let n=As(e,Zs).getEntry(t),s=new eE;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(rE(e,t),t=t.toString(),t===Zs)throw new Error(Tn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return As(e,t)}catch(s){if(s.message===Tn.DBI_DOES_NOT_EXIST){let i=new ry(r,n===!0),o=e.openDB(t,i),c=new eE(r===!0,n);return o[VM]=c,As(e,Zs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(zM,"createDBI");function As(e,t){if(rE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Zs?r=yX(e,t):r=new eE,r===void 0)throw new Error(Tn.DBI_DOES_NOT_EXIST);let n;try{let s=new ry(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(Tn.DBI_DOES_NOT_EXIST):s}return n[VM]=r,e.dbis[t]=n,n}a(As,"openDBI");function bX(e,t){rE(e,t),t=t.toString();let r=As(e,t),n=r.getStats();return r[ba.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(bX,"statDBI");async function OX(e,t){try{let r=$n.join(e,t+a_);return(await Xs.stat(r)).size}catch{throw new Error(Tn.INVALID_ENVIRONMENT)}}a(OX,"environmentDataSize");function NX(e,t){if(rE(e,t),t=t.toString(),t===Zs)throw new Error(Tn.CANNOT_DROP_INTERNAL_DBIS_NAME);As(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],As(e,Zs).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{As(e,i)}catch(o){if(o.message===Tn.DBI_DOES_NOT_EXIST)zM(e,i,i!==t,i===t),n=!0;else throw o}}n&&hX()}a(wX,"initializeDBIs");jM.exports={openDBI:As,openEnvironment:KM,createEnvironment:SX,listDBIs:WM,listDBIDefinitions:RX,createDBI:zM,dropDBI:NX,statDBI:bX,deleteEnvironment:AX,initializeDBIs:wX,TransactionCursor:ey,environmentDataSize:OX,copyEnvironment:TX,closeEnvironment:YM}});var QM=I((_Oe,JM)=>{"use strict";var iy=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=iy});var ZM=I((hOe,XM)=>{"use strict";var oy=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=oy});var tv=I((EOe,ev)=>{"use strict";var ay=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=ay});var $c=I((ROe,sv)=>{"use strict";var IX=ft(),CX=QM(),PX=ZM(),DX=tv(),Mi=pn(),c_=Bn().LMDB_ERRORS_ENUM,LX=xt(),po=(H(),P(G)),MX=ae(),vX=require("uuid"),SOe=require("lmdb"),{handleHDBError:UX,hdb_errors:xX}=pe(),{OVERFLOW_MARKER:TOe,MAX_SEARCH_KEY_LENGTH:AOe}=LX,rv=ce();rv.initSync();var nE=rv.get(po.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),cy=po.TIME_STAMP_NAMES_ENUM.CREATED_TIME,qc=po.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function BX(e,t,r,n,s=Mi.getNextMonotonicTime()){fy(e,t,r,n),ly(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 uy(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][po.FUNC_VAL],n[o]=c)}let l=Mi.getIndexedValues(c),u=e.dbis[o];if(l){nE&&u.prefetch(l.map(f=>({key:f,value:s})),sE);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}nE&&e.dbis[t].prefetch([s],sE),e.dbis[t].put(s,n,n[qc])})}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[qc]))&&(e[qc]=r||(r=Mi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[cy]))&&(e[cy]=r||Mi.getNextMonotonicTime()):delete e[cy]}a(nv,"setTimestamps");function ly(e,t,r){r.indexOf(po.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(po.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(po.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(po.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),IX.initializeDBIs(e,t,r)}a(ly,"initializeTransaction");async function FX(e,t,r,n,s=Mi.getNextMonotonicTime()){fy(e,t,r,n),ly(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=dy(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(p),l.push(d)}return uy(c,l,n,i,s,o)}a(FX,"updateRecords");async function GX(e,t,r,n,s=Mi.getNextMonotonicTime()){try{fy(e,t,r,n)}catch(l){throw UX(l,l.message,xX.HTTP_STATUS_CODES.BAD_REQUEST)}ly(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=dy(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return uy(o,c,n,i,s)}a(GX,"upsertRecords");async function uy(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||Mi.getNextMonotonicTime(),kX(r,i),n}a(uy,"finalizeWrite");function dy(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[qc])&&u[qc]>r[qc])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][po.FUNC_VAL],r[h]=S)}if(S===R)continue;let E=Mi.getIndexedValues(R);if(E){nE&&g.prefetch(E.map(A=>({key:A,value:n})),sE);for(let A=0,N=E.length;A<N;A++)g.remove(E[A],n)}if(E=Mi.getIndexedValues(S),E){nE&&g.prefetch(E.map(A=>({key:A,value:n})),sE);for(let A=0,N=E.length;A<N;A++)g.put(E[A],n)}}let _={...u,...r};c.put(n,_,_[qc])},"do_put");return l?d=c.ifVersion(n,l.version,p):d=c.ifNoExists(n,p),d.then(_=>_?!0:dy(e,t,r,n,s,i,o))}a(dy,"updateUpsertRecord");function qX(e,t,r){if(Mi.validateEnv(e),t===void 0)throw new Error(c_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(c_.WRITE_ATTRIBUTES_REQUIRED):new Error(c_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(qX,"validateBasic");function fy(e,t,r,n){if(qX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(c_.RECORDS_REQUIRED):new Error(c_.RECORDS_MUST_BE_ARRAY)}a(fy,"validateWrite");function sE(){}a(sE,"noop");sv.exports={insertRecords:BX,updateRecords:FX,upsertRecords:GX}});var ho=I((bOe,$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=I((OOe,iv)=>{"use strict";var VX=require("uuid"),_y=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=_y});var iE=I((wOe,av)=>{"use strict";var KX=ov(),py=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=py});var lv=I((COe,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 oE=I((LOe,dv)=>{"use strict";var zX=(H(),P(G)),hy=ft(),jX=$c(),{getSystemSchemaPath:JX,getSchemaPath:QX}=Et(),DOe=ho(),{validateBySchema:XX}=it(),l_=require("joi"),ZX=iE(),e6=lv(),{handleHDBError:t6,hdb_errors:r6,ClientError:n6}=pe(),uv=ae(),{HTTP_STATUS_CODES:s6}=r6,i6="inserted";dv.exports=o6;async function o6(e){let t=XX(e,l_.object({database:l_.string(),schema:l_.string(),table:l_.string().required(),attribute:l_.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 hy.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}`);hy.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await hy.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 u_=I((UOe,_v)=>{"use strict";var mo=ae(),fv=W(),vOe=GR(),{getDatabases:a6}=(De(),P(nt)),{ClientError:Vc}=pe();_v.exports=c6;function c6(e){if(mo.isEmpty(e))throw new Vc("invalid update parameters defined.");if(mo.isEmptyOrZeroLength(e.schema))throw new Vc("invalid schema specified.");if(mo.isEmptyOrZeroLength(e.table))throw new Vc("invalid table specified.");if(!Array.isArray(e.records))throw new Vc("records must be an array");let t=a6()[e.schema]?.[e.table];if(mo.isEmpty(t))throw new Vc(`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&&mo.isEmptyOrZeroLength(o[r]))throw fv.error("a valid hash attribute must be provided with update record:",o),new Vc("a valid hash attribute must be provided with update record, check log for more info");if(!mo.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 Vc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!mo.isEmpty(o[r])&&o[r]!==""&&n.has(mo.autoCast(o[r]))&&(o.skip=!0),n.add(mo.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=I((BOe,pv)=>{"use strict";var my=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};pv.exports=my});var gv=I((kOe,Ev)=>{"use strict";var Ey=ft(),l6=W(),mv=Bn().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 Ey.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 Ey.closeEnvironment(global.lmdb_map[n]),await Ey.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=I((qOe,Pv)=>{"use strict";var gy=require("recursive-iterator"),d6=require("alasql"),Sy=require("clone"),Sv=ae(),{handleHDBError:Tv,hdb_errors:f6}=pe(),{HDB_ERROR_MSGS:Av,HTTP_STATUS_CODES:Rv}=f6,{getDatabases:_6}=(De(),P(nt)),p6=["DISTINCT_ARRAY"],yv=Symbol("validateTables"),Ty=Symbol("validateTable"),GOe=Symbol("getAllColumns"),bv=Symbol("validateAllColumns"),aE=Symbol("findColumn"),Ov=Symbol("validateOrderBy"),d_=Symbol("validateSegment"),Ay=Symbol("validateColumn"),Nv=Symbol("setColumnsForTable"),wv=Symbol("checkColumnsForAsterisk"),Iv=Symbol("validateGroupBy"),Cv=Symbol("hasColumns"),Ry=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[Ty](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Ty](t.table)})}}[Cv](){let t=!1,r=new gy(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Ty](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=Sy(s);i.table=Sy(t),this.attributes.push(i)})}[aE](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 gy(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[d_](this.statement.columns,!1),this[d_](this.statement.joins,!1),this[d_](this.statement.where,!1),this[Iv](this.statement.group,!1),this[d_](this.statement.order,!0)}[d_](t,r){if(!t)return;let n=new gy(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[Ay](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=Sy(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[aE](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[aE](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[Ay](t)}[Ay](t){let r=this[aE](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=Ry});var Uv=I((VOe,vv)=>{"use strict";var Lv=require("lodash"),f_=require("mathjs"),h6=require("jsonata"),Mv=ae();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Lv.uniqWith(e,Lv.isEqual):e,"distinct_array"),searchJSON:m6,mad:__.bind(null,f_.mad),mean:__.bind(null,f_.mean),mode:__.bind(null,f_.mode),prod:__.bind(null,f_.prod),median:__.bind(null,f_.median)};function __(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(__,"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=I((YOe,xv)=>{"use strict";var er=require("moment"),yy="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(yy),"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(yy),"get_server_time"),offset_utc:a((e,t)=>er(e).utc().utcOffset(t).format(yy),"offset_utc")}});var Gv=I((zOe,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(),P(G)),qe=ae(),Eo=W();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(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return E6.default(e)}catch(t){return Eo.trace(t,e),NaN}}a(N6,"geoArea");function w6(e,t){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return g6.default(e,{units:t||"kilometers"})}catch(r){return Eo.trace(r,e),NaN}}a(w6,"geoLength");function I6(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return S6.default(e,t,{units:r||"kilometers"})}catch(n){return Eo.trace(n,e,t),NaN}}a(I6,"geoCircle");function C6(e,t){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return T6(e,t)}catch(r){return Eo.trace(r,e,t),NaN}}a(C6,"geoDifference");function kv(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return A6.default(e,t,{units:r||"kilometers"})}catch(n){return Eo.trace(n,e,t),NaN}}a(kv,"geoDistance");function P6(e,t,r,n){if(qe.isEmpty(e)||qe.isEmpty(t))return!1;if(qe.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return kv(e,t,n)<=r}catch(s){return Eo.trace(s,e,t),!1}}a(P6,"geoNear");function D6(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return R6.default(e,t)}catch(r){return Eo.trace(r,e,t),!1}}a(D6,"geoContains");function L6(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return y6.default(e,t)}catch(r){return Eo.trace(r,e,t),!1}}a(L6,"geoEqual");function M6(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return!b6.default(e,t)}catch(r){return Eo.trace(r,e,t),!1}}a(M6,"geoCrosses");function v6(e,t,r){if(qe.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(qe.isEmpty(t))throw new Error("geo_type is required");if(qe.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=qe.autoCastJSON(e)),O6[t](e,r)}a(v6,"geoConvert")});var cE=I((JOe,qv)=>{var Kc=Uv(),Vn=Bv(),vi=Gv();qv.exports=e=>{e.aggr.mad=e.aggr.MAD=Kc.mad,e.aggr.mean=e.aggr.MEAN=Kc.mean,e.aggr.mode=e.aggr.MODE=Kc.mode,e.aggr.prod=e.aggr.PROD=Kc.prod,e.aggr.median=e.aggr.MEDIAN=Kc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Kc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Kc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Vn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Vn.current_time,e.fn.extract=e.fn.EXTRACT=Vn.extract,e.fn.date=e.fn.DATE=Vn.date,e.fn.date_format=e.fn.DATE_FORMAT=Vn.date_format,e.fn.date_add=e.fn.DATE_ADD=Vn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Vn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Vn.date_diff,e.fn.now=e.fn.NOW=Vn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Vn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Vn.get_server_time,e.fn.getdate=e.fn.GETDATE=Vn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Vn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=vi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=vi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=vi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=vi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=vi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=vi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=vi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=vi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=vi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=vi.geoNear}});var Yv=I((QOe,Kv)=>{"use strict";var p_=require("lodash"),An=require("alasql");An.options.cache=!1;var U6=cE(),$v=require("clone"),lE=require("recursive-iterator"),Be=W(),ze=ae(),Cu=Kn(),x6=(H(),P(G)),{hdb_errors:B6}=pe(),{getDatabases:Vv}=(De(),P(nt)),H6="IS NULL",ei="There was a problem performing this search. Please check the logs and try again.";U6(An);var by=class{static{a(this,"SQLSearch")}constructor(t,r){if(ze.isEmpty(t))throw Be.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 Be.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Be.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Be.error(n),new Error(ei)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Be.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Be.error(n),new Error(ei)}if(Object.keys(this.data).length===0)return Be.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Be.error("Error thrown from processJoins in SQLSearch class method search."),Be.error(n),new Error(ei)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Be.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Be.error(n),new Error(ei)}try{return t=await this._finalSQL(),t}catch(n){throw Be.error("Error thrown from finalSQL in SQLSearch class method search."),Be.error(n),new Error(ei)}}_getColumns(){let t=new lE(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=p_.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)){Be.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new lE(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 An.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 An.yy.LogicValue({value:i}):n instanceof An.yy.StringValue&&ze.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new An.yy.NumValue({value:i}))});if(t){Be.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new lE(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&&p_.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 An.promise(r)}catch(r){throw Be.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Be.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=p_.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 Cu.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 Be.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Be.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 Cu.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 Be.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Be.error(f),new Error(ei)}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 Cu.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 Be.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Be.error(f),new Error(ei)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await Cu.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 Be.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Be.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 An.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 An.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new An.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 An.yy.FuncValue:new An.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 An.promise(h,t),t=null}catch(_){throw Be.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Be.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=p_.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 lE(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=p_.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 Be.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Be.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 Cu.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 Be.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Be.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();Be.trace(`Final SQL: ${s}`),n=await An.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Be.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Be.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Be.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 Be.error(B6.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Be.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 Cu.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 Be.error("There was an error when processing this SQL operation. Check your logs"),Be.error(o),new Error(ei)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Kv.exports=by});var Wr=I((ZOe,Wv)=>{"use strict";var k6=Dv();Wv.exports={searchByConditions:G6,searchByHash:q6,searchByValue:$6,search:V6};var Oy=Kn(),{transformReq:Ny}=ae(),F6=Yv();async function G6(e){return Ny(e),Oy.searchByConditions(e)}a(G6,"searchByConditions");async function q6(e){Ny(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of Oy.searchByHash(e))r&&t.push(r);return t}a(q6,"searchByHash");async function $6(e){Ny(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of Oy.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 go=I((tNe,Qv)=>{"use strict";var h_=require("crypto"),K6=ce(),{CONFIG_PARAMS:Y6}=(H(),P(G)),jv="aes-256-cbc",W6=32,z6=16,wy=64,Jv=32,j6=wy+Jv,zv=new Map;Qv.exports={encrypt:J6,decrypt:Q6,createNatsTableStreamName:X6};function J6(e){let t=h_.randomBytes(W6),r=h_.randomBytes(z6),n=h_.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,wy),r=e.substr(wy,Jv),n=e.substr(j6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=h_.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=h_.createHash("md5").update(r).digest("hex"),zv.set(r,n)),n}a(X6,"createNatsTableStreamName")});var So=I((sNe,tU)=>{"use strict";var nNe=Wr(),m_=W(),{validateBySchema:Xv}=it(),Yc=require("joi"),Z6=go(),uE=ae(),{handleHDBError:dE,hdb_errors:eZ,ClientError:Zv}=pe(),{HDB_ERROR_MSGS:fE,HTTP_STATUS_CODES:Iy}=eZ,eU=ce();eU.initSync();var{getDatabases:Cy}=(De(),P(nt)),tZ=require("fs-extra"),rZ=(H(),P(G));tU.exports={describeAll:nZ,describeTable:_E,describeSchema:sZ};async function nZ(e={}){try{let t=uE.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=Cy(),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 _E({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 _E({schema:d,table:_,exact_count:u},S)}h&&l.push(h)}catch(h){m_.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 m_.error("Got an error in describeAll"),m_.error(t),dE(new Error,fE.DESCRIBE_ALL_ERR)}}a(nZ,"describeAll");async function _E(e,t){uE.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,Yc.object({database:Yc.string(),table:Yc.string().required(),exact_count:Yc.boolean().strict()}));if(i)throw new Zv(i.message);let c=Cy()[r];if(!c)throw dE(new Error,fE.SCHEMA_NOT_FOUND(e.schema),Iy.NOT_FOUND);let l=c[n];if(!l)throw dE(new Error,fE.TABLE_NOT_FOUND(e.schema,e.table),Iy.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(_){m_.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(_){m_.warn(`unable to stat table dbi due to ${_}`)}return p}a(_E,"descTable");async function sZ(e){uE.transformReq(e);let t=Xv(e,Yc.object({database:Yc.string(),exact_count:Yc.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=Cy()[n];if(!i)throw dE(new Error,fE.SCHEMA_NOT_FOUND(e.schema),Iy.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),uE.isEmpty(l)||l.describe){let u=await _E({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 Rs=I((cNe,oU)=>{var iZ=ho(),{callbackify:nU,promisify:oZ}=require("util"),{getDatabases:sU}=(De(),P(nt));oU.exports={setSchemaDataToGlobal:rU,getTableSchema:aZ,getSystemSchema:cZ,setSchemaDataToGlobalAsync:oZ(rU)};var iU=So(),oNe=nU(iU.describeAll),aNe=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 Dy=I((uNe,lU)=>{var lZ=it(),Py=require("joi"),{hdb_table:uZ,hdb_database:aU}=Li(),cU={schema:aU,database:aU,table:uZ},dZ={date:Py.date().iso().required()},fZ={timestamp:Py.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lU.exports=function(e,t){let r=t==="timestamp"?{...cU,...fZ}:{...cU,...dZ},n=Py.object(r);return lZ.validateBySchema(e,n)}});var fU=I((dNe,dU)=>{var _Z=it(),Ly=require("joi"),{hdb_table:pZ,hdb_database:uU}=Li(),hZ=Ly.object({schema:uU,database:uU,table:pZ,hash_values:Ly.array().required(),ids:Ly.array()});dU.exports=function(e){return _Z.validateBySchema(e,hZ)}});var xy=I((fNe,_U)=>{"use strict";var My=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}},vy=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}},Uy=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};_U.exports={InsertObject:My,NoSQLSeachObject:vy,DeleteResponseObject:Uy}});var jc=I((pNe,gU)=>{"use strict";var hU=Dy(),mZ=fU(),Wc=ae(),pU=require("moment"),mU=W(),{promisify:EZ,callbackify:gZ}=require("util"),zc=(H(),P(G)),SZ=Rs(),By=EZ(SZ.getTableSchema),Hy=Kn(),{DeleteResponseObject:TZ}=xy(),{handleHDBError:Oa,hdb_errors:AZ}=pe(),{HDB_ERROR_MSGS:pE,HTTP_STATUS_CODES:Na}=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 Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);if(Wc.transformReq(e),!pU(e.date,pU.ISO_8601).isValid())throw Oa(new Error,pE.INVALID_DATE,Na.BAD_REQUEST,zc.LOG_LEVELS.ERROR,pE.INVALID_DATE,!0);let n=Wc.checkSchemaTableExist(e.schema,e.table);if(n)throw Oa(new Error,n,Na.NOT_FOUND,zc.LOG_LEVELS.ERROR,n,!0);let s=await Hy.deleteRecordsBefore(e);if(await By(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 Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);if(Wc.transformReq(e),isNaN(e.timestamp))throw Oa(new Error,pE.INVALID_VALUE("Timestamp"),Na.BAD_REQUEST,zc.LOG_LEVELS.ERROR,pE.INVALID_VALUE("Timestamp"),!0);let r=Wc.checkSchemaTableExist(e.schema,e.table);if(r)throw Oa(new Error,r,Na.NOT_FOUND,zc.LOG_LEVELS.ERROR,r,!0);let n=await Hy.deleteAuditLogsBefore(e);return await By(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 Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);Wc.transformReq(e);let r=Wc.checkSchemaTableExist(e.schema,e.table);if(r)throw Oa(new Error,r,Na.NOT_FOUND,zc.LOG_LEVELS.ERROR,r,!0);try{await By(e.schema,e.table);let n=await Hy.deleteRecords(e);return Wc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${RZ}`),n}catch(n){if(n.message===zc.SEARCH_NOT_FOUND_MESSAGE){let s=new TZ;return s.message=zc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(EU,"deleteRecord")});var hE={};Ue(hE,{HASH_FUNCTION:()=>S_,hash:()=>Gy,validate:()=>qy});function ky(e=g_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(E_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function Gy(e,t=S_[TU?.toUpperCase()]??"sha256"){return Fy[t](e)}function qy(e,t,r=S_[TU?.toUpperCase()]??"sha256"){return e?NZ[r](e,t):!1}var E_,Pu,SU,TU,g_,AU,S_,Fy,NZ,mE=be(()=>{E_=M(require("node:crypto")),Pu=M(require("argon2")),SU=M(ce());H();TU=(0,SU.get)(x.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),g_=16,AU=9,S_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(S_||{});a(ky,"generateSalt");Fy={md5:a((e,t=void 0)=>{t=t??ky(AU);let r=E_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??ky(g_);let r=E_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=ky(g_),r=await Pu.hash(e,{type:Pu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},NZ={md5:a((e,t)=>{let r=e.slice(0,AU);return e===Fy.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,g_);return e===Fy.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await Pu.verify(e.slice(g_),t),"argon2id")};a(Gy,"hash");a(qy,"validate")});var yU=I((gNe,RU)=>{var $y=it(),zr={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 zr.password.presence=!0,zr.username.presence=!0,zr.role.presence=!0,zr.active.presence=!0,$y.validateObject(e,zr)}a(wZ,"addUserValidation");function IZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,$y.validateObject(e,zr)}a(IZ,"alterUserValidation");function CZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,$y.validateObject(e,zr)}a(CZ,"dropUserValidation");RU.exports={addUserValidation:wZ,alterUserValidation:IZ,dropUserValidation:CZ}});var St=I((ANe,OU)=>{"use strict";var{platform:TNe}=require("os"),PZ="nats-server.zip",Vy="nats-server",DZ=process.platform==="win32"?`${Vy}.exe`:Vy,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"},Du={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},GZ={[Du.ERR]:1,[Du.WRN]:2,[Du.INF]:3,[Du.DBG]:4,[Du.TRC]:5},qZ={debug:"-D",trace:"-DVV"};OU.exports={NATS_SERVER_ZIP:PZ,NATS_SERVER_NAME:Vy,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:Du,LOG_LEVEL_FLAGS:qZ,LOG_LEVEL_HIERARCHY:GZ}});var Ky=I(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
|
-
`)},KZ="certificate.pem",YZ="privateKey.pem",WZ="caCertificate.pem",zZ="natsCertificate.pem",jZ="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"]},QZ={[At.SERVER]:2,[At.DEFAULT]:1},XZ={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},ZZ={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},e8={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},t8={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},r8={[At.CA]:2,[At["DEFAULT-CA"]]:1};Object.assign(OU,{CERTIFICATE_PEM_NAME:KZ,PRIVATEKEY_PEM_NAME:YZ,CA_PEM_NAME:WZ,CERT_NAME:At,CERT_CONFIG_NAME_MAP:JZ,CERT_PREFERENCE_APP:QZ,CERT_PREFERENCE_OPS:XZ,CERT_PREFERENCE_REP:ZZ,CA_CERT_PREFERENCE_REP:e8,CA_CERT_PREFERENCE_OPS:t8,CA_CERT_PREFERENCE_APP:r8,CERTIFICATE_VALUES:VZ,NATS_CERTIFICATE_PEM_NAME:zZ,NATS_CA_PEM_NAME:jZ})});var Ky=w((bNe,DU)=>{"use strict";var CU=require("fs-extra"),Te=require("joi"),n8=require("os"),{boolean:Be,string:Rt,number:tr,array:Yc}=Te.types(),{totalmem:NU}=require("os"),Kc=require("path"),s8=z(),Vy=ie(),yNe=$y(),wU=(H(),C(G)),i8=it(),IU="log",o8="components",a8="Invalid logging.rotation.maxSize unit. Available units are G, M or K",c8="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",l8="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",u8="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",d8="rootPath config parameter is undefined",Tn=Te.alternatives([tr.min(0),Rt]).optional().empty(null),hE=Te.alternatives([Yc.items(Rt,{host:Rt.required(),port:Tn},{hostname:Rt.required(),port:Tn}).empty(null),Yc.items(Rt)]),vi,PU=!1;DU.exports={configValidator:f8,routesValidator:g8,route_constraints:hE};function f8(e,t=!1){if(PU=t,vi=e.rootPath,Vy.isEmpty(vi))throw d8;let r=Be.optional(),n=tr.min(0).max(1e3).empty(null).default(E8),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=Te.string().empty(null).default(S_),l=Te.custom(p8).empty(null).default(S_),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:hE}).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:hE}).required(),streams:Te.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: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:tr.required(),enableSessions:Be,hashFunction:Rt.valid("md5","sha256","argon2id").optional().empty(null)}),Be).optional(),analytics:Te.object({aggregatePeriod:tr}),replication:Te.object({hostname:Te.alternatives(Rt,tr).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(m8).optional().empty(null),maxSize:Rt.custom(h8).optional().empty(null),path:Rt.optional().empty(null).default(S_)}).required(),root:s,stdStreams:Be.required(),auditLog:Be.required()}).required(),operationsApi:Te.object({network:Te.object({cors:Be.optional(),corsAccessList:Yc.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:Tn,domainSocket:Te.optional().empty("hdb/operations-server").default(S_),securePort:Tn,timeout:tr.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:tr.optional(),cors:Be.optional(),corsAccessList:Yc.optional(),headersTimeout:tr.min(1).optional(),port:Tn,securePort:Tn,maxHeaderSize:tr.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:tr.min(1).optional(),host:Rt.optional(),waitForDebugger:Be.optional()})),maxHeapMemory:tr.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: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:Te.alternatives([Te.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(f8,"configValidator");function _8(e){return PU||CU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(_8,"doesPathExist");function p8(e,t){Te.assert(e,Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=_8(e);if(r)return t.message(r)}a(p8,"validatePath");function h8(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(a8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(l8):e}a(h8,"validateRotationMaxSize");function m8(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(c8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(u8):e}a(m8,"validateRotationInterval");function E8(e,t){let r=t.state.path.join("."),n=n8.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),s8.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(E8,"setDefaultThreads");function S_(e,t){let r=t.state.path.join(".");if(!Vy.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Vy.isEmpty(vi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Kc.join(vi,o8);case"logging.root":return Kc.join(vi,IU);case"clustering.leafServer.streams.path":return Kc.join(vi,"clustering","leaf");case"storage.path":let n=Kc.join(vi,wU.LEGACY_DATABASES_DIR_NAME);return CU.existsSync(n)?n:Kc.join(vi,wU.DATABASES_DIR_NAME);case"logging.rotation.path":return Kc.join(vi,IU);case"operationsApi.network.domainSocket":return r==null?null:Kc.join(vi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(S_,"setDefaultRoot");function g8(e){let t=Te.object({routes:hE});return i8.validateBySchema({routes:e},t)}a(g8,"routesValidator")});var yt=w(qU=>{"use strict";var Rs=(H(),C(G)),gr=ie(),rr=z(),{configValidator:S8,routesValidator:LU}=Ky(),zr=require("fs-extra"),vU=require("yaml"),Yn=require("path"),T8=require("is-number"),UU=require("properties-reader"),A8=require("lodash"),{handleHDBError:R8}=pe(),{HTTP_STATUS_CODES:y8,HDB_ERROR_MSGS:Pu}=Un(),{server:b8}=(Vr(),C(Tu)),{PACKAGE_ROOT:xU}=st(),{DATABASES_PARAM_CONFIG:T_,CONFIG_PARAMS:Kn,CONFIG_PARAM_MAP:ei}=Rs,O8="Unable to get config value because config is uninitialized",N8="Config successfully initialized",w8="Error backing up config file",I8="Empty parameter sent to getConfigValue",BU=Yn.join(xU,"config","yaml",Rs.HDB_DEFAULT_CONFIG_FILE),C8=Yn.join(xU,"config","yaml","defaultNatsConfig.yaml"),P8="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"},mE,It,EE;Object.assign(qU,{createConfigFile:D8,getDefaultConfig:L8,getConfigValue:kU,initConfig:gE,flattenConfig:Du,updateConfigValue:FU,updateConfigObject:v8,getConfiguration:B8,setConfiguration:H8,readConfigFile:jy,getClusteringRoutes:k8,initOldConfig:GU,getConfigFromFile:F8,getConfigFilePath:Wc,addConfig:G8,deleteConfigFromFile:q8,getConfigObj:$8,resolvePath:Yy,getFlatConfigObj:V8});function Yy(e){if(e?.startsWith("~/"))return Yn.join(gr.getHomeDir(),e.slice(1));let t=ae();return Yn.resolve(t.getHdbBasePath(),e)}a(Yy,"resolvePath");function D8(e,t=!1){let r=Na(BU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=vU.parseDocument(zr.readFileSync(C8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}mE=Du(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=Wy(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){rr.error(d)}}}n&&HU(r,n),zy(r,t);let s=r.toJSON();It=Du(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(D8,"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(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(HU,"setSchemasConfig");function L8(e){if(mE===void 0){let r=Na(BU);mE=Du(r.toJSON())}let t=ei[e.toLowerCase()];if(t!==void 0)return mE[t.toLowerCase()]}a(L8,"getDefaultConfig");function kU(e){if(e==null){rr.info(I8);return}if(It===void 0){rr.trace(O8);return}let t=ei[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 Yy(Yn.join(t,Rs.HDB_CONFIG_FILE));let r=UU(e);return Yy(r.get(Rs.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Wc,"getConfigFilePath");function gE(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 rr.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!==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}`)}M8(n,r),zy(n);let s=n.toJSON();if(b8.config=s,It=Du(s),It.logging_rotation_rotate)for(let i in MU)It[i]&&rr.error(`Config ${MU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);rr.trace(N8)}}a(gE,"initConfig");function M8(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(M8,"checkForUpdatedConfig");function zy(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 Pu.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 Pu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=S8(r,t);if(n.error)throw Pu.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(zy,"validateConfig");function v8(e,t){It===void 0&&(It={});let r=ei[e.toLowerCase()];if(r===void 0){rr.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a(v8,"updateConfigObject");function FU(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&gE();let o=kU(ei.hdb_root),c=Yn.join(o,Rs.HDB_CONFIG_FILE),l=Na(c),u;if(r&&It){let p=!1;for(let _ in r)if(r[_]!=It[_.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=Wy(p,t);l.setIn([..._],h)}else for(let p in r){let _=ei[p.toLowerCase()];if(_===Kn.HTTP_SECUREPORT&&r[p]===It[Kn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===Kn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[p]===It[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=Wy(_,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&&HU(l,u),zy(l);let f=l.getIn(["rootPath"]),d=Yn.join(f,Rs.HDB_CONFIG_FILE);if(n===!0&&U8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);zr.writeFileSync(d,String(l)),s&&(It=Du(l.toJSON())),rr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(FU,"updateConfigValue");function U8(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(w8),rr.error(r)}}a(U8,"backupConfigFile");var x8=["databases"];function Du(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}),EE=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])&&!x8.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(Du,"flattenConfig");function Wy(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(T8(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(Wy,"castConfigValue");function B8(){let e=gr.getPropsFilePath(),t=Wc(e);return Na(t).toJSON()}a(B8,"getConfiguration");async function H8(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return FU(void 0,void 0,s,!0),P8}catch(i){throw typeof i=="string"||i instanceof String?R8(i,i,y8.BAD_REQUEST,void 0,void 0,!0):i}}a(H8,"setConfiguration");function jy(){let e=gr.getPropsFilePath();try{zr.accessSync(e,zr.constants.F_OK|zr.constants.R_OK)}catch(n){if(!gr.noBootFile())throw rr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Wc(e);return Na(t).toJSON()}a(jy,"readConfigFile");function Na(e){return vU.parseDocument(zr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Na,"parseYamlDoc");function k8(){let e=jy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=gr.isEmptyOrZeroLength(t)?[]:t;let r=LU(t);if(r)throw Pu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=gr.isEmptyOrZeroLength(n)?[]:n;let s=LU(n);if(s)throw Pu.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 Pu.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(k8,"getClusteringRoutes");function GU(e){let t=UU(e);It={};for(let r in ei){let n=t.get(r.toUpperCase());if(gr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ei[r].toLowerCase();s===Kn.LOGGING_ROOT?It[s]=Yn.dirname(n):It[s]=n}return It}a(GU,"initOldConfig");function F8(e){let t=jy();return A8.get(t,e.replaceAll("_","."))}a(F8,"getConfigFromFile");async function G8(e,t){let r=Na(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(G8,"addConfig");function q8(e){let t=Wc(gr.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(q8,"deleteConfigFromFile");function $8(){return EE||(gE(),EE)}a($8,"getConfigObj");function V8(){return It||gE(),It}a(V8,"getFlatConfigObj")});var An=w((INe,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=Z8;Or.exports.alterUser=e5;Or.exports.dropUser=r5;Or.exports.getSuperUser=a5;Or.exports.userInfo=n5;Or.exports.listUsers=TE;Or.exports.listUsersExternal=s5;Or.exports.setUsersWithRolesCache=zc;Or.exports.findAndValidateUser=sb;Or.exports.getClusterUser=c5;Or.exports.getUsersWithRolesCache=o5;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 JU=Rn(),K8=Vc(),A_=(pE(),C(_E)),QU=RU(),R_=Yr(),eb=To(),Ui=ie(),XU=require("validate.js"),tb=z(),{promisify:Y8}=require("util"),rb=Eo(),Qy=(H(),C(G)),$U=Tt(),W8=yt(),z8=ae(),j8=po(),{hdb_errors:J8,ClientError:ti}=pe(),{HTTP_STATUS_CODES:So,AUTHENTICATION_ERROR_MSGS:Jy,HDB_ERROR_MSGS:Lu}=J8,{UserEventMsg:nb}=ri(),Xy=require("lodash"),{server:SE}=(Vr(),C(Tu)),Q8=z();SE.getUser=(e,t)=>sb(e,t,t!=null);SE.authenticateUser=(e,t)=>sb(e,t);var ZU={username:!0,active:!0,role:!0,password:!0},VU=new Map,X8=Y8(K8.delete),Zy=z8.get(Qy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??A_.HASH_FUNCTION.SHA256,xi;async function Z8(e){let t=XU.cleanAttributes(e,ZU),r=QU.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(Lu.ROLE_NAME_NOT_FOUND(t.role),So.NOT_FOUND);if(n.length>1)throw new ti(Lu.DUP_ROLES_FOUND(t.role),So.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=rb.encrypt(t.password)),t.password=await A_.hash(t.password,Zy),t.hash_function=Zy,t.role=n[0].id;let s=await JU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(tb.debug(s),await zc(),s.skipped_hashes.length===1)throw new ti(Lu.USER_ALREADY_EXISTS(t.username),So.CONFLICT);return eb.signalUserChange(new nb(process.pid)),`${t.username} successfully added`}a(Z8,"addUser");async function e5(e){let t=XU.cleanAttributes(e,ZU);if(Ui.isEmptyOrZeroLength(t.username))throw new Error(KU);if(Ui.isEmptyOrZeroLength(t.password)&&Ui.isEmptyOrZeroLength(t.role)&&Ui.isEmptyOrZeroLength(t.active))throw new Error(YU);if(!Ui.isEmpty(t.password)&&Ui.isEmptyOrZeroLength(t.password.trim()))throw new Error(WU);if(!Ui.isEmpty(t.active)&&!Ui.isBoolean(t.active))throw new Error(jU);if(!Ui.isEmpty(t.password)&&!Ui.isEmptyOrZeroLength(t.password.trim())&&(t5(t.username)&&(t.hash=rb.encrypt(t.password)),t.password=await A_.hash(t.password,Zy)),t.role==="")throw new Error(zU);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(Lu.ALTER_USER_ROLE_NOT_FOUND(t.role),So.NOT_FOUND);if(n.length>1)throw new ti(Lu.DUP_ROLES_FOUND(t.role),So.CONFLICT);t.role=n[0].id}let r=await JU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await zc(),eb.signalUserChange(new nb(process.pid)),r}a(e5,"alterUser");function t5(e){let t=!1,r=xi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(t5,"isClusterUser");async function r5(e){let t=QU.dropUserValidation(e);if(t)throw new ti(t.message);if(xi.get(e.username)===void 0)throw new ti(Lu.USER_NOT_EXIST(e.username),So.NOT_FOUND);let r=await X8({table:"hdb_user",schema:"system",hash_values:[e.username]});return tb.debug(r),await zc(),eb.signalUserChange(new nb(process.pid)),`${e.username} successfully deleted`}a(r5,"dropUser");async function n5(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Xy.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(n5,"userInfo");async function s5(){let e=await TE();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(s5,"listUsersExternal");async function TE(){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]=Xy.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=Xy.cloneDeep(s),s.role=t[s.role],i5(s.role),n.set(s.username,s);return n}a(TE,"listUsers");function i5(e){if(!e){tb.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(j8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(i5,"appendSystemTablesToRole");async function zc(e=void 0){e?xi=e:xi=await TE()}a(zc,"setUsersWithRolesCache");async function o5(){return xi||await zc(),xi}a(o5,"getUsersWithRolesCache");async function sb(e,t,r=!0){xi||await zc();let n=xi.get(e);if(!n){if(!r)return{username:e};throw new ti(Jy.GENERIC_AUTH_FAIL,So.UNAUTHORIZED)}if(n&&!n.active)throw new ti(Jy.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(VU.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)VU.set(t,n.password);else throw new ti(Jy.GENERIC_AUTH_FAIL,So.UNAUTHORIZED)}}return s}a(sb,"findAndValidateUser");async function a5(){xi||await zc();for(let[,e]of xi)if(e.role.role==="super_user")return e}a(a5,"getSuperUser");async function c5(){let e=await TE(),t=W8.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=rb.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(c5,"getClusterUser");var e0=[];SE.invalidateUser=function(e){for(let t of e0)try{t(e)}catch(r){Q8.error("Error invalidating user",r)}};SE.onInvalidatedUser=function(e){e0.push(e)}});var b_=w((LNe,s0)=>{"use strict";var jc=z(),Wn=(H(),C(G)),l5=Ev(),PNe=As(),DNe=go(),u5=An(),{validateEvent:t0}=ri(),y_=Vn(),d5=require("process"),{resetDatabases:f5}=(Pe(),C(tt)),_5={[Wn.ITC_EVENT_TYPES.SCHEMA]:p5,[Wn.ITC_EVENT_TYPES.USER]:n0};async function p5(e){let t=t0(e);if(t){jc.error(t);return}jc.trace("ITC schemaHandler received schema event:",e),await l5(e.message),await h5(e.message)}a(p5,"schemaHandler");async function h5(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=f5();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){jc.error(t)}}a(h5,"syncSchemaMetadata");var r0=[];async function n0(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){jc.warn(r)}let t=t0(e);if(t){jc.error(t);return}jc.trace(`ITC userHandler ${Wn.HDB_ITC_CLIENT_PREFIX}${d5.pid} received user event:`,e),await u5.setUsersWithRolesCache();for(let r of r0)r()}catch(t){jc.error(t)}}a(n0,"userHandler");n0.addListener=function(e){r0.push(e)};s0.exports=_5});var ri=w((HNe,o0)=>{"use strict";var vNe=z(),ib=ie(),m5=(H(),C(G)),{ITC_ERRORS:O_}=Un(),{parentPort:UNe,threadId:E5,isMainThread:g5,workerData:xNe}=require("worker_threads"),{onMessageFromWorkers:S5,broadcast:BNe,broadcastWithAcknowledgement:T5}=et();o0.exports={sendItcEvent:A5,validateEvent:i0,SchemaEventMsg:R5,UserEventMsg:y5};var AE;S5(async(e,t)=>{AE=AE||b_(),i0(e),AE[e.type]&&await AE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function A5(e){return!g5&&e.message&&(e.message.originator=E5),T5(e)}a(A5,"sendItcEvent");function i0(e){if(typeof e!="object")return O_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||ib.isEmpty(e.type))return O_.MISSING_TYPE;if(!e.hasOwnProperty("message")||ib.isEmpty(e.message))return O_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||ib.isEmpty(e.message.originator))return O_.MISSING_ORIGIN;if(m5.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return O_.INVALID_EVENT(e.type)}a(i0,"validateEvent");function R5(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(R5,"SchemaEventMsg");function y5(e){this.originator=e}a(y5,"UserEventMsg")});var To=w((GNe,u0)=>{"use strict";var a0=(H(),C(G)),FNe=ie(),RE=z(),c0=pv(),Mu,{sendItcEvent:l0}=ri();function b5(e){try{RE.info("signalSchemaChange called with message:",e),Mu=Mu||b_();let t=new c0(a0.ITC_EVENT_TYPES.SCHEMA,e);return Mu.schema(t),l0(t)}catch(t){RE.error(t)}}a(b5,"signalSchemaChange");function O5(e){try{RE.trace("signalUserChange called with message:",e),Mu=Mu||b_();let t=new c0(a0.ITC_EVENT_TYPES.USER,e);return Mu.user(t),l0(t)}catch(t){RE.error(t)}}a(O5,"signalUserChange");u0.exports={signalSchemaChange:b5,signalUserChange:O5}});var yE=w(($Ne,f0)=>{"use strict";var d0=ie(),N5=(H(),C(G)),w5=z(),I5=sE(),C5=nE(),P5=To(),{SchemaEventMsg:D5}=ri(),L5="already exists in";f0.exports=M5;async function M5(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 v5(e,t.schema,t.name,i)})),s}a(M5,"lmdbCheckForNewAttributes");async function v5(e,t,r,n){let s=new C5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await U5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(L5))w5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(v5,"createNewAttribute");async function U5(e){let t;return t=await I5(e),P5.signalSchemaChange(new D5(process.pid,N5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(U5,"createAttribute")});var vu=w((KNe,_0)=>{"use strict";var ob=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=ob});var h0=w((WNe,p0)=>{"use strict";var x5=vu(),B5=(H(),C(G)).OPERATIONS_ENUM,ab=class extends x5{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(B5.INSERT,r,n,s,i),this.records=t}};p0.exports=ab});var E0=w((jNe,m0)=>{"use strict";var H5=vu(),k5=(H(),C(G)).OPERATIONS_ENUM,cb=class extends H5{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(k5.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};m0.exports=cb});var S0=w((QNe,g0)=>{"use strict";var F5=vu(),G5=(H(),C(G)).OPERATIONS_ENUM,lb=class extends F5{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(G5.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};g0.exports=lb});var A0=w((ZNe,T0)=>{"use strict";var q5=vu(),$5=(H(),C(G)).OPERATIONS_ENUM,ub=class extends q5{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super($5.DELETE,n,s,t,i),this.original_records=r}};T0.exports=ub});var N_=w((rwe,O0)=>{"use strict";var twe=require("path"),R0=_t(),V5=h0(),K5=E0(),Y5=S0(),W5=A0(),Uu=Ut(),y0=ie(),{CONFIG_PARAMS:z5}=(H(),C(G)),b0=ae();b0.initSync();var bE=(H(),C(G)).OPERATIONS_ENUM,{getTransactionAuditStorePath:j5}=gt();O0.exports=J5;async function J5(e,t){if(b0.get(z5.LOGGING_AUDITLOG)===!1)return;let r=j5(e.schema,e.table),n=await R0.openEnvironment(r,e.table,!0),s=Q5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){R0.initializeDBIs(n,Uu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Uu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Uu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Uu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),y0.isEmpty(s.user_name)||n.dbis[Uu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Uu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(J5,"writeTransaction");function Q5(e,t){let r=y0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===bE.INSERT)return new V5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===bE.UPDATE)return new K5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===bE.UPSERT)return new Y5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===bE.DELETE)return new W5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(Q5,"createTransactionObject")});var db=w((iwe,N0)=>{"use strict";var X5=l_(),swe=Uf(),w_=(H(),C(G)),Z5=xf(),e9=Hc().insertRecords,t9=_t(),r9=z(),n9=yE(),{getSchemaPath:s9}=gt(),i9=N_();N0.exports=o9;async function o9(e){try{let{schema_table:t,attributes:r}=X5(e);Z5(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 n9(e.hdb_auth_header,t,r),s=s9(e.schema,e.table),i=await t9.openEnvironment(s,e.table),o=await e9(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await i9(e,o)}catch(c){r9.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(o9,"lmdbCreateRecords")});var C0=w((awe,I0)=>{"use strict";var w0=(H(),C(G)),a9=db(),c9=Uf(),l9=require("fs-extra"),{getSchemaPath:u9}=gt();I0.exports=d9;async function d9(e){let t=[{name:e.schema,createddate:Date.now()}],r=new c9(w0.SYSTEM_SCHEMA_NAME,w0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await a9(r),await l9.mkdirp(u9(e.schema))}a(d9,"lmdbCreateSchema")});var D0=w((lwe,P0)=>{"use strict";var fb=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=fb});var U0=w((pwe,v0)=>{"use strict";var L0=_t(),_b=_n(),pb=Un().LMDB_ERRORS_ENUM,f9=Ut(),M0=z(),dwe=ie(),_9=require("lmdb"),p9=D0(),h9=(H(),C(G)),{OVERFLOW_MARKER:fwe,MAX_SEARCH_KEY_LENGTH:_we}=f9,m9=h9.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function E9(e,t,r,n){if(_b.validateEnv(e),t===void 0)throw new Error(pb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(pb.IDS_REQUIRED):new Error(pb.IDS_MUST_BE_ITERABLE);try{let s=L0.listDBIs(e);L0.initializeDBIs(e,t,s);let i=new p9,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[m9]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,_9.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=_b.getIndexedValues(T);if(b)for(let v=0,F=b.length;v<F;v++)E.remove(b[v],o)}catch{M0.warn(`cannot delete from attribute: ${R}, ${T}:${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=_b.getNextMonotonicTime(),i}catch(s){throw s}}a(E9,"deleteRecords");v0.exports={deleteRecords:E9}});var I_=w((mwe,B0)=>{"use strict";var xu=ie(),g9=U0(),S9=_t(),{getSchemaPath:T9}=gt(),A9=N_(),R9=z();B0.exports=y9;async function y9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(xu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(xu.isEmptyOrZeroLength(e.hash_values)&&!xu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];xu.isEmpty(l)||e.hash_values.push(l)}}if(xu.isEmptyOrZeroLength(e.hash_values))return x0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(xu.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=T9(e.schema,e.table),i=await S9.openEnvironment(s,e.table),o=await g9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await A9(e,o)}catch(c){R9.error(`unable to write transaction due to ${c.message}`)}return x0(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(y9,"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 mb=w((Swe,H0)=>{"use strict";var b9=(H(),C(G)),gwe=_n();function hb(e,t){let r=Object.create(null);if(t.length===1&&b9.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(hb,"parseRow");function O9(e,t,r,n){let s=hb(r,e);n.push(s)}a(O9,"searchAll");function N9(e,t,r,n){let s=hb(r,e);n[t]=s}a(N9,"searchAllToMap");function w9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(w9,"iterateDBI");function Jc(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(Jc,"pushResults");function I9(e,t,r,n,s,i){t.toString().endsWith(e)&&Jc(t,r,n,s,i)}a(I9,"endsWith");function C9(e,t,r,n,s,i){t.toString().includes(e)&&Jc(t,r,n,s,i)}a(C9,"contains");function P9(e,t,r,n,s,i){t>e&&Jc(t,r,n,s,i)}a(P9,"greaterThanCompare");function D9(e,t,r,n,s,i){t>=e&&Jc(t,r,n,s,i)}a(D9,"greaterThanEqualCompare");function L9(e,t,r,n,s,i){t<e&&Jc(t,r,n,s,i)}a(L9,"lessThanCompare");function M9(e,t,r,n,s,i){t<=e&&Jc(t,r,n,s,i)}a(M9,"lessThanEqualCompare");H0.exports={parseRow:hb,searchAll:O9,searchAllToMap:N9,iterateDBI:w9,endsWith:I9,contains:C9,greaterThanCompare:P9,greaterThanEqualCompare:D9,lessThanCompare:L9,lessThanEqualCompare:M9,pushResults:Jc}});var Bu=w((bwe,K0)=>{"use strict";var wa=_t(),Awe=z(),zn=_n(),OE=Ut(),Wt=Un().LMDB_ERRORS_ENUM,Rwe=ie(),v9=(H(),C(G)),NE=mb(),{parseRow:U9}=NE,ywe=require("lmdb"),{OVERFLOW_MARKER:k0,MAX_SEARCH_KEY_LENGTH:x9}=OE;function F0(e,t,r,n=!1,s=void 0,i=void 0){return Qc(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 C_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Qc(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 Qc(e,t,r,n){let s=e.database||e,i=wa.openDBI(s,r);i[OE.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(Qc,"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=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[OE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(G0,"getOverflowCheck");function B9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);return Qc(e,t,t,(o,c,l)=>(wE(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=>U9(u.value,r))))}a(B9,"searchAll");function H9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);wE(r),r=P_(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,NE.parseRow(l,r));return o}a(H9,"searchAllToMap");function k9(e,t,r=!1,n=void 0,s=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.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(k9,"iterateDBI");function F9(e,t){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);return wa.statDBI(e,t).entryCount}a(F9,"countAll");function G9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ia(e,r,n),Qc(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(G9,"equals");function q9(e,t,r){return Ia(e,t,r),wa.openDBI(e,t).getValuesCount(r)}a(q9,"count");function $9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ia(e,r,n),Qc(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($9,"startsWith");function V9(e,t,r,n,s=!1,i=void 0,o=void 0){return q0(e,t,r,n,s,i,o,!0)}a(V9,"endsWith");function q0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Ia(e,r,n),Qc(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[OE.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 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,!0,!1)}a(K9,"greaterThan");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="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),C_(e,t,r,n,l,s,i,o,!1,!1)}a(Y9,"greaterThanEqual");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,!0)}a(W9,"lessThan");function z9(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(z9,"lessThanEqual");function j9(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(zn.validateEnv(e),r===void 0)throw new Error(Wt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Wt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Wt.END_VALUE_REQUIRED);if(n=zn.convertKeyValueToWrite(n),s=zn.convertKeyValueToWrite(s),n>s)throw new Error(Wt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return C_(e,t,r,n,s,i,o,c)}a(j9,"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(Wt.HASH_ATTRIBUTE_REQUIRED);if(wE(r),r=P_(s,r),n===void 0)throw new Error(Wt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=NE.parseRow(c,r)),o}a(J9,"searchByHash");function Q9(e,t,r){zn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Wt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(Q9,"checkHashExists");function X9(e,t,r,n,s=[]){return V0(e,t,r,n,s),$0(e,t,r,n,s).map(i=>i[1])}a(X9,"batchSearchByHash");function Z9(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(Z9,"batchSearchByHashToMap");function $0(e,t,r,n,s=[]){return Qc(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,NE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a($0,"batchHashSearch");function V0(e,t,r,n,s){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);if(wE(r),n==null)throw new Error(Wt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Wt.IDS_MUST_BE_ITERABLE)}a(V0,"initializeBatchSearchByHash");function wE(e){if(!Array.isArray(e))throw e===void 0?new Error(Wt.FETCH_ATTRIBUTES_REQUIRED):new Error(Wt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(wE,"validateFetchAttributes");function Ia(e,t,r){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Wt.SEARCH_VALUE_REQUIRED);if(r?.length>x9)throw new Error(Wt.SEARCH_VALUE_TOO_LARGE)}a(Ia,"validateComparisonFunctions");function P_(e,t){return t.length===1&&v9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wa.listDBIs(e)),t}a(P_,"setGetWholeRowAttributes");K0.exports={searchAll:B9,searchAllToMap:H9,count:q9,countAll:F9,equals:G9,startsWith:$9,endsWith:V9,contains:q0,searchByHash:J9,setGetWholeRowAttributes:P_,batchSearchByHash:X9,batchSearchByHashToMap:Z9,checkHashExists:Q9,iterateDBI:k9,greaterThan:K9,greaterThanEqual:Y9,lessThan:W9,lessThanEqual:z9,between:j9}});var Hu=w((Nwe,J0)=>{var Y0=require("lodash"),W0=it(),He=require("joi"),e7=ie(),{hdb_schema_table:D_,checkValidTable:z0,hdb_table:j0,hdb_database:IE}=Di(),{handleHDBError:t7,hdb_errors:r7}=pe(),{getDatabases:n7}=(Pe(),C(tt)),{HTTP_STATUS_CODES:s7}=r7,i7=He.object({database:IE,schema:IE,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)}),o7=He.object({database:IE,schema:IE,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()});J0.exports=function(e,t){let r=null;switch(t){case"value":r=W0.validateBySchema(e,i7);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,o7);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=e7.checkGlobalSchemaTable(e.schema,e.table);if(s)return t7(new Error,s,s7.NOT_FOUND);let o=n7()[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 Eb=w((Iwe,Q0)=>{"use strict";var a7=_t(),c7=Hu(),{getSchemaPath:l7}=gt();Q0.exports=u7;function u7(e){let t=c7(e,"hashes");if(t)throw t;let r=l7(e.schema,e.table);return a7.openEnvironment(r,e.table)}a(u7,"initialize")});var gb=w((Pwe,X0)=>{"use strict";var d7=Bu(),f7=Eb();X0.exports=_7;async function _7(e){let t=await f7(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return d7.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(_7,"lmdbGetDataByHash")});var ku=w((Lwe,Z0)=>{"use strict";var Sb=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=Sb});var tx=w((Uwe,ex)=>{"use strict";var vwe=ku(),p7=Bu(),h7=Eb();ex.exports=m7;async function m7(e){let t=await h7(e),r=global.hdb_schema[e.schema][e.table];return p7.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(m7,"lmdbSearchByHash")});var ni=w((Bwe,rx)=>{"use strict";var Tb=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=Tb});var CE=w((kwe,cx)=>{"use strict";var jr=Bu(),E7=_t(),g7=ie(),ke=Ut(),Xc=(H(),C(G)),S7=po(),nx=Un().LMDB_ERRORS_ENUM,{getSchemaPath:T7}=gt(),Ao=Xc.SEARCH_WILDCARDS;async function A7(e,t,r){let n;e.schema===Xc.SYSTEM_SCHEMA_NAME?n=S7[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(A7,"prepSearch");async function ix(e,t,r,n){let s=T7(e.schema,e.table),i=await E7.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(R7(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 R7(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(R7,"checkToFetchMore");function ax(e,t,r,n){if(g7.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(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:A7,searchByType:ox}});var ux=w((qwe,lx)=>{"use strict";var Gwe=ni(),y7=Hu(),b7=ie(),O7=(H(),C(G)),N7=CE();lx.exports=w7;function w7(e,t){if(!b7.isEmpty(t)&&O7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=y7(e,"value");if(n)throw n;return N7.prepSearch(e,t,!0)}a(w7,"lmdbGetDataByValue")});var L_=w((Kwe,dx)=>{"use strict";var Vwe=ni(),I7=Hu(),C7=ie(),P7=(H(),C(G)),D7=CE();dx.exports=L7;async function L7(e,t){if(!C7.isEmpty(t)&&P7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=I7(e,"value");if(n)throw n;return D7.prepSearch(e,t,!1)}a(L7,"lmdbSearchByValue")});var _x=w((zwe,fx)=>{"use strict";var Wwe=Ut(),Ab=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}},Rb=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},yb=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};fx.exports={SearchByConditionsObject:Ab,SearchCondition:Rb,SortAttribute:yb}});var gx=w((Xwe,Ex)=>{"use strict";var Jwe=_x().SearchByConditionsObject,M7=ni(),v7=Hu(),bb=Bu(),PE=Ut(),{Resource:Qwe}=(Ea(),C(ER)),mx=CE(),U7=mb(),x7=require("lodash"),{getSchemaPath:B7}=gt(),px=_t(),{handleHDBError:H7,hdb_errors:k7}=pe(),{HTTP_STATUS_CODES:F7}=k7,G7=1e8;Ex.exports=q7;async function q7(e){let t=v7(e,"conditions");if(t)throw H7(t,t.message,F7.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=B7(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=x7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===PE.SEARCH_TYPES.EQUALS?u.estimated_count=bb.count(n,u.search_attribute,u.search_value):f===PE.SEARCH_TYPES.CONTAINS||f===PE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=G7}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=bb.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(_=>U7.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=bb.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(q7,"lmdbSearchByConditions");async function hx(e,t,r,n){let s=new M7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===PE.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 M_=w((eIe,Sx)=>{"use strict";var $7=(H(),C(G)).OPERATIONS_ENUM,Ob=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=$7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Sx.exports=Ob});var Nb=w((rIe,wx)=>{"use strict";var yx=ni(),bx=M_(),Ox=L_(),Nx=I_(),yn=(H(),C(G)),Tx=ie(),Ax=_t(),{getTransactionAuditStorePath:V7,getSchemaPath:K7}=gt(),Rx=z();wx.exports=Y7;async function Y7(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 W7(e),await z7(e);let t=K7(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=V7(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(Y7,"lmdbDropTable");async function W7(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(W7,"deleteAttributesFromSystem");async function z7(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(z7,"dropTableFromSystem")});var Cx=w((sIe,Ix)=>{"use strict";var j7=require("fs-extra"),J7=ni(),Q7=ku(),X7=M_(),Z7=Nb(),eee=I_(),tee=gb(),ree=L_(),Ro=(H(),C(G)),{getSchemaPath:nee}=gt(),{handleHDBError:see,hdb_errors:iee}=pe(),{HDB_ERROR_MSGS:oee,HTTP_STATUS_CODES:aee}=iee;Ix.exports=cee;async function cee(e){let t;try{t=await lee(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 ree(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await Z7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new X7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await eee(s);let i=nee(t);await j7.remove(i)}catch(r){throw r}}a(cee,"lmdbDropSchema");async function lee(e){let t=new Q7(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 tee(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw see(new Error,oee.SCHEMA_NOT_FOUND(e),aee.NOT_FOUND,void 0,void 0,!0);return n}a(lee,"validateDropSchema")});var v_=w((oIe,Px)=>{"use strict";var wb=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Px.exports=wb});var Cb=w((lIe,Dx)=>{"use strict";var uee=require("fs-extra"),DE=_t(),{getTransactionAuditStorePath:dee}=gt(),Ib=Ut(),cIe=v_();Dx.exports=fee;async function fee(e){let t;try{let r=dee(e.schema,e.table);await uee.mkdirp(r),t=await DE.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{DE.createDBI(t,Ib.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),DE.createDBI(t,Ib.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),DE.createDBI(t,Ib.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(fee,"createTransactionsAuditEnvironment")});var vx=w((fIe,Mx)=>{"use strict";var Pb=(H(),C(G)),Lx=_t(),_ee=Hc(),{getSystemSchemaPath:pee,getSchemaPath:hee}=gt(),dIe=po(),mee=sE(),Db=nE(),Eee=z(),gee=Cb();Mx.exports=See;async function See(e,t){let r=hee(t.schema,t.table),n=new Db(t.schema,t.table,Pb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Db(t.schema,t.table,Pb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Db(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(pee(),Pb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await _ee.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 Lb(n),await Lb(s),await Lb(i)}await gee(t)}catch(o){throw o}}a(See,"lmdbCreateTable");async function Lb(e){try{await mee(e)}catch(t){Eee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Lb,"createAttribute")});var xx=w((pIe,Ux)=>{"use strict";var Tee=l_(),Aee=xf(),Ree=yE(),U_=(H(),C(G)),yee=Hc().updateRecords,bee=_t(),{getSchemaPath:Oee}=gt(),Nee=N_(),wee=z();Ux.exports=Iee;async function Iee(e){try{let{schema_table:t,attributes:r}=Tee(e);Aee(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 Ree(e.hdb_auth_header,t,r),s=Oee(e.schema,e.table),i=await bee.openEnvironment(s,e.table),o=await yee(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Nee(e,o)}catch(c){wee.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(Iee,"lmdbUpdateRecords")});var Hx=w((mIe,Bx)=>{"use strict";var Cee=(H(),C(G)).OPERATIONS_ENUM,Mb=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Cee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Bx.exports=Mb});var Fx=w((SIe,kx)=>{"use strict";var gIe=Hx(),Pee=l_(),Dee=xf(),Lee=yE(),x_=(H(),C(G)),Mee=Hc().upsertRecords,vee=_t(),{getSchemaPath:Uee}=gt(),xee=N_(),Bee=z(),{handleHDBError:Hee,hdb_errors:kee}=pe();kx.exports=Fee;async function Fee(e){let t;try{t=Pee(e)}catch(l){throw Hee(l,l.message,kee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;Dee(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 Lee(e.hdb_auth_header,r,n),i=Uee(e.schema,e.table),o=await vee.openEnvironment(i,e.table),c=await Mee(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await xee(e,c)}catch(l){Bee.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(Fee,"lmdbUpsertRecords")});var qx=w((AIe,Gx)=>{"use strict";var vb=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};Gx.exports=vb});var Vx=w((yIe,$x)=>{"use strict";var Ub=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=Ub});var Wx=w((NIe,Yx)=>{"use strict";var xb=_t(),{getTransactionAuditStorePath:Gee}=gt(),OIe=qx(),B_=Ut(),qee=ie(),Kx=Vx(),$ee=require("util").promisify,Vee=$ee(setTimeout),Kee=1e4,Yee=100;Yx.exports=Wee;async function Wee(e){let t=Gee(e.schema,e.table),r=await xb.openEnvironment(t,e.table,!0),n=xb.listDBIs(r);xb.initializeDBIs(r,B_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Kx;do s=await zee(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 Vee(Yee);while(s.transactions_deleted>0);return i}a(Wee,"deleteAuditLogsBefore");async function zee(e,t){let r=new Kx;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];qee.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>Kee)break}return await s,r}catch(n){throw n}}a(zee,"deleteTransactions")});var jx=w((IIe,zx)=>{"use strict";var Bb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};zx.exports=Bb});var Qx=w((DIe,Jx)=>{"use strict";var jee=ni(),Jee=M_(),PIe=jx(),Bi=(H(),C(G)),Qee=ie(),Hb=_t(),Xee=po(),Zee=L_(),ete=I_(),{getSchemaPath:tte}=gt();Jx.exports=rte;async function rte(e,t=!0){let r;e.schema===Bi.SYSTEM_SCHEMA_NAME?r=Xee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await ste(e),s=tte(e.schema,e.table),i=await Hb.openEnvironment(s,e.table);return t===!0&&await nte(e,i,r.hash_attribute),Hb.dropDBI(i,e.attribute),n}a(rte,"lmdbDropAttribute");async function nte(e,t,r){let n=Hb.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(nte,"removeAttributeFromAllObjects");async function ste(e){let t=new jee(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 Zee(t)).filter(o=>o[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Qee.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 ete(i)}a(ste,"dropAttributeFromSystem")});var nB=w((vIe,rB)=>{"use strict";var kb=_t(),Fu=Ut(),MIe=_n(),Fb=(H(),C(G)),Xx=ie(),{getTransactionAuditStorePath:ite}=gt(),ote=Bu(),LE=vu(),ate=z();rB.exports=cte;async function cte(e){let t=ite(e.schema,e.table),r=await kb.openEnvironment(t,e.table,!0),n=kb.listDBIs(r);kb.initializeDBIs(r,Fu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Fb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Zx(r,e.search_values);case Fb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,ute(r,e.search_values,s);case Fb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return lte(r,e.search_values);default:return Zx(r)}}a(cte,"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[Fu.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 LE,s))}a(Zx,"searchTransactionsByTimestamp");function lte(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[Fu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,tB(e,i))}return Object.fromEntries(r)}a(lte,"searchTransactionsByUsername");function ute(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=ote.equals(e,Fu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Fu.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(ute,"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 LE(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new LE(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[Fu.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 LE,i);r.push(o)}}catch(i){ate.warn(i)}return r}catch(n){throw n}}a(tB,"batchSearchTransactions")});var iB=w((HIe,sB)=>{"use strict";var{getSchemaPath:xIe}=gt(),BIe=_t(),{database:dte}=(Pe(),C(tt));sB.exports={writeTransaction:fte};async function fte(e,t,r){return dte({database:e,table:t}).transaction(r)}a(fte,"writeTransaction")});var lB=w((FIe,cB)=>{"use strict";var{getSchemaPath:oB}=gt(),aB=_t();cB.exports={flush:_te,resetReadTxn:pte};async function _te(e,t){return(await aB.openEnvironment(oB(e,t),t.toString())).flushed}a(_te,"flush");async function pte(e,t){try{(await aB.openEnvironment(oB(e,t),t.toString())).resetReadTxn()}catch{}}a(pte,"resetReadTxn")});var _B=w((qIe,fB)=>{"use strict";var{Readable:hte}=require("stream"),{getDatabases:mte}=(Pe(),C(tt)),{readSync:Ete,openSync:gte,createReadStream:uB}=require("fs"),{open:Ste}=require("lmdb"),dB=s_(),Tte=i_(),{AUDIT_STORE_OPTIONS:Ate}=(fo(),C(pB)),{INTERNAL_DBIS_NAME:Rte,AUDIT_STORE_NAME:yte}=Ut();fB.exports=Ote;var Gb=32768,bte=100;async function Ote(e){let t=e.database||e.schema||"data",r=mte()[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=Ste({noSync:!0,maxDbs:Tte.MAX_DBS}),p,_=d.openDB(Rte,new dB(!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++%bte===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 dB(!v,v);await g(E,F)}e.include_audit&&await g(yte,{...Ate}),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=gte(o.path);return o.transaction(()=>{let u=Buffer.alloc(Gb);Ete(c,u,0,Gb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=uB(null,{fd:c,start:Gb}),p=new hte.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(Ote,"getBackup")});var EB=w((VIe,mB)=>{"use strict";var Nte=z(),{handleHDBError:wte}=pe(),Ite=IM(),Cte=sE(),Pte=db(),Dte=C0(),Lte=I_(),Mte=gb(),vte=tx(),Ute=ux(),xte=L_(),Bte=gx(),Hte=Cx(),kte=vx(),Fte=xx(),Gte=Fx(),qte=Wx(),$te=Nb(),Vte=Qx(),Kte=nB(),Yte=iB(),hB=lB(),Wte=_B(),qb=class extends Ite{static{a(this,"LMDBBridge")}async searchByConditions(t){return Bte(t)}async getDataByHash(t){return await Mte(t)}async searchByHash(t){return await vte(t)}async getDataByValue(t,r){return await Ute(t,r)}async searchByValue(t){return await xte(t)}async createSchema(t){return await Dte(t)}async dropSchema(t){return await Hte(t)}async createTable(t,r){return await kte(t,r)}async dropTable(t){return await $te(t)}async createAttribute(t){return await Cte(t)}async createRecords(t){return await Pte(t)}async updateRecords(t){return await Fte(t)}async upsertRecords(t){try{return await Gte(t)}catch(r){throw wte(r,null,null,Nte.ERR,r)}}async deleteRecords(t){return await Lte(t)}async dropAttribute(t){return await Vte(t)}async deleteAuditLogsBefore(t){return await qte(t)}async readAuditLog(t){return await Kte(t)}writeTransaction(t,r,n){return Yte.writeTransaction(t,r,n)}flush(t,r){return hB.flush(t,r)}resetReadTxn(t,r){return hB.resetReadTxn(t,r)}getBackup(t){return Wte(t)}};mB.exports=qb});var Vb={};ve(Vb,{add:()=>ME,applyReverse:()=>gB,getRecordAtTime:()=>$b,rebuildUpdateBefore:()=>vE});function ME(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 vE(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,ME(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=zte[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=SB}}function $b(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 zte,SB,UE=be(()=>{fo();a(ME,"add");ME.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)};zte={add:ME};a(vE,"rebuildUpdateBefore");a(gB,"applyReverse");SB={};a($b,"getRecordAtTime")});function bn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function kE(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 wi||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 _=Kb(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 Kb(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")}},kE(r,t)),new r(e)):new H_(e);case Array:let n=new BE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=Kb(o,t?.elements)),n[s]=o}return n;default:return e}}function FE(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=FE(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=Vb[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)jte.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function xE(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(xE(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(xE(s))return!0}else return!0}else return!0}}return!1}var jn,TB,AB,H_,jte,Zc,BE,HE,Yb=be(()=>{jn=M(pe());UE();gs();a(bn,"getChanges");a(kE,"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=Kb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(Kb,"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}};kE(H_,{});a(FE,"collapseData");jte=Object.prototype.hasOwnProperty;a(el,"updateAndFreeze");a(xE,"hasChanges");Zc=Symbol.for("has-array-changes"),BE=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()}};BE.prototype.constructor=Array;HE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var CB={};ve(CB,{ResourceBridge:()=>jb});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=Hi(e),n=Jb(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;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&&FE(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||Qte,r=Qe()[t];if(!r)throw(0,si.handleHDBError)(new Error,Jte.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,GE,si,wB,Wb,zb,IB,Jte,Qte,Xte,Zte,RB,jb,PB=be(()=>{"use strict";NB=M(EB()),GE=M(Hu()),si=M(pe());Pe();wB=M(l_());H();Wb=M(To()),zb=M(ri()),IB=M(ie());bc();Yb();({HDB_ERROR_MSGS:Jte}=si.hdb_errors),Qte="data",Xte=1e4,Zte=10,jb=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,GE.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: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 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 Gu({database:t.schema,table:null}),Wb.signalSchemaChange(new zb.SchemaEventMsg(process.pid,Kt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Qb(t.schema),Wb.signalSchemaChange(new zb.SchemaEventMsg(process.pid,Kt.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=Qe()[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=FE(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=Qe()[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=Qe()[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: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)(Zte),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Xte===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,GE.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,GE.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===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=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 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(Hi,"getTable");a(bB,"createDeleteResponse");a(OB,"groupRecordsInHistory")});var Vn=w((nCe,DB)=>{"use strict";var{ResourceBridge:ere}=(PB(),C(CB)),tre=ae();tre.initSync();var qE;function rre(){return qE||(qE=new ere,qE)}a(rre,"getBridge");DB.exports=rre()});var Rn=w((iCe,UB)=>{"use strict";var VE=kR(),Dr=ie(),nre=require("util"),KE=Vn(),sre=As(),LB=z(),{handleHDBError:tl,hdb_errors:ire}=pe(),{HTTP_STATUS_CODES:rl}=ire,ore=nre.promisify(sre.getTableSchema),are="updated",MB="inserted",vB="upserted";UB.exports={insert:lre,update:ure,upsert:dre,validation:cre,flush:fre};async function cre(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 ore(e.schema,e.table),r=VE(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(cre,"validation");async function lre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=VE(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 KE.createRecords(e);return $E(MB,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(lre,"insertData");async function ure(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=VE(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 KE.updateRecords(e);return Dr.isEmpty(n.existing_rows)?$E(are,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):$E(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(ure,"updateData");async function dre(e){if(e.operation!=="upsert")throw tl(new Error,"invalid operation, must be upsert",rl.INTERNAL_SERVER_ERROR);let t=VE(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 KE.upsertRecords(e);return $E(vB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(dre,"upsertData");function $E(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($E,"returnObject");function fre(e){return Dr.transformReq(e),KE.flush(e.schema,e.table)}a(fre,"flush")});var GB=w((aCe,FB)=>{var qu=require("validate.js"),BB=it(),$u=(H(),C(G)),{handleHDBError:_re,hdb_errors:pre}=pe(),{HDB_ERROR_MSGS:zt,HTTP_STATUS_CODES:hre}=pre,Xb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),mre={STRUCTURE_USER:"structure_user"},xB=Object.values($u.ROLE_TYPES_ENUM),Ere="attribute_permissions",gre="attribute_name",{PERMS_CRUD_ENUM:Vu}=$u,Sre=[Ere,...Object.values(Vu)],HB=[Vu.READ,Vu.INSERT,Vu.UPDATE],Tre=[gre,...HB];function Are(e){let t=Xb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,kB(e,t)}a(Are,"addRoleValidation");function Rre(e){let t=Xb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,kB(e,t)}a(Rre,"alterRoleValidation");function yre(e){let t=Xb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,BB.validateObject(e,t)}a(yre,"dropRoleValidation");var bre=["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++)bre.includes(n[o])||s.push(n[o]);s.length>0&&nr(zt.INVALID_ROLE_JSON_KEYS(s),r);let i=BB.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=Ore(e);o&&nr(o,r),xB.forEach(c=>{e.permission[c]&&!qu.isBoolean(e.permission[c])&&nr(zt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(xB.indexOf(o)<0){if(o===mre.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(zt.SCHEMA_NOT_FOUND(d),r)}continue}nr(zt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(zt.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(zt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{Sre.includes(f)||nr(zt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Vu).forEach(f=>{qu.isDefined(u[f])?qu.isBoolean(u[f])||nr(zt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(zt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(zt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(zt.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=>{!Tre.includes(S)&&S!==Vu.DELETE&&nr(zt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!qu.isDefined(_.attribute_name)){nr(zt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!f.includes(h)){nr(zt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}HB.forEach(S=>{qu.isDefined(_[S])?qu.isBoolean(_[S])||nr(zt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,l):nr(zt.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(zt.MISMATCHED_TABLE_ATTR_PERMS(p),r,o,l)}}}}return Nre(r)}a(kB,"customValidate");FB.exports={addRoleValidation:Are,alterRoleValidation:Rre,dropRoleValidation:yre};function Ore(e){let{operation:t,permission:r}=e;if(t===$u.OPERATIONS_ENUM.ADD_ROLE||t===$u.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 zt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?$u.ROLE_TYPES_ENUM.SUPER_USER:$u.ROLE_TYPES_ENUM.CLUSTER_USER;return zt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Ore,"validateNoSUPerms");function Nre(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:zt.ROLE_PERMS_ERROR,...e};return _re(new Error,n,hre.BAD_REQUEST)}else return null}a(Nre,"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((uCe,KB)=>{"use strict";var qB=Rn(),$B=Yr(),wre=Vc(),eO=GB(),tO=To(),lCe=require("uuid").v4,Ire=require("util"),YE=(H(),C(G)),Cre=ie(),rO=$B.searchByValue,Pre=$B.searchByHash,Dre=Ire.promisify(wre.delete),Lre=ni(),Mre=ku(),{hdb_errors:vre,handleHDBError:nl}=pe(),{HDB_ERROR_MSGS:VB,HTTP_STATUS_CODES:k_}=vre,{UserEventMsg:nO}=ri();KB.exports={addRole:Ure,alterRole:xre,dropRole:Bre,listRoles:Hre};function Zb(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(Zb,"scrubRoleDetails");async function Ure(e){let t=eO.addRoleValidation(e);if(t)throw t;e=Zb(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 rO(r)||[])}catch(i){throw nl(i)}if(n&&n.length>0)throw nl(new Error,VB.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 qB.insert(s),tO.signalUserChange(new nO(process.pid)),e=Zb(e),e}a(Ure,"addRole");async function xre(e){let t=eO.alterRoleValidation(e);if(t)throw t;e=Zb(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",k_.BAD_REQUEST,void 0,void 0,!0);return await tO.signalUserChange(new nO(process.pid)),e}a(xre,"alterRole");async function Bre(e){let t=eO.dropRoleValidation(e);if(t)throw nl(new Error,t,k_.BAD_REQUEST,void 0,void 0,!0);let r=new Mre(YE.SYSTEM_SCHEMA_NAME,YE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Pre(r));if(n.length===0)throw nl(new Error,VB.ROLE_NOT_FOUND,k_.NOT_FOUND,void 0,void 0,!0);let s=new Lre(YE.SYSTEM_SCHEMA_NAME,YE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await rO(s)),o=!1;if(Cre.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`,k_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Dre(c),tO.signalUserChange(new nO(process.pid)),`${n[0].role} successfully deleted`}a(Bre,"dropRole");async function Hre(){return rO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Hre,"listRoles")});var sO={};ve(sO,{start:()=>zB,startOnMainThread:()=>Gre});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(kre.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 Fre(i)}}}async function Fre(e){let t=Qe().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,WE.alterRole)(e))}return(0,WE.addRole)(e)}var WE,YB,WB,kre,Gre,jB=be(()=>{Pe();WE=M(F_()),YB=require("yaml"),WB=require("lodash"),kre=["super_user","cluster_user","structure_user"];a(zB,"start");a(Fre,"ensureRole");Gre=zB});async function zE(e){let t=(0,XB.pathToFileURL)(e).toString();return qre?(G_||(G_=$re(Kre)),(await(await G_).import(t)).namespace):import(t)}async function $re(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:Vre,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,QB.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,JB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),G_}function Vre(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 Kre(){return{Resource:$r,tables:Jn}}var JB,QB,XB,qre,G_,iO=be(()=>{Ea();Pe();JB=require("fs/promises"),QB=require("path"),XB=require("url"),qre=!1;a(zE,"secureImport");a($re,"getCompartment");a(Vre,"secureOnlyFetch");a(Kre,"getGlobalVars")});var aO={};ve(aO,{handleFile:()=>Yre});async function Yre(e,t,r,n){let s=new Map,i=await zE(r);c(i.default)&&n.set((0,oO.dirname)(t),i.default),o(i,(0,oO.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 oO,ZB=be(()=>{iO();oO=require("path");a(Yre,"handleFile")});var lO={};ve(lO,{start:()=>Wre});function Wre({resources:e}){e.set("login",cO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var cO,eH=be(()=>{Ea();a(Wre,"start");cO=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:()=>SH,diffResourceUsage:()=>TH,recordAction:()=>sr,recordActionBinary:()=>Qn,setAnalyticsEnabled:()=>zre});function zre(e){pH=e}function jre(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},JE.set(e,o)}function sr(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?jre(e,o):Jre(i,e,t,r,n,s),jE||Qre()}function Qn(e,t,r,n,s){sr(!!e,t,r,n,s)}function Y_(e){EH.push(e)}function Qre(){jE=performance.now(),setTimeout(async()=>{let e=performance.now()-jE;jE=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 QE(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 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 Xre(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};QE(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=Xre(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};QE(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};QE(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 Zre(e,t=6e4){let r=dO(),n=RH(),s=new Promise(E=>{let T=performance.now();setImmediate(()=>{let b=performance.now();b-T>5e3&&il.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&&il.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:he,...Re}=F;Q||(Q=1);let Ce=se+(q?"-"+q:"");Y!==void 0&&(Ce+="-"+Y),Z!==void 0&&(Ce+="-"+Z);let me=c.get(Ce);if(me){if(me.threads){let ut=me.threads[v];if(ut)me=ut;else{me.threads[v]={...Re};continue}}me.count||(me.count=1);let Zt=me.count;for(let ut in Re){let yr=Re[ut];typeof yr=="number"&&(me[ut]=(me[ut]*Zt+yr*Q)/(Zt+Q))}me.count+=Q,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(J){J=J.map(ut=>typeof ut=="number"?{value:ut,count:1}:ut);let Zt=l.get(Ce);Zt?Zt.push(...J):l.set(Ce,J)}}await AH()}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 he of se){let Re=he[ne];typeof Re=="number"&&(J+=Re)}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((ut,yr)=>ut.value>yr.value?1:-1);let v=b.count-1,F=[],q=0,Y=0,Z;for(let ut of gH){let yr=v*ut;for(;q<yr;)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-yr)/Z.count)}let[se,Q,ne,J,he,Re,Ce,me,Zt]=F;Object.assign(b,{p1:se,p10:Q,p25:ne,median:J,p75:he,p90:Re,p95:Ce,p99:me,p999:Zt})}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:_-nH,active:h-sH,taskQueueLatency:await s,time:p,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(b=>{b||n.primaryStore.put(E,T)})}nH=_,sH=h;let S=process.resourceUsage(),g=TH(q_,S);g.time=p,g.period=q_.time?p-q_.time:t,g.cpuUtilization=SH(q_,g.period),QE(n,"resource-usage",g),q_=g;let R=Qe();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 dO(){return oH||(oH=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function RH(){return aH||(aH=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function rne(){yH=!0;let e=(0,K_.get)(B.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Zre(hH,e),await iH(dO(),ene),await iH(RH(),tne)},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,V_.getNextMonotonicTime)(),dO().primaryStore.put(r.id,r),yH||rne(),nne&&(OH=ine(r))}async function ine(e){if(await OH,!Ca){let r=(0,$_.dirname)((0,dH.getLogFilePath)());try{Ca=await(0,uO.open)((0,$_.join)(r,"analytics.log"),"r+")}catch{Ca=await(0,uO.open)((0,$_.join)(r,"analytics.log"),"w+")}}let t=(await Ca.stat()).size;if(t>sne){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 sl,uH,dH,fH,$_,uO,V_,K_,_H,il,JE,pH,jE,hH,mH,EH,gH,nH,sH,q_,AH,ene,tne,oH,aH,yH,cH,lH,nne,OH,Ca,sne,ki=be(()=>{sl=require("worker_threads"),uH=M(et());Pe();dH=M(z()),fH=M(Ni()),$_=require("path"),uO=require("fs/promises"),V_=M(_n()),K_=M(ae());H();Vr();_H=M(require("node:fs")),il=(0,fH.loggerWithTag)("analytics");(0,K_.initSync)();JE=new Map,pH=(0,K_.get)(B.ANALYTICS_AGGREGATEPERIOD)>-1;a(zre,"setAnalyticsEnabled");a(jre,"recordExistingAction");a(Jre,"recordNewAction");a(sr,"recordAction");Ye.recordAnalytics=sr;a(Qn,"recordActionBinary");jE=0,hH=1e3,mH="analytics-report",EH=[];a(Y_,"addAnalyticsListener");gH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Qre,"sendAnalytics");a(QE,"storeMetric");a(SH,"calculateCPUUtilization");a(TH,"diffResourceUsage");a(Xre,"storeTableSizeMetrics");a(tH,"storeDBSizeMetrics");a(rH,"storeVolumeMetrics");a(Zre,"aggregation");nH=0,sH=0,q_={},AH=a(()=>new Promise(setImmediate),"rest");a(iH,"cleanup");ene=36e5,tne=31536e6;a(dO,"getRawAnalyticsTable");a(RH,"getAnalyticsTable");(0,uH.setChildListenerByType)(mH,bH);a(rne,"startScheduledTasks");cH=0,lH=new Map,nne=!1;a(bH,"recordAnalytics");sne=1e6;a(ine,"logAnalytics")});var NH={};ve(NH,{Headers:()=>yo,appendHeader:()=>XE,mergeHeaders:()=>fO});function XE(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 fO(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(XE,"appendHeader");a(fO,"mergeHeaders")});function DH(e){let t={openapi:one,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: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 mO(_O[se.type],se.type)}),t.components.schemas[Y.type]=new CH(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 mO(_O[v.type],v.type)}:T==="Any"||T=="ID"?u[b]={format:T}:u[b]=new mO(_O[T],T)}f.push(new EO(b,"query",u[b]))}let d=Object.keys(u),p=new EO(c,"path",{format:"ID"});p.required=!0,p.description="primary key of record";let _=new EO("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 ane(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new pO(f,r,{200:new hO({$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 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 pO([p],r,{200:new hO({$ref:Pa+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new cne([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 pO([p,_],r,{200:new hO({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function ane(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Pa+e}}}},this.security=t,this.responses={200:{description:gO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function pO(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function hO(e){this.description=gO,this.content={"application/json":{schema:e}}}function wH(){this.description="successfully processed request, no content returned to client"}function cne(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:gO}}}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 mO(e,t){this.type=e,this.format=t}function EO(e,t,r){this.name=e,this.in=t,this.schema=r}var PH,one,_O,Pa,gO,LH=be(()=>{PH=M(st()),one="3.0.3",_O={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Pa="#/components/schemas/",gO="successful operation";a(DH,"generateJsonApi");a(ane,"Post");a(pO,"Get");a(hO,"Response200");a(wH,"Response204");a(cne,"Put");a(IH,"Delete");a(CH,"ResourceSchema");a(mO,"Type");a(EO,"Parameter")});var eg={};ve(eg,{parseHeaderValue:()=>TO,start:()=>dne});async function une(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 yo;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==MH){let g=ZE.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Oc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=TO(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=TO(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=uo(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Ku.ClientError(g,400)}if(e.authorize=!0,o===MH&&s==="GET"){if(e?.user?.role?.permission?.super_user)return DH(ZE);throw new Ku.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 Ku.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Ku.ServerError(`Method ${s} is not recognized`,501)}}),p=200,_;if(d==null)p=s==="GET"||s==="HEAD"?404:204,SO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=fO(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){lne[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),SO.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 dne(e){SO=e,!vH&&(vH=!0,ZE=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return une(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{j_++;let s=new xn;UH||(UH=!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=ZE.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 Oc(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 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(fne[l.statusCode]||1011,l.toString())}t.close()},e))}function TO(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,Ku,Lr,lne,SO,MH,vH,ZE,UH,j_,fne,xH=be(()=>{ao();ki();Fi=M(z()),Ku=M(pe());Gf();_u();bc();z_();LH();Gf();Lr=new Uint8Array(8),lne=new Float64Array(Lr.buffer,0,1),SO={},MH="openapi";a(une,"http");j_=0;a(dne,"start");fne={401:3e3,403:3003};a(TO,"parseHeaderValue")});var AO=w((kCe,HH)=>{var{recordAction:tg,recordActionBinary:BH}=(ki(),C(W_)),_ne=require("fastify-plugin"),pne=200;HH.exports=_ne(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),tg(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=pne;i?.pipe?(i.on("data",g=>{p+=g.length}),i.on("end",()=>{tg(performance.now()-c,"transfer",u,d,f),tg(p,"bytes-sent",u,d,f)})):(p+=i?.length||0,tg(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((FCe,kH)=>{var hne=it(),mne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};kH.exports=function(e){return hne.validateObject(e,mne)}});var rg=w((GCe,GH)=>{"use strict";var Ene=(H(),C(G)).OPERATIONS_ENUM,RO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Ene.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};GH.exports=RO});var X_={};ve(X_,{createTokens:()=>Sne,getJWTRSAKeys:()=>ag,refreshOperationToken:()=>Tne,validateOperationToken:()=>OO,validateRefreshToken:()=>cg});async function ag(){if(ng)return ng;try{let e=J_.default.join(Q_.default.getHdbBasePath(),WA),t=await sg.default.readFile(J_.default.join(e,Of.JWT_PASSPHRASE_NAME),"utf8"),r=await sg.default.readFile(J_.default.join(e,Of.JWT_PRIVATE_KEY_NAME),"utf8");return ng={publicKey:await sg.default.readFile(J_.default.join(e,Of.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},ng}catch(e){throw og.default.error(e),new ii.ClientError(Wu.NO_ENCRYPTION_KEYS,Yu.INTERNAL_SERVER_ERROR)}}async function Sne(e){let t=(0,yO.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,bO.findAndValidateUser)(e.username,e.password,d)}catch(d){throw og.default.error(d),new ii.ClientError(Wu.INVALID_CREDENTIALS,Yu.UNAUTHORIZED)}if(!r)throw new ii.ClientError(Wu.INVALID_CREDENTIALS,Yu.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 ag(),c=await zu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??YH,algorithm:ig,subject:"operation"}),l=await zu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:gne,algorithm:ig,subject:"refresh"}),u=ky(l,"sha256");if((await(0,qH.update)(new $H.default(bf,du.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new ii.ClientError(Wu.REFRESH_TOKEN_SAVE_FAILED,Yu.INTERNAL_SERVER_ERROR);return VH.default.signalUserChange(new KH.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function Tne(e){let t=(0,yO.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 cg(r);let n=await ag(),s=await zu.default.decode(r);return{operation_token:await zu.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:YH,algorithm:ig,subject:"operation"})}}async function OO(e){return WH(e,"operation")}async function cg(e){return WH(e,"refresh")}async function WH(e,t){try{let r=await ag(),n=await zu.default.verify(e,r.publicKey,{algorithms:ig,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,bO.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!Fy(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw og.default.warn(r),r?.name==="TokenExpiredError"?new ii.ClientError(Wu.TOKEN_EXPIRED,Yu.FORBIDDEN):new ii.ClientError(Wu.INVALID_TOKEN,Yu.UNAUTHORIZED)}}var zu,sg,J_,Gi,yO,ii,og,bO,qH,$H,VH,KH,Q_,Yu,Wu,YH,gne,ig,ng,ju=be(()=>{zu=M(require("jsonwebtoken")),sg=M(require("fs-extra")),J_=M(require("node:path")),Gi=M(require("joi")),yO=M(it());H();ii=M(pe()),og=M(z());pE();bO=M(An()),qH=M(Rn()),$H=M(rg()),VH=M(To()),KH=M(ri()),Q_=M(ae()),{HTTP_STATUS_CODES:Yu,AUTHENTICATION_ERROR_MSGS:Wu}=ii.hdb_errors;Q_.default.initSync();YH=Q_.default.get(B.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",gne=Q_.default.get(B.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",ig="RS256";a(ag,"getJWTRSAKeys");a(Sne,"createTokens");a(Tne,"refreshOperationToken");a(OO,"validateOperationToken");a(cg,"validateRefreshToken");a(WH,"validateToken")});var NO=w((YCe,JH)=>{"use strict";var Ane=FH(),Ju=require("passport"),Rne=require("passport-local").Strategy,yne=require("passport-http").BasicStrategy,bne=require("util"),One=An(),jH=bne.callbackify(One.findAndValidateUser),KCe=Un(),Nne=(H(),C(G)),zH=(ju(),C(X_));Ju.use(new Rne(function(e,t,r){jH(e,t,r)}));Ju.use(new yne(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 wne(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===Nne.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(wne,"authorize");function Ine(e,t){let r=Ane(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(Ine,"checkPermissions");JH.exports={authorize:wne,checkPermissions:Ine}});var lg=w((zCe,QH)=>{"use strict";var Cne=Vn();QH.exports={writeTransaction:Pne};function Pne(e,t,r){return Cne.writeTransaction(e,t,r)}a(Pne,"writeTransaction")});var tk=w((QCe,ek)=>{"use strict";var Dne=Yr(),Lne=As(),XH=z(),Mne=Rn(),JCe=lg(),vne=require("clone"),IO=require("alasql"),Une=oE(),ZH=require("util"),xne=ZH.promisify(Lne.getTableSchema),Bne=ZH.promisify(Dne.search),Hne=(H(),C(G)),wO=ie();Une(IO);ek.exports={update:Fne};var kne="There was a problem performing this update. Please check the logs and try again.";async function Fne({statement:e,hdb_user:t}){let r=await xne(e.table.databaseid,e.table.tableid),n=Gne(e.columns);wO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=vne(s),c=wO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=IO.parse(l).statements[0],f=await Bne(u),d=qne(n,f);return $ne(o,d,t)}a(Fne,"update");function Gne(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=IO.compile(`SELECT ${r.expression.toString()} AS [${Hne.FUNC_VAL}] FROM ?`)}),t}catch(t){throw XH.error(t),new Error(kne)}}a(Gne,"createUpdateRecord");function qne(e,t){return wO.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(qne,"buildUpdateRecords");async function $ne(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await Mne.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($ne,"updateRecords")});var nk=w((tPe,rk)=>{var Vne=require("alasql"),Kne=Yr(),Yne=z(),Wne=Vn(),PO=require("util"),CO=ie(),zne=(H(),C(G)),jne=As(),ZCe=lg(),ePe=Rn(),Jne="record",Qne="successfully deleted",Xne=PO.callbackify(rse),Zne=PO.promisify(Kne.search),ese=PO.promisify(jne.getTableSchema);rk.exports={convertDelete:Xne};function tse(e){return`${e.deleted_hashes.length} ${Jne}${e.deleted_hashes.length===1?"":"s"} ${Qne}`}a(tse,"generateReturnMessage");async function rse({statement:e,hdb_user:t}){let r=await ese(e.table.databaseid,e.table.tableid);CO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=CO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=Vne.parse(o).statements[0],l={operation:zne.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Zne(c);let u=await Wne.deleteRecords(l);return CO.isEmptyOrZeroLength(u.message)&&(u.message=tse(u)),delete u.txn_time,u}catch(u){throw Yne.error(u),u.hdb_code?u.message:u}}a(rse,"convertDelete")});var ck=w((nPe,ak)=>{"use strict";var nse=go(),{hdb_errors:sk}=pe(),{getDatabases:ik}=(Pe(),C(tt));ak.exports={checkSchemaExists:ok,checkSchemaTableExists:sse,schema_describe:nse};async function ok(e){if(!ik()[e])return sk.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(ok,"checkSchemaExists");async function sse(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(sse,"checkSchemaTableExists")});var UO=w((cPe,Tk)=>{"use strict";var{decode:ise}=require("msgpackr"),{isMainThread:iPe,parentPort:oPe,threadId:aPe}=require("worker_threads"),fg=ir(),Qu=Tt(),MO=(H(),C(G)),Jr=z(),LO=ae(),ose=(H(),C(G)),{onMessageByType:ase}=et(),fk=Eo(),{recordAction:lk,recordActionBinary:cse}=(ki(),C(W_)),{publishToStream:lse}=fg,{ConsumerEvents:uk}=require("nats"),use=Yr(),{promisify:dse}=require("util"),{decodeBlobsWithWrites:fse}=(gs(),C(Fm)),_k=dse(setTimeout),_g=1e4,pg,dg,_se,pse,pk,Z_=new Map,Xu=new Map;Tk.exports={initialize:hk,ingestConsumer:vO,setSubscription:hse,setIgnoreOrigin:gse,getDatabaseSubscriptions:Ese,updateConsumer:mk};async function hk(){ase(MO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await mk(n)}),pk=!0,Jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await fg.getNATSReferences();pg=e,dg=e.info.server_name,_se=t,pse=r}a(hk,"initialize");async function mk(e){if(e.status==="start"){let{js:t,jsm:r}=await Ek(e.node_domain_name);vO(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")),Xu.get(e.node_domain_name)==="failed"&&Xu.set(e.node_domain_name,"close")}}a(mk,"updateConsumer");var hg=new Map;function hse(e,t,r){let n=hg.get(e);n||hg.set(e,n=new Map),n.set(t,r),pk||hk().then(mse)}a(hse,"setSubscription");async function mse(){let e=await use.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);vO(l,n,s,r)}}}a(mse,"accessConsumers");async function Ek(e){let t,r,n=1;for(;!r;)try{t=await pg.jetstream({domain:e}),r=await pg.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Xu.get(e)==="close")break;Xu.set(e,"failed"),n%10===1&&Jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<_g?n++*100:_g;await _k(i)}return{js:t,jsm:r}}a(Ek,"connectToRemoteJS");function Ese(){return hg}a(Ese,"getDatabaseSubscriptions");var gk;function gse(e){gk=e}a(gse,"setIgnoreOrigin");var Sk=100,dk=new Array(Sk),ug=0;async function vO(e,t,r,n){let{connection:s}=await fg.getNATSReferences();pg=s,dg=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,dg),Jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Xu.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 fg.createConsumer(r,e,dg,new Date(Date.now()).toISOString()));let f=o++*100<_g?o++*100:_g;await _k(f)}let c=!1,l;for(;!c;){if(Z_.get(e+n)==="close"||Xu.get(n)==="close"){Z_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:LO.get(MO.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===uk.ConsumerDeleted&&(await l.close(),c=!0),f.type===uk.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 dk[ug],dk[ug]=Sse(f).catch(d=>{Jr.error(d)}),++ug>=Sk&&(ug=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(vO,"ingestConsumer");async function Sse(e){let t;await fse(()=>{t=ise(e.data)}),lk(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=LO.get(MO.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),cse(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;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(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||{},T=hg.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:DO(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:DO(o),value:F,expiresAt:_,id:d?.[q],table:u}));for(;l;)v.push({type:DO(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})}LO.get(ose.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&lse(e.subject.split(".").slice(0,-1).join("."),fk.createNatsTableStreamName(c,u),e.headers,e.data),await S;let b=Date.now()-g;g&&lk(b,"replication-latency",e.subject,o,"ingest")}catch(o){Jr.error(o)}e.ack()}a(Sse,"messageProcessor");function DO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(DO,"convertOperation")});var ir=w((hPe,Bk)=>{"use strict";var Nr=ae();Nr.initSync();var Tse=require("fs-extra"),Ase=require("semver"),rp=require("path"),{monotonicFactory:Rse}=require("ulidx"),Rk=Rse(),yse=require("util"),yk=require("child_process"),bse=yse.promisify(yk.exec),Ose=yk.spawn,Mr=Tt(),$e=(H(),C(G)),{packageJson:Nse,PACKAGE_ROOT:wse}=st(),mg=ie(),oi=z(),Eg=Eo(),Ise=lg(),ep=yt(),{broadcast:Cse,onMessageByType:Pse,getWorkerIndex:Dse}=et(),{isMainThread:bk}=require("worker_threads"),{Encoder:Lse,decode:kO}=require("msgpackr"),Ok=new Lse,{isEmpty:ll}=mg,Nk=An(),uPe=48*36e11;bk&&Pse($e.ITC_EVENT_TYPES.RESTART,()=>{Qr=void 0,cl=void 0});var{connect:Mse,StorageType:vse,RetentionPolicy:Use,AckPolicy:FO,DeliverPolicy:GO,DiscardPolicy:xse,NatsConnection:dPe,JetStreamManager:fPe,JetStreamClient:_Pe,StringCodec:pPe,JSONCodec:Bse,createInbox:qO,headers:Hse,ErrorCode:Ak}=require("nats"),{recordAction:kse}=(ki(),C(W_)),{encodeBlobsAsBuffers:Fse}=(gs(),C(Fm)),wk=Bse(),Gse="clustering",qse=Nse.engines[Mr.NATS_SERVER_NAME],$se=rp.join(wse,"dependencies"),HO=rp.join($se,`${process.platform}-${process.arch}`,Mr.NATS_BINARY_NAME),xO,BO,tp,ol,al;Bk.exports={runCommand:Ik,checkNATSServerInstalled:Vse,createConnection:$O,getConnection:np,getJetStreamManager:sp,getJetStream:Pk,getNATSReferences:qi,getServerList:Yse,createLocalStream:VO,listStreams:Dk,deleteLocalStream:Wse,getServerConfig:Zu,listRemoteStreams:zse,viewStream:jse,viewStreamIterator:Jse,publishToStream:Qse,request:eie,reloadNATS:KO,reloadNATSHub:tie,reloadNATSLeaf:rie,extractServerName:Zse,requestErrorHandler:nie,createLocalTableStream:Uk,createTableStreams:oie,purgeTableStream:xk,purgeSchemaTableStreams:aie,getStreamInfo:cie,updateLocalStreams:uie,closeConnection:Kse,getJsmServerName:gg,addNatsMsgHeader:Lk,clearClientCache:Ck,updateRemoteConsumer:sie,createConsumer:Mk,updateConsumerIterator:iie};async function Ik(e,t=void 0){let{stdout:r,stderr:n}=await bse(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",Tt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},jZ={tls_certificate:Tt.SERVER,tls_certificateAuthority:Tt.CA,customFunctions_tls_certificate:Tt.SERVER,customFunctions_tls_certificateAuthority:Tt.CA,operationsApi_tls_certificate:Tt["OPERATIONS-API"],operationsApi_tls_certificateAuthority:Tt["OPERATIONS-CA"]},JZ={[Tt.SERVER]:2,[Tt.DEFAULT]:1},QZ={[Tt["OPERATIONS-API"]]:3,[Tt.SERVER]:2,[Tt.DEFAULT]:1},XZ={[Tt["OPERATIONS-API"]]:3,[Tt.SERVER]:2,[Tt.DEFAULT]:1},ZZ={[Tt["OPERATIONS-CA"]]:3,[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1},e8={[Tt["OPERATIONS-CA"]]:3,[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1},t8={[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1};Object.assign(NU,{CERTIFICATE_PEM_NAME:VZ,PRIVATEKEY_PEM_NAME:KZ,CA_PEM_NAME:YZ,CERT_NAME:Tt,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 Wy=I((ONe,LU)=>{"use strict";var PU=require("fs-extra"),Se=require("joi"),r8=require("os"),{boolean:He,string:At,number:tr,array:Qc}=Se.types(),{totalmem:wU}=require("os"),Jc=require("path"),n8=W(),Yy=ae(),bNe=Ky(),IU=(H(),P(G)),s8=it(),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",Rn=Se.alternatives([tr.min(0),At]).optional().empty(null),EE=Se.alternatives([Qc.items(At,{host:At.required(),port:Rn},{hostname:At.required(),port:Rn}).empty(null),Qc.items(At)]),Ui,DU=!1;LU.exports={configValidator:d8,routesValidator:E8,route_constraints:EE};function d8(e,t=!1){if(DU=t,Ui=e.rootPath,Yy.isEmpty(Ui))throw u8;let r=He.optional(),n=tr.min(0).max(1e3).empty(null).default(m8),s=At.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(T_),i=At.optional().empty(null),o=At.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Se.string().empty(null).default(T_),l=Se.custom(_8).empty(null).default(T_),u=e.clustering?.enabled,f=Se.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Se.object({enabled:r,hubServer:Se.object({cluster:Se.object({name:Se.required().empty(null),network:Se.object({port:Rn,routes:EE}).required()}).required(),leafNodes:Se.object({network:Se.object({port:Rn}).required()}).required(),network:Se.object({port:Rn}).required()}).required(),leafServer:Se.object({network:Se.object({port:Rn,routes:EE}).required(),streams:Se.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:Se.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:He.optional(),databaseLevel:He.optional(),tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.required(),verify:He.optional()}),user:At.optional().empty(null)}).optional():d=Se.object({enabled:r,tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.optional()})}).optional(),Se.object({authentication:Se.alternatives(Se.object({authorizeLocal:He,cacheTTL:tr.required(),enableSessions:He,hashFunction:At.valid("md5","sha256","argon2id").optional().empty(null)}),He).optional(),analytics:Se.object({aggregatePeriod:tr}),replication:Se.object({hostname:Se.alternatives(At,tr).optional().empty(null),url:At.optional().empty(null),port:Rn,securePort:Rn,routes:Qc.optional().empty(null),databases:Se.alternatives(At,Qc),enableRootCAs:He.optional(),copyTablesToCatchUp:He.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Se.object({enabled:r}).required(),logging:Se.object({auditAuthEvents:Se.object({logFailed:He,logSuccessful:He}),file:He.required(),level:Se.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Se.object({enabled:He.optional(),compress:He.optional(),interval:At.custom(h8).optional().empty(null),maxSize:At.custom(p8).optional().empty(null),path:At.optional().empty(null).default(T_)}).required(),root:s,stdStreams:He.required(),auditLog:He.required()}).required(),operationsApi:Se.object({network:Se.object({cors:He.optional(),corsAccessList:Qc.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:Rn,domainSocket:Se.optional().empty("hdb/operations-server").default(T_),securePort:Rn,timeout:tr.min(1).optional()}).optional(),tls:Se.alternatives([Se.array().items(f),f])}).required(),rootPath:At.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Se.object({network:Se.object({port:Rn,securePort:Rn,mtls:Se.alternatives([He.optional(),Se.object({user:At.optional(),certificateAuthority:i,required:He.optional()})])}).required(),webSocket:He.optional(),requireAuthentication:He.optional()}),http:Se.object({compressionThreshold:tr.optional(),cors:He.optional(),corsAccessList:Qc.optional(),headersTimeout:tr.min(1).optional(),port:Rn,securePort:Rn,maxHeaderSize:tr.optional(),mtls:Se.alternatives([He.optional(),Se.object({user:At.optional(),certificateAuthority:i,required:He.optional()})]),threadRange:Se.alternatives([Qc.optional(),At.optional()])}).required(),threads:Se.alternatives(n.optional(),Se.object({count:n.optional(),debug:Se.alternatives(He.optional(),Se.object({startingPort:tr.min(1).optional(),host:At.optional(),waitForDebugger:He.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:Se.object({writeAsync:He.required(),overlappingSync:He.optional(),caching:He.optional(),compression:Se.alternatives([He.optional(),Se.object({dictionary:At.optional(),threshold:tr.optional()})]),compactOnStart:He.optional(),compactOnStartKeepBackup:He.optional(),noReadAhead:He.optional(),path:l,prefetchWrites:He.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:He.optional(),tls:Se.alternatives([Se.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){Se.assert(e,At.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 T_(e,t){let r=t.state.path.join(".");if(!Yy.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Yy.isEmpty(Ui))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Jc.join(Ui,i8);case"logging.root":return Jc.join(Ui,CU);case"clustering.leafServer.streams.path":return Jc.join(Ui,"clustering","leaf");case"storage.path":let n=Jc.join(Ui,IU.LEGACY_DATABASES_DIR_NAME);return PU.existsSync(n)?n:Jc.join(Ui,IU.DATABASES_DIR_NAME);case"logging.rotation.path":return Jc.join(Ui,CU);case"operationsApi.network.domainSocket":return r==null?null:Jc.join(Ui,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(T_,"setDefaultRoot");function E8(e){let t=Se.object({routes:EE});return s8.validateBySchema({routes:e},t)}a(E8,"routesValidator")});var Rt=I($U=>{"use strict";var ys=(H(),P(G)),Sr=ae(),rr=W(),{configValidator:g8,routesValidator:MU}=Wy(),jr=require("fs-extra"),UU=require("yaml"),Wn=require("path"),S8=require("is-number"),xU=require("properties-reader"),T8=require("lodash"),{handleHDBError:A8}=pe(),{HTTP_STATUS_CODES:R8,HDB_ERROR_MSGS:Lu}=Bn(),{server:y8}=(Kr(),P(Ru)),{PACKAGE_ROOT:BU}=st(),{DATABASES_PARAM_CONFIG:A_,CONFIG_PARAMS:Yn,CONFIG_PARAM_MAP:ti}=ys,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=Wn.join(BU,"config","yaml",ys.HDB_DEFAULT_CONFIG_FILE),I8=Wn.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"},gE,It,SE;Object.assign($U,{createConfigFile:P8,getDefaultConfig:D8,getConfigValue:FU,initConfig:TE,flattenConfig:Mu,updateConfigValue:GU,updateConfigObject:M8,getConfiguration:x8,setConfiguration:B8,readConfigFile:Qy,getClusteringRoutes:H8,initOldConfig:qU,getConfigFromFile:k8,getConfigFilePath:Xc,addConfig:F8,deleteConfigFromFile:G8,getConfigObj:q8,resolvePath:zy,getFlatConfigObj:$8});function zy(e){if(e?.startsWith("~/"))return Wn.join(Sr.getHomeDir(),e.slice(1));let t=ce();return Wn.resolve(t.getHdbBasePath(),e)}a(zy,"resolvePath");function P8(e,t=!1){let r=wa(HU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=UU.parseDocument(jr.readFileSync(I8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}gE=Mu(r.toJSON());let n;for(let c in e){let l=ti[c.toLowerCase()];if(l===Yn.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=jy(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();It=Mu(s);let i=r.getIn(["rootPath"]),o=Wn.join(i,ys.HDB_CONFIG_FILE);if(jr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);jr.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(A_.TABLES))for(let i in n[s][A_.TABLES])for(let o in n[s][A_.TABLES][i]){let c=n[s][A_.TABLES][i][o],l=[Yn.DATABASES,s,A_.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=[Yn.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(gE===void 0){let r=wa(HU);gE=Mu(r.toJSON())}let t=ti[e.toLowerCase()];if(t!==void 0)return gE[t.toLowerCase()]}a(D8,"getDefaultConfig");function FU(e){if(e==null){rr.info(w8);return}if(It===void 0){rr.trace(b8);return}let t=ti[e.toLowerCase()];if(t!==void 0)return It[t.toLowerCase()]}a(FU,"getConfigValue");function Xc(e=Sr.getPropsFilePath()){let t=Sr.getEnvCliRootPath();if(t)return zy(Wn.join(t,ys.HDB_CONFIG_FILE));let r=xU(e);return zy(r.get(ys.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Xc,"getConfigFilePath");function TE(e=!1){if(It===void 0||e){let t;if(!Sr.noBootFile()){t=Sr.getPropsFilePath();try{jr.accessSync(t,jr.constants.F_OK|jr.constants.R_OK)}catch(i){throw rr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Xc(t),n;if(r.includes("config/settings.js"))try{qU(r);return}catch(i){if(i.code!==ys.NODE_ERROR_CODES.ENOENT)throw i}try{n=wa(r)}catch(i){if(i.code===ys.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,It=Mu(s),It.logging_rotation_rotate)for(let i in vU)It[i]&&rr.error(`Config ${vU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);rr.trace(O8)}}a(TE,"initConfig");function L8(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Wn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Wn.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}`);jr.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 Lu.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 Lu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=g8(r,t);if(n.error)throw Lu.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){It===void 0&&(It={});let r=ti[e.toLowerCase()];if(r===void 0){rr.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a(M8,"updateConfigObject");function GU(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&TE();let o=FU(ti.hdb_root),c=Wn.join(o,ys.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){rr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===Yn.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=jy(p,t);l.setIn([..._],h)}else for(let p in r){let _=ti[p.toLowerCase()];if(_===Yn.HTTP_SECUREPORT&&r[p]===It[Yn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===Yn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[p]===It[Yn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===Yn.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=ys.LEGACY_CONFIG_PARAMS[p.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,h=S.split("_"));let g=jy(_,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=Wn.join(f,ys.HDB_CONFIG_FILE);if(n===!0&&v8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);jr.writeFileSync(d,String(l)),s&&(It=Mu(l.toJSON())),rr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(GU,"updateConfigValue");function v8(e,t){try{let r=Wn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${ys.HDB_CONFIG_FILE}.bak`);jr.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 Mu(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}),SE=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;!Yn[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(Mu,"flattenConfig");function jy(e,t){if(e===Yn.CLUSTERING_NODENAME||e===Yn.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(jy,"castConfigValue");function x8(){let e=Sr.getPropsFilePath(),t=Xc(e);return wa(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 Qy(){let e=Sr.getPropsFilePath();try{jr.accessSync(e,jr.constants.F_OK|jr.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=Xc(e);return wa(t).toJSON()}a(Qy,"readConfigFile");function wa(e){return UU.parseDocument(jr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(wa,"parseYamlDoc");function H8(){let e=Qy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Sr.isEmptyOrZeroLength(t)?[]:t;let r=MU(t);if(r)throw Lu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Sr.isEmptyOrZeroLength(n)?[]:n;let s=MU(n);if(s)throw Lu.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 Lu.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(H8,"getClusteringRoutes");function qU(e){let t=xU(e);It={};for(let r in ti){let n=t.get(r.toUpperCase());if(Sr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ti[r].toLowerCase();s===Yn.LOGGING_ROOT?It[s]=Wn.dirname(n):It[s]=n}return It}a(qU,"initOldConfig");function k8(e){let t=Qy();return T8.get(t,e.replaceAll("_","."))}a(k8,"getConfigFromFile");async function F8(e,t){let r=wa(Xc());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 jr.writeFile(Xc(),String(r))}a(F8,"addConfig");function G8(e){let t=Xc(Sr.getPropsFilePath()),r=wa(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Wn.join(n,ys.HDB_CONFIG_FILE);jr.writeFileSync(s,String(r))}a(G8,"deleteConfigFromFile");function q8(){return SE||(TE(),SE)}a(q8,"getConfigObj");function $8(){return It||TE(),It}a($8,"getFlatConfigObj")});var yn=I((CNe,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=RE;Nr.exports.listUsersExternal=n5;Nr.exports.setUsersWithRolesCache=Zc;Nr.exports.findAndValidateUser=ob;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=bn(),V8=jc(),R_=(mE(),P(hE)),XU=yU(),y_=Wr(),rb=Ao(),xi=ae(),ZU=require("validate.js"),nb=W(),{promisify:K8}=require("util"),sb=go(),Zy=(H(),P(G)),VU=St(),Y8=Rt(),W8=ce(),z8=ho(),{hdb_errors:j8,ClientError:ri}=pe(),{HTTP_STATUS_CODES:To,AUTHENTICATION_ERROR_MSGS:Xy,HDB_ERROR_MSGS:vu}=j8,{UserEventMsg:ib}=ni(),eb=require("lodash"),{server:AE}=(Kr(),P(Ru)),J8=W();AE.getUser=(e,t)=>ob(e,t,t!=null);AE.authenticateUser=(e,t)=>ob(e,t);var e0={username:!0,active:!0,role:!0,password:!0},KU=new Map,Q8=K8(V8.delete),tb=W8.get(Zy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??R_.HASH_FUNCTION.SHA256,Bi;async function X8(e){let t=ZU.cleanAttributes(e,e0),r=XU.addUserValidation(t);if(r)throw new ri(r.message);let n=await y_.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(vu.ROLE_NAME_NOT_FOUND(t.role),To.NOT_FOUND);if(n.length>1)throw new ri(vu.DUP_ROLES_FOUND(t.role),To.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=sb.encrypt(t.password)),t.password=await R_.hash(t.password,tb),t.hash_function=tb,t.role=n[0].id;let s=await QU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(nb.debug(s),await Zc(),s.skipped_hashes.length===1)throw new ri(vu.USER_ALREADY_EXISTS(t.username),To.CONFLICT);return rb.signalUserChange(new ib(process.pid)),`${t.username} successfully added`}a(X8,"addUser");async function Z8(e){let t=ZU.cleanAttributes(e,e0);if(xi.isEmptyOrZeroLength(t.username))throw new Error(YU);if(xi.isEmptyOrZeroLength(t.password)&&xi.isEmptyOrZeroLength(t.role)&&xi.isEmptyOrZeroLength(t.active))throw new Error(WU);if(!xi.isEmpty(t.password)&&xi.isEmptyOrZeroLength(t.password.trim()))throw new Error(zU);if(!xi.isEmpty(t.active)&&!xi.isBoolean(t.active))throw new Error(JU);if(!xi.isEmpty(t.password)&&!xi.isEmptyOrZeroLength(t.password.trim())&&(e5(t.username)&&(t.hash=sb.encrypt(t.password)),t.password=await R_.hash(t.password,tb)),t.role==="")throw new Error(jU);if(t.role){let n=await y_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ri(vu.ALTER_USER_ROLE_NOT_FOUND(t.role),To.NOT_FOUND);if(n.length>1)throw new ri(vu.DUP_ROLES_FOUND(t.role),To.CONFLICT);t.role=n[0].id}let r=await QU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await Zc(),rb.signalUserChange(new ib(process.pid)),r}a(Z8,"alterUser");function e5(e){let t=!1,r=Bi.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 ri(t.message);if(Bi.get(e.username)===void 0)throw new ri(vu.USER_NOT_EXIST(e.username),To.NOT_FOUND);let r=await Q8({table:"hdb_user",schema:"system",hash_values:[e.username]});return nb.debug(r),await Zc(),rb.signalUserChange(new ib(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=eb.cloneDeep(e.hdb_user);let r=await y_.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 RE();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 RE(){let e=await y_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=eb.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await y_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=eb.cloneDeep(s),s.role=t[s.role],s5(s.role),n.set(s.username,s);return n}a(RE,"listUsers");function s5(e){if(!e){nb.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 Zc(e=void 0){e?Bi=e:Bi=await RE()}a(Zc,"setUsersWithRolesCache");async function i5(){return Bi||await Zc(),Bi}a(i5,"getUsersWithRolesCache");async function ob(e,t,r=!0){Bi||await Zc();let n=Bi.get(e);if(!n){if(!r)return{username:e};throw new ri(Xy.GENERIC_AUTH_FAIL,To.UNAUTHORIZED)}if(n&&!n.active)throw new ri(Xy.USER_INACTIVE,To.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=R_.validate(n.password,t,n.hash_function||R_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)KU.set(t,n.password);else throw new ri(Xy.GENERIC_AUTH_FAIL,To.UNAUTHORIZED)}}return s}a(ob,"findAndValidateUser");async function o5(){Bi||await Zc();for(let[,e]of Bi)if(e.role.role==="super_user")return e}a(o5,"getSuperUser");async function a5(){let e=await RE(),t=Y8.getConfigFromFile(Zy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==Zy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=sb.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=[];AE.invalidateUser=function(e){for(let t of t0)try{t(e)}catch(r){J8.error("Error invalidating user",r)}};AE.onInvalidatedUser=function(e){t0.push(e)}});var O_=I((MNe,i0)=>{"use strict";var el=W(),zn=(H(),P(G)),c5=gv(),DNe=Rs(),LNe=So(),l5=yn(),{validateEvent:r0}=ni(),b_=Kn(),u5=require("process"),{resetDatabases:d5}=(De(),P(nt)),f5={[zn.ITC_EVENT_TYPES.SCHEMA]:_5,[zn.ITC_EVENT_TYPES.USER]:s0};async function _5(e){let t=r0(e);if(t){el.error(t);return}el.trace("ITC schemaHandler received schema event:",e),await c5(e.message),await p5(e.message)}a(_5,"schemaHandler");async function p5(e){try{b_.resetReadTxn(zn.SYSTEM_SCHEMA_NAME,zn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),b_.resetReadTxn(zn.SYSTEM_SCHEMA_NAME,zn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),b_.resetReadTxn(zn.SYSTEM_SCHEMA_NAME,zn.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){el.error(t)}}a(p5,"syncSchemaMetadata");var n0=[];async function s0(e){try{try{b_.resetReadTxn(zn.SYSTEM_SCHEMA_NAME,zn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),b_.resetReadTxn(zn.SYSTEM_SCHEMA_NAME,zn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){el.warn(r)}let t=r0(e);if(t){el.error(t);return}el.trace(`ITC userHandler ${zn.HDB_ITC_CLIENT_PREFIX}${u5.pid} received user event:`,e),await l5.setUsersWithRolesCache();for(let r of n0)r()}catch(t){el.error(t)}}a(s0,"userHandler");s0.addListener=function(e){n0.push(e)};i0.exports=f5});var ni=I((kNe,a0)=>{"use strict";var UNe=W(),ab=ae(),h5=(H(),P(G)),{ITC_ERRORS:N_}=Bn(),{parentPort:xNe,threadId:m5,isMainThread:E5,workerData:BNe}=require("worker_threads"),{onMessageFromWorkers:g5,broadcast:HNe,broadcastWithAcknowledgement:S5}=rt();a0.exports={sendItcEvent:T5,validateEvent:o0,SchemaEventMsg:A5,UserEventMsg:R5};var yE;g5(async(e,t)=>{yE=yE||O_(),o0(e),yE[e.type]&&await yE[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 N_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||ab.isEmpty(e.type))return N_.MISSING_TYPE;if(!e.hasOwnProperty("message")||ab.isEmpty(e.message))return N_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||ab.isEmpty(e.message.originator))return N_.MISSING_ORIGIN;if(h5.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return N_.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 Ao=I((qNe,d0)=>{"use strict";var c0=(H(),P(G)),GNe=ae(),bE=W(),l0=hv(),Uu,{sendItcEvent:u0}=ni();function y5(e){try{bE.info("signalSchemaChange called with message:",e),Uu=Uu||O_();let t=new l0(c0.ITC_EVENT_TYPES.SCHEMA,e);return Uu.schema(t),u0(t)}catch(t){bE.error(t)}}a(y5,"signalSchemaChange");function b5(e){try{bE.trace("signalUserChange called with message:",e),Uu=Uu||O_();let t=new l0(c0.ITC_EVENT_TYPES.USER,e);return Uu.user(t),u0(t)}catch(t){bE.error(t)}}a(b5,"signalUserChange");d0.exports={signalSchemaChange:y5,signalUserChange:b5}});var OE=I((VNe,_0)=>{"use strict";var f0=ae(),O5=(H(),P(G)),N5=W(),w5=oE(),I5=iE(),C5=Ao(),{SchemaEventMsg:P5}=ni(),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 xu=I((YNe,p0)=>{"use strict";var cb=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=cb});var m0=I((zNe,h0)=>{"use strict";var U5=xu(),x5=(H(),P(G)).OPERATIONS_ENUM,lb=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=lb});var g0=I((JNe,E0)=>{"use strict";var B5=xu(),H5=(H(),P(G)).OPERATIONS_ENUM,ub=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=ub});var T0=I((XNe,S0)=>{"use strict";var k5=xu(),F5=(H(),P(G)).OPERATIONS_ENUM,db=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=db});var R0=I((ewe,A0)=>{"use strict";var G5=xu(),q5=(H(),P(G)).OPERATIONS_ENUM,fb=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=fb});var w_=I((nwe,N0)=>{"use strict";var rwe=require("path"),y0=ft(),$5=m0(),V5=g0(),K5=T0(),Y5=R0(),Bu=xt(),b0=ae(),{CONFIG_PARAMS:W5}=(H(),P(G)),O0=ce();O0.initSync();var NE=(H(),P(G)).OPERATIONS_ENUM,{getTransactionAuditStorePath:z5}=Et();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,Bu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Bu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Bu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Bu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),b0.isEmpty(s.user_name)||n.dbis[Bu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Bu.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===NE.INSERT)return new $5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===NE.UPDATE)return new V5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===NE.UPSERT)return new K5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===NE.DELETE)return new Y5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(J5,"createTransactionObject")});var _b=I((owe,w0)=>{"use strict";var Q5=u_(),iwe=xf(),I_=(H(),P(G)),X5=Bf(),Z5=$c().insertRecords,e9=ft(),t9=W(),r9=OE(),{getSchemaPath:n9}=Et(),s9=w_();w0.exports=i9;async function i9(e){try{let{schema_table:t,attributes:r}=Q5(e);X5(e,r,t.hash_attribute),e.schema!==I_.SYSTEM_SCHEMA_NAME&&(r.includes(I_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(I_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(I_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(I_.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=I((cwe,C0)=>{"use strict";var I0=(H(),P(G)),o9=_b(),a9=xf(),c9=require("fs-extra"),{getSchemaPath:l9}=Et();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=I((uwe,D0)=>{"use strict";var pb=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=pb});var x0=I((hwe,U0)=>{"use strict";var M0=ft(),hb=pn(),mb=Bn().LMDB_ERRORS_ENUM,d9=xt(),v0=W(),fwe=ae(),f9=require("lmdb"),_9=L0(),p9=(H(),P(G)),{OVERFLOW_MARKER:_we,MAX_SEARCH_KEY_LENGTH:pwe}=d9,h9=p9.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function m9(e,t,r,n){if(hb.validateEnv(e),t===void 0)throw new Error(mb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(mb.IDS_REQUIRED):new Error(mb.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],A=h[R];if(A!=null)try{let N=hb.getIndexedValues(A);if(N)for(let v=0,F=N.length;v<F;v++)E.remove(N[v],o)}catch{v0.warn(`cannot delete from attribute: ${R}, ${A}:${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=hb.getNextMonotonicTime(),i}catch(s){throw s}}a(m9,"deleteRecords");U0.exports={deleteRecords:m9}});var C_=I((Ewe,H0)=>{"use strict";var Hu=ae(),E9=x0(),g9=ft(),{getSchemaPath:S9}=Et(),T9=w_(),A9=W();H0.exports=R9;async function R9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Hu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Hu.isEmptyOrZeroLength(e.hash_values)&&!Hu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Hu.isEmpty(l)||e.hash_values.push(l)}}if(Hu.isEmptyOrZeroLength(e.hash_values))return B0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Hu.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 gb=I((Twe,k0)=>{"use strict";var y9=(H(),P(G)),Swe=pn();function Eb(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(Eb,"parseRow");function b9(e,t,r,n){let s=Eb(r,e);n.push(s)}a(b9,"searchAll");function O9(e,t,r,n){let s=Eb(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 tl(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(tl,"pushResults");function w9(e,t,r,n,s,i){t.toString().endsWith(e)&&tl(t,r,n,s,i)}a(w9,"endsWith");function I9(e,t,r,n,s,i){t.toString().includes(e)&&tl(t,r,n,s,i)}a(I9,"contains");function C9(e,t,r,n,s,i){t>e&&tl(t,r,n,s,i)}a(C9,"greaterThanCompare");function P9(e,t,r,n,s,i){t>=e&&tl(t,r,n,s,i)}a(P9,"greaterThanEqualCompare");function D9(e,t,r,n,s,i){t<e&&tl(t,r,n,s,i)}a(D9,"lessThanCompare");function L9(e,t,r,n,s,i){t<=e&&tl(t,r,n,s,i)}a(L9,"lessThanEqualCompare");k0.exports={parseRow:Eb,searchAll:b9,searchAllToMap:O9,iterateDBI:N9,endsWith:w9,contains:I9,greaterThanCompare:C9,greaterThanEqualCompare:P9,lessThanCompare:D9,lessThanEqualCompare:L9,pushResults:tl}});var ku=I((Owe,Y0)=>{"use strict";var Ia=ft(),Rwe=W(),jn=pn(),wE=xt(),Wt=Bn().LMDB_ERRORS_ENUM,ywe=ae(),M9=(H(),P(G)),IE=gb(),{parseRow:v9}=IE,bwe=require("lmdb"),{OVERFLOW_MARKER:F0,MAX_SEARCH_KEY_LENGTH:U9}=wE;function G0(e,t,r,n=!1,s=void 0,i=void 0){return rl(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 P_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return rl(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(P_,"iterateRangeBetween");function rl(e,t,r,n){let s=e.database||e,i=Ia.openDBI(s,r);i[wE.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(rl,"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=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[wE.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(jn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);return rl(e,t,t,(o,c,l)=>(CE(r),r=D_(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(jn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);CE(r),r=D_(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,IE.parseRow(l,r));return o}a(B9,"searchAllToMap");function H9(e,t,r=!1,n=void 0,s=void 0){if(jn.validateEnv(e),t===void 0)throw new Error(Wt.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(jn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);return Ia.statDBI(e,t).entryCount}a(k9,"countAll");function F9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ca(e,r,n),rl(e,t,r,(c,l,u,f)=>(n=jn.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 Ca(e,t,r),Ia.openDBI(e,t).getValuesCount(r)}a(G9,"count");function q9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ca(e,r,n),rl(e,null,r,(c,l)=>{n=jn.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 Ca(e,r,n),rl(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[wE.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){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),P_(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){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),P_(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){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),P_(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){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),P_(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(jn.validateEnv(e),r===void 0)throw new Error(Wt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Wt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Wt.END_VALUE_REQUIRED);if(n=jn.convertKeyValueToWrite(n),s=jn.convertKeyValueToWrite(s),n>s)throw new Error(Wt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return P_(e,t,r,n,s,i,o,c)}a(z9,"between");function j9(e,t,r,n){jn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);if(CE(r),r=D_(s,r),n===void 0)throw new Error(Wt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=IE.parseRow(c,r)),o}a(j9,"searchByHash");function J9(e,t,r){jn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Wt.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 rl(e,t,t,(i,o,c)=>{r=D_(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,IE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(V0,"batchHashSearch");function K0(e,t,r,n,s){if(jn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);if(CE(r),n==null)throw new Error(Wt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Wt.IDS_MUST_BE_ITERABLE)}a(K0,"initializeBatchSearchByHash");function CE(e){if(!Array.isArray(e))throw e===void 0?new Error(Wt.FETCH_ATTRIBUTES_REQUIRED):new Error(Wt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(CE,"validateFetchAttributes");function Ca(e,t,r){if(jn.validateEnv(e),t===void 0)throw new Error(Wt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Wt.SEARCH_VALUE_REQUIRED);if(r?.length>U9)throw new Error(Wt.SEARCH_VALUE_TOO_LARGE)}a(Ca,"validateComparisonFunctions");function D_(e,t){return t.length===1&&M9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Ia.listDBIs(e)),t}a(D_,"setGetWholeRowAttributes");Y0.exports={searchAll:x9,searchAllToMap:B9,count:G9,countAll:k9,equals:F9,startsWith:q9,endsWith:$9,contains:$0,searchByHash:j9,setGetWholeRowAttributes:D_,batchSearchByHash:Q9,batchSearchByHashToMap:X9,checkHashExists:J9,iterateDBI:H9,greaterThan:V9,greaterThanEqual:K9,lessThan:Y9,lessThanEqual:W9,between:z9}});var Fu=I((wwe,Q0)=>{var W0=require("lodash"),z0=it(),ke=require("joi"),Z9=ae(),{hdb_schema_table:L_,checkValidTable:j0,hdb_table:J0,hdb_database:PE}=Li(),{handleHDBError:e7,hdb_errors:t7}=pe(),{getDatabases:r7}=(De(),P(nt)),{HTTP_STATUS_CODES:n7}=t7,s7=ke.object({database:PE,schema:PE,table:J0,search_attribute:L_,search_value:ke.any().required(),get_attributes:ke.array().min(1).items(ke.alternatives(L_,ke.object())).optional(),desc:ke.bool(),limit:ke.number().integer().min(1),offset:ke.number().integer().min(0)}),i7=ke.object({database:PE,schema:PE,table:J0,operator:ke.string().valid("and","or").default("and").lowercase(),offset:ke.number().integer().min(0),limit:ke.number().integer().min(1),get_attributes:ke.array().min(1).items(ke.alternatives(L_,ke.object())).optional(),sort:ke.object({attribute:ke.alternatives(L_,ke.array().min(1)),descending:ke.bool().optional()}).optional(),conditions:ke.array().min(1).items(ke.alternatives(ke.object({operator:ke.string().valid("and","or").default("and").lowercase(),conditions:ke.array()}),ke.object({search_attribute:ke.alternatives(L_,ke.array().min(1)),search_type:ke.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:ke.when("search_type",{switch:[{is:"equals",then:ke.any()},{is:"between",then:ke.array().items(ke.alternatives([ke.string(),ke.number()])).length(2)}],otherwise:ke.alternatives(ke.string(),ke.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 Sb=I((Cwe,X0)=>{"use strict";var o7=ft(),a7=Fu(),{getSchemaPath:c7}=Et();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 Tb=I((Dwe,Z0)=>{"use strict";var u7=ku(),d7=Sb();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 Gu=I((Mwe,ex)=>{"use strict";var Ab=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=Ab});var rx=I((xwe,tx)=>{"use strict";var Uwe=Gu(),_7=ku(),p7=Sb();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 si=I((Hwe,nx)=>{"use strict";var Rb=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=Rb});var DE=I((Fwe,lx)=>{"use strict";var Jr=ku(),m7=ft(),E7=ae(),Fe=xt(),nl=(H(),P(G)),g7=ho(),sx=Bn().LMDB_ERRORS_ENUM,{getSchemaPath:S7}=Et(),Ro=nl.SEARCH_WILDCARDS;async function T7(e,t,r){let n;e.schema===nl.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([Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Fe.SEARCH_TYPES.SEARCH_ALL,Fe.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 Fe.SEARCH_TYPES.EQUALS:s=Jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.CONTAINS:s=Jr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.ENDS_WITH:case Fe.SEARCH_TYPES._ENDS_WITH:s=Jr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.STARTS_WITH:case Fe.SEARCH_TYPES._STARTS_WITH:s=Jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.SEARCH_ALL:return Jr.searchAll(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.BETWEEN:s=Jr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN:case Fe.SEARCH_TYPES._GREATER_THAN:s=Jr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN_EQUAL:case Fe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Jr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN:case Fe.SEARCH_TYPES._LESS_THAN:s=Jr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN_EQUAL:case Fe.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),Ro.indexOf(s)>-1)return r===!0?Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Fe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Ro[0])<0&&s.indexOf(Ro[1])<0)return c===!0?r===!0?Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Fe.SEARCH_TYPES.EQUALS;if(Ro.indexOf(i)>=0&&Ro.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Fe.SEARCH_TYPES.CONTAINS;if(Ro.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Fe.SEARCH_TYPES.ENDS_WITH;if(Ro.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Fe.SEARCH_TYPES.STARTS_WITH;if(s.includes(Ro[0])||s.includes(Ro[1]))return Fe.SEARCH_TYPES.EQUALS;throw new Error(sx.UNKNOWN_SEARCH_TYPE)}else switch(n){case nl.VALUE_SEARCH_COMPARATORS.BETWEEN:return Fe.SEARCH_TYPES.BETWEEN;case nl.VALUE_SEARCH_COMPARATORS.GREATER:return Fe.SEARCH_TYPES.GREATER_THAN;case nl.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Fe.SEARCH_TYPES.GREATER_THAN_EQUAL;case nl.VALUE_SEARCH_COMPARATORS.LESS:return Fe.SEARCH_TYPES.LESS_THAN;case nl.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Fe.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=I(($we,ux)=>{"use strict";var qwe=si(),R7=Fu(),y7=ae(),b7=(H(),P(G)),O7=DE();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 M_=I((Ywe,fx)=>{"use strict";var Kwe=si(),w7=Fu(),I7=ae(),C7=(H(),P(G)),P7=DE();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=I((jwe,_x)=>{"use strict";var zwe=xt(),yb=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}},bb=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Ob=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};_x.exports={SearchByConditionsObject:yb,SearchCondition:bb,SortAttribute:Ob}});var Sx=I((Zwe,gx)=>{"use strict";var Qwe=px().SearchByConditionsObject,L7=si(),M7=Fu(),Nb=ku(),LE=xt(),{Resource:Xwe}=(ga(),P(SR)),Ex=DE(),v7=gb(),U7=require("lodash"),{getSchemaPath:x7}=Et(),hx=ft(),{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===LE.SEARCH_TYPES.EQUALS?u.estimated_count=Nb.count(n,u.search_attribute,u.search_value):f===LE.SEARCH_TYPES.CONTAINS||f===LE.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=Nb.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=Nb.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===LE.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 v_=I((tIe,Tx)=>{"use strict";var q7=(H(),P(G)).OPERATIONS_ENUM,wb=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=wb});var Ib=I((nIe,Ix)=>{"use strict";var bx=si(),Ox=v_(),Nx=M_(),wx=C_(),On=(H(),P(G)),Ax=ae(),Rx=ft(),{getTransactionAuditStorePath:$7,getSchemaPath:V7}=Et(),yx=W();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(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,On.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[On.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(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await wx(s)}a(Y7,"deleteAttributesFromSystem");async function W7(e){let t=new bx(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,On.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[On.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,On.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,On.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(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await wx(s)}catch(i){throw i}}a(W7,"dropTableFromSystem")});var Px=I((iIe,Cx)=>{"use strict";var z7=require("fs-extra"),j7=si(),J7=Gu(),Q7=v_(),X7=Ib(),Z7=C_(),eee=Tb(),tee=M_(),yo=(H(),P(G)),{getSchemaPath:ree}=Et(),{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(yo.SYSTEM_SCHEMA_NAME,yo.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,yo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[yo.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(yo.SYSTEM_SCHEMA_NAME,yo.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(yo.SYSTEM_SCHEMA_NAME,yo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[yo.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 U_=I((aIe,Dx)=>{"use strict";var Cb=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Dx.exports=Cb});var Db=I((uIe,Lx)=>{"use strict";var lee=require("fs-extra"),ME=ft(),{getTransactionAuditStorePath:uee}=Et(),Pb=xt(),lIe=U_();Lx.exports=dee;async function dee(e){let t;try{let r=uee(e.schema,e.table);await lee.mkdirp(r),t=await ME.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{ME.createDBI(t,Pb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),ME.createDBI(t,Pb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),ME.createDBI(t,Pb.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=I((_Ie,vx)=>{"use strict";var Lb=(H(),P(G)),Mx=ft(),fee=$c(),{getSystemSchemaPath:_ee,getSchemaPath:pee}=Et(),fIe=ho(),hee=oE(),Mb=iE(),mee=W(),Eee=Db();vx.exports=gee;async function gee(e,t){let r=pee(t.schema,t.table),n=new Mb(t.schema,t.table,Lb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Mb(t.schema,t.table,Lb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Mb(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(),Lb.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 vb(n),await vb(s),await vb(i)}await Eee(t)}catch(o){throw o}}a(gee,"lmdbCreateTable");async function vb(e){try{await hee(e)}catch(t){mee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(vb,"createAttribute")});var Bx=I((hIe,xx)=>{"use strict";var See=u_(),Tee=Bf(),Aee=OE(),x_=(H(),P(G)),Ree=$c().updateRecords,yee=ft(),{getSchemaPath:bee}=Et(),Oee=w_(),Nee=W();xx.exports=wee;async function wee(e){try{let{schema_table:t,attributes:r}=See(e);Tee(e,r,t.hash_attribute),e.schema!==x_.SYSTEM_SCHEMA_NAME&&(r.includes(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(x_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(x_.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=I((EIe,Hx)=>{"use strict";var Iee=(H(),P(G)).OPERATIONS_ENUM,Ub=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=Ub});var Gx=I((TIe,Fx)=>{"use strict";var SIe=kx(),Cee=u_(),Pee=Bf(),Dee=OE(),B_=(H(),P(G)),Lee=$c().upsertRecords,Mee=ft(),{getSchemaPath:vee}=Et(),Uee=w_(),xee=W(),{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!==B_.SYSTEM_SCHEMA_NAME&&(n.includes(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(B_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(B_.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=I((RIe,qx)=>{"use strict";var xb=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};qx.exports=xb});var Kx=I((bIe,Vx)=>{"use strict";var Bb=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=Bb});var zx=I((wIe,Wx)=>{"use strict";var Hb=ft(),{getTransactionAuditStorePath:Fee}=Et(),NIe=$x(),H_=xt(),Gee=ae(),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 Hb.openEnvironment(t,e.table,!0),n=Hb.listDBIs(r);Hb.initializeDBIs(r,H_.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[H_.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[H_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Gee.isEmpty(c)||(s=e.dbis[H_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[H_.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=I((CIe,jx)=>{"use strict";var kb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};jx.exports=kb});var Xx=I((LIe,Qx)=>{"use strict";var zee=si(),jee=v_(),DIe=Jx(),Hi=(H(),P(G)),Jee=ae(),Fb=ft(),Qee=ho(),Xee=M_(),Zee=C_(),{getSchemaPath:ete}=Et();Qx.exports=tte;async function tte(e,t=!0){let r;e.schema===Hi.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 Fb.openEnvironment(s,e.table);return t===!0&&await rte(e,i,r.hash_attribute),Fb.dropDBI(i,e.attribute),n}a(tte,"lmdbDropAttribute");async function rte(e,t,r){let n=Fb.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(Hi.SYSTEM_SCHEMA_NAME,Hi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Hi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Hi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Hi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Xee(t)).filter(o=>o[Hi.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[Hi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new jee(Hi.SYSTEM_SCHEMA_NAME,Hi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Zee(i)}a(nte,"dropAttributeFromSystem")});var sB=I((UIe,nB)=>{"use strict";var Gb=ft(),qu=xt(),vIe=pn(),qb=(H(),P(G)),Zx=ae(),{getTransactionAuditStorePath:ste}=Et(),ite=ku(),vE=xu(),ote=W();nB.exports=ate;async function ate(e){let t=ste(e.schema,e.table),r=await Gb.openEnvironment(t,e.table,!0),n=Gb.listDBIs(r);Gb.initializeDBIs(r,qu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case qb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return eB(r,e.search_values);case qb.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 qb.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[qu.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 vE,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[qu.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,qu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,qu.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 vE(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new vE(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[qu.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 vE,i);r.push(o)}}catch(i){ote.warn(i)}return r}catch(n){throw n}}a(rB,"batchSearchTransactions")});var oB=I((kIe,iB)=>{"use strict";var{getSchemaPath:BIe}=Et(),HIe=ft(),{database:ute}=(De(),P(nt));iB.exports={writeTransaction:dte};async function dte(e,t,r){return ute({database:e,table:t}).transaction(r)}a(dte,"writeTransaction")});var uB=I((GIe,lB)=>{"use strict";var{getSchemaPath:aB}=Et(),cB=ft();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=I(($Ie,_B)=>{"use strict";var{Readable:pte}=require("stream"),{getDatabases:hte}=(De(),P(nt)),{readSync:mte,openSync:Ete,createReadStream:dB}=require("fs"),{open:gte}=require("lmdb"),fB=i_(),Ste=o_(),{AUDIT_STORE_OPTIONS:Tte}=(_o(),P(hB)),{INTERNAL_DBIS_NAME:Ate,AUDIT_STORE_NAME:Rte}=xt();_B.exports=bte;var $b=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,A){A.encoding="binary",A.encoder=void 0;let N=d.openDB(E,A),v=f.openDB(E,A);for(let{key:F,version:$,value:Y}of v.getRange({start:null,transaction:h,versions:v.useVersions}))p=N.put(F,Y,$),S++%yte===0&&(await new Promise(ee=>setTimeout(ee,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:E,value:A}of f.getRange({transaction:h,start:!1}))if(s.some(N=>E.startsWith?.(N+"/"))){_.put(E,A);let[,N]=E.split("/"),v=!N,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($b);mte(c,u,0,$b),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=dB(null,{fd:c,start:$b}),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=I((KIe,EB)=>{"use strict";var Ote=W(),{handleHDBError:Nte}=pe(),wte=CM(),Ite=oE(),Cte=_b(),Pte=P0(),Dte=C_(),Lte=Tb(),Mte=rx(),vte=dx(),Ute=M_(),xte=Sx(),Bte=Px(),Hte=Ux(),kte=Bx(),Fte=Gx(),Gte=zx(),qte=Ib(),$te=Xx(),Vte=sB(),Kte=oB(),mB=uB(),Yte=pB(),Vb=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=Vb});var Yb={};Ue(Yb,{add:()=>UE,applyReverse:()=>SB,getRecordAtTime:()=>Kb,rebuildUpdateBefore:()=>xE});function UE(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 xE(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,UE(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 Kb(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":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=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 Wte,TB,BE=be(()=>{_o();a(UE,"add");UE.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:UE};a(xE,"rebuildUpdateBefore");a(SB,"applyReverse");TB={};a(Kb,"getRecordAtTime")});function Nn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function GE(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}`);Nn(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}`);Nn(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}`);Nn(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}`);Nn(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}`);Nn(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}`);Nn(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}`);Nn(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}`);Nn(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}`);Nn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Ii||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);Nn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){Nn(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}`);Nn(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 _=Wb(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");Nn(this)[c]=l}),i("deleteProperty",function(c){Nn(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 Wb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends k_{static{a(this,"TrackedObject")}},GE(r,t)),new r(e)):new k_(e);case Array:let n=new kE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=Wb(o,t?.elements)),n[s]=o}return n;default:return e}}function qE(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=qE(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 il(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=il(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=Yb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=il(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 HE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[sl]||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(HE(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(HE(s))return!0}else return!0}else return!0}}return!1}var Jn,AB,RB,k_,zte,sl,kE,FE,zb=be(()=>{Jn=M(pe());BE();Ss();a(Nn,"getChanges");a(GE,"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=Wb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(Wb,"trackObject");k_=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}};GE(k_,{});a(qE,"collapseData");zte=Object.prototype.hasOwnProperty;a(il,"updateAndFreeze");a(HE,"hasChanges");sl=Symbol.for("has-array-changes"),kE=class extends Array{static{a(this,"TrackedArray")}#e;[sl];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[sl]=!0,super.splice(...t)}push(...t){return this[sl]=!0,super.push(...t)}pop(){return this[sl]=!0,super.pop()}unshift(...t){return this[sl]=!0,super.unshift(...t)}shift(){return this[sl]=!0,super.shift()}};kE.prototype.constructor=Array;FE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var PB={};Ue(PB,{ResourceBridge:()=>Qb});function Xb({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=ki(e),n=Xb(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&&qE(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 ki(e){let t=e.database||e.schema||Jte,r=Xe()[t];if(!r)throw(0,ii.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,$E,ii,IB,jb,Jb,CB,jte,Jte,Qte,Xte,yB,Qb,DB=be(()=>{"use strict";wB=M(gB()),$E=M(Fu()),ii=M(pe());De();IB=M(u_());H();jb=M(Ao()),Jb=M(ni()),CB=M(ae());Cc();zb();({HDB_ERROR_MSGS:jte}=ii.hdb_errors),Jte="data",Qte=1e4,Xte=10,Qb=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,$E.default)(t,"conditions");if(r)throw(0,ii.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=ki(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:Xb(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 ki(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=ki(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){ki(t).dropTable()}createSchema(t){return $u({database:t.schema,table:null}),jb.signalSchemaChange(new Jb.SchemaEventMsg(process.pid,Kt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Zb(t.schema),jb.signalSchemaChange(new Jb.SchemaEventMsg(process.pid,Kt.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),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=qE(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),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 OB(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Xe()[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:cm.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,$E.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&&XA[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,$E.default)(t,"value");if(n)throw n;let s=ki(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===cm.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:Xb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=ki(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){ki({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return ki(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=ki(t),n={};switch(t.search_type){case lm.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 lm.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(Xb,"getSelect");a(bB,"getRecords");a(ki,"getTable");a(OB,"createDeleteResponse");a(NB,"groupRecordsInHistory")});var Kn=I((sCe,LB)=>{"use strict";var{ResourceBridge:Zte}=(DB(),P(PB)),ere=ce();ere.initSync();var VE;function tre(){return VE||(VE=new Zte,VE)}a(tre,"getBridge");LB.exports=tre()});var bn=I((oCe,xB)=>{"use strict";var YE=GR(),Lr=ae(),rre=require("util"),WE=Kn(),nre=Rs(),MB=W(),{handleHDBError:ol,hdb_errors:sre}=pe(),{HTTP_STATUS_CODES:al}=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=YE(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=YE(e);if(t)throw ol(new Error,t.message,al.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw ol(new Error,r,al.BAD_REQUEST);let n=await WE.createRecords(e);return KE(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=YE(e);if(t)throw ol(new Error,t.message,al.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw ol(new Error,r,al.BAD_REQUEST);let n=await WE.updateRecords(e);return Lr.isEmpty(n.existing_rows)?KE(ore,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):KE(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(lre,"updateData");async function ure(e){if(e.operation!=="upsert")throw ol(new Error,"invalid operation, must be upsert",al.INTERNAL_SERVER_ERROR);let t=YE(e);if(t)throw ol(new Error,t.message,al.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw ol(new Error,r,al.BAD_REQUEST);let n=await WE.upsertRecords(e);return KE(UB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(ure,"upsertData");function KE(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(KE,"returnObject");function dre(e){return Lr.transformReq(e),WE.flush(e.schema,e.table)}a(dre,"flush")});var qB=I((cCe,GB)=>{var Vu=require("validate.js"),HB=it(),Ku=(H(),P(G)),{handleHDBError:fre,hdb_errors:_re}=pe(),{HDB_ERROR_MSGS:zt,HTTP_STATUS_CODES:pre}=_re,eO=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),hre={STRUCTURE_USER:"structure_user"},BB=Object.values(Ku.ROLE_TYPES_ENUM),mre="attribute_permissions",Ere="attribute_name",{PERMS_CRUD_ENUM:Yu}=Ku,gre=[mre,...Object.values(Yu)],kB=[Yu.READ,Yu.INSERT,Yu.UPDATE],Sre=[Ere,...kB];function Tre(e){let t=eO();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,FB(e,t)}a(Tre,"addRoleValidation");function Are(e){let t=eO();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,FB(e,t)}a(Are,"alterRoleValidation");function Rre(e){let t=eO();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","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(zt.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]&&!Vu.isBoolean(e.permission[c])&&nr(zt.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(zt.SCHEMA_NOT_FOUND(d),r)}continue}nr(zt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(zt.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(zt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{gre.includes(f)||nr(zt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Yu).forEach(f=>{Vu.isDefined(u[f])?Vu.isBoolean(u[f])||nr(zt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(zt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(zt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(zt.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!==Yu.DELETE&&nr(zt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!Vu.isDefined(_.attribute_name)){nr(zt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!f.includes(h)){nr(zt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}kB.forEach(S=>{Vu.isDefined(_[S])?Vu.isBoolean(_[S])||nr(zt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,l):nr(zt.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(zt.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===Ku.OPERATIONS_ENUM.ADD_ROLE||t===Ku.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 zt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Ku.ROLE_TYPES_ENUM.SUPER_USER:Ku.ROLE_TYPES_ENUM.CLUSTER_USER;return zt.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:zt.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 G_=I((dCe,YB)=>{"use strict";var $B=bn(),VB=Wr(),Nre=jc(),rO=qB(),nO=Ao(),uCe=require("uuid").v4,wre=require("util"),zE=(H(),P(G)),Ire=ae(),sO=VB.searchByValue,Cre=VB.searchByHash,Pre=wre.promisify(Nre.delete),Dre=si(),Lre=Gu(),{hdb_errors:Mre,handleHDBError:cl}=pe(),{HDB_ERROR_MSGS:KB,HTTP_STATUS_CODES:F_}=Mre,{UserEventMsg:iO}=ni();YB.exports={addRole:vre,alterRole:Ure,dropRole:xre,listRoles:Bre};function tO(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(tO,"scrubRoleDetails");async function vre(e){let t=rO.addRoleValidation(e);if(t)throw t;e=tO(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 sO(r)||[])}catch(i){throw cl(i)}if(n&&n.length>0)throw cl(new Error,KB.ROLE_ALREADY_EXISTS(e.role),F_.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),nO.signalUserChange(new iO(process.pid)),e=tO(e),e}a(vre,"addRole");async function Ure(e){let t=rO.alterRoleValidation(e);if(t)throw t;e=tO(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await $B.update(r)}catch(s){throw cl(s)}if(n&&n?.message==="updated 0 of 1 records")throw cl(new Error,"Invalid role id",F_.BAD_REQUEST,void 0,void 0,!0);return await nO.signalUserChange(new iO(process.pid)),e}a(Ure,"alterRole");async function xre(e){let t=rO.dropRoleValidation(e);if(t)throw cl(new Error,t,F_.BAD_REQUEST,void 0,void 0,!0);let r=new Lre(zE.SYSTEM_SCHEMA_NAME,zE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Cre(r));if(n.length===0)throw cl(new Error,KB.ROLE_NOT_FOUND,F_.NOT_FOUND,void 0,void 0,!0);let s=new Dre(zE.SYSTEM_SCHEMA_NAME,zE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await sO(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 cl(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,F_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Pre(c),nO.signalUserChange(new iO(process.pid)),`${n[0].role} successfully deleted`}a(xre,"dropRole");async function Bre(){return sO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Bre,"listRoles")});var oO={};Ue(oO,{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,jE.alterRole)(e))}return(0,jE.addRole)(e)}var jE,WB,zB,Hre,Fre,JB=be(()=>{De();jE=M(G_()),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 q_||(q_=qre(Vre)),(await(await q_).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"}),q_=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:Vr,tables:Qn,databases:$e})}};let n=await(0,QB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),q_}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:Vr,tables:Qn}}var QB,XB,ZB,Gre,q_,aO=be(()=>{ga();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 lO={};Ue(lO,{handleFile:()=>Kre});async function Kre(e,t,r,n){let s=new Map,i=await JE(r);c(i.default)&&n.set((0,cO.dirname)(t),i.default),o(i,(0,cO.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 cO,eH=be(()=>{aO();cO=require("path");a(Kre,"handleFile")});var dO={};Ue(dO,{start:()=>Yre});function Yre({resources:e}){e.set("login",uO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var uO,tH=be(()=>{ga();a(Yre,"start");uO=class extends Vr{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 z_={};Ue(z_,{addAnalyticsListener:()=>W_,calculateCPUUtilization:()=>TH,diffResourceUsage:()=>AH,recordAction:()=>sr,recordActionBinary:()=>Xn,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},XE.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=XE.get(i);o?zre(e,o):jre(i,e,t,r,n,s),QE||Jre()}function Xn(e,t,r,n,s){sr(!!e,t,r,n,s)}function W_(e){gH.push(e)}function Jre(){QE=performance.now(),setTimeout(async()=>{let e=performance.now()-QE;QE=0;let t=[],r={time:Date.now(),period:e,threadId:ll.threadId,metrics:t};for(let[s,i]of XE){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:ll.threadId,byThread:!0,...n});for(let s of gH)s(t);XE=new Map,ll.parentPort?ll.parentPort.postMessage({type:EH,report:r}):OH({report:r})},mH).unref()}function ZE(e,t,r){let n={id:(0,K_.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};ZE(e,"table-size",l),ul.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};ZE(e,"database-size",u),ul.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){ul.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};ZE(e,"storage-volume",o),ul.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){ul.warn?.("Error getting DB volumne metrics",s)}}async function Xre(e,t=6e4){let r=_O(),n=yH(),s=new Promise(E=>{let A=performance.now();setImmediate(()=>{let N=performance.now();N-A>5e3&&ul.warn?.("Unusually high event queue latency on the main thread of "+Math.round(N-A)+"ms"),A=performance.now()}),n.primaryStore.prefetch([1],()=>{let N=performance.now();N-A>5e3&&ul.warn?.("Unusually high task queue latency on the main thread of "+Math.round(N-A)+"ms"),E(N-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:N,threadId:v}=A;for(let F of N||[]){let{path:$,method:Y,type:ee,metric:oe,count:j,total:se,distribution:z,threads:me,...Ae}=F;j||(j=1);let Pe=oe+($?"-"+$:"");Y!==void 0&&(Pe+="-"+Y),ee!==void 0&&(Pe+="-"+ee);let he=c.get(Pe);if(he){if(he.threads){let ut=he.threads[v];if(ut)he=ut;else{he.threads[v]={...Ae};continue}}he.count||(he.count=1);let Ot=he.count;for(let ut in Ae){let br=Ae[ut];typeof br=="number"&&(he[ut]=(he[ut]*Ot+br*j)/(Ot+j))}he.count+=j,se>=0&&(he.total+=se,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]={...Ae},u.push(he));if(z){z=z.map(ut=>typeof ut=="number"?{value:ut,count:1}:ut);let Ot=l.get(Pe);Ot?Ot.push(...z):l.set(Pe,z)}}await RH()}for(let E of u){let{path:A,method:N,type:v,metric:F,count:$,total:Y,distribution:ee,threads:oe,...j}=E;oe=oe.filter(se=>se);for(let se in j){if(typeof E[se]!="number")continue;let z=0;for(let me of oe){let Ae=me[se];typeof Ae=="number"&&(z+=Ae)}E[se]=z}E.count=oe.length,delete E.threads,delete E.byThread}for(let[E,A]of l){let N=c.get(E);A.sort((ut,br)=>ut.value>br.value?1:-1);let v=N.count-1,F=[],$=0,Y=0,ee;for(let ut of SH){let br=v*ut;for(;$<br;)ee=A[Y++],$+=ee.count,Y===1&&$--;let ms=A[Y>1?Y-2:0];ee||(ee=A[0]),F.push(ee.value-(ee.value-ms.value)*($-br)/ee.count)}let[oe,j,se,z,me,Ae,Pe,he,Ot]=F;Object.assign(N,{p1:oe,p10:j,p25:se,median:z,p75:me,p90:Ae,p95:Pe,p99:he,p999:Ot})}let d;for(let[E,A]of c)A.id=(0,K_.getNextMonotonicTime)(),A.time=f,n.primaryStore.put(A.id,A,{append:!0}).then(N=>{N||n.primaryStore.put(A.id,A)}),d=!0;let p=Date.now(),{idle:_,active:h}=performance.eventLoopUtilization();if(d||h*10>_){let E=(0,K_.getNextMonotonicTime)(),A={id:E,metric:"main-thread-utilization",idle:_-sH,active:h-iH,taskQueueLatency:await s,time:p,...process.memoryUsage()};n.primaryStore.put(E,A,{append:!0}).then(N=>{N||n.primaryStore.put(E,A)})}sH=_,iH=h;let S=process.resourceUsage(),g=AH($_,S);g.time=p,g.period=$_.time?p-$_.time:t,g.cpuUtilization=TH($_,g.period),ZE(n,"resource-usage",g),$_=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 _O(){return aH||(aH=dt({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function yH(){return cH||(cH=dt({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,Y_.get)(x.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Xre(mH,e),await oH(_O(),Zre),await oH(yH(),ene)},Math.min(e/2,2147483647)).unref()}function OH(e,t){let r=e.report;r.threadId=t?.threadId||ll.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,K_.getNextMonotonicTime)(),_O().primaryStore.put(r.id,r),bH||tne(),rne&&(NH=sne(r))}async function sne(e){if(await NH,!Pa){let r=(0,V_.dirname)((0,fH.getLogFilePath)());try{Pa=await(0,fO.open)((0,V_.join)(r,"analytics.log"),"r+")}catch{Pa=await(0,fO.open)((0,V_.join)(r,"analytics.log"),"w+")}}let t=(await Pa.stat()).size;if(t>nne){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 ll,dH,fH,_H,V_,fO,K_,Y_,pH,ul,XE,hH,QE,mH,EH,gH,SH,sH,iH,$_,RH,Zre,ene,aH,cH,bH,lH,uH,rne,NH,Pa,nne,Fi=be(()=>{ll=require("worker_threads"),dH=M(rt());De();fH=M(W()),_H=M(wi()),V_=require("path"),fO=require("fs/promises"),K_=M(pn()),Y_=M(ce());H();Kr();pH=M(require("node:fs")),ul=(0,_H.loggerWithTag)("analytics");(0,Y_.initSync)();XE=new Map,hH=(0,Y_.get)(x.ANALYTICS_AGGREGATEPERIOD)>-1;a(Wre,"setAnalyticsEnabled");a(zre,"recordExistingAction");a(jre,"recordNewAction");a(sr,"recordAction");We.recordAnalytics=sr;a(Xn,"recordActionBinary");QE=0,mH=1e3,EH="analytics-report",gH=[];a(W_,"addAnalyticsListener");SH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Jre,"sendAnalytics");a(ZE,"storeMetric");a(TH,"calculateCPUUtilization");a(AH,"diffResourceUsage");a(Qre,"storeTableSizeMetrics");a(rH,"storeDBSizeMetrics");a(nH,"storeVolumeMetrics");a(Xre,"aggregation");sH=0,iH=0,$_={},RH=a(()=>new Promise(setImmediate),"rest");a(oH,"cleanup");Zre=36e5,ene=31536e6;a(_O,"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={};Ue(wH,{Headers:()=>bo,appendHeader:()=>eg,mergeHeaders:()=>pO});function eg(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 pO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new bo(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 bo,j_=be(()=>{bo=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(eg,"appendHeader");a(pO,"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:A,name:N,elements:v,relationship:F,definition:$}of o){if(F)A==="array"?u[N]={type:"array",items:{$ref:Da+v.type}}:u[N]={$ref:Da+A};else{let Y=$??v?.definition;if(Y){if(!t.components.schemas[Y.type]){let ee={};Y.properties.forEach(oe=>{ee[oe.name]=new gO(hO[oe.type],oe.type)}),t.components.schemas[Y.type]=new PH(ee)}A==="array"?u[N]={type:"array",items:{$ref:Da+Y.type}}:u[N]={$ref:Da+Y.type}}else A==="array"?v.type==="Any"||v.type=="ID"?u[N]={type:"array",items:{format:v.type}}:u[N]={type:"array",items:new gO(hO[v.type],v.type)}:A==="Any"||A=="ID"?u[N]={format:A}:u[N]=new gO(hO[A],A)}f.push(new SO(N,"query",u[N]))}let d=Object.keys(u),p=new SO(c,"path",{format:"ID"});p.required=!0,p.description="primary key of record";let _=new SO("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 mO(f,r,{200:new EO({$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 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 mO([p],r,{200:new EO({$ref:Da+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 mO([p,_],r,{200:new EO({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:Da+e}}}},this.security=t,this.responses={200:{description:TO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function mO(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function EO(e){this.description=TO,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:Da+r}}}},this.responses={200:{description:TO}}}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 gO(e,t){this.type=e,this.format=t}function SO(e,t,r){this.name=e,this.in=t,this.schema=r}var DH,ine,hO,Da,TO,MH=be(()=>{DH=M(st()),ine="3.0.3",hO={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Da="#/components/schemas/",TO="successful operation";a(LH,"generateJsonApi");a(one,"Post");a(mO,"Get");a(EO,"Response200");a(IH,"Response204");a(ane,"Put");a(CH,"Delete");a(PH,"ResourceSchema");a(gO,"Type");a(SO,"Parameter")});var rg={};Ue(rg,{parseHeaderValue:()=>RO,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&&Nm(e);let i=new bo;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==vH){let g=tg.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Pc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=RO(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=RO(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=fo(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Wu.ClientError(g,400)}if(e.authorize=!0,o===vH&&s==="GET"){if(e?.user?.role?.permission?.super_user)return LH(tg);throw new Wu.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 Wu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Wu.ServerError(`Method ${s} is not recognized`,501)}}),p=200,_;if(d==null)p=s==="GET"||s==="HEAD"?404:204,AO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=pO(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){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),AO.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?Gi.warn(o):Gi.info(o):Gi.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 une(e){AO=e,!UH&&(UH=!0,tg=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 Hn;xH||(xH=!0,W_(l=>{J_>0&&l.push({metric:"ws-connections",connections:J_,byThread:!0})}));let i;t.on("error",l=>{i=!0,Gi.warn(l)});let o;t.on("message",a(function(u){o||(o=fo(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_--,Xn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=tg.getMatch(l,"ws");if(Xn(!!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 Pc(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),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?Gi.warn(l):Gi.info(l):Gi.error(l),t.close(dne[l.statusCode]||1011,l.toString())}t.close()},e))}function RO(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 Gi,Wu,Mr,cne,AO,vH,UH,tg,xH,J_,dne,BH=be(()=>{co();Fi();Gi=M(W()),Wu=M(pe());qf();hu();Cc();j_();MH();qf();Mr=new Uint8Array(8),cne=new Float64Array(Mr.buffer,0,1),AO={},vH="openapi";a(lne,"http");J_=0;a(une,"start");dne={401:3e3,403:3003};a(RO,"parseHeaderValue")});var yO=I((FCe,kH)=>{var{recordAction:ng,recordActionBinary:HH}=(Fi(),P(z_)),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),ng(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",()=>{ng(performance.now()-c,"transfer",u,d,f),ng(p,"bytes-sent",u,d,f)})):(p+=i?.length||0,ng(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=I((GCe,FH)=>{var pne=it(),hne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};FH.exports=function(e){return pne.validateObject(e,hne)}});var sg=I((qCe,qH)=>{"use strict";var mne=(H(),P(G)).OPERATIONS_ENUM,bO=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=bO});var Z_={};Ue(Z_,{createTokens:()=>gne,getJWTRSAKeys:()=>lg,refreshOperationToken:()=>Sne,validateOperationToken:()=>wO,validateRefreshToken:()=>ug});async function lg(){if(ig)return ig;try{let e=Q_.default.join(X_.default.getHdbBasePath(),jA),t=await og.default.readFile(Q_.default.join(e,Nf.JWT_PASSPHRASE_NAME),"utf8"),r=await og.default.readFile(Q_.default.join(e,Nf.JWT_PRIVATE_KEY_NAME),"utf8");return ig={publicKey:await og.default.readFile(Q_.default.join(e,Nf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},ig}catch(e){throw cg.default.error(e),new oi.ClientError(ju.NO_ENCRYPTION_KEYS,zu.INTERNAL_SERVER_ERROR)}}async function gne(e){let t=(0,OO.validateBySchema)(e,qi.default.object({username:qi.default.string().optional(),password:qi.default.string().optional(),role:qi.default.string().optional(),expires_in:qi.default.alternatives(qi.default.string(),qi.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,NO.findAndValidateUser)(e.username,e.password,d)}catch(d){throw cg.default.error(d),new oi.ClientError(ju.INVALID_CREDENTIALS,zu.UNAUTHORIZED)}if(!r)throw new oi.ClientError(ju.INVALID_CREDENTIALS,zu.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 lg(),c=await Ju.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??WH,algorithm:ag,subject:"operation"}),l=await Ju.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:Ene,algorithm:ag,subject:"refresh"}),u=Gy(l,"sha256");if((await(0,$H.update)(new VH.default(Of,_u.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new oi.ClientError(ju.REFRESH_TOKEN_SAVE_FAILED,zu.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,OO.validateBySchema)(e,qi.default.object({refresh_token:qi.default.string().required()}).required());if(t)throw new oi.ClientError(t.message);let{refresh_token:r}=e;await ug(r);let n=await lg(),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:ag,subject:"operation"})}}async function wO(e){return zH(e,"operation")}async function ug(e){return zH(e,"refresh")}async function zH(e,t){try{let r=await lg(),n=await Ju.default.verify(e,r.publicKey,{algorithms:ag,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,NO.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!qy(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw cg.default.warn(r),r?.name==="TokenExpiredError"?new oi.ClientError(ju.TOKEN_EXPIRED,zu.FORBIDDEN):new oi.ClientError(ju.INVALID_TOKEN,zu.UNAUTHORIZED)}}var Ju,og,Q_,qi,OO,oi,cg,NO,$H,VH,KH,YH,X_,zu,ju,WH,Ene,ag,ig,Qu=be(()=>{Ju=M(require("jsonwebtoken")),og=M(require("fs-extra")),Q_=M(require("node:path")),qi=M(require("joi")),OO=M(it());H();oi=M(pe()),cg=M(W());mE();NO=M(yn()),$H=M(bn()),VH=M(sg()),KH=M(Ao()),YH=M(ni()),X_=M(ce()),{HTTP_STATUS_CODES:zu,AUTHENTICATION_ERROR_MSGS:ju}=oi.hdb_errors;X_.default.initSync();WH=X_.default.get(x.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Ene=X_.default.get(x.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",ag="RS256";a(lg,"getJWTRSAKeys");a(gne,"createTokens");a(Sne,"refreshOperationToken");a(wO,"validateOperationToken");a(ug,"validateRefreshToken");a(zH,"validateToken")});var IO=I((WCe,QH)=>{"use strict";var Tne=GH(),Xu=require("passport"),Ane=require("passport-local").Strategy,Rne=require("passport-http").BasicStrategy,yne=require("util"),bne=yn(),JH=yne.callbackify(bne.findAndValidateUser),YCe=Bn(),One=(H(),P(G)),jH=(Qu(),P(Z_));Xu.use(new Ane(function(e,t,r){JH(e,t,r)}));Xu.use(new Rne(function(e,t,r){JH(e,t,r)}));Xu.serializeUser(function(e,t){t(null,e)});Xu.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":Xu.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:Xu.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 dg=I((jCe,XH)=>{"use strict";var Ine=Kn();XH.exports={writeTransaction:Cne};function Cne(e,t,r){return Ine.writeTransaction(e,t,r)}a(Cne,"writeTransaction")});var rk=I((XCe,tk)=>{"use strict";var Pne=Wr(),Dne=Rs(),ZH=W(),Lne=bn(),QCe=dg(),Mne=require("clone"),PO=require("alasql"),vne=cE(),ek=require("util"),Une=ek.promisify(Dne.getTableSchema),xne=ek.promisify(Pne.search),Bne=(H(),P(G)),CO=ae();vne(PO);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);CO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=Mne(s),c=CO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=PO.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]=PO.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 CO.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=I((rPe,nk)=>{var $ne=require("alasql"),Vne=Wr(),Kne=W(),Yne=Kn(),LO=require("util"),DO=ae(),Wne=(H(),P(G)),zne=Rs(),ePe=dg(),tPe=bn(),jne="record",Jne="successfully deleted",Qne=LO.callbackify(tse),Xne=LO.promisify(Vne.search),Zne=LO.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);DO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=DO.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 DO.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=I((sPe,ck)=>{"use strict";var rse=So(),{hdb_errors:ik}=pe(),{getDatabases:ok}=(De(),P(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 BO=I((lPe,Ak)=>{"use strict";var{decode:sse}=require("msgpackr"),{isMainThread:oPe,parentPort:aPe,threadId:cPe}=require("worker_threads"),pg=ir(),Zu=St(),UO=(H(),P(G)),Qr=W(),vO=ce(),ise=(H(),P(G)),{onMessageByType:ose}=rt(),_k=go(),{recordAction:uk,recordActionBinary:ase}=(Fi(),P(z_)),{publishToStream:cse}=pg,{ConsumerEvents:dk}=require("nats"),lse=Wr(),{promisify:use}=require("util"),{decodeBlobsWithWrites:dse}=(Ss(),P(qm)),pk=use(setTimeout),hg=1e4,mg,_g,fse,_se,hk,ep=new Map,ed=new Map;Ak.exports={initialize:mk,ingestConsumer:xO,setSubscription:pse,setIgnoreOrigin:Ese,getDatabaseSubscriptions:mse,updateConsumer:Ek};async function mk(){ose(UO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await Ek(n)}),hk=!0,Qr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await pg.getNATSReferences();mg=e,_g=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);xO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=ep.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?.(),ep.set(e.stream_name+e.node_domain_name,"close")),ed.get(e.node_domain_name)==="failed"&&ed.set(e.node_domain_name,"close")}}a(Ek,"updateConsumer");var Eg=new Map;function pse(e,t,r){let n=Eg.get(e);n||Eg.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+Zu.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);xO(l,n,s,r)}}}a(hse,"accessConsumers");async function gk(e){let t,r,n=1;for(;!r;)try{t=await mg.jetstream({domain:e}),r=await mg.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(ed.get(e)==="close")break;ed.set(e,"failed"),n%10===1&&Qr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<hg?n++*100:hg;await pk(i)}return{js:t,jsm:r}}a(gk,"connectToRemoteJS");function mse(){return Eg}a(mse,"getDatabaseSubscriptions");var Sk;function Ese(e){Sk=e}a(Ese,"setIgnoreOrigin");var Tk=100,fk=new Array(Tk),fg=0;async function xO(e,t,r,n){let{connection:s}=await pg.getNATSReferences();mg=s,_g=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,_g),Qr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(ed.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 pg.createConsumer(r,e,_g,new Date(Date.now()).toISOString()));let f=o++*100<hg?o++*100:hg;await pk(f)}let c=!1,l;for(;!c;){if(ep.get(e+n)==="close"||ed.get(n)==="close"){ep.delete(e+n),c=!0;continue}l=await i.consume({max_messages:vO.get(UO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),ep.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;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 fk[fg],fk[fg]=gse(f).catch(d=>{Qr.error(d)}),++fg>=Tk&&(fg=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(xO,"ingestConsumer");async function gse(e){let t;await dse(()=>{t=sse(e.data)}),uk(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=vO.get(UO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Zu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Zu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Zu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!Sk),ase(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Zu.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(Zu.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=Eg.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:MO(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:h,user:R,nodeName:E});else{let v=f.map((F,$)=>({type:MO(o),value:F,expiresAt:_,id:d?.[$],table:u}));for(;l;)v.push({type:MO(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})}vO.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 N=Date.now()-g;g&&uk(N,"replication-latency",e.subject,o,"ingest")}catch(o){Qr.error(o)}e.ack()}a(gse,"messageProcessor");function MO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(MO,"convertOperation")});var ir=I((mPe,Hk)=>{"use strict";var wr=ce();wr.initSync();var Sse=require("fs-extra"),Tse=require("semver"),np=require("path"),{monotonicFactory:Ase}=require("ulidx"),yk=Ase(),Rse=require("util"),bk=require("child_process"),yse=Rse.promisify(bk.exec),bse=bk.spawn,vr=St(),Ve=(H(),P(G)),{packageJson:Ose,PACKAGE_ROOT:Nse}=st(),gg=ae(),ai=W(),Sg=go(),wse=dg(),tp=Rt(),{broadcast:Ise,onMessageByType:Cse,getWorkerIndex:Pse}=rt(),{isMainThread:Ok}=require("worker_threads"),{Encoder:Dse,decode:GO}=require("msgpackr"),Nk=new Dse,{isEmpty:pl}=gg,wk=yn(),dPe=48*36e11;Ok&&Cse(Ve.ITC_EVENT_TYPES.RESTART,()=>{Xr=void 0,_l=void 0});var{connect:Lse,StorageType:Mse,RetentionPolicy:vse,AckPolicy:qO,DeliverPolicy:$O,DiscardPolicy:Use,NatsConnection:fPe,JetStreamManager:_Pe,JetStreamClient:pPe,StringCodec:hPe,JSONCodec:xse,createInbox:VO,headers:Bse,ErrorCode:Rk}=require("nats"),{recordAction:Hse}=(Fi(),P(z_)),{encodeBlobsAsBuffers:kse}=(Ss(),P(qm)),Ik=xse(),Fse="clustering",Gse=Ose.engines[vr.NATS_SERVER_NAME],qse=np.join(Nse,"dependencies"),FO=np.join(qse,`${process.platform}-${process.arch}`,vr.NATS_BINARY_NAME),HO,kO,rp,dl,fl;Hk.exports={runCommand:Ck,checkNATSServerInstalled:$se,createConnection:KO,getConnection:sp,getJetStreamManager:ip,getJetStream:Dk,getNATSReferences:$i,getServerList:Kse,createLocalStream:YO,listStreams:Lk,deleteLocalStream:Yse,getServerConfig:td,listRemoteStreams:Wse,viewStream:zse,viewStreamIterator:jse,publishToStream:Jse,request:Zse,reloadNATS:WO,reloadNATSHub:eie,reloadNATSLeaf:tie,extractServerName:Xse,requestErrorHandler:rie,createLocalTableStream:xk,createTableStreams:iie,purgeTableStream:Bk,purgeSchemaTableStreams:oie,getStreamInfo:aie,updateLocalStreams:lie,closeConnection:Vse,getJsmServerName:Tg,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 Vse(){try{await Tse.access(HO)}catch{return!1}let e=await Ik(`${HO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Ase.eq(t,qse)}a(Vse,"checkNATSServerInstalled");async function $O(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}oi.trace("create nats connection called");let i=await Mse({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(),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&&Ck()}),i}a($O,"createConnection");function Ck(){Qr=void 0,ol=void 0,al=void 0,cl=void 0}a(Ck,"clearClientCache");async function Kse(){Qr&&(await Qr.drain(),Qr=void 0,ol=void 0,al=void 0,cl=void 0)}a(Kse,"closeConnection");var Qr,cl;async function np(){return cl||(cl=$O(Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Qr=await cl),Qr||cl}a(np,"getConnection");async function sp(){if(ol)return ol;ll(Qr)&&await np();let{domain:e}=Zu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ol=await Qr.jetstreamManager({domain:e,timeout:6e4}),ol}a(sp,"getJetStreamManager");async function Pk(){if(al)return al;ll(Qr)&&await np();let{domain:e}=Zu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return al=Qr.jetstream({domain:e,timeout:6e4}),al}a(Pk,"getJetStream");async function qi(){let e=Qr||await np(),t=ol||await sp(),r=al||await Pk();return{connection:e,jsm:t,js:r}}a(qi,"getNATSReferences");async function Yse(e){let t=Nr.get($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await Nk.getClusterUser(),s=await $O(t,r,n),i=qO(),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 mg.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Yse,"getServerList");async function VO(e,t){let{jsm:r}=await qi(),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:vse.File,retention:Use.Limits,subjects:t,discard:xse.Old,max_msgs:s,max_bytes:i,max_age:n})}a(VO,"createLocalStream");async function Dk(){let{jsm:e}=await qi(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Dk,"listStreams");async function Wse(e){let{jsm:t}=await qi();await t.streams.delete(e)}a(Wse,"deleteLocalStream");async function zse(e){let{connection:t}=await qi(),r=[],n=qO(),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(zse,"listRemoteStreams");async function jse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await qi(),i=Rk(),o={durable_name:i,ack_policy:FO.Explicit};t&&(o.deliver_policy=GO.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=kO(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(jse,"viewStream");async function*Jse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await qi(),i=Rk(),o={durable_name:i,ack_policy:FO.Explicit};t&&(o.deliver_policy=GO.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=kO(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(Jse,"viewStreamIterator");async function Qse(e,t,r,n){oi.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Lk(n,r);let{js:s}=await qi(),i=await gg(),o=`${e}.${i}`,c=await Fse(()=>n instanceof Uint8Array?n:Ok.encode(n));try{oi.trace(`publishToStream publishing to subject: ${o}`),kse(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"){oi.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await VO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Qse,"publishToStream");function Lk(e,t){t===void 0&&(t=Hse());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 Zu(e){e=e.toLowerCase();let t=rp.join(Nr.get($e.CONFIG_PARAMS.ROOTPATH),Gse);if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return ll(BO)&&(BO={port:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.HUB,config_file:Mr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:rp.join(t,Mr.PID_FILES.HUB),hdb_nats_path:t}),BO;if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return ll(xO)&&(xO={port:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.LEAF,config_file:Mr.NATS_CONFIG_FILES.LEAF_SERVER,domain:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.LEAF,pid_file_path:rp.join(t,Mr.PID_FILES.LEAF),hdb_nats_path:t}),xO;oi.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Zu,"getServerConfig");async function Mk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:FO.Explicit,durable_name:r,deliver_policy:GO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(Mk,"createConsumer");async function Xse(e,t,r){await e.consumers.delete(t,r)}a(Xse,"removeConsumer");function Zse(e){return e.split(".")[1]}a(Zse,"extractServerName");async function eie(e,t,r=6e4,n=qO()){if(!mg.isObject(t))throw new Error("data param must be an object");let s=Ok.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 kO(c.data)}a(eie,"request");function KO(e){return new Promise(async(t,r)=>{let n=Ose(HO,["--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(KO,"reloadNATS");async function tie(){let{pid_file_path:e}=Zu($e.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await KO(e)}a(tie,"reloadNATSHub");async function rie(){let{pid_file_path:e}=Zu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await KO(e)}a(rie,"reloadNATSLeaf");function nie(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(nie,"requestErrorHandler");async function sie(e,t){let r=t+Mr.SERVER_SUFFIX.LEAF,{connection:n}=await qi(),{jsm:s}=await fie(r),{schema:i,table:o}=e,c=Eg.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 Xse(s,c,n.info.server_name)}catch(u){oi.trace(u)}})}a(sie,"updateRemoteConsumer");async function iie(e,t,r,n){let s=Eg.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&&Dse()<Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=UO();await c(o)}await Cse(o),n==="stop"&&await mg.async_set_timeout(1e3)}a(iie,"updateConsumerIterator");function vk(e){return Ise.writeTransaction($e.SYSTEM_SCHEMA_NAME,$e.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(vk,"exclusiveLock");async function Uk(e,t){let r=Eg.createNatsTableStreamName(e,t),n=await gg(),s=lie(e,t,n);await VO(r,[s])}a(Uk,"createLocalTableStream");async function oie(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(oie,"createTableStreams");async function xk(e,t,r=void 0){if(Nr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Eg.createNatsTableStreamName(e,t),{domain:s}=Zu($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(xk,"purgeTableStream");async function aie(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(aie,"purgeSchemaTableStreams");async function cie(e){return(await sp()).streams.info(e)}a(cie,"getStreamInfo");function lie(e,t,r){return`${Mr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(lie,"createSubjectName");async function gg(){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(gg,"getJsmServerName");async function uie(){let e=await sp(),t=await gg(),r=await Dk();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=die(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(uie,"updateLocalStreams");function die(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(die,"updateStreamLimits");async function fie(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(fie,"connectToRemoteJS")});function YO(e){let t=e.get(Sg),r=t?(0,ed.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:op(e)??1,nodes:[]})})}i[n]=0,e.putSync(Sg,(0,ed.pack)(r))}return r}function ip(e){return YO(e).remoteNameToId}function kk(e,t){let r=YO(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(Sg,(0,ed.pack)(r)),s}function Tg(e,t){let r=YO(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(Sg,(0,ed.pack)(r))}return Hk.trace?.("The remote node name map",e,n,s),s}var Hk,ed,Sg,WO=be(()=>{Hk=M(Ni());Xn();ed=require("msgpackr"),Sg=Symbol.for("remote-ids");a(YO,"getIdMappingRecord");a(ip,"exportIdMapping");a(kk,"remoteToLocalNodeId");a(Tg,"getIdOfRemoteNode")});var zO={};ve(zO,{commits_awaiting_replication:()=>rd,getHDBNodeTable:()=>or,getReplicationSharedStatus:()=>Ag,iterateRoutes:()=>cp,shouldReplicateToNode:()=>ap,subscribeToNodeUpdates:()=>nd});function or(){return Fk||(Fk=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 Ag(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function nd(e){or().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 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(Xe())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function _ie(){nd(e=>{Da({},(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=Ag(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of rd.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=td.default.get(B.REPLICATION_SECUREPORT)??(!td.default.get(B.REPLICATION_PORT)&&td.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||td.default.get(B.REPLICATION_PORT)||td.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,td,Vk,Fk,Gk,rd,ul=be(()=>{Pe();Xn();Am();qk=require("worker_threads"),$k=M(pe()),td=M(ae());H();Vk=M(Ni());server.nodes=[];a(or,"getHDBNodeTable");a(Ag,"getReplicationSharedStatus");a(nd,"subscribeToNodeUpdates");a(ap,"shouldReplicateToNode");Gk=new Map;AL((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})`);rd||(rd=new Map,_ie());let n=rd.get(e);return n||(n=[],rd.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(_ie,"startSubscriptionToReplications");a(cp,"iterateRoutes")});var zk={};ve(zk,{connectedToNode:()=>dl,disconnectedFromNode:()=>od,ensureNode:()=>Oo,requestClusterStatus:()=>Wk,startOnMainThread:()=>JO});async function JO(e){let t=0,r=Qe();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){Rg.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=Xe();or().primaryStore.get(u)===void 0&&await Oo(u,{name:u,url:e.url??La(),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)}nd(s)});let n;function s(i,o=i?.name){let c=Xe()&&o===Xe()||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(at.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),at.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){at.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(at.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 sd)if(i.url===p.url){sd.delete(d);break}sd.set(i.name,i)}let u=Qe();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]||(at.warn(`Database ${p} not found for node ${i.name}, making a subscription anyway`),f(p,!1))}function f(d,p){at.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),h,S=[{replicateByDefault:p,...i}];Rg.has(d)&&(S.push({replicateByDefault:p,name:Xe(),start_time:Rg.get(d),end_time:Date.now(),replicates:!0}),Rg.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):id(E)},pie);else{at.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],or().primaryStore.get(Xe())?.replicates),or().primaryStore.get(Xe())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};h?h.postMessage(E):bg(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),od=a(function(i){try{at.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(sd.keys()),c=o.sort(),l=c.indexOf(i.name||ai(i.url));if(l===-1){at.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){at.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=sd.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)){at.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}R.push(T),E=!0}if(!E){at.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,at.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):id({database:i.database,nodes:R});return}at.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){at.error("Error failing over node",o)}},"disconnectedFromNode"),dl=a(function(i){let o=bo.get(i.url),c=o?.get(i.database);if(!c){at.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}):id({database:i.database,nodes:u}))}},"connectedToNode"),(0,$i.onMessageByType)("disconnected-from-node",od),(0,$i.onMessageByType)("connected-to-node",dl),(0,$i.onMessageByType)("request-cluster-status",Wk)}function Wk(e,t){let r=[];for(let[n,s]of sd)try{let i=bo.get(s.url);at.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){at.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 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){at.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(at.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,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])]}at.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var $i,yg,at,jO,Kk,Yk,pie,bo,od,dl,sd,Rg,lp=be(()=>{Pe();$i=M(et());Xn();yg=require("worker_threads");ul();at=M(z()),jO=require("lodash"),Kk=M(ae());H();Yk=require("crypto"),pie=200,bo=new Map,sd=new Map,Rg=new Map;a(JO,"startOnMainThread");a(Wk,"requestClusterStatus");yg.parentPort&&(od=a(e=>{yg.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),dl=a(e=>{yg.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,$i.onMessageByType)("subscribe-to-node",e=>{id(e)}),(0,$i.onMessageByType)("unsubscribe-from-node",e=>{bg(e)}));a(Oo,"ensureNode")});var Zn=w(EF=>{"use strict";var ar=require("path"),On=require("fs-extra"),ad=require("node-forge"),eF=require("net"),{generateKeyPair:XO,X509Certificate:No,createPrivateKey:tF}=require("crypto"),hie=require("util");XO=hie.promisify(XO);var bt=ad.pki,ci=require("joi"),{v4:rF}=require("uuid"),{validateBySchema:rN}=it(),pt=z(),ys=ae(),bs=(H(),C(G)),{CONFIG_PARAMS:cd}=bs,li=$y(),{ClientError:va}=pe(),Og=require("node:tls"),{relative:nF,join:mie}=require("node:path"),{CERT_PREFERENCE_APP:LPe,CERTIFICATE_VALUES:jk}=li,Eie=ua(),ZO=yt(),{table:gie,getDatabases:Sie,databases:QO}=(Pe(),C(tt)),{getJWTRSAKeys:Jk}=(ju(),C(X_));Object.assign(EF,{generateKeys:iN,updateConfigCert:dF,createCsr:wie,signCertificate:Iie,setCertTable:ld,loadCertificates:cF,reviewSelfSignedCert:aN,createTLSSelector:_F,listCertificates:hF,addCertificate:vie,removeCertificate:xie,createNatsCerts:Die,generateCertsKeys:Pie,getReplicationCert:dp,getReplicationCertAuth:Nie,renewSelfSigned:Lie,hostnamesFromCert:mF,getKey:Bie});var{urlToNodeName:sF,getThisNodeUrl:Tie,getThisNodeName:wg,clearThisNodeName:Aie}=(Xn(),C(wo)),{readFileSync:Rie,watchFile:yie,statSync:iF}=require("node:fs"),MPe=ae(),{getTicketKeys:bie,onMessageFromWorkers:Oie}=et(),Ma=z(),{isMainThread:oF}=require("worker_threads"),{TLSSocket:aF,createSecureContext:vPe}=require("node:tls"),nN=3650,up=["127.0.0.1","localhost","::1"],sN=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Oie(async e=>{e.type===bs.ITC_EVENT_TYPES.RESTART&&(ys.initSync(!0),await aN())});var vr;function xa(){return vr||(vr=Sie().system.hdb_certificate,vr||(vr=gie({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(xa,"getCertTable");async function dp(){let e=_F("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(wg());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 Nie(){xa();let e=(await dp()).options.cert,r=new No(e).issuer.match(/CN=(.*)/)?.[1];return vr.get(r)}a(Nie,"getReplicationCertAuth");var Qk,Ua=new Map;function cF(){if(Qk)return;Qk=!0;let e=[{configKey:cd.TLS},{configKey:cd.OPERATIONSAPI_TLS}];xa();let t=ar.dirname(ZO.getConfigFilePath()),r;for(let{configKey:n}of e){let s=ZO.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&nF(mie(t,"keys"),o);c&&Xk(o,l=>{Ua.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 No(_),S;try{S=cN(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=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),yie(e,{persistent:!1},s)}a(Xk,"loadAndWatch");function eN(){let e=Tie();if(e==null){let t=up[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return sF(e)}a(eN,"getHost");function Ng(){let e=wg();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(Ng,"getCommonName");async function wie(){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:Ng()},...sN];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),ad.pki.certificationRequestToPem(n)}a(wie,"createCsr");function lF(){let e=up.includes(Ng())?up:[...up,Ng()];return e.includes(eN())||e.push(eN()),[{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 Iie(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 vr.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 On.exists(ar.join(r,f.private_key_name))){n=On.readFile(ar.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await tN();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=ad.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()+nN),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,ad.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(Iie,"signCertificate");async function Cie(e,t){await ld({name:wg(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await ld({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(Cie,"createCertificateTable");async function ld(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 vr.patch(e)}a(ld,"setCertTable");async function iN(){let e=await XO("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(iN,"generateKeys");async function oN(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()+nN);let i=[{name:"commonName",value:Ng()},...sN];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(lF()),n.sign(e,ad.md.sha256.create()),bt.certificateToPem(n)}a(oN,"generateCertificates");async function tN(){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 No(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(tN,"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()+nN);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ys.get(cd.REPLICATION_HOSTNAME)??sF(ys.get(cd.REPLICATION_URL))??rF().split("-")[0]}`},...sN];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,ad.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 On.writeFile(c,bt.privateKeyToPem(e)),n}a(uF,"generateCertAuthority");async function Pie(){let{private_key:e,public_key:t}=await iN(),r=await uF(e,t),n=await oN(e,t,r);await Cie(n,r),dF()}a(Pie,"generateCertsKeys");async function Die(){let e=await oN(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 On.exists(r)||await On.writeFile(r,e);let n=ar.join(t,li.NATS_CA_PEM_NAME);await On.exists(n)||await On.writeFile(n,li.CERTIFICATE_VALUES.cert)}a(Die,"createNatsCerts");async function Lie(){xa();for await(let e of vr.search([{attribute:"is_self_signed",value:!0}]))await vr.delete(e.name);await aN()}a(Lie,"renewSelfSigned");async function aN(){Aie(),await cF(),xa();let e=await tN();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(cd.TLS_PRIVATEKEY),n=ar.join(ys.getHdbBasePath(),bs.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 iN(),await On.exists(ar.join(n,li.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${rF().split("-")[0]}.pem`),await On.writeFile(ar.join(n,i),bt.privateKeyToPem(s))}let o=await uF(s,bt.setRsaPublicKey(s.n,s.e),!1);await ld({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=wg();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await tN();let n=bt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await oN(bt.privateKeyFromPem(e.private_key),s,n);await ld({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(aN,"reviewSelfSignedCert");function dF(){let e=Eie(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),ZO.updateConfigValue(void 0,void 0,o,!1,!0)}a(dF,"updateConfigCert");function fF(e){return e.startsWith("-----BEGIN")?e:Rie(e,"utf8")}a(fF,"readPEM");var Zk=Og.createSecureContext;Og.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 Mie=aF.prototype._init;aF.prototype._init=function(e,t){Mie.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 No(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 No(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:bie(),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=Og.createSecureContext(R);E.name=d.name,E.options=R,E.quality=_,E.certificateAuthorities=Array.from(fl),E.certStart=S.toString().slice(0,100);let T=d.hostnames??mF(g);Array.isArray(T)||(T=[T]);let b;for(let v of T)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===eN()&&(_+=2),eF.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",Og.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"),QO.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(_F,"createTLSSelector");async function pF(e){let t=Ua.get(e);return!t&&e?await On.readFile(ar.join(ys.get(cd.ROOTPATH),bs.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(pF,"getPrivateKeyByName");async function hF(){xa();let e=[];for await(let t of vr.search([]))e.push(t);return e}a(hF,"listCertificates");async function vie(e){let t=rN(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(tF(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=cN(o)}catch(_){pt.error(_)}if(f==null)throw new va("Error extracting certificate common name, please provide a name parameter")}let d=Uie(r??f);s&&!c&&!l&&(await On.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 ld(p),"Successfully added certificate: "+d}a(vie,"addCertificate");function Uie(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(Uie,"sanitizeName");async function xie(e){let t=rN(e,ci.object({name:ci.string().required()}));if(t)throw new va(t.message);let{name:r}=e;xa();let n=await vr.get(r);if(!n)throw new va(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(ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME,s)))}return await vr.delete(r),"Successfully removed "+r}a(xie,"removeCertificate");function cN(e){return e.subject.match(/CN=(.*)/)?.[1]}a(cN,"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):[cN(e)]}a(mF,"hostnamesFromCert");async function Bie(e){if(e.bypass_auth!==!0)throw new va("Unauthorized","401");let t=rN(e,ci.object({name:ci.string().required()}));if(t)throw new va(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await Jk()).privateKey;if(r===".jwtPublic")return(await Jk()).publicKey;if(Ua.get(r))return Ua.get(e.name);throw new va("Key not found")}a(Bie,"getKey")});var xF={};ve(xF,{CONFIRMATION_STATUS_POSITION:()=>UF,NodeReplicationConnection:()=>fp,OPERATION_REQUEST:()=>_N,RECEIVED_TIME_POSITION:()=>hN,RECEIVED_VERSION_POSITION:()=>pN,SENDING_TIME_POSITION:()=>Lg,createWebSocket:()=>vg,database_subscriptions:()=>Ha,replicateOverWS:()=>_p,table_update_listeners:()=>EN});async function vg(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Xe(),i;if(e.includes("wss://")){if(!uN){let l=(0,LF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),uN=u.secureContexts}if(i=uN.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 _p(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||Ha,d,p,_=!1,h=t.subscription;h?.then&&h.then(m=>h=m);let S=t.tables||u&&Qe()[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,he=0,Re=new Map,Ce=[],me=0,Zt;if(t.url){let m=a(()=>{q&&J===e._socket?.bytesRead&&he===e._socket?.bytesWritten?e.terminate():(q=performance.now(),e.ping(),J=e._socket?.bytesRead,he=e._socket?.bytesWritten)},"send_ping");v=setInterval(m,wF).unref(),m()}else ut();e._socket?.setMaxListeners(200);function ut(){clearTimeout(F),J=e._socket?.bytesRead,he=e._socket?.bytesWritten,F=setTimeout(()=>{J===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(ut,"resetPingTimer");function yr(){return p||(p=Ag(d,u,E)),p}a(yr,"getSharedStatus"),u&&ia(u);let hs,vn,nu=[],su=[],BA,HA=[],Mt=[],Ef=[],jh=150,Jh=25,gf=0,Qh=0,De=!1,Sf,ln,Ir,iu;e.on("message",m=>{ne=performance.now();try{let A=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)([ud])),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)=>{au(ue)&&oa(ue)}),e.on("close",()=>{hs?.remove()}))}catch(U){le.warn?.(s,"Error setting database",U),e.send((0,ze.encode)([ud])),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=dN(U,qe[ue]?.[U.table])):ce=dN(U,qe[ue]?.[U.table]),d||(d=ce?.auditStore),S||(S=Qe()?.[ue]))}break}case ud:un();break;case _N: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)([Cg,ue]))},ue=>{e.send((0,ze.encode)([Cg,{requestId:L.requestId,error:ue instanceof Error?ue.toString():ue}]))})}catch(U){e.send((0,ze.encode)([Cg,{requestId:L.requestId,error:U instanceof Error?U.toString():U}]))}break;case Cg:let{resolve:D,reject:x}=g.get(L.requestId);L.error?x(new Error(L.error)):D(L),g.delete(L.requestId);break;case lN:let $=P[3];S||(u?le.error?.(s,"No tables found for",u):le.error?.(s,"Database name never received"));let j=S[$];j=dN({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,BA=P[2],le.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${BA}`);break;case AF:let oe=k;Ef[oe]=L;break;case bF:yr()[UF]=L,le.trace?.(s,"received and broadcasting committed update",L),yr().buffer.notify();break;case yF:T=L,h.send({type:"end_txn",localTime:T,remoteNodeIds:R});break;case Pg:{let U=P[1],{fileId:ue,size:ce,finished:fe,error:te}=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 fN.PassThrough,W.expectedSize=ce,Re.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&&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 te=fe.primaryStore.getBinaryFast(Symbol.for("structures")),W=te.length;if(W!==Qh){Qh=W;let Ae=(0,ze.decode)(te);e.send((0,ze.encode)([lN,{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)([Ig,U,{value:Ae.value,expiresAt:Ae.expiresAt,version:Ae.version,residencyId:Ae.residencyId,nodeId:Ae.nodeId,user:Ae.user}])}else ue=(0,ze.encode)([Ig,U])}catch(ce){ue=(0,ze.encode)([Ig,U,{error:ce.message}])}e.send(ue);break}case Ig:{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=nu[ce].decoder.decode(te.value);te.value=W,te.key=fe,U(te)}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(Je=>{le.debug?.("Waiting for subscription to database "+u),Ee=Je}),h.ready=Ee,Ha.set(u,h)}if(r.name)ue=or().subscribe(r.name),ue.then(async Ee=>{U=Ee;for await(let Je of U){let nt=Je.value;if(!(nt?.replicates===!0||nt?.replicates?.receives||nt?.subscriptions?.some($t=>($t.database||$t.schema)===u&&$t.publish!==!1))){ce=!0,e.send((0,ze.encode)([ud])),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)([ud])),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],te=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,dt,rt=a((Ee,Je)=>{if(Ee.type==="end_txn"){W.txnTime&&(o[i]!==66&&le.error?.("Invalid encoding of message"),cu(9),cu(Mg),uu(dt=Je),Gr()),i=c,W.txnTime=0;return}let nt=Ee.nodeId,$t=Ee.tableId,Vt=Ae[$t];if(!Vt&&(Vt=Ae[$t]=te(h.tableById[$t]),!Vt))return le.debug?.("Not subscribed to table",$t);let qr=Vt.table,Sc=qr.primaryStore,vt=Sc.encoder;(Ee.extendedType&zm||!vt.typedStructs)&&(vt._mergeStructures(vt.getStructures()),vt.typedStructs&&(vt.lastTypedStructuresLength=vt.typedStructs.length));let Zh=_e[nt];if(!(Zh&&Zh.startTime<Je&&(!Zh.endTime||Zh.endTime>Je)))return Dg&&le.trace?.(s,"skipping replication update",Ee.recordId,"to:",E,"from:",nt,"subscribed:",_e),iD();Dg&&le.trace?.(s,"sending replication update",Ee.recordId,"to:",E,"from:",nt,"subscribed:",_e);let kA=Ee.version;W.txnTime!==kA&&(W.txnTime&&(Dg&&le.trace?.(s,"new txn time, sending queued txn",W.txnTime),o[i]!==66&&le.error?.("Invalid encoding of message"),Gr()),W.txnTime=kA,i=c,uu(kA));let Tc=Ee.residencyId,FA=ou(Tc,qr),em;if(FA&&!FA.includes(E)){let Ac=ou(Ee.previousResidencyId,qr);if(Ac&&!Ac.includes(E)&&(Ee.type==="put"||Ee.type==="patch")||qr.getResidencyById)return iD();let Rf=Ee.recordId;le.trace?.(s,"sending invalidation",Rf,E,"from",nt);let ca=0;Tc&&(ca|=Uc),Ee.previousResidencyId&&(ca|=xc);let Ks,dn=null;for(let tm in qr.indices){if(!dn){if(Ks=Ee.getValue(Sc,!0),!Ks)break;dn={}}dn[tm]=Ks[tm]}em=Ou(Ee.version,$t,Rf,null,nt,Ee.user,Ee.type==="put"||Ee.type==="patch"?"invalidate":Ee.type,vt.encode(dn),ca,Tc,Ee.previousResidencyId,Ee.expiresAt)}function iD(){le.trace?.(s,"skipping audit record",Ee.recordId),Y||(Y=setTimeout(()=>{Y=null,(dt||0)+NF/2<ye&&(Dg&&le.trace?.(s,"sending skipped sequence update",ye),e.send((0,ze.encode)([yF,ye])))},NF).unref())}a(iD,"skipAuditRecord");let GA=vt.typedStructs,qA=vt.structures;if((GA?.length!=Vt.typed_length||qA?.length!=Vt.structure_length)&&(Vt.typed_length=GA?.length,Vt.structure_length=qA.length,le.debug?.(s,"send table struct",Vt.typed_length,Vt.structure_length),Vt.sentName||(Vt.sentName=!0),e.send((0,ze.encode)([lN,{typedStructs:GA,structures:qA,attributes:qr.attributes,schemaDefined:qr.schemaDefined},$t,Vt.table.tableName]))),Tc&&!Mt[Tc]&&(e.send((0,ze.encode)([AF,FA,Tc])),Mt[Tc]=!0),em)cu(em.length),lu(em);else{let Ac=Ee.encoded;Ee.extendedType&Fn&&CR(()=>Ee.getValue(Sc),async ca=>{let Ks=Bm(ca);try{let dn;me++;for await(let tm of ca.stream()){if(dn&&(le.debug?.("Sending blob chunk",Ks,"length",dn.length),e.send((0,ze.encode)([Pg,{fileId:Ks,size:ca.size},dn]))),dn=tm,ce)return;e._socket.writableNeedDrain&&(le.debug?.("draining",Ks),await new Promise(S2=>e._socket.once("drain",S2)),le.debug?.("drained",Ks))}le.debug?.("Sending final blob chunk",Ks,"length",dn.length),e.send((0,ze.encode)([Pg,{fileId:Ks,size:ca.size,finished:!0},dn]))}catch(dn){le.debug?.("Error sending blob",dn),e.send((0,ze.encode)([Pg,{fileId:Ks,finished:!0,error:dn.toString()},Buffer.alloc(0)]))}finally{me--,me<Jh&&Zt?.()}});let Rf=Ac[0]===66?8:0;cu(Ac.length-Rf),lu(Ac,Rf),le.trace?.("wrote record",Ee.recordId,"length:",Ac.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 mN.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(te),_e=[];for(let{name:Je,startTime:nt,endTime:$t}of Ir){let Vt=Tg(Je,d);le.debug?.("subscription to",Je,"using local id",Vt,"starting",nt),_e[Vt]={startTime:nt,endTime:$t}}oa(u),hs||(hs=ml(Je=>{Je.databaseName===u&&oa(u)}),vn=pp(Je=>{Je===u&&(e.send((0,ze.encode)([ud])),un())}),e.on("close",()=>{hs?.remove(),vn?.remove()})),e.send((0,ze.encode)([TF,ip(h.auditStore),Ir.map(({name:Je})=>Je)]));let Ee=!0;do{isFinite(ye)||(le.warn?.("Invalid sequence id "+ye),un(1008,"Invalid sequence id"+ye));let Je;if(Ee&&!ce&&(Ee=!1,!(SN(d)<=ye)&&(CF.default.get(B.REPLICATION_COPYTABLESTOCATCHUP)??Hie)&&server.nodes[0]?.name===E)){le.info?.("Replicating all tables to",E);let $t=ye,Vt=Ug(d);for(let qr in S){if(!te(qr))continue;let Sc=S[qr];for(let vt of Sc.primaryStore.getRange({snapshot:!1})){if(ce)return;vt.localTime>=ye&&(le.trace?.(s,"Copying record from",u,qr,vt.key,vt.localTime),$t=Math.max(vt.localTime,$t),Je=!0,yr()[Lg]=1,rt({recordId:vt.key,tableId:Sc.tableId,type:"put",getValue(){return vt.value},encoded:Sc.primaryStore.getBinary(vt.key),version:vt.version,residencyId:vt.residencyId,nodeId:Vt,extendedType:vt.metadataFlags},vt.localTime))}}ye=$t}for(let{key:nt,value:$t}of d.getRange({start:ye||1,exclusiveStart:!0,snapshot:!1})){if(ce)return;let Vt=wt($t);le.debug?.("sending audit record",new Date(nt)),yr()[Lg]=nt,ye=nt,rt(Vt,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>Jh?await new Promise(qr=>{Zt=qr}):await new Promise(setImmediate),ln.startTime=nt,Je=!0}Je&&rt({type:"end_txn"},ye),yr()[Lg]=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}A.position=8;let I=!0,y,O;do{yr();let P=A.readInt();if(P===9&&A.getUint8(A.position)==Mg){A.position++,T=O=A.readFloat64(),p[pN]=T,p[hN]=Date.now(),le.trace?.("received remote sequence update",T,u);break}let N=A.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=Ef[L.residencyId],le.trace?.(s,"received residency list",D,L.type,L.recordId));try{IR(()=>{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 fN.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[pN]=L.version,p[hN]=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&&!De&&(De=!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--,De&&(De=!1,e.resume(),le.debug?.(`Replication resuming ${E}`)),Ce.length>0&&await Promise.all(Ce),le.trace?.("All blobs finished"),!b&&O&&(le.trace?.(s,"queuing confirmation of a commit at",O),setTimeout(()=>{e.send((0,ze.encode)([bF,b])),le.trace?.(s,"sent confirmation of a commit at",b),b=null},kie)),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",ut),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-q,dl({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 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 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 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&&Tg(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 x=d&&Tg(A.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",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,ze.encode)([gF,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(Fr,"sendSubscriptionRequestUpdate");function ou(m,A){if(!m)return;let I=HA[m];return I||(I=A.getResidencyRecord(m),HA[m]=I),I}a(ou,"getResidence");function au(m){return!(Ba&&Ba!="*"&&!Ba[m]&&!Ba.includes?.(m)&&!Ba.some?.(A=>A.name===m))}a(au,"checkDatabaseAccess");function ia(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=Qe()?.[m]);let A=Xe();if(A===E)throw A?new Error("Should not connect to self",A):new Error("Node name not defined");return Xh(A,m),!0}a(ia,"setDatabase");function Xh(m,A){let I=Qe()?.[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,ze.encode)([SF,m,A,y]))}a(Xh,"sendNodeDBName");function oa(m){let A=Qe()?.[m],I=[];for(let y in A){if(Ir&&!Ir.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,ze.encode)([OF,I,m]))}a(oa,"sendDBSchema"),Z=setInterval(()=>{for(let[m,A]of Re)A.lastChunk+3e4<Date.now()&&(le.warn?.(`Timeout waiting for blob stream to finish ${m} from ${E}`),Re.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=[RF,A,m.table.tableId,m.id];Af[m.table.tableId]||(O.push(m.table.tableName),Af[m.table.tableId]=!0),e.send((0,ze.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,ze.encode)([_N,m])),new Promise((I,y)=>{g.set(A,{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,A=0,I=m.length){let y=I-A;K(y),m.copy(o,c,A,I),c+=y}function uu(m){K(8),l.setFloat64(c,m),c+=8}function K(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 dN(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 CF,ze,PF,DF,le,mN,LF,MF,_l,vF,fN,gF,SF,TF,ud,AF,lN,RF,Ig,_N,Cg,yF,bF,OF,Pg,UF,pN,hN,Lg,Hie,EN,Ha,Dg,NF,kie,wF,uN,IF,fp,gN=be(()=>{Pe();fo();WO();TN();Xn();CF=M(ae());H();Nu();ze=require("msgpackr"),PF=require("ws"),DF=require("worker_threads"),le=M(Ni());lp();mN=require("events"),LF=M(Zn()),MF=M(require("node:tls"));ul();_l=M(require("node:process")),vF=require("node:net");ki();gs();fN=require("node:stream"),gF=129,SF=140,TF=141,ud=142,AF=130,lN=132,RF=133,Ig=134,_N=136,Cg=137,yF=143,bF=144,OF=145,Pg=146,UF=0,pN=1,hN=2,Lg=3,Hie=_l.env.HDB_LEADER_URL||_l.argv.includes("--HDB_LEADER_URL"),EN=new Map,Ha=new Map,Dg=!0,NF=300,kie=2,wF=3e4;a(vg,"createWebSocket");IF=1e3,fp=class extends mN.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=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 vg(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=_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&&(od({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(dN,"ensureTableIfChanged")});var wo={};ve(wo,{clearThisNodeName:()=>Wie,disableReplication:()=>$ie,enabled_databases:()=>Ba,forEachReplicatedDatabase:()=>Da,getThisNodeId:()=>Ug,getThisNodeName:()=>Xe,getThisNodeUrl:()=>La,hostnameToUrl:()=>kg,lastTimeInAuditStore:()=>op,monitorNodeCAs:()=>KF,replicateOperation:()=>jie,replication_certificate_authorities:()=>pl,sendOperationToNode:()=>mp,servers:()=>Gie,setReplicator:()=>WF,start:()=>qie,startOnMainThread:()=>JO,subscribeToNode:()=>id,unsubscribeFromNode:()=>bg,urlToNodeName:()=>ai});function qie(e){if(e.port||(e.port=Os.default.get(B.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=Os.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 cp(e))t.set(ai(n.url),n);Vie(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(),_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,Ye.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(pl);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.updatedContext=Hg.createSecureContext(l)}catch(c){cr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),KF(s),Os.default.get(B.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function KF(e){let t=0;nd(r=>{r?.ca&&(pl.add(r.ca),pl.size!==t&&(t=pl.size,e?.()))})}function $ie(e=!0){VF=e}function Vie(e){VF||(Qe(),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];WF(r,s,e),EN.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||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 xn,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 _=Kie(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:Fie++,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",Bg,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function zF(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 Kie(e,t,r){let n=HF.get(e)?.get(r);if(n)return n;let s=or().primaryStore.get(e);return s?.url&&(n=zF(s.url,t,r,e,s.authorization),HF.set(e,hp.get(s.url))),n}async function mp(e,t,r){r||(r={}),r.serverName=e.name;let n=await vg(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 id(e){try{$F.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=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=>ap(n,e.database)),e.replicateByDefault)}catch(t){cr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function bg({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 Yie(){if(AN!==void 0)return AN;let e=Os.default.get(B.OPERATIONSAPI_TLS_CERTIFICATE)||Os.default.get(B.TLS_CERTIFICATE);if(e)return AN=new FF.X509Certificate((0,GF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Xe(){return Bg||(Bg=Os.default.get("replication_hostname")??ai(Os.default.get("replication_url"))??Yie()??kF("operationsapi_network_secureport")??kF("operationsapi_network_port")??"127.0.0.1")}function Wie(){Bg=void 0}function kF(e){let t=Os.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function xg(e){let t=Os.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Ug(e){return ip(e)?.[Xe()]}function La(){let e=Os.default.get("replication_url");return e||kg(Xe())}function kg(e){let t=xg("replication_port");if(t)return`ws://${e}:${t}`;if(t=xg("replication_secureport"),t)return`wss://${e}:${t}`;if(t=xg("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=xg("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)}),ml((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):zie(n)&&t(s,n,!1)}a(r,"forDatabase")}function zie(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 jie(e){let t={message:""};if(e.replicated){e.replicated=!1,cr.trace?.("Replicating operation",e.operation,"to nodes",Ye.nodes.map(n=>n.name));let r=await Promise.allSettled(Ye.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=Ye.nodes[s]?.name,i})}return t}var Os,cr,FF,GF,Hg,qF,$F,VF,Fie,Gie,pl,Ba,hp,HF,AN,Bg,Xn=be(()=>{Pe();Ea();_u();gN();Vr();Os=M(ae()),cr=M(z()),FF=require("crypto"),GF=require("fs");lp();ul();H();WO();Hg=M(require("node:tls")),qF=M(pe()),$F=require("worker_threads"),Fie=1,Gie=[],pl=Os.default.get(B.REPLICATION_ENABLEROOTCAS)!==!1?new Set(Hg.rootCertificates):new Set;a(qie,"start");a(KF,"monitorNodeCAs");a($ie,"disableReplication");a(Vie,"assignReplicationSource");a(WF,"setReplicator");hp=new Map;a(zF,"getConnection");HF=new Map;a(Kie,"getConnectionByName");a(mp,"sendOperationToNode");a(id,"subscribeToNode");a(bg,"unsubscribeFromNode");a(Yie,"getCommonNameFromCert");a(Xe,"getThisNodeName");a(Wie,"clearThisNodeName");Object.defineProperty(Ye,"hostname",{get(){return Xe()}});a(kF,"getHostFromListeningPort");a(xg,"getPortFromListeningPort");a(Ug,"getThisNodeId");Ye.replication={getThisNodeId:Ug,exportIdMapping:ip};a(La,"getThisNodeUrl");a(kg,"hostnameToUrl");a(ai,"urlToNodeName");a(Da,"forEachReplicatedDatabase");a(zie,"hasExplicitlyReplicatedTable");a(op,"lastTimeInAuditStore");a(jie,"replicateOperation")});var Vg=w((oDe,ZF)=>{"use strict";var dd=ck(),{validateBySchema:Ep}=it(),{common_validators:fd,schema_regex:RN}=Di(),lr=require("joi"),Jie=z(),Qie=require("uuid").v4,qg=To(),_d=(H(),C(G)),Xie=require("util"),ka=Vn(),{handleHDBError:Io,hdb_errors:Zie,ClientError:gp}=pe(),{HDB_ERROR_MSGS:Fg,HTTP_STATUS_CODES:Co}=Zie,{SchemaEventMsg:$g}=ri(),jF=ir(),{getDatabases:eoe}=(Pe(),C(tt)),{transformReq:pd}=ie(),{replicateOperation:JF}=(Xn(),C(wo)),Gg=lr.string().min(1).max(fd.schema_length.maximum).pattern(RN).messages({"string.pattern.base":"{:#label} "+fd.schema_format.message}),toe=lr.string().min(1).max(fd.schema_length.maximum).pattern(RN).messages({"string.pattern.base":"{:#label} "+fd.schema_format.message}).required(),roe=lr.string().min(1).max(fd.schema_length.maximum).pattern(RN).messages({"string.pattern.base":"{:#label} "+fd.schema_format.message,"any.required":"'primary_key' is required","string.base":"'primary_key' must be a string"}).required();ZF.exports={createSchema:noe,createSchemaStructure:QF,createTable:soe,createTableStructure:XF,createAttribute:loe,dropSchema:ioe,dropTable:ooe,dropAttribute:aoe,getBackup:uoe};async function noe(e){let t=await QF(e);return qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),t}a(noe,"createSchema");async function QF(e){let t=Ep(e,lr.object({database:Gg,schema:Gg}));if(t)throw new gp(t.message);if(pd(e),!await dd.checkSchemaExists(e.schema))throw Io(new Error,Fg.SCHEMA_EXISTS_ERR(e.schema),Co.BAD_REQUEST,_d.LOG_LEVELS.ERROR,Fg.SCHEMA_EXISTS_ERR(e.schema),!0);return await ka.createSchema(e),`database '${e.schema}' successfully created`}a(QF,"createSchemaStructure");async function soe(e){return pd(e),e.hash_attribute=e.primary_key??e.hash_attribute,await XF(e)}a(soe,"createTable");async function XF(e){let t=Ep(e,lr.object({database:Gg,schema:Gg,table:toe,residence:lr.array().items(lr.string().min(1)).optional(),hash_attribute:roe}));if(t)throw new gp(t.message);if(!await dd.checkSchemaTableExists(e.schema,e.table))throw Io(new Error,Fg.TABLE_EXISTS_ERR(e.schema,e.table),Co.BAD_REQUEST,_d.LOG_LEVELS.ERROR,Fg.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Qie(),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(XF,"createTableStructure");async function ioe(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);pd(e);let r=await dd.checkSchemaExists(e.schema);if(r)throw Io(new Error,r,Co.NOT_FOUND,_d.LOG_LEVELS.ERROR,r,!0);let n=await dd.schema_describe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await ka.dropSchema(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),await jF.purgeSchemaTableStreams(e.schema,s);let i=await JF(e);return i.message=`successfully deleted '${e.schema}'`,i}a(ioe,"dropSchema");async function ooe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required()}));if(t)throw new gp(t.message);pd(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw Io(new Error,r,Co.NOT_FOUND,_d.LOG_LEVELS.ERROR,r,!0);await ka.dropTable(e),await jF.purgeTableStream(e.schema,e.table);let n=await JF(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(ooe,"dropTable");async function aoe(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);pd(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw Io(new Error,r,Co.NOT_FOUND,_d.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(_d.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),coe(e),qg.signalSchemaChange(new $g(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 ${Xie.inspect(e)}.`),n}}a(aoe,"dropAttribute");function coe(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(coe,"dropAttributeFromGlobal");async function loe(e){pd(e);let t=eoe()[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),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(loe,"createAttribute");function uoe(e){return ka.getBackup(e)}a(uoe,"getBackup")});var tG=w((cDe,eG)=>{"use strict";var{OPERATIONS_ENUM:doe}=(H(),C(G)),yN=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=doe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};eG.exports=yN});var bN=w((dDe,oG)=>{"use strict";var foe=Vn(),uDe=tG(),Kg=ie(),Yg=(H(),C(G)),_oe=ae(),{handleHDBError:rG,hdb_errors:poe}=pe(),{HDB_ERROR_MSGS:nG,HTTP_STATUS_CODES:sG}=poe,hoe=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=moe;async function moe(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(!_oe.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)&&hoe.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await foe.readAuditLog(e)}a(moe,"readAuditLog")});var cG=w((_De,aG)=>{"use strict";var{OPERATIONS_ENUM:Eoe}=(H(),C(G)),ON=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Eoe.GET_BACKUP,this.schema=t,this.table=r}};aG.exports=ON});var dG=w((EDe,uG)=>{"use strict";var goe=Vn(),hDe=cG(),NN=ie(),Soe=(H(),C(G)),mDe=ae(),{handleHDBError:Toe,hdb_errors:Aoe}=pe(),{HDB_ERROR_MSGS:lG,HTTP_STATUS_CODES:Roe}=Aoe;uG.exports=yoe;async function yoe(e){if(NN.isEmpty(e.schema))throw new Error(lG.SCHEMA_REQUIRED_ERR);if(NN.isEmpty(e.table))throw new Error(lG.TABLE_REQUIRED_ERR);let t=NN.checkSchemaTableExist(e.schema,e.table);if(t)throw Toe(new Error,t,Roe.NOT_FOUND,Soe.LOG_LEVELS.ERROR,t,!0);return await goe.getBackup(read_audit_log_object)}a(yoe,"getBackup")});var hG=w((SDe,pG)=>{"use strict";var boe=ae(),Fa=require("joi"),Ooe=it(),fG=require("moment"),Noe=require("fs-extra"),wN=require("path"),woe=require("lodash"),Sp=(H(),C(G)),{LOG_LEVELS:El}=(H(),C(G)),Ioe="YYYY-MM-DD hh:mm:ss",Coe=wN.resolve(__dirname,"../logs");pG.exports=function(e){return Ooe.validateBySchema(e,Poe)};var Poe=Fa.object({from:Fa.custom(_G),until:Fa.custom(_G),level:Fa.valid(El.NOTIFY,El.FATAL,El.ERROR,El.WARN,El.INFO,El.DEBUG,El.TRACE),order:Fa.valid("asc","desc"),limit:Fa.number().min(1),start:Fa.number().min(0),log_name:Fa.custom(Doe)});function _G(e,t){if(fG(e,fG.ISO_8601).format(Ioe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(_G,"validateDatetime");function Doe(e,t){if(woe.invert(Sp.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=boe.get(Sp.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Sp.LOG_NAMES.HDB:e,i=s===Sp.LOG_NAMES.INSTALL?wN.join(Coe,Sp.LOG_NAMES.INSTALL):wN.join(n,s);return Noe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Doe,"validateReadLogPath")});var CN=w((ADe,EG)=>{"use strict";var Wg=(H(),C(G)),Loe=z(),Moe=ae(),voe=hG(),IN=require("path"),mG=require("fs-extra"),{once:Uoe}=require("events"),{handleHDBError:xoe,hdb_errors:Boe}=pe(),{PACKAGE_ROOT:Hoe}=st(),koe=IN.join(Hoe,"logs"),Foe=1e3,Goe=200;EG.exports=qoe;async function qoe(e){let t=voe(e);if(t)throw xoe(t,t.message,Boe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Moe.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?IN.join(koe,Wg.LOG_NAMES.INSTALL):IN.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?Foe: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)*Goe,0));let g=mG.createReadStream(s,{start:S});g.on("error",F=>{Loe.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("] ["),he=J[0],Re=J[1];J.splice(0,2),b={timestamp:Q,thread:he,level:Re,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 Uoe(g,"close"),E}a(qoe,"readLog");function Ga(e,t,r){t==="desc"?$oe(e,r):t==="asc"?Voe(e,r):r.push(e)}a(Ga,"pushLineToResult");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,"insertDescending");function Voe(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(Voe,"insertAscending")});var zg=w((wDe,AG)=>{"use strict";var PN=require("joi"),{string:hd,boolean:gG,date:Koe}=PN.types(),Yoe=it(),{validateSchemaExists:yDe,validateTableExists:bDe,validateSchemaName:ODe}=Di(),Woe=(H(),C(G)),zoe=Tt(),SG=ae();SG.initSync();var NDe=hd.invalid(SG.get(Woe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(zoe.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:hd.valid("add_node","update_node","set_node_replication"),node_name:hd.optional(),subscriptions:PN.array().items({table:hd.optional(),schema:hd.optional(),database:hd.optional(),subscribe:gG.required(),publish:gG.required().custom(Joe),start_time:Koe.iso()})};function joe(e){return Yoe.validateBySchema(e,PN.object(TG))}a(joe,"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");AG.exports={addUpdateNodeValidator:joe,validation_schema:TG}});var md=w((CDe,RG)=>{"use strict";var DN=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},LN=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:DN,NodeSubscription:LN}});var bG=w((DDe,yG)=>{"use strict";var Qoe=(H(),C(G)).OPERATIONS_ENUM,MN=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Qoe.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};yG.exports=MN});var Tp=w((MDe,OG)=>{"use strict";var vN=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},UN=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:vN,RemotePayloadSubscription:UN}});var wG=w((UDe,NG)=>{"use strict";var xN=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=xN});var CG=w((GDe,IG)=>{"use strict";var Xoe=wG(),BDe=Ut(),HDe=_t(),Zoe=z(),{getSchemaPath:kDe,getTransactionAuditStorePath:FDe}=gt(),{getDatabases:eae}=(Pe(),C(tt));IG.exports=tae;async function tae(e){let t=new Xoe;try{let r=eae()[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){Zoe.warn(`unable to stat table dbi due to ${r}`)}return t}a(tae,"lmdbGetTableSize")});var DG=w(($De,PG)=>{"use strict";var BN=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=BN});var Po=w((jDe,UG)=>{"use strict";var rae=require("fs-extra"),nae=require("path"),Xr=require("systeminformation"),qa=z(),LG=ir(),KDe=Tt(),Ed=(H(),C(G)),sae=CG(),iae=go(),{getThreadInfo:MG}=et(),Ap=ae();Ap.initSync();var oae=DG(),{openEnvironment:YDe}=_t(),{getSchemaPath:WDe}=gt(),{database:zDe,databases:HN}=(Pe(),C(tt)),jg;UG.exports={getHDBProcessInfo:qN,getNetworkInfo:VN,getDiskInfo:$N,getMemoryInfo:GN,getCPUInfo:FN,getTimeInfo:kN,getSystemInformation:KN,systemInformation:aae,getTableSize:YN,getMetrics:WN};function kN(){return Xr.time()}a(kN,"getTimeInfo");async function FN(){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(FN,"getCPUInfo");async function GN(){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(GN,"getMemoryInfo");async function qN(){let e={core:[],clustering:[]};try{let t=await Xr.processes(),r;try{r=Number.parseInt(await rae.readFile(nae.join(Ap.get(Ed.CONFIG_PARAMS.ROOTPATH),Ed.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Ed.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(qN,"getHDBProcessInfo");async function $N(){let e={};try{if(!Ap.get(Ed.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($N,"getDiskInfo");async function VN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Ap.get(Ed.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(VN,"getNetworkInfo");async function KN(){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(KN,"getSystemInformation");async function YN(){let e=[],t=await iae.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await sae(n));return e}a(YN,"getTableSize");async function WN(){let e={};for(let t in HN){let r=e[t]={},n=r.tables={};for(let s in HN[t])try{let i=HN[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(WN,"getMetrics");async function vG(){if(Ap.get(Ed.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 aae(e){let t=new oae;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await KN(),t.time=kN(),t.cpu=await FN(),t.memory=await GN(),t.disk=await $N(),t.network=await VN(),t.harperdb_processes=await qN(),t.table_size=await YN(),t.metrics=await WN(),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 KN();break;case"time":t.time=kN();break;case"cpu":t.cpu=await FN();break;case"memory":t.memory=await GN();break;case"disk":t.disk=await $N();break;case"network":t.network=await VN();break;case"harperdb_processes":t.harperdb_processes=await qN();break;case"table_size":t.table_size=await YN();break;case"database_metrics":case"metrics":t.metrics=await WN();break;case"threads":t.threads=await MG();break;case"replication":t.replication=await vG();break;default:break}return t}a(aae,"systemInformation")});var Do=w((ZDe,kG)=>{"use strict";var cae=Rn(),zN=ie(),lae=require("util"),gl=(H(),C(G)),xG=ae();xG.initSync();var uae=NO(),BG=Yr(),{Node:QDe,NodeSubscription:XDe}=md(),dae=ku(),fae=bG(),{RemotePayloadObject:_ae,RemotePayloadSubscription:pae}=Tp(),{handleHDBError:hae,hdb_errors:mae}=pe(),{HTTP_STATUS_CODES:Eae,HDB_ERROR_MSGS:gae}=mae,Sae=ni(),Tae=Po(),{packageJson:Aae}=st(),{getDatabases:Rae}=(Pe(),C(tt)),yae=lae.promisify(uae.authorize),bae=BG.searchByHash,Oae=BG.searchByValue;kG.exports={authHeaderToUser:Nae,isEmpty:wae,getNodeRecord:Iae,upsertNodeRecord:Cae,buildNodePayloads:Pae,checkClusteringEnabled:Dae,getAllNodeRecords:Lae,getSystemInfo:Mae,reverseSubscription:HG};async function Nae(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await yae(t,null),e}a(Nae,"authHeaderToUser");function wae(e){return e==null}a(wae,"isEmpty");async function Iae(e){let t=new dae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return bae(t)}a(Iae,"getNodeRecord");async function Cae(e){let t=new fae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return cae.upsert(t)}a(Cae,"upsertNodeRecord");function HG(e){if(zN.isEmpty(e.subscribe)||zN.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 Pae(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=zN.getTableHashAttribute(l,u),{subscribe:d,publish:p}=HG(c),_=Rae()[l]?.[u],h=new pae(l,u,f,p,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(h)}return new _ae(r,t,s,n)}a(Pae,"buildNodePayloads");function Dae(){if(!xG.get(gl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw hae(new Error,gae.CLUSTERING_NOT_ENABLED,Eae.BAD_REQUEST,void 0,void 0,!0)}a(Dae,"checkClusteringEnabled");async function Lae(){let e=new Sae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Oae(e))}a(Lae,"getAllNodeRecords");async function Mae(){let e=await Tae.getSystemInformation();return{hdb_version:Aae.version,node_version:e.node_version,platform:e.platform}}a(Mae,"getSystemInfo")});var jN=w((tLe,WG)=>{"use strict";var Jg=ir(),FG=ie(),GG=Tt(),qG=(H(),C(G)),Qg=z(),$G=Vg(),vae=v_(),{RemotePayloadObject:Uae}=Tp(),{handleHDBError:VG,hdb_errors:xae}=pe(),{HTTP_STATUS_CODES:KG}=xae,{NodeSubscription:YG}=md();WG.exports=Bae;async function Bae(e,t){let r;try{r=await Jg.request(`${t}.${GG.REQUEST_SUFFIX}`,new Uae(qG.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Qg.trace("Response from remote describe all request:",r)}catch(o){Qg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Jg.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 Jg.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&&(Qg.trace(`addNode creating schema: ${l}`),await $G.createSchema({operation:"create_schema",schema:l})),!d&&p){Qg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new vae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await $G.createTable(h)}await Jg.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(Bae,"reviewSubscriptions")});var Sl={};ve(Sl,{addNodeBack:()=>qae,removeNodeBack:()=>$ae,setNode:()=>Gae});async function Gae(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=kg(r);let n=(0,jG.validateBySchema)(e,Fae);if(n)throw(0,Lo.handleHDBError)(n,n.message,kae.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:Kt.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Xe():_},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:Kt.ADD_NODE_BACK,hostname:(0,JG.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 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:Hae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Ns.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 Oo(Xe(),_)}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 qae(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);let s=await(0,Ns.getReplicationCertAuth)();if(n.replicates){let i={url:La(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Oo(Xe(),i)}return await Oo(e.hostname,n),t.nodeName=Xe(),t.usingCA=s?.certificate,es.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function $ae(e){es.trace("removeNodeBack received request:",e),await or().delete(e.name)}function zG(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Ns,jG,$a,JG,es,Lo,Hae,kae,Fae,Tl=be(()=>{Ns=M(Zn()),jG=M(it()),$a=M(require("joi")),JG=M(ae());H();lp();ul();Xn();es=M(z()),Lo=M(pe()),{pki:Hae}=require("node-forge"),{HTTP_STATUS_CODES:kae}=Lo.hdb_errors,Fae=$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(Gae,"setNode");a(qae,"addNodeBack");a($ae,"removeNodeBack");a(zG,"reverseSubscription")});var gd=w((uLe,XG)=>{"use strict";var{handleHDBError:Xg,hdb_errors:Vae}=pe(),{HTTP_STATUS_CODES:Zg}=Vae,{addUpdateNodeValidator:Kae}=zg(),eS=z(),tS=(H(),C(G)),QG=Tt(),Yae=ie(),Rp=ir(),yp=Do(),JN=ae(),Wae=jN(),{Node:zae,NodeSubscription:jae}=md(),{broadcast:Jae}=et(),{setNode:Qae}=(Tl(),C(Sl)),cLe=ae(),lLe=(H(),C(G)),Xae="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Zae="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",ece=JN.get(tS.CONFIG_PARAMS.CLUSTERING_NODENAME);XG.exports=tce;async function tce(e,t=!1){if(eS.trace("addNode called with:",e),JN.get(tS.CONFIG_PARAMS.REPLICATION_URL)||JN.get(tS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Qae(e);yp.checkClusteringEnabled();let r=Kae(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(!Yae.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 Wae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Xae,o;let c=yp.buildNodePayloads(s,ece,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}.${QG.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===QG.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 zae(n,l,u.system_info);return await yp.upsertNodeRecord(f),Jae({type:"nats_update"}),i.length>0?o.message=Zae:o.message=`Successfully added '${n}' to manifest`,o}a(tce,"addNode")});var ew=w((_Le,eq)=>{"use strict";var{handleHDBError:QN,hdb_errors:rce}=pe(),{HTTP_STATUS_CODES:XN}=rce,{addUpdateNodeValidator:nce}=zg(),bp=z(),rS=(H(),C(G)),ZG=Tt(),fLe=ie(),Op=ir(),Np=Do(),ZN=ae(),{cloneDeep:sce}=require("lodash"),ice=jN(),{Node:oce,NodeSubscription:ace}=md(),{broadcast:cce}=et(),{setNode:lce}=(Tl(),C(Sl)),uce="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",dce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",fce=ZN.get(rS.CONFIG_PARAMS.CLUSTERING_NODENAME);eq.exports=_ce;async function _ce(e){if(bp.trace("updateNode called with:",e),ZN.get(rS.CONFIG_PARAMS.REPLICATION_URL)??ZN.get(rS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return lce(e);Np.checkClusteringEnabled();let t=nce(e);if(t)throw QN(t,t.message,XN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Np.getNodeRecord(r);s.length>0&&(n=sce(s));let{added:i,skipped:o}=await ice(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=uce,c;let l=Np.buildNodePayloads(i,fce,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 QN(new Error,d,XN.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 QN(new Error,f,XN.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 oce(r,[],u.system_info)]),await pce(n[0],i,u.system_info),o.length>0?c.message=dce:c.message=`Successfully updated '${r}'`,c}a(_ce,"updateNode");async function pce(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 ace(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Np.upsertNodeRecord(n),cce({type:"nats_update"})}a(pce,"updateNodeTable")});var iq=w((hLe,sq)=>{"use strict";var nq=require("joi"),{string:tq}=nq.types(),hce=it(),rq=(H(),C(G)),mce=ae(),Ece=Tt();sq.exports=gce;function gce(e){let t=tq.invalid(mce.get(rq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Ece.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 hce.validateBySchema(e,r)}a(gce,"removeNodeValidator")});var nS=w((ELe,uq)=>{"use strict";var{handleHDBError:oq,hdb_errors:Sce}=pe(),{HTTP_STATUS_CODES:aq}=Sce,Tce=iq(),wp=z(),cq=Do(),Ace=ie(),Sd=(H(),C(G)),lq=Tt(),tw=ir(),rw=ae(),{RemotePayloadObject:Rce}=Tp(),{NodeSubscription:yce}=md(),bce=M_(),Oce=Vc(),{broadcast:Nce}=et(),{setNode:wce}=(Tl(),C(Sl)),Ice=rw.get(Sd.CONFIG_PARAMS.CLUSTERING_NODENAME);uq.exports=Cce;async function Cce(e){if(wp.trace("removeNode called with:",e),rw.get(Sd.CONFIG_PARAMS.REPLICATION_URL)??rw.get(Sd.CONFIG_PARAMS.REPLICATION_HOSTNAME))return wce(e);cq.checkClusteringEnabled();let t=Tce(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(Ace.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 Rce(Sd.OPERATIONS_ENUM.REMOVE_NODE,Ice,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await tw.updateConsumerIterator(f.schema,f.table,r,"stop");try{await tw.updateRemoteConsumer(new yce(f.schema,f.table,!1,!1),r)}catch(d){wp.error(d)}}try{i=await tw.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 bce(Sd.SYSTEM_SCHEMA_NAME,Sd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Oce.deleteRecord(c),Nce({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(Cce,"removeNode")});var _q=w((SLe,fq)=>{"use strict";var dq=require("joi"),{string:Pce,array:Dce}=dq.types(),Lce=it(),Mce=zg();fq.exports=vce;function vce(e){let t=dq.object({operation:Pce.valid("configure_cluster").required(),connections:Dce.items(Mce.validation_schema).required()});return Lce.validateBySchema(e,t)}a(vce,"configureClusterValidator")});var nw=w((ALe,gq)=>{"use strict";var pq=(H(),C(G)),sS=z(),Uce=ie(),xce=ae(),Bce=nS(),Hce=gd(),kce=Do(),Fce=_q(),{handleHDBError:hq,hdb_errors:Gce}=pe(),{HTTP_STATUS_CODES:mq}=Gce,qce="Configure cluster complete.",$ce="Failed to configure the cluster. Check the logs for more details.",Vce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";gq.exports=Kce;async function Kce(e){sS.trace("configure cluster called with:",e);let t=Fce(e);if(t)throw hq(t,t.message,mq.BAD_REQUEST,void 0,void 0,!0);let r=await kce.getAllNodeRecords(),n=[];if(xce.get(pq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let p=await Eq(Bce,{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(Hce,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(Uce.isEmptyOrZeroLength(o))return{message:qce,connections:c};if(l)return{message:Vce,failed_nodes:o,connections:c};throw hq(new Error,$ce,mq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Kce,"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((yLe,Aq)=>{"use strict";var Ip=require("joi"),Yce=it(),{validateSchemaExists:Sq,validateTableExists:Wce,validateSchemaName:Tq}=Di(),zce=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(Wce).required()});function jce(e){return Yce.validateBySchema(e,zce)}a(jce,"purgeStreamValidator");Aq.exports=jce});var sw=w((OLe,yq)=>{"use strict";var{handleHDBError:Jce,hdb_errors:Qce}=pe(),{HTTP_STATUS_CODES:Xce}=Qce,Zce=Rq(),ele=ir(),tle=Do();yq.exports=rle;async function rle(e){e.schema=e.schema??e.database;let t=Zce(e);if(t)throw Jce(t,t.message,Xce.BAD_REQUEST,void 0,void 0,!0);tle.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await ele.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(rle,"purgeStream")});var aS=w((wLe,Pq)=>{"use strict";var ow=Do(),nle=ir(),oS=ae(),Td=(H(),C(G)),Al=Tt(),sle=ie(),iw=z(),{RemotePayloadObject:ile}=Tp(),{ErrorCode:bq}=require("nats"),{parentPort:Oq}=require("worker_threads"),{onMessageByType:ole}=et(),{getThisNodeName:ale}=(Xn(),C(wo)),{requestClusterStatus:cle}=(lp(),C(zk)),{getReplicationSharedStatus:lle}=(ul(),C(zO)),{CONFIRMATION_STATUS_POSITION:ule,RECEIVED_VERSION_POSITION:dle,RECEIVED_TIME_POSITION:fle,SENDING_TIME_POSITION:_le}=(gN(),C(xF)),Nq=oS.get(Td.CONFIG_PARAMS.CLUSTERING_ENABLED),wq=oS.get(Td.CONFIG_PARAMS.CLUSTERING_NODENAME);Pq.exports={clusterStatus:ple,buildNodeStatus:Cq};var Iq;ole("cluster-status",async e=>{Iq(e)});async function ple(){if(oS.get(Td.CONFIG_PARAMS.REPLICATION_URL)||oS.get(Td.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=lle(l,c,i);o.lastCommitConfirmed=iS(u[ule]),o.lastReceivedRemoteTime=iS(u[dle]),o.lastReceivedLocalTime=iS(u[fle]),o.sendingMessage=iS(u[_le])}}}else n=cle();return n.node_name=ale(),n.is_enabled=!0,n}let e={node_name:wq,is_enabled:Nq,connections:[]};if(!Nq)return e;let t=await ow.getAllNodeRecords();if(sle.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 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 ile(Td.OPERATIONS_ENUM.CLUSTER_STATUS,wq,void 0,await ow.getSystemInfo()),s,i,o=Al.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await nle.request(Al.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Al.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Al.CLUSTER_STATUS_STATUSES.CLOSED,iw.error(`Error getting node status from ${r} `,s))}catch(l){iw.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 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!==Td.PRE_4_0_0_VERSION&&await ow.upsertNodeRecord(l)}catch(l){iw.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 lS=w((CLe,Dq)=>{"use strict";var{handleHDBError:mle,hdb_errors:Ele}=pe(),{HTTP_STATUS_CODES:gle}=Ele,Sle=ir(),Tle=Do(),aw=ie(),cS=require("joi"),Ale=it(),Rle=2e3,yle=cS.object({timeout:cS.number().min(1),connected_nodes:cS.boolean(),routes:cS.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||aw.autoCastBoolean(n),o=s===void 0||aw.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:aw.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(ble,"clusterNetwork")});var Uq=w((DLe,vq)=>{"use strict";var cw=require("joi"),Lq=it(),{route_constraints:Mq}=Ky();vq.exports={setRoutesValidator:Ole,deleteRoutesValidator:Nle};function Ole(e){let t=cw.object({server:cw.valid("hub","leaf"),routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Ole,"setRoutesValidator");function Nle(e){let t=cw.object({routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Nle,"deleteRoutesValidator")});var uS=w((MLe,qq)=>{"use strict";var Mo=yt(),lw=ie(),ws=(H(),C(G)),Ad=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=lw.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(Ad.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ile(e);let r=[],n=[],s=Ad.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(Ad.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=Mo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Ad.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(Ad.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED))return Lle(e);let r=[],n=[],s=Ad.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=lw.isEmptyOrZeroLength(r)?null:r,Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=lw.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((ULe,$q)=>{"use strict";var Cp=require("alasql"),Rl=require("recursive-iterator"),ui=z(),Mle=ie(),Pp=(H(),C(G)),uw=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 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{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 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{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 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{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 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{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 Rl(e.columns),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&dw(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 Rl(e.where),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&dw(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 Rl(e.columns),s=e.into.databaseid;Dp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&dw(e.into.tableid,s,i.columnid,t,r)}a(Fle,"getInsertAttributes");function dw(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(dw,"pushAttribute");$q.exports=uw});var Yq=w((BLe,Kq)=>{"use strict";var dS=(H(),C(G)),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}},fw=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:fw}});var bd=w((kLe,Xq)=>{"use strict";var yd=require("fs-extra"),_S=(pE(),C(_E)),zq=require("crypto"),Gle=require("moment"),qle=require("uuid").v4,Zr=z(),pw=require("path"),$le=ie(),yl=(H(),C(G)),{totalmem:Wq}=require("os"),Vle=Yq().ExtendedLicense,Rd="invalid license key format",Kle="061183",Yle="mofi25",Wle="aes-256-cbc",zle=16,jle=32,jq=ae(),{resolvePath:Jq}=yt();jq.initSync();var _w;Xq.exports={validateLicense:Qq,generateFingerPrint:Qle,licenseSearch:Ew,getLicense:eue,checkMemoryLimit:tue};function hw(){return pw.join(jq.getHdbBasePath(),yl.LICENSE_KEY_DIR_NAME,yl.LICENSE_FILE_NAME)}a(hw,"getLicenseDirPath");function Jle(){let e=hw();return Jq(pw.join(e,yl.LICENSE_FILE_NAME))}a(Jle,"getLicenseFilePath");function mw(){let e=hw();return Jq(pw.join(e,yl.REG_KEY_FILE_NAME))}a(mw,"getFingerPrintFilePath");async function Qle(){let e=mw();try{return await yd.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=_S.hash(e,_S.HASH_FUNCTION.MD5),r=mw();try{await yd.mkdirp(hw()),await yd.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: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=mw(),s=!1;try{s=yd.statSync(n)}catch(i){Zr.error(i)}if(s){let i;try{i=yd.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(Rd),Zr.error(Rd),new Error(Rd)}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(Rd),Zr.error(Rd),new Error(Rd)}else r.exp_date=f;r.exp_date<Gle().valueOf()&&(r.valid_date=!1),_S.validate(o[1],`${Kle}${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(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 Ew(){let e=new Vle,t=[];try{t=yd.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=yl.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return _w=e,e}a(Ew,"licenseSearch");async function eue(){return _w||await Ew(),_w}a(eue,"getLicense");function tue(){let e=Ew().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 hS=w((GLe,r$)=>{var pS=bd(),Zq=require("chalk"),ts=z(),e$=require("prompt"),{promisify:rue}=require("util"),gw=(H(),C(G)),nue=require("fs-extra"),sue=require("path"),iue=ie(),{packageJson:oue}=st(),t$=ae();t$.initSync();var aue=require("moment"),cue=rue(e$.get),lue=sue.join(t$.getHdbBasePath(),gw.LICENSE_KEY_DIR_NAME,gw.LICENSE_FILE_NAME,gw.LICENSE_FILE_NAME);r$.exports={getFingerprint:due,setLicense:uue,parseLicense:Sw,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 Sw(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 pS.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 Sw(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ts.info("Validating license input...");let r=pS.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(Sw,"parseLicense");async function fue(){let e=await _ue();return Sw(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(fue,"register");async function _ue(){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){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 pS.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(($Le,n$)=>{"use strict";var hue=Tt(),Tw=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=Tw});var a$=w((KLe,o$)=>{"use strict";var i$=Tt(),Aw=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=Aw});var l$=w((WLe,c$)=>{"use strict";var Rw=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};c$.exports=Rw});var d$=w((jLe,u$)=>{"use strict";var mue=Tt(),yw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+mue.SERVER_SUFFIX.ADMIN,this.password=r}};u$.exports=yw});var SS=w((QLe,p$)=>{"use strict";var bl=require("path"),Ol=require("fs-extra"),Eue=s$(),gue=a$(),Sue=l$(),Tue=d$(),bw=An(),Nd=ie(),Nn=yt(),ES=(H(),C(G)),Lp=Tt(),{CONFIG_PARAMS:jt}=ES,wd=z(),Mp=ae(),f$=Eo(),Ow=ir(),Aue=Zn(),Od="clustering",Rue=1e4,_$=50;p$.exports={generateNatsConfig:bue,removeNatsConfig:Oue,getHubConfigPath:yue};function yue(){let e=Mp.get(jt.ROOTPATH);return bl.join(e,Od,Lp.NATS_CONFIG_FILES.HUB_SERVER)}a(yue,"getHubConfigPath");async function bue(e=!1,t=void 0){let r=Mp.get(jt.ROOTPATH);Ol.ensureDirSync(bl.join(r,"clustering","leaf")),Mp.initSync();let n=Nn.getConfigFromFile(jt.CLUSTERING_TLS_CERT_AUTH),s=Nn.getConfigFromFile(jt.CLUSTERING_TLS_PRIVATEKEY),i=Nn.getConfigFromFile(jt.CLUSTERING_TLS_CERTIFICATE);!await Ol.exists(i)&&!await Ol.exists(!n)&&await Aue.createNatsCerts();let o=bl.join(r,Od,Lp.PID_FILES.HUB),c=bl.join(r,Od,Lp.PID_FILES.LEAF),l=Nn.getConfigFromFile(jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=bl.join(r,Od,Lp.NATS_CONFIG_FILES.HUB_SERVER),f=bl.join(r,Od,Lp.NATS_CONFIG_FILES.LEAF_SERVER),d=Nn.getConfigFromFile(jt.CLUSTERING_TLS_INSECURE),p=Nn.getConfigFromFile(jt.CLUSTERING_TLS_VERIFY),_=Nn.getConfigFromFile(jt.CLUSTERING_NODENAME),h=Nn.getConfigFromFile(jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Ow.checkNATSServerInstalled()||gS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await bw.listUsers(),g=Nn.getConfigFromFile(jt.CLUSTERING_USER),R=await bw.getClusterUser();(Nd.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(jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await mS(jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await mS(jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await mS(jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],T=[];for(let[se,Q]of S.entries())Q.role?.role===ES.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}=Nn.getClusteringRoutes();if(!Nd.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(Nn.getConfigFromFile(jt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,p,h,Nn.getConfigFromFile(jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Nn.getConfigFromFile(jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),b,E,T);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=Nd.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ES.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Ol.writeJson(u,F),wd.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(Nn.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===ES.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Ol.writeJson(f,Z),wd.trace(`Leaf server config written to ${f}`))}a(bue,"generateNatsConfig");async function mS(e){let t=Mp.get(e);return Nd.isEmpty(t)&&gS(`port undefined for '${e}'`),await Nd.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}`;wd.error(t),console.error(t),process.exit(1)}a(gS,"generateNatsConfigError");async function Oue(e){let{port:t,config_file:r}=Ow.getServerConfig(e),{username:n,decrypt_hash:s}=await bw.getClusterUser(),i=0,o=2e3;for(;i<_$;){try{let f=await Ow.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){wd.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&&wd.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Nd.async_set_timeout(u)}let c="0".repeat(Rue),l=bl.join(Mp.get(jt.ROOTPATH),Od,r);await Ol.writeFile(l,c),await Ol.remove(l),wd.notify(e,"started.")}a(Oue,"removeNatsConfig")});var T$=w((ZLe,S$)=>{"use strict";var rs=ae(),Nue=bd(),Fe=(H(),C(G)),vp=Tt(),vo=require("path"),{PACKAGE_ROOT:AS}=st(),h$=ae(),TS=ie(),Id="/dev/null",wue=vo.join(AS,"launchServiceScripts"),m$=vo.join(AS,"utility/scripts"),Iue=vo.join(m$,Fe.HDB_RESTART_SCRIPT),E$=vo.resolve(AS,"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 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 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=Id,i.error_file=Id),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=Id,i.error_file=Id),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=Id,t.error_file=Id),t}a(Mue,"generateClusteringUpgradeV4ServiceConfig");function vue(){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: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 Cd=w((rMe,v$)=>{"use strict";var Ze=(H(),C(G)),xue=ie(),xo=SS(),RS=ir(),Uo=Tt(),Va=T$(),yS=ae(),Nl=z(),Bue=Do(),{startWorker:A$,onMessageFromWorkers:Hue}=et(),kue=Po(),tMe=require("util"),Fue=require("child_process"),Gue=require("fs"),{execFile:que}=Fue,Ve;v$.exports={enterPM2Mode:$ue,start:Ka,stop:Nw,reload:y$,restart:b$,list:ww,describe:w$,connect:Bo,kill:zue,startAllServices:jue,startService:Iw,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"&&yS.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 Ka(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())?Ka(e):(await xo.generateNatsConfig(!0),Ka(e),await new Promise(c=>setTimeout(c,3e3)),await xo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await xo.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&&Uo.LOG_LEVEL_HIERARCHY[o]>=Uo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===Uo.LOG_LEVELS.ERR||f===Uo.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=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?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(Ka,"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 Nw(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(Nw,"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 Ka(Va.generateRestart())}a(N$,"restartHdb");async function Wue(){let e=await ww();for(let t in e)if(e[t].name===Ze.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Wue,"isHdbRestartRunning");function ww(){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(ww,"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 Ka(Va.generateAllServiceConfigs())}catch(e){throw Ve?.disconnect(),e}}a(jue,"startAllServices");async function Iw(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Ze.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Va.generateMainServerConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Va.generateNatsIngestServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Va.generateNatsReplyServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Va.generateNatsHubServerConfig(),await Ka(r,t),await xo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Va.generateNatsLeafServerConfig(),await Ka(r,t),await xo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Va.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Ka(r)}catch(r){throw Ve?.disconnect(),r}}a(Iw,"startService");async function I$(){try{let e=await ww(),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===Ze.PROCESS_DESCRIPTORS.HDB?t=!0:await b$(o))}t&&await P$(Ze.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=yS.get(Ze.CONFIG_PARAMS.THREADS_COUNT)??yS.get(Ze.CONFIG_PARAMS.THREADS),r=await w$(e),n=xue.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await Nw(e),await Iw(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 Iw(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 Bue.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 Que(){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 Nw(t)}}a(Que,"stopClustering");async function Xue(){for(let e in Ze.CLUSTERING_PROCESSES){let t=Ze.CLUSTERING_PROCESSES[e];if(await C$(t)===!1)return!1}return!0}a(Xue,"isClusteringRunning");async function Zue(){await xo.generateNatsConfig(!0),await RS.reloadNATSHub(),await RS.reloadNATSLeaf(),await xo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await xo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Zue,"reloadClustering")});var NS={};ve(NS,{compactOnStart:()=>ede,copyDb:()=>F$});async function ede(){Ya.notify("Running compact on start"),console.log("Running compact on start");let e=(0,Cw.get)(B.ROOTPATH),t=new Map,r=Qe();(0,Pw.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,Rc,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){Ya.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{Pd()}catch(n){Ya.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,Rc,`${n}-copy.mdb-lock`));try{Pd()}catch(n){Ya.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Ya.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,Pw.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 Pd(),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(FO)}catch{return!1}let e=await Ck(`${FO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Tse.eq(t,Gse)}a($se,"checkNATSServerInstalled");async function KO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await wk.getClusterUser();if(pl(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 Lse({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:wr.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:wr.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:wr.get(Ve.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===Xr&&Pk()}),i}a(KO,"createConnection");function Pk(){Xr=void 0,dl=void 0,fl=void 0,_l=void 0}a(Pk,"clearClientCache");async function Vse(){Xr&&(await Xr.drain(),Xr=void 0,dl=void 0,fl=void 0,_l=void 0)}a(Vse,"closeConnection");var Xr,_l;async function sp(){return _l||(_l=KO(wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Xr=await _l),Xr||_l}a(sp,"getConnection");async function ip(){if(dl)return dl;pl(Xr)&&await sp();let{domain:e}=td(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(pl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return dl=await Xr.jetstreamManager({domain:e,timeout:6e4}),dl}a(ip,"getJetStreamManager");async function Dk(){if(fl)return fl;pl(Xr)&&await sp();let{domain:e}=td(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(pl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return fl=Xr.jetstream({domain:e,timeout:6e4}),fl}a(Dk,"getJetStream");async function $i(){let e=Xr||await sp(),t=dl||await ip(),r=fl||await Dk();return{connection:e,jsm:t,js:r}}a($i,"getNATSReferences");async function Kse(e){let t=wr.get(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await wk.getClusterUser(),s=await KO(t,r,n),i=VO(),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 gg.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Kse,"getServerList");async function YO(e,t){let{jsm:r}=await $i(),n=wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=wr.get(Ve.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(YO,"createLocalStream");async function Lk(){let{jsm:e}=await $i(),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 $i();await t.streams.delete(e)}a(Yse,"deleteLocalStream");async function Wse(e){let{connection:t}=await $i(),r=[],n=VO(),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 $i(),i=yk(),o={durable_name:i,ack_policy:qO.Explicit};t&&(o.deliver_policy=$O.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=GO(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 $i(),i=yk(),o={durable_name:i,ack_policy:qO.Explicit};t&&(o.deliver_policy=$O.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=GO(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){ai.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Mk(n,r);let{js:s}=await $i(),i=await Tg(),o=`${e}.${i}`,c=await kse(()=>n instanceof Uint8Array?n:Nk.encode(n));try{ai.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"){ai.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await YO(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(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(vr.MSG_HEADERS.ORIGIN)&&r&&t.append(vr.MSG_HEADERS.ORIGIN,r),t}a(Mk,"addNatsMsgHeader");function td(e){e=e.toLowerCase();let t=np.join(wr.get(Ve.CONFIG_PARAMS.ROOTPATH),Fse);if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return pl(kO)&&(kO={port:tp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:tp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.HUB,config_file:vr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:np.join(t,vr.PID_FILES.HUB),hdb_nats_path:t}),kO;if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return pl(HO)&&(HO={port:tp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:tp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,config_file:vr.NATS_CONFIG_FILES.LEAF_SERVER,domain:tp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,pid_file_path:np.join(t,vr.PID_FILES.LEAF),hdb_nats_path:t}),HO;ai.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(td,"getServerConfig");async function vk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:qO.Explicit,durable_name:r,deliver_policy:$O.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=VO()){if(!gg.isObject(t))throw new Error("data param must be an object");let s=Nk.encode(t),{connection:i}=await $i(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return GO(c.data)}a(Zse,"request");function WO(e){return new Promise(async(t,r)=>{let n=bse(FO,["--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(WO,"reloadNATS");async function eie(){let{pid_file_path:e}=td(Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await WO(e)}a(eie,"reloadNATSHub");async function tie(){let{pid_file_path:e}=td(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await WO(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 $i(),{jsm:s}=await die(r),{schema:i,table:o}=e,c=Sg.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){ai.trace(u)}})}a(nie,"updateRemoteConsumer");async function sie(e,t,r,n){let s=Sg.createNatsTableStreamName(e,t),i=r+vr.SERVER_SUFFIX.LEAF,o={type:Ve.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!Ok&&Pse()<wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=BO();await c(o)}await Ise(o),n==="stop"&&await gg.async_set_timeout(1e3)}a(sie,"updateConsumerIterator");function Uk(e){return wse.writeTransaction(Ve.SYSTEM_SCHEMA_NAME,Ve.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Uk,"exclusiveLock");async function xk(e,t){let r=Sg.createNatsTableStreamName(e,t),n=await Tg(),s=cie(e,t,n);await YO(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(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Sg.createNatsTableStreamName(e,t),{domain:s}=td(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await sp()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")ai.warn(n);else throw n}}a(Bk,"purgeTableStream");async function oie(e,t){if(wr.get(Ve.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 ip()).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 Tg(){if(rp)return rp;if(rp=(await ip())?.nc?.info?.server_name,rp===void 0)throw new Error("Unable to get jetstream manager server name");return rp}a(Tg,"getJsmServerName");async function lie(){let e=await ip(),t=await Tg(),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(".");ai.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(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=wr.get(Ve.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 Xr.jetstream({domain:e}),r=await Xr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw ai.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(die,"connectToRemoteJS")});function zO(e){let t=e.get(Ag),r=t?(0,rd.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:ap(e)??1,nodes:[]})})}i[n]=0,e.putSync(Ag,(0,rd.pack)(r))}return r}function op(e){return zO(e).remoteNameToId}function Fk(e,t){let r=zO(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(Ag,(0,rd.pack)(r)),s}function Rg(e,t){let r=zO(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(Ag,(0,rd.pack)(r))}return kk.trace?.("The remote node name map",e,n,s),s}var kk,rd,Ag,jO=be(()=>{kk=M(wi());Zn();rd=require("msgpackr"),Ag=Symbol.for("remote-ids");a(zO,"getIdMappingRecord");a(op,"exportIdMapping");a(Fk,"remoteToLocalNodeId");a(Rg,"getIdOfRemoteNode")});var JO={};Ue(JO,{commits_awaiting_replication:()=>sd,getHDBNodeTable:()=>or,getReplicationSharedStatus:()=>yg,iterateRoutes:()=>lp,shouldReplicateToNode:()=>cp,subscribeToNodeUpdates:()=>id});function or(){return Gk||(Gk=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 yg(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function id(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 cp(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(){id(e=>{La({},(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=yg(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of sd.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*lp(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=nd.default.get(x.REPLICATION_SECUREPORT)??(!nd.default.get(x.REPLICATION_PORT)&&nd.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||nd.default.get(x.REPLICATION_PORT)||nd.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,nd,Kk,Gk,qk,sd,hl=be(()=>{De();Zn();ym();$k=require("worker_threads"),Vk=M(pe()),nd=M(ce());H();Kk=M(wi());server.nodes=[];a(or,"getHDBNodeTable");a(yg,"getReplicationSharedStatus");a(id,"subscribeToNodeUpdates");a(cp,"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})`);sd||(sd=new Map,fie());let n=sd.get(e);return n||(n=[],sd.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(fie,"startSubscriptionToReplications");a(lp,"iterateRoutes")});var jk={};Ue(jk,{connectedToNode:()=>ml,disconnectedFromNode:()=>cd,ensureNode:()=>No,requestClusterStatus:()=>zk,startOnMainThread:()=>XO});async function XO(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){bg.set(i,ap(l.auditStore));break}}}Vi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of lp(e))try{let c=!o.subscriptions;if(c){let u=Ze(),f=or().primaryStore.get(u);if(f!==null){let d=e.url??Ma();(f===void 0||f.url!==d||f.shard!==e.shard)&&await No(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)}id(s)});let n;function s(i,o=i?.name){let c=Ze()&&o===Ze()||Ma()&&i?.url===Ma();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(at.trace("Setting up node replication for",i),!i){for(let[d,p]of Oo){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),at.warn("Node was deleted, unsubscribing from node",o,E,d),A?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){Oo.get(d).iterator.remove(),Oo.delete(d);return}}return}if(c)return;if(!i.url){at.info(`Node ${i.name} is missing url`);return}let l=Oo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(at.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 od)if(i.url===p.url){od.delete(d);break}od.set(i.name,i)}let u=Xe();if(l||(l=new Map,Oo.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]||(at.warn(`Database ${p} not found for node ${i.name}, making a subscription anyway`),f(p,!1))}function f(d,p){at.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),h,S=[{replicateByDefault:p,...i}];bg.has(d)&&(S.push({replicateByDefault:p,name:Ze(),start_time:bg.get(d),end_time:Date.now(),replicates:!0}),bg.delete(d));let g=cp(i,d),R=Vi.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):ad(E)},_ie);else{at.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):Ng(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),cd=a(function(i){try{at.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(od.keys()),c=o.sort(),l=c.indexOf(i.name||ci(i.url));if(l===-1){at.warn("Disconnected node not found in node map",i.name,o);return}let u=Oo.get(i.url),f=u?.get(i.database);if(!f){at.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=od.get(_);u=Oo.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(N=>N.name===A.name)){at.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}R.push(A),E=!0}if(!E){at.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,at.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):ad({database:i.database,nodes:R});return}at.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){at.error("Error failing over node",o)}},"disconnectedFromNode"),ml=a(function(i){let o=Oo.get(i.url),c=o?.get(i.database);if(!c){at.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}):ad({database:i.database,nodes:u}))}},"connectedToNode"),(0,Vi.onMessageByType)("disconnected-from-node",cd),(0,Vi.onMessageByType)("connected-to-node",ml),(0,Vi.onMessageByType)("request-cluster-status",zk)}function zk(e,t){let r=[];for(let[n,s]of od)try{let i=Oo.get(s.url);at.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,QO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){at.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function No(e,t){let r=or();e=e??ci(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){at.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(at.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,QO.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])]}at.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Vi,Og,at,QO,Yk,Wk,_ie,Oo,cd,ml,od,bg,up=be(()=>{De();Vi=M(rt());Zn();Og=require("worker_threads");hl();at=M(W()),QO=require("lodash"),Yk=M(ce());H();Wk=require("crypto"),_ie=200,Oo=new Map,od=new Map,bg=new Map;a(XO,"startOnMainThread");a(zk,"requestClusterStatus");Og.parentPort&&(cd=a(e=>{Og.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),ml=a(e=>{Og.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Vi.onMessageByType)("subscribe-to-node",e=>{ad(e)}),(0,Vi.onMessageByType)("unsubscribe-from-node",e=>{Ng(e)}));a(No,"ensureNode")});var es=I(gF=>{"use strict";var ar=require("path"),wn=require("fs-extra"),ld=require("node-forge"),tF=require("net"),{generateKeyPair:eN,X509Certificate:wo,createPrivateKey:rF}=require("crypto"),pie=require("util");eN=pie.promisify(eN);var yt=ld.pki,li=require("joi"),{v4:nF}=require("uuid"),{validateBySchema:sN}=it(),_t=W(),bs=ce(),Os=(H(),P(G)),{CONFIG_PARAMS:ud}=Os,ui=Ky(),{ClientError:Ua}=pe(),wg=require("node:tls"),{relative:sF,join:hie}=require("node:path"),{CERT_PREFERENCE_APP:MPe,CERTIFICATE_VALUES:Jk}=ui,mie=da(),tN=Rt(),{table:Eie,getDatabases:gie,databases:ZO}=(De(),P(nt)),{getJWTRSAKeys:Qk}=(Qu(),P(Z_));Object.assign(gF,{generateKeys:aN,updateConfigCert:fF,createCsr:Nie,signCertificate:wie,setCertTable:dd,loadCertificates:lF,reviewSelfSignedCert:lN,createTLSSelector:pF,listCertificates:mF,addCertificate:Mie,removeCertificate:Uie,createNatsCerts:Pie,generateCertsKeys:Cie,getReplicationCert:fp,getReplicationCertAuth:Oie,renewSelfSigned:Die,hostnamesFromCert:EF,getKey:xie});var{urlToNodeName:iF,getThisNodeUrl:Sie,getThisNodeName:Cg,clearThisNodeName:Tie}=(Zn(),P(Io)),{readFileSync:Aie,watchFile:Rie,statSync:oF}=require("node:fs"),vPe=ce(),{getTicketKeys:yie,onMessageFromWorkers:bie}=rt(),va=W(),{isMainThread:aF}=require("worker_threads"),{TLSSocket:cF,createSecureContext:UPe}=require("node:tls"),iN=3650,dp=["127.0.0.1","localhost","::1"],oN=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];bie(async e=>{e.type===Os.ITC_EVENT_TYPES.RESTART&&(bs.initSync(!0),await lN())});var Ur;function Ba(){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(Ba,"getCertTable");async function fp(){let e=pF("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Cg());if(!r)return;let n=new wo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(fp,"getReplicationCert");async function Oie(){Ba();let e=(await fp()).options.cert,r=new wo(e).issuer.match(/CN=(.*)/)?.[1];return Ur.get(r)}a(Oie,"getReplicationCertAuth");var Xk,xa=new Map;function lF(){if(Xk)return;Xk=!0;let e=[{configKey:ud.TLS},{configKey:ud.OPERATIONSAPI_TLS}];Ba();let t=ar.dirname(tN.getConfigFilePath()),r;for(let{configKey:n}of e){let s=tN.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=>{xa.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 wo(_),S;try{S=uN(h)}catch(A){_t.error("error extracting common name from certificate",A);return}if(S==null){_t.error("error extracting common name from certificate");return}if(h.checkIssued(new wo(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&&_t.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&&_t.warn(`Reloading ${r}:`,e),n=c,t(_F(e)))}catch(c){_t.error(`Error loading ${r}:`,e,c)}},"loadFile");wn.existsSync(e)?s(oF(e)):_t.error(`${r} file not found:`,e),Rie(e,{persistent:!1},s)}a(Zk,"loadAndWatch");function rN(){let e=Sie();if(e==null){let t=dp[0];return _t.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return iF(e)}a(rN,"getHost");function Ig(){let e=Cg();if(e==null){let t=dp[0];return _t.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Ig,"getCommonName");async function Nie(){let e=await fp(),t=yt.certificateFromPem(e.options.cert),r=yt.privateKeyFromPem(e.options.key);_t.info("Creating CSR with cert named:",e.name);let n=yt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Ig()},...oN];_t.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:uF()}];return _t.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),ld.pki.certificationRequestToPem(n)}a(Nie,"createCsr");function uF(){let e=dp.includes(Ig())?dp:[...dp,Ig()];return e.includes(rN())||e.push(rN()),[{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(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;Ba();for await(let f of Ur.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 wn.exists(ar.join(r,f.private_key_name))){n=wn.readFile(ar.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await nN();s=f.ca,n=f.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);_t.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return _t.error(f),new Error("Error verifying CSR: "+f.message)}let c=ld.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()+iN),_t.info("sign cert setting validity:",c.validity),_t.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),_t.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;_t.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,ld.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else _t.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(wie,"signCertificate");async function Iie(e,t){await dd({name:Cg(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await dd({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Iie,"createCertificateTable");async function dd(e){let t=new wo(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 Ur.patch(e)}a(dd,"setCertTable");async function aN(){let e=await eN("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(aN,"generateKeys");async function cN(e,t,r){let n=yt.createCertificate();if(!t){let o=await fp();t=yt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+iN);let i=[{name:"commonName",value:Ig()},...oN];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(uF()),n.sign(e,ld.md.sha256.create()),yt.certificateToPem(n)}a(cN,"generateCertificates");async function nN(){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 wo(r.certificate).checkPrivateKey(rF(n))){_t.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;_t.trace("No CA found with matching private key")}a(nN,"getCertAuthority");async function dF(e,t,r=!0){let n=yt.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()+iN);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${bs.get(ud.REPLICATION_HOSTNAME)??iF(bs.get(ud.REPLICATION_URL))??nF().split("-")[0]}`},...oN];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,ld.md.sha256.create());let o=ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),c=ar.join(o,ui.PRIVATEKEY_PEM_NAME);return r&&await wn.writeFile(c,yt.privateKeyToPem(e)),n}a(dF,"generateCertAuthority");async function Cie(){let{private_key:e,public_key:t}=await aN(),r=await dF(e,t),n=await cN(e,t,r);await Iie(n,r),fF()}a(Cie,"generateCertsKeys");async function Pie(){let e=await cN(yt.privateKeyFromPem(ui.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(ui.CERTIFICATE_VALUES.cert)),t=ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),r=ar.join(t,ui.NATS_CERTIFICATE_PEM_NAME);await wn.exists(r)||await wn.writeFile(r,e);let n=ar.join(t,ui.NATS_CA_PEM_NAME);await wn.exists(n)||await wn.writeFile(n,ui.CERTIFICATE_VALUES.cert)}a(Pie,"createNatsCerts");async function Die(){Ba();for await(let e of Ur.search([{attribute:"is_self_signed",value:!0}]))await Ur.delete(e.name);await lN()}a(Die,"renewSelfSigned");async function lN(){Tie(),await lF(),Ba();let e=await nN();if(!e){_t.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=bs.get(ud.TLS_PRIVATEKEY),n=ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),s,i=sF(n,r);try{s=yt.privateKeyFromPem(await wn.readFile(r))}catch(c){_t.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 aN(),await wn.exists(ar.join(n,ui.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${nF().split("-")[0]}.pem`),await wn.writeFile(ar.join(n,i),yt.privateKeyToPem(s))}let o=await dF(s,yt.setRsaPublicKey(s.n,s.e),!1);await dd({name:o.subject.getField("CN").value,uses:["https"],certificate:yt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await fp()){let r=Cg();_t.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await nN();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await cN(yt.privateKeyFromPem(e.private_key),s,n);await dd({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(lN,"reviewSelfSignedCert");function fF(){let e=mie(Object.keys(Os.CONFIG_PARAM_MAP),!0),t=ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),r=ar.join(t,ui.PRIVATEKEY_PEM_NAME),n=ar.join(t,ui.NATS_CERTIFICATE_PEM_NAME),s=ar.join(t,ui.NATS_CA_PEM_NAME),i=Os.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),tN.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=wg.createSecureContext;wg.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 El=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(),El.clear();let f=0;for await(let d of ZO.system.hdb_certificate.search([])){let p=d.certificate,_=new wo(p);d.is_authority&&(_.asString=p,El.set(_.subject,p))}for await(let d of ZO.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 wo(S);if(El.has(g.issuer)&&(S+=`
|
|
24
|
+
`+El.get(g.issuer)),!h||!S)throw new Error("Missing private key or certificate for secure server");let R={ciphers:d.ciphers,ticketKeys:yie(),availableCAs:El,ca:t&&Array.from(El.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=wg.createSecureContext(R);E.name=d.name,E.options=R,E.quality=_,E.certificateAuthorities=Array.from(El),E.certStart=S.toString().slice(0,100);let A=d.hostnames??EF(g);Array.isArray(A)||(A=[A]);let N;for(let v of A)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===rN()&&(_+=2),tF.isIP(v)&&(N=!0);let F=r.get(v)?.quality??0;_>F&&r.set(v,E)}else va.error("No hostname found for certificate at",wg.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"),ZO.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(pF,"createTLSSelector");async function hF(e){let t=xa.get(e);return!t&&e?await wn.readFile(ar.join(bs.get(ud.ROOTPATH),Os.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(hF,"getPrivateKeyByName");async function mF(){Ba();let e=[];for await(let t of Ur.search([]))e.push(t);return e}a(mF,"listCertificates");async function Mie(e){let t=sN(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 wo(n),c=!1,l=!1,u;for(let[_,h]of xa)!s&&!c&&o.checkPrivateKey(rF(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=uN(o)}catch(_){_t.error(_)}if(f==null)throw new Ua("Error extracting certificate common name, please provide a name parameter")}let d=vie(r??f);s&&!c&&!l&&(await wn.writeFile(ar.join(bs.getHdbBasePath(),Os.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 dd(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=sN(e,li.object({name:li.string().required()}));if(t)throw new Ua(t.message);let{name:r}=e;Ba();let n=await Ur.get(r);if(!n)throw new Ua(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&&(_t.info("Removing private key named",s),await wn.remove(ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME,s)))}return await Ur.delete(r),"Successfully removed "+r}a(Uie,"removeCertificate");function uN(e){return e.subject.match(/CN=(.*)/)?.[1]}a(uN,"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):[uN(e)]}a(EF,"hostnamesFromCert");async function xie(e){if(e.bypass_auth!==!0)throw new Ua("Unauthorized","401");let t=sN(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(xie,"getKey")});var BF={};Ue(BF,{CONFIRMATION_STATUS_POSITION:()=>xF,NodeReplicationConnection:()=>_p,OPERATION_REQUEST:()=>pN,RECEIVED_TIME_POSITION:()=>mN,RECEIVED_VERSION_POSITION:()=>hN,SENDING_TIME_POSITION:()=>vg,createWebSocket:()=>xg,database_subscriptions:()=>ka,replicateOverWS:()=>pp,table_update_listeners:()=>gN});async function xg(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Ze(),i;if(e==null)throw new TypeError(`Invalid URL: Expected a string URL for node "${s}" but received ${e}`);if(e.includes("wss://")){if(!fN){let l=(0,MF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),fN=u.secureContexts}if(i=fN.get(s),i&&ue.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(Sl)})),new DF.WebSocket(e,"harperdb-replication-v1",c)}function pp(e,t,r){let n=t.port||t.securePort,s=gl.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||ka,d,p,_=!1,h=t.subscription;h?.then&&h.then(T=>h=T);let S=t.tables||u&&Xe()[u];if(!r){ue.error?.("No authorization provided"),dn(1008,"Unauthorized");return}let g=new Map,R=[],E=r.name;E&&t.connection&&(t.connection.nodeName=E);let A,N,v,F,$,Y,ee,oe=1e3,j,se=0,z=0,me=0,Ae=new Map,Pe=[],he=0,Ot;if(t.url){let T=a(()=>{$&&z===e._socket?.bytesRead&&me===e._socket?.bytesWritten?e.terminate():($=performance.now(),e.ping(),z=e._socket?.bytesRead,me=e._socket?.bytesWritten)},"send_ping");v=setInterval(T,IF).unref(),T()}else ut();e._socket?.setMaxListeners(200);function ut(){clearTimeout(F),z=e._socket?.bytesRead,me=e._socket?.bytesWritten,F=setTimeout(()=>{z===e._socket?.bytesRead&&me===e._socket?.bytesWritten&&(ue.warn?.(`Timeout waiting for ping from ${E}, terminating connection and reconnecting`),e.terminate())},IF*2).unref()}a(ut,"resetPingTimer");function br(){return p||(p=yg(d,u,E)),p}a(br,"getSharedStatus"),u&&oa(u);let ms,xn,au=[],cu=[],kA,FA=[],Mt=[],gf=[],Qh=150,Xh=25,Sf=0,Zh=0,Ie=!1,Tf,un,Cr,lu;e.on("message",T=>{se=performance.now();try{let b=T.dataView=new Tl(T.buffer,T.byteOffset,T.byteLength);if(T[0]>127){let O=(0,je.decode)(T),[U,L,C]=O;switch(U){case TF:{if(L){if(E){if(E!==L){ue.error?.(s,`Node name mismatch, expecting to connect to ${E}, but peer reported name as ${L}, disconnecting`),e.send((0,je.encode)([fd])),dn(1008,"Node name mismatch");return}}else if(E=L,t.connection?.tentativeNode){let de=t.connection.tentativeNode;de.name=E,t.connection.tentativeNode=null,No(E,de)}if(t.connection&&(t.connection.nodeName=E),ue.debug?.(s,"received node name:",E,"db:",u),!u)try{oa(u=O[2]),u==="system"&&(ms=La(t,(de,re)=>{du(re)&&aa(re)}),e.on("close",()=>{ms?.remove()}))}catch(de){ue.warn?.(s,"Error setting database",de),e.send((0,je.encode)([fd])),dn(1008,de.message);return}Gr()}break}case NF:{ue.debug?.(s,"Received table definitions for",L.map(de=>de.table));for(let de of L){let re=O[2];de.database=re;let fe;du(re)&&(re==="system"?$e[re]?.[de.table]||(fe=m(de,$e[re]?.[de.table])):fe=m(de,$e[re]?.[de.table]),d||(d=fe?.auditStore),S||(S=Xe()?.[re]))}break}case fd:dn();break;case pN:try{let de=r?.replicates||r?.subscribers||r?.name;server.operation(L,{user:r},!de).then(re=>{Array.isArray(re)&&(re={results:re}),re.requestId=L.requestId,e.send((0,je.encode)([Dg,re]))},re=>{e.send((0,je.encode)([Dg,{requestId:L.requestId,error:re instanceof Error?re.toString():re}]))})}catch(de){e.send((0,je.encode)([Dg,{requestId:L.requestId,error:de instanceof Error?de.toString():de}]))}break;case Dg:let{resolve:B,reject:q}=g.get(L.requestId);L.error?q(new Error(L.error)):B(L),g.delete(L.requestId);break;case dN:let Q=O[3];S||(u?ue.error?.(s,"No tables found for",u):ue.error?.(s,"Database name never received"));let X=S[Q];X=m({table:Q,database:u,attributes:L.attributes,schemaDefined:L.schemaDefined},X),au[C]={name:Q,decoder:new je.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:L.typedStructs,structures:L.structures}),getEntry(de){return X.primaryStore.getEntry(de)},rootStore:X.primaryStore.rootStore};break;case AF:lu=d?Fk(L,d):new Map,kA=O[2],ue.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${kA}`);break;case RF:let k=C;gf[k]=L;break;case OF:br()[xF]=L,ue.trace?.(s,"received and broadcasting committed update",L),br().buffer.notify();break;case bF:A=L,h.send({type:"end_txn",localTime:A,remoteNodeIds:R});break;case Lg:{let de=O[1],{fileId:re,size:fe,finished:ie,error:J}=de,le=Ae.get(re);ue.debug?.("Received blob",re,"has stream",!!le,"connectedToBlob",!!le?.connectedToBlob,"length",O[2].length,"finished",ie),le||(le=new _N.PassThrough,le.expectedSize=fe,Ae.set(re,le)),le.lastChunk=Date.now(),ie?(J?(le.on("error",()=>{}),le.destroy(new Error("Blob error: "+J))):le.end(O[2]),le.connectedToBlob&&Ae.delete(re)):le.write(O[2]);break}case yF:{let de=L,re;try{let fe=O[3],ie=cu[C]||(cu[C]=S[O[4]]);if(!ie)return ue.warn?.("Unknown table id trying to handle record request",C);let J=ie.primaryStore.getBinaryFast(Symbol.for("structures")),le=J.length;if(le!==Zh){Zh=le;let Te=(0,je.decode)(J);e.send((0,je.encode)([dN,{typedStructs:Te.typed,structures:Te.named},C,ie.tableName]))}let Re=ie.primaryStore.getBinaryFast(fe);if(Re){let Te=ie.primaryStore.decoder.decode(Re,{valueAsBuffer:!0});re=(0,je.encode)([Pg,de,{value:Te.value,expiresAt:Te.expiresAt,version:Te.version,residencyId:Te.residencyId,nodeId:Te.nodeId,user:Te.user}])}else re=(0,je.encode)([Pg,de])}catch(fe){re=(0,je.encode)([Pg,de,{error:fe.message}])}e.send(re);break}case Pg:{let{resolve:de,reject:re,tableId:fe,key:ie}=g.get(O[1]),J=O[2];if(J?.error)re(new Error(J.error));else if(J){let le=au[fe].decoder.decode(J.value);J.value=le,J.key=ie,de(J)}else de();g.delete(O[1]);break}case SF:{Cr=L;let de,re,fe=!1;if(h){if(u!==h.databaseName&&!h.then){ue.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=f.get(u);if(ue.debug?.(s,"received subscription request for",u,"at",Cr),!h){let ye;h=new Promise(tt=>{ue.debug?.("Waiting for subscription to database "+u),ye=tt}),h.ready=ye,ka.set(u,h)}if(r.name)re=or().subscribe(r.name),re.then(async ye=>{de=ye;for await(let tt of de){let vt=tt.value;if(!(vt?.replicates===!0||vt?.replicates?.receives||vt?.subscriptions?.some(mr=>(mr.database||mr.schema)===u&&mr.publish!==!1))){fe=!0,e.send((0,je.encode)([fd])),dn(1008,`Unauthorized database subscription to ${u}`);return}}},ye=>{ue.error?.(s,"Error subscribing to HDB nodes",ye)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,je.encode)([fd])),dn(1008,`Unauthorized database subscription to ${u}`);return}if(un&&(ue.debug?.(s,"stopping previous subscription",u),un.emit("close")),Cr.length===0)return;let ie=Cr[0],J=a(ye=>{if(ye&&(ie.replicateByDefault?!ie.tables.includes(ye.tableName):ie.tables.includes(ye.tableName)))return{table:ye}},"tableToTableEntry"),le={txnTime:0},Re,Te,ve=1/0,Je,Zt=a((ye,tt)=>{if(ye.type==="end_txn"){le.txnTime&&(o[i]!==66&&ue.error?.("Invalid encoding of message"),fu(9),fu(Ug),yc(Je=tt),qr()),i=c,le.txnTime=0;return}let vt=ye.nodeId,mr=ye.tableId,Vt=Te[mr];if(!Vt&&(Vt=Te[mr]=J(h.tableById[mr]),!Vt))return ue.debug?.("Not subscribed to table",mr);let $r=Vt.table,bc=$r.primaryStore,Ut=bc.encoder;(ye.extendedType&Jm||!Ut.typedStructs)&&(Ut._mergeStructures(Ut.getStructures()),Ut.typedStructs&&(Ut.lastTypedStructuresLength=Ut.typedStructs.length));let tm=Re[vt];if(!(tm&&tm.startTime<tt&&(!tm.endTime||tm.endTime>tt)))return Mg&&ue.trace?.(s,"skipping replication update",ye.recordId,"to:",E,"from:",vt,"subscribed:",Re),oD();Mg&&ue.trace?.(s,"sending replication update",ye.recordId,"to:",E,"from:",vt,"subscribed:",Re);let GA=ye.version;le.txnTime!==GA&&(le.txnTime&&(Mg&&ue.trace?.(s,"new txn time, sending queued txn",le.txnTime),o[i]!==66&&ue.error?.("Invalid encoding of message"),qr()),le.txnTime=GA,i=c,yc(GA));let Oc=ye.residencyId,qA=uu(Oc,$r),rm;if(qA&&!qA.includes(E)){let Nc=uu(ye.previousResidencyId,$r);if(Nc&&!Nc.includes(E)&&(ye.type==="put"||ye.type==="patch")||$r.getResidencyById)return oD();let yf=ye.recordId;ue.trace?.(s,"sending invalidation",yf,E,"from",vt);let la=0;Oc&&(la|=Fc),ye.previousResidencyId&&(la|=Gc);let Ys,fn=null;for(let nm in $r.indices){if(!fn){if(Ys=ye.getValue(bc,!0),!Ys)break;fn={}}fn[nm]=Ys[nm]}rm=wu(ye.version,mr,yf,null,vt,ye.user,ye.type==="put"||ye.type==="patch"?"invalidate":ye.type,Ut.encode(fn),la,Oc,ye.previousResidencyId,ye.expiresAt)}function oD(){ue.trace?.(s,"skipping audit record",ye.recordId),Y||(Y=setTimeout(()=>{Y=null,(Je||0)+wF/2<ve&&(Mg&&ue.trace?.(s,"sending skipped sequence update",ve),e.send((0,je.encode)([bF,ve])))},wF).unref())}a(oD,"skipAuditRecord");let $A=Ut.typedStructs,VA=Ut.structures;if(($A?.length!=Vt.typed_length||VA?.length!=Vt.structure_length)&&(Vt.typed_length=$A?.length,Vt.structure_length=VA.length,ue.debug?.(s,"send table struct",Vt.typed_length,Vt.structure_length),Vt.sentName||(Vt.sentName=!0),e.send((0,je.encode)([dN,{typedStructs:$A,structures:VA,attributes:$r.attributes,schemaDefined:$r.schemaDefined},mr,Vt.table.tableName]))),Oc&&!Mt[Oc]&&(e.send((0,je.encode)([RF,qA,Oc])),Mt[Oc]=!0),rm)fu(rm.length),Rc(rm);else{let Nc=ye.encoded;ye.extendedType&Gn&&DR(()=>ye.getValue(bc),async la=>{let Ys=km(la);try{let fn;he++;for await(let nm of la.stream()){if(fn&&(ue.debug?.("Sending blob chunk",Ys,"length",fn.length),e.send((0,je.encode)([Lg,{fileId:Ys,size:la.size},fn]))),fn=nm,fe)return;e._socket.writableNeedDrain&&(ue.debug?.("draining",Ys),await new Promise(g2=>e._socket.once("drain",g2)),ue.debug?.("drained",Ys))}ue.debug?.("Sending final blob chunk",Ys,"length",fn.length),e.send((0,je.encode)([Lg,{fileId:Ys,size:la.size,finished:!0},fn]))}catch(fn){ue.debug?.("Error sending blob",fn),e.send((0,je.encode)([Lg,{fileId:Ys,finished:!0,error:fn.toString()},Buffer.alloc(0)]))}finally{he--,he<Xh&&Ot?.()}});let yf=Nc[0]===66?8:0;fu(Nc.length-yf),Rc(Nc,yf),ue.trace?.("wrote record",ye.recordId,"length:",Nc.length)}},"sendAuditRecord"),qr=a(()=>{c-i>8?(e.send(o.subarray(i,c)),ue.debug?.(s,"Sent message, size:",c-i)):ue.debug?.(s,"skipping empty transaction")},"sendQueuedData");un=new EN.EventEmitter,un.once("close",()=>{fe=!0,de?.end()});for(let{startTime:ye}of Cr)ye<ve&&(ve=ye);(re||Promise.resolve()).then(async()=>{h=await h,d=h.auditStore,Te=h.tableById.map(J),Re=[];for(let{name:tt,startTime:vt,endTime:mr}of Cr){let Vt=Rg(tt,d);ue.debug?.("subscription to",tt,"using local id",Vt,"starting",vt),Re[Vt]={startTime:vt,endTime:mr}}aa(u),ms||(ms=Al(tt=>{tt.databaseName===u&&aa(u)}),xn=hp(tt=>{tt===u&&(e.send((0,je.encode)([fd])),dn())}),e.on("close",()=>{ms?.remove(),xn?.remove()})),e.send((0,je.encode)([AF,op(h.auditStore),Cr.map(({name:tt})=>tt)]));let ye=!0;do{isFinite(ve)||(ue.warn?.("Invalid sequence id "+ve),dn(1008,"Invalid sequence id"+ve));let tt;if(ye&&!fe&&(ye=!1,!(TN(d)<=ve)&&(PF.default.get(x.REPLICATION_COPYTABLESTOCATCHUP)??Bie)&&server.nodes[0]?.name===E)){ue.info?.("Replicating all tables to",E);let mr=ve,Vt=Bg(d);for(let $r in S){if(!J($r))continue;let bc=S[$r];for(let Ut of bc.primaryStore.getRange({snapshot:!1})){if(fe)return;Ut.localTime>=ve&&(ue.trace?.(s,"Copying record from",u,$r,Ut.key,Ut.localTime),mr=Math.max(Ut.localTime,mr),tt=!0,br()[vg]=1,Zt({recordId:Ut.key,tableId:bc.tableId,type:"put",getValue(){return Ut.value},encoded:bc.primaryStore.getBinary(Ut.key),version:Ut.version,residencyId:Ut.residencyId,nodeId:Vt,extendedType:Ut.metadataFlags},Ut.localTime))}}ve=mr}for(let{key:vt,value:mr}of d.getRange({start:ve||1,exclusiveStart:!0,snapshot:!1})){if(fe)return;let Vt=wt(mr);ue.debug?.("sending audit record",new Date(vt)),br()[vg]=vt,ve=vt,Zt(Vt,vt),e._socket.writableNeedDrain?await new Promise($r=>{ue.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",$r)}):he>Xh?await new Promise($r=>{Ot=$r}):await new Promise(setImmediate),un.startTime=vt,tt=!0}tt&&Zt({type:"end_txn"},ve),br()[vg]=0,await HF(d)}while(!fe)}).catch(ye=>{ue.error?.(s,"Error handling subscription to node",ye),dn(1008,"Error handling subscription to node")});break}}return}b.position=8;let w=!0,y,D;do{br();let O=b.readInt();if(O===9&&b.getUint8(b.position)==Ug){b.position++,A=D=b.readFloat64(),p[hN]=A,p[mN]=Date.now(),ue.trace?.("received remote sequence update",A,u);break}let U=b.position,L=wt(T,U,U+O),C=au[L.tableId];C||ue.error?.(`No table found with an id of ${L.tableId}`);let B;L.residencyId&&(B=gf[L.residencyId],ue.trace?.(s,"received residency list",B,L.type,L.recordId));try{PR(()=>{y={table:C.name,id:L.recordId,type:L.type,nodeId:lu.get(L.nodeId),residencyList:B,timestamp:L.version,value:L.getValue(C),user:L.user,beginTxn:w,expiresAt:L.expiresAt}},q=>{let Q=km(q),X=Ae.get(Q);ue.debug?.("Received transaction with blob",Q,"has stream",!!X,"ended",!!X?.writableEnded),X?X.writableEnded&&Ae.delete(Q):(X=new _N.PassThrough,Ae.set(Q,X)),X.connectedToBlob=!0,X.lastChunk=Date.now(),q.size===void 0&&X.expectedSize&&(q.size=X.expectedSize);let k=createBlob(X,q),de=k.save({primaryStore:h.auditStore});return de&&(de.blobId=Q,Pe.push(de),de.finally(()=>{ue.debug?.(`Finished receiving blob stream ${Q}`),Pe.splice(Pe.indexOf(de),1)})),k})}catch(q){throw q.message+="typed structures for current decoder"+JSON.stringify(C.decoder.typedStructs),q}w=!1,ue.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),b.position=U+O}while(b.position<T.byteLength);Sf++,sr(T.byteLength,"bytes-received",`${E}.${u}.${y?.table||"unknown_table"}`,"replication","ingest"),Sf>Qh&&!Ie&&(Ie=!0,e.pause(),ue.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 O=Date.now()-y.timestamp;sr(O,"replication-latency",E+"."+u+"."+y.table,y.type,"ingest")}Sf--,Ie&&(Ie=!1,e.resume(),ue.debug?.(`Replication resuming ${E}`)),Pe.length>0&&await Promise.all(Pe),ue.trace?.("All blobs finished"),!N&&D&&(ue.trace?.(s,"queuing confirmation of a commit at",D),setTimeout(()=>{e.send((0,je.encode)([OF,N])),ue.trace?.(s,"sent confirmation of a commit at",N),N=null},Hie)),N=D,ue.debug?.("last sequence committed",new Date(D),u)}})}catch(b){ue.error?.(s,"Error handling incoming replication message",b)}}),e.on("ping",ut),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-$,ml({name:E,database:u,url:t.url,latency:t.connection.latency})),$=null}),e.on("close",(T,b)=>{clearInterval(v),clearTimeout(F),clearInterval(ee),un&&un.emit("close"),Tf&&Tf.end();for(let[w,{reject:y}]of g)y(new Error(`Connection closed ${b?.toString()} ${T}`));ue.debug?.(s,"closed",T,b?.toString())});function Af(){}a(Af,"recordRemoteNodeSequence");function dn(T,b){e.isFinished=!0,e.close(T,b)}a(dn,"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 T=new Map;try{for(let y of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let D of y.value.nodes||[])D.lastTxnTime>(T.get(D.id)??0)&&T.set(D.id,D.lastTxnTime)}catch(y){if(!y.message.includes("Can not re"))throw y}let b=t.connection?.nodeSubscriptions?.[0];R=[];let w=t.connection?.nodeSubscriptions.map((y,D)=>{let O=[],{replicateByDefault:U}=y;if(y.subscriptions){for(let q of y.subscriptions)if(q.subscribe&&(q.schema||q.database)===u){let Q=q.table;S?.[Q]?.replicate!==!1&&O.push(Q)}U=!1}else for(let q in S)(U?S[q].replicate===!1:S[q].replicate)&&O.push(q);let L=d&&Rg(y.name,d),C=h?.dbisDB?.get([Symbol.for("seq"),L])??1,B=Math.max(C?.seqId??1,(typeof y.start_time=="string"?new Date(y.start_time).getTime():y.start_time)??1);if(ue.debug?.("Starting time recorded in db",y.name,L,u,C?.seqId,"start time:",B,new Date(B)),b!==y){let q=d&&Rg(b.name,d),Q=h?.dbisDB?.get([Symbol.for("seq"),q])??1;for(let X of Q?.nodes||[])X.name===y.name&&(B=X.seqId,ue.debug?.("Using sequence id from proxy node",b.name,B))}return R.push(L),T.get(L)>B&&(B=T.get(L),ue.debug?.("Updating start time from more recent txn recorded",b.name,B)),{name:y.name,replicateByDefault:U,tables:O,startTime:B,endTime:y.end_time}});if(w)if(ue.debug?.(s,"sending subscription request",w,h?.dbisDB?.path),clearTimeout(j),w.length>0)e.send((0,je.encode)([SF,w]));else{let y=a(()=>{let D=performance.now();j=setTimeout(()=>{se<=D?dn(1008,"No nodes to subscribe to"):y()},oe)},"schedule_close");y()}}a(Gr,"sendSubscriptionRequestUpdate");function uu(T,b){if(!T)return;let w=FA[T];return w||(w=b.getResidencyRecord(T),FA[T]=w),w}a(uu,"getResidence");function du(T){return!(Ha&&Ha!="*"&&!Ha[T]&&!Ha.includes?.(T)&&!Ha.some?.(b=>b.name===T))}a(du,"checkDatabaseAccess");function oa(T){if(h=h||f.get(T),!du(T))throw new Error(`Access to database "${T}" is not permitted`);h||ue.warn?.(`No database named "${T}" was declared and registered`),d=h?.auditStore,S||(S=Xe()?.[T]);let b=Ze();if(b===E)throw b?new Error("Should not connect to self",b):new Error("Node name not defined");return em(b,T),!0}a(oa,"setDatabase");function em(T,b){let w=Xe()?.[b],y=[];for(let D in w){let O=w[D];y.push({table:D,schemaDefined:O.schemaDefined,attributes:O.attributes.map(U=>({name:U.name,type:U.type,isPrimaryKey:U.isPrimaryKey}))})}ue.trace?.("Sending database info for node",T,"database name",b),e.send((0,je.encode)([TF,T,b,y]))}a(em,"sendNodeDBName");function aa(T){let b=Xe()?.[T],w=[];for(let y in b){if(Cr&&!Cr.some(O=>O.replicateByDefault?!O.tables.includes(y):O.tables.includes(y)))continue;let D=b[y];w.push({table:y,schemaDefined:D.schemaDefined,attributes:D.attributes.map(O=>({name:O.name,type:O.type,isPrimaryKey:O.isPrimaryKey}))})}e.send((0,je.encode)([NF,w,T]))}a(aa,"sendDBSchema"),ee=setInterval(()=>{for(let[T,b]of Ae)b.lastChunk+3e4<Date.now()&&(ue.warn?.(`Timeout waiting for blob stream to finish ${T} from ${E}`),Ae.delete(T),b.end())},3e4).unref();let ca=1,Rf=[];return{end(){Tf&&Tf.end(),un&&un.emit("close")},getRecord(T){let b=ca++;return new Promise((w,y)=>{let D=[yF,b,T.table.tableId,T.id];Rf[T.table.tableId]||(D.push(T.table.tableName),Rf[T.table.tableId]=!0),e.send((0,je.encode)(D)),g.set(b,{tableId:T.table.tableId,key:T.id,resolve(O){let{table:U,entry:L}=T;w(O),O&&U._recordRelocate(L,O)},reject:y})})},sendOperation(T){let b=ca++;return T.requestId=b,e.send((0,je.encode)([pN,T])),new Promise((w,y)=>{g.set(b,{resolve:w,reject:y})})}};function fu(T){V(5),T<128?o[c++]=T:T<16384?(l.setUint16(c,T|32768),c+=2):T<1056964608?(l.setUint32(c,T|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,T),c+=5)}function Rc(T,b=0,w=T.length){let y=w-b;V(y),T.copy(o,c,b,w),c+=y}function yc(T){V(8),l.setFloat64(c,T),c+=8}function V(T){if(T+16>o.length-c){let b=Buffer.allocUnsafeSlow(c+T-i+65536>>10<<11);o.copy(b,0,i,c),c=c-i,i=0,o=b,l=new DataView(o.buffer,0,o.length)}}function m(T,b){let w=T.database??"data";if(w!=="data"&&!$e[w]){ue.warn?.("Database not found",T.database);return}b||(b={});let y=b.schemaDefined,D=!1,O=T.schemaDefined,U=b.attributes||[];for(let L=0;L<T.attributes?.length;L++){let C=T.attributes[L],B=U[L];(!B||B.name!==C.name||B.type!==C.type)&&(y?ue.error?.(`Schema for '${u}.${T.table}' is defined locally, but attribute '${C.name}: ${C.type}' from '${E}' does not match local attribute ${B?"'"+B.name+": "+B.type+"'":"which does not exist"}`):(D=!0,O||(C.indexed=!0),U[L]=C))}return D?(ue.debug?.("(Re)creating",T),dt({table:T.table,database:T.database,schemaDefined:T.schemaDefined,attributes:U,...b})):b}}var PF,je,DF,LF,ue,EN,MF,vF,gl,UF,_N,SF,TF,AF,fd,RF,dN,yF,Pg,pN,Dg,bF,OF,NF,Lg,xF,hN,mN,vg,Bie,gN,ka,Mg,wF,Hie,IF,fN,CF,_p,SN=be(()=>{De();_o();jO();AN();Zn();PF=M(ce());H();Iu();je=require("msgpackr"),DF=require("ws"),LF=require("worker_threads"),ue=M(wi());up();EN=require("events"),MF=M(es()),vF=M(require("node:tls"));hl();gl=M(require("node:process")),UF=require("node:net");Fi();Ss();_N=require("node:stream"),SF=129,TF=140,AF=141,fd=142,RF=130,dN=132,yF=133,Pg=134,pN=136,Dg=137,bF=143,OF=144,NF=145,Lg=146,xF=0,hN=1,mN=2,vg=3,Bie=gl.env.HDB_LEADER_URL||gl.argv.includes("--HDB_LEADER_URL"),gN=new Map,ka=new Map,Mg=!0,wF=300,Hie=2,IF=3e4;a(xg,"createWebSocket");CF=1e3,_p=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??ci(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 xg(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;ue.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${gl.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),ue[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=CF,ml({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=pp(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"?(ue.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"?ue.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`):ue.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(cd({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();ue.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(pp,"replicateOverWS")});var Io={};Ue(Io,{clearThisNodeName:()=>Yie,disableReplication:()=>qie,enabled_databases:()=>Ha,forEachReplicatedDatabase:()=>La,getThisNodeId:()=>Bg,getThisNodeName:()=>Ze,getThisNodeUrl:()=>Ma,hostnameToUrl:()=>Gg,lastTimeInAuditStore:()=>ap,monitorNodeCAs:()=>YF,replicateOperation:()=>zie,replication_certificate_authorities:()=>Sl,sendOperationToNode:()=>Ep,servers:()=>Fie,setReplicator:()=>zF,start:()=>Gie,startOnMainThread:()=>XO,subscribeToNode:()=>ad,unsubscribeFromNode:()=>Ng,urlToNodeName:()=>ci});function Gie(e){if(e.port||(e.port=Ns.default.get(x.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=Ns.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 lp(e))t.set(ci(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(),pp(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(Sl);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.updatedContext=Fg.createSecureContext(l)}catch(c){cr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),YF(s),Ns.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function YF(e){let t=0;id(r=>{r?.ca&&(Sl.add(r.ca),Sl.size!==t&&(t=Sl.size,e?.()))})}function qie(e=!0){KF=e}function $ie(e){KF||(Xe(),Ha=e.databases,La(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||ka;for(let[s,i]of mp){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 Vr{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(cr.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 _=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",kg,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function jF(e,t,r,n,s){let i=mp.get(e);i||mp.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new _p(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,mp.get(s.url))),n}async function Ep(e,t,r){r||(r={}),r.serverName=e.name;let n=await xg(e.url,r),s=pp(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 ad(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=ka.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,ka.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=>cp(n,e.database)),e.replicateByDefault)}catch(t){cr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Ng({name:e,url:t,database:r}){cr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(or().primaryStore.getRange({})));let n=mp.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=Ns.default.get(x.OPERATIONSAPI_TLS_CERTIFICATE)||Ns.default.get(x.TLS_CERTIFICATE);if(e)return RN=new GF.X509Certificate((0,qF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Ze(){return kg||(kg=Ns.default.get("replication_hostname")??ci(Ns.default.get("replication_url"))??Kie()??FF("operationsapi_network_secureport")??FF("operationsapi_network_port")??"127.0.0.1")}function Yie(){kg=void 0}function FF(e){let t=Ns.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Hg(e){let t=Ns.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Bg(e){return op(e)?.[Ze()]}function Ma(){let e=Ns.default.get("replication_url");return e||Gg(Ze())}function Gg(e){let t=Hg("replication_port");if(t)return`ws://${e}:${t}`;if(t=Hg("replication_secureport"),t)return`wss://${e}:${t}`;if(t=Hg("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=Hg("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($e))r(n);return hp(n=>{r(n)}),Al((n,s)=>{r(n.databaseName)});function r(n){let s=$e[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=$e[e];for(let r in t)if(t[r].replicate)return!0}function ap(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=>Ep(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 Ns,cr,GF,qF,Fg,$F,VF,KF,kie,Fie,Sl,Ha,mp,kF,RN,kg,Zn=be(()=>{De();ga();hu();SN();Kr();Ns=M(ce()),cr=M(W()),GF=require("crypto"),qF=require("fs");up();hl();H();jO();Fg=M(require("node:tls")),$F=M(pe()),VF=require("worker_threads"),kie=1,Fie=[],Sl=Ns.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1?new Set(Fg.rootCertificates):new Set;a(Gie,"start");a(YF,"monitorNodeCAs");a(qie,"disableReplication");a($ie,"assignReplicationSource");a(zF,"setReplicator");mp=new Map;a(jF,"getConnection");kF=new Map;a(Vie,"getConnectionByName");a(Ep,"sendOperationToNode");a(ad,"subscribeToNode");a(Ng,"unsubscribeFromNode");a(Kie,"getCommonNameFromCert");a(Ze,"getThisNodeName");a(Yie,"clearThisNodeName");Object.defineProperty(We,"hostname",{get(){return Ze()}});a(FF,"getHostFromListeningPort");a(Hg,"getPortFromListeningPort");a(Bg,"getThisNodeId");We.replication={getThisNodeId:Bg,exportIdMapping:op};a(Ma,"getThisNodeUrl");a(Gg,"hostnameToUrl");a(ci,"urlToNodeName");a(La,"forEachReplicatedDatabase");a(Wie,"hasExplicitlyReplicatedTable");a(ap,"lastTimeInAuditStore");a(zie,"replicateOperation")});var Yg=I((aDe,eG)=>{"use strict";var _d=lk(),{validateBySchema:gp}=it(),{common_validators:pd,schema_regex:yN}=Li(),lr=require("joi"),jie=W(),Jie=require("uuid").v4,Vg=Ao(),hd=(H(),P(G)),Qie=require("util"),Fa=Kn(),{handleHDBError:Co,hdb_errors:Xie,ClientError:Sp}=pe(),{HDB_ERROR_MSGS:qg,HTTP_STATUS_CODES:Po}=Xie,{SchemaEventMsg:Kg}=ni(),JF=ir(),{getDatabases:Zie}=(De(),P(nt)),{transformReq:md}=ae(),{replicateOperation:QF}=(Zn(),P(Io)),$g=lr.string().min(1).max(pd.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+pd.schema_format.message}),eoe=lr.string().min(1).max(pd.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+pd.schema_format.message}).required(),toe=lr.string().min(1).max(pd.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+pd.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 Vg.signalSchemaChange(new Kg(process.pid,e.operation,e.schema)),t}a(roe,"createSchema");async function XF(e){let t=gp(e,lr.object({database:$g,schema:$g}));if(t)throw new Sp(t.message);if(md(e),!await _d.checkSchemaExists(e.schema))throw Co(new Error,qg.SCHEMA_EXISTS_ERR(e.schema),Po.BAD_REQUEST,hd.LOG_LEVELS.ERROR,qg.SCHEMA_EXISTS_ERR(e.schema),!0);return await Fa.createSchema(e),`database '${e.schema}' successfully created`}a(XF,"createSchemaStructure");async function noe(e){return md(e),e.hash_attribute=e.primary_key??e.hash_attribute,await ZF(e)}a(noe,"createTable");async function ZF(e){let t=gp(e,lr.object({database:$g,schema:$g,table:eoe,residence:lr.array().items(lr.string().min(1)).optional(),hash_attribute:toe}));if(t)throw new Sp(t.message);if(!await _d.checkSchemaTableExists(e.schema,e.table))throw Co(new Error,qg.TABLE_EXISTS_ERR(e.schema,e.table),Po.BAD_REQUEST,hd.LOG_LEVELS.ERROR,qg.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 Fa.createTable(n,e);else throw Co(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Po.BAD_REQUEST);else await Fa.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(ZF,"createTableStructure");async function soe(e){let t=gp(e,lr.object({database:lr.string(),schema:lr.string()}).or("database","schema").messages({"object.missing":"'database' is required"}));if(t)throw new Sp(t.message);md(e);let r=await _d.checkSchemaExists(e.schema);if(r)throw Co(new Error,r,Po.NOT_FOUND,hd.LOG_LEVELS.ERROR,r,!0);let n=await _d.schema_describe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await Fa.dropSchema(e),Vg.signalSchemaChange(new Kg(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=gp(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required()}));if(t)throw new Sp(t.message);md(e);let r=await _d.checkSchemaTableExists(e.schema,e.table);if(r)throw Co(new Error,r,Po.NOT_FOUND,hd.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(ioe,"dropTable");async function ooe(e){let t=gp(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required(),attribute:lr.string().required()}));if(t)throw new Sp(t.message);md(e);let r=await _d.checkSchemaTableExists(e.schema,e.table);if(r)throw Co(new Error,r,Po.NOT_FOUND,hd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Co(new Error,"You cannot drop a hash attribute",Po.BAD_REQUEST,void 0,void 0,!0);if(hd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Co(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Po.BAD_REQUEST,void 0,void 0,!0);try{return await Fa.dropAttribute(e),aoe(e),Vg.signalSchemaChange(new Kg(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){md(e);let t=Zie()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Co(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Po.BAD_REQUEST,void 0,void 0,!0);return await Fa.createAttribute(e),Vg.signalSchemaChange(new Kg(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 Fa.getBackup(e)}a(loe,"getBackup")});var rG=I((lDe,tG)=>{"use strict";var{OPERATIONS_ENUM:uoe}=(H(),P(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=I((fDe,aG)=>{"use strict";var doe=Kn(),dDe=rG(),Wg=ae(),zg=(H(),P(G)),foe=ce(),{handleHDBError:nG,hdb_errors:_oe}=pe(),{HDB_ERROR_MSGS:sG,HTTP_STATUS_CODES:iG}=_oe,poe=Object.values(zg.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(Wg.isEmpty(e.schema))throw new Error(sG.SCHEMA_REQUIRED_ERR);if(Wg.isEmpty(e.table))throw new Error(sG.TABLE_REQUIRED_ERR);if(!foe.get(zg.CONFIG_PARAMS.LOGGING_AUDITLOG))throw nG(new Error,oG,iG.BAD_REQUEST,zg.LOG_LEVELS.ERROR,oG,!0);let t=Wg.checkSchemaTableExist(e.schema,e.table);if(t)throw nG(new Error,t,iG.NOT_FOUND,zg.LOG_LEVELS.ERROR,t,!0);if(!Wg.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=I((pDe,cG)=>{"use strict";var{OPERATIONS_ENUM:moe}=(H(),P(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=I((gDe,dG)=>{"use strict";var Eoe=Kn(),mDe=lG(),wN=ae(),goe=(H(),P(G)),EDe=ce(),{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=I((TDe,hG)=>{"use strict";var yoe=ce(),Ga=require("joi"),boe=it(),_G=require("moment"),Ooe=require("fs-extra"),IN=require("path"),Noe=require("lodash"),Tp=(H(),P(G)),{LOG_LEVELS:Rl}=(H(),P(G)),woe="YYYY-MM-DD hh:mm:ss",Ioe=IN.resolve(__dirname,"../logs");hG.exports=function(e){return boe.validateBySchema(e,Coe)};var Coe=Ga.object({from:Ga.custom(pG),until:Ga.custom(pG),level:Ga.valid(Rl.NOTIFY,Rl.FATAL,Rl.ERROR,Rl.WARN,Rl.INFO,Rl.DEBUG,Rl.TRACE),order:Ga.valid("asc","desc"),limit:Ga.number().min(1),start:Ga.number().min(0),log_name:Ga.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(Tp.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=yoe.get(Tp.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Tp.LOG_NAMES.HDB:e,i=s===Tp.LOG_NAMES.INSTALL?IN.join(Ioe,Tp.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=I((RDe,gG)=>{"use strict";var jg=(H(),P(G)),Doe=W(),Loe=ce(),Moe=mG(),CN=require("path"),EG=require("fs-extra"),{once:voe}=require("events"),{handleHDBError:Uoe,hdb_errors:xoe}=pe(),{PACKAGE_ROOT:Boe}=st(),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(jg.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?jg.LOG_NAMES.HDB:e.log_name,s=n===jg.LOG_NAMES.INSTALL?CN.join(Hoe,jg.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=[],A="",N;g.on("data",F=>{let $=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;F=A+F;let Y=0,ee;for(;(ee=$.exec(F))&&!g.destroyed;){N&&(N.message=F.slice(Y,ee.index),v(N));let[oe,j,se]=ee,z=se.split("] ["),me=z[0],Ae=z[1];z.splice(0,2),N={timestamp:j,thread:me,level:Ae,tags:z,message:""},Y=ee.index+oe.length}A=F.slice(Y)}),g.on("end",F=>{g.destroyed||N&&(N.message=A.trim(),v(N))}),g.resume();function v(F){let $,Y,ee;switch(!0){case(i&&c&&u):$=new Date(F.timestamp),Y=new Date(l),ee=new Date(f),F.level===o&&$>=Y&&$<=ee&&R<_?R++:F.level===o&&$>=Y&&$<=ee&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(i&&c):$=new Date(F.timestamp),Y=new Date(l),F.level===o&&$>=Y&&R<_?R++:F.level===o&&$>=Y&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(i&&u):$=new Date(F.timestamp),ee=new Date(f),F.level===o&&$<=ee&&R<_?R++:F.level===o&&$<=ee&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(c&&u):$=new Date(F.timestamp),Y=new Date(l),ee=new Date(f),$>=Y&&$<=ee&&R<_?R++:$>=Y&&$<=ee&&(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:$=new Date(F.timestamp),Y=new Date(l),$>=Y&&R<_?R++:$>=Y&&R>=_&&(qa(F,p,E),R++,R===h&&g.destroy());break;case u:$=new Date(F.timestamp),ee=new Date(f),$<=ee&&R<_?R++:$<=ee&&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 voe(g,"close"),E}a(Goe,"readLog");function qa(e,t,r){t==="desc"?qoe(e,r):t==="asc"?$oe(e,r):r.push(e)}a(qa,"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=I((IDe,RG)=>{"use strict";var DN=require("joi"),{string:Ed,boolean:SG,date:Voe}=DN.types(),Koe=it(),{validateSchemaExists:bDe,validateTableExists:ODe,validateSchemaName:NDe}=Li(),Yoe=(H(),P(G)),Woe=St(),TG=ce();TG.initSync();var wDe=Ed.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:Ed.valid("add_node","update_node","set_node_replication"),node_name:Ed.optional(),subscriptions:DN.array().items({table:Ed.optional(),schema:Ed.optional(),database:Ed.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 gd=I((PDe,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=I((LDe,bG)=>{"use strict";var Joe=(H(),P(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 Ap=I((vDe,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=I((xDe,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=I((qDe,CG)=>{"use strict";var Qoe=IG(),HDe=xt(),kDe=ft(),Xoe=W(),{getSchemaPath:FDe,getTransactionAuditStorePath:GDe}=Et(),{getDatabases:Zoe}=(De(),P(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=I((VDe,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 Do=I((JDe,xG)=>{"use strict";var tae=require("fs-extra"),rae=require("path"),Zr=require("systeminformation"),$a=W(),MG=ir(),YDe=St(),Sd=(H(),P(G)),nae=PG(),sae=So(),{getThreadInfo:vG}=rt(),Rp=ce();Rp.initSync();var iae=LG(),{openEnvironment:WDe}=ft(),{getSchemaPath:zDe}=Et(),{database:jDe,databases:kN}=(De(),P(nt)),Qg;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 Zr.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 Zr.cpu();f.cpu_speed=await Zr.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 Zr.currentLoad();return E.cpus=[],R.forEach(A=>{let{raw_load:N,raw_load_idle:v,raw_load_irq:F,raw_load_nice:$,raw_load_system:Y,raw_load_user:ee,...oe}=A;E.cpus.push(oe)}),f.current_load=E,f}catch(e){return $a.error(`error in getCPUInfo: ${e}`),{}}}a(GN,"getCPUInfo");async function qN(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Zr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return $a.error(`error in getMemoryInfo: ${e}`),{}}}a(qN,"getMemoryInfo");async function $N(){let e={core:[],clustering:[]};try{let t=await Zr.processes(),r;try{r=Number.parseInt(await tae.readFile(rae.join(Rp.get(Sd.CONFIG_PARAMS.ROOTPATH),Sd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Sd.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($N,"getHDBProcessInfo");async function VN(){let e={};try{if(!Rp.get(Sd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Zr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Zr.fsStats();return e.read_write=u,e.size=await Zr.fsSize(),e}catch(t){return $a.error(`error in getDiskInfo: ${t}`),e}}a(VN,"getDiskInfo");async function KN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Rp.get(Sd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Zr.networkInterfaceDefault(),e.latency=await Zr.inetChecksite("google.com"),(await Zr.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 Zr.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(KN,"getNetworkInfo");async function YN(){if(Qg!==void 0)return Qg;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Zr.osInfo();e=c;let l=await Zr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,Qg=e,Qg}catch(t){return $a.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){$a.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(zN,"getMetrics");async function UG(){if(Rp.get(Sd.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 Lo=I((tLe,FG)=>{"use strict";var aae=bn(),jN=ae(),cae=require("util"),yl=(H(),P(G)),BG=ce();BG.initSync();var lae=IO(),HG=Wr(),{Node:XDe,NodeSubscription:ZDe}=gd(),uae=Gu(),dae=OG(),{RemotePayloadObject:fae,RemotePayloadSubscription:_ae}=Ap(),{handleHDBError:pae,hdb_errors:hae}=pe(),{HTTP_STATUS_CODES:mae,HDB_ERROR_MSGS:Eae}=hae,gae=si(),Sae=Do(),{packageJson:Tae}=st(),{getDatabases:Aae}=(De(),P(nt)),eLe=cae.promisify(lae.authorize),Rae=HG.searchByHash,yae=HG.searchByValue;FG.exports={isEmpty:bae,getNodeRecord:Oae,upsertNodeRecord:Nae,buildNodePayloads:wae,checkClusteringEnabled:Iae,getAllNodeRecords:Cae,getSystemInfo:Pae,reverseSubscription:kG};function bae(e){return e==null}a(bae,"isEmpty");async function Oae(e){let t=new uae(yl.SYSTEM_SCHEMA_NAME,yl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Rae(t)}a(Oae,"getNodeRecord");async function Nae(e){let t=new dae(yl.SYSTEM_SCHEMA_NAME,yl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return aae.upsert(t)}a(Nae,"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 wae(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(wae,"buildNodePayloads");function Iae(){if(!BG.get(yl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw pae(new Error,Eae.CLUSTERING_NOT_ENABLED,mae.BAD_REQUEST,void 0,void 0,!0)}a(Iae,"checkClusteringEnabled");async function Cae(){let e=new gae(yl.SYSTEM_SCHEMA_NAME,yl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await yae(e))}a(Cae,"getAllNodeRecords");async function Pae(){let e=await Sae.getSystemInformation();return{hdb_version:Tae.version,node_version:e.node_version,platform:e.platform}}a(Pae,"getSystemInfo")});var JN=I((nLe,zG)=>{"use strict";var Xg=ir(),GG=ae(),qG=St(),$G=(H(),P(G)),Zg=W(),VG=Yg(),Dae=U_(),{RemotePayloadObject:Lae}=Ap(),{handleHDBError:KG,hdb_errors:Mae}=pe(),{HTTP_STATUS_CODES:YG}=Mae,{NodeSubscription:WG}=gd();zG.exports=vae;async function vae(e,t){let r;try{r=await Xg.request(`${t}.${qG.REQUEST_SUFFIX}`,new Lae($G.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Zg.trace("Response from remote describe all request:",r)}catch(o){Zg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Xg.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 Xg.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&&(Zg.trace(`addNode creating schema: ${l}`),await VG.createSchema({operation:"create_schema",schema:l})),!d&&p){Zg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Dae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await VG.createTable(h)}await Xg.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(vae,"reviewSubscriptions")});var bl={};Ue(bl,{addNodeBack:()=>kae,removeNodeBack:()=>Fae,setNode:()=>Hae});async function Hae(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=Gg(r);let n=(0,JG.validateBySchema)(e,Bae);if(n)throw(0,Mo.handleHDBError)(n,n.message,xae.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=or(),S=await h.get(_);if(!S)throw new Mo.ClientError(_+" does not exist");try{await Ep({url:S.url},{operation:Kt.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Ze():_},void 0)}catch(g){ts.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,ws.getReplicationCert)();let _=await(0,ws.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ws.createCsr)(),ts.info("Sending CSR to target node:",t)):_&&(c=_.certificate,ts.info("Sending CA named",_.name,"to target node",t))}let l={operation:Kt.ADD_NODE_BACK,hostname:(0,Ka.get)(x.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if((0,Ka.get)(x.REPLICATION_SHARD)!==void 0&&(l.shard=(0,Ka.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 Ep({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,ts.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&&(ts.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,ws.setCertTable)({name:Uae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,ws.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,Ka.get)(x.REPLICATION_SHARD)!==void 0&&(_.shard=(0,Ka.get)(x.REPLICATION_SHARD)),e.retain_authorization&&(_.authorization=e.authorization),e.start_time&&(_.start_time=e.start_time),await No(Ze(),_)}await No(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 kae(e){ts.trace("addNodeBack received request:",e);let t=await(0,ws.signCertificate)(e),r;e.csr?(r=t.signingCA,ts.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,ts.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,ws.getReplicationCertAuth)();if(n.replicates){let i={url:Ma(),ca:s?.certificate,replicates:!0,subscriptions:null};(0,Ka.get)(x.REPLICATION_SHARD)!==void 0&&(i.shard=(0,Ka.get)(x.REPLICATION_SHARD)),e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await No(Ze(),i)}return await No(e.hostname,n),t.nodeName=Ze(),t.usingCA=s?.certificate,ts.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Fae(e){ts.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 ws,JG,Va,Ka,ts,Mo,Uae,xae,Bae,Ol=be(()=>{ws=M(es()),JG=M(it()),Va=M(require("joi")),Ka=M(ce());H();up();hl();Zn();ts=M(W()),Mo=M(pe()),{pki:Uae}=require("node-forge"),{HTTP_STATUS_CODES:xae}=Mo.hdb_errors,Bae=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(Hae,"setNode");a(kae,"addNodeBack");a(Fae,"removeNodeBack");a(jG,"reverseSubscription")});var Td=I((fLe,XG)=>{"use strict";var{handleHDBError:eS,hdb_errors:Gae}=pe(),{HTTP_STATUS_CODES:tS}=Gae,{addUpdateNodeValidator:qae}=Jg(),rS=W(),nS=(H(),P(G)),QG=St(),$ae=ae(),yp=ir(),bp=Lo(),QN=ce(),Vae=JN(),{Node:Kae,NodeSubscription:Yae}=gd(),{broadcast:Wae}=rt(),{setNode:zae}=(Ol(),P(bl)),uLe=ce(),dLe=(H(),P(G)),jae="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Jae="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Qae=QN.get(nS.CONFIG_PARAMS.CLUSTERING_NODENAME);XG.exports=Xae;async function Xae(e,t=!1){if(rS.trace("addNode called with:",e),QN.get(nS.CONFIG_PARAMS.REPLICATION_URL)||QN.get(nS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return zae(e);bp.checkClusteringEnabled();let r=qae(e);if(r)throw eS(r,r.message,tS.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await bp.getNodeRecord(n);if(!$ae.isEmptyOrZeroLength(d))throw eS(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,tS.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Vae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=jae,o;let c=bp.buildNodePayloads(s,Qae,nS.OPERATIONS_ENUM.ADD_NODE,await bp.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 Yae(_.schema,_.table,_.publish,_.subscribe))}rS.trace("addNode sending remote payload:",c);let u;try{u=await yp.request(`${n}.${QG.REQUEST_SUFFIX}`,c)}catch(d){rS.error(`addNode received error from request: ${d}`);for(let _=0,h=s.length;_<h;_++){let S=s[_];S.publish=!1,S.subscribe=!1,await yp.updateRemoteConsumer(S,n)}let p=yp.requestErrorHandler(d,"add_node",n);throw eS(new Error,p,tS.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 eS(new Error,d,tS.INTERNAL_SERVER_ERROR,"error",d)}rS.trace(u);for(let d=0,p=s.length;d<p;d++){let _=s[d];await yp.updateRemoteConsumer(_,n),_.subscribe===!0&&await yp.updateConsumerIterator(_.schema,_.table,n,"start")}let f=new Kae(n,l,u.system_info);return await bp.upsertNodeRecord(f),Wae({type:"nats_update"}),i.length>0?o.message=Jae:o.message=`Successfully added '${n}' to manifest`,o}a(Xae,"addNode")});var tw=I((hLe,eq)=>{"use strict";var{handleHDBError:XN,hdb_errors:Zae}=pe(),{HTTP_STATUS_CODES:ZN}=Zae,{addUpdateNodeValidator:ece}=Jg(),Op=W(),sS=(H(),P(G)),ZG=St(),pLe=ae(),Np=ir(),wp=Lo(),ew=ce(),{cloneDeep:tce}=require("lodash"),rce=JN(),{Node:nce,NodeSubscription:sce}=gd(),{broadcast:ice}=rt(),{setNode:oce}=(Ol(),P(bl)),ace="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",cce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",lce=ew.get(sS.CONFIG_PARAMS.CLUSTERING_NODENAME);eq.exports=uce;async function uce(e){if(Op.trace("updateNode called with:",e),ew.get(sS.CONFIG_PARAMS.REPLICATION_URL)??ew.get(sS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return oce(e);wp.checkClusteringEnabled();let t=ece(e);if(t)throw XN(t,t.message,ZN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await wp.getNodeRecord(r);s.length>0&&(n=tce(s));let{added:i,skipped:o}=await rce(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=ace,c;let l=wp.buildNodePayloads(i,lce,sS.OPERATIONS_ENUM.UPDATE_NODE,await wp.getSystemInfo());for(let f=0,d=i.length;f<d;f++){let p=i[f];Op.trace(`updateNode updating work stream for node: ${r} subscription:`,p),i[f].start_time===void 0&&delete i[f].start_time}Op.trace("updateNode sending remote payload:",l);let u;try{u=await Np.request(`${r}.${ZG.REQUEST_SUFFIX}`,l)}catch(f){Op.error(`updateNode received error from request: ${f}`);let d=Np.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)}Op.trace(u);for(let f=0,d=i.length;f<d;f++){let p=i[f];await Np.updateRemoteConsumer(p,r),p.subscribe===!0?await Np.updateConsumerIterator(p.schema,p.table,r,"start"):await Np.updateConsumerIterator(p.schema,p.table,r,"stop")}return n||(n=[new nce(r,[],u.system_info)]),await dce(n[0],i,u.system_info),o.length>0?c.message=cce:c.message=`Successfully updated '${r}'`,c}a(uce,"updateNode");async function dce(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 sce(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await wp.upsertNodeRecord(n),ice({type:"nats_update"})}a(dce,"updateNodeTable")});var iq=I((ELe,sq)=>{"use strict";var nq=require("joi"),{string:tq}=nq.types(),fce=it(),rq=(H(),P(G)),_ce=ce(),pce=St();sq.exports=hce;function hce(e){let t=tq.invalid(_ce.get(rq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(pce.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 fce.validateBySchema(e,r)}a(hce,"removeNodeValidator")});var iS=I((SLe,uq)=>{"use strict";var{handleHDBError:oq,hdb_errors:mce}=pe(),{HTTP_STATUS_CODES:aq}=mce,Ece=iq(),Ip=W(),cq=Lo(),gce=ae(),Ad=(H(),P(G)),lq=St(),rw=ir(),nw=ce(),{RemotePayloadObject:Sce}=Ap(),{NodeSubscription:Tce}=gd(),Ace=v_(),Rce=jc(),{broadcast:yce}=rt(),{setNode:bce}=(Ol(),P(bl)),Oce=nw.get(Ad.CONFIG_PARAMS.CLUSTERING_NODENAME);uq.exports=Nce;async function Nce(e){if(Ip.trace("removeNode called with:",e),nw.get(Ad.CONFIG_PARAMS.REPLICATION_URL)??nw.get(Ad.CONFIG_PARAMS.REPLICATION_HOSTNAME))return bce(e);cq.checkClusteringEnabled();let t=Ece(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(gce.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 Sce(Ad.OPERATIONS_ENUM.REMOVE_NODE,Oce,[]),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 Tce(f.schema,f.table,!1,!1),r)}catch(d){Ip.error(d)}}try{i=await rw.request(`${r}.${lq.REQUEST_SUFFIX}`,s),Ip.trace("Remove node reply from remote node:",r,i)}catch(l){Ip.error("removeNode received error from request:",l),o=!0}let c=new Ace(Ad.SYSTEM_SCHEMA_NAME,Ad.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Rce.deleteRecord(c),yce({type:"nats_update"}),i?.status===lq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Ip.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(Nce,"removeNode")});var _q=I((ALe,fq)=>{"use strict";var dq=require("joi"),{string:wce,array:Ice}=dq.types(),Cce=it(),Pce=Jg();fq.exports=Dce;function Dce(e){let t=dq.object({operation:wce.valid("configure_cluster").required(),connections:Ice.items(Pce.validation_schema).required()});return Cce.validateBySchema(e,t)}a(Dce,"configureClusterValidator")});var sw=I((yLe,gq)=>{"use strict";var pq=(H(),P(G)),oS=W(),Lce=ae(),Mce=ce(),vce=iS(),Uce=Td(),xce=Lo(),Bce=_q(),{handleHDBError:hq,hdb_errors:Hce}=pe(),{HTTP_STATUS_CODES:mq}=Hce,kce="Configure cluster complete.",Fce="Failed to configure the cluster. Check the logs for more details.",Gce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";gq.exports=qce;async function qce(e){oS.trace("configure cluster called with:",e);let t=Bce(e);if(t)throw hq(t,t.message,mq.BAD_REQUEST,void 0,void 0,!0);let r=await xce.getAllNodeRecords(),n=[];if(Mce.get(pq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let p=await Eq(vce,{operation:pq.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name);n.push(p)}oS.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(Uce,d,d.node_name);s.push(p)}oS.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"&&(oS.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(Lce.isEmptyOrZeroLength(o))return{message:kce,connections:c};if(l)return{message:Gce,failed_nodes:o,connections:c};throw hq(new Error,Fce,mq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(qce,"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=I((OLe,Aq)=>{"use strict";var Cp=require("joi"),$ce=it(),{validateSchemaExists:Sq,validateTableExists:Vce,validateSchemaName:Tq}=Li(),Kce=Cp.object({operation:Cp.string().valid("purge_stream"),schema:Cp.string().custom(Sq).custom(Tq).optional(),database:Cp.string().custom(Sq).custom(Tq).optional(),table:Cp.string().custom(Vce).required()});function Yce(e){return $ce.validateBySchema(e,Kce)}a(Yce,"purgeStreamValidator");Aq.exports=Yce});var iw=I((wLe,yq)=>{"use strict";var{handleHDBError:Wce,hdb_errors:zce}=pe(),{HTTP_STATUS_CODES:jce}=zce,Jce=Rq(),Qce=ir(),Xce=Lo();yq.exports=Zce;async function Zce(e){e.schema=e.schema??e.database;let t=Jce(e);if(t)throw Wce(t,t.message,jce.BAD_REQUEST,void 0,void 0,!0);Xce.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await Qce.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(Zce,"purgeStream")});var lS=I((CLe,Pq)=>{"use strict";var aw=Lo(),ele=ir(),cS=ce(),Rd=(H(),P(G)),Nl=St(),tle=ae(),ow=W(),{RemotePayloadObject:rle}=Ap(),{ErrorCode:bq}=require("nats"),{parentPort:Oq}=require("worker_threads"),{onMessageByType:nle}=rt(),{getThisNodeName:sle}=(Zn(),P(Io)),{requestClusterStatus:ile}=(up(),P(jk)),{getReplicationSharedStatus:ole,getHDBNodeTable:ale}=(hl(),P(JO)),{CONFIRMATION_STATUS_POSITION:cle,RECEIVED_VERSION_POSITION:lle,RECEIVED_TIME_POSITION:ule,SENDING_TIME_POSITION:dle}=(SN(),P(BF)),Nq=cS.get(Rd.CONFIG_PARAMS.CLUSTERING_ENABLED),wq=cS.get(Rd.CONFIG_PARAMS.CLUSTERING_NODENAME);Pq.exports={clusterStatus:fle,buildNodeStatus:Cq};var Iq;nle("cluster-status",async e=>{Iq(e)});async function fle(){if(cS.get(Rd.CONFIG_PARAMS.REPLICATION_URL)||cS.get(Rd.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=ole(u,l,o);c.lastCommitConfirmed=aS(f[cle]),c.lastReceivedRemoteTime=aS(f[lle]),c.lastReceivedLocalTime=aS(f[ule]),c.sendingMessage=aS(f[dle])}}}else n=ile();n.node_name=sle();let s=ale().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(tle.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(fle,"clusterStatus");function aS(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}a(aS,"asDate");async function Cq(e,t){let r=e.name,n=new rle(Rd.OPERATIONS_ENUM.CLUSTER_STATUS,wq,void 0,await aw.getSystemInfo()),s,i,o=Nl.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await ele.request(Nl.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Nl.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Nl.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=Nl.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===bq.Timeout?o=Nl.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Nl.CLUSTER_STATUS_STATUSES.CLOSED}let c=new _le(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!==Rd.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 _le(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(_le,"NodeStatusObject")});var dS=I((DLe,Dq)=>{"use strict";var{handleHDBError:ple,hdb_errors:hle}=pe(),{HTTP_STATUS_CODES:mle}=hle,Ele=ir(),gle=Lo(),cw=ae(),uS=require("joi"),Sle=it(),Tle=2e3,Ale=uS.object({timeout:uS.number().min(1),connected_nodes:uS.boolean(),routes:uS.boolean()});Dq.exports=Rle;async function Rle(e){gle.checkClusteringEnabled();let t=Sle.validateBySchema(e,Ale);if(t)throw ple(t,t.message,mle.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 Ele.getServerList(r??Tle),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(Rle,"clusterNetwork")});var Uq=I((MLe,vq)=>{"use strict";var lw=require("joi"),Lq=it(),{route_constraints:Mq}=Wy();vq.exports={setRoutesValidator:yle,deleteRoutesValidator:ble};function yle(e){let t=lw.object({server:lw.valid("hub","leaf"),routes:Mq.required()});return Lq.validateBySchema(e,t)}a(yle,"setRoutesValidator");function ble(e){let t=lw.object({routes:Mq.required()});return Lq.validateBySchema(e,t)}a(ble,"deleteRoutesValidator")});var fS=I((ULe,qq)=>{"use strict";var vo=Rt(),uw=ae(),Is=(H(),P(G)),yd=ce(),xq=Uq(),{handleHDBError:Bq,hdb_errors:Ole}=pe(),{HTTP_STATUS_CODES:Hq}=Ole,kq="cluster routes successfully set",Fq="cluster routes successfully deleted";qq.exports={setRoutes:wle,getRoutes:Ile,deleteRoutes:Cle};function Nle(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=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"?vo.updateConfigValue(Is.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):vo.updateConfigValue(Is.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:kq,set:i,skipped:s}}a(Nle,"setRoutesNats");function wle(e){let t=xq.setRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(yd.get(Is.CONFIG_PARAMS.CLUSTERING_ENABLED))return Nle(e);let r=[],n=[],s=yd.get(Is.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Gq(s,i)?n.push(i):(s.push(i),r.push(i))}),vo.updateConfigValue(Is.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:kq,set:r,skipped:n}}a(wle,"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 Ile(){if(yd.get(Is.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=vo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return yd.get(Is.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Ile,"getRoutes");function Cle(e){let t=xq.deleteRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(yd.get(Is.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ple(e);let r=[],n=[],s=yd.get(Is.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Gq(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),vo.updateConfigValue(Is.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Fq,deleted:r,skipped:n}}a(Cle,"deleteRoutes");function Ple(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=uw.isEmptyOrZeroLength(r)?null:r,vo.updateConfigValue(Is.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=uw.isEmptyOrZeroLength(n)?null:n,vo.updateConfigValue(Is.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Fq,deleted:s,skipped:i}}a(Ple,"deleteRoutesNats")});var Vq=I((BLe,$q)=>{"use strict";var Pp=require("alasql"),wl=require("recursive-iterator"),di=W(),Dle=ae(),Dp=(H(),P(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,Mle(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=>Dp.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=>!Dp.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][Dp.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Lle(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=>!Dp.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let f=new Pp.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 Lle(e){return e.filter(t=>t[Dp.PERMS_CRUD_ENUM.READ])}a(Lle,"filterReadRestrictedAttrs");function Mle(e,t,r,n,s){vle(e,t,r,n,s)}a(Mle,"interpretAST");function Lp(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(Lp,"addSchemaTableToMap");function vle(e,t,r,n,s){if(!e){di.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Pp.yy.Insert?Hle(e,t,r):e instanceof Pp.yy.Select?Ule(e,t,r,n,s):e instanceof Pp.yy.Update?xle(e,t,r):e instanceof Pp.yy.Delete?Ble(e,t,r):di.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(vle,"getRecordAttributesAST");function Ule(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(Dle.isEmptyOrZeroLength(i)){di.error("No schema specified");return}e.from.forEach(c=>{Lp(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Lp(c.table,t,r,n,s)});let o=new wl(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 wl(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 wl(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 wl(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(Ule,"getSelectAttributes");function xle(e,t,r){if(!e){di.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new wl(e.columns),s=e.table.databaseid;Lp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.table.tableid,s,i.columnid,t,r)}a(xle,"getUpdateAttributes");function Ble(e,t,r){if(!e){di.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new wl(e.where),s=e.table.databaseid;Lp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.table.tableid,s,i.columnid,t,r)}a(Ble,"getDeleteAttributes");function Hle(e,t,r){if(!e){di.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new wl(e.columns),s=e.into.databaseid;Lp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.into.tableid,s,i.columnid,t,r)}a(Hle,"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=I((kLe,Kq)=>{"use strict";var _S=(H(),P(G)),pS=class{static{a(this,"BaseLicense")}constructor(t=0,r=_S.RAM_ALLOCATION_ENUM.DEFAULT,n=_S.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},_w=class extends pS{static{a(this,"ExtendedLicense")}constructor(t=0,r=_S.RAM_ALLOCATION_ENUM.DEFAULT,n=_S.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};Kq.exports={BaseLicense:pS,ExtendedLicense:_w}});var Nd=I((GLe,Xq)=>{"use strict";var Od=require("fs-extra"),hS=(mE(),P(hE)),zq=require("crypto"),kle=require("moment"),Fle=require("uuid").v4,en=W(),hw=require("path"),Gle=ae(),Il=(H(),P(G)),{totalmem:Wq}=require("os"),qle=Yq().ExtendedLicense,bd="invalid license key format",$le="061183",Vle="mofi25",Kle="aes-256-cbc",Yle=16,Wle=32,jq=ce(),{resolvePath:Jq}=Rt();jq.initSync();var pw;Xq.exports={validateLicense:Qq,generateFingerPrint:jle,licenseSearch:gw,getLicense:Xle,checkMemoryLimit:Zle};function mw(){return hw.join(jq.getHdbBasePath(),Il.LICENSE_KEY_DIR_NAME,Il.LICENSE_FILE_NAME)}a(mw,"getLicenseDirPath");function zle(){let e=mw();return Jq(hw.join(e,Il.LICENSE_FILE_NAME))}a(zle,"getLicenseFilePath");function Ew(){let e=mw();return Jq(hw.join(e,Il.REG_KEY_FILE_NAME))}a(Ew,"getFingerPrintFilePath");async function jle(){let e=Ew();try{return await Od.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Jle();throw en.error(`Error writing fingerprint file to ${e}`),en.error(t),new Error("There was an error generating the fingerprint")}}a(jle,"generateFingerPrint");async function Jle(){let e=Fle(),t=hS.hash(e,hS.HASH_FUNCTION.MD5),r=Ew();try{await Od.mkdirp(mw()),await Od.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw en.error(`Error writing fingerprint file to ${r}`),en.error(n),new Error("There was an error generating the fingerprint")}return t}a(Jle,"writeFingerprint");function Qq(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Il.RAM_ALLOCATION_ENUM.DEFAULT,version:Il.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return en.error("empty license key passed to validate."),r;let n=Ew(),s=!1;try{s=Od.statSync(n)}catch(i){en.error(i)}if(s){let i;try{i=Od.readFileSync(n,"utf8")}catch{en.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(Vle),c=o[1];c=Buffer.concat([Buffer.from(c)],Yle);let l=Buffer.concat([Buffer.from(i)],Wle),u=zq.createDecipheriv(Kle,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 _=Qle(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(bd),en.error(bd),new Error(bd)}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(bd),en.error(bd),new Error(bd)}else r.exp_date=f;r.exp_date<kle().valueOf()&&(r.valid_date=!1),hS.validate(o[1],`${$le}${i}${t}`,hS.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||en.error("Invalid licence"),r}a(Qq,"validateLicense");function Qle(e,t){try{let r=zq.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{en.warn("Check old license failed")}}a(Qle,"checkOldLicense");function gw(){let e=new qle,t=[];try{t=Od.readFileSync(zle(),"utf-8").split(`\r
|
|
25
|
+
`)}catch(r){r.code==="ENOENT"?en.debug("no license file found"):en.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(Gle.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){en.error("There was an error parsing the license string."),en.error(s),e.ram_allocation=Il.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return pw=e,e}a(gw,"licenseSearch");async function Xle(){return pw||await gw(),pw}a(Xle,"getLicense");function Zle(){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(Zle,"checkMemoryLimit")});var ES=I(($Le,r$)=>{var mS=Nd(),Zq=require("chalk"),rs=W(),e$=require("prompt"),{promisify:eue}=require("util"),Sw=(H(),P(G)),tue=require("fs-extra"),rue=require("path"),nue=ae(),{packageJson:sue}=st(),t$=ce();t$.initSync();var iue=require("moment"),oue=eue(e$.get),aue=rue.join(t$.getHdbBasePath(),Sw.LICENSE_KEY_DIR_NAME,Sw.LICENSE_FILE_NAME,Sw.LICENSE_FILE_NAME);r$.exports={getFingerprint:lue,setLicense:cue,parseLicense:Tw,register:uue,getRegistrationInfo:fue};async function cue(e){if(e&&e.key&&e.company){try{rs.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 rs.error(r),rs.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(cue,"setLicense");async function lue(){let e={};try{e=await mS.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw rs.error(r),rs.error(t),new Error(r)}return e}a(lue,"getFingerprint");async function Tw(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");rs.info("Validating license input...");let r=mS.validateLicense(e,t);if(rs.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(rs.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(rs.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{rs.info("writing license to disk"),await tue.writeFile(aue,JSON.stringify({license_key:e,company:t}))}catch(n){throw rs.error("Failed to write License"),n}return"Registration successful."}a(Tw,"parseLicense");async function uue(){let e=await due();return Tw(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(uue,"register");async function due(){let e=await mS.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){rs.error(n)}let r;try{r=await oue(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(due,"promptForRegistration");async function fue(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await mS.getLicense()}catch(r){throw rs.error(`There was an error when searching licenses due to: ${r.message}`),r}if(nue.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=sue.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=iue.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(fue,"getRegistrationInfo")});var s$=I((KLe,n$)=>{"use strict";var _ue=St(),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+_ue.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$=I((WLe,o$)=>{"use strict";var i$=St(),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$=I((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$=I((QLe,u$)=>{"use strict";var pue=St(),bw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+pue.SERVER_SUFFIX.ADMIN,this.password=r}};u$.exports=bw});var AS=I((ZLe,p$)=>{"use strict";var Cl=require("path"),Pl=require("fs-extra"),hue=s$(),mue=a$(),Eue=l$(),gue=d$(),Ow=yn(),Id=ae(),In=Rt(),SS=(H(),P(G)),Mp=St(),{CONFIG_PARAMS:jt}=SS,Cd=W(),vp=ce(),f$=go(),Nw=ir(),Sue=es(),wd="clustering",Tue=1e4,_$=50;p$.exports={generateNatsConfig:Rue,removeNatsConfig:yue,getHubConfigPath:Aue};function Aue(){let e=vp.get(jt.ROOTPATH);return Cl.join(e,wd,Mp.NATS_CONFIG_FILES.HUB_SERVER)}a(Aue,"getHubConfigPath");async function Rue(e=!1,t=void 0){let r=vp.get(jt.ROOTPATH);Pl.ensureDirSync(Cl.join(r,"clustering","leaf")),vp.initSync();let n=In.getConfigFromFile(jt.CLUSTERING_TLS_CERT_AUTH),s=In.getConfigFromFile(jt.CLUSTERING_TLS_PRIVATEKEY),i=In.getConfigFromFile(jt.CLUSTERING_TLS_CERTIFICATE);!await Pl.exists(i)&&!await Pl.exists(!n)&&await Sue.createNatsCerts();let o=Cl.join(r,wd,Mp.PID_FILES.HUB),c=Cl.join(r,wd,Mp.PID_FILES.LEAF),l=In.getConfigFromFile(jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Cl.join(r,wd,Mp.NATS_CONFIG_FILES.HUB_SERVER),f=Cl.join(r,wd,Mp.NATS_CONFIG_FILES.LEAF_SERVER),d=In.getConfigFromFile(jt.CLUSTERING_TLS_INSECURE),p=In.getConfigFromFile(jt.CLUSTERING_TLS_VERIFY),_=In.getConfigFromFile(jt.CLUSTERING_NODENAME),h=In.getConfigFromFile(jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Nw.checkNATSServerInstalled()||TS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await Ow.listUsers(),g=In.getConfigFromFile(jt.CLUSTERING_USER),R=await Ow.getClusterUser();(Id.isEmpty(R)||R.active!==!0)&&TS(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await gS(jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await gS(jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await gS(jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await gS(jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],A=[];for(let[oe,j]of S.entries())j.role?.role===SS.ROLE_TYPES_ENUM.CLUSTER_USER&&j.active&&(E.push(new gue(j.username,f$.decrypt(j.hash))),A.push(new Eue(j.username,f$.decrypt(j.hash))));let N=[],{hub_routes:v}=In.getClusteringRoutes();if(!Id.isEmptyOrZeroLength(v))for(let oe of v)N.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${oe.host}:${oe.port}`);let F=new hue(In.getConfigFromFile(jt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,p,h,In.getConfigFromFile(jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),In.getConfigFromFile(jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),N,E,A);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=Id.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===SS.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Pl.writeJson(u,F),Cd.trace(`Hub server config written to ${u}`));let $=`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}`,ee=new mue(In.getConfigFromFile(jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[$],[Y],E,A,i,s,n,d);n==null&&delete ee.tls.ca_file,(t===void 0||t===SS.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Pl.writeJson(f,ee),Cd.trace(`Leaf server config written to ${f}`))}a(Rue,"generateNatsConfig");async function gS(e){let t=vp.get(e);return Id.isEmpty(t)&&TS(`port undefined for '${e}'`),await Id.isPortTaken(t)&&TS(`'${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(gS,"isPortAvailable");function TS(e){let t=`Error generating clustering config: ${e}`;Cd.error(t),console.error(t),process.exit(1)}a(TS,"generateNatsConfigError");async function yue(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){Cd.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&&Cd.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Id.async_set_timeout(u)}let c="0".repeat(Tue),l=Cl.join(vp.get(jt.ROOTPATH),wd,r);await Pl.writeFile(l,c),await Pl.remove(l),Cd.notify(e,"started.")}a(yue,"removeNatsConfig")});var T$=I((tMe,S$)=>{"use strict";var ns=ce(),bue=Nd(),Ge=(H(),P(G)),Up=St(),Uo=require("path"),{PACKAGE_ROOT:yS}=st(),h$=ce(),RS=ae(),Pd="/dev/null",Oue=Uo.join(yS,"launchServiceScripts"),m$=Uo.join(yS,"utility/scripts"),Nue=Uo.join(m$,Ge.HDB_RESTART_SCRIPT),E$=Uo.resolve(yS,"dependencies",`${process.platform}-${process.arch}`,Up.NATS_BINARY_NAME);function g$(){let t=bue.licenseSearch().ram_allocation||Ge.RAM_ALLOCATION_ENUM.DEFAULT,r=Ge.MEM_SETTING_KEY+t,n={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return RS.noBootFile()&&(n[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=RS.getEnvCliRootPath()),{name:Ge.PROCESS_DESCRIPTORS.HDB,script:Ge.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:yS}}a(g$,"generateMainServerConfig");var wue=9930;function Iue(){ns.initSync(!0);let e=ns.get(Ge.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",Up.NATS_CONFIG_FILES.HUB_SERVER),r=Uo.join(ns.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=h$.get(Ge.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Up.LOG_LEVEL_FLAGS[ns.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==wue?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return ns.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Pd,i.error_file=Pd),i}a(Iue,"generateNatsHubServerConfig");var Cue=9940;function Pue(){ns.initSync(!0);let e=ns.get(Ge.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",Up.NATS_CONFIG_FILES.LEAF_SERVER),r=Uo.join(ns.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=h$.get(Ge.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Up.LOG_LEVEL_FLAGS[ns.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Cue?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return ns.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Pd,i.error_file=Pd),i}a(Pue,"generateNatsLeafServerConfig");function Due(){ns.initSync();let e=Uo.join(ns.get(Ge.CONFIG_PARAMS.LOGGING_ROOT),Ge.LOG_NAMES.HDB),t={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ge.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Oue,autorestart:!1};return ns.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Pd,t.error_file=Pd),t}a(Due,"generateClusteringUpgradeV4ServiceConfig");function Lue(){let e={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.RESTART_HDB};return RS.noBootFile()&&(e[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=RS.getEnvCliRootPath()),{...{name:Ge.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:m$},script:Nue}}a(Lue,"generateRestart");function Mue(){return{apps:[g$()]}}a(Mue,"generateAllServiceConfigs");S$.exports={generateAllServiceConfigs:Mue,generateMainServerConfig:g$,generateRestart:Lue,generateNatsHubServerConfig:Iue,generateNatsLeafServerConfig:Pue,generateClusteringUpgradeV4ServiceConfig:Due}});var Dd=I((sMe,v$)=>{"use strict";var et=(H(),P(G)),vue=ae(),Bo=AS(),bS=ir(),xo=St(),Ya=T$(),OS=ce(),Dl=W(),Uue=Lo(),{startWorker:A$,onMessageFromWorkers:xue}=rt(),Bue=Do(),nMe=require("util"),Hue=require("child_process"),kue=require("fs"),{execFile:Fue}=Hue,Ke;v$.exports={enterPM2Mode:Gue,start:Wa,stop:ww,reload:y$,restart:b$,list:Iw,describe:w$,connect:Ho,kill:Yue,startAllServices:Wue,startService:Cw,getUniqueServicesList:I$,restartAllServices:zue,isServiceRegistered:C$,reloadStopStart:P$,restartHdb:N$,deleteProcess:Vue,startClusteringProcesses:L$,startClusteringThreads:M$,isHdbRestartRunning:Kue,isClusteringRunning:Jue,stopClustering:jue,reloadClustering:Que,expectedRestartOfChildren:O$};var xp=!1;xue(e=>{e.type==="restart"&&OS.initSync(!0)});function Gue(){xp=!0}a(Gue,"enterPM2Mode");function Ho(){return Ke||(Ke=require("pm2")),new Promise((e,t)=>{Ke.connect((r,n)=>{r&&t(r),e(n)})})}a(Ho,"connect");var tn,que=10,R$;function Wa(e,t=!1){if(xp)return $ue(e);let r=Fue(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=tn.indexOf(r);o>-1&&tn.splice(o,1),!R$&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<que&&(kue.existsSync(Bo.getHubConfigPath())?Wa(e):(await Bo.generateNatsConfig(!0),Wa(e),await new Promise(c=>setTimeout(c,3e3)),await Bo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Bo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=OS.get(et.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?Dl.OUTPUTS.STDERR:Dl.OUTPUTS.STDOUT;Dl.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?Dl.OUTPUTS.STDERR:Dl.OUTPUTS.STDOUT;Dl.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(),!tn&&(tn=[],!t)){let i=a(()=>{R$=!0,tn&&(tn.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)}tn.push(r)}a(Wa,"start");function $ue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.start(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a($ue,"startWithPM2");function ww(e){if(!xp){for(let t of tn||[])t.name===e&&(tn.splice(tn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.stop(e,async(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.delete(e,(i,o)=>{i&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(o)})})})}a(ww,"stop");function y$(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.reload(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(y$,"reload");function b$(e){if(!xp){O$();for(let t of tn||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.restart(e,(n,s)=>{Ke.disconnect(),t(s)})})}a(b$,"restart");function O$(){for(let e of tn||[])e.config&&(e.config.restarts=0)}a(O$,"expectedRestartOfChildren");function Vue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.delete(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(Vue,"deleteProcess");async function N$(){await Wa(Ya.generateRestart())}a(N$,"restartHdb");async function Kue(){let e=await Iw();for(let t in e)if(e[t].name===et.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Kue,"isHdbRestartRunning");function Iw(){return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ke.list((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(Iw,"list");function w$(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.describe(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(w$,"describe");function Yue(){if(!xp){for(let e of tn||[])e.kill();tn=[];return}return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ke.killDaemon((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(Yue,"kill");async function Wue(){try{await L$(),await M$(),await Wa(Ya.generateAllServiceConfigs())}catch(e){throw Ke?.disconnect(),e}}a(Wue,"startAllServices");async function Cw(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case et.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ya.generateMainServerConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ya.generateNatsIngestServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ya.generateNatsReplyServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ya.generateNatsHubServerConfig(),await Wa(r,t),await Bo.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ya.generateNatsLeafServerConfig(),await Wa(r,t),await Bo.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ya.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Wa(r)}catch(r){throw Ke?.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 Ke?.disconnect(),e}}a(I$,"getUniqueServicesList");async function zue(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 Ke?.disconnect(),t}}a(zue,"restartAllServices");async function C$(e){if(tn?.find(r=>r.name===e))return!0;let t=await Bue.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(C$,"isServiceRegistered");async function P$(e){let t=OS.get(et.CONFIG_PARAMS.THREADS_COUNT)??OS.get(et.CONFIG_PARAMS.THREADS),r=await w$(e),n=vue.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 bS.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await bS.updateLocalStreams();let e=await Uue.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===et.PRE_4_0_0_VERSION){Dl.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 jue(){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(jue,"stopClustering");async function Jue(){for(let e in et.CLUSTERING_PROCESSES){let t=et.CLUSTERING_PROCESSES[e];if(await C$(t)===!1)return!1}return!0}a(Jue,"isClusteringRunning");async function Que(){await Bo.generateNatsConfig(!0),await bS.reloadNATSHub(),await bS.reloadNATSLeaf(),await Bo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Bo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Que,"reloadClustering")});var IS={};Ue(IS,{compactOnStart:()=>Xue,copyDb:()=>F$});async function Xue(){za.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,NS.join)(e,"backup",n+".mdb"),o=(0,NS.join)(e,wc,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){za.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,Ll.move)(s,i,{overwrite:!0})}try{Ld()}catch(n){za.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,Ll.move)(i,s,{overwrite:!0}),await(0,Ll.remove)((0,NS.join)(e,wc,`${n}-copy.mdb-lock`));try{Ld()}catch(n){za.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){za.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,Ll.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Ld(),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}`;
|
|
28
|
-
${r.stack}`;throw Uw.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[wn.SYSTEM_SCHEMA_NAME]=n[wn.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]=xw()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=xw()})}),r}a(gde,"translateRolePermissions");function Sde(e){let t=X$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=xw(!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 wn.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;wn.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(B.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 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 Ld.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?kw.notify(g):kw.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&kw.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(_,Ys.SUCCESS,"mTLS")):(0,Ld.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),T=E.indexOf(":");g=E.slice(0,T),R=E.slice(T+1),d=g||R?await Ye.getUser(g,R,e):null;break;case"Bearer":try{d=await OO(S)}catch(b){if(b.message==="invalid token")try{return await cg(S),c({status:-1})}catch{throw b}}break}}catch(E){return wde&&(Cl.get(S)||(Cl.set(S,S),f(g,Ys.FAILURE,h))),c({status:401,body:Aa({error:E.message},e)})}Cl.set(n,d),Nde&&f(d.username,Ys.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")&&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(()=>{Cl=new Map},ns.get(B.AUTHENTICATION_CACHETTL)).unref(),lV.user.addListener(()=>{Cl=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,Ld,lV,kw,Rde,yde,bde,Ode,iV,LS,uV,Nde,wde,Cl,oV,MS=be(()=>{aV=M(An());Vr();Su();ju();Pe();cV=require("uuid"),ns=M(ae());H();Ld=M(z()),lV=M(b_());z_();ao();kw=(0,Ld.loggerWithTag)("auth-event");ns.initSync();Rde=ns.get(B.HTTP_CORSACCESSLIST),yde=ns.get(B.HTTP_CORS),bde=ns.get(B.OPERATIONSAPI_NETWORK_CORSACCESSLIST),Ode=ns.get(B.OPERATIONSAPI_NETWORK_CORS),iV=ft({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),LS=ns.get(B.AUTHENTICATION_ENABLESESSIONS)??!0,uV=process.env.AUTHENTICATION_AUTHORIZELOCAL??ns.get(B.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,Nde=ns.get(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,wde=ns.get(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Cl=new Map;Ye.onInvalidatedUser(()=>{Cl=new Map});a(Ide,"bypassAuth");a(dV,"authentication");a(Cde,"start");a(Pde,"login");a(Dde,"logout")});var gV=w((bMe,EV)=>{"use strict";var Ne=require("joi"),fV=require("fs-extra"),_V=require("path"),ss=it(),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 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 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(vS.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(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 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(vS.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(vS.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((NMe,bV)=>{"use strict";var US=require("joi"),za=require("path"),Md=require("fs-extra"),{exec:zde}=require("child_process"),jde=require("util"),SV=jde.promisify(zde),vd=(H(),C(G)),{PACKAGE_ROOT:Jde}=st(),{handleHDBError:$p,hdb_errors:Qde}=pe(),{HTTP_STATUS_CODES:Vp}=Qde,Pl=ae(),Xde=it(),Dl=z();Pl.initSync();var Fw=Pl.get(vd.CONFIG_PARAMS.COMPONENTSROOT),TV="npm install --force --omit=dev --json",Zde=`${TV} --dry-run`,efe=Pl.get(vd.CONFIG_PARAMS.ROOTPATH),xS=za.join(efe,"ssh");bV.exports={installModules:sfe,auditModules:ife,installAllRootModules:tfe,uninstallRootModule:rfe,linkHarperdb:nfe,runCommand:Ud};async function tfe(e=!1,t=Pl.get(vd.CONFIG_PARAMS.ROOTPATH)){await BS();let r=!1,n=process.env;Md.pathExistsSync(xS)&&Md.readdirSync(xS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+za.join(xS,"config")+" -o UserKnownHostsFile="+za.join(xS,"known_hosts"),...process.env},r=!0)});try{let s=Pl.get(vd.CONFIG_PARAMS.ROOTPATH),i=za.join(s,"node_modules","harperdb");Md.lstatSync(i).isSymbolicLink()&&Md.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Dl.error("Error removing symlink:",s)}await Ud(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(tfe,"installAllRootModules");async function rfe(e){await Ud(`npm uninstall ${e}`,Pl.get(vd.CONFIG_PARAMS.ROOTPATH))}a(rfe,"uninstallRootModule");async function nfe(){await BS(),await Ud(`npm link ${Jde}`,Pl.get(vd.CONFIG_PARAMS.ROOTPATH))}a(nfe,"linkHarperdb");async function Ud(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(Ud,"runCommand");async function sfe(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?Zde: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=za.join(Fw,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}`;za.error(l),console.error(l)}(0,Pw.get)(x.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Ll.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(wS.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=PS(),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 A=o.openDB(p,R);A.encoder=null,console.log("copying",p,"from",e,"to",t),await d(E,A,h,f)}if(i){let p=n.openDB(wS.AUDIT_STORE_NAME,Bp);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,A=null;for(;E-- >0;)try{for(let N of p.getKeys({start:A,transaction:S}))try{A=N;let{value:v,version:F}=p.getEntry(N,{transaction:S});l=_.put(N,v,h?F:void 0),g++,S.openTimer&&(S.openTimer=0),R+=(N?.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 N=="symbol"?"symbol":N,"from",e,"to",t,v)}console.log("finish copying, copied",g,"entries",R,"bytes");return}catch{if(typeof A=="string"){if(A==="z")return console.error("Reached end of dbi",A,"for",e,"to",t);A=A.slice(0,-2)+"z"}else if(typeof A=="number")A++;else return console.error("Unknown key type",A,"for",e,"to",t)}}a(d,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{f.done(),o.close()}}var x$,NS,Ll,Pw,B$,H$,wS,k$,Dw,za,CS=be(()=>{De();x$=require("lmdb"),NS=require("path"),Ll=require("fs-extra"),Pw=M(ce()),B$=M(o_()),H$=M(i_()),wS=M(xt());H();_o();k$=M(So()),Dw=M(Rt()),za=M(W());a(Xue,"compactOnStart");a(U$,"getTotalDBRecordCount");a(F$,"copyDb")});var ja=I((_Me,W$)=>{"use strict";var Zue=require("minimist"),{isMainThread:Mw,parentPort:kp,threadId:uMe}=require("worker_threads"),ot=(H(),P(G)),Ki=W(),vw=ae(),LS=AS(),DS=ir(),dMe=St(),V$=Rt(),fi=Dd(),G$=Do(),{compactOnStart:ede}=(CS(),P(IS)),tde=da(),{restartWorkers:MS,onMessageByType:rde}=rt(),{handleHDBError:nde,hdb_errors:sde}=pe(),{HTTP_STATUS_CODES:ide}=sde,Fp=ce(),{sendOperationToNode:q$,getThisNodeName:ode,monitorNodeCAs:ade}=(Zn(),P(Io)),{getHDBNodeTable:fMe}=(hl(),P(JO));Fp.initSync();var Hp=`Restarting HarperDB. This may take up to ${ot.RESTART_TIMEOUT_MS/1e3} seconds.`,cde="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",lde="Invalid service",Md,Cs;W$.exports={restart:K$,restartService:Uw};Mw&&rde(ot.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){Cs=Object.keys(e).length===0,Md=await fi.isServiceRegistered(ot.PROCESS_DESCRIPTORS.HDB);let t=Zue(process.argv);if(t.service){await Uw(t);return}if(Cs&&!Md){console.error(cde);return}if(Cs&&console.log(Hp),Md){fi.enterPM2Mode(),Ki.notify(Hp);let r=tde(Object.keys(ot.CONFIG_PARAM_MAP),!0);return vw.isEmptyOrZeroLength(Object.keys(r))||V$.updateConfigValue(void 0,void 0,r,!0,!0),ude(),Hp}return Mw?(Ki.notify(Hp),Fp.get(ot.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await ede(),process.env.HARPER_EXIT_ON_RESTART&&process.exit(0),setTimeout(()=>{MS()},50)):kp.postMessage({type:ot.ITC_EVENT_TYPES.RESTART}),Hp}a(K$,"restart");async function Uw(e){let{service:t}=e;if(ot.HDB_PROCESS_SERVICES[t]===void 0)throw nde(new Error,lde,ide.BAD_REQUEST,void 0,void 0,!0);if(fi.expectedRestartOfChildren(),Md=await fi.isServiceRegistered(ot.PROCESS_DESCRIPTORS.HDB),!Mw){e.replicated&&ade(),kp.postMessage({type:ot.ITC_EVENT_TYPES.RESTART,workerType:t}),kp.ref(),await new Promise(s=>{kp.on("message",i=>{i.type==="restart-complete"&&(s(),kp.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===ode())continue;let i;try{({job_id:i}=await q$(s,e))}catch(o){n.push({node:s.name,message:o.message});continue}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 ot.HDB_PROCESS_SERVICES.clustering:if(!Fp.get(ot.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Cs&&console.log("Restarting clustering"),Ki.notify("Restarting clustering"),await Y$();break;case ot.HDB_PROCESS_SERVICES.clustering_config:case ot.HDB_PROCESS_SERVICES["clustering config"]:if(!Fp.get(ot.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Cs&&console.log("Restarting clustering_config"),Ki.notify("Restarting clustering_config"),await fi.reloadClustering();break;case"custom_functions":case"custom functions":case ot.HDB_PROCESS_SERVICES.harperdb:case ot.HDB_PROCESS_SERVICES.http_workers:case ot.HDB_PROCESS_SERVICES.http:if(Cs&&!Md){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}Cs&&console.log("Restarting http_workers"),Ki.notify("Restarting http_workers"),Cs?await fi.restart(ot.PROCESS_DESCRIPTORS.HDB):await MS("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Ki.error(r),Cs&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(Uw,"restartService");async function ude(){await Y$(),await fi.restart(ot.PROCESS_DESCRIPTORS.HDB),await vw.async_set_timeout(2e3),Fp.get(ot.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await Lw(),Cs&&(await DS.closeConnection(),process.exit(0))}a(ude,"restartPM2Mode");async function Y$(){if(!V$.getConfigFromFile(ot.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await G$.getHDBProcessInfo()).clustering.length===0)Ki.trace("Clustering not running, restart will start clustering services"),await LS.generateNatsConfig(!0),await fi.startClusteringProcesses(),await fi.startClusteringThreads(),await Lw(),Cs&&await DS.closeConnection();else{await LS.generateNatsConfig(!0),Md?(Ki.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await fi.restart(ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await fi.restart(ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await G$.getHDBProcessInfo()).clustering.forEach(s=>{Ki.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await vw.async_set_timeout(3e3),await Lw(),await DS.updateLocalStreams(),Cs&&await DS.closeConnection(),Ki.trace("Restart clustering restarting ingest and reply service threads");let t=MS(ot.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=MS(ot.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(Y$,"restartClustering");async function Lw(){await LS.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await LS.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(Lw,"removeNatsConfig")});var sV=I((mMe,nV)=>{"use strict";var hMe=require("lodash"),Cn=(H(),P(G)),{handleHDBError:z$,hdb_errors:dde}=pe(),{HDB_ERROR_MSGS:fde,HTTP_STATUS_CODES:_de}=dde,xw=W();nV.exports={getRolePermissions:hde};var Ml=Object.create(null),pde=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)=>({[Cn.PERMS_CRUD_ENUM.READ]:e,[Cn.PERMS_CRUD_ENUM.INSERT]:t,[Cn.PERMS_CRUD_ENUM.UPDATE]:r,[Cn.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),[Gp]:t[Gp],[Hw]:t[Hw],[kw]:t[kw]}),"attr_perms_template"),J$=a((e,t=!1)=>({attribute_name:e,describe:t,[Gp]:t}),"timestamp_attr_perms_template"),{READ:Gp,INSERT:Hw,UPDATE:kw}=Cn.PERMS_CRUD_ENUM,eV=Object.values(Cn.PERMS_CRUD_ENUM),tV=[Gp,Hw,kw];function hde(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[Cn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Ml[t]&&Ml[t].key===n)return Ml[t].perms;let s=mde(e,r);return Ml[t]?Ml[t].key=n:Ml[t]=pde(n),Ml[t].perms=s,s}catch(r){if(!e[Cn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Cn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Cn.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,fde.OUTDATED_PERMS_TRANSLATION_ERROR,_de.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(hde,"getRolePermissions");function mde(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]=Ede(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=gde(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(mde,"translateRolePermissions");function Ede(e){let t=X$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=Bw(!0,!0,!0,!0,!0)}),t}a(Ede,"createStructureUserPermissions");function gde(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=J$(d,f[Gp])),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||Sde(f,l)}else if(u!==o){let f;Cn.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(gde,"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 Sde(e,t){tV.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(Sde,"checkForHashPerms")});var qp={};Ue(qp,{authentication:()=>dV,bypassAuth:()=>Nde,login:()=>Ide,logout:()=>Cde,start:()=>wde});function Nde(){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?yde?Rde:[]:Ade?Tde:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let h=ss.get(x.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",S=new bo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",h],["Access-Control-Allow-Origin",i]]);return vS&&S.set("Access-Control-Allow-Credentials","true"),{status:200,headers:S}}o.push("Access-Control-Allow-Origin",i),vS&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(vS){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 vd.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?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(_,Ws.SUCCESS,"mTLS")):(0,vd.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=vl.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 We.getUser(g,R,e):null;break;case"Bearer":try{d=await wO(S)}catch(N){if(N.message==="invalid token")try{return await ug(S),c({status:-1})}catch{throw N}}break}}catch(E){return Ode&&(vl.get(S)||(vl.set(S,S),f(g,Ws.FAILURE,h))),c({status:401,body:Ra({error:E.message},e)})}vl.set(n,d),bde&&f(d.username,Ws.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)());vS&&(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")&&Ni.loginPath?(p.status=302,p.headers.set("Location",Ni.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 bo);for(let d=0;d<u;){let p=o[d++];f.set(p,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function wde({server:e,port:t,securePort:r}){e.http(dV,t||r?{port:t,securePort:r}:{port:"all"}),oV||(oV=!0,setInterval(()=>{vl=new Map},ss.get(x.AUTHENTICATION_CACHETTL)).unref(),lV.user.addListener(()=>{vl=new Map}))}async function Ide(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 Cde(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,ss,vd,lV,Fw,Tde,Ade,Rde,yde,iV,vS,uV,bde,Ode,vl,oV,US=be(()=>{aV=M(yn());Kr();Au();Qu();De();cV=require("uuid"),ss=M(ce());H();vd=M(W()),lV=M(O_());j_();co();Fw=(0,vd.loggerWithTag)("auth-event");ss.initSync();Tde=ss.get(x.HTTP_CORSACCESSLIST),Ade=ss.get(x.HTTP_CORS),Rde=ss.get(x.OPERATIONSAPI_NETWORK_CORSACCESSLIST),yde=ss.get(x.OPERATIONSAPI_NETWORK_CORS),iV=dt({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),vS=ss.get(x.AUTHENTICATION_ENABLESESSIONS)??!0,uV=process.env.AUTHENTICATION_AUTHORIZELOCAL??ss.get(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,bde=ss.get(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ode=ss.get(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,vl=new Map;We.onInvalidatedUser(()=>{vl=new Map});a(Nde,"bypassAuth");a(dV,"authentication");a(wde,"start");a(Ide,"login");a(Cde,"logout")});var gV=I((NMe,EV)=>{"use strict";var Ne=require("joi"),fV=require("fs-extra"),_V=require("path"),is=it(),pV=ce(),hV=(H(),P(G)),mV=W(),{hdb_errors:Pde}=pe(),{HDB_ERROR_MSGS:rn}=Pde,ko=/^[a-zA-Z0-9-_]+$/,Dde=/^[a-zA-Z0-9-_]+$/;EV.exports={getDropCustomFunctionValidator:Mde,setCustomFunctionValidator:vde,addComponentValidator:Hde,dropCustomFunctionProjectValidator:kde,packageComponentValidator:Fde,deployComponentValidator:Gde,setComponentFileValidator:Ude,getComponentFileValidator:Bde,dropComponentFileValidator:xde,addSSHKeyValidator:qde,updateSSHKeyValidator:$de,deleteSSHKeyValidator:Vde,setSSHKnownHostsValidator:Kde};function xS(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(rn.PROJECT_EXISTS):e?r.message(rn.NO_PROJECT):t}catch(n){return mV.error(n),r.message(rn.VALIDATION_ERR)}}a(xS,"checkProjectExists");function $p(e,t){return e.includes("..")?t.message("Invalid file path"):e}a($p,"checkFilePath");function Lde(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(rn.NO_FILE)}catch(s){return mV.error(s),n.message(rn.VALIDATION_ERR)}}a(Lde,"checkFileExists");function Mde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(xS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(ko).custom(Lde.bind(null,e.project,e.type)).custom($p).required().messages({"string.pattern.base":rn.BAD_FILE_NAME})});return is.validateBySchema(e,t)}a(Mde,"getDropCustomFunctionValidator");function vde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(xS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom($p).required(),function_content:Ne.string().required()});return is.validateBySchema(e,t)}a(vde,"setCustomFunctionValidator");function Ude(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),file:Ne.string().custom($p).required(),payload:Ne.string().allow("").optional(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return is.validateBySchema(e,t)}a(Ude,"setComponentFileValidator");function xde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),file:Ne.string().custom($p).optional()});return is.validateBySchema(e,t)}a(xde,"dropComponentFileValidator");function Bde(e){let t=Ne.object({project:Ne.string().required(),file:Ne.string().custom($p).required(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return is.validateBySchema(e,t)}a(Bde,"getComponentFileValidator");function Hde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(xS.bind(null,!1)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME})});return is.validateBySchema(e,t)}a(Hde,"addComponentValidator");function kde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(xS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME})});return is.validateBySchema(e,t)}a(kde,"dropCustomFunctionProjectValidator");function Fde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean(),skip_symlinks:Ne.boolean()});return is.validateBySchema(e,t)}a(Fde,"packageComponentValidator");function Gde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.alternatives().try(Ne.boolean(),Ne.string().valid("rolling")).optional()});return is.validateBySchema(e,t)}a(Gde,"deployComponentValidator");function qde(e){let t=Ne.object({name:Ne.string().pattern(Dde).required().messages({"string.pattern.base":rn.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return is.validateBySchema(e,t)}a(qde,"addSSHKeyValidator");function $de(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return is.validateBySchema(e,t)}a($de,"updateSSHKeyValidator");function Vde(e){let t=Ne.object({name:Ne.string().required()});return is.validateBySchema(e,t)}a(Vde,"deleteSSHKeyValidator");function Kde(e){let t=Ne.object({known_hosts:Ne.string().required()});return is.validateBySchema(e,t)}a(Kde,"setSSHKnownHostsValidator")});var Yp=I((IMe,yV)=>{"use strict";var BS=require("joi"),Ja=require("path"),Ud=require("fs-extra"),{exec:Yde,spawn:Wde}=require("child_process"),zde=require("util"),jde=zde.promisify(Yde),xd=(H(),P(G)),{PACKAGE_ROOT:Jde}=st(),{handleHDBError:Vp,hdb_errors:Qde}=pe(),{HTTP_STATUS_CODES:Kp}=Qde,Ul=ce(),Xde=it(),Qa=W(),{once:Zde}=require("events");Ul.initSync();var Gw=Ul.get(xd.CONFIG_PARAMS.COMPONENTSROOT),SV="npm install --force --omit=dev --json",efe=`${SV} --dry-run`,tfe=Ul.get(xd.CONFIG_PARAMS.ROOTPATH),HS=Ja.join(tfe,"ssh");yV.exports={installModules:ife,auditModules:ofe,installAllRootModules:rfe,uninstallRootModule:nfe,linkHarperdb:sfe,runCommand:Bd};async function rfe(e=!1,t=Ul.get(xd.CONFIG_PARAMS.ROOTPATH)){await kS();let r=!1,n=process.env;Ud.pathExistsSync(HS)&&Ud.readdirSync(HS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+Ja.join(HS,"config")+" -o UserKnownHostsFile="+Ja.join(HS,"known_hosts"),...process.env},r=!0)});try{let s=Ul.get(xd.CONFIG_PARAMS.ROOTPATH),i=Ja.join(s,"node_modules","harperdb");Ud.lstatSync(i).isSymbolicLink()&&Ud.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Qa.error("Error removing symlink:",s)}await Bd(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(rfe,"installAllRootModules");async function nfe(e){await Bd(`npm uninstall ${e}`,Ul.get(xd.CONFIG_PARAMS.ROOTPATH))}a(nfe,"uninstallRootModule");async function sfe(){await kS(),await Bd(`npm link ${Jde}`,Ul.get(xd.CONFIG_PARAMS.ROOTPATH))}a(sfe,"linkHarperdb");async function Bd(e,t=void 0,r=process.env){Qa.debug({tagName:"npm_run_command"},`running command: \`${e}\``);let n=Wde(e,{shell:!0,cwd:t,env:r,stdio:["ignore","pipe","pipe"]}),s="",i="";n.stdout.on("data",c=>{let l=c.toString();Qa.debug({tagName:"npm_run_command:stdout"},l),s+=l}),n.stderr.on("data",c=>{let l=c.toString();Qa.error({tagName:"npm_run_command:stderr"},l),i+=l});let[o]=await Zde(n,"close");if(o!==0)throw new Error(`Command \`${e}\` exited with code ${o}.${i===""?"":` Error: ${i}`}`);return s||void 0}a(Bd,"runCommand");async function ife(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Qa.warn(t,e.projects);let r=RV(e);if(r)throw Vp(r,r.message,Kp.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?efe:SV;await kS(),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 jde(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 ife(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=za.join(Fw,o);n[o]={npm_output:null,npm_error:null};try{let l=await Ud("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(ife,"auditModules");async function BS(){return await Ud("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=za.join(Fw,i.toString());if(!await Md.pathExists(o)){t.push(i);continue}let l=za.join(o,"package.json");await Md.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 Xde.validateBySchema(e,t)}a(yV,"modulesValidator")});var qw=w((IMe,PV)=>{"use strict";var Cs=require("fs-extra"),Wp=require("path"),Yp=z(),OV=ie(),{PACKAGE_ROOT:ofe}=st(),Gw=(H(),C(G)),CV=ae(),afe=yt();PV.exports=cfe;async function cfe(){let e=lfe(),t=CV.get(Gw.CONFIG_PARAMS.ROOTPATH),r=Wp.join(t,"package.json"),n={dependencies:{harperdb:"file:"+ofe}},s=Wp.join(t,"node_modules");Cs.ensureDirSync(s);let i,o=!0,c=!1;try{i=Cs.readJsonSync(r)}catch(l){if(OV.isEmptyOrZeroLength(e))return;if(l.code!==Gw.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(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 IV(r,n,i),await NV(t,e))}a(cfe,"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(Cs.existsSync(n)&&Cs.lstatSync(n).isDirectory())return Cs.move(n,s,{overwrite:!0}).then(()=>{Cs.symlink(s,n)})}))}a(NV,"moveModuleToComponents");function lfe(){let e=afe.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(lfe,"getComponentsConfig");function wV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Wp.extname(e)||Cs.existsSync(e)?"file:":"github:"}a(wV,"getPkgPrefix");async function IV(e,t,r){Yp.trace("npm installing components package.json",t),Cs.writeFileSync(e,JSON.stringify(t,null," "));try{await Kp().installAllRootModules(CV.get(Gw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Cs.writeFileSync(e,JSON.stringify(r,null," ")):Cs.unlinkSync(e),n}}a(IV,"installPackages")});var $w={};ve($w,{packageDirectory:()=>ufe});function ufe(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,Vw=be(()=>{DV=require("path"),LV=M(require("tar-fs")),MV=require("node:zlib");a(ufe,"packageDirectory")});var Ww=w(BV=>{"use strict";var Oe=require("fs-extra"),Kw=require("fast-glob"),we=require("path"),dfe=require("tar-fs"),ffe=require("gunzip-maybe"),Yw=require("normalize-path"),In=gV(),xt=z(),ct=(H(),C(G)),Jt=ae(),HS=yt(),_fe=ie(),{PACKAGE_ROOT:pfe}=st(),{handleHDBError:Bt,hdb_errors:hfe}=pe(),{basename:mfe}=require("path"),Efe=qw(),UV=ae(),{Readable:gfe}=require("stream"),{isMainThread:Sfe}=require("worker_threads"),{HDB_ERROR_MSGS:Ll,HTTP_STATUS_CODES:Ht}=hfe,xV=et(),{replicateOperation:fi}=(Xn(),C(wo)),{packageDirectory:Tfe}=(Vw(),C($w)),vV=Kp(),Afe=we.join(pfe,"application-template"),Rfe=Jt.get(ct.CONFIG_PARAMS.ROOTPATH),ja=we.join(Rfe,"ssh"),ko=we.join(ja,"known_hosts");function yfe(){xt.trace("getting custom api status");let e={};try{e={port:Jt.get(ct.CONFIG_PARAMS.HTTP_PORT),directory:Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Bt(new Error,Ll.FUNCTION_STATUS,Ht.INTERNAL_SERVER_ERROR,xt.ERR,t)}return e}a(yfe,"customFunctionsStatus");function bfe(){xt.trace("getting custom api endpoints");let e={},t=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT);try{Kw.sync(Yw(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:Kw.sync(Yw(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:Kw.sync(Yw(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Bt(new Error,Ll.GET_FUNCTIONS,Ht.INTERNAL_SERVER_ERROR,xt.ERR,r)}return e}a(bfe,"getCustomFunctions");function Ofe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=In.getDropCustomFunctionValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);xt.trace("getting custom api endpoint file content");let r=Jt.get(ct.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 Bt(new Error,Ll.GET_FUNCTION,Ht.INTERNAL_SERVER_ERROR,xt.ERR,c)}}a(Ofe,"getCustomFunction");async function Nfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=In.setCustomFunctionValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);xt.trace("setting custom function file content");let r=Jt.get(ct.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 Bt(new Error,Ll.SET_FUNCTION,Ht.INTERNAL_SERVER_ERROR,xt.ERR,c)}}a(Nfe,"setCustomFunction");async function wfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=In.getDropCustomFunctionValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);xt.trace("dropping custom function file");let r=Jt.get(ct.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 Bt(new Error,Ll.DROP_FUNCTION,Ht.INTERNAL_SERVER_ERROR,xt.ERR,o)}}a(wfe,"dropCustomFunction");async function Ife(e){e.project&&(e.project=we.parse(e.project).name);let t=In.addComponentValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);xt.trace("adding component");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=we.join(r,n);Oe.mkdirSync(s,{recursive:!0}),Oe.copySync(Afe,s);let i=await fi(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Bt(new Error,Ll.ADD_FUNCTION,Ht.INTERNAL_SERVER_ERROR,xt.ERR,s)}}a(Ife,"addComponent");async function Cfe(e){e.project&&(e.project=we.parse(e.project).name);let t=In.dropCustomFunctionProjectValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);xt.trace("dropping custom function project");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Jt.get(ct.CONFIG_PARAMS.APPS);if(!_fe.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(ct.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 Bt(new Error,Ll.DROP_FUNCTION_PROJECT,Ht.INTERNAL_SERVER_ERROR,xt.ERR,i)}}a(Cfe,"dropCustomFunctionProject");async function Pfe(e){e.project&&(e.project=we.parse(e.project).name);let t=In.packageComponentValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;xt.trace("packaging component",n);let s;try{s=await Oe.realpath(we.join(r,n))}catch(o){if(o.code!==ct.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Oe.realpath(we.join(Jt.get(ct.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===ct.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await Tfe(s,e)).toString("base64");return{project:n,payload:i}}a(Pfe,"packageComponent");async function Dfe(e){e.project?e.project=we.parse(e.project).name:e.package&&(e.project=Lfe(e.package));let t=In.deployComponentValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(xt.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=gfe.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((E,T)=>{S.pipe(ffe()).pipe(dfe.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 vV.runCommand(o,c):Oe.existsSync(R)||await vV.installAllRootModules(!1,c)}else{await HS.addConfig(n,{package:i}),await Efe();let S=UV.get(ct.CONFIG_PARAMS.ROOTPATH);c=we.join(S,"node_modules",n)}if(Sfe)return;let l=new Map;l.isWorker=!0;let u=(jp(),C(zp)),f;u.setErrorReporter(S=>f=S);let d=mfe(c),p=u.component_errors.get(d);try{await u.loadComponent(c,l)}finally{u.component_errors.set(d,p)}if(f)throw f;xt.info("Installed component");let _=e.restart==="rolling";e.restart=_?!1:e.restart;let h=await fi(e);if(e.restart===!0)xV.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(_){let g=await zw().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(Dfe,"deployComponent");function Lfe(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(Lfe,"getProjectNameFromPackage");async function Mfe(){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 xt.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{name:Jt.get(ct.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(Mfe,"getComponents");async function vfe(e){let t=In.getComponentFileValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let n=HS.getConfigObj()[e.project]||e.project==="harperdb"?we.join(UV.get(ct.CONFIG_PARAMS.ROOTPATH),"node_modules"):Jt.get(ct.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===ct.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${we.join(e.project,e.file)}'`):i}}a(vfe,"getComponentFile");async function Ufe(e){let t=In.setComponentFileValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=we.join(Jt.get(ct.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(Ufe,"setComponentFile");async function xfe(e){let t=In.dropComponentFileValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?we.join(r,n):r,i=we.join(Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),s),o=we.join(Jt.get(ct.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(ct.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 fi(e);return e.restart===!0?(xV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(xfe,"dropComponent");async function Bfe(e){let t=In.addSSHKeyValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;xt.trace("adding ssh key",r);let c=we.join(ja,r+".key"),l=we.join(ja,"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 Qa.info(`finished installModules with response ${o}`),o.warning=t,o}a(ife,"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 ofe(e){Qa.info(`starting auditModules for request: ${e}`);let t=RV(e);if(t)throw Vp(t,t.message,Kp.BAD_REQUEST);let{projects:r}=e;await kS(),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 Bd("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=TV(l.stderr)}}return Qa.info(`finished auditModules with response ${n}`),n}a(ofe,"auditModules");async function kS(){return await Bd("npm -v"),!0}a(kS,"checkNPMInstalled");async function AV(e){if(!Array.isArray(e)||e.length===0)throw Vp(new Error,"projects argument must be an array with at least 1 element",Kp.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 Ud.pathExists(o)){t.push(i);continue}let l=Ja.join(o,"package.json");await Ud.pathExists(l)||r.push(i)}if(t.length>0)throw Vp(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Kp.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw Vp(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Kp.BAD_REQUEST,void 0,void 0,!0)}a(AV,"checkProjectPaths");function RV(e){let t=BS.object({projects:BS.array().min(1).items(BS.string()).required(),dry_run:BS.boolean().default(!1)});return Xde.validateBySchema(e,t)}a(RV,"modulesValidator")});var $w=I((PMe,CV)=>{"use strict";var Ps=require("fs-extra"),zp=require("path"),Wp=W(),bV=ae(),{PACKAGE_ROOT:afe}=st(),qw=(H(),P(G)),IV=ce(),cfe=Rt();CV.exports=lfe;async function lfe(){let e=ufe(),t=IV.get(qw.CONFIG_PARAMS.ROOTPATH),r=zp.join(t,"package.json"),n={dependencies:{harperdb:"file:"+afe}},s=zp.join(t,"node_modules");Ps.ensureDirSync(s);let i,o=!0,c=!1;try{i=Ps.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){Wp.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(Ps.statSync(new URL(u+"/package.json")).mtimeMs>Ps.statSync(r).mtimeMs){c=!0;break}}catch(p){Wp.info(`Error checking ${u}/package.json modification time`,p);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Wp.notify("Removing component",l),c=!0);c&&(Wp.notify("Updating components."),await wV(r,n,i),await OV(t,e))}a(lfe,"installComponents");function OV(e,t){return Promise.all(t.map(({name:r})=>{let n=zp.join(e,"node_modules",r),s=zp.join(e,"components",r);if(Ps.existsSync(n)&&Ps.lstatSync(n).isDirectory())return Ps.move(n,s,{overwrite:!0}).then(()=>{Ps.symlink(s,n)})}))}a(OV,"moveModuleToComponents");function ufe(){let e=cfe.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(ufe,"getComponentsConfig");function NV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":zp.extname(e)||Ps.existsSync(e)?"file:":"github:"}a(NV,"getPkgPrefix");async function wV(e,t,r){Wp.trace("npm installing components package.json",t),Ps.writeFileSync(e,JSON.stringify(t,null," "));try{await Yp().installAllRootModules(IV.get(qw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Ps.writeFileSync(e,JSON.stringify(r,null," ")):Ps.unlinkSync(e),n}}a(wV,"installPackages")});var Vw={};Ue(Vw,{packageDirectory:()=>dfe});function dfe(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(dfe,"packageDirectory")});var zw=I(xV=>{"use strict";var Oe=require("fs-extra"),Yw=require("fast-glob"),we=require("path"),ffe=require("tar-fs"),_fe=require("gunzip-maybe"),Ww=require("normalize-path"),Pn=gV(),Bt=W(),ct=(H(),P(G)),Jt=ce(),FS=Rt(),pfe=ae(),{PACKAGE_ROOT:hfe}=st(),{handleHDBError:Ht,hdb_errors:mfe}=pe(),{basename:Efe}=require("path"),gfe=$w(),vV=ce(),{Readable:Sfe}=require("stream"),{isMainThread:Tfe}=require("worker_threads"),{HDB_ERROR_MSGS:xl,HTTP_STATUS_CODES:kt}=mfe,UV=rt(),{replicateOperation:_i}=(Zn(),P(Io)),{packageDirectory:Afe}=(Kw(),P(Vw)),MV=Yp(),Rfe=we.join(hfe,"application-template"),yfe=Jt.get(ct.CONFIG_PARAMS.ROOTPATH),Xa=we.join(yfe,"ssh"),Fo=we.join(Xa,"known_hosts");function bfe(){Bt.trace("getting custom api status");let e={};try{e={port:Jt.get(ct.CONFIG_PARAMS.HTTP_PORT),directory:Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Ht(new Error,xl.FUNCTION_STATUS,kt.INTERNAL_SERVER_ERROR,Bt.ERR,t)}return e}a(bfe,"customFunctionsStatus");function Ofe(){Bt.trace("getting custom api endpoints");let e={},t=Jt.get(ct.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,xl.GET_FUNCTIONS,kt.INTERNAL_SERVER_ERROR,Bt.ERR,r)}return e}a(Ofe,"getCustomFunctions");function Nfe(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 Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("getting custom api endpoint file content");let r=Jt.get(ct.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,xl.GET_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,c)}}a(Nfe,"getCustomFunction");async function wfe(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 Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("setting custom function file content");let r=Jt.get(ct.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 Ht(new Error,xl.SET_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,c)}}a(wfe,"setCustomFunction");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.getDropCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("dropping custom function file");let r=Jt.get(ct.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 Ht(new Error,xl.DROP_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,o)}}a(Ife,"dropCustomFunction");async function Cfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.addComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("adding component");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=we.join(r,n);Oe.mkdirSync(s,{recursive:!0}),Oe.copySync(Rfe,s);let i=await _i(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Ht(new Error,xl.ADD_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,s)}}a(Cfe,"addComponent");async function Pfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.dropCustomFunctionProjectValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("dropping custom function project");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Jt.get(ct.CONFIG_PARAMS.APPS);if(!pfe.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 FS.updateConfigValue(ct.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 Ht(new Error,xl.DROP_FUNCTION_PROJECT,kt.INTERNAL_SERVER_ERROR,Bt.ERR,i)}}a(Pfe,"dropCustomFunctionProject");async function Dfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.packageComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=Jt.get(ct.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!==ct.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Oe.realpath(we.join(Jt.get(ct.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===ct.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await Afe(s,e)).toString("base64");return{project:n,payload:i}}a(Dfe,"packageComponent");async function Lfe(e){e.project?e.project=we.parse(e.project).name:e.package&&(e.project=Mfe(e.package));let t=Pn.deployComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=Jt.get(ct.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=Sfe.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((E,A)=>{S.pipe(_fe()).pipe(ffe.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 MV.runCommand(o,c):Oe.existsSync(R)||await MV.installAllRootModules(!1,c)}else{await FS.addConfig(n,{package:i}),await gfe();let S=vV.get(ct.CONFIG_PARAMS.ROOTPATH);c=we.join(S,"node_modules",n)}if(Tfe)return;let l=new Map;l.isWorker=!0;let u=(Jp(),P(jp)),f;u.setErrorReporter(S=>f=S);let d=Efe(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 _i(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(Lfe,"deployComponent");function Mfe(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(Mfe,"getProjectNameFromPackage");async function vfe(){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(Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{name:Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT).split(we.sep).slice(-1).pop(),entries:[]}),n=(Jp(),P(jp)).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(vfe,"getComponents");async function Ufe(e){let t=Pn.getComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let n=FS.getConfigObj()[e.project]||e.project==="harperdb"?we.join(vV.get(ct.CONFIG_PARAMS.ROOTPATH),"node_modules"):Jt.get(ct.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===ct.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${we.join(e.project,e.file)}'`):i}}a(Ufe,"getComponentFile");async function xfe(e){let t=Pn.setComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=we.join(Jt.get(ct.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(xfe,"setComponentFile");async function Bfe(e){let t=Pn.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(Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),s),o=we.join(Jt.get(ct.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(ct.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")}FS.deleteConfigFromFile([r]);let l=await _i(e);return e.restart===!0?(UV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(Bfe,"dropComponent");async function Hfe(e){let t=Pn.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(Xa,r+".key"),l=we.join(Xa,"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(ko,o);let d=await fi(e);return d.message=`Added ssh key: ${r}${f}`,d}a(Bfe,"addSSHKey");async function Hfe(e){let t=In.updateSSHKeyValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let{name:r,key:n}=e;xt.trace("updating ssh key",r);let s=we.join(ja,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(Hfe,"updateSSHKey");async function kfe(e){let t=In.deleteSSHKeyValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let{name:r}=e;xt.trace("deleting ssh key",r);let n=we.join(ja,r+".key"),s=we.join(ja,"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(kfe,"deleteSSHKey");async function Ffe(e){let t=[];return await Oe.pathExists(ja)&&(await Oe.readdir(ja)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(Ffe,"listSSHKeys");async function Gfe(e){let t=In.setSSHKnownHostsValidator(e);if(t)throw Bt(t,t.message,Ht.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(Gfe,"setSSHKnownHosts");async function qfe(e){return await Oe.pathExists(ko)?{known_hosts:await Oe.readFile(ko,"utf8")}:{known_hosts:null}}a(qfe,"getSSHKnownHosts");Object.assign(BV,{customFunctionsStatus:yfe,getCustomFunctions:bfe,getCustomFunction:Ofe,setCustomFunction:Nfe,dropCustomFunction:wfe,addComponent:Ife,dropCustomFunctionProject:Cfe,packageComponent:Pfe,deployComponent:Dfe,getComponents:Mfe,getComponentFile:vfe,setComponentFile:Ufe,dropComponent:xfe,addSSHKey:Bfe,updateSSHKey:Hfe,deleteSSHKey:kfe,listSSHKeys:Ffe,setSSHKnownHosts:Gfe,getSSHKnownHosts:qfe})});var jw=w((MMe,kV)=>{"use strict";var Ps=require("joi"),HV=it();kV.exports={readTransactionLogValidator:$fe,deleteTransactionLogsBeforeValidator:Vfe};function $fe(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 HV.validateBySchema(e,t)}a($fe,"readTransactionLogValidator");function Vfe(e){let t=Ps.object({schema:Ps.string(),database:Ps.string(),table:Ps.string().required(),timestamp:Ps.date().timestamp().required()});return HV.validateBySchema(e,t)}a(Vfe,"deleteTransactionLogsBeforeValidator")});var GS=w((UMe,KV)=>{"use strict";var Jw=(H(),C(G)),Jp=ir(),FV=ie(),GV=ae(),qV=Eo(),$V=z(),{handleHDBError:kS,hdb_errors:Kfe}=pe(),{HTTP_STATUS_CODES:FS}=Kfe,{readTransactionLogValidator:Yfe,deleteTransactionLogsBeforeValidator:Wfe}=jw(),VV=Vn(),zfe="Logs successfully deleted from transaction log.",jfe="All logs successfully deleted from transaction log.";KV.exports={readTransactionLog:Jfe,deleteTransactionLogsBefore:Xfe};async function Jfe(e){let t=Yfe(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(Jw.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Qfe(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(Jfe,"readTransactionLog");async function*Qfe(e){let t=qV.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===Jw.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Qfe,"readTransactionLogNats");async function Xfe(e){let t=Wfe(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(Jw.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 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=zfe,d,p=new Date(l.state.last_ts).getTime();return s>p?(d=l.state.last_seq+1,f=jfe):d=(await Jp.viewStream(o,parseInt(s),1))[0].nats_sequence,await Jp.purgeTableStream(r,n,{seq:d}),f}a(Xfe,"deleteTransactionLogsBefore")});var WV=w((BMe,YV)=>{"use strict";var Qw=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=Qw});var jV=w((kMe,zV)=>{"use strict";var Xw=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};zV.exports=Xw});var eI=w((GMe,QV)=>{"use strict";var JV=WV(),Zfe=jV(),{HDB_ERROR_MSGS:e_e}=Un(),Zw=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=e_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 Zfe(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}};QV.exports=Zw});var KS=w((KMe,p1)=>{"use strict";var tI=Rn(),qS=Yr(),Ds=Vg(),Zp=go(),rI=Vc(),t_e=bN(),r_e=dG(),eh=An(),$S=F_(),Sr=z(),n_e=CN(),s_e=gd(),i_e=ew(),o_e=nS(),a_e=nw(),c_e=sw(),l_e=aS(),u_e=lS(),nI=uS(),Fo=ie(),d_e=Vq(),sI=hS(),e1=Wa(),rn=(H(),C(G)),t1=sV(),f_e=Po(),r1=(ju(),C(X_)),n1=(MS(),C(Gp)),s1=yt(),ur=Ww(),__e=require("alasql"),i1=GS(),o1=Kp(),xd=Zn(),a1=(Tl(),C(Sl)),c1=eI(),{handleHDBError:Cn,hdb_errors:l1}=pe(),{addNodeBack:$Me,removeNodeBack:VMe}=(Tl(),C(Sl)),{HDB_ERROR_MSGS:Ur,HTTP_STATUS_CODES:Qp}=l1,X=new Map,u1="delete",Ja="insert",Go="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},p_e={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},h_e="catchup",m_e="handleGetJob",E_e="handleGetJobsByStartDate",VS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},g_e=[Ds.createTable.name,Ds.createAttribute.name,Ds.dropTable.name,Ds.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}};X.set(tI.insert.name,new re(!1,[Ja]));X.set(tI.update.name,new re(!1,[Ml]));X.set(tI.upsert.name,new re(!1,[Ja,Ml]));X.set(qS.searchByConditions.name,new re(!1,[Go]));X.set(qS.searchByHash.name,new re(!1,[Go]));X.set(qS.searchByValue.name,new re(!1,[Go]));X.set(qS.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,[Ja]));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(rI.deleteRecord.name,new re(!1,[u1]));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($S.listRoles.name,new re(!0,[]));X.set($S.addRole.name,new re(!0,[]));X.set($S.alterRole.name,new re(!0,[]));X.set($S.dropRole.name,new re(!0,[]));X.set(n_e.name,new re(!0,[]));X.set(s_e.name,new re(!0,[]));X.set(i_e.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(nI.setRoutes.name,new re(!0,[]));X.set(nI.getRoutes.name,new re(!0,[]));X.set(nI.deleteRoutes.name,new re(!0,[]));X.set(s1.setConfiguration.name,new re(!0,[]));X.set(l_e.clusterStatus.name,new re(!0,[]));X.set(u_e.name,new re(!0,[]));X.set(sI.getFingerprint.name,new re(!0,[]));X.set(sI.setLicense.name,new re(!0,[]));X.set(rI.deleteFilesBefore.name,new re(!0,[]));X.set(rI.deleteAuditLogsBefore.name,new re(!0,[]));X.set(e1.restart.name,new re(!0,[]));X.set(e1.restartService.name,new re(!0,[]));X.set(t_e.name,new re(!0,[]));X.set(r_e.name,new re(!0,[Go]));X.set(f_e.systemInformation.name,new re(!0,[]));X.set(s1.getConfiguration.name,new re(!0,[]));X.set(i1.readTransactionLog.name,new re(!0,[]));X.set(i1.deleteTransactionLogsBefore.name,new re(!0,[]));X.set(o1.installModules.name,new re(!0,[]));X.set(o1.auditModules.name,new re(!0,[]));X.set(xd.createCsr.name,new re(!0,[]));X.set(xd.signCertificate.name,new re(!0,[]));X.set(xd.listCertificates.name,new re(!0,[]));X.set(xd.addCertificate.name,new re(!0,[]));X.set(xd.removeCertificate.name,new re(!0,[]));X.set(xd.getKey.name,new re(!0,[]));X.set(a1.addNodeBack.name,new re(!0,[]));X.set(a1.removeNodeBack.name,new re(!0,[]));X.set(r1.createTokens.name,new re(!1,[]));X.set(r1.refreshOperationToken.name,new re(!1,[]));X.set(n1.login.name,new re(!1,[]));X.set(n1.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(sI.getRegistrationInfo.name,new re(!1,[]));X.set(eh.userInfo.name,new re(!1,[]));X.set(Zp.describeAll.name,new re(!1,[]));X.set(m_e,new re(!1,[]));X.set(E_e,new re(!0,[]));X.set(h_e,new re(!0,[]));X.set(VS.CSV_DATA_LOAD,new re(!1,[Ja,Ml]));X.set(VS.CSV_URL_LOAD,new re(!1,[Ja,Ml]));X.set(VS.CSV_FILE_LOAD,new re(!1,[Ja,Ml]));X.set(VS.IMPORT_FROM_S3,new re(!1,[Ja,Ml]));X.set(f1.EXPORT_TO_S3,new re(!0,[]));X.set(f1.EXPORT_LOCAL,new re(!0,[]));X.set(rn.VALID_SQL_OPS_ENUM.DELETE,new re(!1,[u1]));X.set(rn.VALID_SQL_OPS_ENUM.SELECT,new re(!1,[Go]));X.set(rn.VALID_SQL_OPS_ENUM.INSERT,new re(!1,[Ja]));X.set(rn.VALID_SQL_OPS_ENUM.UPDATE,new re(!1,[Ml]));p1.exports={verifyPerms:T_e,verifyPermsAst:S_e,verifyBulkLoadAttributePerms:R_e};function S_e(e,t,r){if(Fo.isEmptyOrZeroLength(e))throw Sr.info("verify_perms_ast has an empty user parameter"),Cn(new Error);if(Fo.isEmptyOrZeroLength(t))throw Sr.info("verify_perms_ast has an empty user parameter"),Cn(new Error);if(Fo.isEmptyOrZeroLength(r))throw Sr.info("verify_perms_ast has a null operation parameter"),Cn(new Error);try{let n=new c1,s=new d_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."),Cn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&d1[r])throw Cn(new Error,Ur.DROP_SYSTEM,Qp.FORBIDDEN);if(c&&!l)return null;let u=t1.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof __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=oI(t.role.permission,p,d[_]);iI(h,S,r,d[_],p,n)}}),n.getPermsResponse())}catch(n){throw Cn(n)}}a(S_e,"verifyPermsAst");function T_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"),Cn(new Error,Ur.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 c1;if(Fo.isEmptyOrZeroLength(e.hdb_user?.role)||Fo.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&&p_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 Cn(new Error,Ur.DROP_SYSTEM,Qp.FORBIDDEN);if(l&&!f||u===!0&&(r===Ds.createSchema.name||r===Ds.dropSchema.name))return null;if(g_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(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 _=A_e(e),h=oI(e.hdb_user?.role?.permission,s,i);return iI(_,h,r,i,s,c,n),c.getPermsResponse()}a(T_e,"verifyPerms");function _1(e,t,r,n,s){if(Fo.arrayHasEmptyValues([e,t,r]))throw Sr.info("hasPermissions has an invalid parameter"),Cn(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 Sr.info(`operation ${t} not found.`),Cn(new Error,Ur.OP_NOT_FOUND(t),Qp.BAD_REQUEST);if(X.get(t)&&X.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=[],_=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)&&(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),Cn(l1.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(_1,"hasPermissions");function iI(e,t,r,n,s,i,o){if(!e||!t)throw Sr.info("no attributes specified in checkAttributePerms."),Cn(new Error);let c=X.get(r).perms;if(!c||c==="")throw Sr.info(`no permissions found for ${r} in checkAttributePerms().`),Cn(new Error);if(Fo.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!==Go)throw Cn(new Error,Ur.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(Ur.ATTR_NOT_FOUND(s,n,f),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(iI,"checkAttributePerms");function A_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(A_e,"getRecordAttributes");function oI(e,t,r){let n=new Map;if(Fo.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(oI,"getAttributePermissions");function R_e(e,t,r,n,s,i,o){let c=new Set(i),l=oI(e,n,s);iI(c,l,t,s,n,o,r)}a(R_e,"verifyBulkLoadAttributePerms")});var WS=w((WMe,S1)=>{"use strict";S1.exports={evaluateSQL:U_e,processAST:g1,convertSQLToAST:E1,checkASTPermissions:m1};var y_e=Rn(),h1=require("util"),b_e=h1.callbackify(y_e.insert),O_e=Yr().search,N_e=tk().update,w_e=h1.callbackify(N_e),I_e=nk().convertDelete,Qa=require("alasql"),C_e=KS(),YS=z(),P_e=oE(),D_e=ie(),th=(H(),C(G)),{hdb_errors:L_e,handleHDBError:aI}=pe(),{HTTP_STATUS_CODES:cI}=L_e;P_e(Qa);var M_e=403,v_e="There was a problem performing this insert. Please check the logs and try again.",lI=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function U_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 Qa.yy.Insert?n=s.into.databaseid:s instanceof Qa.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Qa.yy.Update||s instanceof Qa.yy.Delete?n=s.table.databaseid:YS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Qa.yy.Select)&&D_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}g1(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(U_e,"evaluateSQL");function m1(e,t){let r;try{r=C_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 lI;if(!e)throw aI(new Error,"The 'sql' parameter is missing from the request body",cI.BAD_REQUEST);try{let r=e.trim(),n=Qa.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
41
|
-
`);throw n[1]?aI(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,cI.BAD_REQUEST):aI(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",cI.BAD_REQUEST)}return t}a(E1,"convertSQLToAST");function g1(e,t,r){try{let n=x_e;if(!e.bypass_auth&&!t.permissions_checked){let i=m1(e,t);if(i&&i.length>0)return r(M_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=O_e,s=t.ast.statements[0];break;case th.VALID_SQL_OPS_ENUM.INSERT:n=B_e;break;case th.VALID_SQL_OPS_ENUM.UPDATE:n=w_e;break;case th.VALID_SQL_OPS_ENUM.DELETE:n=I_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 x_e(e,t){YS.info(e),t("unknown sql statement")}a(x_e,"nullFunction");function B_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=H_e(i,e.values)}catch(o){return r(o)}b_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(B_e,"convertInsert");function H_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]]=Qa.compile(`SELECT ${s.toString()} AS [${th.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw YS.error(r),new Error(v_e)}}a(H_e,"createDataObjects")});var hI=w((QMe,y1)=>{var QS=require("clone"),XS=it(),k_e=ie(),jS=(H(),C(G)),jMe=z(),uI=require("fs"),fI=require("joi"),{string:JS}=fI.types(),{hdb_errors:F_e,handleHDBError:zS}=pe(),{HDB_ERROR_MSGS:JMe,HTTP_STATUS_CODES:dI}=F_e,{common_validators:Bd}=Di(),T1=" is required",G_e=["insert","update","upsert"],_I={database:{presence:!1,format:Bd.schema_format,length:Bd.schema_length},schema:{presence:!1,format:Bd.schema_format,length:Bd.schema_length},table:{presence:!0,format:Bd.schema_format,length:Bd.schema_length},action:{inclusion:{within:G_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},q_e={schema:JS.required(),table:JS.required(),action:JS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:$_e,AWS_SECRET:V_e,AWS_BUCKET:K_e,AWS_FILE_KEY:Y_e,REGION:W_e}=jS.S3_BUCKET_AUTH_KEYS,z_e={s3:{presence:!0},[`s3.${$_e}`]:{presence:!0,type:"String"},[`s3.${V_e}`]:{presence:!0,type:"String"},[`s3.${K_e}`]:{presence:!0,type:"String"},[`s3.${Y_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${W_e}`]:{presence:!0,type:"String"}},A1=QS(_I);A1.data.presence={message:T1};var R1=QS(_I);R1.file_path.presence={message:T1};var j_e=Object.assign(QS(_I),z_e),pI=QS(q_e);pI.csv_url=JS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();pI.passthrough_headers=fI.object();function J_e(e){let t=XS.validateObject(e,A1);return ZS(e,t)}a(J_e,"dataObject");function Q_e(e){let t=XS.validateBySchema(e,fI.object(pI));return ZS(e,t)}a(Q_e,"urlObject");function X_e(e){let t=XS.validateObject(e,R1);return ZS(e,t)}a(X_e,"fileObject");function Z_e(e){let t=XS.validateObject(e,j_e);return ZS(e,t)}a(Z_e,"s3FileObject");function ZS(e,t){if(!t){let r=k_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return zS(new Error,r,dI.BAD_REQUEST);if(e.operation===jS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{uI.accessSync(e.file_path,uI.constants.R_OK|uI.constants.F_OK)}catch(n){return n.code===jS.NODE_ERROR_CODES.ENOENT?zS(n,`No such file or directory ${n.path}`,dI.BAD_REQUEST):n.code===jS.NODE_ERROR_CODES.EACCES?zS(n,`Permission denied ${n.path}`,dI.BAD_REQUEST):zS(n)}}return t}a(ZS,"postValidateChecks");y1.exports={dataObject:J_e,urlObject:Q_e,fileObject:X_e,s3FileObject:Z_e}});var mI=w((ZMe,b1)=>{"use strict";var rh=z(),eT=(H(),C(G));async function epe(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(epe,"callOperationFunctionAsAwait");b1.exports={callOperationFunctionAsAwait:epe}});var EI=w((tve,N1)=>{"use strict";var{S3:tpe,GetObjectCommand:rpe}=require("@aws-sdk/client-s3");N1.exports={getFileStreamFromS3:npe,getS3AuthObj:O1};async function npe(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 rpe(r))).Body}a(npe,"getFileStreamFromS3");function O1(e,t,r){return new tpe({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(O1,"getS3AuthObj")});var I1=w((nve,w1)=>{"use strict";var gI=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}},SI=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:gI,BulkLoadDataObject:SI}});var P1=w((ive,C1)=>{"use strict";var TI=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};C1.exports=TI});var NI=w((dve,W1)=>{"use strict";var tT=Rn(),nT=hI(),spe=require("needle"),_i=(H(),C(G)),ave=Tt(),Hd=ie(),{handleHDBError:kt,hdb_errors:k1}=pe(),{HTTP_STATUS_CODES:xr,HDB_ERROR_MSGS:Tr,CHECK_LOGS_WRAPPER:Ul}=k1,kd=z(),AI=require("papaparse");Hd.promisifyPapaParse();var pi=require("fs-extra"),ipe=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"),ope=ae(),F1=mI(),ape=EI(),{BulkLoadFileObject:yI,BulkLoadDataObject:cpe}=I1(),bI=eI(),{verifyBulkLoadAttributePerms:G1}=KS(),cve=P1(),lve=ir(),uve=Eo(),{databases:lpe}=(Pe(),C(tt)),{coerceType:upe}=(qf(),C(wI)),x1="No records parsed from csv file.",vl=`${ope.get("HDB_ROOT")}/tmp`,{schema_regex:dpe}=Di(),B1=1024*1024*2,H1=5e3,fpe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};W1.exports={csvDataLoad:_pe,csvURLLoad:ppe,csvFileLoad:hpe,importFromS3:mpe};async function _pe(e,t){let r=nT.dataObject(e);if(r)throw kt(r,r.message,xr.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=V1(e.schema,e.table),i=AI.parse(e.data,{header:!0,skipEmptyLines:!0,transform:RI.bind(null,s),dynamicTyping:!1}),o=new bI;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 kt(new Error,c,xr.BAD_REQUEST,void 0,void 0,!0);let l=new cpe(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(_pe,"csvDataLoad");async function ppe(e){let t=nT.urlObject(e);if(t)throw kt(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${vl}/${r}`;try{await Epe(e,r)}catch(s){throw kd.error(Tr.DOWNLOAD_FILE_ERR(r)+" - "+s),kt(s,Ul(Tr.DOWNLOAD_FILE_ERR(r)))}try{let s=new yI(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 OI(s);return await rT(n),i}catch(s){throw await rT(n),xl(s)}}a(ppe,"csvURLLoad");async function hpe(e){let t=nT.fileObject(e);if(t)throw kt(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r=new yI(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 OI(r)}catch(n){throw xl(n)}}a(hpe,"csvFileLoad");async function mpe(e){let t=nT.s3FileObject(e);if(t)throw kt(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=ipe.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${vl}/${s}`;let i=new yI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await gpe(s,e);let o=await OI(i);return await rT(r),o}catch(n){throw await rT(r),xl(n)}}a(mpe,"importFromS3");async function Epe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await spe("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 kt(n,s,n.statusCode,_i.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Tpe(r,e.csv_url),await Spe(t,r.raw)}a(Epe,"downloadCSVFile");async function gpe(e,t){try{let r=`${vl}/${e}`;await pi.mkdirp(vl),await pi.writeFile(`${vl}/${e}`,"",{flag:"a+"});let n=await pi.createWriteStream(r),s=await ape.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(){kd.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw kd.error(Tr.S3_DOWNLOAD_ERR+" - "+r),kt(r,Ul(Tr.S3_DOWNLOAD_ERR))}}a(gpe,"downloadFileFromS3");async function Spe(e,t){try{await pi.mkdirp(vl),await pi.writeFile(`${vl}/${e}`,t)}catch(r){throw kd.error(Tr.WRITE_TEMP_FILE_ERR),kt(r,Ul(Tr.DEFAULT_BULK_LOAD_ERR))}}a(Spe,"writeFileToTempFolder");async function rT(e){if(e)try{await pi.access(e),await pi.unlink(e)}catch{kd.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(rT,"deleteTempFile");function Tpe(e,t){if(e.statusCode!==k1.HTTP_STATUS_CODES.OK)throw kt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,xr.BAD_REQUEST);if(!fpe[e.headers["content-type"]])throw kt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,xr.BAD_REQUEST);if(!e.raw)throw kt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,xr.BAD_REQUEST)}a(Tpe,"validateURLResponse");async function OI(e){try{let t;switch(e.file_type){case _i.VALID_S3_FILE_TYPES.CSV:t=await Ape(e);break;case _i.VALID_S3_FILE_TYPES.JSON:t=await Rpe(e);break;default:throw kt(new Error,Tr.DEFAULT_BULK_LOAD_ERR,xr.BAD_REQUEST,_i.LOG_LEVELS.ERROR,Tr.INVALID_FILE_EXT_ERR(e))}return Y1(t.records,t.number_written)}catch(t){throw xl(t)}}a(OI,"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=kt(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;Hd.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Hd.isEmpty(c)&&!Hd.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=kt(c,Ul(Tr.INSERT_CSV_ERR),xr.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Tr.INSERT_CSV_ERR+" - "+c);r(l)}}a($1,"insertChunk");async function Ape(e){let t={records:0,number_written:0},r=V1(e.schema,e.table);try{let n=new bI,s=pi.createReadStream(e.file_path,{highWaterMark:B1});s.setEncoding("utf8"),await AI.parsePromise(s,q1.bind(null,e,n),RI.bind(null,r));let i=n.getPermsResponse();if(i)throw kt(new Error,i,xr.BAD_REQUEST);return s=pi.createReadStream(e.file_path,{highWaterMark:B1}),s.setEncoding("utf8"),await AI.parsePromise(s,$1.bind(null,e,t),RI.bind(null,r)),s.destroy(),t}catch(n){throw kt(n,Ul(Tr.PAPA_PARSE_ERR),xr.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Tr.PAPA_PARSE_ERR+n)}}a(Ape,"callPapaParse");function V1(e,t){let r=lpe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>upe(i,s));return n}a(V1,"createTransformMap");function RI(e,t,r){let n=e.get(r);return n?n(t):Hd.autoCast(t)}a(RI,"typeFunction");async function Rpe(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new bI,s=D1([pi.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 kt(new Error,i,xr.BAD_REQUEST);let o=D1([pi.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 kt(n,Ul(Tr.INSERT_JSON_ERR),xr.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Tr.INSERT_JSON_ERR+n)}}a(Rpe,"insertJson");async function K1(e){let t={};try{e.data&&e.data.length>0&&ype(e.data[0])?t=await bpe(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",kd.info(t.message))}catch(r){throw xl(r)}return t}a(K1,"callBulkFileLoad");function ype(e){let t=Object.keys(e);for(let r of t)if(!dpe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(ype,"validateColumnNames");async function bpe(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 kt(new Error,Tr.INVALID_ACTION_PARAM_ERR(n),xr.BAD_REQUEST,_i.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=Hd.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw xl(o)}}a(bpe,"bulkFileLoad");function Y1(e,t){return`successfully loaded ${t} of ${e} records`}a(Y1,"buildResponseMsg");function xl(e){return kt(e,Ul(Tr.DEFAULT_BULK_LOAD_ERR),xr.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Tr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(xl,"buildTopLevelErrMsg")});var PI=w((_ve,tK)=>{"use strict";var CI=Yr(),Ope=EI(),{AsyncParser:Npe}=require("json2csv"),sT=require("stream"),is=ie(),II=require("fs-extra"),wpe=require("path"),Ls=z(),{promisify:J1}=require("util"),nh=ie(),{handleHDBError:dr,hdb_errors:Ipe}=pe(),{HDB_ERROR_MSGS:Pn,HTTP_STATUS_CODES:fr}=Ipe,{streamAsJSON:Cpe}=(bR(),C(VL)),{Upload:Ppe}=require("@aws-sdk/lib-storage"),{toCsvStream:Dpe}=(ao(),C(uM)),z1=["search_by_value","search_by_hash","sql","search_by_conditions"],j1=["json","csv"],Q1="json",X1="csv",Lpe="Successfully exported JSON locally.",Mpe="Successfully exported CSV locally.",vpe=1e3,Upe=CI.searchByHash,xpe=CI.searchByValue,Bpe=J1(sT.finished);tK.exports={export_to_s3:Gpe,export_local:Hpe};async function Hpe(e){Ls.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=Z1(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(Pn.MISSING_VALUE("path")),dr(new Error,Pn.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(wpe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=is.buildFolderPath(e.path,r);await kpe(e.path);let s=await eK(e);return await Fpe(n,e.format,s)}a(Hpe,"export_local");async function kpe(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 II.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(kpe,"confirmPath");async function Fpe(e,t,r){if(Ls.trace("in saveToLocal"),nh.isEmptyOrZeroLength(e))throw dr(new Error,Pn.INVALID_VALUE("file_path"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmptyOrZeroLength(t))throw dr(new Error,Pn.INVALID_VALUE("Source format"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmpty(r))throw dr(new Error,Pn.NOT_FOUND("Data"),fr.BAD_REQUEST,void 0,void 0,!0);if(t===Q1){let n=II.createWriteStream(e);return Cpe(r).pipe(n),await Bpe(n),{message:Lpe,path:e}}else if(t===X1){let n=II.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 Npe(i,c).fromInput(s).toOutput(n).promise(!1),{message:Mpe,path:e}}throw dr(new Error,Pn.INVALID_VALUE("format"),fr.BAD_REQUEST)}a(Fpe,"saveToLocal");async function Gpe(e){if(!e.s3||Object.keys(e.s3).length===0)throw dr(new Error,Pn.MISSING_VALUE("S3 object"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw dr(new Error,Pn.MISSING_VALUE("aws_access_key_id"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw dr(new Error,Pn.MISSING_VALUE("aws_secret_access_key"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.bucket))throw dr(new Error,Pn.MISSING_VALUE("bucket"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.key))throw dr(new Error,Pn.MISSING_VALUE("key"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.region))throw dr(new Error,Pn.MISSING_VALUE("region"),fr.BAD_REQUEST);let t=Z1(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 eK(e)}catch(l){throw Ls.error(l),l}let n,s=await Ope.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=Dpe(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===Q1){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%vpe===0&&(l.push(f),f="")}f.length!==0&&l.push(f),l.push("]"),l.push(null)}else throw dr(new Error,Pn.INVALID_VALUE("format"),fr.BAD_REQUEST);return new Ppe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(Gpe,"export_to_s3");function Z1(e){if(Ls.trace("in exportCoreValidation"),is.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(is.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){Ls.trace("in getRecords");let t,r;if(nh.isEmpty(e.search_operation)||nh.isEmptyOrZeroLength(e.search_operation.operation))throw dr(new Error,Pn.INVALID_VALUE("Search operation"),fr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=xpe;break;case"search_by_hash":t=Upe;break;case"search_by_conditions":t=CI.searchByConditions;break;case"sql":{let n=WS();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(eK,"getRecords")});var nK=w((hve,rK)=>{"use strict";var DI=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};rK.exports=DI});var oK=w((Eve,iK)=>{"use strict";var qpe=(H(),C(G)),sK=require("moment"),$pe=require("uuid").v4,LI=class{static{a(this,"JobObject")}constructor(){this.id=$pe(),this.type=void 0,this.start_datetime=sK().valueOf(),this.created_datetime=sK().valueOf(),this.end_datetime=void 0,this.status=qpe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};iK.exports=LI});var MI=w((Sve,pK)=>{"use strict";var Vpe=require("uuid").v4,dK=Rn(),fK=Yr(),Kpe=ni(),Ype=ku(),Wpe=nK(),Ot=(H(),C(G)),zpe=oK(),jpe=rg(),hi=z(),Jpe=Uf(),Fd=ie(),{promisify:Qpe}=require("util"),Bl=require("moment"),Xpe=WS(),iT=hI(),aK=Cy(),{deleteTransactionLogsBeforeValidator:Zpe}=jw(),{handleHDBError:cK,hdb_errors:ehe,ClientError:the}=pe(),{HTTP_STATUS_CODES:lK}=ehe,uK=fK.searchByValue,rhe=fK.searchByHash,nhe=dK.insert,she=Qpe(Xpe.evaluateSQL),ihe=dK.update;pK.exports={addJob:che,updateJob:uhe,handleGetJob:ohe,handleGetJobsByStartDate:ahe,getJobById:_K};async function ohe(e){if(e.id===void 0)throw new the("'id' is required");let t=await _K(e.id);return Fd.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(ohe,"handleGetJob");async function ahe(e){try{let t=await lhe(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=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 hi.error(r),new Error(r)}}a(ahe,"handleGetJobsByStartDate");async function che(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Fd.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=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=Zpe(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 zpe;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 Kpe(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 hi.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Vpe();try{o=await uK(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 Jpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await nhe(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(che,"addJob");async function lhe(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 Wpe(n,e.hdb_user);try{return await she(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(lhe,"getJobsInDateRange");async function _K(e){if(Fd.isEmptyOrZeroLength(e))return Fd.errorizeMessage("Invalid job ID specified.");let t=new Ype(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await rhe(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return hi.error(n),Fd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(_K,"getJobById");async function uhe(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Fd.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 ihe(t),r}a(uhe,"updateJob")});var RK=w((Ave,AK)=>{"use strict";var hK=ie(),Ar=(H(),C(G)),dhe=require("moment"),oT=NI(),sh=z(),mK=MI(),EK=PI(),gK=Vc(),SK=et(),fhe=GS(),_he=Wa(),{parentPort:phe,isMainThread:TK}=require("worker_threads"),{onMessageByType:hhe}=et(),vI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function mhe(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 Ki(e,oT.csvFileLoad);break;case Ar.JOB_TYPE_ENUM.csv_url_load:await Ki(e,oT.csvURLLoad);break;case Ar.JOB_TYPE_ENUM.csv_data_load:await Ki(e,oT.csvDataLoad);break;case Ar.JOB_TYPE_ENUM.import_from_s3:await Ki(e,oT.importFromS3);break;case Ar.JOB_TYPE_ENUM.empty_trash:break;case Ar.JOB_TYPE_ENUM.export_local:await Ki(e,EK.export_local);break;case Ar.JOB_TYPE_ENUM.export_to_s3:await Ki(e,EK.export_to_s3);break;case Ar.JOB_TYPE_ENUM.delete_files_before:case Ar.JOB_TYPE_ENUM.delete_records_before:await Ki(e,gK.deleteFilesBefore);break;case Ar.JOB_TYPE_ENUM.delete_audit_logs_before:await Ki(e,gK.deleteAuditLogsBefore);break;case Ar.JOB_TYPE_ENUM.delete_transaction_logs_before:await Ki(e,fhe.deleteTransactionLogsBefore);break;case Ar.JOB_TYPE_ENUM.restart_service:return await Ki(e,_he.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(mhe,"parseMessage");async function Ki(e,t){try{e.job.status=Ar.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=dhe().valueOf(),await mK.updateJob(e.job),await Ehe(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(Ki,"runJob");async function Ehe(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}`}}):phe.postMessage({type:Ar.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(Ehe,"launchJobThread");TK&&hhe(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:mhe,RunnerMessage:vI}});var bK=w((yve,yK)=>{"use strict";var UI=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};yK.exports=UI});var zw=w((Nve,GI)=>{"use strict";var dT=Yr(),HI=WS(),aT=NI(),qo=Vg(),cT=go(),oh=Vc(),ghe=bN(),ih=An(),lT=F_(),Ct=Ww(),uT=z(),She=CN(),The=gd(),OK=ew(),Ahe=nS(),Rhe=nw(),yhe=sw(),bhe=aS(),Ohe=lS(),xI=uS(),NK=PI(),Nhe=KS(),kI=MI(),V=(H(),C(G)),{hdb_errors:ch,handleHDBError:ah}=pe(),{HTTP_STATUS_CODES:wK}=ch,BI=hS(),IK=Wa(),HK=require("util"),qd=Rn(),whe=As(),Ihe=Po(),CK=RK(),PK=(ju(),C(X_)),DK=(MS(),C(Gp)),LK=yt(),MK=GS(),vK=Kp(),{setServerUtilities:Che}=(qf(),C(wI)),{CONTEXT:Ove}=(Ea(),C(ER)),{_assignPackageExport:Phe}=Ti(),{transformReq:Dhe}=ie(),{server:Lhe}=(Vr(),C(Tu)),nn=uT.loggerWithTag("operation"),Gd=Zn(),UK=(Tl(),C(Sl)),Mhe=mI(),xK=dT.searchByHash,vhe=dT.searchByValue,Uhe=HK.promisify(dT.search),xhe=HK.promisify(HI.evaluateSQL),Bhe={[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},ee=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 Mhe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Bhe[e.body.operation]&&whe.setSchemaDataToGlobal(n=>{n&&nn.error(n)}),r}a(kK,"processLocalTransaction");var BK=khe();GI.exports={chooseOperation:FK,getOperationFunction:GK,operation:FI,processLocalTransaction:kK,executeJob:Ms};Che(GI.exports);Lhe.operation=FI;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=HI.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=HI.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=Nhe.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");Phe("operation",FI);function FI(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=FK(e);return kK({body:e},n)}a(FI,"operation");async function Hhe(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 qd.insert(i);break;case V.OPERATIONS_ENUM.UPDATE:o=await qd.update(i);break;case V.OPERATIONS_ENUM.UPSERT:o=await qd.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(Hhe,"catchup");async function Ms(e){Dhe(e);let t,r;try{r=await kI.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(Ms,"executeJob");function khe(){let e=new Map;return e.set(V.OPERATIONS_ENUM.INSERT,new ee(qd.insert)),e.set(V.OPERATIONS_ENUM.UPDATE,new ee(qd.update)),e.set(V.OPERATIONS_ENUM.UPSERT,new ee(qd.upsert)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new ee(dT.searchByConditions)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_HASH,new ee(xK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_ID,new ee(xK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_VALUE,new ee(vhe)),e.set(V.OPERATIONS_ENUM.SEARCH,new ee(Uhe)),e.set(V.OPERATIONS_ENUM.SQL,new ee(xhe)),e.set(V.OPERATIONS_ENUM.CSV_DATA_LOAD,new ee(Ms,aT.csvDataLoad)),e.set(V.OPERATIONS_ENUM.CSV_FILE_LOAD,new ee(Ms,aT.csvFileLoad)),e.set(V.OPERATIONS_ENUM.CSV_URL_LOAD,new ee(Ms,aT.csvURLLoad)),e.set(V.OPERATIONS_ENUM.IMPORT_FROM_S3,new ee(Ms,aT.importFromS3)),e.set(V.OPERATIONS_ENUM.CREATE_SCHEMA,new ee(qo.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_DATABASE,new ee(qo.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_TABLE,new ee(qo.createTable)),e.set(V.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new ee(qo.createAttribute)),e.set(V.OPERATIONS_ENUM.DROP_SCHEMA,new ee(qo.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_DATABASE,new ee(qo.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_TABLE,new ee(qo.dropTable)),e.set(V.OPERATIONS_ENUM.DROP_ATTRIBUTE,new ee(qo.dropAttribute)),e.set(V.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new ee(cT.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_DATABASE,new ee(cT.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_TABLE,new ee(cT.describeTable)),e.set(V.OPERATIONS_ENUM.DESCRIBE_ALL,new ee(cT.describeAll)),e.set(V.OPERATIONS_ENUM.DELETE,new ee(oh.deleteRecord)),e.set(V.OPERATIONS_ENUM.ADD_USER,new ee(ih.addUser)),e.set(V.OPERATIONS_ENUM.ALTER_USER,new ee(ih.alterUser)),e.set(V.OPERATIONS_ENUM.DROP_USER,new ee(ih.dropUser)),e.set(V.OPERATIONS_ENUM.LIST_USERS,new ee(ih.listUsersExternal)),e.set(V.OPERATIONS_ENUM.LIST_ROLES,new ee(lT.listRoles)),e.set(V.OPERATIONS_ENUM.ADD_ROLE,new ee(lT.addRole)),e.set(V.OPERATIONS_ENUM.ALTER_ROLE,new ee(lT.alterRole)),e.set(V.OPERATIONS_ENUM.DROP_ROLE,new ee(lT.dropRole)),e.set(V.OPERATIONS_ENUM.USER_INFO,new ee(ih.userInfo)),e.set(V.OPERATIONS_ENUM.READ_LOG,new ee(She)),e.set(V.OPERATIONS_ENUM.ADD_NODE,new ee(The)),e.set(V.OPERATIONS_ENUM.UPDATE_NODE,new ee(OK)),e.set(V.OPERATIONS_ENUM.SET_NODE_REPLICATION,new ee(OK)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE,new ee(Ahe)),e.set(V.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new ee(Rhe)),e.set(V.OPERATIONS_ENUM.PURGE_STREAM,new ee(yhe)),e.set(V.OPERATIONS_ENUM.SET_CONFIGURATION,new ee(LK.setConfiguration)),e.set(V.OPERATIONS_ENUM.CLUSTER_STATUS,new ee(bhe.clusterStatus)),e.set(V.OPERATIONS_ENUM.CLUSTER_NETWORK,new ee(Ohe)),e.set(V.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new ee(xI.setRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new ee(xI.getRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new ee(xI.deleteRoutes)),e.set(V.OPERATIONS_ENUM.EXPORT_TO_S3,new ee(Ms,NK.export_to_s3)),e.set(V.OPERATIONS_ENUM.CREATE_CSR,new ee(Gd.createCsr)),e.set(V.OPERATIONS_ENUM.SIGN_CERTIFICATE,new ee(Gd.signCertificate)),e.set(V.OPERATIONS_ENUM.LIST_CERTIFICATES,new ee(Gd.listCertificates)),e.set(V.OPERATIONS_ENUM.ADD_CERTIFICATES,new ee(Gd.addCertificate)),e.set(V.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new ee(Gd.removeCertificate)),e.set(V.OPERATIONS_ENUM.GET_KEY,new ee(Gd.getKey)),e.set(V.OPERATIONS_ENUM.ADD_NODE_BACK,new ee(UK.addNodeBack)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE_BACK,new ee(UK.removeNodeBack)),e.set(V.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new ee(Ms,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new ee(Ms,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.EXPORT_LOCAL,new ee(Ms,NK.export_local)),e.set(V.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new ee(kI.handleGetJobsByStartDate)),e.set(V.OPERATIONS_ENUM.GET_JOB,new ee(kI.handleGetJob)),e.set(V.OPERATIONS_ENUM.GET_FINGERPRINT,new ee(BI.getFingerprint)),e.set(V.OPERATIONS_ENUM.SET_LICENSE,new ee(BI.setLicense)),e.set(V.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new ee(BI.getRegistrationInfo)),e.set(V.OPERATIONS_ENUM.RESTART,new ee(IK.restart)),e.set(V.OPERATIONS_ENUM.RESTART_SERVICE,new ee(Ms,IK.restartService)),e.set(V.OPERATIONS_ENUM.CATCHUP,new ee(Hhe)),e.set(V.OPERATIONS_ENUM.SYSTEM_INFORMATION,new ee(Ihe.systemInformation)),e.set(V.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new ee(Ms,oh.deleteAuditLogsBefore)),e.set(V.OPERATIONS_ENUM.READ_AUDIT_LOG,new ee(ghe)),e.set(V.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new ee(PK.createTokens)),e.set(V.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new ee(PK.refreshOperationToken)),e.set(V.OPERATIONS_ENUM.LOGIN,new ee(DK.login)),e.set(V.OPERATIONS_ENUM.LOGOUT,new ee(DK.logout)),e.set(V.OPERATIONS_ENUM.GET_CONFIGURATION,new ee(LK.getConfiguration)),e.set(V.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new ee(Ct.customFunctionsStatus)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new ee(Ct.getCustomFunctions)),e.set(V.OPERATIONS_ENUM.GET_COMPONENT_FILE,new ee(Ct.getComponentFile)),e.set(V.OPERATIONS_ENUM.GET_COMPONENTS,new ee(Ct.getComponents)),e.set(V.OPERATIONS_ENUM.SET_COMPONENT_FILE,new ee(Ct.setComponentFile)),e.set(V.OPERATIONS_ENUM.DROP_COMPONENT,new ee(Ct.dropComponent)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new ee(Ct.getCustomFunction)),e.set(V.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new ee(Ct.setCustomFunction)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new ee(Ct.dropCustomFunction)),e.set(V.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new ee(Ct.addComponent)),e.set(V.OPERATIONS_ENUM.ADD_COMPONENT,new ee(Ct.addComponent)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new ee(Ct.dropCustomFunctionProject)),e.set(V.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new ee(Ct.packageComponent)),e.set(V.OPERATIONS_ENUM.PACKAGE_COMPONENT,new ee(Ct.packageComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new ee(Ct.deployComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_COMPONENT,new ee(Ct.deployComponent)),e.set(V.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new ee(MK.readTransactionLog)),e.set(V.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new ee(Ms,MK.deleteTransactionLogsBefore)),e.set(V.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new ee(vK.installModules)),e.set(V.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new ee(vK.auditModules)),e.set(V.OPERATIONS_ENUM.GET_BACKUP,new ee(qo.getBackup)),e.set(V.OPERATIONS_ENUM.ADD_SSH_KEY,new ee(Ct.addSSHKey)),e.set(V.OPERATIONS_ENUM.UPDATE_SSH_KEY,new ee(Ct.updateSSHKey)),e.set(V.OPERATIONS_ENUM.DELETE_SSH_KEY,new ee(Ct.deleteSSHKey)),e.set(V.OPERATIONS_ENUM.LIST_SSH_KEYS,new ee(Ct.listSSHKeys)),e.set(V.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new ee(Ct.setSSHKnownHosts)),e.set(V.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new ee(Ct.getSSHKnownHosts)),e}a(khe,"initializeOperationFunctionMap")});var pT=w((Ive,VK)=>{"use strict";var fT=(H(),C(G)),Fhe=ie(),lh=z(),{handleHDBError:qI,hdb_errors:_T}=pe(),{isMainThread:Ghe}=require("worker_threads"),{Readable:qhe}=require("stream"),qK=require("os"),$he=require("util"),Vhe=NO(),Khe=$he.promisify(Vhe.authorize),$K=zw(),{createGzip:Yhe,constants:Whe}=require("zlib"),zhe=[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 ${Ghe?"HDB":"thread"}.`;console.error(t),lh.fatal(t),process.exit(1)}a(jhe,"handleServerUncaughtException");function Jhe(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(Jhe,"serverErrorHandler");function Qhe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=qI(new Error,"Invalid JSON.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(Fhe.isEmpty(e.body.operation)){let n=qI(new Error,"Request body must include an 'operation' property.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Qhe,"reqBodyValidationHandler");function Xhe(e,t,r){let n;!zhe.includes(e.body.operation)||e.body.operation===fT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&!e.body.username&&!e.body.password?Khe(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(qI(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(Xhe,"authHandler");async function Zhe(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 qhe&&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(Yhe({level:Whe.Z_BEST_SPEED})))}return s}catch(s){throw lh.error(s),s}}a(Zhe,"handlePostRequest");VK.exports={authHandler:Xhe,handlePostRequest:Zhe,handleServerUncaughtException:jhe,serverErrorHandler:Jhe,reqBodyValidationHandler:Qhe}});var zK=w((Pve,WK)=>{"use strict";var eme=require("fastify-plugin"),{handlePostRequest:KK,authHandler:tme,reqBodyValidationHandler:rme}=pT();async function nme(e){e.decorate("hdbCore",{preValidation:[rme,tme],request:a(t=>YK(KK(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>YK(KK(t,r,!0)),"requestWithoutAuthentication")})}a(nme,"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=eme(nme)});var JK=w((Mve,jK)=>{"use strict";var Lve=require("fs"),hT=ae();hT.initSync();var{CONFIG_PARAMS:$I}=(H(),C(G)),sme=1024*1024*1024;function ime(e){let t=hT.get($I.HTTP_TIMEOUT),r=hT.get($I.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:sme,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:hT.get($I.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(ime,"getServerOptions");jK.exports=ime});var ZK=w((Uve,XK)=>{"use strict";var VI=ae();VI.initSync();var{CONFIG_PARAMS:QK}=(H(),C(G));function ome(){let e=VI.get(QK.HTTP_CORSACCESSLIST),t=VI.get(QK.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(ome,"getCORSOptions");XK.exports=ome});var rY=w((Bve,tY)=>{"use strict";var eY=ae();eY.initSync();var ame=(H(),C(G));function cme(){return eY.get(ame.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(cme,"getHeaderTimeoutConfig");tY.exports=cme});var YI={};ve(YI,{customFunctionsServer:()=>dme,ready:()=>mY,start:()=>ume});function ume(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){$o||($o=hY(t),Ye.http((await $o).server));let o=await $o,c=(0,KI.dirname)(s),l=(0,KI.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!nY.has(c)){nY.add(c);try{o.register(_me(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 dme(){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 fme();let e=lY.get(B.HTTP_SECUREPORT)>0,t;try{t=$o=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 fme(){try{ht.info("Custom Functions starting configuration."),await uY.setUsersWithRolesCache(),ht.info("Custom Functions completed configuration.")}catch(e){ht.error(e)}}function _me(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(lme),await r.after(),jf(r),ht.info("Custom Functions completed buildServer."),r}function mY(){if($o)return $o.then?$o.then(e=>e.ready()):$o.ready()}var KI,sY,iY,oY,aY,cY,lY,ht,lme,uY,dY,fY,_Y,pY,$o,nY,EY=be(()=>{KI=require("path"),sY=require("fs"),iY=M(require("fastify")),oY=M(require("@fastify/cors")),aY=M(AO()),cY=M(require("@fastify/autoload")),lY=M(ae());H();ht=M(z()),lme=M(zK()),uY=M(An()),dY=M(JK()),fY=M(ZK()),_Y=M(rY()),pY=M(pT());ao();Vr();nY=new Set;a(ume,"start");a(dme,"customFunctionsServer");a(fme,"setUp");a(_me,"buildRouteFolder");a(hY,"buildServer");a(mY,"ready")});var WI={};ve(WI,{start:()=>pme});function pme(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(pme,"start")});var zI={};ve(zI,{start:()=>hme});function hme({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(hme,"start")});var wY={};ve(wY,{Request:()=>jI,createReuseportFd:()=>ET});var NY,jI,JI,QI,ET,XI=be(()=>{NY=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 QI(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 JI(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)}},JI=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)}},QI=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 eC=w((Yve,IY)=>{"use strict";var uh=ae();uh.initSync();var $d=require("fs-extra"),ZI=require("path"),Vd=(H(),C(G)),mme=require("crypto"),Eme=require("uuid").v4;IY.exports=gme;function gme(){if(uh.getHdbBasePath()!==void 0){let e=ZI.join(uh.getHdbBasePath(),Vd.LICENSE_KEY_DIR_NAME,Vd.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=ZI.join(uh.getHdbBasePath(),Vd.LICENSE_KEY_DIR_NAME,Vd.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=ZI.join(uh.getHdbBasePath(),Vd.LICENSE_KEY_DIR_NAME,Vd.JWT_ENUM.JWT_PASSPHRASE_NAME);try{$d.accessSync(r),$d.accessSync(e),$d.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=Eme(),i=mme.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});$d.writeFileSync(r,s),$d.writeFileSync(e,i.privateKey),$d.writeFileSync(t,i.publicKey)}else throw n}}}a(gme,"checkJWTTokenExist")});var PY=w((zve,CY)=>{"use strict";var tC=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:tC}});var MY=w((Jve,LY)=>{"use strict";var DY=(H(),C(G)),rC=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:rC}});var gT=w((Xve,UY)=>{"use strict";var vs=require("prompt"),Kd=require("chalk"),vY=z(),mi=require("os"),nC=ua(),sC=["yes","y"];async function Sme(e){let t=`${mi.EOL}`+Kd.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=nC(["CONFIRM_UPGRADE"]),vs.start(),vs.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Kd.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 vY.error("There was an error when prompting user about an upgrade."),vY.error(s),!1}return sC.includes(n.CONFIRM_UPGRADE)}a(Sme,"forceUpdatePrompt");async function Tme(e){let t=`${mi.EOL}`+Kd.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=nC(["CONFIRM_DOWNGRADE"]),vs.start(),vs.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Kd.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 sC.includes(n.CONFIRM_DOWNGRADE)}a(Tme,"forceDowngradePrompt");async function Ame(){let e=`${mi.EOL}`+Kd.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=nC(["GENERATE_CERTS"]),vs.start(),vs.message=e;let t={properties:{GENERATE_CERTS:{description:Kd.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 sC.includes(r.GENERATE_CERTS)}a(Ame,"upgradeCertsPrompt");UY.exports={forceUpdatePrompt:Sme,forceDowngradePrompt:Tme,upgradeCertsPrompt:Ame}});var oC=w((eUe,xY)=>{"use strict";var iC=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};xY.exports=iC});var HY=w((oUe,BY)=>{"use strict";var Rme=ie(),yme=yt(),rUe=z(),nUe=require("path"),sUe=require("fs"),iUe=(H(),C(G));BY.exports={getOldPropsValue:bme};function bme(e,t,r=!1){let n=t.getRaw(e);return Rme.isNotEmptyAndHasValue(n)?n:r?yme.getDefaultConfig(e):""}a(bme,"getOldPropsValue")});var qY=w((cUe,GY)=>{"use strict";var Xa=require("path"),Za=require("fs-extra"),Ome=require("properties-reader"),Nme=oC(),_r=z(),{getOldPropsValue:mt}=HY(),{HDB_SETTINGS_NAMES:ge,CONFIG_PARAMS:Hl}=(H(),C(G)),kl=yt(),ST=ae(),kY=ie(),Yi=(H(),C(G)),aC=new Nme("3.1.0"),FY=[];function wme(){let e=Ome(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(Fo)||(await Oe.writeFile(Fo,""),await Oe.chmod(Fo,"0600")),i=="github.com"&&!(await Oe.readFile(Fo,"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(Fo,"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(Fo,o);let d=await _i(e);return d.message=`Added ssh key: ${r}${f}`,d}a(Hfe,"addSSHKey");async function kfe(e){let t=Pn.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(Xa,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(kfe,"updateSSHKey");async function Ffe(e){let t=Pn.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(Xa,r+".key"),s=we.join(Xa,"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(Ffe,"deleteSSHKey");async function Gfe(e){let t=[];return await Oe.pathExists(Xa)&&(await Oe.readdir(Xa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(Gfe,"listSSHKeys");async function qfe(e){let t=Pn.setSSHKnownHostsValidator(e);if(t)throw Ht(t,t.message,kt.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(qfe,"setSSHKnownHosts");async function $fe(e){return await Oe.pathExists(Fo)?{known_hosts:await Oe.readFile(Fo,"utf8")}:{known_hosts:null}}a($fe,"getSSHKnownHosts");Object.assign(xV,{customFunctionsStatus:bfe,getCustomFunctions:Ofe,getCustomFunction:Nfe,setCustomFunction:wfe,dropCustomFunction:Ife,addComponent:Cfe,dropCustomFunctionProject:Pfe,packageComponent:Dfe,deployComponent:Lfe,getComponents:vfe,getComponentFile:Ufe,setComponentFile:xfe,dropComponent:Bfe,addSSHKey:Hfe,updateSSHKey:kfe,deleteSSHKey:Ffe,listSSHKeys:Gfe,setSSHKnownHosts:qfe,getSSHKnownHosts:$fe})});var Jw=I((UMe,HV)=>{"use strict";var Ds=require("joi"),BV=it();HV.exports={readTransactionLogValidator:Vfe,deleteTransactionLogsBeforeValidator:Kfe};function Vfe(e){let t=Ds.object({schema:Ds.string(),database:Ds.string(),table:Ds.string().required(),from:Ds.date().timestamp(),to:Ds.date().timestamp(),limit:Ds.number().min(1)});return BV.validateBySchema(e,t)}a(Vfe,"readTransactionLogValidator");function Kfe(e){let t=Ds.object({schema:Ds.string(),database:Ds.string(),table:Ds.string().required(),timestamp:Ds.date().timestamp().required()});return BV.validateBySchema(e,t)}a(Kfe,"deleteTransactionLogsBeforeValidator")});var $S=I((BMe,VV)=>{"use strict";var Qw=(H(),P(G)),Qp=ir(),kV=ae(),FV=ce(),GV=go(),qV=W(),{handleHDBError:GS,hdb_errors:Yfe}=pe(),{HTTP_STATUS_CODES:qS}=Yfe,{readTransactionLogValidator:Wfe,deleteTransactionLogsBeforeValidator:zfe}=Jw(),$V=Kn(),jfe="Logs successfully deleted from transaction log.",Jfe="All logs successfully deleted from transaction log.";VV.exports={readTransactionLog:Qfe,deleteTransactionLogsBefore:Zfe};async function Qfe(e){let t=Wfe(e);if(t)throw GS(t,t.message,qS.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 GS(new Error,r,qS.NOT_FOUND,void 0,void 0,!0);return FV.get(Qw.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Xfe(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(Qfe,"readTransactionLog");async function*Xfe(e){let t=GV.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===Qw.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Xfe,"readTransactionLogNats");async function Zfe(e){let t=zfe(e);if(t)throw GS(t,t.message,qS.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 GS(new Error,i,qS.NOT_FOUND,void 0,void 0,!0);let o=GV.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=jfe,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(Zfe,"deleteTransactionLogsBefore")});var YV=I((kMe,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=I((GMe,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=I(($Me,JV)=>{"use strict";var jV=YV(),e_e=zV(),{HDB_ERROR_MSGS:t_e}=Bn(),eI=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=t_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 e_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 WS=I((WMe,_1)=>{"use strict";var rI=bn(),VS=Wr(),Ls=Yg(),eh=So(),nI=jc(),r_e=ON(),n_e=fG(),th=yn(),KS=G_(),Tr=W(),s_e=PN(),i_e=Td(),o_e=tw(),a_e=iS(),c_e=sw(),l_e=iw(),u_e=lS(),d_e=dS(),sI=fS(),Go=ae(),f_e=Vq(),iI=ES(),ZV=ja(),nn=(H(),P(G)),e1=sV(),__e=Do(),t1=(Qu(),P(Z_)),r1=(US(),P(qp)),n1=Rt(),ur=zw(),p_e=require("alasql"),s1=$S(),i1=Yp(),Hd=es(),o1=(Ol(),P(bl)),a1=tI(),{handleHDBError:Dn,hdb_errors:c1}=pe(),{addNodeBack:KMe,removeNodeBack:YMe}=(Ol(),P(bl)),{HDB_ERROR_MSGS:xr,HTTP_STATUS_CODES:Xp}=c1,Z=new Map,l1="delete",Za="insert",qo="read",Bl="update",Zp="describe",QV=eh.describeSchema.name,XV=eh.describeTable.name,u1={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},h_e={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},m_e="catchup",E_e="handleGetJob",g_e="handleGetJobsByStartDate",YS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},S_e=[Ls.createTable.name,Ls.createAttribute.name,Ls.dropTable.name,Ls.dropAttribute.name],d1={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},ne=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};Z.set(rI.insert.name,new ne(!1,[Za]));Z.set(rI.update.name,new ne(!1,[Bl]));Z.set(rI.upsert.name,new ne(!1,[Za,Bl]));Z.set(VS.searchByConditions.name,new ne(!1,[qo]));Z.set(VS.searchByHash.name,new ne(!1,[qo]));Z.set(VS.searchByValue.name,new ne(!1,[qo]));Z.set(VS.search.name,new ne(!1,[qo]));Z.set(Ls.createSchema.name,new ne(!0,[]));Z.set(Ls.createTable.name,new ne(!0,[]));Z.set(Ls.createAttribute.name,new ne(!1,[Za]));Z.set(Ls.dropSchema.name,new ne(!0,[]));Z.set(Ls.dropTable.name,new ne(!0,[]));Z.set(Ls.dropAttribute.name,new ne(!0,[]));Z.set(eh.describeSchema.name,new ne(!1,[qo]));Z.set(eh.describeTable.name,new ne(!1,[qo]));Z.set(nI.deleteRecord.name,new ne(!1,[l1]));Z.set(th.addUser.name,new ne(!0,[]));Z.set(th.alterUser.name,new ne(!0,[]));Z.set(th.dropUser.name,new ne(!0,[]));Z.set(th.listUsersExternal.name,new ne(!0,[]));Z.set(KS.listRoles.name,new ne(!0,[]));Z.set(KS.addRole.name,new ne(!0,[]));Z.set(KS.alterRole.name,new ne(!0,[]));Z.set(KS.dropRole.name,new ne(!0,[]));Z.set(s_e.name,new ne(!0,[]));Z.set(i_e.name,new ne(!0,[]));Z.set(o_e.name,new ne(!0,[]));Z.set(a_e.name,new ne(!0,[]));Z.set(c_e.name,new ne(!0,[]));Z.set(l_e.name,new ne(!0,[]));Z.set(sI.setRoutes.name,new ne(!0,[]));Z.set(sI.getRoutes.name,new ne(!0,[]));Z.set(sI.deleteRoutes.name,new ne(!0,[]));Z.set(n1.setConfiguration.name,new ne(!0,[]));Z.set(u_e.clusterStatus.name,new ne(!0,[]));Z.set(d_e.name,new ne(!0,[]));Z.set(iI.getFingerprint.name,new ne(!0,[]));Z.set(iI.setLicense.name,new ne(!0,[]));Z.set(nI.deleteFilesBefore.name,new ne(!0,[]));Z.set(nI.deleteAuditLogsBefore.name,new ne(!0,[]));Z.set(ZV.restart.name,new ne(!0,[]));Z.set(ZV.restartService.name,new ne(!0,[]));Z.set(r_e.name,new ne(!0,[]));Z.set(n_e.name,new ne(!0,[qo]));Z.set(__e.systemInformation.name,new ne(!0,[]));Z.set(n1.getConfiguration.name,new ne(!0,[]));Z.set(s1.readTransactionLog.name,new ne(!0,[]));Z.set(s1.deleteTransactionLogsBefore.name,new ne(!0,[]));Z.set(i1.installModules.name,new ne(!0,[]));Z.set(i1.auditModules.name,new ne(!0,[]));Z.set(Hd.createCsr.name,new ne(!0,[]));Z.set(Hd.signCertificate.name,new ne(!0,[]));Z.set(Hd.listCertificates.name,new ne(!0,[]));Z.set(Hd.addCertificate.name,new ne(!0,[]));Z.set(Hd.removeCertificate.name,new ne(!0,[]));Z.set(Hd.getKey.name,new ne(!0,[]));Z.set(o1.addNodeBack.name,new ne(!0,[]));Z.set(o1.removeNodeBack.name,new ne(!0,[]));Z.set(t1.createTokens.name,new ne(!1,[]));Z.set(t1.refreshOperationToken.name,new ne(!1,[]));Z.set(r1.login.name,new ne(!1,[]));Z.set(r1.logout.name,new ne(!1,[]));Z.set(ur.customFunctionsStatus.name,new ne(!0,[]));Z.set(ur.getCustomFunctions.name,new ne(!0,[]));Z.set(ur.getComponents.name,new ne(!0,[]));Z.set(ur.getComponentFile.name,new ne(!0,[]));Z.set(ur.setComponentFile.name,new ne(!0,[]));Z.set(ur.dropComponent.name,new ne(!0,[]));Z.set(ur.getCustomFunction.name,new ne(!0,[]));Z.set(ur.setCustomFunction.name,new ne(!0,[]));Z.set(ur.dropCustomFunction.name,new ne(!0,[]));Z.set(ur.addComponent.name,new ne(!0,[]));Z.set(ur.dropCustomFunctionProject.name,new ne(!0,[]));Z.set(ur.packageComponent.name,new ne(!0,[]));Z.set(ur.deployComponent.name,new ne(!0,[]));Z.set(ur.addSSHKey.name,new ne(!0,[]));Z.set(ur.updateSSHKey.name,new ne(!0,[]));Z.set(ur.deleteSSHKey.name,new ne(!0,[]));Z.set(ur.listSSHKeys.name,new ne(!0,[]));Z.set(ur.setSSHKnownHosts.name,new ne(!0,[]));Z.set(ur.getSSHKnownHosts.name,new ne(!0,[]));Z.set(iI.getRegistrationInfo.name,new ne(!1,[]));Z.set(th.userInfo.name,new ne(!1,[]));Z.set(eh.describeAll.name,new ne(!1,[]));Z.set(E_e,new ne(!1,[]));Z.set(g_e,new ne(!0,[]));Z.set(m_e,new ne(!0,[]));Z.set(YS.CSV_DATA_LOAD,new ne(!1,[Za,Bl]));Z.set(YS.CSV_URL_LOAD,new ne(!1,[Za,Bl]));Z.set(YS.CSV_FILE_LOAD,new ne(!1,[Za,Bl]));Z.set(YS.IMPORT_FROM_S3,new ne(!1,[Za,Bl]));Z.set(d1.EXPORT_TO_S3,new ne(!0,[]));Z.set(d1.EXPORT_LOCAL,new ne(!0,[]));Z.set(nn.VALID_SQL_OPS_ENUM.DELETE,new ne(!1,[l1]));Z.set(nn.VALID_SQL_OPS_ENUM.SELECT,new ne(!1,[qo]));Z.set(nn.VALID_SQL_OPS_ENUM.INSERT,new ne(!1,[Za]));Z.set(nn.VALID_SQL_OPS_ENUM.UPDATE,new ne(!1,[Bl]));_1.exports={verifyPerms:A_e,verifyPermsAst:T_e,verifyBulkLoadAttributePerms:y_e};function T_e(e,t,r){if(Go.isEmptyOrZeroLength(e))throw Tr.info("verify_perms_ast has an empty user parameter"),Dn(new Error);if(Go.isEmptyOrZeroLength(t))throw Tr.info("verify_perms_ast has an empty user parameter"),Dn(new Error);if(Go.isEmptyOrZeroLength(r))throw Tr.info("verify_perms_ast has a null operation parameter"),Dn(new Error);try{let n=new a1,s=new f_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."),Dn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&u1[r])throw Dn(new Error,xr.DROP_SYSTEM,Xp.FORBIDDEN);if(c&&!l)return null;let u=e1.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof p_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 Dn(n)}}a(T_e,"verifyPermsAst");function A_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"),Dn(new Error,xr.DEFAULT_INVALID_REQUEST,Xp.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(Go.isEmptyOrZeroLength(e.hdb_user?.role)||Go.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(nn.SYSTEM_SCHEMA_NAME)||s===nn.SYSTEM_SCHEMA_NAME;if(l&&f&&h_e[e.operation]&&(i===nn.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===nn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===nn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(f&&u1[r])throw Dn(new Error,xr.DROP_SYSTEM,Xp.FORBIDDEN);if(l&&!f||u===!0&&(r===Ls.createSchema.name||r===Ls.dropSchema.name))return null;if(S_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===nn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(xr.SCHEMA_PERM_ERROR(s));if(r===QV&&(!d[s]||!d[s][Zp]))return c.handleInvalidItem(xr.SCHEMA_NOT_FOUND(s));if(r===XV&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Zp]))return c.handleInvalidItem(xr.TABLE_NOT_FOUND(s,i))}let p=f1(e.hdb_user,r,o,c,n);if(p)return p;if(Z.get(r)&&Z.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&nn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let S=[],g=d[s].tables[i];g[nn.PERMS_CRUD_ENUM.READ]&&(g.attribute_permissions.length>0?g.attribute_permissions.filter(E=>E[nn.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 _=R_e(e),h=aI(e.hdb_user?.role?.permission,s,i);return oI(_,h,r,i,s,c,n),c.getPermsResponse()}a(A_e,"verifyPerms");function f1(e,t,r,n,s){if(Go.arrayHasEmptyValues([e,t,r]))throw Tr.info("hasPermissions has an invalid parameter"),Dn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||Z.get(t).requires_su))return null;if(!Z.get(t))throw Tr.info(`operation ${t} not found.`),Dn(new Error,xr.OP_NOT_FOUND(t),Xp.BAD_REQUEST);if(Z.get(t)&&Z.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][Zp]===!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[Zp]===!1)n.addInvalidItem(xr.TABLE_NOT_FOUND(l,f));else try{let p=[],_=Z.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)&&(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),Dn(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."),Dn(new Error);let c=Z.get(r).perms;if(!c||c==="")throw Tr.info(`no permissions found for ${r} in checkAttributePerms().`),Dn(new Error);if(Go.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[Zp]===!1){i.addInvalidItem(xr.ATTR_NOT_FOUND(s,n,f),s,n);continue}if(c)for(let p of c){if(nn.TIME_STAMP_NAMES.includes(d.attribute_name)&&p!==qo)throw Dn(new Error,xr.SYSTEM_TIMESTAMP_PERMS_ERR,Xp.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 R_e(e){let t=new Set;try{if(e.action)return t;if(e.operation===nn.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(R_e,"getRecordAttributes");function aI(e,t,r){let n=new Map;if(Go.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 y_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(y_e,"verifyBulkLoadAttributePerms")});var jS=I((jMe,g1)=>{"use strict";g1.exports={evaluateSQL:x_e,processAST:E1,convertSQLToAST:m1,checkASTPermissions:h1};var b_e=bn(),p1=require("util"),O_e=p1.callbackify(b_e.insert),N_e=Wr().search,w_e=rk().update,I_e=p1.callbackify(w_e),C_e=sk().convertDelete,ec=require("alasql"),P_e=WS(),zS=W(),D_e=cE(),L_e=ae(),rh=(H(),P(G)),{hdb_errors:M_e,handleHDBError:cI}=pe(),{HTTP_STATUS_CODES:lI}=M_e;D_e(ec);var v_e=403,U_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 x_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 ec.yy.Insert?n=s.into.databaseid:s instanceof ec.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof ec.yy.Update||s instanceof ec.yy.Delete?n=s.table.databaseid:zS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof ec.yy.Select)&&L_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}E1(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(x_e,"evaluateSQL");function h1(e,t){let r;try{r=P_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=ec.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=B_e;if(!e.bypass_auth&&!t.permissions_checked){let i=h1(e,t);if(i&&i.length>0)return r(v_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case rh.VALID_SQL_OPS_ENUM.SELECT:n=N_e,s=t.ast.statements[0];break;case rh.VALID_SQL_OPS_ENUM.INSERT:n=H_e;break;case rh.VALID_SQL_OPS_ENUM.UPDATE:n=I_e;break;case rh.VALID_SQL_OPS_ENUM.DELETE:n=C_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 B_e(e,t){zS.info(e),t("unknown sql statement")}a(B_e,"nullFunction");function H_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=k_e(i,e.values)}catch(o){return r(o)}O_e(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){zS.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(H_e,"convertInsert");function k_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]]=ec.compile(`SELECT ${s.toString()} AS [${rh.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw zS.error(r),new Error(U_e)}}a(k_e,"createDataObjects")});var mI=I((ZMe,R1)=>{var ZS=require("clone"),eT=it(),F_e=ae(),QS=(H(),P(G)),QMe=W(),dI=require("fs"),_I=require("joi"),{string:XS}=_I.types(),{hdb_errors:G_e,handleHDBError:JS}=pe(),{HDB_ERROR_MSGS:XMe,HTTP_STATUS_CODES:fI}=G_e,{common_validators:kd}=Li(),S1=" is required",q_e=["insert","update","upsert"],pI={database:{presence:!1,format:kd.schema_format,length:kd.schema_length},schema:{presence:!1,format:kd.schema_format,length:kd.schema_length},table:{presence:!0,format:kd.schema_format,length:kd.schema_length},action:{inclusion:{within:q_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},$_e={schema:XS.required(),table:XS.required(),action:XS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:V_e,AWS_SECRET:K_e,AWS_BUCKET:Y_e,AWS_FILE_KEY:W_e,REGION:z_e}=QS.S3_BUCKET_AUTH_KEYS,j_e={s3:{presence:!0},[`s3.${V_e}`]:{presence:!0,type:"String"},[`s3.${K_e}`]:{presence:!0,type:"String"},[`s3.${Y_e}`]:{presence:!0,type:"String"},[`s3.${W_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${z_e}`]:{presence:!0,type:"String"}},T1=ZS(pI);T1.data.presence={message:S1};var A1=ZS(pI);A1.file_path.presence={message:S1};var J_e=Object.assign(ZS(pI),j_e),hI=ZS($_e);hI.csv_url=XS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();hI.passthrough_headers=_I.object();function Q_e(e){let t=eT.validateObject(e,T1);return tT(e,t)}a(Q_e,"dataObject");function X_e(e){let t=eT.validateBySchema(e,_I.object(hI));return tT(e,t)}a(X_e,"urlObject");function Z_e(e){let t=eT.validateObject(e,A1);return tT(e,t)}a(Z_e,"fileObject");function epe(e){let t=eT.validateObject(e,J_e);return tT(e,t)}a(epe,"s3FileObject");function tT(e,t){if(!t){let r=F_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return JS(new Error,r,fI.BAD_REQUEST);if(e.operation===QS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{dI.accessSync(e.file_path,dI.constants.R_OK|dI.constants.F_OK)}catch(n){return n.code===QS.NODE_ERROR_CODES.ENOENT?JS(n,`No such file or directory ${n.path}`,fI.BAD_REQUEST):n.code===QS.NODE_ERROR_CODES.EACCES?JS(n,`Permission denied ${n.path}`,fI.BAD_REQUEST):JS(n)}}return t}a(tT,"postValidateChecks");R1.exports={dataObject:Q_e,urlObject:X_e,fileObject:Z_e,s3FileObject:epe}});var EI=I((tve,y1)=>{"use strict";var nh=W(),rT=(H(),P(G));async function tpe(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===rT.OPERATIONS_ENUM.INSERT||t.operation===rT.OPERATIONS_ENUM.UPDATE||t.operation===rT.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===rT.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(nh.info(i.message),i):i.http_resp_msg?(nh.error(`Error calling operation: ${e.name}`),nh.error(i.http_resp_msg),i):(nh.error(`Error calling operation: ${e.name}`),nh.error(i),i)}}a(tpe,"callOperationFunctionAsAwait");y1.exports={callOperationFunctionAsAwait:tpe}});var gI=I((nve,O1)=>{"use strict";var{S3:rpe,GetObjectCommand:npe}=require("@aws-sdk/client-s3");O1.exports={getFileStreamFromS3:spe,getS3AuthObj:b1};async function spe(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 npe(r))).Body}a(spe,"getFileStreamFromS3");function b1(e,t,r){return new rpe({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(b1,"getS3AuthObj")});var w1=I((ive,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=I((ave,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=I((_ve,Y1)=>{"use strict";var nT=bn(),iT=mI(),ipe=require("needle"),pi=(H(),P(G)),lve=St(),Fd=ae(),{handleHDBError:Ft,hdb_errors:H1}=pe(),{HTTP_STATUS_CODES:Br,HDB_ERROR_MSGS:Ar,CHECK_LOGS_WRAPPER:kl}=H1,Gd=W(),RI=require("papaparse");Fd.promisifyPapaParse();var hi=require("fs-extra"),ope=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"),ape=ce(),k1=EI(),cpe=gI(),{BulkLoadFileObject:bI,BulkLoadDataObject:lpe}=w1(),OI=tI(),{verifyBulkLoadAttributePerms:F1}=WS(),uve=C1(),dve=ir(),fve=go(),{databases:upe}=(De(),P(nt)),{coerceType:dpe}=($f(),P(II)),U1="No records parsed from csv file.",Hl=`${ape.get("HDB_ROOT")}/tmp`,{schema_regex:fpe}=Li(),x1=1024*1024*2,B1=5e3,_pe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};Y1.exports={csvDataLoad:ppe,csvURLLoad:hpe,csvFileLoad:mpe,importFromS3:Epe};async function ppe(e,t){let r=iT.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 lpe(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 Fl(s)}}a(ppe,"csvDataLoad");async function hpe(e){let t=iT.urlObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Hl}/${r}`;try{await gpe(e,r)}catch(s){throw Gd.error(Ar.DOWNLOAD_FILE_ERR(r)+" - "+s),Ft(s,kl(Ar.DOWNLOAD_FILE_ERR(r)))}try{let s=new bI(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 NI(s);return await sT(n),i}catch(s){throw await sT(n),Fl(s)}}a(hpe,"csvURLLoad");async function mpe(e){let t=iT.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,pi.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await NI(r)}catch(n){throw Fl(n)}}a(mpe,"csvFileLoad");async function Epe(e){let t=iT.s3FileObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=ope.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Hl}/${s}`;let i=new bI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Spe(s,e);let o=await NI(i);return await sT(r),o}catch(n){throw await sT(r),Fl(n)}}a(Epe,"importFromS3");async function gpe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await ipe("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,pi.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Ape(r,e.csv_url),await Tpe(t,r.raw)}a(gpe,"downloadCSVFile");async function Spe(e,t){try{let r=`${Hl}/${e}`;await hi.mkdirp(Hl),await hi.writeFile(`${Hl}/${e}`,"",{flag:"a+"});let n=await hi.createWriteStream(r),s=await cpe.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(){Gd.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Gd.error(Ar.S3_DOWNLOAD_ERR+" - "+r),Ft(r,kl(Ar.S3_DOWNLOAD_ERR))}}a(Spe,"downloadFileFromS3");async function Tpe(e,t){try{await hi.mkdirp(Hl),await hi.writeFile(`${Hl}/${e}`,t)}catch(r){throw Gd.error(Ar.WRITE_TEMP_FILE_ERR),Ft(r,kl(Ar.DEFAULT_BULK_LOAD_ERR))}}a(Tpe,"writeFileToTempFolder");async function sT(e){if(e)try{await hi.access(e),await hi.unlink(e)}catch{Gd.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(sT,"deleteTempFile");function Ape(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(!_pe[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(Ape,"validateURLResponse");async function NI(e){try{let t;switch(e.file_type){case pi.VALID_S3_FILE_TYPES.CSV:t=await Rpe(e);break;case pi.VALID_S3_FILE_TYPES.JSON:t=await ype(e);break;default:throw Ft(new Error,Ar.DEFAULT_BULK_LOAD_ERR,Br.BAD_REQUEST,pi.LOG_LEVELS.ERROR,Ar.INVALID_FILE_EXT_ERR(e))}return K1(t.records,t.number_written)}catch(t){throw Fl(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 nT.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;Fd.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Fd.isEmpty(c)&&!Fd.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,kl(Ar.INSERT_CSV_ERR),Br.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Ar.INSERT_CSV_ERR+" - "+c);r(l)}}a(q1,"insertChunk");async function Rpe(e){let t={records:0,number_written:0},r=$1(e.schema,e.table);try{let n=new OI,s=hi.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=hi.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,kl(Ar.PAPA_PARSE_ERR),Br.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Ar.PAPA_PARSE_ERR+n)}}a(Rpe,"callPapaParse");function $1(e,t){let r=upe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>dpe(i,s));return n}a($1,"createTransformMap");function yI(e,t,r){let n=e.get(r);return n?n(t):Fd.autoCast(t)}a(yI,"typeFunction");async function ype(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new OI,s=P1([hi.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([hi.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,kl(Ar.INSERT_JSON_ERR),Br.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Ar.INSERT_JSON_ERR+n)}}a(ype,"insertJson");async function V1(e){let t={};try{e.data&&e.data.length>0&&bpe(e.data[0])?t=await Ope(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Gd.info(t.message))}catch(r){throw Fl(r)}return t}a(V1,"callBulkFileLoad");function bpe(e){let t=Object.keys(e);for(let r of t)if(!fpe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(bpe,"validateColumnNames");async function Ope(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=nT.insert;break;case"update":i=nT.update;break;case"upsert":i=nT.upsert;break;default:throw Ft(new Error,Ar.INVALID_ACTION_PARAM_ERR(n),Br.BAD_REQUEST,pi.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=Fd.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw Fl(o)}}a(Ope,"bulkFileLoad");function K1(e,t){return`successfully loaded ${t} of ${e} records`}a(K1,"buildResponseMsg");function Fl(e){return Ft(e,kl(Ar.DEFAULT_BULK_LOAD_ERR),Br.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Ar.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(Fl,"buildTopLevelErrMsg")});var DI=I((hve,eK)=>{"use strict";var PI=Wr(),Npe=gI(),{AsyncParser:wpe}=require("json2csv"),oT=require("stream"),os=ae(),CI=require("fs-extra"),Ipe=require("path"),Ms=W(),{promisify:j1}=require("util"),sh=ae(),{handleHDBError:dr,hdb_errors:Cpe}=pe(),{HDB_ERROR_MSGS:Ln,HTTP_STATUS_CODES:fr}=Cpe,{streamAsJSON:Ppe}=(NR(),P(KL)),{Upload:Dpe}=require("@aws-sdk/lib-storage"),{toCsvStream:Lpe}=(co(),P(dM)),W1=["search_by_value","search_by_hash","sql","search_by_conditions"],z1=["json","csv"],J1="json",Q1="csv",Mpe="Successfully exported JSON locally.",vpe="Successfully exported CSV locally.",Upe=1e3,xpe=PI.searchByHash,Bpe=PI.searchByValue,Hpe=j1(oT.finished);eK.exports={export_to_s3:qpe,export_local:kpe};async function kpe(e){Ms.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=X1(e);if(!os.isEmpty(t))throw Ms.error(t),dr(new Error,t,fr.BAD_REQUEST,void 0,void 0,!0);if(os.isEmpty(e.path))throw Ms.error(Ln.MISSING_VALUE("path")),dr(new Error,Ln.MISSING_VALUE("path"),fr.BAD_REQUEST,void 0,void 0,!0);let r=(os.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Ipe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=os.buildFolderPath(e.path,r);await Fpe(e.path);let s=await Z1(e);return await Gpe(n,e.format,s)}a(kpe,"export_local");async function Fpe(e){if(Ms.trace("in confirmPath"),os.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,Ms.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 Ms.error(r),dr(new Error,r,fr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(Fpe,"confirmPath");async function Gpe(e,t,r){if(Ms.trace("in saveToLocal"),sh.isEmptyOrZeroLength(e))throw dr(new Error,Ln.INVALID_VALUE("file_path"),fr.BAD_REQUEST,void 0,void 0,!0);if(sh.isEmptyOrZeroLength(t))throw dr(new Error,Ln.INVALID_VALUE("Source format"),fr.BAD_REQUEST,void 0,void 0,!0);if(sh.isEmpty(r))throw dr(new Error,Ln.NOT_FOUND("Data"),fr.BAD_REQUEST,void 0,void 0,!0);if(t===J1){let n=CI.createWriteStream(e);return Ppe(r).pipe(n),await Hpe(n),{message:Mpe,path:e}}else if(t===Q1){let n=CI.createWriteStream(e),s=oT.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(f=>({label:f,value:f})));let c={objectMode:!0};return await new wpe(i,c).fromInput(s).toOutput(n).promise(!1),{message:vpe,path:e}}throw dr(new Error,Ln.INVALID_VALUE("format"),fr.BAD_REQUEST)}a(Gpe,"saveToLocal");async function qpe(e){if(!e.s3||Object.keys(e.s3).length===0)throw dr(new Error,Ln.MISSING_VALUE("S3 object"),fr.BAD_REQUEST);if(os.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw dr(new Error,Ln.MISSING_VALUE("aws_access_key_id"),fr.BAD_REQUEST);if(os.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw dr(new Error,Ln.MISSING_VALUE("aws_secret_access_key"),fr.BAD_REQUEST);if(os.isEmptyOrZeroLength(e.s3.bucket))throw dr(new Error,Ln.MISSING_VALUE("bucket"),fr.BAD_REQUEST);if(os.isEmptyOrZeroLength(e.s3.key))throw dr(new Error,Ln.MISSING_VALUE("key"),fr.BAD_REQUEST);if(os.isEmptyOrZeroLength(e.s3.region))throw dr(new Error,Ln.MISSING_VALUE("region"),fr.BAD_REQUEST);let t=X1(e);if(!os.isEmpty(t))throw dr(new Error,t,fr.BAD_REQUEST);Ms.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 Ms.error(l),l}let n,s=await Npe.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new oT.PassThrough;if(e.format===Q1){i=e.s3.key+".csv";let l=Lpe(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 oT.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%Upe===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 Dpe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(qpe,"export_to_s3");function X1(e){if(Ms.trace("in exportCoreValidation"),os.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(os.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){Ms.trace("in getRecords");let t,r;if(sh.isEmpty(e.search_operation)||sh.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=Bpe;break;case"search_by_hash":t=xpe;break;case"search_by_conditions":t=PI.searchByConditions;break;case"sql":{let n=jS();t=j1(n.evaluateSQL);break}default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,Ms.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=I((Eve,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=I((Sve,sK)=>{"use strict";var $pe=(H(),P(G)),nK=require("moment"),Vpe=require("uuid").v4,MI=class{static{a(this,"JobObject")}constructor(){this.id=Vpe(),this.type=void 0,this.start_datetime=nK().valueOf(),this.created_datetime=nK().valueOf(),this.end_datetime=void 0,this.status=$pe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};sK.exports=MI});var vI=I((Ave,_K)=>{"use strict";var Kpe=require("uuid").v4,uK=bn(),dK=Wr(),Ype=si(),Wpe=Gu(),zpe=rK(),bt=(H(),P(G)),jpe=iK(),Jpe=sg(),mi=W(),Qpe=xf(),qd=ae(),{promisify:Xpe}=require("util"),Gl=require("moment"),Zpe=jS(),aT=mI(),oK=Dy(),{deleteTransactionLogsBeforeValidator:ehe}=Jw(),{handleHDBError:aK,hdb_errors:the,ClientError:rhe}=pe(),{HTTP_STATUS_CODES:cK}=the,lK=dK.searchByValue,nhe=dK.searchByHash,she=uK.insert,ihe=Xpe(Zpe.evaluateSQL),ohe=uK.update;_K.exports={addJob:lhe,updateJob:dhe,handleGetJob:ahe,handleGetJobsByStartDate:che,getJobById:fK};async function ahe(e){if(e.id===void 0)throw new rhe("'id' is required");let t=await fK(e.id);return qd.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(ahe,"handleGetJob");async function che(e){try{let t=await uhe(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=Gl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Gl(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(che,"handleGetJobsByStartDate");async function lhe(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||qd.isEmptyOrZeroLength(e.operation)){let f="job parameter is invalid";return mi.info(f),t.error=f,t}if(!bt.JOB_TYPE_ENUM[e.operation])return mi.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case bt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=aT.fileObject(e);break;case bt.OPERATIONS_ENUM.CSV_URL_LOAD:n=aT.urlObject(e);break;case bt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=aT.dataObject(e);break;case bt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=aT.s3FileObject(e);break;case bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=oK(e,"date");break;case bt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=oK(e,"timestamp");break;case bt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=ehe(e);break;case bt.OPERATIONS_ENUM.RESTART_SERVICE:if(bt.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 jpe;s.type=e.operation===bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new Ype(bt.SYSTEM_SCHEMA_NAME,bt.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 mi.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Kpe();try{o=await lK(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 Qpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await she(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(lhe,"addJob");async function uhe(e){let t=Gl(e.from_date,Gl.ISO_8601),r=Gl(e.to_date,Gl.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 zpe(n,e.hdb_user);try{return await ihe(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(uhe,"getJobsInDateRange");async function fK(e){if(qd.isEmptyOrZeroLength(e))return qd.errorizeMessage("Invalid job ID specified.");let t=new Wpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await nhe(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return mi.error(n),qd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(fK,"getJobById");async function dhe(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(qd.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===bt.JOB_STATUS_ENUM.COMPLETE||e.status===bt.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Gl().valueOf());let t=new Jpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await ohe(t),r}a(dhe,"updateJob")});var AK=I((yve,TK)=>{"use strict";var pK=ae(),Rr=(H(),P(G)),fhe=require("moment"),cT=wI(),ih=W(),hK=vI(),mK=DI(),EK=jc(),gK=rt(),_he=$S(),phe=ja(),{parentPort:hhe,isMainThread:SK}=require("worker_threads"),{onMessageByType:mhe}=rt(),UI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Ehe(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 Yi(e,cT.csvFileLoad);break;case Rr.JOB_TYPE_ENUM.csv_url_load:await Yi(e,cT.csvURLLoad);break;case Rr.JOB_TYPE_ENUM.csv_data_load:await Yi(e,cT.csvDataLoad);break;case Rr.JOB_TYPE_ENUM.import_from_s3:await Yi(e,cT.importFromS3);break;case Rr.JOB_TYPE_ENUM.empty_trash:break;case Rr.JOB_TYPE_ENUM.export_local:await Yi(e,mK.export_local);break;case Rr.JOB_TYPE_ENUM.export_to_s3:await Yi(e,mK.export_to_s3);break;case Rr.JOB_TYPE_ENUM.delete_files_before:case Rr.JOB_TYPE_ENUM.delete_records_before:await Yi(e,EK.deleteFilesBefore);break;case Rr.JOB_TYPE_ENUM.delete_audit_logs_before:await Yi(e,EK.deleteAuditLogsBefore);break;case Rr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Yi(e,_he.deleteTransactionLogsBefore);break;case Rr.JOB_TYPE_ENUM.restart_service:return await Yi(e,phe.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(Ehe,"parseMessage");async function Yi(e,t){try{e.job.status=Rr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=fhe().valueOf(),await hK.updateJob(e.job),await ghe(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):ih.error(`There was an error running ${t.name} job with id ${e.job.id}`),ih.error(n),e.job.message=n,e.job.status=Rr.JOB_STATUS_ENUM.ERROR;try{await hK.updateJob(e.job)}catch(s){throw ih.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Yi,"runJob");async function ghe(e){ih.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}`}}):hhe.postMessage({type:Rr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(ghe,"launchJobThread");SK&&mhe(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){ih.error(r)}});TK.exports={parseMessage:Ehe,RunnerMessage:UI}});var yK=I((Ove,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=I((Ive,qI)=>{"use strict";var _T=Wr(),kI=jS(),lT=wI(),$o=Yg(),uT=So(),ah=jc(),She=ON(),oh=yn(),dT=G_(),Ct=zw(),fT=W(),The=PN(),Ahe=Td(),bK=tw(),Rhe=iS(),yhe=sw(),bhe=iw(),Ohe=lS(),Nhe=dS(),BI=fS(),OK=DI(),whe=WS(),FI=vI(),K=(H(),P(G)),{hdb_errors:lh,handleHDBError:ch}=pe(),{HTTP_STATUS_CODES:NK}=lh,HI=ES(),wK=ja(),BK=require("util"),Vd=bn(),Ihe=Rs(),Che=Do(),IK=AK(),CK=(Qu(),P(Z_)),PK=(US(),P(qp)),DK=Rt(),LK=$S(),MK=Yp(),{setServerUtilities:Phe}=($f(),P(II)),{CONTEXT:wve}=(ga(),P(SR)),{_assignPackageExport:Dhe}=Ai(),{transformReq:Lhe}=ae(),{server:Mhe}=(Kr(),P(Ru)),sn=fT.loggerWithTag("operation"),$d=es(),vK=(Ol(),P(bl)),vhe=EI(),UK=_T.searchByHash,Uhe=_T.searchByValue,xhe=BK.promisify(_T.search),Bhe=BK.promisify(kI.evaluateSQL),Hhe={[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},te=yK();async function HK(e,t){try{if(e.body.operation!=="read_log"&&(fT.log_level===K.LOG_LEVELS.INFO||fT.log_level===K.LOG_LEVELS.DEBUG||fT.log_level===K.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;sn.info(c)}}catch(n){sn.error(n)}let r=await vhe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Hhe[e.body.operation]&&Ihe.setSchemaDataToGlobal(n=>{n&&sn.error(n)}),r}a(HK,"processLocalTransaction");var xK=Fhe();qI.exports={chooseOperation:kK,getOperationFunction:FK,operation:GI,processLocalTransaction:HK,executeJob:vs};Phe(qI.exports);Mhe.operation=GI;function kK(e){let t;try{t=FK(e)}catch(s){throw sn.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 sn.error(`${NK.FORBIDDEN} from operation ${e.operation}`),sn.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),ch(new Error,o,lh.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=whe.verifyPerms(i,s);if(o)throw sn.error(`${NK.FORBIDDEN} from operation ${e.operation}`),sn.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),ch(new Error,o,lh.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw ch(s,"There was an error when trying to choose an operation path")}return r}a(kK,"chooseOperation");function FK(e){if(sn.trace(`getOperationFunction with operation: ${e.operation}`),xK.has(e.operation))return xK.get(e.operation);throw ch(new Error,lh.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),lh.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(FK,"getOperationFunction");Dhe("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 khe(e){sn.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 Vd.insert(i);break;case K.OPERATIONS_ENUM.UPDATE:o=await Vd.update(i);break;case K.OPERATIONS_ENUM.UPSERT:o=await Vd.upsert(i);break;case K.OPERATIONS_ENUM.DELETE:o=await ah.deleteRecord(i);break;default:sn.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){sn.info("Invalid operation in transaction"),sn.error(o)}}a(khe,"catchup");async function vs(e){Lhe(e);let t,r;try{r=await FI.addJob(e),t=r.createdJob,sn.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 sn.error(s),ch(n,s)}}a(vs,"executeJob");function Fhe(){let e=new Map;return e.set(K.OPERATIONS_ENUM.INSERT,new te(Vd.insert)),e.set(K.OPERATIONS_ENUM.UPDATE,new te(Vd.update)),e.set(K.OPERATIONS_ENUM.UPSERT,new te(Vd.upsert)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new te(_T.searchByConditions)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_HASH,new te(UK)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_ID,new te(UK)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_VALUE,new te(Uhe)),e.set(K.OPERATIONS_ENUM.SEARCH,new te(xhe)),e.set(K.OPERATIONS_ENUM.SQL,new te(Bhe)),e.set(K.OPERATIONS_ENUM.CSV_DATA_LOAD,new te(vs,lT.csvDataLoad)),e.set(K.OPERATIONS_ENUM.CSV_FILE_LOAD,new te(vs,lT.csvFileLoad)),e.set(K.OPERATIONS_ENUM.CSV_URL_LOAD,new te(vs,lT.csvURLLoad)),e.set(K.OPERATIONS_ENUM.IMPORT_FROM_S3,new te(vs,lT.importFromS3)),e.set(K.OPERATIONS_ENUM.CREATE_SCHEMA,new te($o.createSchema)),e.set(K.OPERATIONS_ENUM.CREATE_DATABASE,new te($o.createSchema)),e.set(K.OPERATIONS_ENUM.CREATE_TABLE,new te($o.createTable)),e.set(K.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new te($o.createAttribute)),e.set(K.OPERATIONS_ENUM.DROP_SCHEMA,new te($o.dropSchema)),e.set(K.OPERATIONS_ENUM.DROP_DATABASE,new te($o.dropSchema)),e.set(K.OPERATIONS_ENUM.DROP_TABLE,new te($o.dropTable)),e.set(K.OPERATIONS_ENUM.DROP_ATTRIBUTE,new te($o.dropAttribute)),e.set(K.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new te(uT.describeSchema)),e.set(K.OPERATIONS_ENUM.DESCRIBE_DATABASE,new te(uT.describeSchema)),e.set(K.OPERATIONS_ENUM.DESCRIBE_TABLE,new te(uT.describeTable)),e.set(K.OPERATIONS_ENUM.DESCRIBE_ALL,new te(uT.describeAll)),e.set(K.OPERATIONS_ENUM.DELETE,new te(ah.deleteRecord)),e.set(K.OPERATIONS_ENUM.ADD_USER,new te(oh.addUser)),e.set(K.OPERATIONS_ENUM.ALTER_USER,new te(oh.alterUser)),e.set(K.OPERATIONS_ENUM.DROP_USER,new te(oh.dropUser)),e.set(K.OPERATIONS_ENUM.LIST_USERS,new te(oh.listUsersExternal)),e.set(K.OPERATIONS_ENUM.LIST_ROLES,new te(dT.listRoles)),e.set(K.OPERATIONS_ENUM.ADD_ROLE,new te(dT.addRole)),e.set(K.OPERATIONS_ENUM.ALTER_ROLE,new te(dT.alterRole)),e.set(K.OPERATIONS_ENUM.DROP_ROLE,new te(dT.dropRole)),e.set(K.OPERATIONS_ENUM.USER_INFO,new te(oh.userInfo)),e.set(K.OPERATIONS_ENUM.READ_LOG,new te(The)),e.set(K.OPERATIONS_ENUM.ADD_NODE,new te(Ahe)),e.set(K.OPERATIONS_ENUM.UPDATE_NODE,new te(bK)),e.set(K.OPERATIONS_ENUM.SET_NODE_REPLICATION,new te(bK)),e.set(K.OPERATIONS_ENUM.REMOVE_NODE,new te(Rhe)),e.set(K.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new te(yhe)),e.set(K.OPERATIONS_ENUM.PURGE_STREAM,new te(bhe)),e.set(K.OPERATIONS_ENUM.SET_CONFIGURATION,new te(DK.setConfiguration)),e.set(K.OPERATIONS_ENUM.CLUSTER_STATUS,new te(Ohe.clusterStatus)),e.set(K.OPERATIONS_ENUM.CLUSTER_NETWORK,new te(Nhe)),e.set(K.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new te(BI.setRoutes)),e.set(K.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new te(BI.getRoutes)),e.set(K.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new te(BI.deleteRoutes)),e.set(K.OPERATIONS_ENUM.EXPORT_TO_S3,new te(vs,OK.export_to_s3)),e.set(K.OPERATIONS_ENUM.CREATE_CSR,new te($d.createCsr)),e.set(K.OPERATIONS_ENUM.SIGN_CERTIFICATE,new te($d.signCertificate)),e.set(K.OPERATIONS_ENUM.LIST_CERTIFICATES,new te($d.listCertificates)),e.set(K.OPERATIONS_ENUM.ADD_CERTIFICATES,new te($d.addCertificate)),e.set(K.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new te($d.removeCertificate)),e.set(K.OPERATIONS_ENUM.GET_KEY,new te($d.getKey)),e.set(K.OPERATIONS_ENUM.ADD_NODE_BACK,new te(vK.addNodeBack)),e.set(K.OPERATIONS_ENUM.REMOVE_NODE_BACK,new te(vK.removeNodeBack)),e.set(K.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new te(vs,ah.deleteFilesBefore)),e.set(K.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new te(vs,ah.deleteFilesBefore)),e.set(K.OPERATIONS_ENUM.EXPORT_LOCAL,new te(vs,OK.export_local)),e.set(K.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new te(FI.handleGetJobsByStartDate)),e.set(K.OPERATIONS_ENUM.GET_JOB,new te(FI.handleGetJob)),e.set(K.OPERATIONS_ENUM.GET_FINGERPRINT,new te(HI.getFingerprint)),e.set(K.OPERATIONS_ENUM.SET_LICENSE,new te(HI.setLicense)),e.set(K.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new te(HI.getRegistrationInfo)),e.set(K.OPERATIONS_ENUM.RESTART,new te(wK.restart)),e.set(K.OPERATIONS_ENUM.RESTART_SERVICE,new te(vs,wK.restartService)),e.set(K.OPERATIONS_ENUM.CATCHUP,new te(khe)),e.set(K.OPERATIONS_ENUM.SYSTEM_INFORMATION,new te(Che.systemInformation)),e.set(K.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new te(vs,ah.deleteAuditLogsBefore)),e.set(K.OPERATIONS_ENUM.READ_AUDIT_LOG,new te(She)),e.set(K.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new te(CK.createTokens)),e.set(K.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new te(CK.refreshOperationToken)),e.set(K.OPERATIONS_ENUM.LOGIN,new te(PK.login)),e.set(K.OPERATIONS_ENUM.LOGOUT,new te(PK.logout)),e.set(K.OPERATIONS_ENUM.GET_CONFIGURATION,new te(DK.getConfiguration)),e.set(K.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new te(Ct.customFunctionsStatus)),e.set(K.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new te(Ct.getCustomFunctions)),e.set(K.OPERATIONS_ENUM.GET_COMPONENT_FILE,new te(Ct.getComponentFile)),e.set(K.OPERATIONS_ENUM.GET_COMPONENTS,new te(Ct.getComponents)),e.set(K.OPERATIONS_ENUM.SET_COMPONENT_FILE,new te(Ct.setComponentFile)),e.set(K.OPERATIONS_ENUM.DROP_COMPONENT,new te(Ct.dropComponent)),e.set(K.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new te(Ct.getCustomFunction)),e.set(K.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new te(Ct.setCustomFunction)),e.set(K.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new te(Ct.dropCustomFunction)),e.set(K.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new te(Ct.addComponent)),e.set(K.OPERATIONS_ENUM.ADD_COMPONENT,new te(Ct.addComponent)),e.set(K.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new te(Ct.dropCustomFunctionProject)),e.set(K.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new te(Ct.packageComponent)),e.set(K.OPERATIONS_ENUM.PACKAGE_COMPONENT,new te(Ct.packageComponent)),e.set(K.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new te(Ct.deployComponent)),e.set(K.OPERATIONS_ENUM.DEPLOY_COMPONENT,new te(Ct.deployComponent)),e.set(K.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new te(LK.readTransactionLog)),e.set(K.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new te(vs,LK.deleteTransactionLogsBefore)),e.set(K.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new te(MK.installModules)),e.set(K.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new te(MK.auditModules)),e.set(K.OPERATIONS_ENUM.GET_BACKUP,new te($o.getBackup)),e.set(K.OPERATIONS_ENUM.ADD_SSH_KEY,new te(Ct.addSSHKey)),e.set(K.OPERATIONS_ENUM.UPDATE_SSH_KEY,new te(Ct.updateSSHKey)),e.set(K.OPERATIONS_ENUM.DELETE_SSH_KEY,new te(Ct.deleteSSHKey)),e.set(K.OPERATIONS_ENUM.LIST_SSH_KEYS,new te(Ct.listSSHKeys)),e.set(K.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new te(Ct.setSSHKnownHosts)),e.set(K.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new te(Ct.getSSHKnownHosts)),e}a(Fhe,"initializeOperationFunctionMap")});var mT=I((Pve,$K)=>{"use strict";var pT=(H(),P(G)),Ghe=ae(),uh=W(),{handleHDBError:$I,hdb_errors:hT}=pe(),{isMainThread:qhe}=require("worker_threads"),{Readable:$he}=require("stream"),GK=require("os"),Vhe=require("util"),Khe=IO(),Yhe=Vhe.promisify(Khe.authorize),qK=jw(),{createGzip:Whe,constants:zhe}=require("zlib"),jhe=[pT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,pT.OPERATIONS_ENUM.LOGIN,pT.OPERATIONS_ENUM.LOGOUT];function Jhe(e){let t=`Found an uncaught exception with message: ${e.message}. ${GK.EOL}Stack: ${e.stack} ${GK.EOL}Terminating ${qhe?"HDB":"thread"}.`;console.error(t),uh.fatal(t),process.exit(1)}a(Jhe,"handleServerUncaughtException");function Qhe(e,t,r){if(uh[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:hT.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(Qhe,"serverErrorHandler");function Xhe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=$I(new Error,"Invalid JSON.",hT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(Ghe.isEmpty(e.body.operation)){let n=$I(new Error,"Request body must include an 'operation' property.",hT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Xhe,"reqBodyValidationHandler");function Zhe(e,t,r){let n;!jhe.includes(e.body.operation)||e.body.operation===pT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&!e.body.username&&!e.body.password?Yhe(e,t).then(i=>{n=i,e.body.hdb_user=n,r()}).catch(i=>{uh.warn(i),uh.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${i.stack}"`);let o=typeof i=="string"?{error:i}:{error:i.message};r($I(i,o,hT.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(Zhe,"authHandler");async function eme(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 $he&&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(Whe({level:zhe.Z_BEST_SPEED})))}return s}catch(s){throw uh.error(s),s}}a(eme,"handlePostRequest");$K.exports={authHandler:Zhe,handlePostRequest:eme,handleServerUncaughtException:Jhe,serverErrorHandler:Qhe,reqBodyValidationHandler:Xhe}});var WK=I((Lve,YK)=>{"use strict";var tme=require("fastify-plugin"),{handlePostRequest:VK,authHandler:rme,reqBodyValidationHandler:nme}=mT();async function sme(e){e.decorate("hdbCore",{preValidation:[nme,rme],request:a(t=>KK(VK(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>KK(VK(t,r,!0)),"requestWithoutAuthentication")})}a(sme,"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=tme(sme)});var jK=I((Uve,zK)=>{"use strict";var vve=require("fs"),ET=ce();ET.initSync();var{CONFIG_PARAMS:VI}=(H(),P(G)),ime=1024*1024*1024;function ome(e){let t=ET.get(VI.HTTP_TIMEOUT),r=ET.get(VI.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:ime,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:ET.get(VI.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(ome,"getServerOptions");zK.exports=ome});var XK=I((Bve,QK)=>{"use strict";var KI=ce();KI.initSync();var{CONFIG_PARAMS:JK}=(H(),P(G));function ame(){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(ame,"getCORSOptions");QK.exports=ame});var tY=I((kve,eY)=>{"use strict";var ZK=ce();ZK.initSync();var cme=(H(),P(G));function lme(){return ZK.get(cme.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(lme,"getHeaderTimeoutConfig");eY.exports=lme});var WI={};Ue(WI,{customFunctionsServer:()=>fme,ready:()=>hY,start:()=>dme});function dme(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Vo||(Vo=pY(t),We.http((await Vo).server));let o=await Vo,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(pme(c,l))}catch(u){if(u.message==="Root plugin has already booted")pt.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:hY}}async function fme(){try{pt.info("In Custom Functions Fastify server"+process.cwd()),pt.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),pt.debug(`Custom Functions server process ${process.pid} starting up.`),await _me();let e=cY.get(x.HTTP_SECUREPORT)>0,t;try{t=Vo=await pY(e)}catch(r){throw pt.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw pt.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){pt.error(`Custom Functions ${process.pid} Error: ${e}`),pt.error(e),process.exit(1)}}async function _me(){try{pt.info("Custom Functions starting configuration."),await lY.setUsersWithRolesCache(),pt.info("Custom Functions completed configuration.")}catch(e){pt.error(e)}}function pme(e,t){return async function(r){try{pt.info("Custom Functions starting buildRoutes"),pt.trace("Loading fastify routes folder "+e),(0,nY.existsSync)(e)&&r.register(aY.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:pt.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?pt.error(s.message):s&&pt.error(s),o()})}catch(n){pt.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function pY(e){pt.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(ume),await r.after(),Jf(r),pt.info("Custom Functions completed buildServer."),r}function hY(){if(Vo)return Vo.then?Vo.then(e=>e.ready()):Vo.ready()}var YI,nY,sY,iY,oY,aY,cY,pt,ume,lY,uY,dY,fY,_Y,Vo,rY,mY=be(()=>{YI=require("path"),nY=require("fs"),sY=M(require("fastify")),iY=M(require("@fastify/cors")),oY=M(yO()),aY=M(require("@fastify/autoload")),cY=M(ce());H();pt=M(W()),ume=M(WK()),lY=M(yn()),uY=M(jK()),dY=M(XK()),fY=M(tY()),_Y=M(mT());co();Kr();rY=new Set;a(dme,"start");a(fme,"customFunctionsServer");a(_me,"setUp");a(pme,"buildRouteFolder");a(pY,"buildServer");a(hY,"ready")});var zI={};Ue(zI,{start:()=>hme});function hme(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(hme,"start")});var jI={};Ue(jI,{start:()=>mme});function mme({override:e}){return{handleFile:a((t,r,n)=>{gT.default.debug(`Loading env file: ${n}`);for(let[s,i]of Object.entries((0,yY.parse)(t))){if(process.env[s]!==void 0)if(gT.default.warn(`Environment variable conflict: ${s} from ${n} is already set on process.env`),e)gT.default.debug(`override option enabled. overriding environment variable: ${s}`);else continue;process.env[s]=i}},"handleFile")}}var yY,gT,bY=be(()=>{yY=require("dotenv"),gT=M(W());a(mme,"start")});var NY={};Ue(NY,{Request:()=>JI,createReuseportFd:()=>ST});var OY,JI,QI,XI,ST,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"&&(ST=require("node-unix-socket").createReuseportFd)});var tC=I((zve,wY)=>{"use strict";var dh=ce();dh.initSync();var Kd=require("fs-extra"),eC=require("path"),Yd=(H(),P(G)),Eme=require("crypto"),gme=require("uuid").v4;wY.exports=Sme;function Sme(){if(dh.getHdbBasePath()!==void 0){let e=eC.join(dh.getHdbBasePath(),Yd.LICENSE_KEY_DIR_NAME,Yd.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=eC.join(dh.getHdbBasePath(),Yd.LICENSE_KEY_DIR_NAME,Yd.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=eC.join(dh.getHdbBasePath(),Yd.LICENSE_KEY_DIR_NAME,Yd.JWT_ENUM.JWT_PASSPHRASE_NAME);try{Kd.accessSync(r),Kd.accessSync(e),Kd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=gme(),i=Eme.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});Kd.writeFileSync(r,s),Kd.writeFileSync(e,i.privateKey),Kd.writeFileSync(t,i.publicKey)}else throw n}}}a(Sme,"checkJWTTokenExist")});var CY=I((Jve,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=I((Xve,DY)=>{"use strict";var PY=(H(),P(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 TT=I((eUe,vY)=>{"use strict";var Us=require("prompt"),Wd=require("chalk"),MY=W(),Ei=require("os"),sC=da(),iC=["yes","y"];async function Tme(e){let t=`${Ei.EOL}`+Wd.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}`;Us.override=sC(["CONFIRM_UPGRADE"]),Us.start(),Us.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Wd.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 Us.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(Tme,"forceUpdatePrompt");async function Ame(e){let t=`${Ei.EOL}`+Wd.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}`);Us.override=sC(["CONFIRM_DOWNGRADE"]),Us.start(),Us.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Wd.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 Us.get([r]);return iC.includes(n.CONFIRM_DOWNGRADE)}a(Ame,"forceDowngradePrompt");async function Rme(){let e=`${Ei.EOL}`+Wd.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");Us.override=sC(["GENERATE_CERTS"]),Us.start(),Us.message=e;let t={properties:{GENERATE_CERTS:{description:Wd.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 Us.get([t]);return iC.includes(r.GENERATE_CERTS)}a(Rme,"upgradeCertsPrompt");vY.exports={forceUpdatePrompt:Tme,forceDowngradePrompt:Ame,upgradeCertsPrompt:Rme}});var aC=I((rUe,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=I((cUe,xY)=>{"use strict";var yme=ae(),bme=Rt(),sUe=W(),iUe=require("path"),oUe=require("fs"),aUe=(H(),P(G));xY.exports={getOldPropsValue:Ome};function Ome(e,t,r=!1){let n=t.getRaw(e);return yme.isNotEmptyAndHasValue(n)?n:r?bme.getDefaultConfig(e):""}a(Ome,"getOldPropsValue")});var GY=I((uUe,FY)=>{"use strict";var tc=require("path"),rc=require("fs-extra"),Nme=require("properties-reader"),wme=aC(),_r=W(),{getOldPropsValue:ht}=BY(),{HDB_SETTINGS_NAMES:Ee,CONFIG_PARAMS:ql}=(H(),P(G)),$l=Rt(),AT=ce(),HY=ae(),Wi=(H(),P(G)),cC=new wme("3.1.0"),kY=[];function Ime(){let e=Nme(AT.get(Ee.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
|
+
${Ee.HDB_ROOT_KEY} = ${ht(Ee.HDB_ROOT_KEY,e)}
|
|
45
43
|
;The port the HarperDB REST interface will listen on.
|
|
46
|
-
${
|
|
44
|
+
${Ee.SERVER_PORT_KEY} = ${ht(Ee.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
|
+
${Ee.HTTP_SECURE_ENABLED_KEY} = ${ht(Ee.HTTP_SECURE_ENABLED_KEY,e)}
|
|
49
47
|
;The path to the SSL certificate used when running with HTTPS enabled.
|
|
50
|
-
${
|
|
48
|
+
${Ee.CERT_KEY} = ${ht(Ee.CERT_KEY,e)}
|
|
51
49
|
;The path to the SSL private key used when running with HTTPS enabled.
|
|
52
|
-
${
|
|
50
|
+
${Ee.PRIVATE_KEY_KEY} = ${ht(Ee.PRIVATE_KEY_KEY,e)}
|
|
53
51
|
;Set to true to enable Cross Origin Resource Sharing, which allows requests across a domain.
|
|
54
|
-
${
|
|
52
|
+
${Ee.CORS_ENABLED_KEY} = ${ht(Ee.CORS_ENABLED_KEY,e)}
|
|
55
53
|
;Allows for setting allowable domains with CORS. Comma separated list.
|
|
56
|
-
${
|
|
54
|
+
${Ee.CORS_WHITELIST_KEY} = ${ht(Ee.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
|
+
${Ee.SERVER_TIMEOUT_KEY} = ${ht(Ee.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
|
+
${Ee.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${ht(Ee.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
|
+
${Ee.SERVER_HEADERS_TIMEOUT_KEY} = ${ht(Ee.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
|
|
63
61
|
;Define whether to log to file or not.
|
|
64
|
-
${
|
|
62
|
+
${Ee.LOG_TO_FILE} = ${$l.getDefaultConfig(ql.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
|
+
${Ee.LOG_TO_STDSTREAMS} = ${$l.getDefaultConfig(ql.LOGGING_STDSTREAMS)}
|
|
67
65
|
;Set to control amount of logging generated. Accepted levels are trace, debug, warn, error, fatal.
|
|
68
|
-
${
|
|
66
|
+
${Ee.LOG_LEVEL_KEY} = ${ht(Ee.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
|
+
${Ee.LOG_PATH_KEY} = ${ht(Ee.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
|
+
${Ee.LOG_DAILY_ROTATE_KEY} = ${ht(Ee.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
|
+
${Ee.LOG_MAX_DAILY_FILES_KEY} = ${ht(Ee.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
|
+
${Ee.PROPS_ENV_KEY} = ${ht(Ee.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
|
+
${Ee.ALLOW_SELF_SIGNED_SSL_CERTS} = ${ht(Ee.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
|
+
${Ee.MAX_HDB_PROCESSES} = ${ht(Ee.MAX_HDB_PROCESSES,e)}
|
|
84
82
|
;Set to true to enable clustering. Requires a valid enterprise license.
|
|
85
|
-
${
|
|
83
|
+
${Ee.CLUSTERING_ENABLED_KEY} = ${ht(Ee.CLUSTERING_ENABLED_KEY,e,!0)}
|
|
86
84
|
;The port that will be used for HarperDB clustering.
|
|
87
|
-
${
|
|
85
|
+
${Ee.CLUSTERING_PORT_KEY} = ${ht(Ee.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
|
+
${Ee.CLUSTERING_NODE_NAME_KEY} = ${ht(Ee.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
|
+
${Ee.CLUSTERING_USER_KEY} = ${ht(Ee.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
|
+
${Ee.DISABLE_TRANSACTION_LOG_KEY} = ${ht(Ee.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
|
+
${Ee.OPERATION_TOKEN_TIMEOUT_KEY} = ${ht(Ee.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
|
+
${Ee.REFRESH_TOKEN_TIMEOUT_KEY} = ${ht(Ee.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
|
|
98
96
|
;The port the IPC server will run on.
|
|
99
|
-
${
|
|
97
|
+
${Ee.IPC_SERVER_PORT} = ${$l.getDefaultConfig(ql.IPC_NETWORK_PORT)}
|
|
100
98
|
;Run HDB in the foreground.
|
|
101
|
-
${
|
|
99
|
+
${Ee.RUN_IN_FOREGROUND} = ${$l.getDefaultConfig(ql.OPERATIONSAPI_FOREGROUND)}
|
|
102
100
|
;Set to true to enable custom API endpoints. Requires a valid enterprise license.
|
|
103
|
-
${
|
|
101
|
+
${Ee.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${$l.getDefaultConfig(ql.CUSTOMFUNCTIONS_ENABLED)}
|
|
104
102
|
;The port used to access the custom functions server.
|
|
105
|
-
${
|
|
103
|
+
${Ee.CUSTOM_FUNCTIONS_PORT_KEY} = ${$l.getDefaultConfig(ql.HTTP_PORT)}
|
|
106
104
|
;The path to the folder containing HarperDB custom function files.
|
|
107
|
-
${
|
|
105
|
+
${Ee.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${tc.join(ht(Ee.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
|
+
${Ee.MAX_CUSTOM_FUNCTION_PROCESSES} = ${$l.getDefaultConfig(ql.HTTP_THREADS)}
|
|
108
|
+
`,n=AT.get("settings_path"),s=tc.dirname(n),i=tc.join(s,"3_1_0_upgrade_settings.bak");try{_r.info(`Backing up old settings file to: ${i}`),rc.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}'`),rc.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),rc.copySync(i,n),c}AT.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),_r.info(o),o}a(Ime,"updateSettingsFile_3_1_0");function Cme(){let e=tc.join(HY.getHomeDir(),Wi.HDB_HOME_DIR_NAME,Wi.LICENSE_KEY_DIR_NAME,Wi.LICENSE_FILE_NAME),t=tc.join(HY.getHomeDir(),Wi.HDB_HOME_DIR_NAME,Wi.LICENSE_KEY_DIR_NAME,Wi.REG_KEY_FILE_NAME),r=tc.join(AT.getHdbBasePath(),Wi.LICENSE_KEY_DIR_NAME,Wi.LICENSE_FILE_NAME),n=tc.join(r,Wi.LICENSE_FILE_NAME),s=tc.join(r,Wi.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),rc.mkdirpSync(r);try{rc.accessSync(e);try{let c="Moving licence file";console.log(c),_r.info(c),rc.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{rc.accessSync(t);try{let c="Moving registration file";console.log(c),_r.info(c),rc.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(Cme,"moveLicenseFiles");cC.sync_functions.push(Ime);cC.sync_functions.push(Cme);kY.push(cC);FY.exports=kY});var YY=I((fUe,KY)=>{"use strict";var as=ft(),{insertRecords:Pme}=$c(),Dme=pn(),nc=xt(),Lme=ae(),Ko=W(),Mme=ae(),zi=require("fs-extra"),Yo=require("path"),vme=require("cli-progress"),fh=require("assert"),Ume=require("pino"),xme=ce();KY.exports=Bme;var RT,qY,yT,lC,on,_h=!1;async function Bme(e=!0){return RT=xme.getHdbBasePath(),qY=Yo.join(RT,"schema"),yT=Yo.join(RT,"4_0_0_upgrade_tmp"),lC=Yo.join(RT,"transactions"),console.info("Reindexing upgrade started for schemas"),Ko.notify("Reindexing upgrade started for schemas"),await $Y(qY,!1,e),await zi.pathExists(lC)&&(console.info(`
|
|
111
109
|
|
|
112
|
-
Reindexing upgrade started for transaction logs`),
|
|
113
|
-
install_user = ${l}`;try{tc.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{lC.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{tc.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(rEe,"updateSettingsFile_4_0_0");hh.async_functions.push(rEe);hh.async_functions.push(eEe);hh.async_functions.push(Xme);hh.async_functions.push(tEe);JY.push(hh);QY.exports=JY});var uC=w((hUe,rW)=>{"use strict";var Gl=ie(),nEe=(H(),C(G)),ZY=z(),{DATA_VERSION:sEe,UPGRADE_VERSION:iEe}=nEe.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 oEe(){return[...ql.keys()].sort(Gl.compareVersions)}a(oEe,"getSortedVersions");function tW(e){let t=e[sEe],r=e[iEe];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 aEe(e){return tW(e).length>0}a(aEe,"hasUpgradesRequired");function cEe(e){return Gl.isEmptyOrZeroLength(e)?null:ql.has(e)?ql.get(e):null}a(cEe,"getDirectiveByVersion");rW.exports={getSortedVersions:oEe,getDirectiveByVersion:cEe,getVersionsForUpgrade:tW,hasUpgradesRequired:aEe}});var mh=w((EUe,aW)=>{"use strict";var lEe=require("util"),dC=require("chalk"),uEe=require("os"),sW=Rn(),dEe=Yr(),as=(H(),C(G)),iW=PY(),_C=vy(),{UpgradeObject:nW}=MY(),{forceDowngradePrompt:fEe}=gT(),{packageJson:_Ee}=st(),OT=z(),Yd=ie(),pC=As(),pEe=(Pe(),C(tt)),hEe=uC(),mEe=lEe.promisify(pC.setSchemaDataToGlobal),EEe=dEe.searchByValue,gEe="info_id",SEe="2.9.9",TEe="3.0.0";async function AEe(e){let t=new iW.HdbInfoInsertObject(1,e,e),r=new _C.InsertObject(as.OPERATIONS_ENUM.INSERT,as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,as.INFO_TABLE_HASH_ATTRIBUTE,[t]);return pC.setSchemaDataToGlobal(),sW.insert(r)}a(AEe,"insertHdbInstallInfo");async function fC(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 _C.InsertObject(as.OPERATIONS_ENUM.INSERT,as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,as.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await mEe(),sW.insert(o)}a(fC,"insertHdbUpgradeInfo");async function oW(){let e=new _C.NoSQLSeachObject(as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,gEe,as.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await EEe(e))}catch(r){console.error(r)}return t}a(oW,"getAllHdbInfoRecords");async function REe(){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(REe,"getLatestHdbInfoRecord");async function yEe(){OT.info("Checking if HDB software has been updated");try{let e=_Ee.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await REe(),r;if(Yd.isEmpty(t))r=SEe;else if(r=t.data_version_num,Yd.compareVersions(r.toString(),e.toString())>0){if(!Yd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(dC.yellow(`This instance's data was last run on version ${r}`)),console.error(dC.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.${uEe.EOL}${as.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Yd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(dC.yellow(`This instance's data was last run on version ${r}`)),await fEe(new nW(r,e))?await fC(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(pC.setSchemaDataToGlobal(),bEe(r),e.toString()===r.toString())return;let n=new nW(r,e);if(hEe.hasUpgradesRequired(n))return n;Yd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await fC(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(yEe,"getVersionUpdateInfo");function bEe(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 pEe.databases.system))throw console.log(t),new Error(t);if(!Yd.isEmpty(e)&&e<TEe)throw console.log(t),new Error(t)}a(bEe,"checkIfInstallIsSupported");aW.exports={insertHdbInstallInfo:AEe,insertHdbUpgradeInfo:fC,getVersionUpdateInfo:yEe}});var dW=w((SUe,uW)=>{"use strict";var NT=require("joi"),{boolean:OEe,string:hC,number:NEe}=NT.types(),cW=require("fs-extra"),Eh=(H(),C(G)),lW=require("path"),wEe=it();uW.exports=IEe;function IEe(e){let t=hC.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=NT.object({[Eh.INSTALL_PROMPTS.ROOTPATH]:NT.custom(CEe),[Eh.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:NT.alternatives([NEe.min(0),hC]).allow("null",null),[Eh.INSTALL_PROMPTS.TC_AGREEMENT]:hC.valid("yes","YES","Yes"),[Eh.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[Eh.INSTALL_PROMPTS.CLUSTERING_ENABLED]:OEe});return wEe.validateBySchema(e,r)}a(IEe,"installValidator");function CEe(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(CEe,"validateRootAvailable")});var gC=w((AUe,fW)=>{"use strict";var{mkdirpSync:PEe,copySync:DEe}=require("fs-extra"),rc=require("path"),gh=(H(),C(G)),{PACKAGE_ROOT:LEe}=st(),EC=z(),MEe=Vn(),mC=po(),vEe=gt();fW.exports=UEe;async function UEe(e){EC.trace("Mounting HarperDB"),$l(e),$l(rc.join(e,"backup")),$l(rc.join(e,"keys")),$l(rc.join(e,"keys",gh.LICENSE_FILE_NAME)),$l(rc.join(e,"log")),$l(rc.join(e,"database")),$l(rc.join(e,"components")),DEe(rc.resolve(LEe,"./utility/install/README.md"),rc.join(e,"README.md")),await xEe()}a(UEe,"mountHdb");async function xEe(){let e=v_(),t=Object.keys(mC);for(let r=0;r<t.length;r++){let n=t[r],s=mC[n].hash_attribute;try{vEe.initSystemSchemaPaths(gh.SYSTEM_SCHEMA_NAME,n);let i=new e(gh.SYSTEM_SCHEMA_NAME,n,s);i.attributes=mC[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await MEe.createTable(n,i)}catch(i){throw EC.error(`issue creating environment for ${gh.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(xEe,"createLMDBTables");function $l(e){PEe(e,{mode:gh.HDB_FILE_PERMISSIONS}),EC.info(`Directory ${e} created`)}a($l,"makeDirectory")});var CT=w((OUe,OW)=>{"use strict";var TC=require("os"),EW=require("inquirer"),xs=require("fs-extra"),BEe=require("properties-reader"),Kl=require("chalk"),ji=require("path"),HEe=require("human-readable-ids").hri,kEe=require("ora"),FEe=require("yaml"),pr=z(),nc=ae(),Sh=ie(),IT=ua(),gW=mh(),{packageJson:SW}=st(),de=(H(),C(G)),{CONFIG_PARAM_MAP:yUe,CONFIG_PARAMS:Pt}=de,GEe=dW(),qEe=gC(),AC=yt(),$Ee=An(),VEe=F_(),KEe=eC(),YEe=As(),WEe=require("util").promisify,zEe=WEe(YEe.setSchemaDataToGlobal),_W=Zn(),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",sc=TC.EOL,Yo="",JEe="yes",pW="Starting HarperDB install...",hW="HarperDB installation was successful.",mW="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",QEe="An out of date version of HarperDB is already installed.",SC="It appears that HarperDB is already installed. Exiting install...",XEe="Aborting install",bUe=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])$/),ZEe=new RegExp(/^[^\s.,*>]+$/),ege=TC.homedir(),tge=ji.join(ege,de.HDB_ROOT_DIR_NAME),rge="HDB_ADMIN",nge="CLUSTER_USER",sge="dev",ige="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:"},ic=IT([de.INSTALL_PROMPTS.HDB_CONFIG]),zi,TW=!1,RC=!1,AW=!1;OW.exports={install:RW,updateConfigEnv:mge,setIgnoreExisting:Ege};RW.createSuperUser=bW;async function RW(){console.log(Hr(sc+pW+sc)),pr.notify(pW);let e;ic[de.INSTALL_PROMPTS.HDB_CONFIG]&&(e=oge());let t=cge();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=GEe(t);if(r)throw r.message;await lge(),await uge(t);let n=await age(t);zi=n[de.INSTALL_PROMPTS.ROOTPATH],ic[de.INSTALL_PROMPTS.HDB_CONFIG]&&ji.dirname(ic[de.INSTALL_PROMPTS.HDB_CONFIG])===zi&&(TW=!0),!RC&&!ic[de.INSTALL_PROMPTS.HDB_CONFIG]&&await xs.pathExists(ji.join(zi,de.HDB_CONFIG_FILE))&&(console.error(SC),process.exit());let s=kEe({prefixText:Hr("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.");nc.setHdbBasePath(zi),await qEe(zi),await dge(),await fge(n),pr.initLogSettings(!0),await bW(n),await pge(n),await _W.updateConfigCert(),await _W.generateCertsKeys(),await hge(),KEe(),s.stop(),console.log(Hr(sc+hW+sc)),pr.notify(hW)}a(RW,"install");function oge(){let e=FEe.parseDocument(xs.readFileSync(ic[de.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=AC.flattenConfig(e.toJSON());return t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(oge,"getConfigFromFile");async function age(e){pr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.ROOTPATH],Br.DESTINATION),name:de.INSTALL_PROMPTS.ROOTPATH,prefix:Yo,default:tge,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:Hr(Br.DESTINATION)},{type:"input",transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Br.HDB_USERNAME),name:de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Yo,default:rge,validate:a(s=>Us(s)?Us(s):(t=s,!0),"validate"),message:Hr(Br.HDB_USERNAME)},{type:"password",when:Wo(e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Br.HDB_PASS),name:de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Yo,validate:a(s=>Us(s)?Us(s):!0,"validate"),message:Hr(Br.HDB_PASS)},{type:"input",transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.DEFAULTS_MODE],Br.DEFAULTS_MODE),name:de.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Yo,default:sge,validate:a(s=>Us(s)?Us(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:Wo(e[de.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Br.REPLICATION_HOSTNAME),prefix:Yo,default:ige,message:Hr(Br.REPLICATION_HOSTNAME)}),Sh.autoCastBoolean(e[de.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_NODENAME],Br.NODE_NAME),name:de.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Yo,default:HEe.random(),validate:a(i=>ZEe.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:Hr(Br.NODE_NAME)},{type:"input",transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_USER],Br.CLUSTER_USERNAME),name:de.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Yo,default:nge,validate:a(i=>Us(i)?Us(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:Hr(Br.CLUSTER_USERNAME)},{type:"password",when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Br.CLUSTER_PASS),name:de.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Yo,validate:a(i=>Us(i)?Us(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(age,"installPrompts");function Wo(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(Wo,"displayCmdEnvVar");function Us(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(Us,"checkForEmptyValue");function cge(){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(cge,"checkForPromptOverride");async function lge(){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=BEe(e),s=AC.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&&!RC){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(sc+Kl.magenta.bold(QEe)),console.log(Kl.magenta.bold(s)),pr.error(s)}else console.log(sc+Kl.magenta.bold(SC)),pr.error(SC);process.exit(0)}}a(lge,"checkForExistingInstall");async function uge(e){pr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${jEe}${sc}and can be viewed by typing or copying and pasting the URL into your web browser.${sc}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Yo,transformer:Vl,when:Wo(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()!==JEe&&(console.log(Kl.yellow(mW)),pr.error(mW),process.exit(0))}a(uge,"termsAgreement");async function dge(){let e=ji.join(zi,de.HDB_CONFIG_FILE),t;try{t=TC.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=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}nc.setProperty(de.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),nc.setProperty(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),nc.setProperty(nc.BOOT_PROPS_FILE_PATH,o)}}a(dge,"createBootPropertiesFile");async function fge(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{ic[de.INSTALL_PROMPTS.HDB_CONFIG]||AC.createConfigFile(t),nc.initSync()}catch(r){_ge(r)}}a(fge,"createConfigFile");function _ge(e){pr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(XEe);let t=ji.resolve(nc.get(nc.BOOT_PROPS_FILE_PATH),"../");t&&xs.removeSync(t),zi&&(TW?xs.readdirSync(zi,{withFileTypes:!0}).forEach(n=>{let s=ji.join(n.path,n.name);s!==ic[de.INSTALL_PROMPTS.HDB_CONFIG]&&xs.removeSync(s)}):xs.removeSync(zi)),process.exit(1)}a(_ge,"rollbackInstall");async function yW(e,t){pr.trace("Creating admin user"),await zEe();let r;try{r=await VEe.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 $Ee.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 pge(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(pge,"createClusterUser");async function hge(){let e=SW.version;if(e)await gW.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(hge,"insertHdbVersionInfo");function mge(e){ic[de.INSTALL_PROMPTS.HDB_CONFIG]=e}a(mge,"updateConfigEnv");function Ege(e){RC=e}a(Ege,"setIgnoreExisting")});var IW=w((wUe,wW)=>{"use strict";var yC=ie(),cs=z(),NW=uC();wW.exports={processDirectives:gge};async function gge(e){console.log("Starting upgrade process...");let t=NW.getVersionsForUpgrade(e),r=Age(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=Sge(o.sync_functions)}catch(f){throw cs.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await Tge(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(gge,"processDirectives");function Sge(e){if(yC.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(Sge,"runSyncFunctions");async function Tge(e){if(yC.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(Tge,"runAsyncFunctions");function Age(e){if(yC.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=NW.getDirectiveByVersion(r);n&&t.push(n)}return t}a(Age,"getUpgradeDirectivesToInstall")});var wC=w((CUe,vW)=>{"use strict";var PT=ae();PT.initSync();var LW=require("chalk"),CW=require("fs-extra"),jo=z(),zo=(H(),C(G)),Rge=IW(),bC=ie(),MW=mh(),yge=gT(),PW=sR(),bge=As(),{packageJson:DW}=st(),Oge=require("util").promisify,Nge=Oge(bge.setSchemaDataToGlobal),OC,{UPGRADE_VERSION:NC}=zo.UPGRADE_JSON_FIELD_NAMES_ENUM;vW.exports={upgrade:wge};async function wge(e){await Nge(),OC===void 0&&(OC=Cd()),CW.existsSync(PT.get(PT.BOOT_PROPS_FILE_PATH))||(Th("The hdb_boot_properties file was not found. Please install HDB.",zo.LOG_LEVELS.ERROR),process.exit(1)),CW.existsSync(PT.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 MW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),Th(`This version of HarperDB is ${DW.version}`,zo.LOG_LEVELS.INFO);let r=t[NC]??DW.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 Ige();let n,s=0;try{n=await yge.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 Cge(t),Th(`HarperDB was successfully upgraded to version ${t[NC]}`,zo.LOG_LEVELS.INFO)}a(wge,"upgrade");async function Ige(){let e=!1,t=await PW.findPs(zo.HDB_PROC_NAME);if(bC.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await PW.findPs("hdb_express");bC.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await OC.list();bC.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)),jo.error(r),process.exit(1)}}a(Ige,"checkIfRunning");async function Cge(e){try{await Rge.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 MW.insertHdbUpgradeInfo(e[NC])}catch(t){jo.error("Error updating the 'hdb_info' system table."),jo.error(t)}}a(Cge,"runUpgrade");function Th(e,t=void 0){t||(t=jo.info),jo[t](e),console.log(LW.magenta(e))}a(Th,"printToLogAndConsole")});var kW={};ve(kW,{onStorageReclamation:()=>Ah,runReclamationHandlers:()=>DC,setAvailableSpaceRatioGetter:()=>Dge});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}),PC||(PC=setTimeout(DC,xW).unref()))}async function DC(){for(let[e,t]of DT)try{let r=await HW(e),n=Pge/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&&(CC.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){CC.default.error?.("Error running storage reclamation handlers",r)}PC=setTimeout(DC,xW).unref()}function Dge(e){HW=e??BW}var IC,LT,CC,MT,UW,DT,Pge,xW,PC,BW,HW,vT=be(()=>{IC=require("node:fs/promises"),LT=M(et()),CC=M(Ni());H();MT=M(ae()),UW=M(ie());MT.default.initSync();DT=new Map,Pge=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(IC.statfs){let t=await(0,IC.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(DC,"runReclamationHandlers");a(Dge,"setAvailableSpaceRatioGetter")});var VW=w((MUe,$W)=>{"use strict";var{promises:Wd,createReadStream:Lge,createWriteStream:Mge}=require("fs"),{createGzip:vge}=require("zlib"),{promisify:Uge}=require("util"),{pipeline:xge}=require("stream"),Bge=Uge(xge),MC=require("path"),ac=ae();ac.initSync();var oc=z(),{CONFIG_PARAMS:zd,ITC_EVENT_TYPES:Hge}=(H(),C(G)),{onMessageFromWorkers:kge}=et(),{convertToMS:Fge}=ie(),{onStorageReclamation:Gge}=(vT(),C(kW)),qge=6e4,$ge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Vge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",LC,GW;$W.exports=qW;kge(e=>{e.type===Hge.RESTART&&(ac.initSync(!0),clearInterval(GW),ac.get(zd.LOGGING_ROTATION_ENABLED)&&qW())});async function qW(){try{let e=oc.getLogFilePath(),t=ac.get(zd.LOGGING_ROTATION_MAXSIZE),r=ac.get(zd.LOGGING_ROTATION_INTERVAL),n=ac.get(zd.LOGGING_ROTATION_RETENTION),s=0;if(Gge(e,l=>{s=l},!0),!t&&!r){oc.error($ge);return}let i=ac.get(zd.LOGGING_ROTATION_PATH);if(!i){oc.error(Vge);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}LC=Date.now()/6e4,oc.trace("Log rotate enabled, maxSize:",t,"interval:",r),GW=setInterval(async()=>{if(o){let l;l=await Wd.stat(e),l.size>=o&&await FW(e,i)}if(c&&Date.now()/6e4-LC>=c&&(await FW(e,i),LC=Date.now()/6e4),n||s){let l=Fge(n??"1M")/(1+s);s=0;let u=await Wd.readdir(i);for(let f of u)try{let d=await Wd.stat(MC.join(i,f));Date.now()-d.mtimeMs>l&&await Wd.unlink(MC.join(i,f))}catch(d){oc.error("Error trying to remove log",f,d)}}},qge).unref()}catch(e){oc.error(e)}}a(qW,"logRotator");async function FW(e,t){let r=ac.get(zd.LOGGING_ROTATION_COMPRESS),n=MC.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);await Wd.rename(e,n),r&&(e=n,n+=".gz",await Bge(Lge(e),vge(),Mge(n)),await Wd.unlink(e)),oc.closeLogFile(),oc.notify(`hdb.log rotated, old log moved to ${n}`)}a(FW,"moveLogFile")});var Jd=w(QW=>{"use strict";var Se=ae();Se.initSync();Wa();var Ft=(H(),C(G)),{CONFIG_PARAMS:Ie}=Ft,ls=z(),Jo=require("fs-extra"),Qo=require("path"),Kge=eC(),{install:Yge}=CT(),vC=require("chalk"),{packageJson:Wge,PACKAGE_ROOT:zge}=st(),Xo=ie(),UC=yt(),YW=ua(),KW=SS(),jge=wC(),Jge=VW(),{compactOnStart:Qge}=(wS(),C(NS)),Xge=require("minimist"),Zge=Zn(),{startHTTPThreads:eSe}=(xC(),C(XW)),tSe=mh(),{isMainThread:rSe}=require("worker_threads"),UUe=po(),xUe=go(),BUe=Cb(),HUe=v_(),UT=(H(),C(G)),Ji,jd,WW=!1,nSe="Upgrade complete. Starting HarperDB.",sSe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",iSe="HarperDB not found, starting install process.",oSe="There was an error during install, check install_log.log for more details. Exiting.",aSe="HarperDB successfully started.";function cSe(){if(!WW){let e=a(()=>{Jo.removeSync(Qo.join(Se.get(Ft.CONFIG_PARAMS.ROOTPATH),Ft.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(cSe,"addExitListeners");async function zW(e=!1,t=!1){if(console.log(vC.magenta("Starting HarperDB...")),ls.suppressLogging?.(()=>{console.log(vC.magenta(""+Jo.readFileSync(Qo.join(zge,"utility/install/ascii_logo.txt"))))}),await JW()===!1){console.log(iSe);try{await Yge()}catch(l){console.error(oSe,l),ls.error(l),process.exit(1)}}if(!e){let l=YW(Object.keys(Ft.CONFIG_PARAM_MAP),!0);!Xo.isEmpty(l)&&!Xo.isEmptyOrZeroLength(Object.keys(l))&&UC.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(Se.get(Ft.CONFIG_PARAMS.ROOTPATH),Ft.HDB_PID_FILE),i=_Se(s);i&&i!==1&&pSe(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),Ji===void 0&&(Ji=Cd()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),Se.get(Ft.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 Ji.startClusteringProcesses(!0),process.exit()),cSe(),await Jo.writeFile(Qo.join(Se.get(UT.CONFIG_PARAMS.ROOTPATH),UT.HDB_PID_FILE),`${process.pid}`),ls.info("HarperDB PID",process.pid);let o;try{let l=await tSe.getVersionUpdateInfo();l!==void 0&&(o=l[Ft.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await jge.upgrade(l),console.log(nSe))}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(sSe,l),ls.error(l)),process.exit(1)}Kge(),dSe(),await Zge.reviewSelfSignedCert(),Xo.autoCastBoolean(Se.get(Ft.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&rSe&&await KW.generateNatsConfig(t)}a(zW,"initialize");async function lSe(e=!1){try{jd=Xge(process.argv),jd.ROOTPATH&&UC.updateConfigObject("settings_path",Qo.join(jd.ROOTPATH,Ft.HDB_CONFIG_FILE)),await zW(e,!0),Se.get(Ft.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Qge();let t=process.env.IS_SCRIPTED_SERVICE&&!jd.service;Xo.autoCastBoolean(Se.get(Ft.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Ji.startClusteringProcesses(),await Ji.startClusteringThreads()),await eSe(process.env.DEV_MODE?1:Se.get(UT.CONFIG_PARAMS.THREADS_COUNT)??Se.get(UT.CONFIG_PARAMS.THREADS)),Se.get(Ft.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Jge(),t||jW()}catch(t){console.error(t),ls.error(t),process.exit(1)}}a(lSe,"main");function jW(){ls.suppressLogging(()=>{console.log(vC.magenta(`HarperDB ${Wge.version} successfully started`))}),ls.notify(aSe)}a(jW,"started");async function uSe(e=!0){WW=!e;try{Ji===void 0&&(Ji=Cd()),Ji.enterPM2Mode(),await zW(),Xo.autoCastBoolean(Se.get(Ft.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Ji.startClusteringProcesses(),await Ji.startService(Ft.PROCESS_DESCRIPTORS.HDB),jW(),e&&process.exit(0)}catch(t){console.error(t),ls.error(t),process.exit(1)}}a(uSe,"launch");function dSe(){let e=Qo.join(Se.get(Ft.CONFIG_PARAMS.ROOTPATH),Ft.LICENSE_KEY_DIR_NAME,Ft.LICENSE_FILE_NAME),t=Qo.join(e,Ft.LICENSE_FILE_NAME),r=Qo.join(e,Ft.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=YW(["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(dSe,"writeLicenseFromVars");Object.assign(QW,{launch:uSe,main:lSe,isHdbInstalled:JW,startupLog:fSe});async function JW(){try{await Jo.stat(Xo.getPropsFilePath()),await Jo.stat(Se.get(Ft.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 fSe(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`),Ko.notify("Reindexing upgrade started for transaction logs"),await $Y(lC,!0,e)),Ko.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(_h?", but errors occurred":"")}a(Bme,"reindexUpgrade");async function $Y(e,t,r){let n=await zi.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Yo.join(e,o.toString());if(o===".DS_Store")continue;let l=await zi.readdir(c),u=l.length;for(let f=0;f<u;f++){let d=l[f];if(d!==".DS_Store"&&zi.statSync(Yo.join(c,d)).isDirectory())try{await Hme(o,d,t),on.info(`Reindexing started for ${o}.${d}`),Ko.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${d}`),await Fme(o,d,c,t,r),on.info(`Reindexing completed for ${o}.${d}`),Ko.notify(`Reindexing completed for ${o}.${d}`)}catch(p){_h=!0,p.schema_path=c,p.table_name=d,Ko.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Ko.error(p),on.error(p),console.error(p)}}}if(!_h)try{await zi.rm(yT,{recursive:!0})}catch{}}a($Y,"processTables");async function Hme(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Yo.join(yT,s);await zi.ensureDir(yT),await zi.writeFile(i,""),on=Ume({level:"debug",formatters:{bindings(){}}},i)}a(Hme,"initPinoLogger");var kme=20;async function Fme(e,t,r,n,s){let i;try{i=await as.openEnvironment(r,t,n)}catch(E){if(E.message==="MDB_INVALID: File is not an LMDB file"){Ko.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`),on.error(E);return}throw E}let o=$me(i.dbis),c=as.openDBI(i,o),l=Object.keys(i.dbis),u=as.statDBI(i,o);on.info(`Old environment stats: ${JSON.stringify(u)}`);let f=new vme.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 as.createEnvironment(r,t,!1);as.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>kme&&await _();await _()}catch(E){throw _h=!0,on.error(E),E}async function _(){let E,A=p.map(({value:v})=>v);n?E=await Promise.all(A.map(v=>Gme(d,v))):E=await Pme(d,o,l.filter(v=>v!=="__blob__"),A,!1);for(let v=0,F=p.length;v<F;v++){let{key:$,value:Y}=p[v];on.info(`Record hash value: ${$} hash: ${o}`);let ee;n?ee=E[v]:ee=E.written_hashes.indexOf($)>-1,fh(ee,!0),qme(d,o,Y[o],n),on.info(`Insert success, written hashes: ${E.written_hashes}`),f.increment()}p=[],f.value/f.total*100%10===0&&Ko.notify(`${e}.${t} ${f.value}/${f.total} records inserted`),on.info(`${f.value}/${f.total} records inserted`)}a(_,"finishOutstanding"),f.stop();let h=as.statDBI(i,o),S=as.statDBI(d,o);if(on.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${S.entryCount}`),fh.deepStrictEqual(h.entryCount,S.entryCount),await as.closeEnvironment(i),await as.closeEnvironment(d),delete global.lmdb_map[`${e}.${t}`],s){let E=Yo.join(r,t),A=Yo.join(E,"data.mdb"),N=Yo.join(E,"lock.mdb");await zi.unlink(A),await zi.unlink(N),await zi.rmdir(E),on.info(`Deleted old environment files from schema folder: ${A}, ${N}`)}let g=await as.openEnvironment(r,t),R=as.statDBI(g,o);on.info(`New stats: ${JSON.stringify(S)}. New stats after move: ${JSON.stringify(R)}`),fh.deepStrictEqual(R.entryCount,S.entryCount),await as.closeEnvironment(g),delete global.lmdb_map[`${e}.${t}`]}a(Fme,"processTable");async function Gme(e,t){as.initializeDBIs(e,nc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,nc.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[nc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[nc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),Mme.isEmpty(t.user_name)||e.dbis[nc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[nc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(Gme,"insertTransaction");function qme(e,t,r,n){let i=e.dbis[t].get(r);fh.deepStrictEqual(typeof i,"object");let o;if(n){let c={[nc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[nc.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&&!Lme.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(qme,"validateIndices");function VY(e,t,r,n){try{let s=!1,i=Dme.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||on.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),fh.deepStrictEqual(s,!0)}catch(s){_h=!0,on.error(s),console.error(s)}}a(VY,"validateIndex");function $me(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($me,"getHashDBI")});var QY=I((hUe,JY)=>{"use strict";var bT=require("path"),sc=require("fs-extra"),Vme=aC(),Vl=W(),WY=Rt(),uC=ce(),gi=(H(),P(G)),OT=ae(),Kme=require("properties-reader"),Yme=si(),Wme=sg(),zme=Wr(),pUe=require("util"),jme=zme.searchByValue,Jme=bn(),Qme=fS(),Xme=St(),Zme=YY(),zY=es(),eEe=TT(),mh=new Vme("4.0.0"),jY=[],ph,hh;async function tEe(){try{if(await eEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),ph){let t=OT.changeExtension(ph,".bak");await sc.move(ph,t)}if(hh){let t=OT.changeExtension(hh,".bak");await sc.move(hh,t)}await zY.generateKeys()}else console.log("Using existing certificates."),zY.updateConfigCert(ph,hh,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(tEe,"generateNewKeys");async function rEe(){console.log("Updating HarperDB nodes."),Vl.info("Updating HarperDB nodes.");let e=[];try{let t=new Yme(gi.SYSTEM_SCHEMA_NAME,gi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await jme(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!Xme.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:gi.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(OT.isEmptyOrZeroLength(n))return;let s=new Wme(gi.SYSTEM_SCHEMA_NAME,gi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await Jme.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{Qme.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(rEe,"updateNodes");async function nEe(){let e=uC.get(gi.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(bT.join("config","settings.js"))){Vl.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),Vl.info(t);let r=bT.dirname(e),n=uC.get(gi.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=bT.join(n,"backup","4_0_0_upgrade_settings.bak"),i=bT.join(n,gi.HDB_CONFIG_FILE);try{Vl.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),sc.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{Vl.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),Vl.info("Updating env variables with new settings values");let d=WY.initOldConfig(e);ph=d[gi.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],hh=d[gi.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=OT.getPropsFilePath();sc.accessSync(o,sc.constants.F_OK|sc.constants.R_OK);let l=Kme(o).get(gi.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
|
|
111
|
+
install_user = ${l}`;try{sc.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{sc.removeSync(r),console.log(f),Vl.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(nEe,"updateSettingsFile_4_0_0");mh.async_functions.push(nEe);mh.async_functions.push(tEe);mh.async_functions.push(Zme);mh.async_functions.push(rEe);jY.push(mh);JY.exports=jY});var dC=I((EUe,tW)=>{"use strict";var Kl=ae(),sEe=(H(),P(G)),XY=W(),{DATA_VERSION:iEe,UPGRADE_VERSION:oEe}=sEe.UPGRADE_JSON_FIELD_NAMES_ENUM,ZY=GY(),NT=QY(),Yl=new Map;ZY&&ZY.forEach(e=>{Yl.set(e.version,e)});NT&&NT.forEach(e=>{Yl.set(e.version,e)});NT&&NT.forEach(e=>{Yl.set(e.version,e)});function aEe(){return[...Yl.keys()].sort(Kl.compareVersions)}a(aEe,"getSortedVersions");function eW(e){let t=e[iEe],r=e[oEe];return Kl.isEmptyOrZeroLength(t)||Kl.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."),[]):[...Yl.keys()].sort(Kl.compareVersions).filter(function(n){return Kl.compareVersions(n,t)>0&&Kl.compareVersions(n,r)<=0})}a(eW,"getVersionsForUpgrade");function cEe(e){return eW(e).length>0}a(cEe,"hasUpgradesRequired");function lEe(e){return Kl.isEmptyOrZeroLength(e)?null:Yl.has(e)?Yl.get(e):null}a(lEe,"getDirectiveByVersion");tW.exports={getSortedVersions:aEe,getDirectiveByVersion:lEe,getVersionsForUpgrade:eW,hasUpgradesRequired:cEe}});var Eh=I((SUe,oW)=>{"use strict";var uEe=require("util"),fC=require("chalk"),dEe=require("os"),nW=bn(),fEe=Wr(),cs=(H(),P(G)),sW=CY(),pC=xy(),{UpgradeObject:rW}=LY(),{forceDowngradePrompt:_Ee}=TT(),{packageJson:pEe}=st(),wT=W(),zd=ae(),hC=Rs(),hEe=(De(),P(nt)),mEe=dC(),EEe=uEe.promisify(hC.setSchemaDataToGlobal),gEe=fEe.searchByValue,SEe="info_id",TEe="2.9.9",AEe="3.0.0";async function REe(e){let t=new sW.HdbInfoInsertObject(1,e,e),r=new pC.InsertObject(cs.OPERATIONS_ENUM.INSERT,cs.SYSTEM_SCHEMA_NAME,cs.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,cs.INFO_TABLE_HASH_ATTRIBUTE,[t]);return hC.setSchemaDataToGlobal(),nW.insert(r)}a(REe,"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(cs.OPERATIONS_ENUM.INSERT,cs.SYSTEM_SCHEMA_NAME,cs.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,cs.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await EEe(),nW.insert(o)}a(_C,"insertHdbUpgradeInfo");async function iW(){let e=new pC.NoSQLSeachObject(cs.SYSTEM_SCHEMA_NAME,cs.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,SEe,cs.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await gEe(e))}catch(r){console.error(r)}return t}a(iW,"getAllHdbInfoRecords");async function yEe(){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(yEe,"getLatestHdbInfoRecord");async function bEe(){wT.info("Checking if HDB software has been updated");try{let e=pEe.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await yEe(),r;if(zd.isEmpty(t))r=TEe;else if(r=t.data_version_num,zd.compareVersions(r.toString(),e.toString())>0){if(!zd.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.${dEe.EOL}${cs.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");zd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(fC.yellow(`This instance's data was last run on version ${r}`)),await _Ee(new rW(r,e))?await _C(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(hC.setSchemaDataToGlobal(),OEe(r),e.toString()===r.toString())return;let n=new rW(r,e);if(mEe.hasUpgradesRequired(n))return n;zd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await _C(n.upgrade_version),wT.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw wT.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),wT.fatal(e),e}}a(bEe,"getVersionUpdateInfo");function OEe(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 ${cs.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in hEe.databases.system))throw console.log(t),new Error(t);if(!zd.isEmpty(e)&&e<AEe)throw console.log(t),new Error(t)}a(OEe,"checkIfInstallIsSupported");oW.exports={insertHdbInstallInfo:REe,insertHdbUpgradeInfo:_C,getVersionUpdateInfo:bEe}});var uW=I((AUe,lW)=>{"use strict";var IT=require("joi"),{boolean:NEe,string:mC,number:wEe}=IT.types(),aW=require("fs-extra"),gh=(H(),P(G)),cW=require("path"),IEe=it();lW.exports=CEe;function CEe(e){let t=mC.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=IT.object({[gh.INSTALL_PROMPTS.ROOTPATH]:IT.custom(PEe),[gh.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:IT.alternatives([wEe.min(0),mC]).allow("null",null),[gh.INSTALL_PROMPTS.TC_AGREEMENT]:mC.valid("yes","YES","Yes"),[gh.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[gh.INSTALL_PROMPTS.CLUSTERING_ENABLED]:NEe});return IEe.validateBySchema(e,r)}a(CEe,"installValidator");function PEe(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(PEe,"validateRootAvailable")});var SC=I((yUe,dW)=>{"use strict";var{mkdirpSync:DEe,copySync:LEe}=require("fs-extra"),ic=require("path"),Sh=(H(),P(G)),{PACKAGE_ROOT:MEe}=st(),gC=W(),vEe=Kn(),EC=ho(),UEe=Et();dW.exports=xEe;async function xEe(e){gC.trace("Mounting HarperDB"),Wl(e),Wl(ic.join(e,"backup")),Wl(ic.join(e,"keys")),Wl(ic.join(e,"keys",Sh.LICENSE_FILE_NAME)),Wl(ic.join(e,"log")),Wl(ic.join(e,"database")),Wl(ic.join(e,"components")),LEe(ic.resolve(MEe,"./utility/install/README.md"),ic.join(e,"README.md")),await BEe()}a(xEe,"mountHdb");async function BEe(){let e=U_(),t=Object.keys(EC);for(let r=0;r<t.length;r++){let n=t[r],s=EC[n].hash_attribute;try{UEe.initSystemSchemaPaths(Sh.SYSTEM_SCHEMA_NAME,n);let i=new e(Sh.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 vEe.createTable(n,i)}catch(i){throw gC.error(`issue creating environment for ${Sh.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(BEe,"createLMDBTables");function Wl(e){DEe(e,{mode:Sh.HDB_FILE_PERMISSIONS}),gC.info(`Directory ${e} created`)}a(Wl,"makeDirectory")});var DT=I((wUe,bW)=>{"use strict";var AC=require("os"),mW=require("inquirer"),Bs=require("fs-extra"),HEe=require("properties-reader"),jl=require("chalk"),Ji=require("path"),kEe=require("human-readable-ids").hri,FEe=require("ora"),GEe=require("yaml"),pr=W(),oc=ce(),Th=ae(),PT=da(),EW=Eh(),{packageJson:gW}=st(),_e=(H(),P(G)),{CONFIG_PARAM_MAP:OUe,CONFIG_PARAMS:Pt}=_e,qEe=uW(),$Ee=SC(),RC=Rt(),VEe=yn(),KEe=G_(),YEe=tC(),WEe=Rs(),zEe=require("util").promisify,jEe=zEe(WEe.setSchemaDataToGlobal),fW=es(),zl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),kr=a(e=>jl.magenta.bold(e),"HDB_PROMPT_MSG"),JEe="https://harperdb.io/legal/end-user-license-agreement",ac=AC.EOL,Wo="",QEe="yes",_W="Starting HarperDB install...",pW="HarperDB installation was successful.",hW="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",XEe="An out of date version of HarperDB is already installed.",TC="It appears that HarperDB is already installed. Exiting install...",ZEe="Aborting install",NUe=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])$/),ege=new RegExp(/^[^\s.,*>]+$/),tge=AC.homedir(),rge=Ji.join(tge,_e.HDB_ROOT_DIR_NAME),nge="HDB_ADMIN",sge="CLUSTER_USER",ige="dev",oge="localhost",CT={[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},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:"},cc=PT([_e.INSTALL_PROMPTS.HDB_CONFIG]),ji,SW=!1,yC=!1,TW=!1;bW.exports={install:AW,updateConfigEnv:Ege,setIgnoreExisting:gge};AW.createSuperUser=yW;async function AW(){console.log(kr(ac+_W+ac)),pr.notify(_W);let e;cc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&(e=age());let t=lge();Object.assign(t,e),t[_e.INSTALL_PROMPTS.TC_AGREEMENT]&&t[_e.INSTALL_PROMPTS.ROOTPATH]&&t[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[_e.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(TW=!0,t[_e.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=qEe(t);if(r)throw r.message;await uge(),await dge(t);let n=await cge(t);ji=n[_e.INSTALL_PROMPTS.ROOTPATH],cc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&Ji.dirname(cc[_e.INSTALL_PROMPTS.HDB_CONFIG])===ji&&(SW=!0),!yC&&!cc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&await Bs.pathExists(Ji.join(ji,_e.HDB_CONFIG_FILE))&&(console.error(TC),process.exit());let s=FEe({prefixText:kr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),Th.isEmpty(ji))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");oc.setHdbBasePath(ji),await $Ee(ji),await fge(),await _ge(n),pr.initLogSettings(!0),await yW(n),await hge(n),await fW.updateConfigCert(),await fW.generateCertsKeys(),await mge(),YEe(),s.stop(),console.log(kr(ac+pW+ac)),pr.notify(pW)}a(AW,"install");function age(){let e=GEe.parseDocument(Bs.readFileSync(cc[_e.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=RC.flattenConfig(e.toJSON());return t[_e.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[_e.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(age,"getConfigFromFile");async function cge(e){pr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:_e.INSTALL_PROMPTS.ROOTPATH,prefix:Wo,default:rge,validate:a(async s=>xs(s)?xs(s):await Bs.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:zl,when:zo(e[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Wo,default:nge,validate:a(s=>xs(s)?xs(s):(t=s,!0),"validate"),message:kr(Hr.HDB_USERNAME)},{type:"password",when:zo(e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Hr.HDB_PASS),name:_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Wo,validate:a(s=>xs(s)?xs(s):!0,"validate"),message:kr(Hr.HDB_PASS)},{type:"input",transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:_e.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Wo,default:ige,validate:a(s=>xs(s)?xs(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:_e.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Wo,default:oge,message:kr(Hr.REPLICATION_HOSTNAME)}),Th.autoCastBoolean(e[_e.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:_e.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Wo,default:kEe.random(),validate:a(i=>ege.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:kr(Hr.NODE_NAME)},{type:"input",transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:_e.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Wo,default:sge,validate:a(i=>xs(i)?xs(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:kr(Hr.CLUSTER_USERNAME)},{type:"password",when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Hr.CLUSTER_PASS),name:_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Wo,validate:a(i=>xs(i)?xs(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(cge,"installPrompts");function zo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${kr(t)} ${jl.gray("[hidden]")}`),pr.trace(`${kr(t)} [hidden]`)):(console.log(`${kr(t)} ${e}`),pr.trace(`${kr(t)} ${e}`)),!1):!0}a(zo,"displayCmdEnvVar");function xs(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(xs,"checkForEmptyValue");function lge(){let e=Object.keys(_e.INSTALL_PROMPTS),t=PT(e),r=PT(Object.keys(_e.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=_e.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(lge,"checkForPromptOverride");async function uge(){pr.trace("Checking for existing install.");let e=Th.getPropsFilePath(),t=await Bs.pathExists(e),r;if(t){pr.trace(`Install found an existing boot prop file at:${e}`);let n=HEe(e),s=RC.getConfigValue(_e.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(_e.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Bs.pathExists(s)}if(!t&&Th.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(ac+jl.magenta.bold(XEe)),console.log(jl.magenta.bold(s)),pr.error(s)}else console.log(ac+jl.magenta.bold(TC)),pr.error(TC);process.exit(0)}}a(uge,"checkForExistingInstall");async function dge(e){pr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${JEe}${ac}and can be viewed by typing or copying and pasting the URL into your web browser.${ac}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Wo,transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.TC_AGREEMENT],t),name:_e.INSTALL_PROMPTS.TC_AGREEMENT,message:kr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:jl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await mW.prompt([r]);n[_e.INSTALL_PROMPTS.TC_AGREEMENT]&&n[_e.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==QEe&&(console.log(jl.yellow(hW)),pr.error(hW),process.exit(0))}a(dge,"termsAgreement");async function fge(){let e=Ji.join(ji,_e.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=Th.getHomeDir(),s=Ji.join(n,_e.HDB_HOME_DIR_NAME),i=Ji.join(s,_e.LICENSE_KEY_DIR_NAME);try{Bs.mkdirpSync(s,{mode:_e.HDB_FILE_PERMISSIONS}),Bs.mkdirpSync(i,{mode:_e.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${_e.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Ji.join(s,_e.BOOT_PROPS_FILE_NAME);try{await Bs.writeFile(o,r)}catch(c){throw pr.error(`There was an error creating the boot file at path: ${o}`),c}oc.setProperty(_e.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),oc.setProperty(_e.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),oc.setProperty(oc.BOOT_PROPS_FILE_PATH,o)}}a(fge,"createBootPropertiesFile");async function _ge(e){pr.trace("Creating HarperDB config file");let t=PT(Object.keys(_e.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[_e.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in CT){if(r===Pt.HTTP_PORT&&t[Pt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??CT[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()]??CT[r],t[Pt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Pt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=CT[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{cc[_e.INSTALL_PROMPTS.HDB_CONFIG]||RC.createConfigFile(t),oc.initSync()}catch(r){pge(r)}}a(_ge,"createConfigFile");function pge(e){pr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(ZEe);let t=Ji.resolve(oc.get(oc.BOOT_PROPS_FILE_PATH),"../");t&&Bs.removeSync(t),ji&&(SW?Bs.readdirSync(ji,{withFileTypes:!0}).forEach(n=>{let s=Ji.join(n.path,n.name);s!==cc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&Bs.removeSync(s)}):Bs.removeSync(ji)),process.exit(1)}a(pge,"rollbackInstall");async function RW(e,t){pr.trace("Creating admin user"),await jEe();let r;try{r=await KEe.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 VEe.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[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await RW(t,r),delete e[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(yW,"createSuperUser");async function hge(e){pr.trace("Creating Cluster user.");let t;e[_e.INSTALL_PROMPTS.CLUSTERING_USER]&&e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[_e.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await RW({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[_e.INSTALL_PROMPTS.CLUSTERING_USER],delete e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(hge,"createClusterUser");async function mge(){let e=gW.version;if(e)await EW.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(mge,"insertHdbVersionInfo");function Ege(e){cc[_e.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Ege,"updateConfigEnv");function gge(e){yC=e}a(gge,"setIgnoreExisting")});var wW=I((CUe,NW)=>{"use strict";var bC=ae(),ls=W(),OW=dC();NW.exports={processDirectives:Sge};async function Sge(e){console.log("Starting upgrade process...");let t=OW.getVersionsForUpgrade(e),r=Rge(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;ls.notify(c),console.log(c);let l=[],u=[];try{l=Tge(o.sync_functions)}catch(f){throw ls.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await Age(o.async_functions)}catch(f){throw ls.error(`Error while running an upgrade script for ${o.version}`),f}n.push(...l,...u)}return n}a(Sge,"processDirectives");function Tge(e){if(bC.isEmptyOrZeroLength(e))return ls.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return ls.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(ls.info(`Running function ${r.name}`),!(r instanceof Function)){ls.info("Variable being processed is not a function");continue}let n=r();ls.info(n),t.push(n)}return t}a(Tge,"runSyncFunctions");async function Age(e){if(bC.isEmptyOrZeroLength(e))return ls.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return ls.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(ls.info(`Running function ${s.name}`),!(s instanceof Function)){ls.info("Variable being processed is not a function");continue}let i=await s();ls.info(i),t.push(i)}return t}a(Age,"runAsyncFunctions");function Rge(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(Rge,"getUpgradeDirectivesToInstall")});var IC=I((DUe,MW)=>{"use strict";var LT=ce();LT.initSync();var DW=require("chalk"),IW=require("fs-extra"),Jo=W(),jo=(H(),P(G)),yge=wW(),OC=ae(),LW=Eh(),bge=TT(),CW=oR(),Oge=Rs(),{packageJson:PW}=st(),Nge=require("util").promisify,wge=Nge(Oge.setSchemaDataToGlobal),NC,{UPGRADE_VERSION:wC}=jo.UPGRADE_JSON_FIELD_NAMES_ENUM;MW.exports={upgrade:Ige};async function Ige(e){await wge(),NC===void 0&&(NC=Dd()),IW.existsSync(LT.get(LT.BOOT_PROPS_FILE_PATH))||(Ah("The hdb_boot_properties file was not found. Please install HDB.",jo.LOG_LEVELS.ERROR),process.exit(1)),IW.existsSync(LT.get(jo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(Ah("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 LW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),Ah(`This version of HarperDB is ${PW.version}`,jo.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 ${jo.HDB_SUPPORT_ADDRESS}`),Jo.notify("Missing new version field from upgrade info object"),process.exit(1)),await Cge();let n,s=0;try{n=await bge.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 Pge(t),Ah(`HarperDB was successfully upgraded to version ${t[wC]}`,jo.LOG_LEVELS.INFO)}a(Ige,"upgrade");async function Cge(){let e=!1,t=await CW.findPs(jo.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(Cge,"checkIfRunning");async function Pge(e){try{await yge.processDirectives(e)}catch(t){throw Ah("There was an error during the data upgrade. Please check the logs.",jo.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(Pge,"runUpgrade");function Ah(e,t=void 0){t||(t=Jo.info),Jo[t](e),console.log(DW.magenta(e))}a(Ah,"printToLogAndConsole")});var HW={};Ue(HW,{onStorageReclamation:()=>Rh,runReclamationHandlers:()=>LC,setAvailableSpaceRatioGetter:()=>Lge});function Rh(e,t,r){(r||(0,vT.getWorkerIndex)()===(0,vT.getWorkerCount)()-1)&&(MT.has(e)||MT.set(e,[]),MT.get(e).push({priority:0,handler:t}),DC||(DC=setTimeout(LC,UW).unref()))}async function LC(){for(let[e,t]of MT)try{let r=await BW(e),n=Dge/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 Lge(e){BW=e??xW}var CC,vT,PC,UT,vW,MT,Dge,UW,DC,xW,BW,xT=be(()=>{CC=require("node:fs/promises"),vT=M(rt()),PC=M(wi());H();UT=M(ce()),vW=M(ae());UT.default.initSync();MT=new Map,Dge=UT.default.get(x.STORAGE_RECLAMATION_THRESHOLD)??.4,UW=(0,vW.convertToMS)(UT.default.get(x.STORAGE_RECLAMATION_INTERVAL))||36e5;a(Rh,"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(Lge,"setAvailableSpaceRatioGetter")});var $W=I((UUe,qW)=>{"use strict";var{promises:jd,createReadStream:Mge,createWriteStream:vge}=require("fs"),{createGzip:Uge}=require("zlib"),{promisify:xge}=require("util"),{pipeline:Bge}=require("stream"),Hge=xge(Bge),vC=require("path"),uc=ce();uc.initSync();var lc=W(),{CONFIG_PARAMS:Jd,ITC_EVENT_TYPES:kge}=(H(),P(G)),{onMessageFromWorkers:Fge}=rt(),{convertToMS:Gge}=ae(),{onStorageReclamation:qge}=(xT(),P(HW)),$ge=6e4,Vge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Kge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",MC,FW;qW.exports=GW;Fge(e=>{e.type===kge.RESTART&&(uc.initSync(!0),clearInterval(FW),uc.get(Jd.LOGGING_ROTATION_ENABLED)&&GW())});async function GW(){try{let e=lc.getLogFilePath(),t=uc.get(Jd.LOGGING_ROTATION_MAXSIZE),r=uc.get(Jd.LOGGING_ROTATION_INTERVAL),n=uc.get(Jd.LOGGING_ROTATION_RETENTION),s=0;if(qge(e,l=>{s=l},!0),!t&&!r){lc.error(Vge);return}let i=uc.get(Jd.LOGGING_ROTATION_PATH);if(!i){lc.error(Kge);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,lc.trace("Log rotate enabled, maxSize:",t,"interval:",r),FW=setInterval(async()=>{if(o){let l;l=await jd.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=Gge(n??"1M")/(1+s);s=0;let u=await jd.readdir(i);for(let f of u)try{let d=await jd.stat(vC.join(i,f));Date.now()-d.mtimeMs>l&&await jd.unlink(vC.join(i,f))}catch(d){lc.error("Error trying to remove log",f,d)}}},$ge).unref()}catch(e){lc.error(e)}}a(GW,"logRotator");async function kW(e,t){let r=uc.get(Jd.LOGGING_ROTATION_COMPRESS),n=vC.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);await jd.rename(e,n),r&&(e=n,n+=".gz",await Hge(Mge(e),Uge(),vge(n)),await jd.unlink(e)),lc.closeLogFile(),lc.notify(`hdb.log rotated, old log moved to ${n}`)}a(kW,"moveLogFile")});var Xd=I(JW=>{"use strict";var ge=ce();ge.initSync();ja();var Gt=(H(),P(G)),{CONFIG_PARAMS:Ce}=Gt,us=W(),Qo=require("fs-extra"),Xo=require("path"),Yge=tC(),{install:Wge}=DT(),UC=require("chalk"),{packageJson:zge,PACKAGE_ROOT:jge}=st(),Zo=ae(),xC=Rt(),KW=da(),VW=AS(),Jge=IC(),Qge=$W(),{compactOnStart:Xge}=(CS(),P(IS)),Zge=require("minimist"),eSe=es(),{startHTTPThreads:tSe}=(BC(),P(QW)),rSe=Eh(),{isMainThread:nSe}=require("worker_threads"),BUe=ho(),HUe=So(),kUe=Db(),FUe=U_(),BT=(H(),P(G)),Qi,Qd,YW=!1,sSe="Upgrade complete. Starting HarperDB.",iSe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",oSe="HarperDB not found, starting install process.",aSe="There was an error during install, check install_log.log for more details. Exiting.",cSe="HarperDB successfully started.";function lSe(){if(!YW){let e=a(()=>{Qo.removeSync(Xo.join(ge.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(lSe,"addExitListeners");async function WW(e=!1,t=!1){if(console.log(UC.magenta("Starting HarperDB...")),us.suppressLogging?.(()=>{console.log(UC.magenta(""+Qo.readFileSync(Xo.join(jge,"utility/install/ascii_logo.txt"))))}),await jW()===!1){console.log(oSe);try{await Wge()}catch(l){console.error(aSe,l),us.error(l),process.exit(1)}}if(!e){let l=KW(Object.keys(Gt.CONFIG_PARAM_MAP),!0);!Zo.isEmpty(l)&&!Zo.isEmptyOrZeroLength(Object.keys(l))&&xC.updateConfigValue(void 0,void 0,l,!0,!0)}let r,n=Qd?.service==="clustering";Qd?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));let s=Xo.join(ge.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.HDB_PID_FILE),i=pSe(s);i&&i!==1&&hSe(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),Qi===void 0&&(Qi=Dd()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),ge.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 Qi.startClusteringProcesses(!0),process.exit()),lSe(),await Qo.writeFile(Xo.join(ge.get(BT.CONFIG_PARAMS.ROOTPATH),BT.HDB_PID_FILE),`${process.pid}`),us.info("HarperDB PID",process.pid);let o;try{let l=await rSe.getVersionUpdateInfo();l!==void 0&&(o=l[Gt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Jge.upgrade(l),console.log(sSe))}catch(l){o?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${o}. Exiting HarperDB.`,l),us.error(l)):(console.error(iSe,l),us.error(l)),process.exit(1)}Yge(),fSe(),await eSe.reviewSelfSignedCert(),Zo.autoCastBoolean(ge.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&nSe&&await VW.generateNatsConfig(t)}a(WW,"initialize");async function uSe(e=!1){try{Qd=Zge(process.argv),Qd.ROOTPATH&&xC.updateConfigObject("settings_path",Xo.join(Qd.ROOTPATH,Gt.HDB_CONFIG_FILE)),await WW(e,!0),ge.get(Gt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Xge();let t=process.env.IS_SCRIPTED_SERVICE&&!Qd.service;Zo.autoCastBoolean(ge.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Qi.startClusteringProcesses(),await Qi.startClusteringThreads()),await tSe(process.env.DEV_MODE?1:ge.get(BT.CONFIG_PARAMS.THREADS_COUNT)??ge.get(BT.CONFIG_PARAMS.THREADS)),ge.get(Gt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Qge(),t||zW()}catch(t){console.error(t),us.error(t),process.exit(1)}}a(uSe,"main");function zW(){us.suppressLogging(()=>{console.log(UC.magenta(`HarperDB ${zge.version} successfully started`))}),us.notify(cSe)}a(zW,"started");async function dSe(e=!0){YW=!e;try{Qi===void 0&&(Qi=Dd()),Qi.enterPM2Mode(),await WW(),Zo.autoCastBoolean(ge.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Qi.startClusteringProcesses(),await Qi.startService(Gt.PROCESS_DESCRIPTORS.HDB),zW(),e&&process.exit(0)}catch(t){console.error(t),us.error(t),process.exit(1)}}a(dSe,"launch");function fSe(){let e=Xo.join(ge.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.LICENSE_KEY_DIR_NAME,Gt.LICENSE_FILE_NAME),t=Xo.join(e,Gt.LICENSE_FILE_NAME),r=Xo.join(e,Gt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=KW(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Zo.isEmpty(n)||Zo.isEmpty(s))return;Qo.mkdirpSync(e),Qo.writeFileSync(r,n),Qo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),us.error(s)}}a(fSe,"writeLicenseFromVars");Object.assign(JW,{launch:dSe,main:uSe,isHdbInstalled:jW,startupLog:_Se});async function jW(){try{await Qo.stat(Zo.getPropsFilePath()),await Qo.stat(ge.get(Gt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Zo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw us.error(`Error checking for HDB install - ${e}`),e}return!0}a(jW,"isHdbInstalled");function _Se(e){let r=a(_=>_.padEnd(20),"pad"),n=`
|
|
113
|
+
`;ge.get(Ce.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${ge.get(Ce.REPLICATION_HOSTNAME)}
|
|
114
|
+
`),ge.get(Ce.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${ge.get(Ce.REPLICATION_URL)}
|
|
115
|
+
`),n+=`${r("Worker Threads:")}${ge.get(Ce.THREADS_COUNT)}
|
|
116
|
+
`,n+=`${r("Root Path:")}${ge.get(Ce.ROOTPATH)}
|
|
117
|
+
`,ge.get(Ce.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=ge.get(Ce.THREADS_DEBUG_PORT)?`, TCP: ${ge.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=Xo.join(ge.get(Ce.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${ge.get(Ce.LOGGING_LEVEL)}, location: ${s+(ge.get(Ce.LOGGING_STDSTREAMS)?", stdout/err":"")}
|
|
120
|
+
`,n+=r("Default:"),n+=ge.get(Ce.HTTP_PORT)?`HTTP (and WS): ${ge.get(Ce.HTTP_PORT)}, `:"",n+=ge.get(Ce.HTTP_SECUREPORT)?`HTTPS (and WS): ${ge.get(Ce.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${ge.get(Ce.HTTP_CORS)?`enabled for ${ge.get(Ce.HTTP_CORSACCESSLIST)}`:"disabled"}
|
|
121
|
+
`,n+=r("Operations API:"),n+=ge.get(Ce.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${ge.get(Ce.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=ge.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${ge.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${ge.get(Ce.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${ge.get(Ce.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${ge.get(Ce.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
|
|
122
|
+
`,n+=r("MQTT:"),n+=ge.get(Ce.MQTT_NETWORK_PORT)?`TCP: ${ge.get(Ce.MQTT_NETWORK_PORT)}, `:"",n+=ge.get(Ce.MQTT_NETWORK_SECUREPORT)?`TLS: ${ge.get(Ce.MQTT_NETWORK_SECUREPORT)}`:"",n+=ge.get(Ce.MQTT_WEBSOCKET)&&ge.get(Ce.HTTP_PORT)?`, WS: ${ge.get(Ce.HTTP_PORT)}`:"",n+=ge.get(Ce.MQTT_WEBSOCKET)&&ge.get(Ce.HTTP_SECUREPORT)?`, WSS: ${ge.get(Ce.HTTP_SECUREPORT)}
|
|
125
123
|
`:`
|
|
126
|
-
`;let i=
|
|
127
|
-
`;let l=[],u=
|
|
128
|
-
`);let p=
|
|
124
|
+
`;let i=ge.get(Ce.REPLICATION_PORT)??ge.get(Ce.OPERATIONSAPI_NETWORK_PORT),o=ge.get(Ce.REPLICATION_SECUREPORT)??ge.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=ge.get(Ce.HTTP_PORT)?`HTTP: ${ge.get(Ce.HTTP_PORT)}, `:"";p+=ge.get(Ce.HTTP_SECUREPORT)?`HTTPS: ${ge.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),ge.get(Ce.LOGGING_STDSTREAMS)&&us.logsAtLevel("info")&&us.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(_Se,"startupLog");function pSe(e){try{return Number.parseInt(Qo.readFileSync(e,"utf8"),10)}catch{return null}}a(pSe,"readPidFile");function hSe(e){try{return process.kill(e,0),!0}catch(t){return t.code==="EPERM"}}a(hSe,"isProcessRunning")});var WC=I(ea=>{"use strict";sm();var{isMainThread:HC,parentPort:Nh,threadId:kT,workerData:mSe}=require("node:worker_threads"),{Socket:ESe,createServer:gSe}=require("node:net"),{createServer:SSe,IncomingMessage:TSe}=require("node:http"),{createServer:ASe}=require("node:https"),{createSecureServer:RSe}=require("node:http2"),{Blob:ySe}=(Ss(),P(qm)),{unlinkSync:iz,existsSync:bSe}=require("fs"),Mn=W(),mt=ce(),Qt=(H(),P(G)),{server:wh}=(Kr(),P(Ru)),{WebSocketServer:OSe}=require("ws"),{createServer:NSe}=require("node:tls"),{getTicketKeys:wSe,restartNumber:ISe,getWorkerIndex:Zd}=rt(),{Headers:kC,appendHeader:CSe}=(j_(),P(wH)),{recordAction:yh,recordActionBinary:XW}=(Fi(),P(z_)),{Request:oz,createReuseportFd:Oh}=(ZI(),P(NY)),{checkMemoryLimit:PSe}=Nd(),{createTLSSelector:az}=es(),{resolvePath:cz}=Rt(),{startupLog:DSe}=Xd(),{Readable:ZW}=require("node:stream"),LSe=Ai(),lz=mt.get(Qt.CONFIG_PARAMS.THREADS_DEBUG);if(lz){let e;if(HC)e=mt.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Mn.info("Could not close debugger",t)}});else{let t=mt.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&Zd()>=0&&(e=t+Zd())}if(e){let t=mt.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=mt.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Mn.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){ISe<=1&&Mn.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:$Ue,CONFIG_PARAMS:MSe}=Qt;mt.initSync();var vSe=mt.get(MSe.HTTP_SESSIONAFFINITY),Xi={},FC=new Map;ea.registerServer=VC;ea.httpServer=YC;ea.deliverSocket=$C;ea.startServers=uz;ea.listenOnPorts=dz;ea.globals=LSe;ea.when_components_loaded=null;wh.http=YC;wh.request=xSe;wh.socket=BSe;wh.ws=HSe;wh.upgrade=pz;var bh={},HT={},FT={},GC=[];function uz(){return ea.when_components_loaded=VT().loadRootComponents(!0).then(()=>{Nh?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)$C(n,r,s);else if(t.requestId)USe(t);else if(t.type===Qt.ITC_EVENT_TYPES.SHUTDOWN){Mn.trace("received shutdown request",kT);for(let i in Xi){let o=Xi[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?Mn.info(`Closing ${_.length} idle connections`):p&&Mn.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(
|
|
134
|
-
`)}a(iz,"defaultNotFound")});var XW={};ve(XW,{startHTTPThreads:()=>kSe,startSocketServer:()=>QC,updateWorkerIdleness:()=>bz});async function kSe(e=2,t){try{if(t)jC(0,1,!0);else{let{loadRootComponents:r}=qT();if(e===0)return(0,Bs.setMainIsWorker)(!0),await YC().startServers(),Promise.resolve([]);await r()}yz();for(let r=0;r<e;r++)jC(r,e);return Promise.all(Rz)}finally{(0,Bs.threadsHaveStarted)()}}function yz(){let e=(0,Sz.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),zC=setInterval(()=>{KT.notify(e)},HSe).unref())}function jC(e,t=1,r){if(WC++,(0,Bs.startWorker)("server/threads/threadServer.js",{name:XA.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)});Rz.push(s),await s,Xd.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=Xd.indexOf(n);o>-1&&Xd.splice(o,1)}if(a(i,"removeWorker"),Zd){let o=Zd;Zd=[];for(let c of o)Az[c.localPort](null,c)}}}),r){let n=setInterval(()=>{JC?JC=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Bs.shutdownWorkers)(),WC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function QC(e=0,t){if(typeof e=="string")try{(0,YT.existsSync)(e)&&(0,YT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=FSe:r=GSe(t):r=XC;let n=(0,ef.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()),JC=!0,r(i,(o,c)=>{if(!o){if(mz){let u=i._socket||new ef.Socket({handle:i,writable:!0,readable:!0});mz.deliverSocket(u,e,c),u.resume()}else WC>0?(Zd.length===0&&setTimeout(()=>{Zd.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,Zd.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 ef.Socket({handle:i,writable:!0,readable:!0});VSe(u,o,e)}sr(!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 XC(e,t){let r,n=0;for(let s of Xd){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 FSe(e,t){let r={};e.getpeername(r);let n=r.address,s=tf.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);XC(e,o=>{tf.set(n,{worker:o,lastUsed:i}),t(o)})}function GSe(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new ef.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=tf.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);XC(n,d=>{tf.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function bz(){$T=0;for(let e of Xd)e.expectedIdle=e.recentELU.idle+qSe,e.requests=1;Xd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function VSe(e,t,r){let n=$Se++;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 Bs,ef,KT,YT,gz,Sz,Tz,Xd,Zd,Az,mz,WC,Rz,zC,HSe,JC,$T,Ez,tf,qSe,VT,$Se,xC=be(()=>{Bs=M(et()),ef=require("net");H();KT=M(z()),YT=require("fs");ki();gz=require("worker_threads"),Sz=M(bd()),Tz=M(st()),Xd=[],Zd=[],Az=[],WC=0,Rz=[];gz.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Bs.onMessageFromWorkers)(e=>{e.type===QA.RESTART&&zC&&(clearInterval(zC),yz())}));HSe=6e5;a(kSe,"startHTTPThreads");a(yz,"licenseWarning");a(jC,"startHTTPWorker");a(QC,"startSocketServer");$T=0;a(XC,"findMostIdleWorker");Ez=36e5,tf=new Map;a(FSe,"findByRemoteAddressAffinity");a(GSe,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of tf)r.lastUsed+Ez<e&&tf.delete(t)},Ez).unref();qSe=1e3;a(bz,"updateWorkerIdleness");(0,Bs.setMonitorListener)(bz);VT=new Map,$Se=1;a(VSe,"proxySocket")});var kz=w((jUe,Hz)=>{var Nz=M(require("cluster")),cc=M(ae());H();var Xi=M(z()),wz=M(require("fastify")),Iz=M(require("@fastify/cors")),Cz=M(require("@fastify/compress")),Pz=M(require("@fastify/static")),Dz=M(AO()),Lz=M(require("path")),Mz=M(st()),vz=M(As()),Uz=M(ie()),xz=M(An()),Bz=M(bd());Vr();var lc=M(pT());ao();cc.default.initSync();var KSe=6e4,YSe=1024*1024*1024,WSe="TRUE",{CONFIG_PARAMS:wh}=G,rf;Hz.exports={hdbServer:Oz,start:Oz};async function Oz(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=Nz.default.isMaster,await zSe();let t=e.securePort>0;rf=jSe(t),await rf.ready(),e||(e={}),e.isOperationsServer=!0;try{Ye.http(rf.server,e),rf.server.closeIdleConnections||await rf.listen({port:0,host:"::"})}catch(r){throw rf.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(Oz,"operationsServer");async function zSe(){Xi.default.trace("Configuring HarperDB process."),vz.default.setSchemaDataToGlobal(),await xz.default.setUsersWithRolesCache(),await Bz.default.getLicense()}a(zSe,"setUp");function jSe(e){Xi.default.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=JSe(e),r=(0,wz.default)(t);r.server.headersTimeout=XSe(),r.setErrorHandler(lc.serverErrorHandler);let n=QSe();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=cc.default.get(zA.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:[lc.reqBodyValidationHandler,lc.authHandler],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),(0,lc.handlePostRequest)(i,o)}),r.get("/health",()=>"HarperDB is running."),Xi.default.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(jSe,"buildServer");function JSe(e){let t=cc.default.get(wh.OPERATIONSAPI_NETWORK_TIMEOUT),r=cc.default.get(wh.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:YSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(JSe,"getServerOptions");function QSe(){let e=cc.default.get(wh.OPERATIONSAPI_NETWORK_CORS),t=cc.default.get(wh.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===WSe)&&(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(QSe,"getCORSOpts");function XSe(){return cc.default.get(wh.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??KSe}a(XSe,"getHeaderTimeoutConfig")});var sP={};ve(sP,{disableNATS:()=>eTe,publishToStream:()=>jT,setNATSReplicator:()=>ZC,setPublishToStream:()=>tTe,setSubscription:()=>nP,start:()=>ZSe});function ZSe(){Ih.default.get(B.CLUSTERING_ENABLED)&&nTe()}function eTe(e=!0){Vz=e}function tTe(e,t){jT=e,nP=t}function nTe(){if(Vz||process.env._DISABLE_NATS)return;let e=Qe(),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];ZC(s,r,i)}}ml((r,n)=>{ZC(r.tableName,r.databaseName,r),n&&Yz(r)}),!Fz&&(Fz=!0)}function ZC(e,t,r){if(t==="system"&&sTe.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 xn;return nP(t,e,i),i}static subscribeOnThisThread(i){return i<(Ih.default.get(B.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??rTe)}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(`${tP.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,rP.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,tP,rP,qz,$z,Ih,zT,Vz,jT,nP,rTe,Kz,Fz,sTe,WT,eP,Wz=be(()=>{Pe();Ea();Gz=M(ir()),tP=M(Tt()),rP=M(Eo());_u();qz=M(UO()),$z=M(_n()),Ih=M(ae());H();zT=M(z());a(ZSe,"start");a(eTe,"disableNATS");jT=Gz.publishToStream,nP=qz.setSubscription;a(tTe,"setPublishToStream");rTe=2;a(nTe,"assignReplicationSource");sTe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(ZC,"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(`${tP.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,rP.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)}},eP=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 eP});async function Xz({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await iP.get(e,{returnNonexistent:!0});i=new cP(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await iP.get(e);o&&o.delete()}i=new QT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ch.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function oP(){return JT++,JT>65500&&(JT=1),JT}function aP(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 Nt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var jz,uc,Jz,Qz,zz,iP,Ch,JT,QT,cP,Zz=be(()=>{Pe();Su();jz=M(_n()),uc=M(z());bc();Jz=M(et()),Qz=M(YC());Vr();zz=100,iP=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 Qz.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 aP(r,t,r)}catch{(0,uc.warn)("Failed to publish will",t)}Ch.delete(e.id)}})();a(Xz,"getSession");JT=1;a(oP,"getNextMessageId");QT=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,uc.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 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 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=oP());let F=b.id;if(Array.isArray(F)&&(F=gu(F)),F==null&&(F=""),await this.listener(h+"/"+F,b.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,uc.warn)(v)}})();return E});if(g)return g.topic=s,g.qos=t.qos,this.subscriptions.push(g),g}resume(){}needsAcknowledge(t){let r=oP();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 aP(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 aP(n,n.data,r)}}finally{await Ch.delete(this.sessionId)}}).catch(n=>{(0,uc.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(aP,"publish");cP=class extends QT{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=oP(),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,uc.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,uc.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),iP.put(this.sessionRecord)}}});var uP={};ve(uP,{bypassAuth:()=>iTe,start:()=>oTe});function iTe(){sj=!0}function oTe({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,nf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:f?.username,status:Ys.SUCCESS,type:la.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,nf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.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&&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,Y_(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),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 Ye.getUser(d.username,d.password.toString(),r),(0,nf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:n?.username,status:Ys.SUCCESS,type:la.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(se){return(0,nf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.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=Xz({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 he=se.indexOf("/",1),Re=he>0?se.slice(0,he):se;g({cmd:"publish",topic:se,payload:await E(Q),messageId:ne||Math.floor(Math.random()*1e8),qos:J.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(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,eA.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 eA,rj,nf,lP,nj,ZT,hr,sj,ej,XT,ij=be(()=>{eA=require("mqtt-packet");Zz();rj=M(An());ao();ki();Vr();nf=M(ae());H();lP=M(Ni()),nj=require("events"),ZT=(0,lP.loggerWithTag)("auth-event"),hr=(0,lP.loggerWithTag)("mqtt"),sj=(0,nf.get)(B.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(iTe,"bypassAuth");a(oTe,"start");XT=0;a(tj,"onSocket")});var zp={};ve(zp,{component_errors:()=>of,getComponentName:()=>dTe,loadComponent:()=>nA,loadComponentDirectories:()=>uj,setErrorReporter:()=>uTe});function uj(e,t){t&&(fP=t),e&&(mP=e);let r=[];if((0,lt.existsSync)(dP)){let s=(0,lt.readdirSync)(dP,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,St.join)(dP,o);r.push(nA(c,fP,VA,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(nA(n,fP,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{lj=!0})}function uTe(e){Ph=e}async function nA(e,t,r,n,s,i){let o=(0,lt.realpathSync)(e);if(tA.has(o))return tA.get(o);tA.set(o,!0),s&&(mP=s);try{let c;n&&(of=new Map);let l=(0,St.join)(e,"harperdb-config.yaml");(0,lt.existsSync)(l)?c=n?(0,sA.getConfigObj)():(0,_P.parseDocument)((0,lt.readFileSync)(l,"utf8")).toJSON():!n&&(0,lt.existsSync)(l=(0,St.join)(e,"config.yaml"))?c=(0,_P.parseDocument)((0,lt.readFileSync)(l,"utf8")).toJSON():c=EP;let u=(0,St.join)(e,"node_modules","harperdb");try{Yl.isMainThread&&(n||((0,lt.existsSync)(u)||!e.startsWith((0,hP.getHdbBasePath)()))&&(!(0,lt.existsSync)(u)||(0,lt.realpathSync)(pP.PACKAGE_ROOT)!==(0,lt.realpathSync)(u)))&&((0,lt.rmSync)(u,{recursive:!0,force:!0}),(0,lt.existsSync)((0,St.join)(e,"node_modules"))||(0,lt.mkdirSync)((0,St.join)(e,"node_modules")),(0,lt.symlinkSync)(pP.PACKAGE_ROOT,u,"dir"))}catch(p){sf.default.error("Error symlinking harperdb module",p)}let f=rA,d=n;for(let p in c){rA=p;let _=c[p];if(of.set(n?p:(0,St.basename)(e),!1),!_)continue;let h,S=_.package;try{if(S){let b=e,v;for(;!(0,lt.existsSync)(v=(0,St.join)(b,"node_modules",p));)if(b=(0,St.dirname)(b),b.length<(0,hP.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=lTe[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(Yl.isMainThread&&(h=await h.startOnMainThread?.({server:Ye,ensureTable:g,port:T,securePort:E,resources:t,..._})||h,n&&R))for(let b of[T,E])try{if(+b&&!oj.includes(b)){let v=gP.get(B.HTTP_SESSIONAFFINITY);v&&sf.default.warn("Session affinity is not recommended and may cause memory leaks"),(v||!ET)&&(oj.push(b),QC(b,v))}}catch(v){console.error("Error listening on socket",b,v,p)}if(t.isWorker&&(h=await h.start?.({server:Ye,ensureTable:g,port:T,securePort:E,resources:t,..._})||h),mP.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 b=(0,St.join)(e,_.files).replace(/\\/g,"/"),v=b.indexOf("/*");if(v>-1&&_.files!==EP[p]?.files&&!(0,lt.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(Yl.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,aj.default)(b,{onlyFiles:!1,objectMode:!0})){let{path:J,dirent:he}=ne;d=!0;let Re=(0,St.relative)(e,J).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=q+(q.endsWith("/")?"":"/")+Re;try{if(he.isFile()){let me=await cTe(J);Yl.isMainThread&&await h.setupFile?.(me,Ce,J,t),t.isWorker&&await h.handleFile?.(me,Ce,J,t)}else Yl.isMainThread&&await h.setupDirectory?.(Ce,J,t),t.isWorker&&await h.handleDirectory?.(Ce,J,t)}catch(me){me.message=`Could not load ${he.isFile()?"file":"directory"} '${J}'${_.module?" using '"+_.module+"'":""} for application '${e}' due to: ${me.message}`,Ph?.(me),((0,af.getWorkerIndex)()===0?console:sf.default).error(me),t.set(_.path||"/",new ga(me)),of.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,af.getWorkerIndex)()===0?console:sf.default).error(g),t.set(_.path||"/",new ga(g),null,!0),of.set(n?p:(0,St.basename)(e),g.message)}}if(rA=f,Yl.isMainThread&&!lj&&i&&(0,af.watchDir)(e,async()=>uj()),c.extensionModule){let p=await zE((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,af.getWorkerIndex)()===0?console:sf.default).error(p),of.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 lt,St,Yl,_P,gP,pP,aj,af,sf,cj,hP,aTe,sA,cTe,dP,mP,lj,fP,of,lTe,EP,oj,tA,Ph,rA,dTe,jp=be(()=>{lt=require("fs"),St=require("path"),Yl=require("worker_threads"),_P=require("yaml"),gP=M(ae()),pP=M(st());H();BL();TM();jB();ZB();eH();xH();EY();yY();OY();aj=M(require("fast-glob")),af=M(et()),sf=M(z());iO();Vr();cj=M(pe());Pe();xC();hP=M(ae()),aTe=M(kz());MS();Wz();Xn();ij();sA=M(yt());XI();gR();({readFile:cTe}=lt.promises),dP=(0,sA.resolvePath)(gP.get(B.COMPONENTSROOT)),mP=new Map,of=new Map;a(uj,"loadComponentDirectories");lTe={REST:eg,rest:eg,graphql:BR,graphqlSchema:AR,roles:sO,jsResource:aO,fastifyRoutes:YI,login:lO,static:WI,operationsApi:aTe,customFunctions:{},http:{},clustering:sP,replication:wo,authentication:Gp,mqtt:uP,loadEnv:zI},EP={rest:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(EP,"static",{value:{files:"web/**"}});oj=[],tA=new Map;a(uTe,"setErrorReporter");dTe=a(()=>rA,"getComponentName");a(nA,"loadComponent")});var qT=w((O0e,fj)=>{var{isMainThread:dj}=require("worker_threads"),{getTables:fTe,getDatabases:y0e,table:b0e}=(Pe(),C(tt)),{loadComponentDirectories:_Te,loadComponent:pTe}=(jp(),C(zp)),{resetResources:hTe}=(Su(),C(ML)),mTe=qw(),ETe=yt(),{dirname:gTe}=require("path"),{getConnection:STe}=ir(),TTe=ae(),{CONFIG_PARAMS:ATe}=(H(),C(G)),{loadCertificates:RTe}=Zn(),SP=new Map;async function yTe(e=!1){!dj&&TTe.get(ATe.CLUSTERING_ENABLED)&&STe();try{dj&&await mTe()}catch(n){console.error(n)}let t=hTe();fTe(),t.isWorker=e,await RTe(),await pTe(gTe(ETe.getConfigFilePath()),t,"hdb",!0,SP),await _Te(SP,t);let r=[];for(let[n]of SP)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(yTe,"loadRootComponents");fj.exports.loadRootComponents=yTe});var et=w((w0e,Si)=>{"use strict";rm();var{Worker:bTe,MessageChannel:OTe,parentPort:Zi,isMainThread:bP,threadId:NTe,workerData:eo}=require("worker_threads"),{PACKAGE_ROOT:wTe}=st(),{join:mj,isAbsolute:ITe,extname:CTe}=require("path"),{server:Ej}=(Vr(),C(Tu)),{watch:PTe,readdir:DTe}=require("fs/promises"),{totalmem:_j}=require("os"),cf=(H(),C(G)),gj=ae(),gi=z(),{randomBytes:LTe}=require("crypto"),{_assignPackageExport:MTe}=Ti(),pj=1024*1024,dc=[],Hs=[],vTe=50,OP=1e4,UTe="restart",Sj="request_thread_info",Tj="resource_report",Aj="thread_info",Rj="added-port",xTe="ack",TP;MTe("threads",Hs);Si.exports={startWorker:AP,restartWorkers:wP,shutdownWorkers:GTe,workers:dc,setMonitorListener:jTe,onMessageFromWorkers:qTe,onMessageByType:Cj,broadcast:VTe,broadcastWithAcknowledgement:YTe,setChildListenerByType:FTe,getWorkerIndex:yj,getWorkerCount:bj,getTicketKeys:Nj,setMainIsWorker:HTe,setTerminateTimeout:BTe,restartNumber:eo?.restartNumber||1};Hs.onMessageByType=Cj;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 NP;function BTe(e){OP=e}a(BTe,"setTerminateTimeout");function yj(){return eo?eo.workerIndex:NP?0:void 0}a(yj,"getWorkerIndex");function bj(){return eo?eo.workerCount:NP?1:void 0}a(bj,"getWorkerCount");function HTe(e){NP=e,Si.exports.threadsHaveStarted()}a(HTe,"setMainIsWorker");var Oj=1,iA;function Nj(){return iA||(iA=bP?LTe(48):eo.ticketKeys,iA)}a(Nj,"getTicketKeys");Object.defineProperty(Ej,"workerIndex",{get(){return yj()}});Object.defineProperty(Ej,"workerCount",{get(){return bj()}});var wj={[Sj](e,t){WTe(t)},[Tj](e,t){zTe(t,e)}};function AP(e,t={}){let r=process.constrainedMemory?.()||_j();r=Math.min(r,_j(),2e4*pj);let n=gj.get(cf.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 Hs){let u=new OTe;u.existingPort=l,i.push(u),o.push(u.port2)}CTe(e)||(e+=".js");let c=new bTe(ITe(e)?e:mj(wTe,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:Si.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=()=>AP(e,t),c.on("error",l=>{gi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{dc.splice(dc.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<vTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,AP(e,t)):gi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{wj[l.type]?.(l,c)}),dc.push(c),QTe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(AP,"startWorker");var kTe=[cf.THREAD_TYPES.HTTP];async function wP(e=null,t=Math.max(Oj>3,1),r=!0){if(bP){try{process.chdir(process.cwd())}catch(o){gi.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=qT();await o()}Si.exports.restartNumber++,t<1&&(t=t*dc.length);let n=[],s=[];for(let o of dc.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=kTe.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()},OP*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}=Wa();r&&(e==="http"||!e)&&gj.get(cf.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Zi.postMessage({type:UTe,workerType:e})}a(wP,"restartWorkers");function FTe(e,t){wj[e]=t}a(FTe,"setChildListenerByType");function GTe(e){return wP(e,1/0,!1)}a(GTe,"shutdownWorkers");var Ij=[];function qTe(e){Ij.push(e)}a(qTe,"onMessageFromWorkers");var RP=new Map;function Cj(e,t){let r=RP.get(e);r||RP.set(e,r=[]),r.push(t)}a(Cj,"onMessageByType");var $Te=10;async function VTe(e,t){let r=0;for(let n of Hs)try{n.postMessage(e),r++>$Te&&(r=0,await new Promise(setImmediate))}catch(s){gi.error("Unable to send message to worker",s)}t&&Dj(e,null)}a(VTe,"broadcast");var oA=new Map,KTe=1;function YTe(e){return new Promise(t=>{let r=0;for(let n of Hs)try{let s=KTe++,i=a(()=>{oA.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,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){gi.error("Unable to send message to worker",s)}r===0&&t()})}a(YTe,"broadcastWithAcknowledgement");function WTe(e){e.postMessage({type:Aj,workers:Pj()})}a(WTe,"sendThreadInfo");function Pj(){let e=Date.now();return dc.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 zTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(zTe,"recordResourceReport");var yP;function jTe(e){yP=e}a(jTe,"setMonitorListener");var JTe=1e3,hj=!1;function QTe(){hj||(hj=!0,setInterval(()=>{for(let e of dc){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}yP&&yP()},JTe).unref())}a(QTe,"startMonitoring");var XTe=1e3;if(Zi&&eo?.addPorts){aA(Zi);for(let e=0,t=eo.addPorts.length;e<t;e++){let r=eo.addPorts[e];r.threadId=eo.addThreadIds[e],aA(r)}setInterval(()=>{let e=process.memoryUsage();Zi.postMessage({type:Tj,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},XTe).unref(),TP=a(()=>new Promise((e,t)=>{Zi.on("message",r),Zi.postMessage({type:Sj});function r(n){n.type===Aj&&(Zi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else TP=Pj;Si.exports.getThreadInfo=TP;function aA(e,t){Hs.push(e),e.on("message",r=>{if(r.type===Rj)r.port.threadId=r.threadId,aA(r.port);else if(r.type===xTe){let n=oA.get(r.id);n&&n()}else Dj(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(aA,"addPort");function Dj(e,t){for(let n of Ij)n(e,t);let r=RP.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){gi.error(s)}}a(Dj,"notifyMessageListeners");if(bP){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await DTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(mj(s,o.name));try{for await(let{filename:o}of PTe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await wP(),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",NTe),process.exit(0)},OP).unref())})});var pB={};ve(pB,{ACTION_32_BIT:()=>Wm,ACTION_64_BIT:()=>tAe,AUDIT_STORE_OPTIONS:()=>xp,Decoder:()=>hl,HAS_BLOBS:()=>Fn,HAS_CURRENT_RESIDENCY_ID:()=>Uc,HAS_EXPIRATION_EXTENDED_TYPE:()=>n_,HAS_ORIGINATING_OPERATION:()=>r_,HAS_PREVIOUS_RESIDENCY_ID:()=>xc,REMOTE_SEQUENCE_UPDATE:()=>Mg,createAuditEntry:()=>Ou,getLastRemoved:()=>SN,openAuditStore:()=>uA,readAuditEntry:()=>wt,removeAuditEntry:()=>dA,setAuditRetention:()=>eAe,transactionKeyEncoder:()=>Fj});function uA(e){let t=e.auditStore=e.openDB(IP.AUDIT_STORE_NAME,{create:!1,...xp});t||(t=e.auditStore=e.openDB(IP.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=PP;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()-CP/(1+i*i)})){try{p=dA(t,h,S)}catch(g){lf.warn("Error removing audit entry",g)}if(_=h,await new Promise(setImmediate),++d>=ZTe){o=10;break}}await p}finally{d===0?o=Math.min(o<<1,CP/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,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 dA(e,t,r){let n=rAe(r),s;if(n&Fn){s=wt(r);let i=e.tableStores[s.tableId],o=i.getEntry(s.recordId);(!o||o.version!==s.version||!o.value)&&Pc(()=>Ta(s.getValue(i)),i.rootStore)}if((n&15)===DP){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){LP[0]=t,e.put(Symbol.for("last-removed"),Gj)}function SN(e){let t=e.get(Symbol.for("last-removed"));if(t)return Gj.set(t),LP[0]}function eAe(e,t=PP){CP=e,PP=t}function Ou(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?fc.setFloat64(0,n):ks.set(WR),h=9),l){if(l&255)throw new Error("Illegal extended type");h+=3}R(s),R(t),g(r),fc.setFloat64(h,e),h+=8,l&Uc&&R(u),l&xc&&R(f),l&n_&&(fc.setFloat64(h,d),h+=8),l&r_&&R($j[p]),i?g(i):ks[h++]=0,l?fc.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,Wl.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),fc.setUint16(T,b|32768),h++):ks[T]=b}function R(E){E<128?ks[h++]=E:E<16384?(fc.setUint16(h,E|32768),h+=2):E<1056964608?(fc.setUint32(h,E|3221225472),h+=4):(ks[h]=255,fc.setUint32(h+1,E),h+=5)}}function rAe(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&Uc&&(p=n.readInt()),i&xc&&(_=n.readInt()),i&n_&&(h=n.readFloat64()),i&r_){let T=n.readInt();S=$j[T]}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(T,b,v){if(i&cA||i&Dh&&!b)return E||(E=Pc(()=>T.decoder.decode(e.subarray(n.position,r)),T.rootStore)),E;if(i&Dh&&v)return $b(T.getEntry(this.recordId),v,T)},getBinaryValue(){return i&(cA|Dh)?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 Wl,lA,IP,Lh,kj,lf,ks,fc,Fj,xp,CP,ZTe,LP,Gj,PP,Lj,cA,Dh,vj,DP,Uj,xj,Bj,Hj,Wm,tAe,Mg,Uc,xc,r_,n_,Fn,qj,$j,hl,fo=be(()=>{Wl=require("ordered-binary"),lA=M(ae()),IP=M(Ut());H();Lh=M(et()),kj=M(ie());Nu();lf=M(z());UE();gs();vT();(0,lA.initSync)();ks=Buffer.alloc(2816),fc=new DataView(ks.buffer,ks.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},CP=(0,kj.convertToMS)((0,lA.get)(B.LOGGING_AUDITRETENTION))||86400*3,ZTe=1e3,LP=new Float64Array(1),Gj=new Uint8Array(LP.buffer),PP=1e4,Lj=!1;a(uA,"openAuditStore");a(dA,"removeAuditEntry");a(Mj,"updateLastRemoved");a(SN,"getLastRemoved");a(eAe,"setAuditRetention");cA=16,Dh=32,vj=1,DP=2,Uj=3,xj=4,Bj=5,Hj=6,Wm=14,tAe=15,Mg=11,Uc=512,xc=1024,r_=2048,n_=4096,Fn=8192,qj={put:vj|cA,[vj]:"put",delete:DP,[DP]:"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(Ou,"createAuditEntry");a(rAe,"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 UP(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Kj,nAe(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 vP(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,MP.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,MP.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 nAe(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||(UP({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),Wj(e)),e.nextTransaction}var MP,Vj,Kj,vP,TN=be(()=>{MP=M(z());_u();Su();fo();Vj=Object.create(null),Kj=Object.create(null);a(UP,"addSubscription");vP=class extends xn{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(nAe,"listenToCommits");a(Wj,"nextTransaction");a(BF,"whenNextTransaction")});var wI={};ve(wI,{EVICTED:()=>ma,INVALIDATED:()=>Bn,coerceType:()=>pA,makeTable:()=>mA,setServerUtilities:()=>dAe});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 T=JR(i,n,l),b,v,F={},q=Promise.resolve(),Y,Z,se;for(let K of E)(K.assignCreatedTime||K.name==="__createdtime__")&&(Y=K),(K.assignUpdatedTime||K.name==="__updatedtime__")&&(Z=K),K.expiresAt&&(se=K),K.isPrimaryKey&&(F=K);let Q,ne=[],J=[],he=1,Re=2,Ce={},me={},Zt=864e5,ut=0,yr,hs,vn,nu=!1,su,BA=new Map,HA=new Map,Mt,Ef,jh=jl.get(B.REPLICATION_DATABASES);if(Array.isArray(jh)){for(let K of jh)if(K.name===c&&K.replicateTo>=0){Ef=K.replicateTo;break}}let Jh=i.getRange({start:!1,end:!1}).constructor,gf=10,Qh=6;g&&Af(),Ah(i.env.path,K=>{if(v)return aa(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=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,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 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");Ce={put:O("put"),patch:O("patch"),delete:O("delete"),publish:O("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===bf&&(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]],te=f.get(fe),W=te?.nodes;W||(W=[]);for(let Ae of U.remoteNodeIds.slice(1)){let ye=W.find(dt=>dt.id===Ae);W=W.filter(dt=>dt.id!==Ae||dt===ye),ye||(ye={id:Ae,seqId:0},W.push(ye)),ye.seqId=Math.max(te?.seqId??1,U.localTime),Ae===oe?.nodeId&&(ye.lastTxnTime=U.timestamp)}let _e=Math.max(te?.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 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"}),vh.signalSchemaChange(new Uh.SchemaEventMsg(process.pid,Kt.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,A,I){let y=super.getResource(m,A,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 O=!I?.async||i.cache?.get?.(m),P=Fr(A),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,A,{transaction:N,ensureLoaded:I?.ensureLoaded},O,L=>{if(L?De._updateResource(y,L):y.#e=null,A.onlyIfCached&&A.noCacheStore){if(!y.doesExist())throw new wr.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,BP(k,D=>(De._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,BP(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(!Mt){let O=i.getEntry(Symbol.for("id_allocation")),P=O?.value,N;if(P&&P.nodeName===server.hostname&&(!_Ae(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;Mt=new BigInt64Array([BigInt(N)+1n]),Mt=new BigInt64Array(i.getUserSharedBuffer("id",Mt.buffer)),Mt.maxSafeId=P.end}let A=Number(Atomics.add(Mt,0,1n)),I=m==="Int"?512:1048576;if(A+I>=Mt.maxSafeId){let O=a(P=>{Mt.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(Mt[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(Mt.maxSafeId<N){if(D.end>Mt.maxSafeId-100)return;xe.default.info?.("New id allocation",A,Mt.maxSafeId,x),i.put(Symbol.for("id_allocation"),{start:D.start,end:Mt.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 ${Mt.maxSafeId}, but id of ${N} detected`);let $=y(x);$.alreadyUpdated||Atomics.store(Mt,0,BigInt($.start+1)),Mt.maxSafeId=$.end}},"updateEnd");A+I===Mt.maxSafeId?setImmediate(O):A+100>=Mt.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(()=>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,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)==O?(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,aa()}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,A){if(De.getResidencyById)return De.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(),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&Fn&&m.value&&Ta(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,Kt.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||nu&&O){if(A||(A={}),O){let P=y?.length>0&&xP(y,"read");A.select=O.map(N=>{let L=N.name||N;if(!P||P[L]){let k=vn[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&&!vn[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=xP(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=xP(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(!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&&(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===jj?this.set(m,(+this.getProperty(m)||0)+A):(this.#s||this.update(),this.set(m,new HE(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();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(!(ia(P,N,A?.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()}`),T(y,m,this.#r,P,Bn,g,{user:I?.user,residencyId:A?.residencyId,nodeId:A?.nodeId},"invalidate")}},"commit")})}_writeRelocate(m){let A=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,A,I),beforeIntermediate:me.relocate?.bind(this,A,I),commit:a((O,P)=>{if(ia(O,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=Bn}else k=D;xe.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=lu(this.getResidency(A.value,I)),O;if(y){if(!y.includes(server.hostname))return;O=uu(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);vc(i,O??i.getEntry(m),I)}}lock(){throw new Error("Not yet implemented")}static operation(m,A){return m.table||=s,m.schema||=c,nJ.operation(m,A)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,A,I){let y=this.getContext(),O=Fr(y),P=this.getId();Ir(P);let N=this.#r;this.#s=A?jj:cAe;let L={key:P,store:i,entry:N,nodeName:y?.nodeName,validate:a(k=>{m||(m=this.#t),A||m&&xE(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=el(m))):O.removeWrite(L)},"validate"),before:A?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:A?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");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,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 dt=l.get(_e);if(!dt)break;let rt=wt(dt);if(Ae=rt.version,Ae>=k){if(Ae===k){if(U=ia(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((dt,rt)=>dt.version-rt.version);for(let dt of ye){let rt=dt.getValue(i);if(j=vE(j,rt,A),xe.default.debug?.("Rebuilding update with future patch:",j),!j)return}}else{if(A)return;j=vE(j,$,A),xe.default.debug?.("Rebuilding update without audit:",j)}let ce;if(A?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)}A||(ue=m);let te=y?.expiresAt??(h?h+Date.now():-1);xe.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?Bn: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 De.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this.#e?this._writeDelete(m):!1}_writeDelete(m){let A=Fr(this.getContext()),I=this.getId();Ir(I);let y=this.getContext();return A.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((O,P,N)=>{let L=P?.value;N&&(y&&P?.version>(y.lastModified||0)&&(y.lastModified=P.version),De._updateResource(this,P)),!(ia(O,P,m?.nodeId)<=0)&&(ln(this.getId(),L),xe.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()):vc(i,P))},"commit")}),!0}search(m){let A=this.getContext(),I=Fr(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 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 dt=ye[0]??ye.attribute,rt=dt==null?F:bi(E,dt);if(rt)(rt.type||_R[ye.comparator])&&(ye[1]===void 0?ye.value=k(ye.value,rt):ye[1]=k(ye[1],rt));else if(dt!=null)throw(0,wr.handleHDBError)(new Error,`${dt} 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,Je;if(Gr.comparator==="gt"||Gr.comparator==="greater_than"||Gr.comparator==="ge"||Gr.comparator==="greater_than_equal"?(Ee=ye,Je=Gr):(Ee=Gr,Je=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=Je.comparator==="ge"||Je.comparator==="greater_than_equal",$t=Ee.comparator==="le"||Ee.comparator==="less_than_equal";ye.comparator=(nt?"ge":"gt")+($t?"le":"lt"),ye.value=[Je.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,tJ.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(O=y.find(_e=>Eu(_e.attribute)===Eu(W)),!O){let _e=bi(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)O={attribute:W,comparator:"sort"},y.push(O);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)}O&&(O.descending=!!x.descending)}y=L(y,D),x&&(O&&y[0]===O?x.next&&($={dbOrderedAttribute:x.attribute,attribute:x.next.attribute,descending:x.next.descending,next:x.next.next}):(O&&y.splice(y.indexOf(O),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=pR(y,D,De,oe,m,A,(W,_e)=>au(W,j,A,oe,_e),P),ue=m.ensureLoaded!==!1;$||(U=te(U));let ce=De.transformEntryForSelect(j,A,oe,P,ue,!0),fe=De.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(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,A,I,y,O,P){let N=new Jh;if(I){m=au(m,A,y,O,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(te){let W=te.next&&ce(te.next),_e=te.descending;return(Ae,ye)=>{let dt=ou(Ae,te.attribute,y),rt=ou(ye,te.attribute,y),Gr=_e?(0,Jl.compareKeys)(rt,dt):(0,Jl.compareKeys)(dt,rt);return Gr===0?W?.(Ae,ye)||0:Gr}}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 x.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=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](),te=D.next(),te.done?(N.onDone&&N.onDone(),te):{value:await P.call(this,te.value)}},return(){N.onDone&&N.onDone(),x.return()},throw(){N.onDone&&N.onDone(),x.throw()}}};let k=a(D=>{if(typeof A=="object"&&Array.isArray(D.attribute))for(let x=0;x<A.length;x++){let $=A[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]&&(A[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,A,I,y,O,P){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let D=a(x=>(A?.transaction?.stale&&(A.transaction.stale=!1),x?.key??x),"transform");return m===t?D:m.asArray?x=>[D(x)]:x=>({[t]:D(x)})}let N;O&&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(A?.transaction?.stale&&(A.transaction.stale=!1),D!=null){if(x=D.value||D.deref?.()?.value,!x&&(D.key===void 0||D.deref)||D.metadataFlags&Bn){if(D.metadataFlags&Bn&&A.replicateFrom===!1&&P&&D.residencyId)return pc.SKIP;if(D=iu(D.key??D,A,{transaction:I,lazy:m?.length<4,ensureLoaded:O},this?.isSync,$=>$),D?.then)return D.then(k.bind(this));x=D?.value}if(N&&D?.metadataFlags&(Bn|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(x==null)return P?pc.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=vn?.[ce],te;if(fe){let W=y?.[ce];if(W)if(W.hasMappings){let Ae=fe.from?x[fe.from]:Eu(D.key);te=W.get(Ae),te||(te=[])}else te=W.fromRecord?.(x);else te=fe(x,A,D);let _e=a(Ae=>{if(Ae&&typeof Ae=="object"){let ye=fe.definition?.tableClass||De;L||(L={});let dt=L[ce]||(L[ce]=ye.transformEntryForSelect(ce===U?null:U.select||(Array.isArray(U)?U:null),A,I,W,O));if(Array.isArray(Ae)){let rt=[],Gr=ye.transformToOrderedSelect(Ae,U.select,typeof U.sort=="object"&&U.sort,A,I,dt)[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"),Je=Ee(Gr.next());Je&&($||($=[]),$.push(Je));return}else if(Ae=dt.call(this,Ae),Ae?.then){$||($=[]),$.push(Ae.then(rt=>ue(rt,ce)));return}}ue(Ae,ce)},"handleResolvedValue");te?.then?($||($=[]),$.push(te.then(_e))):_e(te);return}else te=x[ce],te&&typeof te=="object"&&ce!==U&&(te=De.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]=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||ft({table:s,database:c,schemaDefined:u,attributes:E,audit:!0}),m||(m={});let A=!m.rawEvents,I=[],y=this,O=UP(De,this.getId()??null,function(N,L,k,D){try{let x=L.getValue?.(i,A),$=L.type;if(!x&&$==="patch"&&A){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&&(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 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,A,D);if(O.send({id:j,localTime:D,value:oe,version:$.version,type:$.type}),O.queue?.length>Qj&&await O.waitForDrain()===!1)return}O.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,A,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;)O.send(D[--x]);D[0]&&(O.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,Jl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(x&&(O.send({id:D,localTime:j,value:x,version:$,type:"put"}),O.queue?.length>Qj&&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),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,A,$);A&&(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;)O.send(x[--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=Fr(this.getContext()),y=this.getId()||null;y!=null&&Ir(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:Ce.publish?.bind(this,O,y,m),beforeIntermediate:me.publish?.bind(this,O,y,m),commit:a((P,N,L)=>{N===void 0&&R&&!g&&aa(),xe.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 x=L[k],$=y(O[x.name],x,N+"."+x.name);$&&(O[x.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],x=y(D,P.elements,N+"[*]");x&&(O[L]=x)}}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 wr.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 wr.ClientError("Attribute name is required");if(I.name.match(/[`/]/))throw new wr.ClientError("Attribute names cannot include backticks or forward slashes");(0,rJ.validateAttribute)(I.name),A.push(I)}return ft({table:s,database:c,schemaDefined:u,attributes:A}),De.indexingOperation}static async removeAttributes(m){let A=E.filter(I=>!m.includes(I.name));return ft({table:s,database:c,schemaDefined:u,attributes:A}),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,A=_A.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 _c(),!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 _c();let x=k*2,$=(N+D)/x,j=Math.pow((N-D+1)/k/2,2)+$*(1-$)/x,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(){vn=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)"),nu=!0,A.to)m.elements?.definition?(vn[m.name]=m.resolve=(y,O,P)=>{let N=y[A.from?A.from:t],L=m.elements.definition.tableClass;return P?mu({attribute:A.to,value:N},Fr(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?(vn[m.name]=m.resolve=(O,P,N)=>{let L=O[A.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 A.filterMissing?k?Promise.all(D).then(x=>x.filter(eJ)):D.filter(eJ):k?Promise.all(D):D}return N?y.tableClass.primaryStore.getEntry(L,{transaction:Fr(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),vn[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);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]=()=>{}})}kE(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 _c(),wt(O).tableId===n&&(I=dA(l,y,O));if(A)for(let y of i.getRange({start:0,versions:!0})){let{key:O,value:P,localTime:N}=y;await _c(),P===null&&N<m&&(I=vc(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 _c();let O=wt(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 _c();let P=l.get(y);if(P){let N=wt(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()}}De.updatedAttributes();let Sf=De.prototype;return h&&De.setTTLExpiration(h/1e3),se&&cu(),De;function ln(K,m,A){let I;for(let y in r){let O=r[y],P=O.isIndexing,N=vn[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,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}));O.prefetch(oe,Xj)}for(let oe=0,U=$.length;oe<U;oe++)O.remove($[oe],K)}else x?.length>0&&zj&&O.prefetch(x.map(j=>({key:j,value:K})),Xj);if(x)for(let j=0,oe=x.length;j<oe;j++)O.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>Jj)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,Jl.writeKey)(K,lAe,0)>Jj)throw new Error("Primary key size is too large: "+K.length);return!0}a(Ir,"checkValidId");function iu(K,m,A,I,y){if(De.getResidencyById&&A.ensureLoaded&&m?.replicateFrom!==!1){let P=lu(De.getResidencyById(K));if(P&&!P.includes(server.hostname)&&b)return b({key:K,residency:P}).then(y)}let O=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),A.transaction?.isDone)return y(null,K);let P=i.getEntry(K,A);return P?.residencyId&&P.metadataFlags&Bn&&b&&A.ensureLoaded&&m?.replicateFrom!==!1?b(P).then(N=>y(N,K),N=>(xe.default.error?.("Error loading remote record",K,P,A,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?O():he>0?(he--,O()):new Promise((P,N)=>{he===0?(he--,i.prefetch([K],()=>{L(),k()})):(ne.push(K),J.push(k),ne.length>Qh&&(he--,L()));function L(){if(ne.length>0){let D=J;i.prefetch(ne,()=>{he===-1?L():he++;for(let x of D)x()}),ne=[],J=[],Re>2&&Re--}else he=Re,Re<gf&&Re++}a(L,"prefetch");function k(){try{P(O())}catch(D){N(D)}}a(k,"load")})}a(iu,"loadLocalRecord");function Tf(K){if(!K?.role)return;let m=K.role.permission;if(m.super_user)return uAe;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(K,m,A,I){if(v){let y=!1;if(A.noCache?y=!0:(m?(!m.value||m.metadataFlags&(Bn|ma)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(y=!0):y=!0,Qn(!y,"cache-hit",s)),y){let O=Xh(K,m,A).then(P=>(P?.value&&P?.value.getRecord?.()&&xe.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,K)){if(O.catch(P=>xe.default.warn?.(P)),A?.onlyIfCached&&!I.doesExist())throw new wr.ServerError("Entry is not cached",504);return}else return O}}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 A=m.next;if(!A)return m=m.next=new yc,m.lmdbDb=i,m;m=A}while(!0)}else return new Tm}a(Fr,"txnForContext");function ou(K,m,A){if(!K)return;let I=K.value||i.getEntry(K.key)?.value;if(typeof m=="object"){let O=vn,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=vn[m];return y?y(I,A):I[m]}a(ou,"getAttributeValue");function au(K,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 x=k?.value;if(!x)return pc.SKIP;for(let $=0;$<O;$++)if(!N?.includes($)&&!y[$](x,k))return pc.SKIP;return D!==void 0&&(k.key=D),k}if(a(L,"processEntry"),O>0||!K.hasEntries){let k=K.map(D=>{if(N=null,typeof D=="object"&&D?.key!==void 0)return O>0?L(D):D;if(D==null)return pc.SKIP;for(let x=0;x<O;x++){let j=y[x].idFilter;if(j){if(!j(D))return pc.SKIP;N||(N=[]),N.push(x)}}return iu(D,A,P,!1,L)});return Array.isArray(K)&&(k=k.filter(D=>D!==pc.SKIP)),k.hasEntries=!0,k}return K}a(au,"transformToEntries");function ia(K,m,A=server.replication?.getThisNodeId(l)){if(K<=m?.version){if(m?.version===K&&A!==void 0){let I=server.replication?.exportIdMapping(l),y=m.localTime,O=y&&l.get(y);if(O){let P,N,L=wt(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 Xh(K,m,A){let I=m?.metadataFlags,y=m?.version,O,P;if(!i.attemptLock(K,y,()=>{clearTimeout(P);let D=i.getEntry(K);!D||!D.value||D.metadataFlags&(Bn|ma)?O(Xh(K,i.getEntry(K),A)):O(D)}))return new Promise(D=>{O=D,P=setTimeout(()=>{i.unlock(K,y)},aAe)});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,x)=>{let $;BP(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&Bn;let te=L.lastModified||ce&&y;ue=ce||te>y||!N,te||(te=(0,Mh.getNextMonotonicTime)());let W=performance.now()-oe;if(sr(W,"cache-resolution",s,null,"success"),k&&XE(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 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:te,value:U})}catch(te){te.message+=` while resolving record ${K} 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:K,version:y,value:N}),xe.default.trace?.(te.message,"(returned stale record)")):x(te);let W=performance.now()-oe;sr(W,"cache-resolution",s,null,"fail"),k&&XE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),L.transaction.abort();return}if(A?.noCacheStore||L.noCacheStore){L.transaction.abort();return}Fr(L).addWrite({key:K,store:i,entry:m,nodeName:"source",commit:a((te,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(te).toISOString()}`),T(K,U,W,te,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(te).toISOString()}`),g||R?T(K,null,W,te,0,g&&ue||null,{user:L?.user},"delete",!!ce):vc(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 oa(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(oa,"checkContextPermissions");function aa(K){let m=!1;if(K&&(K-ut>1&&(m=!0),ut=K),!(Zt===yr&&!m)&&(yr=Zt,(0,zl.getWorkerIndex)()===(0,zl.getWorkerCount)()-1))return hs&&clearTimeout(hs),Zt?new Promise(A=>{let I=new Date;I.setMonth(0),I.setDate(1),I.setHours(0),I.setMinutes(0),I.setSeconds(0);let y=Zt/(1+ut),O=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)}`),hs=setTimeout(()=>q=q.then(async()=>{if(P(Math.max(N+Zt,Date.now())),i.rootStore.status!=="open"){clearTimeout(hs);return}let L=50,k=new Array(L),D=0,x=Math.pow(ut,8)*(jl.get(B.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),$=S/Math.pow(Math.max(ut,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(ut){let te=i.lastSize;return ue&Fn&&Ru(ce,W=>{W.size&&(te+=W.size)}),xe.default.trace?.(`shouldEvict adjusted ${fe} ${te}, ${fe*(oe-U)/te} < ${x}`),fe*(oe-U)/te<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:te,metadataFlags:W}=U,_e;ce===null&&!g&&fe+oAe<Date.now()?_e=vc(i,U,fe):te!=null&&j(te,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 _c()}xe.default.info?.(`Finished cleanup scan for ${s}, evicted ${oe} entries`)}catch(oe){xe.default.warn?.(`Error in cleanup scan for ${s}:`,oe)}A(void 0),ut=0}),Math.min(N-Date.now(),2147483647)).unref()},"startNextTimer");P(O)}):void 0}a(aa,"scheduleCleanup");function Af(){Q=l?.addDeleteRemovalCallback(n,i,(K,m)=>{i.remove(K,m)})}a(Af,"addDeleteRemoval");function cu(){(0,zl.getWorkerIndex)()===0&&setInterval(async()=>{if(!su){su=!0;try{let K=se.name,m=r[K];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[K]<Date.now()&&De.evict(I,y.value,y.version):i.ifVersion(I,y?.version,()=>m.remove(A,I))}await _c()}}catch(K){xe.default.error?.("Error in evicting old records",K)}finally{su=!1}}},iAe).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(A=>A.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(","),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],K),A)}}a(uu,"getResidencyId")}function xP(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 dAe(e){nJ=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;fAe.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 BP(e,t,r){return e?.then?e.then(t,r):t(e)}function eJ(e){return e!=null}function Fs(e){try{return JSON.stringify(e)}catch{return e}}function _Ae(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var pc,Mh,tJ,rJ,jl,wr,vh,Uh,xe,Jl,zl,hA,_A,sAe,nJ,iAe,oAe,zj,aAe,jj,cAe,Bn,ma,lAe,Jj,Qj,uAe,sxe,fAe,_c,qf=be(()=>{H();pc=require("lmdb"),Mh=M(_n()),tJ=require("lodash"),rJ=M(xf());Ea();Am();jl=M(ae());TN();wr=M(pe()),vh=M(To()),Uh=M(ri());Pe();Gf();xe=M(Ni());Yb();bc();Jl=require("ordered-binary"),zl=M(et());fo();hA=M(ie());Nu();ki();UE();z_();_A=M(require("node:fs"));gs();vT();sAe=new Uint8Array(9);sAe[8]=192;iAe=6e4,oAe=864e5;jl.initSync();zj=jl.get(B.STORAGE_PREFETCHWRITES),aAe=1e4,jj=1,cAe=2,Bn=1,ma=8,lAe=Buffer.allocUnsafeSlow(8192),Jj=1978,Qj=100,uAe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},sxe=(0,hA.convertToMS)(jl.get(B.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(mA,"makeTable");a(xP,"attributesAsObject");a(Xj,"noop");a(dAe,"setServerUtilities");fAe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(pA,"coerceType");a(fA,"rejectNaN");a(Zj,"isDescendantId");_c=a(()=>new Promise(setImmediate),"rest");a(BP,"when");a(eJ,"exists");a(Fs,"stringify");a(_Ae,"hasOtherProcesses")});var tt={};ve(tt,{database:()=>Gu,database_envs:()=>ea,databases:()=>qe,dropDatabase:()=>Qb,dropTableMeta:()=>gAe,getDatabases:()=>Qe,getDefaultCompression:()=>IS,getTables:()=>pAe,onRemovedDB:()=>pp,onUpdatedTable:()=>ml,readMetaDb:()=>xh,resetDatabases:()=>Pd,table:()=>ft,tables:()=>Jn});function pAe(){return TA||Qe(),Jn||{}}function Qe(){if(TA)return qe;TA=!0,ff=new Map;let e=(0,Xt.getHdbBasePath)()&&(0,Dt.join)((0,Xt.getHdbBasePath)(),Rc),t=(0,Xt.get)(B.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Xt.get)(B.STORAGE_PATH)||e&&((0,us.existsSync)(e)?e:(0,Dt.join)((0,Xt.getHdbBasePath)(),im)),!e)return;if((0,us.existsSync)(e))for(let n of(0,us.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,us.existsSync)((0,df.getBaseSchemaPath)())){for(let n of(0,us.readdirSync)((0,df.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Dt.join)((0,df.getBaseSchemaPath)(),n.name),i=(0,Dt.join)((0,df.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,us.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,us.existsSync)(i))for(let c of(0,us.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,us.existsSync)(u)&&xh(u,c,n,null,!0)}}for(let n in qe){let s=ff.get(n);if(s){let i=qe[n];n.includes("delete")&&Gt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Gt.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[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 ff=null,qe}function Pd(){TA=!1;for(let[,e]of ea)e.needsDeletion=!0;Qe();for(let[e,t]of ea)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),ea.delete(e),delete qe[t.databaseName],Hh.forEach(r=>r(t.databaseName)));return qe}function xh(e,t,r=FP,n,s){let i=new HP.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 Ql.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(EA.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=uA(o));let f=aJ(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 J of S)if(J.is_hash_attribute||J.isPrimaryKey){g=J;break}if(!g){Gt.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,Xt.get)(B.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),Gt.info(`Updating next table id (it was out of sync) to ${b+1} for ${_}`)):(g.tableId=b=l.get(uf),b||(b=1),Gt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(uf,b+1),l.putSync(g.key,g));let J=new Ql.default(!g.is_hash_attribute,g.is_hash_attribute);if(J.compression=g.compression,J.compression){let he=(0,Xt.get)(B.STORAGE_COMPRESSION_THRESHOLD)||oJ;J.compression.threshold=he}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 Re=new Ql.default(!J.is_hash_attribute,J.is_hash_attribute);E[J.name]=o.openDB(J.key,Re),E[J.name].indexNulls=J.indexNulls}let he=T.find(Re=>Re.name===J.name);he?T.splice(T.indexOf(he),1,J):T.push(J)}}catch(he){Gt.error("Error trying to update attribute",J,T,E,he)}}if(!R){R=cJ(f,_,mA({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 Bh)J(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function aJ(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[AA]=r,ff.set(e,r)}return t}function cJ(e,t,r){return e[t]=r,r}function Gu({database:e,table:t}){e||(e=FP),Qe();let r=aJ(e),n=(0,Dt.join)((0,Xt.getHdbBasePath)(),Rc),s=(0,Xt.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,Xt.get)(B.STORAGE_PATH)||((0,us.existsSync)(n)?n:(0,Dt.join)((0,Xt.getHdbBasePath)(),im));let o=(0,Dt.join)(n,(i?t:e)+".mdb"),c=ea.get(o);if(!c||c.status==="closed"){let l=new HP.default(o,!1);c=(0,_f.open)(l),ea.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,ea.delete(r.path),r.status==="open"&&(await r.close(),await kh.remove(r.path));if(r||(r=Gu({database:e,table:null}),r.status==="open"&&(await r.close(),await kh.remove(r.path))),e==="data"){for(let n in Jn)delete Jn[n];delete Jn[AA]}delete qe[e],Hh.forEach(n=>n(e)),await wR(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=FP);let h=Gu({database:r,table:t}),S=qe[r];Gt.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 Ql.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(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,Xt.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=[_]),Gt.trace(`${t} table loading, opening primary store`);let ne=new Ql.default(!1,!0);ne.compression=E.compression;let J=t+"/";if(T=h.dbisDb=h.openDB(EA.INTERNAL_DBIS_NAME,b),se(),T.get(J))return F&&F(),Pd(),ft(e);let he=jm(h.openDB(J,ne),h);h.databaseName=r,he.tableId=T.get(uf),Gt.trace(`Assigning new table id ${he.tableId} for ${t}`),he.tableId||(he.tableId=1),T.put(uf,he.tableId+1),E.tableId=he.tableId,g=cJ(S,t,mA({primaryStore:he,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:he.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(EA.INTERNAL_DBIS_NAME,b)),g.dbisDB=T;let Y=[];for(let{key:Q,value:ne}of T.getRange({start:!0})){let[J,he]=Q.toString().split("/");if(he===""&&(he=ne.name),he){if(J!==t)continue}else continue;let Re=o.find(me=>me.name===he),Ce=!Re?.indexed&&ne.indexed&&!ne.isPrimaryKey;if((!Re||Ce)&&(se(),v=!0,Re||T.remove(Q),Ce)){let me=g.indices[J];me&&Y.push(me)}}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 Re={...J};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,se(),T.put(ne,Re)}continue}J?.attribute&&!J.name&&(J.indexed=!0);let he=!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 Re=new Ql.default(!0,!1),Ce=h.openDB(ne,Re);(he||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Fh.workerData?.restartNumber)&&(v=!0,se(),J=T.get(ne),(he||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Fh.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,Ce.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:Ce}),Z.push(Q))),T.put(ne,Q)),J?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),Ce.indexNulls=Q.indexNulls,q[Q.name]=Ce}else he&&(v=!0,se(),T.put(ne,Q))}}finally{F&&F()}if(v&&(g.schemaVersion++,g.updatedAttributes()),Gt.trace(`${t} table loading, running index`),Z.length>0||Y.length>0?g.indexingOperation=EAe(g,Z,Y):v&&gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,v)for(let Q of Bh)Q(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Gt.trace(`${t} table loaded`),g;function se(){F||h.transactionSync(()=>({then(Q){F=Q}}))}a(se,"startTxn")}async function EAe(e,t,r){try{Gt.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,_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,sJ.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,Gt.error(`Error indexing attribute ${g}`,R))}}}),s.then(()=>f--,h=>{f--,Gt.error(h)}),Fh.workerData&&Fh.workerData.restartNumber!==iJ.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>hAe?await s:f>mAe&&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)),Gt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Gt.error("Error in indexing",n)}}function gAe({table:e,database:t}){let r=Gu({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 pp(e){return Hh.push(e),{remove(){let t=Hh.indexOf(e);t>-1&&Hh.splice(t,1)}}}function IS(){let e=(0,Xt.get)(B.STORAGE_COMPRESSION),t=(0,Xt.get)(B.STORAGE_COMPRESSION_DICTIONARY),r=(0,Xt.get)(B.STORAGE_COMPRESSION_THRESHOLD)||oJ,n={startingOffset:32};return t&&(n.dictionary=kh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Xt,EA,_f,Dt,us,df,Ql,HP,kh,kP,sJ,gA,SA,Fh,Gt,iJ,FP,AA,oJ,Jn,qe,uf,Bh,Hh,TA,ea,ff,hAe,mAe,Pe=be(()=>{Xt=M(ae()),EA=M(Ut()),_f=require("lmdb"),Dt=require("path"),us=require("fs"),df=M(gt());qf();Ql=M(s_()),HP=M(i_());H();kh=M(require("fs-extra")),kP=M(Ti()),sJ=M(_n()),gA=M(To()),SA=M(ri()),Fh=require("worker_threads"),Gt=M(z()),iJ=M(et());fo();Nu();gs();FP="data",AA=Symbol("defined-tables"),oJ=((0,Xt.get)(B.STORAGE_PAGESIZE)||4096)-60;(0,Xt.initSync)();Jn=Object.create(null),qe=Object.create(null);(0,kP._assignPackageExport)("databases",qe);(0,kP._assignPackageExport)("tables",Jn);uf=Symbol.for("next-table-id"),Bh=[],Hh=[],ea=new Map;a(pAe,"getTables");a(Qe,"getDatabases");a(Pd,"resetDatabases");a(xh,"readMetaDb");a(aJ,"ensureDB");a(cJ,"setTable");a(Gu,"database");a(Qb,"dropDatabase");a(ft,"table");hAe=1e3,mAe=10;a(EAe,"runIndexing");a(gAe,"dropTableMeta");a(ml,"onUpdatedTable");a(pp,"onRemovedDB");a(IS,"getDefaultCompression")});var ie=w((hxe,RJ)=>{"use strict";var hc=require("path"),_J=require("fs-extra"),Ln=z(),lJ=require("fs-extra"),RA=require("os"),SAe=require("net"),TAe=require("recursive-iterator"),Rr=(H(),C(G)),{PACKAGE_ROOT:AAe}=st(),RAe=sR(),uJ=require("papaparse"),yA=require("moment"),{inspect:yAe}=require("util"),dJ=require("is-number"),pxe=require("lodash"),bAe=require("minimist"),OAe=require("https"),NAe=require("http"),{hdb_errors:bA}=pe(),wAe=/^((\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)))$/,pJ=require("util").promisify(setTimeout),IAe=100,CAe=5,PAe="",DAe=4,fJ={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};RJ.exports={isEmpty:ds,isEmptyOrZeroLength:to,arrayHasEmptyValues:vAe,arrayHasEmptyOrZeroLengthValues:UAe,buildFolderPath:xAe,isBoolean:hJ,errorizeMessage:LAe,stripFileExtension:HAe,autoCast:kAe,autoCastJSON:mJ,autoCastJSONDeep:qP,removeDir:FAe,compareVersions:GAe,isCompatibleDataVersion:qAe,escapeRawValue:$Ae,unescapeValue:VAe,stringifyProps:KAe,timeoutPromise:WAe,isClusterOperation:jAe,getClusterUser:QAe,checkGlobalSchemaTable:JAe,getHomeDir:gJ,getPropsFilePath:YAe,promisifyPapaParse:XAe,removeBOM:SJ,createEventPromise:ZAe,checkProcessRunning:eRe,checkSchemaTableExist:tRe,checkSchemaExists:TJ,checkTableExists:AJ,getStartOfTomorrowInSeconds:rRe,getLimitKey:nRe,isObject:BAe,isNotEmptyAndHasValue:MAe,autoCasterIsNumberCheck:EJ,backtickASTSchemaItems:sRe,isPortTaken:zAe,createForkArgs:iRe,autoCastBoolean:oRe,async_set_timeout:pJ,getTableHashAttribute:aRe,doesSchemaExist:cRe,doesTableExist:lRe,stringifyObj:uRe,ms_to_time:dRe,changeExtension:fRe,getEnvCliRootPath:$P,noBootFile:_Re,httpRequest:pRe,transformReq:hRe,convertToMS:mRe,PACKAGE_ROOT:AAe};function LAe(e){return e instanceof Error?e:new Error(e)}a(LAe,"errorizeMessage");function ds(e){return e==null}a(ds,"isEmpty");function MAe(e){return!ds(e)&&(e||e===0||e===""||hJ(e))}a(MAe,"isNotEmptyAndHasValue");function to(e){return ds(e)||e.length===0||e.size===0}a(to,"isEmptyOrZeroLength");function vAe(e){if(ds(e))return!0;for(let t=0;t<e.length;t++)if(ds(e[t]))return!0;return!1}a(vAe,"arrayHasEmptyValues");function UAe(e){if(to(e))return!0;for(let t=0;t<e.length;t++)if(to(e[t]))return!0;return!1}a(UAe,"arrayHasEmptyOrZeroLengthValues");function xAe(...e){try{return e.join(hc.sep)}catch{console.error(e)}}a(xAe,"buildFolderPath");function hJ(e){return ds(e)?!1:e===!0||e===!1}a(hJ,"isBoolean");function BAe(e){return ds(e)?!1:typeof e=="object"}a(BAe,"isObject");function HAe(e){return to(e)?PAe:e.slice(0,-DAe)}a(HAe,"stripFileExtension");function kAe(e){return ds(e)||e===""||typeof e!="string"?e:fJ[e]!==void 0?fJ[e]:EJ(e)===!0?Number(e):wAe.test(e)?new Date(e):e}a(kAe,"autoCast");function mJ(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(mJ,"autoCastJSON");function qP(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=qP(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=qP(r);n!==r&&(e[t]=n)}return e}else return mJ(e)}a(qP,"autoCastJSONDeep");function EJ(e){if(e.startsWith("0.")&&dJ(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&dJ(e))}a(EJ,"autoCasterIsNumberCheck");async function FAe(e){if(to(e))throw new Error(`Directory path: ${e} does not exist`);try{await lJ.emptyDir(e),await lJ.remove(e)}catch(t){throw Ln.error(`Error removing files in ${e} -- ${t}`),t}}a(FAe,"removeDir");function GAe(e,t){if(to(e)){Ln.info("Invalid current version sent as parameter.");return}if(to(t)){Ln.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(GAe,"compareVersions");function qAe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(qAe,"isCompatibleDataVersion");function $Ae(e){if(ds(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($Ae,"escapeRawValue");function VAe(e){if(ds(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(VAe,"unescapeValue");function KAe(e,t){if(ds(e))return Ln.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}!to(n)&&n[0]===";"?r+=" "+n+s+RA.EOL:to(n)||(r+=n+"="+s+RA.EOL)}catch{Ln.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(KAe,"stringifyProps");function gJ(){let e;try{e=RA.homedir()}catch{e=process.env.HOME}return e}a(gJ,"getHomeDir");function YAe(){let e=hc.join(gJ(),Rr.HDB_HOME_DIR_NAME,Rr.BOOT_PROPS_FILE_NAME);return _J.existsSync(e)||(e=hc.join(__dirname,"../","hdb_boot_properties.file")),e}a(YAe,"getPropsFilePath");function WAe(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(WAe,"timeoutPromise");async function zAe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=SAe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(zAe,"isPortTaken");function jAe(e){try{return Rr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Ln.error(`Error checking operation against cluster ops ${t}`)}return!1}a(jAe,"isClusterOperation");function JAe(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(JAe,"checkGlobalSchemaTable");function QAe(e,t){if(ds(t)){Ln.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ds(e)||to(e)){Ln.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){Ln.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Ln.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(QAe,"getClusterUser");function XAe(){uJ.parsePromise=function(e,t,r){return new Promise(function(n,s){uJ.parse(e,{header:!0,transformHeader:SJ,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(XAe,"promisifyPapaParse");function SJ(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(SJ,"removeBOM");function ZAe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Ln.info(`Got cluster status event response: ${yAe(s)}`);try{i.cancel()}catch{Ln.error("Error trying to cancel timeout.")}n(s)})})}a(ZAe,"createEventPromise");async function eRe(e){let t=!0,r=0;do await pJ(IAe*r++),(await RAe.findPs(e)).length>0&&(t=!1);while(t&&r<CAe);if(t)throw new Error(`process ${e} was not started`)}a(eRe,"checkProcessRunning");function tRe(e,t){let r=TJ(e);if(r)return r;let n=AJ(e,t);if(n)return n}a(tRe,"checkSchemaTableExist");function TJ(e){let{getDatabases:t}=(Pe(),C(tt));if(!t()[e])return bA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(TJ,"checkSchemaExists");function AJ(e,t){let{getDatabases:r}=(Pe(),C(tt));if(!r()[e][t])return bA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(AJ,"checkTableExists");function rRe(){let e=yA().utc().add(1,"d").startOf("d").unix(),t=yA().utc().unix();return e-t}a(rRe,"getStartOfTomorrowInSeconds");function nRe(){return yA().utc().format("DD-MM-YYYY")}a(nRe,"getLimitKey");function sRe(e){try{let t=new TAe(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){Ln.error("Got an error back ticking items."),Ln.error(t)}}a(sRe,"backtickASTSchemaItems");function iRe(e){return[e]}a(iRe,"createForkArgs");function oRe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(oRe,"autoCastBoolean");function aRe(e,t){let{getDatabases:r}=(Pe(),C(tt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(aRe,"getTableHashAttribute");function cRe(e){let{getDatabases:t}=(Pe(),C(tt));return t()[e]!==void 0}a(cRe,"doesSchemaExist");function lRe(e,t){let{getDatabases:r}=(Pe(),C(tt));return r()[e]?.[t]!==void 0}a(lRe,"doesTableExist");function uRe(e){try{return JSON.stringify(e)}catch{return e}}a(uRe,"stringifyObj");function dRe(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(dRe,"ms_to_time");function fRe(e,t){let r=hc.basename(e,hc.extname(e));return hc.join(hc.dirname(e),r+t)}a(fRe,"changeExtension");function $P(){if(process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=bAe(process.argv);if(e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a($P,"getEnvCliRootPath");var GP;function _Re(){if(GP)return GP;let e=$P();if($P()&&_J.pathExistsSync(hc.join(e,Rr.HDB_CONFIG_FILE)))return GP=!0,!0}a(_Re,"noBootFile");function pRe(e,t){let r;return e.protocol==="http:"?r=NAe:r=OAe,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(pRe,"httpRequest");function hRe(e){if(!e.schema&&!e.database){e.schema=Rr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(hRe,"transformReq");function mRe(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(mRe,"convertToMS")});var ae=w((wJ,IJ)=>{"use strict";var VP=require("fs-extra"),Xl=require("path"),yJ=require("os"),ERe=require("properties-reader"),qh=z(),Gh=ie(),Me=(H(),C(G)),OA=yt(),gRe="Error initializing environment manager",NA="BOOT_PROPS_FILE_PATH",bJ=!1,SRe={[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(wJ,IJ.exports={BOOT_PROPS_FILE_PATH:NA,getHdbBasePath:TRe,setHdbBasePath:ARe,get:OJ,initSync:yRe,setProperty:Ke,initTestEnvironment:ORe,setCloneVar:bRe});function TRe(){return ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(TRe,"getHdbBasePath");function ARe(e){ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(ARe,"setHdbBasePath");function OJ(e){let t=OA.getConfigValue(e);return t===void 0?ta[e]:t}a(OJ,"get");function Ke(e,t){SRe[e]&&(ta[e]=t),OA.updateConfigObject(e,t)}a(Ke,"setProperty");function RRe(){let e;try{e=Gh.getPropsFilePath(),VP.accessSync(e,VP.constants.F_OK|VP.constants.R_OK),bJ=!0;let t=ERe(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[NA]=e,!0}catch{return qh.trace(`Environment manager found no properties file at ${e}`),!1}}a(RRe,"doesPropFileExist");function yRe(e=!1){try{((bJ||RRe()||Gh.noBootFile())&&!NJ||e)&&(OA.initConfig(e),ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=OA.getConfigValue(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){qh.error(gRe),qh.error(t),console.error(t),process.exit(1)}}a(yRe,"initSync");var NJ=!1;function bRe(e){NJ=e}a(bRe,"setCloneVar");function ORe(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");ta[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,yJ.userInfo()?yJ.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,OJ(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(ORe,"initTestEnvironment")});var MJ=w((gxe,LJ)=>{"use strict";var IA=ae();IA.initSync();var wA=(H(),C(G)),{httpRequest:NRe}=ie(),DJ=require("path"),CJ=require("fs-extra"),wRe=require("yaml"),{packageDirectory:IRe}=(Vw(),C($w)),{encode:CRe}=require("cbor-x"),PRe=["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"],PJ={deploy:"deploy_component",package:"package_component"};LJ.exports={cliOperations:MRe,buildRequest:LRe};var DRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await IRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=DJ.basename(t))},"deploy_component")};function LRe(){let e={};for(let t of process.argv.slice(2))if(PRe.includes(t))e.operation=t;else if(PJ.hasOwnProperty(t))e.operation=PJ[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(LRe,"buildRequest");async function MRe(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 CJ.existsSync(DJ.join(IA.get(wA.CONFIG_PARAMS.ROOTPATH),wA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),CJ.existsSync(IA.get(wA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await DRe[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=CRe(e));let n=await NRe(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(wRe.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(MRe,"cliOperations")});var xJ=w((Txe,UJ)=>{"use strict";var vJ=require("semver/functions/major"),{packageJson:vRe}=st(),KP=process.versions&&process.versions.node?process.versions.node:void 0;UJ.exports=URe;function URe(){let e=vRe.engines["minimum-node"];if(KP&&vJ(KP)<vJ(e))return{error:`The minimum version of Node.js HarperDB supports is: ${e}, the currently installed Node.js version is: ${KP}. Please install a version of Node.js that is withing the defined range.`}}a(URe,"checkNodeVersion")});var XP=w((yxe,n2)=>{"use strict";var BJ=require("os"),CA=require("https"),HJ=require("http"),qt=require("fs-extra"),kJ=require("yaml"),{pipeline:FJ}=require("stream/promises"),{createWriteStream:PA,ensureDir:$h,writeFileSync:GJ}=require("fs-extra"),{join:$s}=require("path"),KJ=require("lodash"),xRe=require("minimist"),ra=require("path"),BRe=require("node:crypto"),HRe=require("properties-reader"),qs=ae(),kRe=Po(),jP=z(),DA=yt(),{restart:FRe}=Wa(),LA=ie(),GRe=ua(),qRe=As(),{main:MA,launch:$Re}=Jd(),{install:YJ,updateConfigEnv:VRe,setIgnoreExisting:UA}=CT(),WJ=gC(),an=(H(),C(G)),{packageJson:KRe}=st(),YRe=mh(),{sendOperationToNode:zP}=(Xn(),C(wo)),{updateConfigCert:WRe}=Zn(),{restartWorkers:zRe}=et(),{databases:jRe}=(Pe(),C(tt)),{SYSTEM_TABLE_NAMES:YP,SYSTEM_SCHEMA_NAME:Rxe,CONFIG_PARAMS:Vh,OPERATIONS_ENUM:ps}=an,JRe=1e4,QRe="clone-node-config.yaml",zJ=[YP.ROLE_TABLE_NAME,YP.USER_TABLE_NAME,YP.NODE_TABLE_NAME],XRe={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"},sa=xRe(process.argv),pf=sa[kr.HDB_LEADER_USERNAME]??process.env[kr.HDB_LEADER_USERNAME],hf=sa[kr.HDB_LEADER_PASSWORD]??process.env[kr.HDB_LEADER_PASSWORD],eu=sa[kr.HDB_LEADER_URL]??process.env[kr.HDB_LEADER_URL],na=sa[kr.REPLICATION_HOSTNAME]??process.env[kr.REPLICATION_HOSTNAME],jJ,JJ;na&&([jJ,JJ]=na.split(":"));var JP=(sa[kr.HDB_CLONE_OVERTOP]??process.env[kr.HDB_CLONE_OVERTOP])==="true",QJ=sa[Vh.CLONED.toUpperCase()]??process.env[Vh.CLONED.toUpperCase()],ZRe=sa[kr.CLONE_KEYS]!=="false"&&process.env[kr.CLONE_KEYS]!=="false",XJ=(sa[kr.CLONE_USING_WS]??process.env[kr.CLONE_USING_WS])==="true",ZJ=(sa[kr.NO_START]??process.env[kr.NO_START])==="true",_s,mc={},qJ,$J,Zl={},on,Lt,Gs,ro,tu=!1,QP=!1,fs,mf;n2.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${eu}`),delete process.env.HDB_LEADER_URL,Lt=LA.getEnvCliRootPath(),!Lt)try{let i=$s(BJ.homedir(),an.HDB_HOME_DIR_NAME,an.BOOT_PROPS_FILE_NAME);if(await qt.pathExists(i)){let o=HRe(i);Lt=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.")}Lt?await qt.pathExists(Lt)?console.log(`Existing HarperDB install found at ${Lt}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Lt} starting fresh clone`),tu=!0):(console.log("No HarperDB install found, starting fresh clone"),tu=!0),Lt||(Lt=$s(BJ.homedir(),an.HDB_ROOT_DIR_NAME),console.log("Using default root path",Lt));let n;try{n=$s(Lt,QRe),_s=kJ.parseDocument(await qt.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=$s(Lt,an.HDB_CONFIG_FILE);if(await qt.pathExists(s))try{qJ=kJ.parseDocument(await qt.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),mc=DA.flattenConfig(qJ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(na){let i=new URL(eu);mf=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${JJ||9933}`}if(XJ){await eye();return}if(mc?.cloned&&QJ!=="false")return console.log("Instance marked as cloned, clone will not run"),qs.setCloneVar(!1),qs.initSync(),MA();on=await vA({operation:ps.DESCRIBE_ALL}),await t2(),qs.setCloneVar(!1),qs.setHdbBasePath(Lt),qt.ensureDir(qs.get(an.CONFIG_PARAMS.LOGGING_ROOT)),jP.initLogSettings(),await rye(),QP||await nye(),await oye(t,r),na&&(await cye(),await e2()),console.info(`
|
|
135
|
-
Successfully cloned node: `+eu),(t||ZJ)&&process.exit()},"cloneNode");async function eye(){if(mc?.cloned&&QJ!=="false")return console.log("Instance marked as cloned, clone will not run"),qs.setCloneVar(!1),qs.initSync(),MA();console.log("Cloning using WebSockets");let e=Ec("system"),t=$s(e,"system.mdb"),r=qt.existsSync(t);tu||!r||JP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Lt,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=BRe.randomBytes(10).toString("base64").slice(0,10),UA(!0),await YJ()):(qs.setCloneVar(!1),qs.initSync()),await MA(),await t2(!0),await WRe(),r||await jRe.system.hdb_user.delete({username:"clone-temp-admin"}),await zRe(),await tye(),console.log("Adding node to the cluster");let s=await gd()({operation:ps.ADD_NODE,url:mf});console.log("Add node response: ",s),await e2(),console.log(`Successfully cloned node: ${eu} using WebSockets`),DA.updateConfigValue(Vh.CLONED,!0),ZJ&&process.exit()}a(eye,"cloneUsingWS");async function tye(){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 vA({operation:"describe_database",database:"system"});t.system=e(r);let n=await vA({operation:"describe_all"});for(let i in n)typeof n[i]=="object"&&(t[i]=e(n[i]));let s=$s(Lt,"tmp","lastUpdated.json");console.log("Writing last updated database timestamps to:",s),await qt.outputJson(s,t)}a(tye,"getLastUpdatedRecord");async function vA(e){return XJ?zP({url:mf},e,{rejectUnauthorized:!1}):JSON.parse((await lye(e)).body)}a(vA,"leaderReq");async function e2(){try{if(ZRe!==!1){console.log("Cloning JWT keys");let e=ra.join(Lt,an.LICENSE_KEY_DIR_NAME),t=await zP({url:mf},{operation:ps.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});GJ(ra.join(e,an.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await zP({url:mf},{operation:ps.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});GJ(ra.join(e,an.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r.message)}}catch(e){console.error("Error cloning JWT keys",e)}}a(e2,"cloneKeys");async function t2(e=!1){console.info("Cloning configuration"),$J=await vA({operation:ps.GET_CONFIGURATION}),Zl=DA.flattenConfig($J);let t=_s?.componentConfig?.exclude,r={rootpath:Lt};na&&(r.replication_hostname=jJ);for(let i in Zl)if(!(Zl[i]!==null&&typeof Zl[i]=="object"&&!(Zl[i]instanceof Array)||XRe[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}}mc[i]||(r[i]=Zl[i])}for(let i in mc)i!=="databases"&&typeof mc[i]=="object"&&!(mc[i]instanceof Array)||(r[i]=mc[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=GRe(Object.keys(an.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),DA.createConfigFile(r,!0)}a(t2,"cloneConfig");async function rye(){process.env.HDB_FETCH==="true"?(await iye(),process.env.NODE_TLS_REJECT_UNAUTHORIZED&&delete process.env.NODE_TLS_REJECT_UNAUTHORIZED):await sye()}a(rye,"cloneDatabases");async function nye(){if(console.info("Clone node installing HarperDB."),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Lt,!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(Vh.OPERATIONSAPI_NETWORK_PORT),VRe(ra.join(Lt,an.HDB_CONFIG_FILE)),UA(!0),await YJ()}a(nye,"installHDB");function Ec(e){return qs.get(an.CONFIG_PARAMS.DATABASES)?.[e]?.path||qs.get(Vh.STORAGE_PATH)||ra.join(Lt,an.DATABASES_DIR_NAME)}a(Ec,"getDBPath");async function sye(){let e=Ec("system"),t=$s(e,"system.mdb");if(await $h(e),tu||!await qt.exists(t)||JP){if(!na){console.info("Cloning system database"),await $h(e);let r=PA(t,{overwrite:!0}),n={operation:ps.GET_BACKUP,database:"system",tables:zJ},s=await VJ(n,r),i=new Date(s.date);(!fs||i<fs)&&(fs=i),await qt.utimes(t,Date.now(),i)}tu||(await WJ(Lt),await r2(),UA(!0))}else QP=!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 qt.exists(ra.join(Ec(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(KJ.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=(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:ps.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:ps.GET_BACKUP,database:r});let o=Ec(r);await $h(o);let c=$s(o,r+".mdb"),l=PA(c,{overwrite:!0}),u=await VJ(i,l),f=new Date(u.date);(!fs||f<fs)&&(fs=f),await qt.utimes(c,Date.now(),f)}}a(sye,"cloneTablesHttp");async function iye(){let e=Ec("system"),t=$s(e,"system.mdb");if(tu||!await qt.exists(t)||JP){if(!na){console.info("Cloning system database using fetch");let r={operation:ps.GET_BACKUP,database:"system",tables:zJ},n=await WP(r,!0),s=Ec("system");await $h(s);let i=$s(s,"system.mdb");await FJ(n.body,PA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!fs||o<fs)&&(fs=o),await qt.utimes(i,Date.now(),new Date(n.headers.get("date")))}tu||(await WJ(Lt),await r2(),UA(!0))}else QP=!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 qt.exists(ra.join(Ec(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(KJ.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 WP({operation:ps.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await WP({operation:ps.GET_BACKUP,database:r},!0));let o=Ec(r);await $h(o);let c=new Date(i.headers.get("date")),l=$s(o,`${c.getTime()}-${r}.mdb`);await FJ(i.body,PA(l,{overwrite:!0}));let u=$s(o,r+".mdb");await qt.rename(l,u),(!fs||c<fs)&&(fs=c),await qt.utimes(u,Date.now(),c)}}a(iye,"cloneTablesFetch");async function WP(e,t=!1){let r=_s?.httpsRejectUnauthorized??!1,n=new CA.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(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(WP,"leaderHttpReqFetch");async function oye(e,t=!1){let r=await kRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await $Re(!1):(t&&await aye(),await MA()):(console.info(await FRe({operation:ps.RESTART})),await LA.async_set_timeout(JRe)),e&&await LA.async_set_timeout(2e3)}a(oye,"startHDB");async function aye(){let e=process.argv[3];e&&e[0]!=="-"&&(await qt.exists(e)||console.error(`The folder ${e} does not exist`),qt.statSync(e).isDirectory()||console.error(`The path ${e} is not a folder`),e=await qt.realpath(e),await qt.exists(ra.join(e,an.HDB_CONFIG_FILE))?process.env.ROOTPATH=e:process.env.RUN_HDB_APP=e)}a(aye,"setAppPath");async function cye(){console.info("Setting up replication"),await qRe.setSchemaDataToGlobalAsync();let t=await gd()({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(cye,"setupReplication");async function lye(e){let t=new CA.Agent({rejectUnauthorized:_s?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(pf+":"+hf).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(lye,"leaderHttpReq");async function VJ(e,t){let r=new CA.Agent({rejectUnauthorized:_s?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(pf+":"+hf).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,HJ=CA),i.port&&(o.port=i.port),new Promise((c,l)=>{let u=HJ.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(VJ,"leaderHttpStream");async function r2(){let e=KRe.version;if(e)await YRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(r2,"insertHdbVersionInfo")});var i2=w((Oxe,s2)=>{var uye=CT(),dye=z();s2.exports=fye;async function fye(){try{await uye.install()}catch(e){console.error("There was an error during the install."),console.error(e),dye.error(e),process.exit(1)}}a(fye,"install")});var c2=w((wxe,a2)=>{"use strict";var _ye=hS(),pye=z(),o2="Registration failed.";async function hye(){let e;try{e=await _ye.register()}catch(t){return pye.error(`Registration error ${t}`),o2}return e||o2}a(hye,"register");a2.exports={register:hye}});var f2=w((Cxe,d2)=>{"use strict";var mye=z(),Eye=(H(),C(G)),gye=require("util"),Sye=require("child_process"),l2=gye.promisify(Sye.exec),Tye=Po(),Kh=Cd(),u2="Stopping HarperDB.";d2.exports=Aye;async function Aye(){if(console.log(u2),mye.notify(u2),await Kh.isServiceRegistered(Eye.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 Tye.getHDBProcessInfo();t.clustering.forEach(r=>{l2(`kill ${r.pid}`)}),t.core.forEach(r=>{l2(`kill ${r.pid}`)})}a(Aye,"stop")});var h2=w((Dxe,p2)=>{"use strict";var eD=require("fs-extra"),tD=require("path"),ZP=require("yaml"),Yh=ir(),gc=(H(),C(G)),_2=Tt(),rD=z(),Rye=An(),yye=lS(),bye=aS(),Oye=Po(),Wh=ae(),Nye=Jd(),wye=ie();Wh.initSync();var Vs={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},Mn={LEAF:"leaf server",HUB:"hub server"},xA;p2.exports=Iye;async function Iye(){let e={harperdb:{status:Vs.STOPPED}};if(!await Nye.isHdbInstalled()){e.harperdb.status=Vs.NOT_INSTALLED,console.log(ZP.stringify(e));return}xA=Wh.get(gc.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await eD.readFile(tD.join(xA,gc.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===gc.NODE_ERROR_CODES.ENOENT){rD.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Vs.STOPPED,console.log(ZP.stringify(e));return}throw n}let r=await Oye.getHDBProcessInfo();for(let n of r.core)if(n.pid===t){e.harperdb.status=Vs.RUNNING,e.harperdb.pid=t;break}if((Wh.get(gc.CONFIG_PARAMS.REPLICATION_URL)||Wh.get(gc.CONFIG_PARAMS.REPLICATION_HOSTNAME))&&(e.replication=await Pye()),e.clustering=await Cye(r),e.clustering[Mn.HUB].status===Vs.RUNNING&&e.clustering[Mn.LEAF].status===Vs.RUNNING){let n=[],s=await yye({});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 bye.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(ZP.stringify(e)),process.exit()}a(Iye,"status");async function Cye(e){let t={[Mn.HUB]:{},[Mn.LEAF]:{}};if(e.clustering.length===0)return t[Mn.HUB].status=Vs.STOPPED,t[Mn.LEAF].status=Vs.STOPPED,t;let{port:r}=Yh.getServerConfig(gc.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await Rye.getClusterUser();try{(await Yh.createConnection(r,n,s,!1)).close(),t[Mn.HUB].status=Vs.RUNNING}catch{t[Mn.HUB].status=Vs.ERRORED}let{port:i}=Yh.getServerConfig(gc.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await Yh.createConnection(i,n,s,!1)).close(),t[Mn.LEAF].status=Vs.RUNNING}catch{t[Mn.LEAF].status=Vs.ERRORED}try{t[Mn.HUB].pid=Number.parseInt(await eD.readFile(tD.join(xA,"clustering",_2.PID_FILES.HUB),"utf8"))}catch(o){rD.error(o),t[Mn.HUB].pid=void 0}try{t[Mn.LEAF].pid=Number.parseInt(await eD.readFile(tD.join(xA,"clustering",_2.PID_FILES.LEAF),"utf8"))}catch(o){rD.error(o),t[Mn.LEAF].pid=void 0}return t}a(Cye,"getHubLeafStatus");async function Pye(){let e=await wye.httpRequest({method:"POST",protocol:"http:",socketPath:Wh.get(gc.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(Pye,"getReplicationStatus")});rm();var nD=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");nD&&ae().setCloneVar(!0);var zh=require("node:fs"),m2=require("node:path"),ru=z(),E2=MJ(),{packageJson:Dye,PACKAGE_ROOT:g2}=st(),Lye=xJ(),sD=(H(),C(G)),{SERVICE_ACTIONS_ENUM:cn}=sD,Mye=`
|
|
131
|
+
`))}},25).unref()}o.close?.(()=>{if(mt.get(Qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Zd()==0)try{iz(cz(mt.get(Qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,kT),o.cantCleanupProperly||Mn.warn("Had to forcefully exit the thread",kT),process.exit(0)},5e3).unref()})}if(lz||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Mn.info("Could not close debugger",i)}}}).ref();let e;Oh&&!vSe&&(e=dz()),Promise.resolve(e).then(()=>{if(Zd()===0)try{DSe(FC)}catch(t){console.error("Error displaying start-up log",t)}Nh?.postMessage({type:Qt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(uz,"startServers");function dz(){let e=[];for(let t in Xi){let r=Xi[t];if(t.includes?.("/")&&Zd()==0){bSe(t)&&iz(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Mn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=mt.get(Qt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=Zd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?Oh?n={fd:Oh(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:Oh?n={fd:Oh(+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}),Mn.trace("Listening on port "+t,kT)}).on("error",c)}))}return Promise.all(e)}a(dz,"listenOnPorts");!HC&&!mSe?.noServerStart&&uz();function $C(e,t,r){let n=e?.read?e:new ESe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=Xi[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=Xi[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Mn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a($C,"deliverSocket");var ez=new Map;function USe(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)=>(Nh.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(Nh.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Nh.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(USe,"proxyRequest");var{getComponentName:GT}=(Jp(),P(jp));function VC(e,t,r=!0){t||(t=mt.get(Qt.CONFIG_PARAMS.HTTP_PORT));let n=Xi[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 Xi[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=[],mt.get(Qt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:mt.get(Qt.CONFIG_PARAMS.HTTP_PORT),secure:mt.get(Qt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),mt.get(Qt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:mt.get(Qt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&mt.get(Qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:cz(mt.get(Qt.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)),FT[n]=$T(GC,n);return r}a(YC,"httpServer");function qT(e,t){let r=FC.get(e)??[];FC.set(e,[...r,t])}a(qT,"setPortServerMap");function fz(e,t,r,n){if(qT(e,{protocol_name:t?"HTTPS":"HTTP",name:GT()}),!HT[e]){let s=r?"operationsApi_network":"http",i=mt.get(s+"_keepAliveTimeout"),o=mt.get(s+"_timeout"),c=mt.get(s+"_headersTimeout"),l={keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:mt.get(Qt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=mt.get(s+"_mtls"),f=mt.get(s+"_mtls_required"),d;t&&(d=mt.get(s+"_http2"),Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!f,requestCert:!!(u||n),ticketKeys:wSe(),SNICallback:az(r?"operations-api":"server",u)}));let p=PSe(),_=HT[e]=(t?d?RSe:ASe:SSe)(l,async(h,S)=>{try{let R=performance.now(),E=new oz(h,S);r&&(E.isOperationsServer=!0);let A=await FT[e](E);if(!A){if(E._nodeResponse.statusCode)return;A=_z(E)}if(A.headers?.set||(A.headers=new kC(A.headers)),p?A.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):A.headers?.set?.("Server","HarperDB"),A.status===-1){for(let se of A.headers||[])S.setHeader(se[0],se[1]);return h.baseRequest=E,S.baseResponse=A,HT[e].emit("unhandled",h,S)}let N=A.status||200,v=performance.now(),F=v-R,$=A.body,Y,ee=!1;if(!A.handlesHeaders){let se=A.headers||new kC;$?$.length>=0?(typeof $=="string"?se.set("Content-Length",Buffer.byteLength($)):se.set("Content-Length",$.length),Y=!0):$ instanceof ySe&&($.size?se.set("Content-Length",$.size):$.on&&(ee=!0,$.on("size",me=>{S.headersSent||S.setHeader("Content-Length",me)})),$=$.stream()):(se.set("Content-Length","0"),Y=!0);let z=`hdb;dur=${F.toFixed(2)}`;if(A.wasCacheMiss&&(z+=", miss"),CSe(se,"Server-Timing",z,!0),!S.headersSent)if(ee){if(S.statusCode=N,se)if(se[Symbol.iterator])for(let[me,Ae]of se)S.setHeader(me,Ae);else for(let me in se)S.setHeader(me,se[me])}else S.writeHead(N,se&&(se[Symbol.iterator]?Array.from(se):se));Y&&S.end($)}let oe=E.handlerPath,j=E.method;if(yh(F,"duration",oe,j,A.wasCacheMiss==null?void 0:A.wasCacheMiss?"cache-miss":"cache-hit"),XW(N<400,"success",oe,j),XW(1,"response_"+N,oe,j),!Y)if($ instanceof ReadableStream&&($=ZW.fromWeb($)),($[Symbol.iterator]||$[Symbol.asyncIterator])&&($=ZW.from($)),$?.pipe){$.pipe(S),$.destroy&&S.on("close",()=>{$.destroy()});let se=0;$.on("data",z=>{se+=z.length}),$.on("end",()=>{yh(performance.now()-v,"transfer",oe,j),yh(se,"bytes-sent",oe,j)})}else $?.then?$.then(se=>{S.end(se)},g):S.end($)}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?Mn.warn(R):Mn.info(R):Mn.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&&yh(performance.now()-h._parent.startTime,"tls-handshake",e),yh(h.isSessionReused(),"tls-reused",e)}),_.isSecure=!0),VC(_,e)}return HT[e]}a(fz,"getHTTPServer");function $T(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($T,"makeCallbackChain");function _z(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new kC}}a(_z,"unhandled");function xSe(e,t){YC(e,{requestOnly:!0,...t})}a(xSe,"onRequest");function BSe(e,t){let r;if(t.securePort){qT(t.securePort,{protocol_name:"TLS",name:GT()});let n=az("server",t.mtls);r=NSe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),Xi[t.securePort]=r}return t.port&&(qT(t.port,{protocol_name:"TCP",name:GT()}),r=gSe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),Xi[t.port]=r),r}a(BSe,"onSocket");Object.defineProperty(TSe.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]=$T(tz,r)}a(pz,"onUpgrade");var rz=[],nz={};function HSe(e,t){let r=[];for(let{port:n,secure:s}of KC(t)){qT(n,{protocol_name:s?"WSS":"WS",name:GT()});let i=fz(n,s,t?.isOperationsServer,t?.mtls);bh[n]||(bh[n]=new OSe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),bh[n].on("connection",(o,c)=>{let l=new oz(c);l.isWebSocket=!0;let u=FT[n](l);nz[n](o,l,u)}),pz((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):bh[n].handleUpgrade(o,c,l,f=>{o.__harperdb_request_upgraded=!0,u(o,c,l),bh[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]=$T(rz,n),FT[n]=$T(GC,n)}return r}a(HSe,"onWebSocket");function sz(e,t){t.writeHead(404),t.end(`Not found
|
|
132
|
+
`)}a(sz,"defaultNotFound")});var QW={};Ue(QW,{startHTTPThreads:()=>FSe,startSocketServer:()=>XC,updateWorkerIdleness:()=>yz});async function FSe(e=2,t){try{if(t)JC(0,1,!0);else{let{loadRootComponents:r}=VT();if(e===0)return(0,Hs.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,Hs.threadsHaveStarted)()}}function Rz(){let e=(0,gz.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),jC=setInterval(()=>{WT.notify(e)},kSe).unref())}function JC(e,t=1,r){if(zC++,(0,Hs.startWorker)("server/threads/threadServer.js",{name:eR.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===QA.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Az.push(s),await s,ef.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=YT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=ef.indexOf(n);o>-1&&ef.splice(o,1)}if(a(i,"removeWorker"),tf){let o=tf;tf=[];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,Hs.shutdownWorkers)(),zC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function XC(e=0,t){if(typeof e=="string")try{(0,zT.existsSync)(e)&&(0,zT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=GSe:r=qSe(t):r=ZC;let n=(0,rf.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 rf.Socket({handle:i,writable:!0,readable:!0});hz.deliverSocket(u,e,c),u.resume()}else zC>0?(tf.length===0&&setTimeout(()=>{tf.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,tf.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 rf.Socket({handle:i,writable:!0,readable:!0});KSe(u,o,e)}sr(!0,"socket-routed")})},WT.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 ef){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=KT)return KT=i,t(r);n=i}KT=0,t(r)}function GSe(e,t){let r={};e.getpeername(r);let n=r.address,s=nf.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);ZC(e,o=>{nf.set(n,{worker:o,lastUsed:i}),t(o)})}function qSe(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new rf.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=nf.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);ZC(n,d=>{nf.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function yz(){KT=0;for(let e of ef)e.expectedIdle=e.recentELU.idle+$Se,e.requests=1;ef.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function KSe(e,t,r){let n=VSe++;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(),YT.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")),YT.delete(n)),s.event=="destroy"&&(e.destroy(),YT.delete(n))})}var Hs,rf,WT,zT,Ez,gz,Sz,ef,tf,Tz,hz,zC,Az,jC,kSe,QC,KT,mz,nf,$Se,YT,VSe,BC=be(()=>{Hs=M(rt()),rf=require("net");H();WT=M(W()),zT=require("fs");Fi();Ez=require("worker_threads"),gz=M(Nd()),Sz=M(st()),ef=[],tf=[],Tz=[],zC=0,Az=[];Ez.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Hs.onMessageFromWorkers)(e=>{e.type===ZA.RESTART&&jC&&(clearInterval(jC),Rz())}));kSe=6e5;a(FSe,"startHTTPThreads");a(Rz,"licenseWarning");a(JC,"startHTTPWorker");a(XC,"startSocketServer");KT=0;a(ZC,"findMostIdleWorker");mz=36e5,nf=new Map;a(GSe,"findByRemoteAddressAffinity");a(qSe,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of nf)r.lastUsed+mz<e&&nf.delete(t)},mz).unref();$Se=1e3;a(yz,"updateWorkerIdleness");(0,Hs.setMonitorListener)(yz);YT=new Map,VSe=1;a(KSe,"proxySocket")});var Hz=I((QUe,Bz)=>{var Oz=M(require("cluster")),dc=M(ce());H();var Zi=M(W()),Nz=M(require("fastify")),wz=M(require("@fastify/cors")),Iz=M(require("@fastify/compress")),Cz=M(require("@fastify/static")),Pz=M(yO()),Dz=M(require("path")),Lz=M(st()),Mz=M(Rs()),vz=M(ae()),Uz=M(yn()),xz=M(Nd());Kr();var fc=M(mT());co();dc.default.initSync();var YSe=6e4,WSe=1024*1024*1024,zSe="TRUE",{CONFIG_PARAMS:Ih}=G,sf;Bz.exports={hdbServer:bz,start:bz};async function bz(e){try{Zi.default.debug("In Fastify server"+process.cwd()),Zi.default.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Zi.default.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=Oz.default.isMaster,await jSe();let t=e.securePort>0;sf=JSe(t),await sf.ready(),e||(e={}),e.isOperationsServer=!0;try{We.http(sf.server,e),sf.server.closeIdleConnections||await sf.listen({port:0,host:"::"})}catch(r){throw sf.close(),Zi.default.error(r),Zi.default.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Zi.default.fatal(t),process.exit(1)}}a(bz,"operationsServer");async function jSe(){Zi.default.trace("Configuring HarperDB process."),Mz.default.setSchemaDataToGlobal(),await Uz.default.setUsersWithRolesCache(),await xz.default.getLicense()}a(jSe,"setUp");function JSe(e){Zi.default.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=QSe(e),r=(0,Nz.default)(t);r.server.headersTimeout=ZSe(),r.setErrorHandler(fc.serverErrorHandler);let n=XSe();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=dc.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:[fc.reqBodyValidationHandler,fc.authHandler],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),(0,fc.handlePostRequest)(i,o)}),r.get("/health",()=>"HarperDB is running."),Zi.default.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(JSe,"buildServer");function QSe(e){let t=dc.default.get(Ih.OPERATIONSAPI_NETWORK_TIMEOUT),r=dc.default.get(Ih.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:WSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(QSe,"getServerOptions");function XSe(){let e=dc.default.get(Ih.OPERATIONSAPI_NETWORK_CORS),t=dc.default.get(Ih.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===zSe)&&(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(XSe,"getCORSOpts");function ZSe(){return dc.default.get(Ih.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??YSe}a(ZSe,"getHeaderTimeoutConfig")});var iP={};Ue(iP,{disableNATS:()=>tTe,publishToStream:()=>QT,setNATSReplicator:()=>eP,setPublishToStream:()=>rTe,setSubscription:()=>sP,start:()=>eTe});function eTe(){Ch.default.get(x.CLUSTERING_ENABLED)&&sTe()}function tTe(e=!0){$z=e}function rTe(e,t){QT=e,sP=t}function sTe(){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)}}Al((r,n)=>{eP(r.tableName,r.databaseName,r),n&&Kz(r)}),!kz&&(kz=!0)}function eP(e,t,r){if(t==="system"&&iTe.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 Vr{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 Hn;return sP(t,e,i),i}static subscribeOnThisThread(i){return i<(Ch.default.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??nTe)}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 jT(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=Ch.default.get(x.CLUSTERING_NODENAME);QT(`${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,Ch,JT,$z,QT,sP,nTe,Vz,kz,iTe,jT,tP,Yz=be(()=>{De();ga();Fz=M(ir()),rP=M(St()),nP=M(go());hu();Gz=M(BO()),qz=M(pn()),Ch=M(ce());H();JT=M(W());a(eTe,"start");a(tTe,"disableNATS");QT=Fz.publishToStream,sP=Gz.setSubscription;a(rTe,"setPublishToStream");nTe=2;a(sTe,"assignReplicationSource");iTe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(eP,"setNATSReplicator");a(Kz,"publishSchema");jT=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=Ch.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(QT(`${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 jT{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 ZT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ph.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function aP(){return XT++,XT>65500&&(XT=1),XT}function cP(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Ni.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 zz,_c,jz,Jz,Wz,oP,Ph,XT,ZT,lP,Xz=be(()=>{De();Au();zz=M(pn()),_c=M(W());Cc();jz=M(rt()),Jz=M(WC());Kr();Wz=100,oP=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"}]}}]}),Ph=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,jz.getWorkerIndex)()===0&&(async()=>{await Jz.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of Ph.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,_c.warn)("Failed to publish will",t)}Ph.delete(e.id)}})();a(Qz,"getSession");XT=1;a(aP,"getNextMessageId");ZT=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,_c.trace)("Resuming subscription from",s,"from",o);let _=Ni.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 N=!0;E[E.length-1]==="#"&&(E.length--,N=!1),A&&(n=a(F=>{let $=F.id;if(!Array.isArray($))if($?.indexOf?.("/")>-1)$=$.split("/");else return!1;if(N&&$.length!==E.length)return!1;for(let Y=0;Y<E.length;Y++)if(E[Y]!=="+"&&E[Y]!==$[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 N of E)try{let v;if(N.type&&N.type!=="put"&&N.type!=="delete"&&N.type!=="message"&&N.type!=="patch"||n&&!n(N))continue;r?(N.topic=s,v=this.needsAcknowledge(N)):(N.acknowledge?.(),v=aP());let F=N.id;if(Array.isArray(F)&&(F=Tu(F)),F==null&&(F=""),await this.listener(h+"/"+F,N.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,_c.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();Nt(r,async()=>{try{if(!t){let n=await Ph.get(this.sessionId);n?.doesExist()&&await cP(n,n.data,r)}}finally{await Ph.delete(this.sessionId)}}).catch(n=>{(0,_c.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 ZT{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,_c.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,_c.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),oP.put(this.sessionRecord)}}});var dP={};Ue(dP,{bypassAuth:()=>oTe,start:()=>aTe});function oTe(){nj=!0}function aTe({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,of.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&tA.notify?.({username:f?.username,status:Ws.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,of.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&tA.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&&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,W_(d=>{eA>0&&d.push({metric:"mqtt-connections",connections:eA,byThread:!0})}));let i;eA++;let o,c={protocolVersion:4},l=(0,rA.parser)({protocolVersion:5});function u(d){l.parse(d)}a(u,"onMessage");function f(){eA--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Xn(!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,of.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&tA.notify?.({username:n?.username,status:Ws.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(oe){return(0,of.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&tA.error?.({username:d.username,status:Ws.FAILURE,type:ua.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,oe),Xn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Xn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let oe=e.deserialize||(e.deserialize=fo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?oe(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(oe){return hr.error?.(oe),s.events.emit("auth-failed",d,e,oe),Xn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:oe.code||5,returnCode:oe.code||128})}s.events.emit("connected",o,e),Xn(!0,"connection","mqtt","connect"),g({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0});let A=a(async(oe,j,se,z)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",oe);let me=oe.indexOf("/",1),Ae=me>0?oe.slice(0,me):oe;g({cmd:"publish",topic:oe,payload:await E(j),messageId:se||Math.floor(Math.random()*1e8),qos:z.qos},Ae);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(A),o.sessionWasPresent&&await o.resume();break;case"subscribe":let N=[];for(let oe of d.subscriptions){let j;try{let se=await o.addSubscription(oe,oe.qos>=1);j=se?se.qos||0:c.protocolVersion<5?128:143}catch(se){s.events.emit("error",se,e,oe,o),se.statusCode?se.statusCode===500?hr.warn?.(se):hr.info?.(se):hr.error?.(se),j=c.protocolVersion<5?128:se.statusCode===403?135:se.statusCode===404?143:128}N.push(j)}await o.committed,g({cmd:"suback",granted:N,messageId:d.messageId});break;case"unsubscribe":{let oe=[];for(let j of d.unsubscriptions)oe.push(o.removeSubscription(j)?0:17);g({cmd:"unsuback",granted:oe,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=fo(r?.headers.get?.("content-type"))),Y=(d.payload?.length||0)>0?F(d.payload):void 0,ee;try{ee=await o.publish(d,Y)}catch(oe){s.events.emit("error",oe,e,d,o),hr.warn?.(oe),d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:ee===!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),Xn(!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,N){let v=(0,rA.generate)(A,c);t(v),sr(v.length,"bytes-sent",N,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 rA,tj,of,uP,rj,tA,hr,nj,Zz,eA,sj=be(()=>{rA=require("mqtt-packet");Xz();tj=M(yn());co();Fi();Kr();of=M(ce());H();uP=M(wi()),rj=require("events"),tA=(0,uP.loggerWithTag)("auth-event"),hr=(0,uP.loggerWithTag)("mqtt"),nj=(0,of.get)(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(oTe,"bypassAuth");a(aTe,"start");eA=0;a(ej,"onSocket")});var jp={};Ue(jp,{component_errors:()=>cf,getComponentName:()=>fTe,loadComponent:()=>iA,loadComponentDirectories:()=>lj,setErrorReporter:()=>dTe});function lj(e,t){t&&(_P=t),e&&(EP=e);let r=[];if((0,lt.existsSync)(fP)){let s=(0,lt.readdirSync)(fP,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,gt.join)(fP,o);r.push(iA(c,_P,YA,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(iA(n,_P,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{cj=!0})}function dTe(e){Dh=e}async function iA(e,t,r,n,s,i){let o=(0,lt.realpathSync)(e);if(nA.has(o))return nA.get(o);nA.set(o,!0),s&&(EP=s);try{let c;n&&(cf=new Map);let l=(0,gt.join)(e,"harperdb-config.yaml");(0,lt.existsSync)(l)?c=n?(0,oA.getConfigObj)():(0,pP.parseDocument)((0,lt.readFileSync)(l,"utf8")).toJSON():!n&&(0,lt.existsSync)(l=(0,gt.join)(e,"config.yaml"))?c=(0,pP.parseDocument)((0,lt.readFileSync)(l,"utf8")).toJSON():c=gP;let u=(0,gt.join)(e,"node_modules","harperdb");try{Jl.isMainThread&&(n||((0,lt.existsSync)(u)||!e.startsWith((0,mP.getHdbBasePath)()))&&(!(0,lt.existsSync)(u)||(0,lt.realpathSync)(hP.PACKAGE_ROOT)!==(0,lt.realpathSync)(u)))&&((0,lt.rmSync)(u,{recursive:!0,force:!0}),(0,lt.existsSync)((0,gt.join)(e,"node_modules"))||(0,lt.mkdirSync)((0,gt.join)(e,"node_modules")),(0,lt.symlinkSync)(hP.PACKAGE_ROOT,u,"dir"))}catch(p){af.default.error("Error symlinking harperdb module",p)}let f=sA,d=n;for(let p in c){sA=p;let _=c[p];if(cf.set(n?p:(0,gt.basename)(e),!1),!_)continue;let h,S=_.package;try{if(S){let N=e,v;for(;!(0,lt.existsSync)(v=(0,gt.join)(N,"node_modules",p));)if(N=(0,gt.dirname)(N),N.length<(0,mP.getHdbBasePath)().length){v=null;break}if(v)h=await iA(v,t,r,!1),d=!0;else throw new Error(`Unable to find package ${p}:${S}`)}else h=uTe[p];if(!h)continue;let g=a(N=>(N.origin=r,dt(N)),"ensureTable"),R=_.network||(_.port||_.securePort)&&_,E=R?.securePort||R?.https&&R.port,A=!R?.https&&R?.port;if(Jl.isMainThread&&(h=await h.startOnMainThread?.({server:We,ensureTable:g,port:A,securePort:E,resources:t,..._})||h,n&&R))for(let N of[A,E])try{if(+N&&!ij.includes(N)){let v=SP.get(x.HTTP_SESSIONAFFINITY);v&&af.default.warn("Session affinity is not recommended and may cause memory leaks"),(v||!ST)&&(ij.push(N),XC(N,v))}}catch(v){console.error("Error listening on socket",N,v,p)}if(t.isWorker&&(h=await h.start?.({server:We,ensureTable:g,port:A,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 N=(0,gt.join)(e,_.files).replace(/\\/g,"/"),v=N.indexOf("/*");if(v>-1&&_.files!==gP[p]?.files&&!(0,lt.existsSync)(N.slice(0,v)))throw new Error(`The path '${N.slice(0,v)}' does not exist and cannot be used as the base of the resolved 'files' path value '${_.files}'`);let F=(0,gt.basename)(e),$=_.path||"/";$=$.startsWith("/")?$:$.startsWith("./")?"/"+F+$.slice(2):$==="."?"/"+F:"/"+F+"/"+$;let Y,ee,oe;if(_.root){let se=_.root;se.startsWith("/")&&(se=se.slice(1)),se.endsWith("/")&&(se=se.slice(0,-1)),se+="/",ee=(0,gt.join)(e,se)}else(oe=N.indexOf("/*"))>-1?(ee=N.slice(0,oe+1),Y=(0,gt.relative)(e,ee)):_.files.indexOf("/")>-1&&(ee=N.slice(0,N.lastIndexOf("/")+1),Y=(0,gt.relative)(e,ee));let j=!1;if(Jl.isMainThread&&h.setupDirectory&&(j=await h.setupDirectory?.($,ee,t)),t.isWorker&&h.handleDirectory&&(j=await h.handleDirectory?.($,ee,t)),j){d=!0;continue}for(let se of await(0,oj.default)(N,{onlyFiles:!1,objectMode:!0})){let{path:z,dirent:me}=se;d=!0;let Ae=(0,gt.relative)(e,z).replace(/\\/g,"/");if(Y)if(Ae.startsWith(Y))Ae=Ae.slice(Y.length+1);else throw new Error(`The root path '${_.root}' does not reference a valid part of the file path '${Ae}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Pe=$+($.endsWith("/")?"":"/")+Ae;try{if(me.isFile()){let he=await lTe(z);Jl.isMainThread&&await h.setupFile?.(he,Pe,z,t),t.isWorker&&await h.handleFile?.(he,Pe,z,t)}else Jl.isMainThread&&await h.setupDirectory?.(Pe,z,t),t.isWorker&&await h.handleDirectory?.(Pe,z,t)}catch(he){let Ot=`Could not load ${me.isFile()?"file":"directory"} '${z}'${_.module?` using '${_.module}'`:""} for application '${e}' due to:
|
|
133
|
+
`;he.message=`${Ot}${he.message}`,he.stack=`${Ot}${he.stack}`,Dh?.(he),af.default.error(he),t.set(_.path||"/",new Sa(he)),cf.set(n?p:(0,gt.basename)(e),he.message)}}}}catch(g){g.message=`Could not load component '${p}' for application '${(0,gt.basename)(e)}' due to: ${g.message}`,Dh?.(g),((0,Lh.getWorkerIndex)()===0?console:af.default).error(g),t.set(_.path||"/",new Sa(g),null,!0),cf.set(n?p:(0,gt.basename)(e),g.message)}}if(sA=f,Jl.isMainThread&&!cj&&i&&(0,Lh.watchDir)(e,async()=>lj()),c.extensionModule){let p=await JE((0,gt.join)(e,c.extensionModule));return nA.set(o,p),p}if(!d&&t.isWorker){let p=`${e} did not load any modules, resources, or files, is this a valid component?`;Dh?.(new Error(p)),((0,Lh.getWorkerIndex)()===0?console:af.default).error(p),cf.set((0,gt.basename)(e),p)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Dh?.(c),t.set("",new Sa(c))}}var lt,gt,Jl,pP,SP,hP,oj,Lh,af,aj,mP,cTe,oA,lTe,fP,EP,cj,_P,cf,uTe,gP,ij,nA,Dh,sA,fTe,Jp=be(()=>{lt=require("fs"),gt=require("path"),Jl=require("worker_threads"),pP=require("yaml"),SP=M(ce()),hP=M(st());H();HL();AM();JB();eH();tH();BH();mY();RY();bY();oj=M(require("fast-glob")),Lh=M(rt()),af=M(W());aO();Kr();aj=M(pe());De();BC();mP=M(ce()),cTe=M(Hz());US();Yz();Zn();sj();oA=M(Rt());ZI();TR();({readFile:lTe}=lt.promises),fP=(0,oA.resolvePath)(SP.get(x.COMPONENTSROOT)),EP=new Map,cf=new Map;a(lj,"loadComponentDirectories");uTe={REST:rg,rest:rg,graphql:kR,graphqlSchema:yR,roles:oO,jsResource:lO,fastifyRoutes:WI,login:dO,static:zI,operationsApi:cTe,customFunctions:{},http:{},clustering:iP,replication:Io,authentication:qp,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=[],nA=new Map;a(dTe,"setErrorReporter");fTe=a(()=>sA,"getComponentName");a(iA,"loadComponent")});var VT=I((w0e,dj)=>{var{isMainThread:uj}=require("worker_threads"),{getTables:_Te,getDatabases:O0e,table:N0e}=(De(),P(nt)),{loadComponentDirectories:pTe,loadComponent:hTe}=(Jp(),P(jp)),{resetResources:mTe}=(Au(),P(vL)),ETe=$w(),gTe=Rt(),{dirname:STe}=require("path"),{getConnection:TTe}=ir(),ATe=ce(),{CONFIG_PARAMS:RTe}=(H(),P(G)),{loadCertificates:yTe}=es(),TP=new Map;async function bTe(e=!1){!uj&&ATe.get(RTe.CLUSTERING_ENABLED)&&TTe();try{uj&&await ETe()}catch(n){console.error(n)}let t=mTe();_Te(),t.isWorker=e,await yTe(),await hTe(STe(gTe.getConfigFilePath()),t,"hdb",!0,TP),await pTe(TP,t);let r=[];for(let[n]of TP)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(bTe,"loadRootComponents");dj.exports.loadRootComponents=bTe});var rt=I((C0e,Ti)=>{"use strict";sm();var{Worker:OTe,MessageChannel:NTe,parentPort:eo,isMainThread:OP,threadId:wTe,workerData:to}=require("worker_threads"),{PACKAGE_ROOT:ITe}=st(),{join:hj,isAbsolute:CTe,extname:PTe}=require("path"),{server:mj}=(Kr(),P(Ru)),{watch:DTe,readdir:LTe}=require("fs/promises"),{totalmem:fj}=require("os"),lf=(H(),P(G)),Ej=ce(),Si=W(),{randomBytes:MTe}=require("crypto"),{_assignPackageExport:vTe}=Ai(),_j=1024*1024,pc=[],ks=[],UTe=50,NP=1e4,xTe="restart",gj="request_thread_info",Sj="resource_report",Tj="thread_info",Aj="added-port",BTe="ack",AP;vTe("threads",ks);Ti.exports={startWorker:RP,restartWorkers:IP,shutdownWorkers:qTe,workers:pc,setMonitorListener:JTe,onMessageFromWorkers:$Te,onMessageByType:Ij,broadcast:KTe,broadcastWithAcknowledgement:WTe,setChildListenerByType:GTe,getWorkerIndex:Rj,getWorkerCount:yj,getTicketKeys:Oj,setMainIsWorker:kTe,setTerminateTimeout:HTe,restartNumber:to?.restartNumber||1};ks.onMessageByType=Ij;ks.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=ks.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Ti.exports.whenThreadsStarted=new Promise(e=>{Ti.exports.threadsHaveStarted=e});var wP;function HTe(e){NP=e}a(HTe,"setTerminateTimeout");function Rj(){return to?to.workerIndex:wP?0:void 0}a(Rj,"getWorkerIndex");function yj(){return to?to.workerCount:wP?1:void 0}a(yj,"getWorkerCount");function kTe(e){wP=e,Ti.exports.threadsHaveStarted()}a(kTe,"setMainIsWorker");var bj=1,aA;function Oj(){return aA||(aA=OP?MTe(48):to.ticketKeys,aA)}a(Oj,"getTicketKeys");Object.defineProperty(mj,"workerIndex",{get(){return Rj()}});Object.defineProperty(mj,"workerCount",{get(){return yj()}});var Nj={[gj](e,t){zTe(t)},[Sj](e,t){jTe(t,e)}};function RP(e,t={}){let r=process.constrainedMemory?.()||fj();r=Math.min(r,fj(),2e4*_j);let n=Ej.get(lf.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 ks){let u=new NTe;u.existingPort=l,i.push(u),o.push(u.port2)}PTe(e)||(e+=".js");let c=new OTe(CTe(e)?e:hj(ITe,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:Ti.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 lA(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>RP(e,t),c.on("error",l=>{Si.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{pc.splice(pc.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<UTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,RP(e,t)):Si.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{Nj[l.type]?.(l,c)}),pc.push(c),XTe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(RP,"startWorker");var FTe=[lf.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){Si.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=VT();await o()}Ti.exports.restartNumber++,t<1&&(t=t*pc.length);let n=[],s=[];for(let o of pc.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:lf.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=FTe.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()},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===lf.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}=ja();r&&(e==="http"||!e)&&Ej.get(lf.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else eo.postMessage({type:xTe,workerType:e})}a(IP,"restartWorkers");function GTe(e,t){Nj[e]=t}a(GTe,"setChildListenerByType");function qTe(e){return IP(e,1/0,!1)}a(qTe,"shutdownWorkers");var wj=[];function $Te(e){wj.push(e)}a($Te,"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 VTe=10;async function KTe(e,t){let r=0;for(let n of ks)try{n.postMessage(e),r++>VTe&&(r=0,await new Promise(setImmediate))}catch(s){Si.error("Unable to send message to worker",s)}t&&Pj(e,null)}a(KTe,"broadcast");var cA=new Map,YTe=1;function WTe(e){return new Promise(t=>{let r=0;for(let n of ks)try{let s=YTe++,i=a(()=>{cA.delete(s),--r===0&&t(),n!==eo&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,cA.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of cA)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Si.error("Unable to send message to worker",s)}r===0&&t()})}a(WTe,"broadcastWithAcknowledgement");function zTe(e){e.postMessage({type:Tj,workers:Cj()})}a(zTe,"sendThreadInfo");function Cj(){let e=Date.now();return pc.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 jTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(jTe,"recordResourceReport");var bP;function JTe(e){bP=e}a(JTe,"setMonitorListener");var QTe=1e3,pj=!1;function XTe(){pj||(pj=!0,setInterval(()=>{for(let e of pc){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()},QTe).unref())}a(XTe,"startMonitoring");var ZTe=1e3;if(eo&&to?.addPorts){lA(eo);for(let e=0,t=to.addPorts.length;e<t;e++){let r=to.addPorts[e];r.threadId=to.addThreadIds[e],lA(r)}setInterval(()=>{let e=process.memoryUsage();eo.postMessage({type:Sj,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},ZTe).unref(),AP=a(()=>new Promise((e,t)=>{eo.on("message",r),eo.postMessage({type:gj});function r(n){n.type===Tj&&(eo.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else AP=Cj;Ti.exports.getThreadInfo=AP;function lA(e,t){ks.push(e),e.on("message",r=>{if(r.type===Aj)r.port.threadId=r.threadId,lA(r.port);else if(r.type===BTe){let n=cA.get(r.id);n&&n()}else Pj(r,e)}).on("close",()=>{ks.splice(ks.indexOf(e),1)}).on("exit",()=>{ks.splice(ks.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(lA,"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){Si.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 LTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(hj(s,o.name));try{for await(let{filename:o}of DTe(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");Ti.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else eo.on("message",async e=>{let{type:t}=e;t===lf.ITC_EVENT_TYPES.SHUTDOWN&&(Ti.exports.restartNumber=e.restartNumber,eo.unref(),setTimeout(()=>{Si.warn("Thread did not voluntarily terminate",wTe),process.exit(0)},NP).unref())})});var hB={};Ue(hB,{ACTION_32_BIT:()=>jm,ACTION_64_BIT:()=>rAe,AUDIT_STORE_OPTIONS:()=>Bp,Decoder:()=>Tl,HAS_BLOBS:()=>Gn,HAS_CURRENT_RESIDENCY_ID:()=>Fc,HAS_EXPIRATION_EXTENDED_TYPE:()=>s_,HAS_ORIGINATING_OPERATION:()=>n_,HAS_PREVIOUS_RESIDENCY_ID:()=>Gc,REMOTE_SEQUENCE_UPDATE:()=>Ug,createAuditEntry:()=>wu,getLastRemoved:()=>TN,openAuditStore:()=>fA,readAuditEntry:()=>wt,removeAuditEntry:()=>_A,setAuditRetention:()=>tAe,transactionKeyEncoder:()=>kj});function fA(e){let t=e.auditStore=e.openDB(CP.AUDIT_STORE_NAME,{create:!1,...Bp});t||(t=e.auditStore=e.openDB(CP.AUDIT_STORE_NAME,Bp),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;Rh(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=_A(t,h,S)}catch(g){uf.warn("Error removing audit entry",g)}if(_=h,await new Promise(setImmediate),++d>=eAe){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,vh.getWorkerIndex)()===(0,vh.getWorkerCount)()-1&&c(),(0,vh.getWorkerIndex)()===0&&!Dj)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Dj=!0,uf.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 _A(e,t,r){let n=nAe(r),s;if(n&Gn){s=wt(r);let i=e.tableStores[s.tableId],o=i?.getEntry(s.recordId);(!o||o.version!==s.version||!o.value)&&Uc(()=>Aa(s.getValue(i)),i.rootStore)}if((n&15)===LP){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 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 tAe(e,t=DP){PP=e,DP=t}function wu(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?hc.setFloat64(0,n):Fs.set(jR),h=9),l){if(l&255)throw new Error("Illegal extended type");h+=3}R(s),R(t),g(r),hc.setFloat64(h,e),h+=8,l&Fc&&R(u),l&Gc&&R(f),l&s_&&(hc.setFloat64(h,d),h+=8),l&n_&&R(qj[p]),i?g(i):Fs[h++]=0,l?hc.setUint32(n?8:0,_|l|3221225472):Fs[n?8:0]=_;let S=Fs.subarray(0,h);if(c)return Buffer.concat([S,c]);return S;function g(E){let A=h;h+=1,h=(0,Ql.writeKey)(E,Fs,h);let N=h-A-1;N>127?N>16383?(uf.error("Key or username was too large for audit entry",E),h=A+1,Fs[A]=0):(Fs.copyWithin(A+2,A+1,h),hc.setUint16(A,N|32768),h++):Fs[A]=N}function R(E){E<128?Fs[h++]=E:E<16384?(hc.setUint16(h,E|32768),h+=2):E<1056964608?(hc.setUint32(h,E|3221225472),h+=4):(Fs[h]=255,hc.setUint32(h+1,E),h+=5)}}function nAe(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 Tl(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 Tl(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&Fc&&(p=n.readInt()),i&Gc&&(_=n.readInt()),i&s_&&(h=n.readFloat64()),i&n_){let A=n.readInt();S=qj[A]}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,Ql.readKey)(e,u,f)},getBinaryRecordId(){return e.subarray(u,f)},version:d,previousLocalTime:s,get user(){return R>g?(0,Ql.readKey)(e,g,R):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(A,N,v){if(i&uA||i&Mh&&!N)return E||(E=Uc(()=>A.decoder.decode(e.subarray(n.position,r)),A.rootStore)),E;if(i&Mh&&v)return Kb(A.getEntry(this.recordId),v,A)},getBinaryValue(){return i&(uA|Mh)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:p,previousResidencyId:_,expiresAt:h,originatingOperation:S}}catch(n){return uf.error("Reading audit entry error",n,e),{}}}var Ql,dA,CP,vh,Hj,uf,Fs,hc,kj,Bp,PP,eAe,MP,Fj,DP,Dj,uA,Mh,Mj,LP,vj,Uj,xj,Bj,jm,rAe,Ug,Fc,Gc,n_,s_,Gn,Gj,qj,Tl,_o=be(()=>{Ql=require("ordered-binary"),dA=M(ce()),CP=M(xt());H();vh=M(rt()),Hj=M(ae());Iu();uf=M(W());BE();Ss();xT();(0,dA.initSync)();Fs=Buffer.alloc(2816),hc=new DataView(Fs.buffer,Fs.byteOffset,2816),kj={writeKey(e,t,r){return e===r_?(t.set(r_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Ql.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,Ql.readKey)(e,t,r)}},Bp={encoding:"binary",keyEncoder:kj},PP=(0,Hj.convertToMS)((0,dA.get)(x.LOGGING_AUDITRETENTION))||86400*3,eAe=1e3,MP=new Float64Array(1),Fj=new Uint8Array(MP.buffer),DP=1e4,Dj=!1;a(fA,"openAuditStore");a(_A,"removeAuditEntry");a(Lj,"updateLastRemoved");a(TN,"getLastRemoved");a(tAe,"setAuditRetention");uA=16,Mh=32,Mj=1,LP=2,vj=3,Uj=4,xj=5,Bj=6,jm=14,rAe=15,Ug=11,Fc=512,Gc=1024,n_=2048,s_=4096,Gn=8192,Gj={put:Mj|uA,[Mj]:"put",delete:LP,[LP]:"delete",message:vj|uA,[vj]:"message",invalidate:Uj|Mh,[Uj]:"invalidate",patch:xj|Mh,[xj]:"patch",relocate:Bj,[Bj]:"relocate"},qj={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(wu,"createAuditEntry");a(nAe,"readAction");a(wt,"readAuditEntry");Tl=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,sAe(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=Tu(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=wt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Tu(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 sAe(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(W());hu();Au();_o();$j=Object.create(null),Vj=Object.create(null);a(xP,"addSubscription");UP=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(Kj,"notifyFromTransactionData");a(sAe,"listenToCommits");a(Yj,"nextTransaction");a(HF,"whenNextTransaction")});var II={};Ue(II,{EVICTED:()=>Ea,INVALIDATED:()=>En,coerceType:()=>mA,makeTable:()=>gA,setServerUtilities:()=>fAe});function gA(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=XR(i,n,l),N,v,F={},$=Promise.resolve(),Y,ee,oe;for(let V of E)(V.assignCreatedTime||V.name==="__createdtime__")&&(Y=V),(V.assignUpdatedTime||V.name==="__updatedtime__")&&(ee=V),V.expiresAt&&(oe=V),V.isPrimaryKey&&(F=V);let j,se=[],z=[],me=1,Ae=2,Pe={},he={},Ot=864e5,ut=0,br,ms,xn,au=!1,cu,kA=new Map,FA=new Map,Mt,gf,Qh=Zl.get(x.REPLICATION_DATABASES);if(Array.isArray(Qh)){for(let V of Qh)if(V.name===c&&V.replicateTo>=0){gf=V.replicateTo;break}}let Xh=i.getRange({start:!1,end:!1}).constructor,Sf=10,Zh=6;g&&Rf(),Rh(i.env.path,V=>{if(v)return ca(V)});class Ie extends Vr{#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=ee;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(O=>!O.intermediateSource)){if(this.sources.some(O=>O.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),N=N||m.load;let b=a(O=>{let U=this.sources;if(U=U.filter(L=>L.intermediateSource&&L[O]&&(!L[O].reliesOnPrototype||L.prototype[O])),U.length>0)if(U.length===1){let L=U[0];return(C,B,q)=>{if(C?.source!==L)return L[O](B,q,C)}}else return(L,C,B)=>{let q=[];for(let Q of U){if(L?.source===Q)break;q.push(Q[O](C,B,L))}return Promise.all(q)}},"getApplyToIntermediateSource"),w=this.sources[this.sources.length-1];w.intermediateSource&&(w={});let y=a(O=>{if(w[O]&&(!w[O].reliesOnPrototype||w.prototype[O]))return(U,L,C)=>{if(!U?.source)return w[O](L,C,U)}},"getApplyToCanonicalSource");Pe={put:y("put"),patch:y("patch"),delete:y("delete"),publish:y("publish")},he={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish"),invalidate:b("invalidate")};let D=w.shouldRevalidateEvents;return(async()=>{let O=!1,U,L=a(async(C,B)=>{let q=C.value,Q=C.table?$e[c][C.table]:Ie;if(c===Of&&(C.table===_u.ROLE_TABLE_NAME||C.table===_u.USER_TABLE_NAME)&&(O=!0),C.id===void 0&&(C.id=q[Q.primaryKey],C.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(C));C.source=m;let X={residencyId:yc(C.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:C.nodeId},k=await Q.getResource(C.id,B,X);switch(C.finished&&await C.finished,C.type){case"put":return D?k._writeInvalidate(q,X):k._writeUpdate(q,!0,X);case"patch":return D?k._writeInvalidate(q,X):k._writeUpdate(q,!1,X);case"delete":return k._writeDelete(X);case"publish":return k._writePublish(q,X);case"invalidate":return k._writeInvalidate(q,X);case"relocate":return k._writeRelocate(X);default:xe.default.error?.("Unknown operation",C.type,C.id)}},"writeUpdate");try{let C=m.subscribe;C&&R==null&&(R=!0);let B={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},q=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Xl.getWorkerIndex)(),B):(0,Xl.getWorkerIndex)()===0,Q=C&&q&&await m.subscribe?.(B);if(Q){let X;for await(let k of Q)try{if(!(k.type==="transaction"?k.writes[0]:k)){xe.default.error?.("Bad subscription event",k);continue}if(k.source=m,k.type==="end_txn"){if(X?.resolve(),k.localTime&&U!==k.localTime){if(k.remoteNodeIds?.length>0){let fe=[Symbol.for("seq"),k.remoteNodeIds[0]],ie=f.get(fe),J=ie?.nodes;J||(J=[]);for(let Re of k.remoteNodeIds.slice(1)){let Te=J.find(ve=>ve.id===Re);J=J.filter(ve=>ve.id!==Re||ve===Te),Te||(Te={id:Re,seqId:0},J.push(Te)),Te.seqId=Math.max(ie?.seqId??1,k.localTime),Re===X?.nodeId&&(Te.lastTxnTime=k.timestamp)}let le=Math.max(ie?.seqId??1,k.localTime);xe.default.trace?.("Received txn",c,new Date(le),new Date(k.localTime),k.remoteNodeIds),f.put(fe,{seqId:le,nodes:J})}U=k.localTime}k.onCommit&&X?.committed.then(k.onCommit);continue}if(X)if(k.beginTxn)X.resolve();else{X.write_promises.push(L(k,X));continue}!k.timestamp&&k.version&&(k.timestamp=k.version);let re=Nt(k,()=>{if(k.type==="transaction"){let fe=[];for(let ie of k.writes)try{fe.push(L(ie,k))}catch(J){throw J.message+=" writing "+JSON.stringify(ie)+" of event "+JSON.stringify(k),J}return Promise.all(fe)}else if(k.type==="define_schema"){let fe=this.attributes.slice(0),ie;for(let J of k.attributes)fe.find(le=>le.name===J.name)||(fe.push(J),ie=!0);ie&&(dt({table:s,database:c,attributes:fe,origin:"cluster"}),xh.signalSchemaChange(new Bh.SchemaEventMsg(process.pid,Kt.CREATE_TABLE,c,s)))}else return k.beginTxn?(X=k,X.write_promises=[L(k,k)],new Promise(fe=>{X.resolve=()=>fe(Promise.all(X.write_promises))})):L(k,k)});X&&(X.committed=re),O&&re&&!re?.waitingForUserChange&&(re.then(()=>xh.signalUserChange(new Bh.UserEventMsg(process.pid))),re.waitingForUserChange=!0),k.onCommit&&(re?re.then(k.onCommit):k.onCommit())}catch(de){xe.default.error?.("error in subscription handler",de)}}}catch(C){xe.default.error?.(C)}})(),this}static get isCaching(){return v}static get shouldRevalidateEvents(){return this.prototype.get!==Ie.prototype.get}static getResource(m,T,b){let w=super.getResource(m,T,b);if(m!=null){Cr(m);try{if(w.getRecord?.())return w;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let y=!b?.async||i.cache?.get?.(m),D=Gr(T),O=D.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return lu(m,T,{transaction:O,ensureLoaded:b?.ensureLoaded},y,U=>{if(U?Ie._updateResource(w,U):w.#e=null,T.onlyIfCached&&T.noCacheStore){if(!w.doesExist())throw new Ir.ServerError("Entry is not cached",504)}else if(b?.ensureLoaded){let L=dn(m,U,T,w);if(L)return D?.disregardReadTxn(),w.#i=!0,HP(L,C=>(Ie._updateResource(w,C),w))}return w})}catch(y){throw y.message.includes("Unable to serialize object")&&(y.message+=": "+JSON.stringify(m)),y}}return w}static _updateResource(m,T){m.#r=T,m.#e=T?.value??null,m.#n=T?.version}ensureLoaded(){let m=dn(this.getId(),this.#r,this.getContext());if(m)return this.#i=!0,HP(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(!Mt){let y=i.getEntry(Symbol.for("id_allocation")),D=y?.value,O;if(D&&D.nodeName===server.hostname&&(!pAe(i)||D.pid===process.pid)){let U=D.start,L=D.end;O=U;for(let C of i.getKeys({start:L,end:U,limit:1,reverse:!0}))O=C}else D=w(y?.version??null),O=D.start;Mt=new BigInt64Array([BigInt(O)+1n]),Mt=new BigInt64Array(i.getUserSharedBuffer("id",Mt.buffer)),Mt.maxSafeId=D.end}let T=Number(Atomics.add(Mt,0,1n)),b=m==="Int"?512:1048576;if(T+b>=Mt.maxSafeId){let y=a(D=>{Mt.maxSafeId=T+(m==="Int"?1023:4194303);let O=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,U=D?void 0:i.useReadTransaction(),L=Number(Mt[0]);for(let q of i.getKeys({start:L+1,end:O,limit:1,transaction:U}))O=q;U?.done();let{value:C,version:B}=i.getEntry(Symbol.for("id_allocation"));if(Mt.maxSafeId<O){if(C.end>Mt.maxSafeId-100)return;xe.default.info?.("New id allocation",T,Mt.maxSafeId,B),i.put(Symbol.for("id_allocation"),{start:C.start,end:Mt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),B)}else{xe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${Mt.maxSafeId}, but id of ${O} detected`);let q=w(B);q.alreadyUpdated||Atomics.store(Mt,0,BigInt(q.start+1)),Mt.maxSafeId=q.end}},"updateEnd");T+b===Mt.maxSafeId?setImmediate(y):T+100>=Mt.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(()=>y(!0)))}return T;function w(y){let D=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=D/4,U,L,C=!1,B,q;do{B=Math.floor(Math.random()*D),q={start:B,end:B+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},U=0;for(let Q of i.getKeys({start:B,limit:1,reverse:!0}))U=Q;L=D;for(let Q of i.getKeys({start:B+1,end:D,limit:1}))L=Q;O*=.875,O<1e3&&!C&&(C=!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":""}`,B,U,L,O))}while(!(O<L-B&&(O<B-U||U===0)));return i.transactionSync(()=>{let Q=i.getEntry(Symbol.for("id_allocation"));return(Q?.version??null)==y?(xe.default.info?.("Allocated new id range",q),i.put(Symbol.for("id_allocation"),q,Date.now()),q):(xe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...Q.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,Ot=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Ot=Ot||(h+S)/4,ca()}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,T){if(Ie.getResidencyById)return Ie.getResidencyById(m[t]);let b=gf;if(T.replicateTo!=null){if(Array.isArray(T.replicateTo))return T.replicateTo.includes(server.hostname)?T.replicateTo:[server.hostname,...T.replicateTo];T.replicateTo>=0&&(b=T.replicateTo)}if(b>=0&&server.nodes){let w=[server.hostname];if(T.previousResidency)w.push(...T.previousResidency.slice(0,b));else{let y=server.nodes.map(U=>U.name),D=Math.floor(y.length*Math.random());w.push(...y.slice(D,D+b));let O=D+b-y.length;O>0&&w.push(...y.slice(0,O))}return w}}static enableAuditing(m=!0){g=m,m&&Rf(),Ie.audit=m}static coerceId(m){return m===""?null:mA(m,F)}static async dropTable(){delete $e[c][s];for(let m of i.getRange({versions:!0,snapshot:!1,lazy:!0}))m.metadataFlags&Gn&&m.value&&Aa(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 hA.default.remove(data_path),await hA.default.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));xh.signalSchemaChange(new Bh.SchemaEventMsg(process.pid,Kt.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 b=Af(m);if(b?.read){if(b.isSuperUser)return!0;let w=b.attribute_permissions,y=T?.select;if(w?.length>0||au&&y){if(T||(T={}),y){let D=w?.length>0&&BP(w,"read");T.select=y.map(O=>{let U=O.name||O;if(!D||D[U]){let L=xn[U]?.definition?.tableClass;if(L){if(O.name||(O={name:O}),!L.prototype.allowRead.call(null,m,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else T.select=w.filter(D=>D.read&&!xn[D.attribute_name]).map(D=>D.attribute_name);return T}else return!0}}allowUpdate(m,T){let b=Af(m);if(b?.update){let w=b.attribute_permissions;if(w?.length>0){let y=BP(w,"update");for(let D in T)if(!y[D])return!1;for(let D of w){let O=D.attribute_name;!D.update&&!(O in T)&&(T[O]=this.getProperty(O))}}return aa(this.getContext())}}allowCreate(m,T){if(this.isCollection){let b=Af(m);if(b?.insert){let w=b.attribute_permissions;if(w?.length>0){let y=BP(w,"insert");for(let D in T)if(!y[D])return!1;return aa(this.getContext())}else return aa(this.getContext())}}else return this.allowUpdate(m,{})}allowDelete(m){return Af(m)?.delete&&aa(this.getContext())}update(m,T){if(!Gr(this.getContext()))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let w;return typeof m=="object"&&m&&(T?(Object.isFrozen(m)&&(m={...m}),this.#e={},this.#t=m):(w=this.#t,w&&(m=Object.assign(w,m)),this.#t=m)),this._writeUpdate(this.#t,T),this}addTo(m,T){if(typeof T=="number"||typeof T=="bigint")this.#s===zj?this.set(m,(+this.getProperty(m)||0)+T):(this.#s||this.update(),this.set(m,new FE(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 b=this.getContext(),w=this.getId();Cr(w),Gr(this.getContext()).addWrite({key:w,store:i,invalidated:!0,entry:this.#r,before:Pe.invalidate?.bind(this,b,w),beforeIntermediate:he.invalidate?.bind(this,b,w),commit:a((D,O)=>{if(!(oa(D,O,T?.nodeId)<=0)){m??=null;for(let U in r)m||(m={}),m[U]===void 0&&(m[U]=this.getProperty(U));xe.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(D).toISOString()}`),A(w,m,this.#r,D,En,g,{user:b?.user,residencyId:T?.residencyId,nodeId:T?.nodeId},"invalidate")}},"commit")})}_writeRelocate(m){let T=this.getContext(),b=this.getId();Cr(b),Gr(this.getContext()).addWrite({key:b,store:i,invalidated:!0,entry:this.#r,before:Pe.relocate?.bind(this,T,b),beforeIntermediate:he.relocate?.bind(this,T,b),commit:a((y,D)=>{if(oa(y,D,m?.nodeId)<=0)return;let O=Ie.getResidencyRecord(m.residencyId),U=0,L=null,C=D?.value;if(O&&!O.includes(server.hostname)){for(let B in r)L||(L={}),L[B]=C(B);U=En}else L=C;xe.default.trace?.(`Relocating entry id: ${b}, timestamp: ${new Date(y).toISOString()}`),A(b,L,this.#r,y,U,g,{user:T.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(m,T){let b={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},w=Rc(this.getResidency(T.value,b)),y;if(w){if(!w.includes(server.hostname))return;y=yc(w)}let O=A(m.key,T.value,m,m.version,0,!0,{residencyId:y,expiresAt:T.expiresAt},"relocate",!1,null)}static evict(m,T,b){let w=this.Source,y;if(!((v||g)&&(!T||(y=i.getEntry(m),!y||!T)||y.version!==b))){if(v){if(i.hasLock(m,y.version))return;let D;for(let O in r)D||(D={}),D[O]=T[O];if(D)return A(m,D,y,b,Ea,null,null,null,!0)}if(i.ifVersion(m,b,()=>{un(m,T,null)}),g)return A(m,null,y,b,Ea,null,null,null,!0);kc(i,y??i.getEntry(m),b)}}lock(){throw new Error("Not yet implemented")}static operation(m,T){return m.table||=s,m.schema||=c,rJ.operation(m,T)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,T,b){let w=this.getContext(),y=Gr(w),D=this.getId();Cr(D);let O=this.#r;this.#s=T?zj:lAe;let U={key:D,store:i,entry:O,nodeName:w?.nodeName,validate:a(L=>{m||(m=this.#t),T||m&&HE(this.#t===m?this:m)?w?.source||(y.checkOverloaded(),this.validate(m,!T),ee&&(m[ee.name]=ee.type==="Date"?new Date(L):ee.type==="String"?new Date(L).toISOString():L),T&&(t&&m[t]!==D&&(m[t]=D),Y&&(O?.value?m[Y.name]=O?.value[Y.name]:m[Y.name]=Y.type==="Date"?new Date(L):Y.type==="String"?new Date(L).toISOString():L),m=il(m))):y.removeWrite(U)},"validate"),before:T?Pe.put?()=>Pe.put(w,D,m):null:Pe.patch?()=>Pe.patch(w,D,m):Pe.put?()=>Pe.put(w,D,il(this)):null,beforeIntermediate:T?he.put?()=>he.put(w,D,m):null:he.patch?()=>he.patch(w,D,m):he.put?()=>he.put(w,D,il(this)):null,commit:a((L,C,B)=>{if(B){if(w&&C?.version>(w.lastModified||0)&&(w.lastModified=C.version),this.#r=C,C?.value&&C.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");T||(this.#e=C?.value??null)}this.#t=void 0,this.#n=L;let q=C?.value,Q=m;this.#s=0;let X=!1,k=oa(L,C,b?.nodeId),de;if(k<=0)if(g){let le=C.localTime,Re=C.version;xe.default.trace?.("Applying CRDT update to record with id: ",D,"applying later update:",Re);let Te=[];for(;le>L||Re>=L&&le>0;){let ve=l.get(le);if(!ve)break;let Je=wt(ve);if(Re=Je.version,Re>=L){if(Re===L){if(k=oa(L,{version:Re,localTime:le},b?.nodeId),k===0)return;if(k>0)continue}if(Je.type==="patch")Te.push(Je),de=m;else if(Je.type==="put"||Je.type==="delete")return}le=Je.previousLocalTime}Te.sort((ve,Je)=>ve.version-Je.version);for(let ve of Te){let Je=ve.getValue(i);if(Q=xE(Q,Je,T),xe.default.debug?.("Rebuilding update with future patch:",Q),!Q)return}}else{if(T)return;Q=xE(Q,q,T),xe.default.debug?.("Rebuilding update without audit:",Q)}let re;if(T?re=Q:(this.#e=q,re=il(this,Q)),this.#e=re,re&&re.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let fe;if(b?.residencyId!=null)fe=b.residencyId;else{O?.residencyId&&(w.previousResidency=Ie.getResidencyRecord(O.residencyId));let le=Rc(Ie.getResidency(re,w));if(le&&!le.includes(server.hostname))if(de??=re,X=!0,Ie.getResidencyById)re=void 0;else{re=null;for(let Re in r)re||(re={}),re[Re]=de[Re]}fe=yc(le)}T||(de=m);let ie=w?.expiresAt??(h?h+Date.now():-1);xe.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(L).toISOString()}${ie?", expires at: "+new Date(ie).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(re).slice(0,100)}catch{return""}})()),un(D,q,re);let J=T?"put":"patch";A(D,re,C,L,X?En:0,g,{omitLocalRecord:X,user:w?.user,residencyId:fe,expiresAt:ie,nodeId:b?.nodeId,originatingOperation:w?.originatingOperation},J,!1,de),w.expiresAt&&ca()},"commit")};y.addWrite(U)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this.isCollection){for await(let T of this.search(m))(await Ie.getResource(T[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this.#e?this._writeDelete(m):!1}_writeDelete(m){let T=Gr(this.getContext()),b=this.getId();Cr(b);let w=this.getContext();return T.addWrite({key:b,store:i,entry:this.#r,nodeName:w?.nodeName,before:Pe.delete?.bind(this,w,b),beforeIntermediate:he.delete?.bind(this,w,b),commit:a((y,D,O)=>{let U=D?.value;O&&(w&&D?.version>(w.lastModified||0)&&(w.lastModified=D.version),Ie._updateResource(this,D)),!(oa(y,D,m?.nodeId)<=0)&&(un(this.getId(),U),xe.default.trace?.(`Deleting record with id: ${b}, txn timestamp: ${new Date(y).toISOString()}`),g||R?(A(b,null,this.#r,y,0,g,{user:w?.user,nodeId:m?.nodeId},"delete"),g||ca()):kc(i,D))},"commit")}),!0}search(m){let T=this.getContext(),b=Gr(T);if(!m)throw new Error("No query provided");let w=m.conditions;w?w.length===void 0&&(w=w[Symbol.iterator]?Array.from(w):[w]):w=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this.getId()&&(w=[{attribute:null,comparator:Array.isArray(this.getId())?"prefix":"starts_with",value:this.getId()}].concat(w));let y,D={};function O(J,le){let Re;switch(le){case"and":case void 0:if(J.length<1)throw new Error('An "and" operator requires at least one condition');Re=!0;break;case"or":if(J.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+le)}for(let Te of J){if(Te.conditions){Te.conditions=O(Te.conditions,Te.operator);continue}let ve=Te[0]??Te.attribute,Je=ve==null?F:Oi(E,ve);if(Je)(Je.type||hR[Te.comparator])&&(Te[1]===void 0?Te.value=L(Te.value,Je):Te[1]=L(Te[1],Je));else if(ve!=null)throw(0,Ir.handleHDBError)(new Error,`${ve} is not a defined attribute`,404);if(Te.chainedConditions)if(Te.chainedConditions.length===1&&(!Te.operator||Te.operator=="and")){let Zt=Te.chainedConditions[0],qr,ye;if(Zt.comparator==="gt"||Zt.comparator==="greater_than"||Zt.comparator==="ge"||Zt.comparator==="greater_than_equal"?(qr=Te,ye=Zt):(qr=Zt,ye=Te),qr.comparator!=="lt"&&qr.comparator!=="less_than"&&qr.comparator!=="le"&&qr.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let tt=ye.comparator==="ge"||ye.comparator==="greater_than_equal",vt=qr.comparator==="le"||qr.comparator==="less_than_equal";Te.comparator=(tt?"ge":"gt")+(vt?"le":"lt"),Te.value=[ye.value,qr.value]}else throw new Error("Multiple chained conditions are not currently supported")}return J}a(O,"prepareConditions");function U(J,le){if(m.enforceExecutionOrder)return J;for(let Re of J)Re.conditions&&(Re.conditions=U(Re.conditions,Re.operator));return J.length>1&&le!=="or"?(0,eJ.sortBy)(J,Om(Ie)):J}a(U,"orderConditions");function L(J,le){return Array.isArray(J)?J.map(Re=>mA(Re,le)):mA(J,le)}a(L,"coerceTypedValues");let C=m.operator;(w.length>0||C)&&(w=O(w,C));let B=typeof m.sort=="object"&&m.sort,q;if(B&&C!=="or"){let J=B.attribute;if(J==null)throw new Ir.ClientError("Sort requires an attribute");if(y=w.find(le=>Su(le.attribute)===Su(J)),!y){let le=Oi(E,J);if(!le)throw(0,Ir.handleHDBError)(new Error,`${Array.isArray(J)?J.join("."):J} is not a defined attribute`,404);if(le.indexed)y={attribute:J,comparator:"sort"},w.push(y);else if(w.length===0&&!m.allowFullScan)throw(0,Ir.handleHDBError)(new Error,`${Array.isArray(J)?J.join("."):J} is not indexed and not combined with any other conditions`,404)}y&&(y.descending=!!B.descending)}w=U(w,C),B&&(y&&w[0]===y?B.next&&(q={dbOrderedAttribute:B.attribute,attribute:B.next.attribute,descending:B.next.descending,next:B.next.next}):(y&&w.splice(w.indexOf(y),1),q=B));let Q=m.select;if(w.length===0&&(w=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:w,operator:C,postOrdering:q,selectApplied:!!Q};let X=b.useReadTxn(),k=mR(w,C,Ie,X,m,T,(J,le)=>du(J,Q,T,X,le),D),de=m.ensureLoaded!==!1;q||(k=ie(k));let re=Ie.transformEntryForSelect(Q,T,X,D,de,!0),fe=Ie.transformToOrderedSelect(k,Q,q,X,T,re);function ie(J){return m.offset||m.limit!==void 0?J.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):J}return a(ie,"applyOffset"),q&&(fe=ie(fe)),fe.onDone=()=>{fe.onDone=null,b.doneReadTxn()},fe.selectApplied=!0,fe.getColumns=()=>{if(Q){let J=[];for(let le of Q)le==="*"?J.push(...E.map(Re=>Re.name)):J.push(le.name||le);return J}return E.filter(J=>!J.computed&&!J.relationship).map(J=>J.name)},fe}static transformToOrderedSelect(m,T,b,w,y,D){let O=new Xh;if(b){m=du(m,T,w,y,null);let U;O.iterate=function(){let C,B=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),q,Q=b.dbOrderedAttribute,X,k,de=!0;function re(ie){let J=ie.next&&re(ie.next),le=ie.descending;return(Re,Te)=>{let ve=uu(Re,ie.attribute,w),Je=uu(Te,ie.attribute,w),Zt=le?(0,eu.compareKeys)(Je,ve):(0,eu.compareKeys)(ve,Je);return Zt===0?J?.(Re,Te)||0:Zt}}a(re,"createComparator");let fe=re(b);return{async next(){let ie;if(C)if(ie=C.next(),ie.done){if(q)return O.onDone&&O.onDone(),ie}else return{value:await D.call(this,ie.value)};U=[],X&&U.push(X);do if(ie=await B.next(),ie.done){if(q=!0,U.length)break;return O.onDone&&O.onDone(),ie}else{let J=ie.value;if(J?.then&&(J=await J),Q){let le=uu(J,Q,w);if(de)de=!1,k=le;else if(le!==k){k=le,X=J;break}}U.push(J)}while(!0);return b.isGrouped,U.sort(fe),C=U[Symbol.iterator](),ie=C.next(),ie.done?(O.onDone&&O.onDone(),ie):{value:await D.call(this,ie.value)}},return(){O.onDone&&O.onDone(),B.return()},throw(){O.onDone&&O.onDone(),B.throw()}}};let L=a(C=>{if(typeof T=="object"&&Array.isArray(C.attribute))for(let B=0;B<T.length;B++){let q=T[B],Q;if(q.name===C.attribute[0]){for(Q=q.sort||(q.sort={});Q.next;)Q=Q.next;Q.attribute=C.attribute.slice(1),Q.descending=C.descending}else q===C.attribute[0]&&(T[B]=Q={name:q,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&L(C.next)},"applySortingOnSelect");L(b)}else O.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),O=O.map(function(U){try{let L=D.call(this,U);return typeof L?.catch=="function"?L.catch(C=>{throw C.partialObject={[t]:U.key},C}):L}catch(L){throw L.partialObject={[t]:U.key},L}});return O}static transformEntryForSelect(m,T,b,w,y,D){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let C=a(B=>(T?.transaction?.stale&&(T.transaction.stale=!1),B?.key??B),"transform");return m===t?C:m.asArray?B=>[C(B)]:B=>({[t]:C(B)})}let O;y&&v&&!(typeof m=="string"?[m]:m)?.every(C=>{let B;return typeof C=="object"?B=C.name:B=C,r[B]||B===t})&&(O=!0);let U,L=a(function(C){let B;if(T?.transaction?.stale&&(T.transaction.stale=!1),C!=null){if(B=C.value||C.deref?.()?.value,!B&&(C.key===void 0||C.deref)||C.metadataFlags&En){if(C.metadataFlags&En&&T.replicateFrom===!1&&D&&C.residencyId)return Ec.SKIP;if(C=lu(C.key??C,T,{transaction:b,lazy:m?.length<4,ensureLoaded:y},this?.isSync,q=>q),C?.then)return C.then(L.bind(this));B=C?.value}if(O&&C?.metadataFlags&(En|Ea)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(T.onlyIfCached&&T.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let q=dn(C.key??C,C,T);if(q?.then)return q.then(L)}}if(B==null)return D?Ec.SKIP:B;if(m&&!(m[0]==="*"&&m.length===1)){let q,Q=a((k,de)=>{let re;typeof k=="object"?re=k.name:re=k;let fe=xn?.[re],ie;if(fe){let J=w?.[re];if(J)if(J.hasMappings){let Re=fe.from?B[fe.from]:Su(C.key);ie=J.get(Re),ie||(ie=[])}else ie=J.fromRecord?.(B);else ie=fe(B,T,C);let le=a(Re=>{if(Re&&typeof Re=="object"){let Te=fe.definition?.tableClass||Ie;U||(U={});let ve=U[re]||(U[re]=Te.transformEntryForSelect(re===k?null:k.select||(Array.isArray(k)?k:null),T,b,J,y));if(Array.isArray(Re)){let Je=[],Zt=Te.transformToOrderedSelect(Re,k.select,typeof k.sort=="object"&&k.sort,T,b,ve)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),qr=a(tt=>{for(;!tt.done;){if(tt?.then)return tt.then(qr);Je.push(tt.value),tt=Zt.next()}de(Je,re)},"nextValue"),ye=qr(Zt.next());ye&&(q||(q=[]),q.push(ye));return}else if(Re=ve.call(this,Re),Re?.then){q||(q=[]),q.push(Re.then(Je=>de(Je,re)));return}}de(Re,re)},"handleResolvedValue");ie?.then?(q||(q=[]),q.push(ie.then(le))):le(ie);return}else ie=B[re],ie&&typeof ie=="object"&&re!==k&&(ie=Ie.transformEntryForSelect(k.select||k,T,b,null)({value:ie}));de(ie,re)},"selectAttribute"),X;if(typeof m=="string")Q(m,k=>{X=k});else if(Array.isArray(m))if(m.asArray)X=[],m.forEach((k,de)=>{k==="*"?m[de]=B:Q(k,re=>X[de]=re)});else{X={};let k=m.forceNulls;for(let de of m)if(de==="*")for(let re in B)X[re]=B[re];else Q(de,(re,fe)=>{re===void 0&&k&&(re=null),X[fe]=re})}else throw new Ir.ClientError("Invalid select"+m);return q?Promise.all(q).then(()=>X):X}return B},"transform");return L}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,b=[],w=this,y=xP(Ie,this.getId()??null,function(O,U,L,C){try{let B=U.getValue?.(i,T),q=U.type;if(!B&&q==="patch"&&T){let X=i.getEntry(O);X?.version===U.version?B=X.value:B=U.getValue?.(i,!0,L),q="put"}let Q={id:O,localTime:L,value:B,version:U.version,type:q,beginTxn:C};b?b.push(Q):this.send(Q)}catch(B){xe.default.error?.(B)}},m.startTime||0,m),D=(async()=>{this.isCollection&&(y.includeDescendants=!0,m.onlyChildren&&(y.onlyChildren=!0)),m.supportsTransactions&&(y.supportsTransactions=!0);let O=this.getId(),U=m.previousCount;U>1e3&&(U=1e3);let L=m.startTime;if(this.isCollection){if(L){if(U)throw new Ir.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:C,value:B}of l.getRange({start:L,exclusiveStart:!0,snapshot:!1})){let q=wt(B);if(q.tableId!==n)continue;let Q=q.recordId;if(O==null||Xj(O,Q)){let X=q.getValue(i,T,C);if(y.send({id:Q,localTime:C,value:X,version:q.version,type:q.type}),y.queue?.length>Jj&&await y.waitForDrain()===!1)return}y.startTime=C}}else if(U){let C=[];for(let{key:B,value:q}of l.getRange({start:"z",end:!1,reverse:!0}))try{let Q=wt(q);if(Q.tableId!==n)continue;let X=Q.recordId;if(O==null||Xj(O,X)){let k=Q.getValue(i,T,B);if(C.push({id:X,localTime:B,value:k,version:Q.version,type:Q.type}),--U<=0)break}}catch(Q){xe.default.error("Error getting history entry",B,Q)}for(let B=C.length;B>0;)y.send(C[--B]);C[0]&&(y.startTime=C[0].localTime)}else if(!m.omitCurrent){for(let{key:C,value:B,version:q,localTime:Q}of i.getRange({start:O??!1,end:O==null?void 0:[O,eu.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(B&&(y.send({id:C,localTime:Q,value:B,version:q,type:"put"}),y.queue?.length>Jj&&await y.waitForDrain()===!1))return}}else{U&&!L&&(L=0);let C=this.#r?.localTime;if(C===QR&&(i.cache?.delete(O),this.#r=i.getEntry(O),xe.default.trace?.("re-retrieved record",C,this.#r?.localTime),C=this.#r?.localTime),xe.default.trace?.("Subscription from",L,"from",O,C),L<C){let B=[],q=C;do{let Q=l.get(q);if(Q){m.omitCurrent=!0;let X=wt(Q),k=X.getValue(i,T,q);T&&(X.type="put"),B.push({id:O,value:k,localTime:q,...X}),q=X.previousLocalTime}else break;U&&U--}while(q>L&&U!==0);for(let Q=B.length;Q>0;)y.send(B[--Q]);y.startTime=C}!m.omitCurrent&&this.doesExist()&&y.send({id:O,localTime:C,value:this.#e,version:this.#n,type:"put"})}for(let C of b)y.send(C);b=null})();return m.listener&&y.on("data",m.listener),y}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 b=Gr(this.getContext()),w=this.getId()||null;w!=null&&Cr(w);let y=this.getContext();b.addWrite({key:w,store:i,entry:this.#r,nodeName:y?.nodeName,validate:a(()=>{y?.source||(b.checkOverloaded(),this.validate(m))},"validate"),before:Pe.publish?.bind(this,y,w,m),beforeIntermediate:he.publish?.bind(this,y,w,m),commit:a((D,O,U)=>{O===void 0&&R&&!g&&ca(),xe.default.trace?.(`Publishing message to id: ${w}, timestamp: ${new Date(D).toISOString()}`),A(w,O?.value??null,O,O?.version||D,0,!0,{user:y?.user,residencyId:T?.residencyId,expiresAt:y?.expiresAt,nodeId:T?.nodeId},"message",!1,m)},"commit")})}validate(m,T){let b,w=a((y,D,O)=>{if(D.type&&y!=null)if(T&&y.__op__&&(y=y.value),D.properties){typeof y!="object"&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be an object${D.type?" ("+D.type+")":""}`);let U=D.properties;for(let L=0,C=U.length;L<C;L++){let B=U[L],q=w(y[B.name],B,O+"."+B.name);q&&(y[B.name]=q)}if(D.sealed&&y!=null&&typeof y=="object")for(let L in y)U.find(C=>C.name===L)||(b||(b=[])).push(`Property ${L} is not allowed within object in property ${O}`)}else switch(D.type){case"Int":(typeof y!="number"||y>>0!==y)&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof y!="number"||!(Math.floor(y)===y&&Math.abs(y)<=9007199254740992))&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof y!="number"&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a number`);break;case"ID":typeof y=="string"||y?.length>0&&y.every?.(U=>typeof U=="string")||(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof y!="string"&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a string`);break;case"Boolean":typeof y!="boolean"&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a boolean`);break;case"Date":if(!(y instanceof Date)){if(typeof y=="string"||typeof y=="number")return new Date(y);(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof y!="bigint"){if(typeof y=="string"||typeof y=="number")return BigInt(y);(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a bigint`)}break;case"Bytes":if(!(y instanceof Uint8Array)){if(typeof y=="string")return Buffer.from(y);(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(y instanceof Ii)){if(typeof y=="string"&&(y=Buffer.from(y)),y instanceof Buffer)return createBlob(y,{type:"text/plain"});(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a Blob`)}break;case"array":if(Array.isArray(y)){if(D.elements)for(let U=0,L=y.length;U<L;U++){let C=y[U],B=w(C,D.elements,O+"[*]");B&&(y[U]=B)}}else(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be an Array`);break}D.nullable===!1&&y==null&&(b||(b=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let y=0,D=E.length;y<D;y++){let O=E[y];if(!(O.relationship||O.computed)&&(!T||O.name in m)){let U=w(m[O.name],O,O.name);U&&(m[O.name]=U)}}if(d)for(let y in m)E.find(D=>D.name===y)||(b||(b=[])).push(`Property ${y} is not allowed`);if(b)throw new Ir.ClientError(b.join(". "))}getUpdatedTime(){return this.#n}wasLoadedFromSource(){return v?!!this.#i:void 0}static async addAttributes(m){let T=E.slice(0);for(let b of m){if(!b.name)throw new Ir.ClientError("Attribute name is required");if(b.name.match(/[`/]/))throw new Ir.ClientError("Attribute names cannot include backticks or forward slashes");(0,tJ.validateAttribute)(b.name),T.push(b)}return dt({table:s,database:c,schemaDefined:u,attributes:T}),Ie.indexingOperation}static async removeAttributes(m){let T=E.filter(b=>!m.includes(b.name));return dt({table:s,database:c,schemaDefined:u,attributes:T}),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,T=hA.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,b=1e3/2,w=performance.now(),y=Math.floor(T/2),D=m?.exactCount,O=0,U=0,L;for(let{value:C}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(C!=null&&O++,U++,await mc(),!D&&U<y&&performance.now()-w>b){L=U;break}if(L){let C=O;O=0;for(let{value:ie}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:L,snapshot:!1}))ie!=null&&O++,await mc();let B=L*2,q=(O+C)/B,Q=Math.pow((O-C+1)/L/2,2)+q*(1-q)/B,X=Math.max(Math.sqrt(Q)*T,1),k=Math.round(q*T),de=Math.max(k-1.96*X,O+C),re=Math.min(k+1.96*X,T),fe=Math.pow(10,Math.round(Math.log10(X)));return fe>k&&(fe=fe/10),O=Math.round(k/fe)*fe,{recordCount:O,estimatedRange:[Math.round(de),Math.round(re)]}}return{recordCount:O}}static updatedAttributes(){xn=this.propertyResolvers={$id:a((m,T,b)=>({value:b.key}),"$id"),$updatedtime:a((m,T,b)=>b.version,"$updatedtime"),$record:a((m,T,b)=>b?{value:m}:m,"$record")};for(let m of this.attributes){m.resolve=null;let T=m.relationship,b=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)"),b&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),au=!0,T.to)m.elements?.definition?(xn[m.name]=m.resolve=(w,y,D)=>{let O=w[T.from?T.from:t],U=m.elements.definition.tableClass;return D?gu({attribute:T.to,value:O},Gr(y).getReadTxn(),!1,U,!1).asArray:U.search([{attribute:T.to,value:O}],y).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,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 w=m.definition||m.elements?.definition;w?(xn[m.name]=m.resolve=(y,D,O)=>{let U=y[T.from];if(U!==void 0){if(m.elements){let L,C=U?.map(B=>{let q=O?w.tableClass.primaryStore.getEntry(B,{transaction:Gr(D).getReadTxn()}):w.tableClass.get(B,D);return q?.then&&(L=!0),q});return T.filterMissing?L?Promise.all(C).then(B=>B.filter(Zj)):C.filter(Zj):L?Promise.all(C):C}return O?w.tableClass.primaryStore.getEntry(U,{transaction:Gr(D).getReadTxn()}):w.tableClass.get(U,D)}},m.set=(y,D)=>{if(Array.isArray(D)){let O=D.map(U=>U.getId?.()||U[w.tableClass.primaryKey]);y[T.from]=O}else{let O=D.getId?.()||D[w.tableClass.primaryKey];y[T.from]=O}},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 b&&(typeof b.from=="function"&&this.setComputedAttribute(m.name,b.from),xn[m.name]=m.resolve=(w,y,D)=>{let O=typeof b.from=="string"?w[b.from]:w,U=this.userResolvers[m.name];if(U)return U(O,y,D);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]=()=>{}})}GE(this,this)}static setComputedAttribute(m,T){let b=Oi(E,m);if(!b){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!b.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 b;for(let{key:w,value:y}of l.getRange({start:0,end:m}))await mc(),wt(y).tableId===n&&(b=_A(l,w,y));if(T)for(let w of i.getRange({start:0,versions:!0})){let{key:y,value:D,localTime:O}=w;await mc(),D===null&&O<m&&(b=kc(i,w))}await b}static async*getHistory(m=0,T=1/0){for(let{key:b,value:w}of l.getRange({start:m||1,end:T})){await mc();let y=wt(w);y.tableId===n&&(yield{id:y.recordId,localTime:b,version:y.version,type:y.type,value:y.getValue(i,!0,b),user:y.user,operation:y.originatingOperation})}}static async getHistoryOfRecord(m){let T=[];if(m==null)throw new Error("An id is required");let b=i.getEntry(m);if(!b)return T;let w=b.localTime;if(!w)throw new Error("The entry does not have a local audit time");let y=0;do{await mc();let D=l.get(w);if(D){let O=wt(D);T.push({id:O.recordId,localTime:w,version:O.version,type:O.type,value:O.getValue(i,!0,w),user:O.user}),w=O.previousLocalTime}else break}while(y<1e3&&w);return T.reverse()}static cleanup(){j?.remove()}}Ie.updatedAttributes();let Tf=Ie.prototype;return h&&Ie.setTTLExpiration(h/1e3),oe&&fu(),Ie;function un(V,m,T){let b;for(let w in r){let y=r[w],D=y.isIndexing,O=xn[w],U=T&&(O?O(T):T[w]),L=m&&(O?O(m):m[w]);if(U===L&&!D)continue;b=!0;let C=y.indexNulls,B=(0,Uh.getIndexedValues)(U,C),q=(0,Uh.getIndexedValues)(L,C);if(q?.length>0){let Q=new Set(q);if(B=B?B.filter(X=>{if(Q.has(X))Q.delete(X);else return!0}):[],q=Array.from(Q),(q.length>0||B.length>0)&&Wj){let X=q.concat(B).map(k=>({key:k,value:V}));y.prefetch(X,Qj)}for(let X=0,k=q.length;X<k;X++)y.remove(q[X],V)}else B?.length>0&&Wj&&y.prefetch(B.map(Q=>({key:Q,value:V})),Qj);if(B)for(let Q=0,X=B.length;Q<X;Q++)y.put(B[Q],V)}return b}a(un,"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,eu.writeKey)(V,uAe,0)>jj)throw new Error("Primary key size is too large: "+V.length);return!0}a(Cr,"checkValidId");function lu(V,m,T,b,w){if(Ie.getResidencyById&&T.ensureLoaded&&m?.replicateFrom!==!1){let D=Rc(Ie.getResidencyById(V));if(D&&!D.includes(server.hostname)&&N)return N({key:V,residency:D}).then(w)}let y=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),T.transaction?.isDone)return w(null,V);let D=i.getEntry(V,T);return D?.residencyId&&D.metadataFlags&En&&N&&T.ensureLoaded&&m?.replicateFrom!==!1?N(D).then(O=>w(O,V),O=>(xe.default.error?.("Error loading remote record",V,D,T,O),w(null,V))):(D&&m&&(D?.version>(m.lastModified||0)&&(m.lastModified=D.version),D?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=D.localTime)),w(D,V))},"whenPrefetched");return b?y():me>0?(me--,y()):new Promise((D,O)=>{me===0?(me--,i.prefetch([V],()=>{U(),L()})):(se.push(V),z.push(L),se.length>Zh&&(me--,U()));function U(){if(se.length>0){let C=z;i.prefetch(se,()=>{me===-1?U():me++;for(let B of C)B()}),se=[],z=[],Ae>2&&Ae--}else me=Ae,Ae<Sf&&Ae++}a(U,"prefetch");function L(){try{D(y())}catch(C){O(C)}}a(L,"load")})}a(lu,"loadLocalRecord");function Af(V){if(!V?.role)return;let m=V.role.permission;if(m.super_user)return dAe;let T=m[c],b,w=T?.tables;if(w)return w[s];if(c==="data"&&(b=m[s])&&!b.tables)return b}a(Af,"getTablePermissions");function dn(V,m,T,b){if(v){let w=!1;if(T.noCache?w=!0:(m?(!m.value||m.metadataFlags&(En|Ea)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(w=!0):w=!0,Xn(!w,"cache-hit",s)),w){let y=em(V,m,T).then(D=>(D?.value&&D?.value.getRecord?.()&&xe.default.error?.("Can not assign a record that is already a resource"),T&&(D?.version>(T.lastModified||0)&&(T.lastModified=D.version),T.lastRefreshed=Date.now()),D));if(T?.onlyIfCached||m?.value&&b?.allowStaleWhileRevalidate?.(m,V)){if(y.catch(D=>xe.default.warn?.(D)),T?.onlyIfCached&&!b.doesExist())throw new Ir.ServerError("Entry is not cached",504);return}else return y}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return Ie.evict(m.key,m.value,m.version),m.value=null,{then(w){return w(m)}}}a(dn,"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 T=m.next;if(!T)return m=m.next=new Ic,m.lmdbDb=i,m;m=T}while(!0)}else return new Rm}a(Gr,"txnForContext");function uu(V,m,T){if(!V)return;let b=V.value||i.getEntry(V.key)?.value;if(typeof m=="object"){let y=xn,D=b;for(let O=0,U=m.length;O<U;O++){let L=m[O],C=y?.[L];D=C&&D?C(D,T,!0)?.value:D?.[L],y=C?.definition?.tableClass?.propertyResolvers}return D}let w=xn[m];return w?w(b,T):b[m]}a(uu,"getAttributeValue");function du(V,m,T,b,w){let y=w?.length,D={transaction:b,lazy:y>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},O;function U(L,C){let B=L?.value;if(!B)return Ec.SKIP;for(let q=0;q<y;q++)if(!O?.includes(q)&&!w[q](B,L))return Ec.SKIP;return C!==void 0&&(L.key=C),L}if(a(U,"processEntry"),y>0||!V.hasEntries){let L=V.map(C=>{if(O=null,typeof C=="object"&&C?.key!==void 0)return y>0?U(C):C;if(C==null)return Ec.SKIP;for(let B=0;B<y;B++){let Q=w[B].idFilter;if(Q){if(!Q(C))return Ec.SKIP;O||(O=[]),O.push(B)}}return lu(C,T,D,!1,U)});return Array.isArray(V)&&(L=L.filter(C=>C!==Ec.SKIP)),L.hasEntries=!0,L}return V}a(du,"transformToEntries");function oa(V,m,T=server.replication?.getThisNodeId(l)){if(V<=m?.version){if(m?.version===V&&T!==void 0){let b=server.replication?.exportIdMapping(l),w=m.localTime,y=w&&l.get(w);if(y){let D,O,U=wt(y);for(let L in b)b[L]===T&&(D=L),b[L]===U.nodeId&&(O=L);if(D>O)return 1;if(D===O)return 0}}return-1}return 1}a(oa,"precedesExistingVersion");async function em(V,m,T){let b=m?.metadataFlags,w=m?.version,y,D;if(!i.attemptLock(V,w,()=>{clearTimeout(D);let C=i.getEntry(V);!C||!C.value||C.metadataFlags&(En|Ea)?y(em(V,i.getEntry(V),T)):y(C)}))return new Promise(C=>{y=C,D=setTimeout(()=>{i.unlock(V,w)},cAe)});let O=m?.value,U={requestContext:T,replacingRecord:O,replacingEntry:m,replacingVersion:w,noCacheStore:!1,source:null,resourceCache:T?.resourceCache},L=T?.responseHeaders;return new Promise((C,B)=>{let q;HP(Nt(U,async Q=>{let X=performance.now(),k,de,re;try{for(let le of Ie.sources)if(le.get&&(!le.get.reliesOnPrototype||le.prototype.get)){if(le.available?.(m)===!1)continue;if(U.source=le,k=await le.get(V,U),k)break}re=b&En;let ie=U.lastModified||re&&w;de=re||ie>w||!O,ie||(ie=(0,Uh.getNextMonotonicTime)());let J=performance.now()-X;if(sr(J,"cache-resolution",s,null,"success"),L&&eg(L,"Server-Timing",`cache-resolve;dur=${J.toFixed(2)}`,!0),Q.timestamp=ie,h&&U.expiresAt==null&&(U.expiresAt=Date.now()+h),k){if(typeof k!="object")throw new Error("Only objects can be cached and stored in tables");if(k.status>0&&k.headers)if(k.status>=300)if(k.status===304)k=O,ie=w;else throw new Ir.ServerError(k.body||"Error from source",k.status);else k=k.body;typeof k.toJSON=="function"&&(k=k.toJSON()),t&&k[t]!==V&&(k[t]=V)}q=!0,C({key:V,version:ie,value:k})}catch(ie){ie.message+=` while resolving record ${V} for ${s}`,O&&((ie.code==="ECONNRESET"||ie.code==="ECONNREFUSED"||ie.code==="EAI_AGAIN")&&!T?.mustRevalidate||T?.staleIfError&&(ie.statusCode===500||ie.statusCode===502||ie.statusCode===503||ie.statusCode===504))?(C({key:V,version:w,value:O}),xe.default.trace?.(ie.message,"(returned stale record)")):B(ie);let J=performance.now()-X;sr(J,"cache-resolution",s,null,"fail"),L&&eg(L,"Server-Timing",`cache-resolve;dur=${J.toFixed(2)}`,!0),U.transaction.abort();return}if(T?.noCacheStore||U.noCacheStore){U.transaction.abort();return}Gr(U).addWrite({key:V,store:i,entry:m,nodeName:"source",commit:a((ie,J)=>{if(J?.version!==w)return;let le=un(V,O,k);if(k){he.put?.(U,V,k),J&&(T.previousResidency=Ie.getResidencyRecord(J.residencyId));let Re,Te=!1,ve,Je=Rc(Ie.getResidency(k,T));if(Je){if(!Je.includes(server.hostname))if(Re=k,Te=!0,Ie.getResidencyById)k=void 0;else{k=null;for(let Zt in r)k||(k={}),k[Zt]=Re[Zt]}ve=yc(Je)}xe.default.trace?.(`Writing resolved record from source with id: ${V}, timestamp: ${new Date(ie).toISOString()}`),A(V,k,J,ie,Te?En:0,g&&(de||Te)||null,{user:U?.user,expiresAt:U.expiresAt,residencyId:ve},"put",!!re,Re)}else J&&(he.delete?.(U,V),xe.default.trace?.(`Deleting resolved record from source with id: ${V}, timestamp: ${new Date(ie).toISOString()}`),g||R?A(V,null,J,ie,0,g&&de||null,{user:U?.user},"delete",!!re):kc(i,J,w))},"commit")})}),()=>{i.unlock(V,w)},Q=>{i.unlock(V,w),q&&xe.default.error?.("Error committing cache update",Q)})})}a(em,"getFromSource");function aa(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(aa,"checkContextPermissions");function ca(V){let m=!1;if(V&&(V-ut>1&&(m=!0),ut=V),!(Ot===br&&!m)&&(br=Ot,(0,Xl.getWorkerIndex)()===(0,Xl.getWorkerCount)()-1))return ms&&clearTimeout(ms),Ot?new Promise(T=>{let b=new Date;b.setMonth(0),b.setDate(1),b.setHours(0),b.setMinutes(0),b.setSeconds(0);let w=Ot/(1+ut),y=m?Date.now():Math.ceil((Date.now()-b.getTime())/w)*w+b.getTime(),D=a(O=>{xe.default.trace?.(`Scheduled next cleanup scan at ${new Date(O)}`),ms=setTimeout(()=>$=$.then(async()=>{if(D(Math.max(O+Ot,Date.now())),i.rootStore.status!=="open"){clearTimeout(ms);return}let U=50,L=new Array(U),C=0,B=Math.pow(ut,8)*(Zl.get(x.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),q=S/Math.pow(Math.max(ut,1),4);xe.default.info?.(`Starting cleanup scan for ${s}, evict threshold ${B}, adjusted eviction ${q}ms`);function Q(X,k,de,re){let fe=X+q-Date.now();if(fe<0)return!0;if(ut){let ie=i.lastSize;return de&Gn&&bu(re,J=>{J.size&&(ie+=J.size)}),xe.default.trace?.(`shouldEvict adjusted ${fe} ${ie}, ${fe*(X-k)/ie} < ${B}`),fe*(X-k)/ie<B}return!1}a(Q,"shouldEvict");try{let X=0;for(let k of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:de,value:re,version:fe,expiresAt:ie,metadataFlags:J}=k,le;re===null&&!g&&fe+aAe<Date.now()?le=kc(i,k,fe):ie!=null&&Q(ie,fe,J,re)&&(le=Ie.evict(de,re,fe),X++),le&&(await L[C],L[C]=le.catch(Re=>{xe.default.error?.("Cleanup error",Re)}),++C>=U&&(C=0)),await mc()}xe.default.info?.(`Finished cleanup scan for ${s}, evicted ${X} entries`)}catch(X){xe.default.warn?.(`Error in cleanup scan for ${s}:`,X)}T(void 0),ut=0}),Math.min(O-Date.now(),2147483647)).unref()},"startNextTimer");D(y)}):void 0}a(ca,"scheduleCleanup");function Rf(){j=l?.addDeleteRemovalCallback(n,i,(V,m)=>{i.remove(V,m)})}a(Rf,"addDeleteRemoval");function fu(){(0,Xl.getWorkerIndex)()===0&&setInterval(async()=>{if(!cu){cu=!0;try{let V=oe.name,m=r[V];if(!m)throw new Error(`expiresAt attribute ${oe} must be indexed`);for(let T of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let b of m.getValues(T)){let w=i.getEntry(b);w?.value?w.value[V]<Date.now()&&Ie.evict(b,w.value,w.version):i.ifVersion(b,w?.version,()=>m.remove(T,b))}await mc()}}catch(V){xe.default.error?.("Error in evicting old records",V)}finally{cu=!1}}},oAe).unref()}a(fu,"runRecordExpirationEviction");function Rc(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 xe.default.trace?.(`Shard ${V} mapped to ${m.map(T=>T.name).join(", ")}`),m.map(T=>T.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(Rc,"residencyFromFunction");function yc(V){if(V){let m=V.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],V),T)}}a(yc,"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 fAe(e){rJ=e}function mA(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 pA(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return pA(+e);case"Float":return e==="null"?null:pA(+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;_Ae.test(e)||(e+="Z");let n=new Date(e);return pA(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,EA.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function pA(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 Gs(e){try{return JSON.stringify(e)}catch{return e}}function pAe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Ec,Uh,eJ,tJ,Zl,Ir,xh,Bh,xe,eu,Xl,EA,hA,iAe,rJ,oAe,aAe,Wj,cAe,zj,lAe,En,Ea,uAe,jj,Jj,dAe,oxe,_Ae,mc,$f=be(()=>{H();Ec=require("lmdb"),Uh=M(pn()),eJ=require("lodash"),tJ=M(Bf());ga();ym();Zl=M(ce());AN();Ir=M(pe()),xh=M(Ao()),Bh=M(ni());De();qf();xe=M(wi());zb();Cc();eu=require("ordered-binary"),Xl=M(rt());_o();EA=M(ae());Iu();Fi();BE();j_();hA=M(require("node:fs"));Ss();xT();iAe=new Uint8Array(9);iAe[8]=192;oAe=6e4,aAe=864e5;Zl.initSync();Wj=Zl.get(x.STORAGE_PREFETCHWRITES),cAe=1e4,zj=1,lAe=2,En=1,Ea=8,uAe=Buffer.allocUnsafeSlow(8192),jj=1978,Jj=100,dAe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},oxe=(0,EA.convertToMS)(Zl.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(gA,"makeTable");a(BP,"attributesAsObject");a(Qj,"noop");a(fAe,"setServerUtilities");_Ae=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(mA,"coerceType");a(pA,"rejectNaN");a(Xj,"isDescendantId");mc=a(()=>new Promise(setImmediate),"rest");a(HP,"when");a(Zj,"exists");a(Gs,"stringify");a(pAe,"hasOtherProcesses")});var nt={};Ue(nt,{database:()=>$u,database_envs:()=>ta,databases:()=>$e,dropDatabase:()=>Zb,dropTableMeta:()=>SAe,getDatabases:()=>Xe,getDefaultCompression:()=>PS,getTables:()=>hAe,onRemovedDB:()=>hp,onUpdatedTable:()=>Al,readMetaDb:()=>Hh,resetDatabases:()=>Ld,table:()=>dt,tables:()=>Qn});function hAe(){return RA||Xe(),Qn||{}}function Xe(){if(RA)return $e;RA=!0,_f=new Map;let e=(0,Xt.getHdbBasePath)()&&(0,Dt.join)((0,Xt.getHdbBasePath)(),wc),t=(0,Xt.get)(x.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Xt.get)(x.STORAGE_PATH)||e&&((0,ds.existsSync)(e)?e:(0,Dt.join)((0,Xt.getHdbBasePath)(),am)),!e)return;if((0,ds.existsSync)(e))for(let n of(0,ds.readdirSync)(e,{withFileTypes:!0})){let s=(0,Dt.basename)(n.name,".mdb");n.isFile()&&(0,Dt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&Hh((0,Dt.join)(e,n.name),null,s)}if((0,ds.existsSync)((0,ff.getBaseSchemaPath)())){for(let n of(0,ds.readdirSync)((0,ff.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Dt.join)((0,ff.getBaseSchemaPath)(),n.name),i=(0,Dt.join)((0,ff.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,ds.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Dt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Dt.join)(i,o.name);Hh((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,ds.existsSync)(i))for(let c of(0,ds.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Dt.extname)(c.name).toLowerCase()===".mdb"&&Hh((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,ds.existsSync)(u)&&Hh(u,c,n,null,!0)}}for(let n in $e){let s=_f.get(n);if(s){let i=$e[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 $e[n],n==="data"){for(let i in Qn)delete Qn[i];delete Qn[yA]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if($e.system)for(let n of r)$e.system[n]&&($e.system[n].replicate=!1);return _f=null,$e}function Ld(){RA=!1;for(let[,e]of ta)e.needsDeletion=!0;Xe();for(let[e,t]of ta)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),ta.delete(e),delete $e[t.databaseName],Fh.forEach(r=>r(t.databaseName)));return $e}function Hh(e,t,r=GP,n,s){let i=new kP.default(e,!1);try{let o=ta.get(e);o?o.needsDeletion=!1:(o=(0,pf.open)(i),ta.set(e,o));let c=new tu.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(SA.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,ds.existsSync)(n)&&(i.path=n,u=(0,pf.open)(i),u.isLegacy=!0):u=fA(o));let f=oJ(r),d=f[yA],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 z of S)if(z.is_hash_attribute||z.isPrimaryKey){g=z;break}if(!g){qt.warn(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(S)}`);continue}}let R=f[_],E={},A=[],N,v,F=typeof g.audit=="boolean"?g.audit:(0,Xt.get)(x.LOGGING_AUDITLOG),$=g.trackDeletes,Y=g.expiration,ee=g.eviction,oe=g.sealed,j=g.splitSegments,se=g.replicate;if(R)E=R.indices,A=R.attributes,R.schemaVersion++;else{N=g.tableId,N?N>=(l.get(df)||0)&&(l.putSync(df,N+1),qt.info(`Updating next table id (it was out of sync) to ${N+1} for ${_}`)):(g.tableId=N=l.get(df),N||(N=1),qt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(df,N+1),l.putSync(g.key,g));let z=new tu.default(!g.is_hash_attribute,g.is_hash_attribute);if(z.compression=g.compression,z.compression){let me=(0,Xt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iJ;z.compression.threshold=me}v=Qm(o.openDB(g.key,z),o),o.databaseName=r,v.tableId=N}for(let z of S){z.attribute=z.name;try{if(!z.is_hash_attribute&&(z.indexed||z.attribute&&!z.name)){if(!E[z.name]){let Ae=new tu.default(!z.is_hash_attribute,z.is_hash_attribute);E[z.name]=o.openDB(z.key,Ae),E[z.name].indexNulls=z.indexNulls}let me=A.find(Ae=>Ae.name===z.name);me?A.splice(A.indexOf(me),1,z):A.push(z)}}catch(me){qt.error("Error trying to update attribute",z,A,E,me)}}if(!R){R=aJ(f,_,gA({primaryStore:v,auditStore:u,audit:F,sealed:oe,splitSegments:j,replicate:se,expirationMS:Y&&Y*1e3,evictionMS:ee&&ee*1e3,trackDeletes:$,tableName:_,tableId:N,primaryKey:g.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:E,attributes:S,schemaDefined:g.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let z of kh)z(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function oJ(e){let t=$e[e];if(t||(e==="data"?t=$e[e]=Qn:e==="system"?Object.defineProperty($e,"system",{value:t=Object.create(null),configurable:!0}):t=$e[e]=Object.create(null)),_f&&!_f.has(e)){let r=new Set;t[yA]=r,_f.set(e,r)}return t}function aJ(e,t,r){return e[t]=r,r}function $u({database:e,table:t}){e||(e=GP),Xe();let r=oJ(e),n=(0,Dt.join)((0,Xt.getHdbBasePath)(),wc),s=(0,Xt.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,Xt.get)(x.STORAGE_PATH)||((0,ds.existsSync)(n)?n:(0,Dt.join)((0,Xt.getHdbBasePath)(),am));let o=(0,Dt.join)(n,(i?t:e)+".mdb"),c=ta.get(o);if(!c||c.status==="closed"){let l=new kP.default(o,!1);c=(0,pf.open)(l),ta.set(o,c)}return c.auditStore||(c.auditStore=fA(c)),c}async function Zb(e){if(!$e[e])throw new Error("Schema does not exist");let t=$e[e],r;for(let n in t)r=t[n].primaryStore.rootStore,ta.delete(r.path),r.status==="open"&&(await r.close(),await Gh.remove(r.path));if(r||(r=$u({database:e,table:null}),r.status==="open"&&(await r.close(),await Gh.remove(r.path))),e==="data"){for(let n in Qn)delete Qn[n];delete Qn[yA]}delete $e[e],Fh.forEach(n=>n(e)),await CR(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=GP);let h=$u({database:r,table:t}),S=$e[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,A;p==null&&(p=!0);let N=new tu.default(!1);for(let j of o)j.attribute&&!j.name?(j.name=j.attribute,j.indexed=!0):j.attribute=j.name,j.expiresAt&&(j.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 j=h.auditStore;E=o.find(Ae=>Ae.isPrimaryKey)||{},R=E.name,E.is_hash_attribute=E.isPrimaryKey=!0,E.schemaDefined=p,E.compression=PS(),d&&(E.trackDeletes=!0),c=E.audit=typeof c=="boolean"?c:(0,Xt.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 se=new tu.default(!1,!0);se.compression=E.compression;let z=t+"/";if(A=h.dbisDb=h.openDB(SA.INTERNAL_DBIS_NAME,N),oe(),A.get(z))return F&&F(),Ld(),dt(e);let me=Qm(h.openDB(z,se),h);h.databaseName=r,me.tableId=A.get(df),qt.trace(`Assigning new table id ${me.tableId} for ${t}`),me.tableId||(me.tableId=1),A.put(df,me.tableId+1),E.tableId=me.tableId,g=aJ(S,t,gA({primaryStore:me,auditStore:j,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:A})),g.schemaVersion=1,v=!0,A.put(z,E)}let $=g.indices;A=A||(h.dbisDb=h.openDB(SA.INTERNAL_DBIS_NAME,N)),g.dbisDB=A;let Y=[];for(let{key:j,value:se}of A.getRange({start:!0})){let[z,me]=j.toString().split("/");if(me===""&&(me=se.name),me){if(z!==t)continue}else continue;let Ae=o.find(he=>he.name===me),Pe=!Ae?.indexed&&se.indexed&&!se.isPrimaryKey;if((!Ae||Pe)&&(oe(),v=!0,Ae||A.remove(j),Pe)){let he=g.indices[z];he&&Y.push(he)}}let ee=[];try{for(let j of o||[]){if((j.relationship||j.computed)&&(v=!0,j.relationship))continue;let se=t+"/"+(j.name||"");Object.defineProperty(j,"key",{value:se,configurable:!0});let z=A.get(se);if(j.isPrimaryKey){if(z=z||A.get(se=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||f!==void 0&&f!==g.replicate||(+n||void 0)!==(+z.expiration||void 0)||(+s||void 0)!==(+z.eviction||void 0)){let Ae={...z};typeof c=="boolean"&&(c&&g.enableAuditing(c),Ae.audit=c),n&&(Ae.expiration=+n),s&&(Ae.eviction=+s),l!==void 0&&(Ae.sealed=l),f!==void 0&&(Ae.replicate=f),v=!0,oe(),A.put(se,Ae)}continue}z?.attribute&&!z.name&&(z.indexed=!0);let me=!z||z.type!==j.type||z.indexed!==j.indexed||z.nullable!==j.nullable||z.version!==j.version||JSON.stringify(z.properties)!==JSON.stringify(j.properties)||JSON.stringify(z.elements)!==JSON.stringify(j.elements);if(j.indexed){let Ae=new tu.default(!0,!1),Pe=h.openDB(se,Ae);(me||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<qh.workerData?.restartNumber)&&(v=!0,oe(),z=A.get(se),(me||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<qh.workerData?.restartNumber)&&(v=!0,j.indexNulls===void 0&&(j.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(j.lastIndexedKey=z?.lastIndexedKey??void 0,j.indexingPID=process.pid,Pe.isIndexing=!0,Object.defineProperty(j,"dbi",{value:Pe}),ee.push(j))),A.put(se,j)),z?.indexNulls&&j.indexNulls===void 0&&(j.indexNulls=!0),Pe.indexNulls=j.indexNulls,$[j.name]=Pe}else me&&(v=!0,oe(),A.put(se,j))}}finally{F&&F()}if(v&&(g.schemaVersion++,g.updatedAttributes()),qt.trace(`${t} table loading, running index`),ee.length>0||Y.length>0?g.indexingOperation=gAe(g,ee,Y):v&&TA.signalSchemaChange(new AA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,v)for(let j of kh)j(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),qt.trace(`${t} table loaded`),g;function oe(){F||h.transactionSync(()=>({then(j){F=j}}))}a(oe,"startTxn")}async function gAe(e,t,r){try{qt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await TA.signalSchemaChange(new AA.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,pf.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,nJ.getIndexedValues)(E);if(A)for(let N=0,v=A.length;N<v;N++)S.dbi.put(A[N],d)}catch(R){o[g]||(o[g]=!0,qt.error(`Error indexing attribute ${g}`,R))}}}),s.then(()=>f--,h=>{f--,qt.error(h)}),qh.workerData&&qh.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>mAe?await s:f>EAe&&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 TA.signalSchemaChange(new AA.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 SAe({table:e,database:t}){let r=$u({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 Al(e){return kh.push(e),{remove(){let t=kh.indexOf(e);t>-1&&kh.splice(t,1)}}}function hp(e){return Fh.push(e),{remove(){let t=Fh.indexOf(e);t>-1&&Fh.splice(t,1)}}}function PS(){let e=(0,Xt.get)(x.STORAGE_COMPRESSION),t=(0,Xt.get)(x.STORAGE_COMPRESSION_DICTIONARY),r=(0,Xt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iJ,n={startingOffset:32};return t&&(n.dictionary=Gh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Xt,SA,pf,Dt,ds,ff,tu,kP,Gh,FP,nJ,TA,AA,qh,qt,sJ,GP,yA,iJ,Qn,$e,df,kh,Fh,RA,ta,_f,mAe,EAe,De=be(()=>{Xt=M(ce()),SA=M(xt()),pf=require("lmdb"),Dt=require("path"),ds=require("fs"),ff=M(Et());$f();tu=M(i_()),kP=M(o_());H();Gh=M(require("fs-extra")),FP=M(Ai()),nJ=M(pn()),TA=M(Ao()),AA=M(ni()),qh=require("worker_threads"),qt=M(W()),sJ=M(rt());_o();Iu();Ss();GP="data",yA=Symbol("defined-tables"),iJ=((0,Xt.get)(x.STORAGE_PAGESIZE)||4096)-60;(0,Xt.initSync)();Qn=Object.create(null),$e=Object.create(null);(0,FP._assignPackageExport)("databases",$e);(0,FP._assignPackageExport)("tables",Qn);df=Symbol.for("next-table-id"),kh=[],Fh=[],ta=new Map;a(hAe,"getTables");a(Xe,"getDatabases");a(Ld,"resetDatabases");a(Hh,"readMetaDb");a(oJ,"ensureDB");a(aJ,"setTable");a($u,"database");a(Zb,"dropDatabase");a(dt,"table");mAe=1e3,EAe=10;a(gAe,"runIndexing");a(SAe,"dropTableMeta");a(Al,"onUpdatedTable");a(hp,"onRemovedDB");a(PS,"getDefaultCompression")});var ae=I((Exe,AJ)=>{"use strict";var gc=require("path"),fJ=require("fs-extra"),vn=W(),cJ=require("fs-extra"),bA=require("os"),TAe=require("net"),AAe=require("recursive-iterator"),yr=(H(),P(G)),{PACKAGE_ROOT:RAe}=st(),yAe=oR(),lJ=require("papaparse"),OA=require("moment"),{inspect:bAe}=require("util"),uJ=require("is-number"),mxe=require("lodash"),OAe=require("minimist"),NAe=require("https"),wAe=require("http"),{hdb_errors:NA}=pe(),IAe=/^((\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),CAe=100,PAe=5,DAe="",LAe=4,dJ={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};AJ.exports={isEmpty:fs,isEmptyOrZeroLength:ro,arrayHasEmptyValues:UAe,arrayHasEmptyOrZeroLengthValues:xAe,buildFolderPath:BAe,isBoolean:pJ,errorizeMessage:MAe,stripFileExtension:kAe,autoCast:FAe,autoCastJSON:hJ,autoCastJSONDeep:$P,removeDir:GAe,compareVersions:qAe,isCompatibleDataVersion:$Ae,escapeRawValue:VAe,unescapeValue:KAe,stringifyProps:YAe,timeoutPromise:zAe,isClusterOperation:JAe,getClusterUser:XAe,checkGlobalSchemaTable:QAe,getHomeDir:EJ,getPropsFilePath:WAe,promisifyPapaParse:ZAe,removeBOM:gJ,createEventPromise:eRe,checkProcessRunning:tRe,checkSchemaTableExist:rRe,checkSchemaExists:SJ,checkTableExists:TJ,getStartOfTomorrowInSeconds:nRe,getLimitKey:sRe,isObject:HAe,isNotEmptyAndHasValue:vAe,autoCasterIsNumberCheck:mJ,backtickASTSchemaItems:iRe,isPortTaken:jAe,createForkArgs:oRe,autoCastBoolean:aRe,async_set_timeout:_J,getTableHashAttribute:cRe,doesSchemaExist:lRe,doesTableExist:uRe,stringifyObj:dRe,ms_to_time:fRe,changeExtension:_Re,getEnvCliRootPath:VP,noBootFile:pRe,httpRequest:hRe,transformReq:mRe,convertToMS:ERe,PACKAGE_ROOT:RAe};function MAe(e){return e instanceof Error?e:new Error(e)}a(MAe,"errorizeMessage");function fs(e){return e==null}a(fs,"isEmpty");function vAe(e){return!fs(e)&&(e||e===0||e===""||pJ(e))}a(vAe,"isNotEmptyAndHasValue");function ro(e){return fs(e)||e.length===0||e.size===0}a(ro,"isEmptyOrZeroLength");function UAe(e){if(fs(e))return!0;for(let t=0;t<e.length;t++)if(fs(e[t]))return!0;return!1}a(UAe,"arrayHasEmptyValues");function xAe(e){if(ro(e))return!0;for(let t=0;t<e.length;t++)if(ro(e[t]))return!0;return!1}a(xAe,"arrayHasEmptyOrZeroLengthValues");function BAe(...e){try{return e.join(gc.sep)}catch{console.error(e)}}a(BAe,"buildFolderPath");function pJ(e){return fs(e)?!1:e===!0||e===!1}a(pJ,"isBoolean");function HAe(e){return fs(e)?!1:typeof e=="object"}a(HAe,"isObject");function kAe(e){return ro(e)?DAe:e.slice(0,-LAe)}a(kAe,"stripFileExtension");function FAe(e){return fs(e)||e===""||typeof e!="string"?e:dJ[e]!==void 0?dJ[e]:mJ(e)===!0?Number(e):IAe.test(e)?new Date(e):e}a(FAe,"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 GAe(e){if(ro(e))throw new Error(`Directory path: ${e} does not exist`);try{await cJ.emptyDir(e),await cJ.remove(e)}catch(t){throw vn.error(`Error removing files in ${e} -- ${t}`),t}}a(GAe,"removeDir");function qAe(e,t){if(ro(e)){vn.info("Invalid current version sent as parameter.");return}if(ro(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(qAe,"compareVersions");function $Ae(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a($Ae,"isCompatibleDataVersion");function VAe(e){if(fs(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(VAe,"escapeRawValue");function KAe(e){if(fs(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(KAe,"unescapeValue");function YAe(e,t){if(fs(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+bA.EOL}!ro(n)&&n[0]===";"?r+=" "+n+s+bA.EOL:ro(n)||(r+=n+"="+s+bA.EOL)}catch{vn.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(YAe,"stringifyProps");function EJ(){let e;try{e=bA.homedir()}catch{e=process.env.HOME}return e}a(EJ,"getHomeDir");function WAe(){let e=gc.join(EJ(),yr.HDB_HOME_DIR_NAME,yr.BOOT_PROPS_FILE_NAME);return fJ.existsSync(e)||(e=gc.join(__dirname,"../","hdb_boot_properties.file")),e}a(WAe,"getPropsFilePath");function zAe(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(zAe,"timeoutPromise");async function jAe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=TAe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(jAe,"isPortTaken");function JAe(e){try{return yr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){vn.error(`Error checking operation against cluster ops ${t}`)}return!1}a(JAe,"isClusterOperation");function QAe(e,t){let r=(De(),P(nt)).getDatabases();if(!r[e])return NA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return NA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(QAe,"checkGlobalSchemaTable");function XAe(e,t){if(fs(t)){vn.warn("No CLUSTERING_USER defined, clustering disabled");return}if(fs(e)||ro(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(XAe,"getClusterUser");function ZAe(){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(ZAe,"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 eRe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;vn.info(`Got cluster status event response: ${bAe(s)}`);try{i.cancel()}catch{vn.error("Error trying to cancel timeout.")}n(s)})})}a(eRe,"createEventPromise");async function tRe(e){let t=!0,r=0;do await _J(CAe*r++),(await yAe.findPs(e)).length>0&&(t=!1);while(t&&r<PAe);if(t)throw new Error(`process ${e} was not started`)}a(tRe,"checkProcessRunning");function rRe(e,t){let r=SJ(e);if(r)return r;let n=TJ(e,t);if(n)return n}a(rRe,"checkSchemaTableExist");function SJ(e){let{getDatabases:t}=(De(),P(nt));if(!t()[e])return NA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(SJ,"checkSchemaExists");function TJ(e,t){let{getDatabases:r}=(De(),P(nt));if(!r()[e][t])return NA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(TJ,"checkTableExists");function nRe(){let e=OA().utc().add(1,"d").startOf("d").unix(),t=OA().utc().unix();return e-t}a(nRe,"getStartOfTomorrowInSeconds");function sRe(){return OA().utc().format("DD-MM-YYYY")}a(sRe,"getLimitKey");function iRe(e){try{let t=new AAe(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(iRe,"backtickASTSchemaItems");function oRe(e){return[e]}a(oRe,"createForkArgs");function aRe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(aRe,"autoCastBoolean");function cRe(e,t){let{getDatabases:r}=(De(),P(nt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(cRe,"getTableHashAttribute");function lRe(e){let{getDatabases:t}=(De(),P(nt));return t()[e]!==void 0}a(lRe,"doesSchemaExist");function uRe(e,t){let{getDatabases:r}=(De(),P(nt));return r()[e]?.[t]!==void 0}a(uRe,"doesTableExist");function dRe(e){try{return JSON.stringify(e)}catch{return e}}a(dRe,"stringifyObj");function fRe(e){let t=OA.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(fRe,"ms_to_time");function _Re(e,t){let r=gc.basename(e,gc.extname(e));return gc.join(gc.dirname(e),r+t)}a(_Re,"changeExtension");function VP(){if(process.env[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=OAe(process.argv);if(e[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(VP,"getEnvCliRootPath");var qP;function pRe(){if(qP)return qP;let e=VP();if(VP()&&fJ.pathExistsSync(gc.join(e,yr.HDB_CONFIG_FILE)))return qP=!0,!0}a(pRe,"noBootFile");function hRe(e,t){let r;return e.protocol==="http:"?r=wAe:r=NAe,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(hRe,"httpRequest");function mRe(e){if(!e.schema&&!e.database){e.schema=yr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(mRe,"transformReq");function ERe(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(ERe,"convertToMS")});var ce=I((NJ,wJ)=>{"use strict";var KP=require("fs-extra"),ru=require("path"),RJ=require("os"),gRe=require("properties-reader"),Vh=W(),$h=ae(),Me=(H(),P(G)),wA=Rt(),SRe="Error initializing environment manager",IA="BOOT_PROPS_FILE_PATH",yJ=!1,TRe={[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(NJ,wJ.exports={BOOT_PROPS_FILE_PATH:IA,getHdbBasePath:ARe,setHdbBasePath:RRe,get:bJ,initSync:bRe,setProperty:Ye,initTestEnvironment:NRe,setCloneVar:ORe});function ARe(){return ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(ARe,"getHdbBasePath");function RRe(e){ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(RRe,"setHdbBasePath");function bJ(e){let t=wA.getConfigValue(e);return t===void 0?ra[e]:t}a(bJ,"get");function Ye(e,t){TRe[e]&&(ra[e]=t),wA.updateConfigObject(e,t)}a(Ye,"setProperty");function yRe(){let e;try{e=$h.getPropsFilePath(),KP.accessSync(e,KP.constants.F_OK|KP.constants.R_OK),yJ=!0;let t=gRe(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[IA]=e,!0}catch{return Vh.trace(`Environment manager found no properties file at ${e}`),!1}}a(yRe,"doesPropFileExist");function bRe(e=!1){try{((yJ||yRe()||$h.noBootFile())&&!OJ||e)&&(wA.initConfig(e),ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=wA.getConfigValue(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Vh.error(SRe),Vh.error(t),console.error(t),process.exit(1)}}a(bRe,"initSync");var OJ=!1;function ORe(e){OJ=e}a(ORe,"setCloneVar");function NRe(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=ru.join(__dirname,"../../","unitTests");ra[IA]=ru.join(l,"hdb_boot_properties.file"),Ye(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,ru.join(l,"settings.test")),Ye(Me.HDB_SETTINGS_NAMES.INSTALL_USER,RJ.userInfo()?RJ.userInfo().username:void 0),Ye(Me.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ye(Me.HDB_SETTINGS_NAMES.LOG_PATH_KEY,ru.join(l,"envDir","log")),Ye(Me.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ye(Me.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ye(Me.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ye(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,ru.join(l,"envDir")),Ye(Me.CONFIG_PARAMS.STORAGE_PATH,ru.join(l,"envDir")),s&&(Ye(Me.CONFIG_PARAMS.HTTP_SECUREPORT,bJ(Me.CONFIG_PARAMS.HTTP_PORT)),Ye(Me.CONFIG_PARAMS.HTTP_PORT,null)),Ye(Me.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ye(Me.CONFIG_PARAMS.HTTP_PORT,9926),Ye(Me.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ye(Me.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Ye(Me.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,$h.isEmpty(i)?!1:i),Ye(Me.CONFIG_PARAMS.HTTP_CORS,$h.isEmpty(i)?!1:i),Ye(Me.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ye(Me.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,ru.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ye(Me.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,$h.isEmpty(c)?!1:c),o&&(Ye("CORS_ACCESSLIST",o),Ye(Me.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ye(Me.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ye(Me.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ye(Me.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${IA}. Please check your boot props and settings files`;Vh.fatal(r),Vh.error(t)}}a(NRe,"initTestEnvironment")});var LJ=I((Txe,DJ)=>{"use strict";var PA=ce();PA.initSync();var CA=(H(),P(G)),{httpRequest:wRe}=ae(),PJ=require("path"),IJ=require("fs-extra"),IRe=require("yaml"),{packageDirectory:CRe}=(Kw(),P(Vw)),{encode:PRe}=require("cbor-x"),DRe=["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:vRe,buildRequest:MRe};var LRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await CRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=PJ.basename(t))},"deploy_component")};function MRe(){let e={};for(let t of process.argv.slice(2))if(DRe.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(MRe,"buildRequest");async function vRe(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(PA.get(CA.CONFIG_PARAMS.ROOTPATH),CA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),IJ.existsSync(PA.get(CA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await LRe[e.operation]?.(e);try{let r=t??{protocol:"http:",socketPath:PA.get(CA.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=PRe(e));let n=await wRe(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(IRe.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(vRe,"cliOperations")});var UJ=I((Rxe,vJ)=>{"use strict";var MJ=require("semver/functions/major"),{packageJson:URe}=st(),YP=process.versions&&process.versions.node?process.versions.node:void 0;vJ.exports=xRe;function xRe(){let e=URe.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(xRe,"checkNodeVersion")});var ZP=I((Oxe,r2)=>{"use strict";var xJ=require("os"),DA=require("https"),BJ=require("http"),$t=require("fs-extra"),HJ=require("yaml"),{pipeline:kJ}=require("stream/promises"),{createWriteStream:LA,ensureDir:Kh,writeFileSync:FJ}=require("fs-extra"),{join:Vs}=require("path"),VJ=require("lodash"),BRe=require("minimist"),na=require("path"),HRe=require("node:crypto"),kRe=require("properties-reader"),$s=ce(),FRe=Do(),JP=W(),MA=Rt(),{restart:GRe}=ja(),vA=ae(),qRe=da(),$Re=Rs(),{main:UA,launch:VRe}=Xd(),{install:KJ,updateConfigEnv:KRe,setIgnoreExisting:BA}=DT(),YJ=SC(),cn=(H(),P(G)),{packageJson:YRe}=st(),WRe=Eh(),{sendOperationToNode:jP}=(Zn(),P(Io)),{updateConfigCert:zRe}=es(),{restartWorkers:jRe}=rt(),{databases:JRe}=(De(),P(nt)),{SYSTEM_TABLE_NAMES:WP,SYSTEM_SCHEMA_NAME:bxe,CONFIG_PARAMS:Yh,OPERATIONS_ENUM:hs}=cn,QRe=1e4,XRe="clone-node-config.yaml",WJ=[WP.ROLE_TABLE_NAME,WP.USER_TABLE_NAME,WP.NODE_TABLE_NAME],ZRe={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"},ia=BRe(process.argv),hf=ia[Fr.HDB_LEADER_USERNAME]??process.env[Fr.HDB_LEADER_USERNAME],mf=ia[Fr.HDB_LEADER_PASSWORD]??process.env[Fr.HDB_LEADER_PASSWORD],su=ia[Fr.HDB_LEADER_URL]??process.env[Fr.HDB_LEADER_URL],sa=ia[Fr.REPLICATION_HOSTNAME]??process.env[Fr.REPLICATION_HOSTNAME],zJ,jJ;sa&&([zJ,jJ]=sa.split(":"));var QP=(ia[Fr.HDB_CLONE_OVERTOP]??process.env[Fr.HDB_CLONE_OVERTOP])==="true",JJ=ia[Yh.CLONED.toUpperCase()]??process.env[Yh.CLONED.toUpperCase()],eye=ia[Fr.CLONE_KEYS]!=="false"&&process.env[Fr.CLONE_KEYS]!=="false",QJ=(ia[Fr.CLONE_USING_WS]??process.env[Fr.CLONE_USING_WS])==="true",XJ=(ia[Fr.NO_START]??process.env[Fr.NO_START])==="true",ps,Sc={},GJ,qJ,nu={},an,Lt,qs,no,iu=!1,XP=!1,_s,Ef;r2.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${su}`),delete process.env.HDB_LEADER_URL,Lt=vA.getEnvCliRootPath(),!Lt)try{let i=Vs(xJ.homedir(),cn.HDB_HOME_DIR_NAME,cn.BOOT_PROPS_FILE_NAME);if(await $t.pathExists(i)){let o=kRe(i);Lt=na.parse(o.get(cn.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.")}Lt?await $t.pathExists(Lt)?console.log(`Existing HarperDB install found at ${Lt}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Lt} starting fresh clone`),iu=!0):(console.log("No HarperDB install found, starting fresh clone"),iu=!0),Lt||(Lt=Vs(xJ.homedir(),cn.HDB_ROOT_DIR_NAME),console.log("Using default root path",Lt));let n;try{n=Vs(Lt,XRe),ps=HJ.parseDocument(await $t.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=Vs(Lt,cn.HDB_CONFIG_FILE);if(await $t.pathExists(s))try{GJ=HJ.parseDocument(await $t.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),Sc=MA.flattenConfig(GJ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(sa){let i=new URL(su);Ef=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${jJ||9933}`}if(QJ){await tye();return}if(Sc?.cloned&&JJ!=="false")return console.log("Instance marked as cloned, clone will not run"),$s.setCloneVar(!1),$s.initSync(),UA();an=await xA({operation:hs.DESCRIBE_ALL}),await e2(),$s.setCloneVar(!1),$s.setHdbBasePath(Lt),$t.ensureDir($s.get(cn.CONFIG_PARAMS.LOGGING_ROOT)),JP.initLogSettings(),await nye(),XP||await sye(),await aye(t,r),sa&&(await lye(),await ZJ()),console.info(`
|
|
134
|
+
Successfully cloned node: `+su),(t||XJ)&&process.exit()},"cloneNode");async function tye(){if(Sc?.cloned&&JJ!=="false")return console.log("Instance marked as cloned, clone will not run"),$s.setCloneVar(!1),$s.initSync(),UA();console.log("Cloning using WebSockets");let e=Tc("system"),t=Vs(e,"system.mdb"),r=$t.existsSync(t);iu||!r||QP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Lt,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=HRe.randomBytes(10).toString("base64").slice(0,10),BA(!0),await KJ()):($s.setCloneVar(!1),$s.initSync()),await UA(),await e2(!0),await zRe(),r||await JRe.system.hdb_user.delete({username:"clone-temp-admin"}),await jRe(),await rye(),console.log("Adding node to the cluster");let s=await Td()({operation:hs.ADD_NODE,url:Ef});console.log("Add node response: ",s),await ZJ(),console.log(`Successfully cloned node: ${su} using WebSockets`),MA.updateConfigValue(Yh.CLONED,!0),XJ&&process.exit()}a(tye,"cloneUsingWS");async function rye(){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 xA({operation:"describe_database",database:"system"});t.system=e(r);let n=await xA({operation:"describe_all"});for(let i in n)typeof n[i]=="object"&&(t[i]=e(n[i]));let s=Vs(Lt,"tmp","lastUpdated.json");console.log("Writing last updated database timestamps to:",s),await $t.outputJson(s,t)}a(rye,"getLastUpdatedRecord");async function xA(e){return QJ?jP({url:Ef},e,{rejectUnauthorized:!1}):JSON.parse((await uye(e)).body)}a(xA,"leaderReq");async function ZJ(){try{if(eye!==!1){console.log("Cloning JWT keys");let e=na.join(Lt,cn.LICENSE_KEY_DIR_NAME),t=await jP({url:Ef},{operation:hs.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});FJ(na.join(e,cn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await jP({url:Ef},{operation:hs.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});FJ(na.join(e,cn.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 xA({operation:hs.GET_CONFIGURATION}),nu=MA.flattenConfig(qJ);let t=ps?.componentConfig?.exclude,r={rootpath:Lt};sa&&(r.replication_hostname=zJ);for(let i in nu)if(!(nu[i]!==null&&typeof nu[i]=="object"&&!(nu[i]instanceof Array)||ZRe[i])){if(i.includes("_package")||i.includes("_port")){if(nu[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}}Sc[i]||(r[i]=nu[i])}for(let i in Sc)i!=="databases"&&typeof Sc[i]=="object"&&!(Sc[i]instanceof Array)||(r[i]=Sc[i]);let n={};if(ps?.databaseConfig?.excludeDatabases&&ps.databaseConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),ps?.clusteringConfig?.excludeDatabases&&ps.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 an)n[i]||r.replication_databases.push(i)}let s=qRe(Object.keys(cn.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),MA.createConfigFile(r,!0)}a(e2,"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=Lt,!hf)throw new Error("HDB_LEADER_USERNAME is undefined.");if(process.env.HDB_ADMIN_USERNAME=hf,!mf)throw new Error("HDB_LEADER_PASSWORD is undefined.");process.env.HDB_ADMIN_PASSWORD=mf,process.env.OPERATIONSAPI_NETWORK_PORT=$s.get(Yh.OPERATIONSAPI_NETWORK_PORT),KRe(na.join(Lt,cn.HDB_CONFIG_FILE)),BA(!0),await KJ()}a(sye,"installHDB");function Tc(e){return $s.get(cn.CONFIG_PARAMS.DATABASES)?.[e]?.path||$s.get(Yh.STORAGE_PATH)||na.join(Lt,cn.DATABASES_DIR_NAME)}a(Tc,"getDBPath");async function iye(){let e=Tc("system"),t=Vs(e,"system.mdb");if(await Kh(e),iu||!await $t.exists(t)||QP){if(!sa){console.info("Cloning system database"),await Kh(e);let r=LA(t,{overwrite:!0}),n={operation:hs.GET_BACKUP,database:"system",tables:WJ},s=await $J(n,r),i=new Date(s.date);(!_s||i<_s)&&(_s=i),await $t.utimes(t,Date.now(),i)}iu||(await YJ(Lt),await t2(),BA(!0))}else XP=!0,console.log("Not cloning system database due to it already existing on clone");qs=ps?.databaseConfig?.excludeDatabases,qs=qs?qs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in an)await $t.exists(na.join(Tc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),qs[r]=!0);no=ps?.databaseConfig?.excludeTables,no=no?no.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in an){if(qs[r]){an[r]="excluded";continue}if(VJ.isEmpty(an[r]))continue;let n=[],s=!1;for(let d in an[r])no[r+d]?(s=!0,an[r][d]="excluded"):n.push(an[r][d]);if(n.length===0)continue;if(sa){JP.debug("Setting up tables for #{db}");let d=(De(),P(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:hs.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:hs.GET_BACKUP,database:r});let o=Tc(r);await Kh(o);let c=Vs(o,r+".mdb"),l=LA(c,{overwrite:!0}),u=await $J(i,l),f=new Date(u.date);(!_s||f<_s)&&(_s=f),await $t.utimes(c,Date.now(),f)}}a(iye,"cloneTablesHttp");async function oye(){let e=Tc("system"),t=Vs(e,"system.mdb");if(iu||!await $t.exists(t)||QP){if(!sa){console.info("Cloning system database using fetch");let r={operation:hs.GET_BACKUP,database:"system",tables:WJ},n=await zP(r,!0),s=Tc("system");await Kh(s);let i=Vs(s,"system.mdb");await kJ(n.body,LA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!_s||o<_s)&&(_s=o),await $t.utimes(i,Date.now(),new Date(n.headers.get("date")))}iu||(await YJ(Lt),await t2(),BA(!0))}else XP=!0,console.log("Not cloning system database due to it already existing on clone");if(sa){JP.info("Replication hostname set, not using backup to clone databases, replication will clone");return}qs=ps?.databaseConfig?.excludeDatabases,qs=qs?qs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in an)await $t.exists(na.join(Tc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),qs[r]=!0);no=ps?.databaseConfig?.excludeTables,no=no?no.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in an){if(qs[r]){an[r]="excluded";continue}if(VJ.isEmpty(an[r]))continue;let n=[],s=!1;for(let f in an[r])no[r+f]?(s=!0,an[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:hs.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await zP({operation:hs.GET_BACKUP,database:r},!0));let o=Tc(r);await Kh(o);let c=new Date(i.headers.get("date")),l=Vs(o,`${c.getTime()}-${r}.mdb`);await kJ(i.body,LA(l,{overwrite:!0}));let u=Vs(o,r+".mdb");await $t.rename(l,u),(!_s||c<_s)&&(_s=c),await $t.utimes(u,Date.now(),c)}}a(oye,"cloneTablesFetch");async function zP(e,t=!1){let r=ps?.httpsRejectUnauthorized??!1,n=new DA.Agent({rejectUnauthorized:r});r||(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0");let i={Authorization:"Basic "+Buffer.from(hf+":"+mf).toString("base64"),"Content-Type":"application/json"};t&&(i["Accept-Encoding"]="gzip");let o=await fetch(su,{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 aye(e,t=!1){let r=await FRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await VRe(!1):(t&&await cye(),await UA()):(console.info(await GRe({operation:hs.RESTART})),await vA.async_set_timeout(QRe)),e&&await vA.async_set_timeout(2e3)}a(aye,"startHDB");async function cye(){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(na.join(e,cn.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 $Re.setSchemaDataToGlobalAsync();let t=await Td()({operation:hs.ADD_NODE,verify_tls:!1,url:Ef,start_time:_s,authorization:{username:hf,password:mf}},!0);console.log("Add node response: ",t)}a(lye,"setupReplication");async function uye(e){let t=new DA.Agent({rejectUnauthorized:ps?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(hf+":"+mf).toString("base64"),"Content-Type":"application/json"},s=new URL(su),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 vA.httpRequest(i,e)}a(uye,"leaderHttpReq");async function $J(e,t){let r=new DA.Agent({rejectUnauthorized:ps?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(hf+":"+mf).toString("base64"),"Content-Type":"application/json"},i=new URL(su),o={protocol:i.protocol,host:i.hostname,method:"POST",headers:s};return i.protocol==="https:"&&(o.agent=r,BJ=DA),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=YRe.version;if(e)await WRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(t2,"insertHdbVersionInfo")});var s2=I((wxe,n2)=>{var dye=DT(),fye=W();n2.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 a2=I((Cxe,o2)=>{"use strict";var pye=ES(),hye=W(),i2="Registration failed.";async function mye(){let e;try{e=await pye.register()}catch(t){return hye.error(`Registration error ${t}`),i2}return e||i2}a(mye,"register");o2.exports={register:mye}});var d2=I((Dxe,u2)=>{"use strict";var Eye=W(),gye=(H(),P(G)),Sye=require("util"),Tye=require("child_process"),c2=Sye.promisify(Tye.exec),Aye=Do(),Wh=Dd(),l2="Stopping HarperDB.";u2.exports=Rye;async function Rye(){if(console.log(l2),Eye.notify(l2),await Wh.isServiceRegistered(gye.PROCESS_DESCRIPTORS.HDB)){Wh.enterPM2Mode();let r=await Wh.getUniqueServicesList();for(let n in r)await Wh.stop(n)}await Wh.kill();let t=await Aye.getHDBProcessInfo();t.clustering.forEach(r=>{c2(`kill ${r.pid}`)}),t.core.forEach(r=>{c2(`kill ${r.pid}`)})}a(Rye,"stop")});var p2=I((Mxe,_2)=>{"use strict";var tD=require("fs-extra"),rD=require("path"),eD=require("yaml"),zh=ir(),Ac=(H(),P(G)),f2=St(),nD=W(),yye=yn(),bye=dS(),Oye=lS(),Nye=Do(),jh=ce(),wye=Xd(),Iye=ae();jh.initSync();var Ks={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},Un={LEAF:"leaf server",HUB:"hub server"},HA;_2.exports=Cye;async function Cye(){let e={harperdb:{status:Ks.STOPPED}};if(!await wye.isHdbInstalled()){e.harperdb.status=Ks.NOT_INSTALLED,console.log(eD.stringify(e));return}HA=jh.get(Ac.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await tD.readFile(rD.join(HA,Ac.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Ac.NODE_ERROR_CODES.ENOENT){nD.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Ks.STOPPED,console.log(eD.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((jh.get(Ac.CONFIG_PARAMS.REPLICATION_URL)||jh.get(Ac.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 zh.closeConnection()}console.log(eD.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}=zh.getServerConfig(Ac.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await yye.getClusterUser();try{(await zh.createConnection(r,n,s,!1)).close(),t[Un.HUB].status=Ks.RUNNING}catch{t[Un.HUB].status=Ks.ERRORED}let{port:i}=zh.getServerConfig(Ac.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await zh.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 tD.readFile(rD.join(HA,"clustering",f2.PID_FILES.HUB),"utf8"))}catch(o){nD.error(o),t[Un.HUB].pid=void 0}try{t[Un.LEAF].pid=Number.parseInt(await tD.readFile(rD.join(HA,"clustering",f2.PID_FILES.LEAF),"utf8"))}catch(o){nD.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:jh.get(Ac.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")});sm();var sD=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");sD&&ce().setCloneVar(!0);var Jh=require("node:fs"),h2=require("node:path"),ou=W(),m2=LJ(),{packageJson:Lye,PACKAGE_ROOT:E2}=st(),Mye=UJ(),iD=(H(),P(G)),{SERVICE_ACTIONS_ENUM:ln}=iD,vye=`
|
|
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 Uye(){let e=Mye();if(e)if(e.error){console.error(e.error),ou.error(e.error);return}else e.warn&&(console.warn(e.warn),ou.warn(e.warn));let t;Jh.existsSync(h2.join(E2,"bin"))||(ou.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=ln.OPERATION),t){case ln.OPERATION:return ou.trace("calling cli operations with:",r),m2.cliOperations(r);case ln.START:return sD?ZP()(!0):Xd().launch();case ln.INSTALL:return s2()();case ln.REGISTER:return a2().register();case ln.STOP:return d2()().then(()=>{process.exit(0)});case ln.RESTART:return ja().restart({});case ln.VERSION:return Lye.version;case ln.UPGRADE:return ou.setLogLevel(iD.LOG_LEVELS.INFO),IC().upgrade(null).then(()=>"Your instance of HarperDB is up to date!");case ln.STATUS:return p2()();case ln.RENEWCERTS:return es().renewSelfSigned().then(()=>"Successfully renewed self-signed certificates");case ln.COPYDB:{let n=process.argv[3],s=process.argv[4];return(CS(),P(IS)).copyDb(n,s)}case ln.DEV:process.env.DEV_MODE=!0;case ln.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()():Xd().main();default:console.warn(`The "${t}" command is not understood.`);case ln.HELP:return vye}}a(Uye,"harperdb");Uye().then(e=>{e&&(console.log(e),ou.notify(e))}).catch(e=>{e&&(console.error(e),ou.error(e)),process.exit(1)});
|