harperdb 4.4.0-alpha.1 → 4.4.0-beta.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 +12 -3
- package/application-template/config.yaml +2 -5
- package/bin/harperdb.js +85 -67
- package/bin/lite.js +118 -27
- package/config/yaml/defaultConfig.yaml +3 -3
- package/config/yaml/defaultNatsConfig.yaml +1 -1
- package/index.js +3 -12
- package/json/hdbConnectorOptions.json +14 -14
- package/json/interNodeConnectorOptions.json +15 -15
- package/json/systemSchema.json +260 -260
- package/launchServiceScripts/launchInstallNATSServer.js +3 -3
- package/launchServiceScripts/launchNatsIngestService.js +118 -27
- package/launchServiceScripts/launchNatsReplyService.js +118 -27
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +118 -27
- package/logs/README.md +1 -1
- package/npm-shrinkwrap.json +7556 -7555
- package/package.json +130 -133
- package/resources/ErrorResource.d.ts +26 -0
- package/resources/IterableEventQueue.d.ts +6 -0
- package/resources/Resource.d.ts +6 -0
- package/resources/ResourceInterface.d.ts +1 -1
- package/resources/Table.d.ts +14 -3
- package/resources/auditStore.d.ts +5 -5
- package/resources/crdt.d.ts +1 -1
- package/resources/databases.d.ts +13 -1
- package/resources/search.d.ts +15 -2
- package/resources/tracked.d.ts +1 -1
- package/server/jobs/jobProcess.js +118 -27
- package/server/serverHelpers/Headers.d.ts +1 -1
- package/server/threads/threadServer.js +118 -27
- package/studio/build-local/asset-manifest.json +47 -46
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/css/main.fee3019a.css +13 -0
- package/studio/build-local/static/js/23.3b9f7144.chunk.js +1 -0
- package/studio/build-local/static/js/239.183c6cbc.chunk.js +2 -0
- package/studio/build-local/static/js/{228.302d7db9.chunk.js → 279.7890bce3.chunk.js} +1 -1
- package/studio/build-local/static/js/311.9e648b13.chunk.js +2 -0
- package/studio/build-local/static/js/311.9e648b13.chunk.js.LICENSE.txt +38 -0
- package/studio/build-local/static/js/43.73dc432d.chunk.js +2 -0
- package/studio/build-local/static/js/452.d771b05a.chunk.js +2 -0
- package/studio/build-local/static/js/{446.5237e847.chunk.js.LICENSE.txt → 452.d771b05a.chunk.js.LICENSE.txt} +2 -2
- package/studio/build-local/static/js/545.be2e36f9.chunk.js +1 -0
- package/studio/build-local/static/js/759.7c5150cd.chunk.js +2 -0
- package/studio/build-local/static/js/805.6aab06e2.chunk.js +1 -0
- package/studio/build-local/static/js/806.afb99f70.chunk.js +1 -0
- package/studio/build-local/static/js/833.5b133801.chunk.js +1 -0
- package/studio/build-local/static/js/851.4c6536d6.chunk.js +1 -0
- package/studio/build-local/static/js/860.727e7fc8.chunk.js +1 -0
- package/studio/build-local/static/js/browse-csvupload.02fdfbea.chunk.js +1 -0
- package/studio/build-local/static/js/browse-datatable.0e20a171.chunk.js +1 -0
- package/studio/build-local/static/js/browse-entitymanager.0db076c3.chunk.js +1 -0
- package/studio/build-local/static/js/browse-jsonviewer.b690b1bb.chunk.js +1 -0
- package/studio/build-local/static/js/custom-functions.04b93135.chunk.js +1 -0
- package/studio/build-local/static/js/instance-charts.217c477d.chunk.js +1 -0
- package/studio/build-local/static/js/instance-cluster.0ba07710.chunk.js +1 -0
- package/studio/build-local/static/js/instance-config.2274de0a.chunk.js +1 -0
- package/studio/build-local/static/js/instance-query.fdc5f922.chunk.js +1 -0
- package/studio/build-local/static/js/instance-roles.38ef8e77.chunk.js +1 -0
- package/studio/build-local/static/js/instance-status.d09551b0.chunk.js +1 -0
- package/studio/build-local/static/js/instance-users-datatable.9b5617bc.chunk.js +1 -0
- package/studio/build-local/static/js/instance-users-edit.6ea9cc6f.chunk.js +1 -0
- package/studio/build-local/static/js/instance-users.876f6070.chunk.js +1 -0
- package/studio/build-local/static/js/instance.ad30f892.chunk.js +1 -0
- package/studio/build-local/static/js/instances.f4fec0cb.chunk.js +1 -0
- package/studio/build-local/static/js/main.e70e768f.js +2 -0
- package/studio/build-local/static/js/{main.4fd117ad.js.LICENSE.txt → main.e70e768f.js.LICENSE.txt} +0 -33
- package/studio/build-local/static/js/offline-app.31ad36fc.chunk.js +1 -0
- package/studio/build-local/static/js/online-app.91033fd0.chunk.js +1 -0
- package/studio/build-local/static/js/organization-billing.21b2d3c9.chunk.js +1 -0
- package/studio/build-local/static/js/organization-users.6f50ca02.chunk.js +1 -0
- package/studio/build-local/static/js/organization.89b902c4.chunk.js +1 -0
- package/studio/build-local/static/js/organizations.4933fdbc.chunk.js +1 -0
- package/studio/build-local/static/js/profile.c05c7042.chunk.js +1 -0
- package/studio/build-local/static/js/resetPassword.3478535b.chunk.js +1 -0
- package/studio/build-local/static/js/roles-jsonviewer.bf1011d5.chunk.js +1 -0
- package/studio/build-local/static/js/signIn.996cf7ee.chunk.js +1 -0
- package/studio/build-local/static/js/signUp.c8fce52d.chunk.js +1 -0
- package/studio/build-local/static/js/structure-reloader.f65842a1.chunk.js +1 -0
- package/studio/build-local/static/js/topnav.0fa4de77.chunk.js +1 -0
- package/studio/build-local/static/js/updatePassword.bc881b36.chunk.js +1 -0
- package/utility/install/README.md +23 -0
- package/utility/scripts/restartHdb.js +118 -27
- package/application-template/routes/index.js +0 -14
- package/studio/build-local/static/css/main.6c0f1b63.css +0 -13
- package/studio/build-local/static/js/110.ca4244a6.chunk.js +0 -2
- package/studio/build-local/static/js/287.21477cf9.chunk.js +0 -1
- package/studio/build-local/static/js/409.17daa4fe.chunk.js +0 -2
- package/studio/build-local/static/js/424.ad87c8fd.chunk.js +0 -1
- package/studio/build-local/static/js/446.5237e847.chunk.js +0 -2
- package/studio/build-local/static/js/662.92e32ffc.chunk.js +0 -1
- package/studio/build-local/static/js/718.74e9355d.chunk.js +0 -1
- package/studio/build-local/static/js/723.c58acced.chunk.js +0 -2
- package/studio/build-local/static/js/731.8a941eb3.chunk.js +0 -1
- package/studio/build-local/static/js/807.510f66df.chunk.js +0 -2
- package/studio/build-local/static/js/807.510f66df.chunk.js.LICENSE.txt +0 -5
- package/studio/build-local/static/js/926.88d6f9ce.chunk.js +0 -1
- package/studio/build-local/static/js/browse-csvupload.453237f3.chunk.js +0 -1
- package/studio/build-local/static/js/browse-datatable.b9ef2d28.chunk.js +0 -1
- package/studio/build-local/static/js/browse-entitymanager.50827a5a.chunk.js +0 -1
- package/studio/build-local/static/js/browse-jsonviewer.a2534004.chunk.js +0 -1
- package/studio/build-local/static/js/custom-functions.dd7e182c.chunk.js +0 -1
- package/studio/build-local/static/js/instance-charts.34d15f02.chunk.js +0 -1
- package/studio/build-local/static/js/instance-cluster.5bce430c.chunk.js +0 -1
- package/studio/build-local/static/js/instance-config.70c17b53.chunk.js +0 -1
- package/studio/build-local/static/js/instance-query.4f6eec62.chunk.js +0 -1
- package/studio/build-local/static/js/instance-roles.507a4ed0.chunk.js +0 -1
- package/studio/build-local/static/js/instance-status.ce9d7f64.chunk.js +0 -1
- package/studio/build-local/static/js/instance-users-datatable.190640fd.chunk.js +0 -1
- package/studio/build-local/static/js/instance-users-edit.d2444479.chunk.js +0 -1
- package/studio/build-local/static/js/instance-users.eabfbbde.chunk.js +0 -1
- package/studio/build-local/static/js/instance.a163623f.chunk.js +0 -1
- package/studio/build-local/static/js/instances.6b88a87c.chunk.js +0 -1
- package/studio/build-local/static/js/main.4fd117ad.js +0 -2
- package/studio/build-local/static/js/offline-app.7371216b.chunk.js +0 -1
- package/studio/build-local/static/js/online-app.db436eec.chunk.js +0 -1
- package/studio/build-local/static/js/organization-billing.b2f260f0.chunk.js +0 -1
- package/studio/build-local/static/js/organization-users.b6171b18.chunk.js +0 -1
- package/studio/build-local/static/js/organization.7800f16a.chunk.js +0 -1
- package/studio/build-local/static/js/organizations.8bb505f2.chunk.js +0 -1
- package/studio/build-local/static/js/profile.292bdd86.chunk.js +0 -1
- package/studio/build-local/static/js/resetPassword.8fdfba77.chunk.js +0 -1
- package/studio/build-local/static/js/roles-jsonviewer.c11f1816.chunk.js +0 -1
- package/studio/build-local/static/js/signIn.b11bdc50.chunk.js +0 -1
- package/studio/build-local/static/js/signUp.564d4e0b.chunk.js +0 -1
- package/studio/build-local/static/js/structure-reloader.b6de4091.chunk.js +0 -1
- package/studio/build-local/static/js/topnav.4fd41d60.chunk.js +0 -1
- package/studio/build-local/static/js/updatePassword.e23019c7.chunk.js +0 -1
- /package/studio/build-local/static/js/{723.c58acced.chunk.js.LICENSE.txt → 239.183c6cbc.chunk.js.LICENSE.txt} +0 -0
- /package/studio/build-local/static/js/{110.ca4244a6.chunk.js.LICENSE.txt → 43.73dc432d.chunk.js.LICENSE.txt} +0 -0
- /package/studio/build-local/static/js/{409.17daa4fe.chunk.js.LICENSE.txt → 759.7c5150cd.chunk.js.LICENSE.txt} +0 -0
|
@@ -1,42 +1,133 @@
|
|
|
1
|
-
"use strict";var U$=Object.create;var Xl=Object.defineProperty;var v$=Object.getOwnPropertyDescriptor;var x$=Object.getOwnPropertyNames;var B$=Object.getPrototypeOf,H$=Object.prototype.hasOwnProperty;var a=(e,t)=>Xl(e,"name",{value:t,configurable:!0});var Oe=(e,t)=>()=>(e&&(t=e(e=0)),t);var N=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Ze=(e,t)=>{for(var r in t)Xl(e,r,{get:t[r],enumerable:!0})},rN=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of x$(t))!H$.call(e,s)&&s!==r&&Xl(e,s,{get:()=>t[s],enumerable:!(n=v$(t,s))||n.enumerable});return e};var v=(e,t,r)=>(r=e!=null?U$(B$(e)):{},rN(t||!e||!e.__esModule?Xl(r,"default",{value:e,enumerable:!0}):r,e)),ae=e=>rN(Xl({},"__esModule",{value:!0}),e);var iN=N((bfe,sN)=>{var k$=require("fast-glob"),{statSync:rS,existsSync:nS,readFileSync:F$,writeFileSync:G$}=require("fs"),{spawnSync:q$,spawn:V$,execFileSync:Afe}=require("child_process"),{isMainThread:$$}=require("worker_threads"),{join:ji,relative:nN}=require("path"),{PACKAGE_ROOT:cs}=M(),{tmpdir:Y$,platform:K$}=require("os");require("source-map-support").install();var W$=["resources","server","dataLayer","components"],Zl="ts-build",sS,Q$=__filename.endsWith("tsBuild.js");if(Q$){if($$){let r;try{rS(ji(cs,Zl)),r=!0}catch{}if(r)for(let n of k$.sync(W$.map(s=>s+"/**/*.ts"),{cwd:cs})){let s=0,i=0;try{s=rS(ji(cs,n)).mtimeMs-5e3,i=rS(ji(cs,Zl,n.replace(/.ts$/,".js"))).mtimeMs}catch{}if(s>i){console.warn(`TypeScript ${n} is not compiled`+(i?` (TS source file was modified at ${new Date(s)} and compiled file at ${new Date(i)})`:"")+", consider enabling auto-compilation of TypeScript in your IDE), compiling now."),sS=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),sS=!0;if(sS){let n=ji(cs,"node_modules/.bin/tsc");K$()==="win32"&&(n+=".cmd");let s=q$(n,{cwd:cs});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=ji(Y$(),"harperdb-tsc.pid"),o;if(nS(i))try{process.kill(+F$(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=V$(n,["--watch"],{cwd:cs,detached:!0,stdio:"ignore"});G$(i,c.pid.toString()),c.unref()}}}}let e=sN.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(cs)&&!n[0].includes("node_modules")){let i=nN(cs,n[0]),o;i.startsWith(Zl)?o=ji(cs,nN(Zl,i)):o=ji(cs,Zl,i);let c=ji(o,r),l=c+".js";if(nS(l))return l;if(c.includes(".")&&nS(c))return c}return t(r,n,s)}}});var M=N((Nfe,TN)=>{"use strict";var kn=require("path"),z$=require("fs"),{relative:yfe,join:Ofe}=kn,{existsSync:j$}=z$;function J$(){let e=__dirname;for(;!j$(kn.join(e,"package.json"));){let t=kn.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(J$,"getHDBPackageRoot");var Ji=J$(),oN="js",_f=oN,X$="harperdb-config.yaml",Z$="defaultConfig.yaml",e1="hdb",aN=`harperdb.${_f}`,cN=`customFunctionsServer.${_f}`,t1=`restartHdb.${_f}`,oS="HarperDB",df="Custom Functions",ff="Clustering Hub",Ef="Clustering Leaf",r1="Clustering Ingest Service",n1="Clustering Reply Service",s1="foreground.pid",i1="hdb.pid",o1="data",a1={HDB:oS,CLUSTERING_HUB:ff,CLUSTERING_LEAF:Ef,CLUSTERING_INGEST_SERVICE:r1,CLUSTERING_REPLY_SERVICE:n1,CUSTOM_FUNCTIONS:df,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"},c1={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},l1={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},u1={harperdb:oS,"clustering hub":ff,"clustering leaf":Ef,"custom functions":df,custom_functions:df,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},d1={CLUSTERING_HUB_PROC_DESCRIPTOR:ff,CLUSTERING_LEAF_PROC_DESCRIPTOR:Ef},iS={HDB:kn.join(Ji,"server/harperdb"),CUSTOM_FUNCTIONS:kn.join(Ji,"server/customFunctions"),CLUSTERING_HUB:kn.join(Ji,"server/nats"),CLUSTERING_LEAF:kn.join(Ji,"server/nats")},_1={HDB:kn.join(iS.HDB,aN),CUSTOM_FUNCTIONS:kn.join(iS.CUSTOM_FUNCTIONS,cN)},f1={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:kn.join(Ji,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:kn.join(Ji,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:kn.join(Ji,"launchServiceScripts/launchUpdateNodes4-0-0.js")},E1={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},lN="support@harperdb.io",h1="customer-success@harperdb.io",uN=1,m1=4141,dN="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",p1="https://www.harperdb.io/product",S1=`For support, please submit a request at ${dN} or contact ${lN}`,_N=`For license support, please contact ${h1}`,T1="None of the specified records were found.",g1="hash attribute not found",R1=`Your current license only supports ${uN} role. ${_N}`,A1="Your current license only supports 3 connections to a node.",b1="127.0.0.1",y1=1,O1=/^\.$/,N1=/^\.\.$/,I1="U+002E",w1=/\//g,C1="U+002F",D1=/U\+002F/g,L1=/^U\+002E$/,P1=/^U\+002EU\+002E$/,M1="d",U1=999999,v1="*",x1="--max-old-space-size=",B1="system",H1="__hdb_hash",k1=".harperdb",F1=".hdb",G1="keys",q1="hdb_boot_properties.file",V1=".updateConfig.json",$1="SIGTSTP",Y1=24,K1=6e4,W1=448,Q1="blob",z1="trash",j1="database",J1="schema",X1="transactions",Z1=".count",eY="id",tY="PROCESS_NAME",fN={SETTINGS_PATH_KEY:"settings_path"},EN=require("lodash"),rY={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"},nY={HDB_PATH_KEY:"HDB_INTERNAL_PATH",HDB_AUTH_HEADER:"hdb_auth_header",HDB_USER_DATA_KEY:"hdb_user",CHUNK_SIZE:1e3,MAX_CHARACTER_SIZE:250},sY={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},iY={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"},oY={JOB_TABLE_HASH_ATTRIBUTE:"id",NODE_TABLE_HASH_ATTRIBUTE:"name",ATTRIBUTE_TABLE_HASH_ATTRIBUTE:"id",LICENSE_TABLE_HASH_ATTRIBUTE:"license_key",ROLE_TABLE_HASH_ATTRIBUTE:"id",SCHEMA_TABLE_HASH_ATTRIBUTE:"name",TABLE_TABLE_HASH_ATTRIBUTE:"id",USER_TABLE_HASH_ATTRIBUTE:"username",INFO_TABLE_ATTRIBUTE:"info_id"},fn="hdb_internal:",aY={CREATE_SCHEMA:fn+"create_schema",CREATE_TABLE:fn+"create_table",CREATE_ATTRIBUTE:fn+"create_attribute",ADD_USER:fn+"add_user",ALTER_USER:fn+"alter_user",DROP_USER:fn+"drop_user",HDB_NODES:fn+"hdb_nodes",HDB_USERS:fn+"hdb_users",HDB_WORKERS:fn+"hdb_workers",CATCHUP:fn+"catchup",SCHEMA_CATCHUP:fn+"schema_catchup",WORKER_ROOM:fn+"cluster_workers"},cY={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"},lY="060493.ks",uY=".license",dY={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},oe={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"},_Y={CSV:".csv",JSON:".json"},fY={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},EY={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},eu={};eu[oe.INSERT]=oe.INSERT;eu[oe.UPDATE]=oe.UPDATE;eu[oe.UPSERT]=oe.UPSERT;eu[oe.DELETE]=oe.DELETE;var ze=Object.create(null);ze[oe.DESCRIBE_ALL]=oe.DESCRIBE_ALL;ze[oe.DESCRIBE_TABLE]=oe.DESCRIBE_TABLE;ze[oe.DESCRIBE_SCHEMA]=oe.DESCRIBE_SCHEMA;ze[oe.READ_LOG]=oe.READ_LOG;ze[oe.ADD_NODE]=oe.ADD_NODE;ze[oe.LIST_USERS]=oe.LIST_USERS;ze[oe.LIST_ROLES]=oe.LIST_ROLES;ze[oe.USER_INFO]=oe.USER_INFO;ze[oe.SQL]=oe.SQL;ze[oe.GET_JOB]=oe.GET_JOB;ze[oe.SEARCH_JOBS_BY_START_DATE]=oe.SEARCH_JOBS_BY_START_DATE;ze[oe.DELETE_FILES_BEFORE]=oe.DELETE_FILES_BEFORE;ze[oe.EXPORT_LOCAL]=oe.EXPORT_LOCAL;ze[oe.EXPORT_TO_S3]=oe.EXPORT_TO_S3;ze[oe.CLUSTER_STATUS]=oe.CLUSTER_STATUS;ze[oe.REMOVE_NODE]=oe.REMOVE_NODE;ze[oe.RESTART]=oe.RESTART;ze[oe.CUSTOM_FUNCTIONS_STATUS]=oe.CUSTOM_FUNCTIONS_STATUS;ze[oe.GET_CUSTOM_FUNCTIONS]=oe.GET_CUSTOM_FUNCTIONS;ze[oe.GET_CUSTOM_FUNCTION]=oe.GET_CUSTOM_FUNCTION;ze[oe.SET_CUSTOM_FUNCTION]=oe.SET_CUSTOM_FUNCTION;ze[oe.DROP_CUSTOM_FUNCTION]=oe.DROP_CUSTOM_FUNCTION;ze[oe.ADD_CUSTOM_FUNCTION_PROJECT]=oe.ADD_CUSTOM_FUNCTION_PROJECT;ze[oe.DROP_CUSTOM_FUNCTION_PROJECT]=oe.DROP_CUSTOM_FUNCTION_PROJECT;ze[oe.PACKAGE_CUSTOM_FUNCTION_PROJECT]=oe.PACKAGE_CUSTOM_FUNCTION_PROJECT;ze[oe.DEPLOY_CUSTOM_FUNCTION_PROJECT]=oe.DEPLOY_CUSTOM_FUNCTION_PROJECT;ze[oe.ADD_SSH_KEY]=oe.ADD_SSH_KEY;ze[oe.UPDATE_SSH_KEY]=oe.UPDATE_SSH_KEY;ze[oe.DELETE_SSH_KEY]=oe.DELETE_SSH_KEY;var hY={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"},mY={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},hN={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"},pY=EN.invert(hN),SY={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"},D={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",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",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},mN={settings_path:fN.SETTINGS_PATH_KEY,hdb_root_key:D.ROOTPATH,hdb_root:D.ROOTPATH,rootpath:D.ROOTPATH,server_port_key:D.OPERATIONSAPI_NETWORK_PORT,server_port:D.OPERATIONSAPI_NETWORK_PORT,cert_key:D.TLS_CERTIFICATE,certificate:D.TLS_CERTIFICATE,private_key_key:D.TLS_PRIVATEKEY,private_key:D.TLS_PRIVATEKEY,http_secure_enabled_key:D.OPERATIONSAPI_NETWORK_HTTPS,https_on:D.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:D.OPERATIONSAPI_NETWORK_CORS,cors_on:D.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:D.LOGGING_LEVEL,log_level:D.LOGGING_LEVEL,log_path_key:D.LOGGING_ROOT,log_path:D.LOGGING_ROOT,clustering_node_name_key:D.CLUSTERING_NODENAME,node_name:D.CLUSTERING_NODENAME,clustering_enabled_key:D.CLUSTERING_ENABLED,clustering:D.CLUSTERING_ENABLED,max_http_threads:D.THREADS_COUNT,max_hdb_processes:D.THREADS_COUNT,server_timeout_key:D.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:D.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:D.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:D.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:D.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:D.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:D.LOGGING_AUDITLOG,disable_transaction_log:D.LOGGING_AUDITLOG,operation_token_timeout_key:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:D.HTTP_PORT,custom_functions_port:D.HTTP_PORT,custom_functions_directory_key:D.COMPONENTSROOT,custom_functions_directory:D.COMPONENTSROOT,max_custom_function_processes:D.THREADS_COUNT,log_to_file:D.LOGGING_FILE,log_to_stdstreams:D.LOGGING_STDSTREAMS,local_studio_on:D.LOCALSTUDIO_ENABLED,clustering_port:D.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:D.CLUSTERING_USER,clustering_enabled:D.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:D.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:D.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:D.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:D.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:D.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:D.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:D.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:D.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:D.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxconsumemsgs:D.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:D.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,clustering_leafserver_streams_maxmsgs:D.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:D.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:D.CLUSTERING_NODENAME,clustering_tls_certificate:D.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:D.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:D.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:D.CLUSTERING_TLS_INSECURE,clustering_tls_verify:D.CLUSTERING_TLS_VERIFY,clustering_loglevel:D.CLUSTERING_LOGLEVEL,clustering_republishmessages:D.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:D.CLUSTERING_DATABASELEVEL,customfunctions_network_port:D.HTTP_PORT,customfunctions_tls_certificate:D.TLS_CERTIFICATE,customfunctions_network_cors:D.HTTP_CORS,customfunctions_network_corsaccesslist:D.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:D.HTTP_HEADERSTIMEOUT,customfunctions_network_https:D.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:D.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:D.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:D.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:D.HTTP_TIMEOUT,customfunctions_tls:D.TLS,http_threads:D.THREADS_COUNT,threads:D.THREADS_COUNT,threads_count:D.THREADS_COUNT,threads_debug:D.THREADS_DEBUG,threads_debug_startingport:D.THREADS_DEBUG_STARTINGPORT,threads_debug_port:D.THREADS_DEBUG_PORT,threads_debug_host:D.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:D.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:D.THREADS_MAXHEAPMEMORY,http_session_affinity:D.HTTP_SESSIONAFFINITY,http_compressionthreshold:D.HTTP_COMPRESSIONTHRESHOLD,http_cors:D.HTTP_CORS,http_corsaccesslist:D.HTTP_CORSACCESSLIST,http_headerstimeout:D.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:D.HTTP_KEEPALIVETIMEOUT,http_timeout:D.HTTP_TIMEOUT,http_port:D.HTTP_PORT,http_secureport:D.HTTP_SECUREPORT,http_mtls:D.HTTP_MTLS,http_mtls_user:D.HTTP_MTLS_USER,http_mtls_required:D.HTTP_MTLS_REQUIRED,http_maxheadersize:D.HTTP_MAXHEADERSIZE,http_threadrange:D.HTTP_THREADRANGE,customfunctions_processes:D.THREADS_COUNT,customfunctions_root:D.COMPONENTSROOT,localstudio_enabled:D.LOCALSTUDIO_ENABLED,logging_file:D.LOGGING_FILE,logging_level:D.LOGGING_LEVEL,logging_root:D.LOGGING_ROOT,logging_rotation_enabled:D.LOGGING_ROTATION_ENABLED,logging_rotation_compress:D.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:D.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:D.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:D.LOGGING_ROTATION_PATH,logging_stdstreams:D.LOGGING_STDSTREAMS,logging_auditlog:D.LOGGING_AUDITLOG,logging_auditretention:D.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:D.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:D.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:D.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:D.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:D.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:D.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:D.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:D.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:D.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls:D.OPERATIONSAPI_TLS,operationsapi_tls_certificate:D.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:D.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:D.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:D.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:D.ROOTPATH,databases:D.DATABASES,storage_path:D.STORAGE_PATH,storage_maxtransactionqueuetime:D.STORAGE_MAXTRANSACTIONQUEUETIME,ignorescripts:D.IGNORE_SCRIPTS,mqtt_network_port:D.MQTT_NETWORK_PORT,mqtt_websocket:D.MQTT_WEBSOCKET,mqtt_network_secureport:D.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:D.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:D.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:D.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:D.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:D.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:D.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:D.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:D.AUTHENTICATION_CACHETTL,authentication_enablesessions:D.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:D.COMPONENTSROOT,replication:D.REPLICATION,replication_port:D.REPLICATION_PORT,replication_secureport:D.REPLICATION_SECUREPORT,replication_hostname:D.REPLICATION_HOSTNAME,replication_url:D.REPLICATION_URL,replication_routes:D.REPLICATION_ROUTES,tls:D.TLS,tls_certificate:D.TLS_CERTIFICATE,tls_privatekey:D.TLS_PRIVATEKEY,tls_certificateauthority:D.TLS_CERTIFICATEAUTHORITY,tls_ciphers:D.TLS_CIPHERS};for(let e in D){let t=D[e];mN[t.toLowerCase()]=t}var TY={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},gY={csv_file_load:"csv_file_load",csv_data_load:oe.CSV_DATA_LOAD,csv_url_load:oe.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"},RY={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"},AY={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},bY={VERSION_DEFAULT:"2.2.0"},yY={DEVELOPMENT:8192,DEFAULT:512},OY={IDENTIFY:"identify",AUTHENTICATE:"authenticate",AUTHENTICATE_OK:"authenticated",AUTHENTICATE_FAIL:"authenticate_fail",CONNECTION:"connection",CONNECT:"connect",CATCHUP_REQUEST:"catchup_request",CATCHUP_RESPONSE:"catchup",CONFIRM_MSG:"confirm_msg",ERROR:"error",DISCONNECT:"disconnect",SCHEMA_UPDATE_REQ:"schema_update_request",SCHEMA_UPDATE_RES:"schema_update_response",RECONNECT_ATTEMPT:"reconnect_attempt",CONNECT_ERROR:"connect_error",MESSAGE:"msg",VERSION_MISMATCH:"version_mismatch",DIRECTION_CHANGE:"direction_change"},NY={1e3:"SUCCESSFUL_SHUTDOWN",1001:"CLOSE_GOING_AWAY",1002:"CLOSE_PROTOCOL_ERROR",1003:"CLOSE_UNSUPPORTED",1005:"CLOSE_NO_STATUS",1006:"CLOSE_ABNORMAL",1007:"UNSUPPORTED_PAYLOAD",1008:"POLICY_VIOLATION",1009:"CLOSE_TOO_LARGE",1010:"MANDATORY_EXTENSION",1011:"SERVER_ERROR",1012:"SERVICE_RESTART",1013:"SERVER_BUSY",1014:"BAD_GATEWAY",1015:"HANDSHAKE_FAIL",4141:"LICENSE_LIMIT_REACHED"},IY={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},pN={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},wY=Symbol("metadata"),CY="__clustering__",DY=Object.values(pN),LY=15984864e5,SN={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},PY=EN.invert(SN),MY={GET_CLUSTER_STATUS:"GET_CLUSTER_STATUS",CLUSTER_STATUS_RESPONSE:"CLUSTER_STATUS_RESPONSE",ERROR_RESPONSE:"ERROR",ADD_USER:"ADD_USER",ALTER_USER:"ALTER_USER",DROP_USER:"DROP_USER",HDB_OPERATION:"HDB_OPERATION",ADD_NODE:"ADD_NODE",UPDATE_NODE:"UPDATE_NODE",REMOVE_NODE:"REMOVE_NODE",HDB_USERS_MSG:"HDB_USERS_MSG",HDB_WORKERS:"HDB_WORKERS",HDB_TRANSACTION:"HDB_TRANSACTION"},UY=111,vY=`\r
|
|
2
|
-
`,
|
|
3
|
-
`&&(e=e.slice(0,-1)),
|
|
4
|
-
`&&(e=e.slice(0,-1)),
|
|
5
|
-
|
|
6
|
-
`).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:mK.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(gK,"findPs")});var Gt=N((Mfe,qN)=>{"use strict";var RK="__dbis__",AK="__txns__",bK="__environment_name__",yK="__dbi_defintion__",OK={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"},NK=["__createdtime__","__updatedtime__"],IK="\uFFFF",GN={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},wK=Object.values(GN);qN.exports={AUDIT_STORE_NAME:AK,INTERNAL_DBIS_NAME:RK,DBI_DEFINITION_NAME:yK,SEARCH_TYPES:OK,TIMESTAMP_NAMES:NK,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:bK,TRANSACTIONS_DBI_NAMES_ENUM:GN,TRANSACTIONS_DBIS:wK,OVERFLOW_MARKER:IK}});var En=N((Ufe,JN)=>{"use strict";var VN=M(),$N=Gt(),YN={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},KN=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),WN={500:KN("There was an error processing your request."),400:"Invalid request"},CK=WN[YN.INTERNAL_SERVER_ERROR],DK={OP_NOT_SUPPORTED_FOR_FS:e=>`${e} is not available for this instance because it uses the File System data store.`,MISSING_VALUE:e=>`${e} is missing.`,INVALID_VALUE:e=>`${e} is invalid.`,NOT_FOUND:e=>`${e} not found.`},LK={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},PK={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:e=>`There was an error downloading '${e}'.`,INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,INVALID_FILE_EXT_ERR:e=>`Error selecting correct parser - valid file type not found in json - ${e}`,MAX_FILE_SIZE_ERR:(e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:e=>`There was an error downloading '${e}' from AWS.`,WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},MK={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 ${$N.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${$N.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"},UK={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${VN.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${VN.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},QN={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"},vK={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:e=>`Operation '${e}' is restricted to 'super_user' roles`,OP_NOT_FOUND:e=>`Operation '${e}' not found`,SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:(e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,USER_HAS_NO_PERMS:e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},xK={ATTR_PERM_MISSING:(e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:(e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:e=>`Invalid attribute '${e}' in 'attribute_permissions'`,INVALID_PERM_KEY:e=>`Invalid table permission key value '${e}'`,INVALID_ATTR_PERM_KEY:e=>`Invalid attribute permission key value '${e}'`,INVALID_ROLE_JSON_KEYS:e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,MISMATCHED_TABLE_ATTR_PERMS:e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:e=>`A role with name '${e}' already exists`,ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:e=>`Your role does not have permission to view database metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:e=>`Value for '${e}' permission must be a boolean`,STRUCTURE_USER_ROLE_TYPE_ERROR:e=>`Value for '${e}' permission must be a boolean or Array`,SU_CU_ROLE_NO_PERMS_ALLOWED:e=>`Roles with '${e}' set to true cannot have other permissions set.`,SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:e=>`Missing table ${e.toUpperCase()} permission`,TABLE_PERM_NOT_BOOLEAN:e=>`Table ${e.toUpperCase()} permission must be a boolean`},BK={ATTR_NOT_FOUND:(e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,ATTR_EXISTS_ERR:(e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:e=>`Invalid table ${JSON.stringify(e)}`,SCHEMA_NOT_FOUND:e=>`database '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`database '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in '${e}'`,SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},HK={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},kK={ALTER_USER_DUP_ROLES:e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,ALTER_USER_ROLE_NOT_FOUND:e=>`Update failed. Requested '${e}' role not found.`,DUP_ROLES_FOUND:e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,ROLE_NAME_NOT_FOUND:e=>`${e} role not found`,USER_ALREADY_EXISTS:e=>`User ${e} already exists`,USER_NOT_EXIST:e=>`User ${e} does not exist`},zN={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`},jN={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:e=>`ITC server received invalid event type: ${e}`},FK={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"},GK={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},qK={...QN,...PK,...DK,...vK,...xK,...BK,...HK,...kK,...UK,...zN,...jN,...FK,...GK,...LK};JN.exports={CHECK_LOGS_WRAPPER:KN,HDB_ERROR_MSGS:qK,DEFAULT_ERROR_MSGS:WN,DEFAULT_ERROR_RESP:CK,HTTP_STATUS_CODES:YN,LMDB_ERRORS_ENUM:MK,AUTHENTICATION_ERROR_MSGS:QN,VALIDATION_ERROR_MSGS:zN,ITC_ERRORS:jN}});var ce=N((xfe,eI)=>{"use strict";var ac=En(),VK=j(),$K=M(),gf=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,XN),this.statusCode=n||ac.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(ac.DEFAULT_ERROR_MSGS[n]?ac.DEFAULT_ERROR_MSGS[n]:ac.DEFAULT_ERROR_MSGS[ac.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&&VK[s](i)}},dS=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}},_S=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function XN(e,t,r,n=$K.LOG_LEVELS.ERROR,s=null,i=!1){if(ZN(e))return e;let o=new gf(e,t,r,n,s);return i&&delete o.stack,o}a(XN,"handleHDBError");function ZN(e){return e.__proto__.constructor.name===gf.name}a(ZN,"isHDBError");eI.exports={isHDBError:ZN,handleHDBError:XN,ClientError:dS,ServerError:_S,hdb_errors:ac}});var pt=N((Hfe,aI)=>{"use strict";var cu=M(),YK=te(),qr=ne(),lu=require("path"),KK=require("minimist"),tI=require("fs-extra"),rI=require("lodash");qr.initSync();var{CONFIG_PARAMS:Zi,DATABASES_PARAM_CONFIG:su,SYSTEM_SCHEMA_NAME:Rf}=cu,iu,ou,au;function nI(){if(iu!==void 0)return iu;if(qr.getHdbBasePath()!==void 0)return iu=qr.get(Zi.STORAGE_PATH)||lu.join(qr.getHdbBasePath(),cu.DATABASES_DIR_NAME),iu}a(nI,"getBaseSchemaPath");function sI(){if(ou!==void 0)return ou;if(qr.getHdbBasePath()!==void 0)return ou=oI(Rf),ou}a(sI,"getSystemSchemaPath");function iI(){if(au!==void 0)return au;if(qr.getHdbBasePath()!==void 0)return au=qr.get(cu.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||lu.join(qr.getHdbBasePath(),cu.TRANSACTIONS_DIR_NAME),au}a(iI,"getTransactionAuditStoreBasePath");function WK(e,t){let r=qr.get(Zi.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||lu.join(iI(),e.toString())}a(WK,"getTransactionAuditStorePath");function oI(e,t){e=e.toString(),t=t&&t.toString();let r=qr.get(cu.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||lu.join(nI(),e)}a(oI,"getSchemaPath");function QK(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,KK(process.argv));let n=r[Zi.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!YK.isObject(n))throw o;i=n}for(let o of i){let c=o[Rf];if(!c)continue;let l=qr.get(Zi.DATABASES);l=l??{};let d=c?.tables?.[t]?.[su.PATH];if(d)return rI.set(l,[Rf,su.TABLES,t,su.PATH],d),qr.setProperty(Zi.DATABASES,l),d;let u=c?.[su.PATH];if(u)return rI.set(l,[Rf,su.PATH],u),qr.setProperty(Zi.DATABASES,l),u}}let s=r[Zi.STORAGE_PATH.toUpperCase()];if(s){if(!tI.pathExistsSync(s))throw new Error(s+" does not exist");let i=lu.join(s,e);return tI.mkdirsSync(i),qr.setProperty(Zi.STORAGE_PATH,s),i}return sI()}a(QK,"initSystemSchemaPaths");function zK(){iu=void 0,ou=void 0,au=void 0}a(zK,"resetPaths");aI.exports={getBaseSchemaPath:nI,getSystemSchemaPath:sI,getTransactionAuditStorePath:WK,getTransactionAuditStoreBasePath:iI,getSchemaPath:oI,initSystemSchemaPaths:QK,resetPaths:zK}});var hn=N((qfe,_I)=>{"use strict";var jK=En().LMDB_ERRORS_ENUM,Ffe=require("lmdb"),JK=Gt(),Gfe=require("buffer").Buffer,{OVERFLOW_MARKER:cI,MAX_SEARCH_KEY_LENGTH:Af}=JK,lI=["number","string","symbol","boolean","bigint"];function XK(e){if(e=e?.primaryStore||e,!e)throw new Error(jK.ENV_REQUIRED)}a(XK,"validateEnv");function ZK(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(ZK,"stringifyData");function eW(e){return e instanceof Date?e.valueOf():e}a(eW,"convertKeyValueToWrite");function tW(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(lI.includes(typeof e))return e.length>Af?[e.slice(0,Af)+cI]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(lI.includes(typeof i))i.length>Af?r.push(i.slice(0,Af)+cI):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(tW,"getIndexedValues");var bf=0,uI=0;function dI(){uI=Date.now()-performance.now()}a(dI,"adjustStartTime");dI();var rW=6e4;setInterval(dI,rW).unref();function nW(){let e=performance.now()+uI;return e>bf?(bf=e,e):(bf+=488e-6,bf)}a(nW,"getNextMonotonicTime");_I.exports={validateEnv:XK,stringifyData:ZK,convertKeyValueToWrite:eW,getNextMonotonicTime:nW,getIndexedValues:tW}});var fI,mn,fS,cc=Oe(()=>{fI=require("events"),mn=class extends fI.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;[Symbol.asyncIterator](){let t=new fS;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){return this.queue?.shift()}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},fS=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var qo={};Ze(qo,{server:()=>it});var EI,it,Lr=Oe(()=>{EI=require("../index"),it={};(0,EI._assignPackageExport)("server",it)});var mS={};Ze(mS,{loadGQLSchema:()=>oW,start:()=>hS,startOnMainThread:()=>iW});function hS({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:d,StringValueNode:u}=await import("graphql"),_=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let g of _.definitions)switch(g.kind){case l.OBJECT_TYPE_DEFINITION:let x=function($){if($.kind==="NonNullType"){let ee=x($.type);return ee.nullable=!1,ee}if($.kind==="ListType")return{type:"array",elements:x($.type)};let se={type:$.name?.value};return Object.defineProperty(se,"location",{value:$.loc.startToken}),se};a(x,"getProperty");let T=g.name.value,A=[],I={table:null,database:null,properties:A};E.set(T,I);for(let $ of g.directives){if($.name.value==="table"){for(let se of $.arguments)I[se.name.value]=se.value.value;I.schema&&(I.database=I.schema),I.table||(I.table=T),I.audit&&(I.audit=I.audit!=="false"),I.attributes=I.properties,f.push(I)}if($.name.value==="sealed"&&(I.sealed=!0),$.name.value==="replicate"&&(I.replicate=!0),$.name.value==="export"){I.export=!0;for(let se of $.arguments)typeof I.export!="object"&&(I.export={}),I.export[se.name.value]=se.value.value}}let V=!1,X={};for(let $ of g.fields){let F=x($.type);F.name=$.name.value,A.push(F),X[F.name]=void 0;for(let se of $.directives){let ee=se.name.value;if(ee==="primaryKey")V?console.warn("Can not define two attributes as a primary key at",se.loc):(F.isPrimaryKey=!0,V=!0);else if(ee==="indexed")F.indexed=!0;else if(ee==="computed"){for(let Z of se.arguments||[])if(Z.name.value==="from"){let le=Z.value.value;F.computed={from:S(le,Z,X)},F.version==null&&(F.version=le)}else Z.name.value==="version"&&(F.version=Z.value.value);F.computed=F.computed||!0}else if(ee==="relationship"){let Z={};for(let le of se.arguments)Z[le.name.value]=le.value.value;F.relationship=Z}else if(ee==="createdTime")F.assignCreatedTime=!0;else if(ee==="updatedTime")F.assignUpdatedTime=!0;else if(ee==="expiresAt")F.expiresAt=!0;else if(ee==="allow"){let Z=F.authorizedRoles=[];for(let le of se.arguments)le.name.value==="role"&&Z.push(le.value.value)}else server.knownGraphQLDirectives.includes(ee)&&console.warn(`@${ee} is an unknown directive, at`,se.loc)}}I.type=T,T==="Query"&&(h=I)}function p(g){let T=E.get(g.type);T?(Object.defineProperty(g,"properties",{value:T.properties}),Object.defineProperty(g,"definition",{value:T})):g.type==="array"?p(g.elements):sW.includes(g.type)||(0,mI.getWorkerIndex)()===0&&console.error(`The type ${g.type} is unknown at line ${g.location.line}, column ${g.location.column}, in ${s}`)}a(p,"connectPropertyType");for(let g of E.values())for(let T of g.properties)p(T);for(let g of f)g.tableClass=e(g),g.export&&(g.export.name===""?i.set((0,ES.dirname)(n),g.tableClass):i.set((0,ES.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function S(g,T,A){return new hI.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${g}; } } } } computed;`,{filename:s,lineOffset:T.loc.startToken.line-1,columnOffset:T.loc.startToken.column}).runInThisContext()(A)}a(S,"createComputedFrom")}}var ES,hI,mI,sW,iW,oW,pI=Oe(()=>{ES=require("path"),hI=require("node:vm");Ne();mI=v(et()),sW=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(hS,"start");iW=hS,oW=hS({ensureTable:ft}).handleFile});async function yf(e){let t=(0,gI.pathToFileURL)(e).toString();return aW?(uu||(uu=cW(uW)),(await(await uu).import(t)).namespace):import(t)}async function cW(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),uu=new Compartment({console,Math,Date,fetch:lW,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,TI.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:pr,tables:pn,databases:Ve})}};let n=await(0,SI.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),uu}function lW(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 uW(){return{Resource:pr,tables:pn}}var SI,TI,gI,aW,uu,pS=Oe(()=>{us();Ne();SI=require("fs/promises"),TI=require("path"),gI=require("url"),aW=!1;a(yf,"secureImport");a(cW,"getCompartment");a(lW,"secureOnlyFetch");a(uW,"getGlobalVars")});var TS={};Ze(TS,{handleFile:()=>dW});async function dW(e,t,r,n){let s=new Map,i=await yf(r);c(i.default)&&n.set((0,SS.dirname)(t),i.default),o(i,(0,SS.dirname)(t));function o(l,d){for(let u in l){let _=l[u];c(_)?n.set(d+"/"+u,_):typeof _=="object"&&o(_,d+"/"+u)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var SS,RI=Oe(()=>{pS();SS=require("path");a(dW,"handleFile")});var RS={};Ze(RS,{start:()=>_W});function _W({resources:e}){e.set("login",gS),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var gS,AI=Oe(()=>{us();a(_W,"start");gS=class extends pr{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 CI={};Ze(CI,{parse:()=>bS,streamAsJSON:()=>du,stringify:()=>Vo});function du(e){return new AS({value:e})}function bI(e){return console.error(e),JSON.stringify(e.toString())}function yI(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Vo(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===II)return wI(e);if(t.resolution)return t.resolution.then(()=>Vo(e));throw t}}function wI(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+=wI(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Vo(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function bS(e){return hW.test(e)?fW.parse(e):JSON.parse(e)}var OI,NI,fW,EW,II,AS,hW,yS=Oe(()=>{OI=require("stream"),NI=v(require("json-bigint-fixes")),fW=(0,NI.default)({useNativeBigInt:!0}),EW=1e4,II={};BigInt.prototype.toJSON=function(){throw II};a(du,"streamAsJSON");AS=class extends OI.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;)if(o=i.next(),o.then&&(yield o.then(c=>(o=c,""))),o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),bI)}catch(s){yield bI(s)}else yield Vo(t)}else yield Vo(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);yI(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>EW?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 yI(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(bI,"handleError");a(yI,"when");a(Vo,"stringify");a(wI,"jsStringify");hW=/[[,:]\s*-?\d{16,}/;a(bS,"parse")});var qI=N((sEe,GI)=>{"use strict";var OS=require("recursive-iterator"),mW=require("alasql"),NS=require("clone"),DI=te(),{handleHDBError:LI,hdb_errors:pW}=ce(),{HDB_ERROR_MSGS:PI,HTTP_STATUS_CODES:MI}=pW,{getDatabases:SW}=(Ne(),ae(ot)),TW=["DISTINCT_ARRAY"],UI=Symbol("validateTables"),IS=Symbol("validateTable"),nEe=Symbol("getAllColumns"),vI=Symbol("validateAllColumns"),Of=Symbol("findColumn"),xI=Symbol("validateOrderBy"),_u=Symbol("validateSegment"),wS=Symbol("validateColumn"),BI=Symbol("setColumnsForTable"),HI=Symbol("checkColumnsForAsterisk"),kI=Symbol("validateGroupBy"),FI=Symbol("hasColumns"),CS=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[UI](),this[HI](),this[vI]()}[UI](){if(this[FI]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[IS](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[IS](t.table)})}}[FI](){let t=!1,r=new OS(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[IS](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=SW();if(!r[t.databaseid])throw LI(new Error,PI.SCHEMA_NOT_FOUND(t.databaseid),MI.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw LI(new Error,PI.TABLE_NOT_FOUND(t.databaseid,t.tableid),MI.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=NS(s);i.table=NS(t),this.attributes.push(i)})}[Of](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)}[HI](){let t=new OS(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[BI](r.tableid)}[BI](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new mW.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[vI](){this[_u](this.statement.columns,!1),this[_u](this.statement.joins,!1),this[_u](this.statement.where,!1),this[kI](this.statement.group,!1),this[_u](this.statement.order,!0)}[_u](t,r){if(!t)return;let n=new OS(t),s=[];for(let{node:i,path:o}of n)!DI.isEmpty(i)&&!DI.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[xI](i):s.push(this[wS](i)));return s}[kI](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&TW.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=NS(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Of](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[Of](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`}[xI](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[wS](t)}[wS](t){let r=this[Of](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]}};GI.exports=CS});var $I=N((oEe,VI)=>{"use strict";var DS=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")}};VI.exports=DS});var KI=N((cEe,YI)=>{"use strict";var LS=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};YI.exports=LS});var jI={};Ze(jI,{HAS_EXPIRATION:()=>wf,HAS_RESIDENCY_ID:()=>kS,HAS_STRUCTURE_UPDATE:()=>Cf,LAST_TIMESTAMP_PLACEHOLDER:()=>mu,LOCAL_TIMESTAMP:()=>gW,METADATA:()=>fu,NO_TIMESTAMP:()=>MS,PENDING_LOCAL_TIME:()=>FS,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>HS,RecordEncoder:()=>BS,TIMESTAMP_ASSIGN_LAST:()=>AW,TIMESTAMP_ASSIGN_NEW:()=>QI,TIMESTAMP_ASSIGN_PREVIOUS:()=>zI,TIMESTAMP_PLACEHOLDER:()=>Nf,TIMESTAMP_RECORD_PREVIOUS:()=>US,getUpdateRecord:()=>GS,handleLocalTimeForGets:()=>Df});function yW(){return hu[0]=hu[0]^64,RW.getFloat64(0)}function Df(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,d=l?.[fu];return d>=0&&(c.metadataFlags=d,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[fu]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,d=l[fu];return d>=0&&(c.metadataFlags=d,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,$o.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<$o.length;l++){let d=$o[l].deref();(!d||d.isDone||d.isCommitted)&&$o.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function GS(e,t,r){return function(n,s,i,o,c=-1,l,d,u="put",_,E){_||l==null?lc=i?.localTime?US|zI:MS:lc=l?i?.localTime?US|16384:QI|16384:MS;let f=d?.expiresAt;if(f>0&&(c|=wf),Eu=c,vS=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:lc>0},p,S=0;try{let g=i?.residencyId,T=d?.residencyId;T&&(xS=T,Eu|=kS,S|=Yo),g!==T&&(S|=Ko,g||(g=0)),c&wf&&(S|=Su),d?.originatingOperation&&(S|=pu),_&&(h.ifVersion=p=i?.version??null);let A=e.put(n,s,h);if(l){let I=d?.user?.username;if(E&&(If=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(S|=Cf,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let V=i?.localTime,x=r.get(V);if(x){let X=Pt(x).previousLocalTime;return r.put(V,uc(o,t,n,X,d?.nodeId??server.replication.getThisNodeId(r)??0,I,u,If,S,T,g,f),{ifVersion:p}),A}}r.put(mu,uc(o,t,n,i?.localTime?1:0,d?.nodeId??server.replication?.getThisNodeId(r)??0,I,u,If,S,T,g,f,d?.originatingOperation),{append:u!=="invalidate",instructedWrite:!0,ifVersion:p})}return A}catch(g){throw g.message+=" id: "+n+" options: "+h,g}}}var WI,PS,Nf,mu,HS,gW,fu,hu,RW,MS,QI,AW,zI,US,wf,kS,FS,Cf,bW,If,lc,Eu,vS,xS,BS,$o,dc=Oe(()=>{WI=require("msgpackr");Ei();PS=v(j()),Nf=new Uint8Array([1,1,1,1,4,64,0,0]),mu=new Uint8Array([1,1,1,1,1,0,0,0]),HS=new Uint8Array([1,1,1,1,3,64,0,0]),gW=Symbol("local-timestamp"),fu=Symbol("metadata"),hu=new Uint8Array(8),RW=new DataView(hu.buffer,0,8),MS=0,QI=0,AW=1,zI=3,US=4,wf=16,kS=32,FS=1,Cf=256,lc=0,Eu=-1,vS=0,xS=0,BS=class extends WI.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(lc||Eu>=0){let o=0,c=lc;c&&(o+=8,lc=0);let l=Eu,d=vS,u=xS;l>=0&&(o+=2,Eu=-1,d&&(o+=8,vS=0),u&&(o+=4,xS=0));let _=bW=r.call(this,s,i|2048|o);If=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(Nf[4]=c,Nf[5]=c>>8,_.set(Nf,E),E+=8),l>=0&&(_[E++]=l&31,_[E++]=l>>5,d&&((_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(E,d),E+=8),u&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setUint32(E,u)),_}else return r.call(this,s,i)};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(hu,0,c),c+=8;else for(let E=0;E<8;E++)hu[E]=t[c++];l=yW(),i=t[c]}let d,u;i<32&&(o=i|t[c+1]<<5,c+=2,o&wf&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&kS&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let _=r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c);return{localTime:l,value:_,[fu]:o,expiresAt:d,residencyId:u}}return r?.valueAsBuffer?t:super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(yW,"getTimestamp");a(Df,"handleLocalTimeForGets");$o=[];setInterval(()=>{for(let e=0;e<$o.length;e++){let t=$o[e].deref();!t||t.isDone||t.isCommitted?$o.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(PS.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):PS.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(GS,"getUpdateRecord")});var Tu=N((fEe,XI)=>{"use strict";var JI=ne(),OW=M(),{RecordEncoder:NW}=(dc(),ae(jI)),_Ee=require("fs");JI.initSync();var IW=JI.get(OW.CONFIG_PARAMS.STORAGE_CACHING)!==!1,qS=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=IW&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:NW})}};XI.exports=qS});var gu=N((hEe,ZI)=>{"use strict";var Sn=ne(),Gn=M();Sn.initSync();var Lf=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=1e3,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Sn.get(Gn.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Sn.get(Gn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Sn.get(Gn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Sn.get(Gn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Sn.get(Gn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Sn.get(Gn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Sn.get(Gn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Sn.get(Gn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Sn.get(Gn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Sn.get(Gn.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Sn.get(Gn.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Sn.get(Gn.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};ZI.exports=Lf;Lf.MAX_DBS=1e4});var Et=N((pEe,lw)=>{"use strict";var $S=require("lmdb"),ds=require("fs-extra"),Tn=require("path"),Pf=hn(),rw=j(),Vr=En().LMDB_ERRORS_ENUM,Mf=KI(),YS=Tu(),nw=gu(),eo=Gt(),ew=M(),{table:wW,resetDatabases:CW}=(Ne(),ae(ot)),tw=ne(),_s=eo.INTERNAL_DBIS_NAME,sw=eo.DBI_DEFINITION_NAME,DW="data.mdb",LW="lock.mdb",Ru=".mdb",PW="-lock",VS=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=qn(t,r),this.key_type=this.dbi[eo.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[eo.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new $S.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Uf(e,t){if(e===void 0)throw new Error(Vr.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Vr.ENV_NAME_REQUIRED)}a(Uf,"pathEnvNameValidation");async function KS(e,t,r=!0){try{await ds.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Vr.INVALID_BASE_PATH):n}try{let n=Tn.join(e,t+Ru);return await ds.access(n,ds.constants.R_OK|ds.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await ds.access(Tn.join(e,t,DW),ds.constants.R_OK|ds.constants.F_OK),Tn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Vr.INVALID_ENVIRONMENT)}else throw new Error(Vr.INVALID_ENVIRONMENT);throw n}}a(KS,"validateEnvironmentPath");function vf(e,t){if(Pf.validateEnv(e),t===void 0)throw new Error(Vr.DBI_NAME_REQUIRED)}a(vf,"validateEnvDBIName");async function MW(e,t,r=!1,n=!1){Uf(e,t);let s=Tn.basename(e);t=t.toString();let i=tw.get(ew.CONFIG_PARAMS.DATABASES);i||tw.setProperty(ew.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await KS(e,t,n),iw(e,t,r)}catch(o){if(o.message===Vr.INVALID_ENVIRONMENT){let c=Tn.join(e,t);await ds.mkdirp(n?c:e);let l=new nw(n?c:c+Ru,!1),d=$S.open(l);d.dbis=Object.create(null);let u=new YS(!1);d.openDB(_s,u),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=WS(e,t,r);return d[eo.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=d,d}throw o}}a(MW,"createEnvironment");async function UW(e,t,r,n=!0){Uf(e,t),t=t.toString();let s=Tn.join(e,t);return wW({table:t,database:Tn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(UW,"copyEnvironment");async function iw(e,t,r=!1){Uf(e,t),t=t.toString();let n=WS(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 KS(e,t),i=Tn.join(e,t+Ru),o=s!=i,c=new nw(s,o),l=$S.open(c);l.dbis=Object.create(null);let d=aw(l);for(let u=0;u<d.length;u++)qn(l,d[u]);return l[eo.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(iw,"openEnvironment");async function vW(e,t,r=!1){Uf(e,t),t=t.toString();let n=Tn.join(e,t+Ru),s=await KS(e,t);if(global.lmdb_map!==void 0){let i=WS(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await ow(o),delete global.lmdb_map[i]}}await ds.remove(s),await ds.remove(s===n?s+PW:Tn.join(Tn.dirname(s),LW))}a(vW,"deleteEnvironment");async function ow(e){Pf.validateEnv(e);let t=e[eo.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(ow,"closeEnvironment");function WS(e,t,r=!1){let s=`${Tn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(WS,"getCachedEnvironmentName");function xW(e){Pf.validateEnv(e);let t=Object.create(null),r=qn(e,_s);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==_s)try{t[n]=Object.assign(new Mf,s)}catch{rw.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(xW,"listDBIDefinitions");function aw(e){Pf.validateEnv(e);let t=[],r=qn(e,_s);for(let{key:n}of r.getRange({start:!1}))n!==_s&&t.push(n);return t}a(aw,"listDBIs");function BW(e,t){let n=qn(e,_s).getEntry(t),s=new Mf;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{rw.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(BW,"getDBIDefinition");function cw(e,t,r,n=!r){if(vf(e,t),t=t.toString(),t===_s)throw new Error(Vr.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return qn(e,t)}catch(s){if(s.message===Vr.DBI_DOES_NOT_EXIST){let i=new YS(r,n===!0),o=e.openDB(t,i),c=new Mf(r===!0,n);return o[sw]=c,qn(e,_s).putSync(t,c),e.dbis[t]=o,o}throw s}}a(cw,"createDBI");function qn(e,t){if(vf(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==_s?r=BW(e,t):r=new Mf,r===void 0)throw new Error(Vr.DBI_DOES_NOT_EXIST);let n;try{let s=new YS(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(Vr.DBI_DOES_NOT_EXIST):s}return n[sw]=r,e.dbis[t]=n,n}a(qn,"openDBI");function HW(e,t){vf(e,t),t=t.toString();let r=qn(e,t),n=r.getStats();return r[eo.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(HW,"statDBI");async function kW(e,t){try{let r=Tn.join(e,t+Ru);return(await ds.stat(r)).size}catch{throw new Error(Vr.INVALID_ENVIRONMENT)}}a(kW,"environmentDataSize");function FW(e,t){if(vf(e,t),t=t.toString(),t===_s)throw new Error(Vr.CANNOT_DROP_INTERNAL_DBIS_NAME);qn(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],qn(e,_s).removeSync(t)}a(FW,"dropDBI");function GW(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{qn(e,i)}catch(o){if(o.message===Vr.DBI_DOES_NOT_EXIST)cw(e,i,i!==t,i===t),n=!0;else throw o}}n&&CW()}a(GW,"initializeDBIs");lw.exports={openDBI:qn,openEnvironment:iw,createEnvironment:MW,listDBIs:aw,listDBIDefinitions:xW,createDBI:cw,dropDBI:FW,statDBI:HW,deleteEnvironment:vW,initializeDBIs:GW,TransactionCursor:VS,environmentDataSize:kW,copyEnvironment:UW,closeEnvironment:ow}});var dw=N((TEe,uw)=>{"use strict";var QS=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};uw.exports=QS});var fw=N((REe,_w)=>{"use strict";var zS=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}};_w.exports=zS});var hw=N((bEe,Ew)=>{"use strict";var jS=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};Ew.exports=jS});var _c=N((wEe,Sw)=>{"use strict";var qW=Et(),VW=dw(),$W=fw(),YW=hw(),vs=hn(),Au=En().LMDB_ERRORS_ENUM,KW=Gt(),hi=M(),WW=te(),QW=require("uuid"),OEe=require("lmdb"),{handleHDBError:zW,hdb_errors:jW}=ce(),{OVERFLOW_MARKER:NEe,MAX_SEARCH_KEY_LENGTH:IEe}=KW,mw=ne();mw.initSync();var xf=mw.get(hi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),JS=hi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Wo=hi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function JW(e,t,r,n,s=vs.getNextMonotonicTime()){tT(e,t,r,n),XS(e,t,r);let i=new VW,o=[],c=[];for(let l=0;l<n.length;l++){let d=n[l];pw(d,!0,s);let u=XW(e,t,r,d),_=d[t];o.push(u),c.push(_)}return ZS(o,c,n,i,s)}a(JW,"insertRecords");function XW(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 u=c([[{}]]);Array.isArray(u)&&(c=u[0][hi.FUNC_VAL],n[o]=c)}let l=vs.getIndexedValues(c),d=e.dbis[o];if(l){xf&&d.prefetch(l.map(u=>({key:u,value:s})),Bf);for(let u=0,_=l.length;u<_;u++)d.put(l[u],s)}}xf&&e.dbis[t].prefetch([s],Bf),e.dbis[t].put(s,n,n[Wo])})}a(XW,"insertRecord");function ZW(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(ZW,"removeSkippedRecords");function pw(e,t,r){let n=r>0;(n||!Number.isInteger(e[Wo]))&&(e[Wo]=r||(r=vs.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[JS]))&&(e[JS]=r||vs.getNextMonotonicTime()):delete e[JS]}a(pw,"setTimestamps");function XS(e,t,r){r.indexOf(hi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(hi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(hi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(hi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),qW.initializeDBIs(e,t,r)}a(XS,"initializeTransaction");async function eQ(e,t,r,n,s=vs.getNextMonotonicTime()){tT(e,t,r,n),XS(e,t,r);let i=new $W,o=[],c=[],l=[];for(let d=0;d<n.length;d++){let u=n[d],_=u[t],E;try{E=eT(e,t,u,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(d);continue}c.push(E),l.push(_)}return ZS(c,l,n,i,s,o)}a(eQ,"updateRecords");async function tQ(e,t,r,n,s=vs.getNextMonotonicTime()){try{tT(e,t,r,n)}catch(l){throw zW(l,l.message,jW.HTTP_STATUS_CODES.BAD_REQUEST)}XS(e,t,r);let i=new YW,o=[],c=[];for(let l=0;l<n.length;l++){let d=n[l],u;WW.isEmpty(d[t])?(u=QW.v4(),d[t]=u):u=d[t];let _=eT(e,t,d,u,i,!1,s);o.push(_),c.push(u)}return ZS(o,c,n,i,s)}a(tQ,"upsertRecords");async function ZS(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||vs.getNextMonotonicTime(),ZW(r,i),n}a(ZS,"finalizeWrite");function eT(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),d=l?.value,u=d;if(!d){if(i)return!1;d={}}if(pw(r,!u,o),Number.isInteger(r[Wo])&&d[Wo]>r[Wo])return!1;u&&s.original_records.push(d);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let p=r[h],S=e.dbis[h];if(S===void 0)continue;let g=d[h];if(typeof p=="function"){let A=p([[d]]);Array.isArray(A)&&(p=A[0][hi.FUNC_VAL],r[h]=p)}if(p===g)continue;let T=vs.getIndexedValues(g);if(T){xf&&S.prefetch(T.map(A=>({key:A,value:n})),Bf);for(let A=0,I=T.length;A<I;A++)S.remove(T[A],n)}if(T=vs.getIndexedValues(p),T){xf&&S.prefetch(T.map(A=>({key:A,value:n})),Bf);for(let A=0,I=T.length;A<I;A++)S.put(T[A],n)}}let f=Object.assign({},d,r);c.put(n,f,f[Wo])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:eT(e,t,r,n,s,i,o))}a(eT,"updateUpsertRecord");function rQ(e,t,r){if(vs.validateEnv(e),t===void 0)throw new Error(Au.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Au.WRITE_ATTRIBUTES_REQUIRED):new Error(Au.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(rQ,"validateBasic");function tT(e,t,r,n){if(rQ(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Au.RECORDS_REQUIRED):new Error(Au.RECORDS_MUST_BE_ARRAY)}a(tT,"validateWrite");function Bf(){}a(Bf,"noop");Sw.exports={insertRecords:JW,updateRecords:eQ,upsertRecords:tQ}});var Qo=N((DEe,nQ)=>{nQ.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:"__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"}]},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 Bs=N((LEe,Rw)=>{"use strict";var gw=te(),Tw=M(),fc=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,xs=require("joi"),to={schema_format:{pattern:fc,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},sQ=xs.alternatives(xs.string().min(1).max(to.schema_length.maximum).pattern(fc).messages({"string.pattern.base":"{:#label} "+to.schema_format.message}),xs.number(),xs.array()).required(),iQ=xs.alternatives(xs.string().min(1).max(to.schema_length.maximum).pattern(fc).messages({"string.pattern.base":"{:#label} "+to.schema_format.message}),xs.number()),oQ=xs.alternatives(xs.string().min(1).max(to.schema_length.maximum).pattern(fc).messages({"string.pattern.base":"{:#label} "+to.schema_format.message}),xs.number()).required();function aQ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>to.schema_length.maximum?`'${e}' maximum of 250 characters`:fc.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(aQ,"checkValidTable");function cQ(e,t){return gw.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(cQ,"validateSchemaExists");function lQ(e,t){let r=t.state.ancestors[0].schema;return gw.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(lQ,"validateTableExists");function uQ(e,t){return e.toLowerCase()===Tw.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${Tw.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(uQ,"validateSchemaName");Rw.exports={common_validators:to,schema_regex:fc,hdb_schema_table:sQ,validateSchemaExists:cQ,validateTableExists:lQ,validateSchemaName:uQ,checkValidTable:aQ,hdb_database:iQ,hdb_table:oQ}});var ct=N((MEe,Aw)=>{"use strict";var $r=require("validate.js");$r.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||$r.validators.type.checks[t](e)?null:` must be a '${t}' value`};$r.validators.type.checks={Object:function(e){return $r.isObject(e)&&!$r.isArray(e)},Array:$r.isArray,Integer:$r.isInteger,Number:$r.isNumber,String:$r.isString,Date:$r.isDate,Boolean:function(e){return typeof e=="boolean"}};$r.validators.hasValidFileExt=function(e,t){return $r.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};Aw.exports={validateObject:dQ,validateObjectAsync:_Q,validateBySchema:fQ};function dQ(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=$r(e,t,{format:"flat"});return r?new Error(r):null}a(dQ,"validateObject");async function _Q(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await $r.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(_Q,"validateObjectAsync");function fQ(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(fQ,"validateBySchema")});var Hf=N((vEe,bw)=>{var{common_validators:Hs}=Bs(),yu=ct(),bu="is required",zt={database:{presence:!1,format:Hs.schema_format,length:Hs.schema_length},schema:{presence:!1,format:Hs.schema_format,length:Hs.schema_length},table:{presence:!0,format:Hs.schema_format,length:Hs.schema_length},attribute:{presence:!0,format:Hs.schema_format,length:Hs.schema_length},hash_attribute:{presence:!0,format:Hs.schema_format,length:Hs.schema_length}};function Ou(e){for(let t in e)e[t]=e[t]===null||e[t]===void 0||typeof e[t]=="object"?e[t]:e[t].toString();return e}a(Ou,"makeAttributesStrings");function EQ(e){return e=Ou(e),zt.table.presence=!1,zt.attribute.presence=!1,zt.hash_attribute.presence=!1,yu.validateObject(e,zt)}a(EQ,"schema_object");function hQ(e){return e=Ou(e),zt.table.presence={message:bu},zt.attribute.presence=!1,zt.hash_attribute.presence=!1,yu.validateObject(e,zt)}a(hQ,"table_object");function mQ(e){return e=Ou(e),zt.table.presence={message:bu},zt.attribute.presence=!1,yu.validateObject(e,zt)}a(mQ,"create_table_object");function pQ(e){return e=Ou(e),zt.table.presence={message:bu},zt.attribute.presence={message:bu},zt.hash_attribute.presence=!1,yu.validateObject(e,zt)}a(pQ,"attribute_object");function SQ(e){return e=Ou(e),zt.table.presence={message:bu},zt.attribute.presence=!1,zt.hash_attribute.presence=!1,yu.validateObject(e,zt)}a(SQ,"describe_table");function TQ(e){if(e){if(!Array.isArray(e))throw new Error("residence must be a string array");if(e.length===0)throw new Error("residence cannot be an empty array");for(let t=0;t<e.length;t++)if(typeof e[t]!="string")throw new Error(`residence must be a string array, item '${e[t]}' is not a string`)}}a(TQ,"validateTableResidence");bw.exports={schema_object:EQ,create_table_object:mQ,table_object:hQ,attribute_object:pQ,describe_table:SQ,validateTableResidence:TQ}});var Ow=N((BEe,yw)=>{"use strict";var gQ=require("uuid"),rT=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||gQ.v4(),this.schema_table=`${this.schema}.${this.table}`}};yw.exports=rT});var kf=N((kEe,Nw)=>{"use strict";var RQ=Ow(),nT=class extends RQ{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}};Nw.exports=nT});var ww=N((GEe,Iw)=>{"use strict";Iw.exports=bQ;var AQ="inserted";function bQ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===AQ?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(bQ,"returnObject")});var Ff=N(($Ee,Pw)=>{"use strict";var yQ=M(),sT=Et(),OQ=_c(),{getSystemSchemaPath:NQ,getSchemaPath:IQ}=pt(),VEe=Qo(),wQ=Hf(),CQ=kf(),DQ=ww(),{handleHDBError:Cw,hdb_errors:Lw}=ce(),Dw=te(),{HTTP_STATUS_CODES:LQ}=Lw,PQ="inserted";Pw.exports=MQ;async function MQ(e){let t=wQ.attribute_object(e);if(t)throw Cw(new Error,t.message,Lw.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&Dw.checkGlobalSchemaTable(e.schema,e.table);if(r)throw Cw(new Error,r,LQ.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=Dw.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 CQ(e.schema,e.table,e.attribute,e.id);try{let i=await sT.openEnvironment(IQ(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}`);sT.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await sT.openEnvironment(NQ(),yQ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await OQ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return DQ(PQ,c,{records:[s]},l)}catch(i){throw i}}a(MQ,"lmdbCreateAttribute")});var oT=N((KEe,Uw)=>{var{hdb_table:UQ,hdb_database:Mw}=Bs(),vQ=ct(),iT=require("joi"),xQ={undefined:"undefined",null:"null"},BQ=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||xQ[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"),HQ=iT.object({database:Mw,schema:Mw,table:UQ,records:iT.array().items(iT.object().custom(BQ)).required()});Uw.exports=function(e){return vQ.validateBySchema(e,HQ)}});var Nu=N((zEe,xw)=>{"use strict";var mi=te(),vw=j(),QEe=oT(),{getDatabases:kQ}=(Ne(),ae(ot)),{ClientError:zo}=ce();xw.exports=FQ;function FQ(e){if(mi.isEmpty(e))throw new zo("invalid update parameters defined.");if(mi.isEmptyOrZeroLength(e.schema))throw new zo("invalid schema specified.");if(mi.isEmptyOrZeroLength(e.table))throw new zo("invalid table specified.");if(!Array.isArray(e.records))throw new zo("records must be an array");let t=kQ()[e.schema]?.[e.table];if(mi.isEmpty(t))throw new zo(`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&&mi.isEmptyOrZeroLength(o[r]))throw vw.error("a valid hash attribute must be provided with update record:",o),new zo("a valid hash attribute must be provided with update record, check log for more info");if(!mi.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw vw.error(`a valid hash value must be provided with ${e.operation} record:`,o),new zo(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!mi.isEmpty(o[r])&&o[r]!==""&&n.has(mi.autoCast(o[r]))&&(o.skip=!0),n.add(mi.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(FQ,"insertUpdateValidate")});var Iu=N((JEe,Bw)=>{"use strict";var GQ=M().OPERATIONS_ENUM,aT=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=GQ.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};Bw.exports=aT});var wu=N((ehe,kw)=>{"use strict";var ZEe=Iu(),Gf=M(),cT=te(),Hw=j(),qQ=require("uuid"),{handleHDBError:qf,hdb_errors:VQ}=ce(),{HDB_ERROR_MSGS:Vf,HTTP_STATUS_CODES:$f}=VQ;kw.exports=$Q;function $Q(e,t,r){for(let s=0;s<t.length;s++)YQ(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];KQ(i,r,e.operation)}}a($Q,"processRows");function YQ(e){if(Buffer.byteLength(String(e))>Gf.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw qf(new Error,Vf.ATTR_NAME_LENGTH_ERR(e),$f.BAD_REQUEST,void 0,void 0,!0);if(cT.isEmptyOrZeroLength(e)||cT.isEmpty(e.trim()))throw qf(new Error,Vf.ATTR_NAME_NULLISH_ERR,$f.BAD_REQUEST,void 0,void 0,!0)}a(YQ,"validateAttribute");function KQ(e,t,r){if(!e.hasOwnProperty(t)||cT.isEmptyOrZeroLength(e[t])){if(r===Gf.OPERATIONS_ENUM.INSERT||r===Gf.OPERATIONS_ENUM.UPSERT){e[t]=qQ.v4();return}throw Hw.error("Update transaction aborted due to record with no hash value:",e),qf(new Error,Vf.RECORD_MISSING_HASH_ERR,$f.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>Gf.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Hw.error(e),qf(new Error,Vf.HASH_VAL_LENGTH_ERR,$f.BAD_REQUEST,void 0,void 0,!0)}a(KQ,"validateHash")});var Gw=N((rhe,Fw)=>{"use strict";var lT=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};Fw.exports=lT});var $w=N((she,Vw)=>{"use strict";var uT=Et(),WQ=j(),qw=En().LMDB_ERRORS_ENUM;Vw.exports=QQ;async function QQ(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 uT.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==qw.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await uT.closeEnvironment(global.lmdb_map[n]),await uT.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==qw.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){WQ.error(t)}}a(QQ,"cleanLMDBMap")});var pi=N((ohe,Qw)=>{"use strict";var Cu=require("crypto"),zQ=ne(),{CONFIG_PARAMS:jQ}=M(),Kw="aes-256-cbc",JQ=32,XQ=16,dT=64,Ww=32,ZQ=dT+Ww,Yw=new Map;Qw.exports={encrypt:ez,decrypt:tz,createNatsTableStreamName:rz};function ez(e){let t=Cu.randomBytes(JQ),r=Cu.randomBytes(XQ),n=Cu.createCipheriv(Kw,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(ez,"encrypt");function tz(e){let t=e.substr(0,dT),r=e.substr(dT,Ww),n=e.substr(ZQ,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Cu.createDecipheriv(Kw,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(tz,"decrypt");function rz(e,t){let r=zQ.get(jQ.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Yw.get(r);return n||(n=Cu.createHash("md5").update(r).digest("hex"),Yw.set(r,n)),n}a(rz,"createNatsTableStreamName")});var Si=N((lhe,jw)=>{"use strict";var che=gn(),Du=j(),zw=Hf(),nz=pi(),Yf=te(),{handleHDBError:Kf,hdb_errors:sz}=ce(),{HDB_ERROR_MSGS:Wf,HTTP_STATUS_CODES:_T}=sz,iz=ne();iz.initSync();var{getDatabases:fT}=(Ne(),ae(ot)),oz=require("fs-extra");jw.exports={describeAll:az,describeTable:Qf,describeSchema:cz};async function az(e){try{let t=Yf.isEmptyOrZeroLength(e),r,n;t||(r=e.hdb_user.role.permission,n=r.super_user||r.cluster_user);let s=fT(),i={},o={},c=[],l=e?.exact_count;for(let u in s){i[u]=!0,!t&&!n&&(o[u]=e.hdb_user.role.permission[u].describe);let _=s[u];for(let E in _)try{let f;if(t||n)f=await Qf({schema:u,table:E,exact_count:l});else if(r&&r[u].describe&&r[u].tables[E].describe){let h=r[u].tables[E].attribute_permissions;f=await Qf({schema:u,table:E,exact_count:l},h)}f&&c.push(f)}catch(f){Du.error(f)}}let d={};for(let u in c)t||n?(d[c[u].schema]==null&&(d[c[u].schema]={}),d[c[u].schema][c[u].name]=c[u],i[c[u].schema]&&delete i[c[u].schema]):o[c[u].schema]&&(d[c[u].schema]==null&&(d[c[u].schema]={}),d[c[u].schema][c[u].name]=c[u],i[c[u].schema]&&delete i[c[u].schema]);for(let u in i)t||n?d[u]={}:o[u]&&(d[u]={});return d}catch(t){return Du.error("Got an error in describeAll"),Du.error(t),Kf(new Error,Wf.DESCRIBE_ALL_ERR)}}a(az,"describeAll");async function Qf(e,t){Yf.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=zw.describe_table(e);if(i)throw i;let c=fT()[r];if(!c)throw Kf(new Error,Wf.SCHEMA_NOT_FOUND(e.schema),_T.NOT_FOUND);let l=c[n];if(!l)throw Kf(new Error,Wf.TABLE_NOT_FOUND(e.schema,e.table),_T.NOT_FOUND);function d(f){u.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0}))}a(d,"pushAtt");let u=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&d(h)})}else l.attributes?.forEach(f=>d(f));let _;try{_=(await oz.stat(l.primaryStore.env.path)).size}catch(f){Du.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:u,db_size:_};E.clustering_stream_name=nz.createNatsTableStreamName(E.schema,E.name);try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let p of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=p[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let p of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=p}catch(f){Du.warn(`unable to stat table dbi due to ${f}`)}return E}a(Qf,"descTable");async function cz(e){Yf.transformReq(e);let t=zw.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user.role.permission.super_user&&(r=e.hdb_user.role.permission[e.schema]);let n=e.schema.toString(),i=fT()[n];if(!i)throw Kf(new Error,Wf.SCHEMA_NOT_FOUND(e.schema),_T.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Yf.isEmpty(l)||l.describe){let d=await Qf({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);d&&(o[d.name]=d)}}return o}a(cz,"describeSchema")});var Ti=N((fhe,tC)=>{var lz=Qo(),{callbackify:Xw,promisify:uz}=require("util"),{getDatabases:Zw}=(Ne(),ae(ot));tC.exports={setSchemaDataToGlobal:Jw,getTableSchema:dz,getSystemSchema:_z,setSchemaDataToGlobalAsync:uz(Jw)};var eC=Si(),dhe=Xw(eC.describeAll),_he=Xw(eC.describeTable);function Jw(e){global.hdb_schema=Zw(),e&&e()}a(Jw,"setSchemaDataToGlobal");function dz(e,t,r){let n=Zw()[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(dz,"getTableSchema");function _z(){return lz}a(_z,"getSystemSchema")});var Rn=N((hhe,iC)=>{"use strict";var jf=oT(),Sr=te(),fz=require("util"),Jf=Vn(),Ez=Ti(),rC=j(),{handleHDBError:jo,hdb_errors:hz}=ce(),{HTTP_STATUS_CODES:Jo}=hz,mz=fz.promisify(Ez.getTableSchema),pz="updated",nC="inserted",sC="upserted";iC.exports={insert:Tz,update:gz,upsert:Rz,validation:Sz,flush:Az};async function Sz(e){if(Sr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Sr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Sr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await mz(e.schema,e.table),r=jf(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&&Sr.isEmptyOrZeroLength(c[n]))throw rC.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(!Sr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw rC.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Sr.isEmpty(c[n])&&c[n]!==""&&s.has(Sr.autoCast(c[n]))&&(c.skip=!0),s.add(Sr.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(Sz,"validation");async function Tz(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=jf(e);if(t)throw jo(new Error,t.message,Jo.BAD_REQUEST);Sr.transformReq(e);let r=Sr.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,Jo.BAD_REQUEST);let n=await Jf.createRecords(e);return zf(nC,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(Tz,"insertData");async function gz(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=jf(e);if(t)throw jo(new Error,t.message,Jo.BAD_REQUEST);Sr.transformReq(e);let r=Sr.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,Jo.BAD_REQUEST);let n=await Jf.updateRecords(e);return Sr.isEmpty(n.existing_rows)?zf(pz,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):zf(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(gz,"updateData");async function Rz(e){if(e.operation!=="upsert")throw jo(new Error,"invalid operation, must be upsert",Jo.INTERNAL_SERVER_ERROR);let t=jf(e);if(t)throw jo(new Error,t.message,Jo.BAD_REQUEST);Sr.transformReq(e);let r=Sr.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,Jo.BAD_REQUEST);let n=await Jf.upsertRecords(e);return zf(sC,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(Rz,"upsertData");function zf(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===nC?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===sC?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(zf,"returnObject");function Az(e){return Sr.transformReq(e),Jf.flush(e.schema,e.table)}a(Az,"flush")});var hT=N((phe,cC)=>{var bz=ct(),ET=require("joi"),{hdb_table:yz,hdb_database:oC}=Bs(),aC={schema:oC,database:oC,table:yz},Oz={date:ET.date().iso().required()},Nz={timestamp:ET.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};cC.exports=function(e,t){let r=t==="timestamp"?{...aC,...Nz}:{...aC,...Oz},n=ET.object(r);return bz.validateBySchema(e,n)}});var dC=N((She,uC)=>{var Iz=ct(),mT=require("joi"),{hdb_table:wz,hdb_database:lC}=Bs(),Cz=mT.object({schema:lC,database:lC,table:wz,hash_values:mT.array().required(),ids:mT.array()});uC.exports=function(e){return Iz.validateBySchema(e,Cz)}});var fC=N((The,_C)=>{"use strict";var pT=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}},ST=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}},TT=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};_C.exports={InsertObject:pT,NoSQLSeachObject:ST,DeleteResponseObject:TT}});var so=N((Rhe,SC)=>{"use strict";var hC=hT(),Dz=dC(),Xo=te(),EC=require("moment"),mC=j(),{promisify:Lz,callbackify:Pz}=require("util"),Zo=M(),Mz=Ti(),gT=Lz(Mz.getTableSchema),RT=Vn(),{DeleteResponseObject:Uz}=fC(),{handleHDBError:ro,hdb_errors:vz}=ce(),{HDB_ERROR_MSGS:Xf,HTTP_STATUS_CODES:no}=vz,xz="records successfully deleted",Bz=Pz(pC);SC.exports={delete:Bz,deleteRecord:pC,deleteFilesBefore:Hz,deleteAuditLogsBefore:kz};async function Hz(e){let t=hC(e,"date");if(t)throw ro(t,t.message,no.BAD_REQUEST,void 0,void 0,!0);if(Xo.transformReq(e),!EC(e.date,EC.ISO_8601).isValid())throw ro(new Error,Xf.INVALID_DATE,no.BAD_REQUEST,Zo.LOG_LEVELS.ERROR,Xf.INVALID_DATE,!0);let n=Xo.checkSchemaTableExist(e.schema,e.table);if(n)throw ro(new Error,n,no.NOT_FOUND,Zo.LOG_LEVELS.ERROR,n,!0);let s=await RT.deleteRecordsBefore(e);if(await gT(e.schema,e.table),mC.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(Hz,"deleteFilesBefore");async function kz(e){let t=hC(e,"timestamp");if(t)throw ro(t,t.message,no.BAD_REQUEST,void 0,void 0,!0);if(Xo.transformReq(e),isNaN(e.timestamp))throw ro(new Error,Xf.INVALID_VALUE("Timestamp"),no.BAD_REQUEST,Zo.LOG_LEVELS.ERROR,Xf.INVALID_VALUE("Timestamp"),!0);let r=Xo.checkSchemaTableExist(e.schema,e.table);if(r)throw ro(new Error,r,no.NOT_FOUND,Zo.LOG_LEVELS.ERROR,r,!0);let n=await RT.deleteAuditLogsBefore(e);return await gT(e.schema,e.table),mC.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(kz,"deleteAuditLogsBefore");async function pC(e){e.ids&&(e.hash_values=e.ids);let t=Dz(e);if(t)throw ro(t,t.message,no.BAD_REQUEST,void 0,void 0,!0);Xo.transformReq(e);let r=Xo.checkSchemaTableExist(e.schema,e.table);if(r)throw ro(new Error,r,no.NOT_FOUND,Zo.LOG_LEVELS.ERROR,r,!0);try{await gT(e.schema,e.table);let n=await RT.deleteRecords(e);return Xo.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${xz}`),n}catch(n){if(n.message===Zo.SEARCH_NOT_FOUND_MESSAGE){let s=new Uz;return s.message=Zo.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(pC,"deleteRecord")});var Zf=N((bhe,RC)=>{var Fz=require("crypto"),TC=9;function Gz(e){let t=Vz(TC),r=gC(e+t);return t+r}a(Gz,"createHash");function qz(e,t){let r=e?.substr(0,TC),n=r+gC(t+r);return e===n}a(qz,"validateHash");function Vz(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(Vz,"generateSalt");function gC(e){return Fz.createHash("md5").update(e).digest("hex")}a(gC,"md5");RC.exports={hash:Gz,validate:qz}});var bC=N((Ohe,AC)=>{var AT=ct(),Pr={username:{presence:!0,format:"[\\w\\-\\_]+",exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function $z(e){return Pr.password.presence=!0,Pr.username.presence=!0,Pr.role.presence=!0,Pr.active.presence=!0,AT.validateObject(e,Pr)}a($z,"addUserValidation");function Yz(e){return Pr.password.presence=!1,Pr.username.presence=!0,Pr.role.presence=!1,Pr.active.presence=!1,AT.validateObject(e,Pr)}a(Yz,"alterUserValidation");function Kz(e){return Pr.password.presence=!1,Pr.username.presence=!0,Pr.role.presence=!1,Pr.active.presence=!1,AT.validateObject(e,Pr)}a(Kz,"dropUserValidation");AC.exports={addUserValidation:$z,alterUserValidation:Yz,dropUserValidation:Kz}});var lt=N((whe,OC)=>{"use strict";var{platform:Ihe}=require("os"),Wz="nats-server.zip",bT="nats-server",Qz=process.platform==="win32"?`${bT}.exe`:bT,zz=/^[^\s.,*>]+$/,yC="__request__",jz=a(e=>`${e}.${yC}`,"REQUEST_SUBJECT"),Jz={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},Xz={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},Zz={HUB:"hub.pid",LEAF:"leaf.pid"},ej={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},tj={SUCCESS:"success",ERROR:"error"},rj={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},nj={TXN:"txn",MSGID:"msgid"},Ec={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},sj={[Ec.ERR]:1,[Ec.WRN]:2,[Ec.INF]:3,[Ec.DBG]:4,[Ec.TRC]:5},ij={debug:"-D",trace:"-DVV"};OC.exports={NATS_SERVER_ZIP:Wz,NATS_SERVER_NAME:bT,NATS_BINARY_NAME:Qz,PID_FILES:Zz,NATS_CONFIG_FILES:Xz,SERVER_SUFFIX:ej,NATS_TERM_CONSTRAINTS_RX:zz,REQUEST_SUFFIX:yC,UPDATE_REMOTE_RESPONSE_STATUSES:tj,CLUSTER_STATUS_STATUSES:rj,REQUEST_SUBJECT:jz,SUBJECT_PREFIXES:nj,MSG_HEADERS:Jz,LOG_LEVELS:Ec,LOG_LEVEL_FLAGS:ij,LOG_LEVEL_HIERARCHY:sj}});var yT=N(NC=>{"use strict";var oj={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
|
|
1
|
+
"use strict";var ej=Object.create;var Od=Object.defineProperty;var tj=Object.getOwnPropertyDescriptor;var rj=Object.getOwnPropertyNames;var nj=Object.getPrototypeOf,sj=Object.prototype.hasOwnProperty;var a=(e,t)=>Od(e,"name",{value:t,configurable:!0});var De=(e,t)=>()=>(e&&(t=e(e=0)),t);var b=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),et=(e,t)=>{for(var r in t)Od(e,r,{get:t[r],enumerable:!0})},Hw=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of rj(t))!sj.call(e,s)&&s!==r&&Od(e,s,{get:()=>t[s],enumerable:!(n=tj(t,s))||n.enumerable});return e};var v=(e,t,r)=>(r=e!=null?ej(nj(e)):{},Hw(t||!e||!e.__esModule?Od(r,"default",{value:e,enumerable:!0}):r,e)),oe=e=>Hw(Od({},"__esModule",{value:!0}),e);var Fw=b((Uge,kw)=>{var ij=require("fast-glob"),{statSync:ng,existsSync:sg,readFileSync:oj,writeFileSync:aj}=require("fs"),{spawnSync:cj,spawn:lj,execFileSync:Mge}=require("child_process"),{isMainThread:uj}=require("worker_threads"),{join:xo,relative:xw}=require("path"),{PACKAGE_ROOT:vs}=M(),{tmpdir:dj,platform:_j}=require("os");require("source-map-support").install();var fj=["resources","server","dataLayer","components"],Nd="ts-build",ig,Ej=__filename.endsWith("tsBuild.js");if(Ej){if(uj){let r;try{ng(xo(vs,Nd)),r=!0}catch{}if(r)for(let n of ij.sync(fj.map(s=>s+"/**/*.ts"),{cwd:vs})){let s=0,i=0;try{s=ng(xo(vs,n)).mtimeMs-5e3,i=ng(xo(vs,Nd,n.replace(/.ts$/,".js"))).mtimeMs}catch{}if(s>i){console.warn(`TypeScript ${n} is not compiled`+(i?` (TS source file was modified at ${new Date(s)} and compiled file at ${new Date(i)})`:"")+", consider enabling auto-compilation of TypeScript in your IDE), compiling now."),ig=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),ig=!0;if(ig){let n=xo(vs,"node_modules/.bin/tsc");_j()==="win32"&&(n+=".cmd");let s=cj(n,{cwd:vs});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=xo(dj(),"harperdb-tsc.pid"),o;if(sg(i))try{process.kill(+oj(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=lj(n,["--watch"],{cwd:vs,detached:!0,stdio:"ignore"});aj(i,c.pid.toString()),c.unref()}}}}let e=kw.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(vs)&&!n[0].includes("node_modules")){let i=xw(vs,n[0]),o;i.startsWith(Nd)?o=xo(vs,xw(Nd,i)):o=xo(vs,Nd,i);let c=xo(o,r),l=c+".js";if(sg(l))return l;if(c.includes(".")&&sg(c))return c}return t(r,n,s)}}});var M=b((Hge,eC)=>{"use strict";var ns=require("path"),hj=require("fs"),{relative:vge,join:Bge}=ns,{existsSync:mj}=hj;function pj(){let e=__dirname;for(;!mj(ns.join(e,"package.json"));){let t=ns.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(pj,"getHDBPackageRoot");var ko=pj(),Gw="js",JE=Gw,Sj="harperdb-config.yaml",Tj="defaultConfig.yaml",gj="hdb",qw=`harperdb.${JE}`,$w=`customFunctionsServer.${JE}`,Rj=`restartHdb.${JE}`,ag="HarperDB",zE="Custom Functions",XE="Clustering Hub",ZE="Clustering Leaf",Aj="Clustering Ingest Service",bj="Clustering Reply Service",yj="foreground.pid",Oj="hdb.pid",Nj="data",Ij={HDB:ag,CLUSTERING_HUB:XE,CLUSTERING_LEAF:ZE,CLUSTERING_INGEST_SERVICE:Aj,CLUSTERING_REPLY_SERVICE:bj,CUSTOM_FUNCTIONS:zE,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"},wj={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},Cj={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},Dj={harperdb:ag,"clustering hub":XE,"clustering leaf":ZE,"custom functions":zE,custom_functions:zE,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},Pj={CLUSTERING_HUB_PROC_DESCRIPTOR:XE,CLUSTERING_LEAF_PROC_DESCRIPTOR:ZE},og={HDB:ns.join(ko,"server/harperdb"),CUSTOM_FUNCTIONS:ns.join(ko,"server/customFunctions"),CLUSTERING_HUB:ns.join(ko,"server/nats"),CLUSTERING_LEAF:ns.join(ko,"server/nats")},Lj={HDB:ns.join(og.HDB,qw),CUSTOM_FUNCTIONS:ns.join(og.CUSTOM_FUNCTIONS,$w)},Mj={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:ns.join(ko,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:ns.join(ko,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:ns.join(ko,"launchServiceScripts/launchUpdateNodes4-0-0.js")},Uj={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},Vw="support@harperdb.io",vj="customer-success@harperdb.io",Yw=1,Bj=4141,Kw="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",Hj="https://www.harperdb.io/product",xj=`For support, please submit a request at ${Kw} or contact ${Vw}`,Ww=`For license support, please contact ${vj}`,kj="None of the specified records were found.",Fj="hash attribute not found",Gj=`Your current license only supports ${Yw} role. ${Ww}`,qj="Your current license only supports 3 connections to a node.",$j="127.0.0.1",Vj=1,Yj=/^\.$/,Kj=/^\.\.$/,Wj="U+002E",jj=/\//g,Qj="U+002F",zj=/U\+002F/g,Jj=/^U\+002E$/,Xj=/^U\+002EU\+002E$/,Zj="d",eQ=999999,tQ="*",rQ="--max-old-space-size=",nQ="system",sQ="__hdb_hash",iQ=".harperdb",oQ=".hdb",aQ="keys",cQ="hdb_boot_properties.file",lQ=".updateConfig.json",uQ="SIGTSTP",dQ=24,_Q=6e4,fQ=448,EQ="blob",hQ="database",mQ="schema",pQ="transactions",SQ=".count",TQ="id",gQ="PROCESS_NAME",jw={SETTINGS_PATH_KEY:"settings_path"},Qw=require("lodash"),RQ={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={HDB_PATH_KEY:"HDB_INTERNAL_PATH",HDB_AUTH_HEADER:"hdb_auth_header",HDB_USER_DATA_KEY:"hdb_user",CHUNK_SIZE:1e3,MAX_CHARACTER_SIZE:250},bQ={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},yQ={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"},OQ={JOB_TABLE_HASH_ATTRIBUTE:"id",NODE_TABLE_HASH_ATTRIBUTE:"name",ATTRIBUTE_TABLE_HASH_ATTRIBUTE:"id",LICENSE_TABLE_HASH_ATTRIBUTE:"license_key",ROLE_TABLE_HASH_ATTRIBUTE:"id",SCHEMA_TABLE_HASH_ATTRIBUTE:"name",TABLE_TABLE_HASH_ATTRIBUTE:"id",USER_TABLE_HASH_ATTRIBUTE:"username",INFO_TABLE_ATTRIBUTE:"info_id"},On="hdb_internal:",NQ={CREATE_SCHEMA:On+"create_schema",CREATE_TABLE:On+"create_table",CREATE_ATTRIBUTE:On+"create_attribute",ADD_USER:On+"add_user",ALTER_USER:On+"alter_user",DROP_USER:On+"drop_user",HDB_NODES:On+"hdb_nodes",HDB_USERS:On+"hdb_users",HDB_WORKERS:On+"hdb_workers",CATCHUP:On+"catchup",SCHEMA_CATCHUP:On+"schema_catchup",WORKER_ROOM:On+"cluster_workers"},IQ={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"},wQ="060493.ks",CQ=".license",DQ={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},ae={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"},PQ={CSV:".csv",JSON:".json"},LQ={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"},Id={};Id[ae.INSERT]=ae.INSERT;Id[ae.UPDATE]=ae.UPDATE;Id[ae.UPSERT]=ae.UPSERT;Id[ae.DELETE]=ae.DELETE;var tt=Object.create(null);tt[ae.DESCRIBE_ALL]=ae.DESCRIBE_ALL;tt[ae.DESCRIBE_TABLE]=ae.DESCRIBE_TABLE;tt[ae.DESCRIBE_SCHEMA]=ae.DESCRIBE_SCHEMA;tt[ae.READ_LOG]=ae.READ_LOG;tt[ae.ADD_NODE]=ae.ADD_NODE;tt[ae.LIST_USERS]=ae.LIST_USERS;tt[ae.LIST_ROLES]=ae.LIST_ROLES;tt[ae.USER_INFO]=ae.USER_INFO;tt[ae.SQL]=ae.SQL;tt[ae.GET_JOB]=ae.GET_JOB;tt[ae.SEARCH_JOBS_BY_START_DATE]=ae.SEARCH_JOBS_BY_START_DATE;tt[ae.DELETE_FILES_BEFORE]=ae.DELETE_FILES_BEFORE;tt[ae.EXPORT_LOCAL]=ae.EXPORT_LOCAL;tt[ae.EXPORT_TO_S3]=ae.EXPORT_TO_S3;tt[ae.CLUSTER_STATUS]=ae.CLUSTER_STATUS;tt[ae.REMOVE_NODE]=ae.REMOVE_NODE;tt[ae.RESTART]=ae.RESTART;tt[ae.CUSTOM_FUNCTIONS_STATUS]=ae.CUSTOM_FUNCTIONS_STATUS;tt[ae.GET_CUSTOM_FUNCTIONS]=ae.GET_CUSTOM_FUNCTIONS;tt[ae.GET_CUSTOM_FUNCTION]=ae.GET_CUSTOM_FUNCTION;tt[ae.SET_CUSTOM_FUNCTION]=ae.SET_CUSTOM_FUNCTION;tt[ae.DROP_CUSTOM_FUNCTION]=ae.DROP_CUSTOM_FUNCTION;tt[ae.ADD_CUSTOM_FUNCTION_PROJECT]=ae.ADD_CUSTOM_FUNCTION_PROJECT;tt[ae.DROP_CUSTOM_FUNCTION_PROJECT]=ae.DROP_CUSTOM_FUNCTION_PROJECT;tt[ae.PACKAGE_CUSTOM_FUNCTION_PROJECT]=ae.PACKAGE_CUSTOM_FUNCTION_PROJECT;tt[ae.DEPLOY_CUSTOM_FUNCTION_PROJECT]=ae.DEPLOY_CUSTOM_FUNCTION_PROJECT;tt[ae.ADD_SSH_KEY]=ae.ADD_SSH_KEY;tt[ae.UPDATE_SSH_KEY]=ae.UPDATE_SSH_KEY;tt[ae.DELETE_SSH_KEY]=ae.DELETE_SSH_KEY;var UQ={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"},vQ={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},zw={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"},BQ=Qw.invert(zw),HQ={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"},P={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_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_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",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",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},Jw={settings_path:jw.SETTINGS_PATH_KEY,hdb_root_key:P.ROOTPATH,hdb_root:P.ROOTPATH,rootpath:P.ROOTPATH,server_port_key:P.OPERATIONSAPI_NETWORK_PORT,server_port:P.OPERATIONSAPI_NETWORK_PORT,cert_key:P.TLS_CERTIFICATE,certificate:P.TLS_CERTIFICATE,private_key_key:P.TLS_PRIVATEKEY,private_key:P.TLS_PRIVATEKEY,http_secure_enabled_key:P.OPERATIONSAPI_NETWORK_HTTPS,https_on:P.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:P.OPERATIONSAPI_NETWORK_CORS,cors_on:P.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:P.LOGGING_LEVEL,log_level:P.LOGGING_LEVEL,log_path_key:P.LOGGING_ROOT,log_path:P.LOGGING_ROOT,clustering_node_name_key:P.CLUSTERING_NODENAME,node_name:P.CLUSTERING_NODENAME,clustering_enabled_key:P.CLUSTERING_ENABLED,clustering:P.CLUSTERING_ENABLED,max_http_threads:P.THREADS_COUNT,max_hdb_processes:P.THREADS_COUNT,server_timeout_key:P.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:P.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:P.LOGGING_AUDITLOG,disable_transaction_log:P.LOGGING_AUDITLOG,operation_token_timeout_key:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:P.HTTP_PORT,custom_functions_port:P.HTTP_PORT,custom_functions_directory_key:P.COMPONENTSROOT,custom_functions_directory:P.COMPONENTSROOT,max_custom_function_processes:P.THREADS_COUNT,logging_console:P.LOGGING_CONSOLE,log_to_file:P.LOGGING_FILE,log_to_stdstreams:P.LOGGING_STDSTREAMS,local_studio_on:P.LOCALSTUDIO_ENABLED,clustering_port:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:P.CLUSTERING_USER,clustering_enabled:P.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:P.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:P.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:P.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:P.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:P.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:P.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:P.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxconsumemsgs:P.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:P.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,clustering_leafserver_streams_maxmsgs:P.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:P.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:P.CLUSTERING_NODENAME,clustering_tls_certificate:P.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:P.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:P.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:P.CLUSTERING_TLS_INSECURE,clustering_tls_verify:P.CLUSTERING_TLS_VERIFY,clustering_loglevel:P.CLUSTERING_LOGLEVEL,clustering_republishmessages:P.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:P.CLUSTERING_DATABASELEVEL,customfunctions_network_port:P.HTTP_PORT,customfunctions_tls_certificate:P.TLS_CERTIFICATE,customfunctions_network_cors:P.HTTP_CORS,customfunctions_network_corsaccesslist:P.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:P.HTTP_HEADERSTIMEOUT,customfunctions_network_https:P.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:P.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:P.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:P.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:P.HTTP_TIMEOUT,customfunctions_tls:P.TLS,http_threads:P.THREADS_COUNT,threads:P.THREADS_COUNT,threads_count:P.THREADS_COUNT,threads_debug:P.THREADS_DEBUG,threads_debug_startingport:P.THREADS_DEBUG_STARTINGPORT,threads_debug_port:P.THREADS_DEBUG_PORT,threads_debug_host:P.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:P.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:P.THREADS_MAXHEAPMEMORY,http_session_affinity:P.HTTP_SESSIONAFFINITY,http_compressionthreshold:P.HTTP_COMPRESSIONTHRESHOLD,http_cors:P.HTTP_CORS,http_corsaccesslist:P.HTTP_CORSACCESSLIST,http_headerstimeout:P.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:P.HTTP_KEEPALIVETIMEOUT,http_timeout:P.HTTP_TIMEOUT,http_port:P.HTTP_PORT,http_secureport:P.HTTP_SECUREPORT,http_mtls:P.HTTP_MTLS,http_mtls_user:P.HTTP_MTLS_USER,http_mtls_required:P.HTTP_MTLS_REQUIRED,http_maxheadersize:P.HTTP_MAXHEADERSIZE,http_threadrange:P.HTTP_THREADRANGE,customfunctions_processes:P.THREADS_COUNT,customfunctions_root:P.COMPONENTSROOT,localstudio_enabled:P.LOCALSTUDIO_ENABLED,logging_file:P.LOGGING_FILE,logging_level:P.LOGGING_LEVEL,logging_root:P.LOGGING_ROOT,logging_rotation_enabled:P.LOGGING_ROTATION_ENABLED,logging_rotation_compress:P.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:P.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:P.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:P.LOGGING_ROTATION_PATH,logging_stdstreams:P.LOGGING_STDSTREAMS,logging_auditlog:P.LOGGING_AUDITLOG,logging_auditretention:P.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:P.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:P.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:P.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:P.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:P.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:P.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:P.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls:P.OPERATIONSAPI_TLS,operationsapi_tls_certificate:P.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:P.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:P.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:P.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:P.ROOTPATH,operationsapi_sysinfo_network:P.OPERATIONSAPI_SYSINFO_NETWORK,operationsapi_sysinfo_disk:P.OPERATIONSAPI_SYSINFO_DISK,databases:P.DATABASES,storage_path:P.STORAGE_PATH,storage_maxtransactionqueuetime:P.STORAGE_MAXTRANSACTIONQUEUETIME,ignorescripts:P.IGNORE_SCRIPTS,mqtt_network_port:P.MQTT_NETWORK_PORT,mqtt_websocket:P.MQTT_WEBSOCKET,mqtt_network_secureport:P.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:P.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:P.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:P.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:P.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:P.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:P.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:P.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:P.AUTHENTICATION_CACHETTL,authentication_enablesessions:P.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:P.COMPONENTSROOT,replication:P.REPLICATION,replication_port:P.REPLICATION_PORT,replication_secureport:P.REPLICATION_SECUREPORT,replication_hostname:P.REPLICATION_HOSTNAME,replication_url:P.REPLICATION_URL,replication_routes:P.REPLICATION_ROUTES,tls:P.TLS,tls_certificate:P.TLS_CERTIFICATE,tls_privatekey:P.TLS_PRIVATEKEY,tls_certificateauthority:P.TLS_CERTIFICATEAUTHORITY,tls_ciphers:P.TLS_CIPHERS};for(let e in P){let t=P[e];Jw[t.toLowerCase()]=t}var xQ={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},kQ={csv_file_load:"csv_file_load",csv_data_load:ae.CSV_DATA_LOAD,csv_url_load:ae.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"},FQ={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"},GQ={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},qQ={VERSION_DEFAULT:"2.2.0"},$Q={DEVELOPMENT:8192,DEFAULT:512},VQ={IDENTIFY:"identify",AUTHENTICATE:"authenticate",AUTHENTICATE_OK:"authenticated",AUTHENTICATE_FAIL:"authenticate_fail",CONNECTION:"connection",CONNECT:"connect",CATCHUP_REQUEST:"catchup_request",CATCHUP_RESPONSE:"catchup",CONFIRM_MSG:"confirm_msg",ERROR:"error",DISCONNECT:"disconnect",SCHEMA_UPDATE_REQ:"schema_update_request",SCHEMA_UPDATE_RES:"schema_update_response",RECONNECT_ATTEMPT:"reconnect_attempt",CONNECT_ERROR:"connect_error",MESSAGE:"msg",VERSION_MISMATCH:"version_mismatch",DIRECTION_CHANGE:"direction_change"},YQ={1e3:"SUCCESSFUL_SHUTDOWN",1001:"CLOSE_GOING_AWAY",1002:"CLOSE_PROTOCOL_ERROR",1003:"CLOSE_UNSUPPORTED",1005:"CLOSE_NO_STATUS",1006:"CLOSE_ABNORMAL",1007:"UNSUPPORTED_PAYLOAD",1008:"POLICY_VIOLATION",1009:"CLOSE_TOO_LARGE",1010:"MANDATORY_EXTENSION",1011:"SERVER_ERROR",1012:"SERVICE_RESTART",1013:"SERVER_BUSY",1014:"BAD_GATEWAY",1015:"HANDSHAKE_FAIL",4141:"LICENSE_LIMIT_REACHED"},KQ={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},Xw={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},WQ=Symbol("metadata"),jQ="__clustering__",QQ=Object.values(Xw),zQ=15984864e5,Zw={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},JQ=Qw.invert(Zw),XQ={GET_CLUSTER_STATUS:"GET_CLUSTER_STATUS",CLUSTER_STATUS_RESPONSE:"CLUSTER_STATUS_RESPONSE",ERROR_RESPONSE:"ERROR",ADD_USER:"ADD_USER",ALTER_USER:"ALTER_USER",DROP_USER:"DROP_USER",HDB_OPERATION:"HDB_OPERATION",ADD_NODE:"ADD_NODE",UPDATE_NODE:"UPDATE_NODE",REMOVE_NODE:"REMOVE_NODE",HDB_USERS_MSG:"HDB_USERS_MSG",HDB_WORKERS:"HDB_WORKERS",HDB_TRANSACTION:"HDB_TRANSACTION"},ZQ=111,ez=`\r
|
|
2
|
+
`,tz={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},rz=["*","%"],nz="unauthorized_access",sz="func_val",iz={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},oz={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},az={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"},cz={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},lz={HTTP:"http"},uz={STOPPED:"stopped",ONLINE:"online"},dz="3.x.x",_z={SUCCESS:"success",FAILURE:"failure"},fz={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"};eC.exports={LOCAL_HARPERDB_OPERATIONS:tt,HDB_SUPPORT_ADDRESS:Vw,HDB_SUPPORT_URL:Kw,HDB_PRICING_URL:Hj,SUPPORT_HELP_MSG:xj,LICENSE_HELP_MSG:Ww,HDB_PROC_NAME:qw,HDB_PROC_DESCRIPTOR:ag,CLUSTERING_LEAF_PROC_DESCRIPTOR:ZE,CLUSTERING_HUB_PROC_DESCRIPTOR:XE,SYSTEM_SCHEMA_NAME:nQ,HASH_FOLDER_NAME:sQ,HDB_HOME_DIR_NAME:iQ,UPDATE_FILE_NAME:lQ,LICENSE_KEY_DIR_NAME:aQ,BOOT_PROPS_FILE_NAME:cQ,JOB_TYPE_ENUM:kQ,JOB_STATUS_ENUM:DQ,SYSTEM_TABLE_NAMES:yQ,SYSTEM_TABLE_HASH_ATTRIBUTES:OQ,OPERATIONS_ENUM:ae,VALID_S3_FILE_TYPES:PQ,S3_BUCKET_AUTH_KEYS:LQ,VALID_SQL_OPS_ENUM:MQ,GEO_CONVERSION_ENUM:vQ,HDB_SETTINGS_NAMES:zw,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:BQ,SERVICE_ACTIONS_ENUM:UQ,CLUSTER_MESSAGE_TYPE_ENUM:FQ,CLUSTER_CONNECTION_DIRECTION_ENUM:GQ,CLUSTER_EVENTS_DEFS_ENUM:VQ,PERIOD_REGEX:Yj,DOUBLE_PERIOD_REGEX:Kj,UNICODE_PERIOD:Wj,FORWARD_SLASH_REGEX:jj,UNICODE_FORWARD_SLASH:Qj,ESCAPED_FORWARD_SLASH_REGEX:zj,ESCAPED_PERIOD_REGEX:Jj,ESCAPED_DOUBLE_PERIOD_REGEX:Xj,REG_KEY_FILE_NAME:wQ,RESTART_TIMEOUT_MS:_Q,HDB_FILE_PERMISSIONS:fQ,DATABASES_DIR_NAME:hQ,LEGACY_DATABASES_DIR_NAME:mQ,TRANSACTIONS_DIR_NAME:pQ,LIMIT_COUNT_NAME:SQ,ID_ATTRIBUTE_STRING:TQ,INSERT_MODULE_ENUM:AQ,UPGRADE_JSON_FIELD_NAMES_ENUM:bQ,RESTART_CODE:uQ,RESTART_CODE_NUM:dQ,CLUSTER_OPERATIONS:Id,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:IQ,HDB_INTERNAL_SC_CHANNEL_PREFIX:On,INTERNAL_SC_CHANNELS:NQ,CLUSTERING_MESSAGE_TYPES:XQ,HDB_FILE_SUFFIX:oQ,BLOB_FOLDER_NAME:EQ,ORIGINATOR_SET_VALUE:ZQ,LICENSE_VALUES:qQ,RAM_ALLOCATION_ENUM:$Q,TIME_STAMP_NAMES_ENUM:Xw,TIME_STAMP_NAMES:QQ,PERMS_UPDATE_RELEASE_TIMESTAMP:zQ,SEARCH_NOT_FOUND_MESSAGE:kj,SEARCH_ATTRIBUTE_NOT_FOUND:Fj,LICENSE_ROLE_DENIED_RESPONSE:Gj,LICENSE_MAX_CONNS_REACHED:qj,BASIC_LICENSE_MAX_NON_CU_ROLES:Yw,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:Bj,VALUE_SEARCH_COMPARATORS:Zw,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:JQ,LICENSE_FILE_NAME:CQ,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:YQ,NEW_LINE:ez,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:Vj,MOMENT_DAYS_TAG:Zj,API_TURNOVER_SEC:eQ,LOOPBACK:$j,CODE_EXTENSION:JE,WILDCARD_SEARCH_VALUE:tQ,NODE_ERROR_CODES:KQ,JAVASCRIPT_EXTENSION:Gw,PERMS_CRUD_ENUM:tz,UNAUTHORIZED_PERMISSION_NAME:nz,SEARCH_WILDCARDS:rz,FUNC_VAL:sz,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:iz,JWT_ENUM:oz,CLUSTERING_FLAG:jQ,ITC_EVENT_TYPES:az,CUSTOM_FUNCTION_PROC_NAME:$w,CUSTOM_FUNCTION_PROC_DESCRIPTOR:zE,SERVICES:cz,THREAD_TYPES:lz,MEM_SETTING_KEY:rQ,HDB_RESTART_SCRIPT:Rj,PROCESS_DESCRIPTORS:Ij,SERVICE_SERVERS:Lj,SERVICE_SERVERS_CWD:og,PROCESS_DESCRIPTORS_VALIDATE:Dj,LAUNCH_SERVICE_SCRIPTS:Mj,LOG_LEVELS:Cj,PROCESS_NAME_ENV_PROP:gQ,LOG_NAMES:wj,PM2_PROCESS_STATUSES:uz,CONFIG_PARAM_MAP:Jw,CONFIG_PARAMS:P,HDB_CONFIG_FILE:Sj,HDB_DEFAULT_CONFIG_FILE:Tj,ROLE_TYPES_ENUM:Uj,BOOT_PROP_PARAMS:jw,INSTALL_PROMPTS:RQ,HDB_ROOT_DIR_NAME:gj,CLUSTERING_PROCESSES:Pj,FOREGROUND_PID_FILE:yj,PACKAGE_ROOT:ko,PRE_4_0_0_VERSION:dz,DATABASES_PARAM_CONFIG:xQ,METADATA_PROPERTY:WQ,AUTH_AUDIT_STATUS:_z,AUTH_AUDIT_TYPES:fz,HDB_PID_FILE:Oj,DEFAULT_DATABASE_NAME:Nj,LEGACY_CONFIG_PARAMS:HQ};Fw()});var qa=b((kge,nC)=>{"use strict";var tC=require("minimist");nC.exports=Ez;function Ez(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=rC(process.env),n=rC(tC(process.argv))):(r=process.env,n=tC(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(Ez,"assignCMDENVVariables");function rC(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(rC,"objKeysToLowerCase")});var Vi=b(oi=>{"use strict";global.Resource=oi.Resource=void 0;global.tables=oi.tables={};global.databases=oi.databases={};global.getUser=oi.getUser=void 0;global.server=oi.server={};global.contentTypes=oi.contentTypes=null;global.threads=oi.threads=[];global.logger={};oi._assignPackageExport=(e,t)=>{global[e]=oi[e]=t}});var V=b((SC,TC)=>{"use strict";var Yi=require("fs-extra"),{workerData:hz,threadId:mz,isMainThread:pz}=require("worker_threads"),ci=require("path"),aC=require("yaml"),cC=require("properties-reader"),Wt=M(),sC=qa(),Sz=require("os"),{PACKAGE_ROOT:dg}=M(),{_assignPackageExport:Tz}=Vi(),iC=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),dr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},lC={STDOUT:"stdOut",STDERR:"stdErr"},gz=ci.join(dg,"logs"),Rz=ci.join(dg,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),Az=1e4,cg,ai,ss,Nr,eh,wd,th,Fo,Cd;Cd===void 0&&uC();Object.assign(SC,{notify:hC,fatal:mC,error:rh,warn:pC,info:_C,debug:EC,trace:fC,setLogLevel:Dz,log_level:Nr,loggerWithTag:Oz,suppressLogging:Nz,initLogSettings:uC,logCustomLevel:wz,closeLogFile:_g,logsAtLevel:bz,getLogFilePath:()=>th,OUTPUTS:lC,AuthAuditLog:Mz});Tz("logger",TC.exports);var lg;function bz(e){return dr[Nr]<=dr[e]}a(bz,"logsAtLevel");function uC(e=!1){try{if(Cd===void 0||e){_g();let t=Cz(),r=sC(["ROOTPATH"]);try{Cd=cC(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!Yi.pathExistsSync(ci.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:Nr,config_log_path:wd,to_file:ai,to_stream:ss}=Pz(r.ROOTPATH?ci.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):Cd.get("settings_path")),eh=Wt.LOG_NAMES.HDB,th=ci.join(wd,eh),pz)try{require("segfault-handler").registerHandler(ci.join(wd,"crash.log"))}catch{}}}catch(t){if(Cd=void 0,t.code===Wt.NODE_ERROR_CODES.ENOENT||t.code===Wt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=sC(Object.keys(Wt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Wt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Wt.CONFIG_PARAMS.LOGGING_LEVEL){Nr=l;continue}if(c===Wt.CONFIG_PARAMS.LOGGING_STDSTREAMS){ss=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(ai=c),c===Wt.CONFIG_PARAMS.LOGGING_CONSOLE&&(cg=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=Lz();ai=ai===void 0?s:ai,ai=oC(ai),ss=ss===void 0?i:ss,ss=oC(ss),Nr=Nr===void 0?n:Nr,wd=gz,eh=Wt.LOG_NAMES.INSTALL,th=ci.join(wd,eh);return}throw rh("Error initializing log settings"),rh(t),t}process.env.DEV_MODE&&(ss=!0),yz()}a(uC,"initLogSettings");var Go=!0;function yz(){ai&&(process.stdout.write=function(e){return typeof e=="string"&&Go&&cg!==!1&&(ug(),e=e.toString(),e[e.length-1]===`
|
|
3
|
+
`&&(e=e.slice(0,-1)),Yi.appendFileSync(Fo,Bs("stdout",[e]))),iC.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&Go&&cg!==!1&&(ug(),e[e.length-1]===`
|
|
4
|
+
`&&(e=e.slice(0,-1)),Yi.appendFileSync(Fo,Bs("stderr",[e]))),iC.apply(process.stderr,arguments)})}a(yz,"stdioLogging");function Oz(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(hC,"notify"),fatal:n(mC,"fatal"),error:n(rh,"error"),warn:n(pC,"warn"),info:n(_C,"info"),debug:n(EC,"debug"),trace:n(fC,"trace")};function n(s,i){return!t||dr[Nr]<=dr[i]?function(...o){return s(r,...o)}:null}}a(Oz,"loggerWithTag");function Nz(e){try{Go=!1,e()}finally{Go=!0}}a(Nz,"suppressLogging");var Iz=hz?.name?.replace(/ /g,"-")||"main";function Bs(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||Iz+"/"+mz);c<s;c++){let d=t[c];if(d instanceof Error&&d.stack)n+=d.stack,Object.keys(d).length>0&&(n+=`
|
|
5
|
+
`+JSON.stringify(d)),d.cause&&(t[c--]=d.cause,d&&(n+=`
|
|
6
|
+
Caused by:`));else if(typeof d=="object")try{n+=JSON.stringify(d)}catch{n+="Object ["+Object.keys(d)+"]"}else n+=d;c<i&&(n+=" ")}return`${r} [${o.join("] [")}]: ${n}
|
|
7
|
+
`}a(Bs,"createLogRecord");function Dd(e){if(ai){if(dC(e),ss){Go=!1;try{process.stdout.write(e)}finally{Go=!0}}}else ss&&process.stdout.write(e)}a(Dd,"logStdOut");function nh(e){if(ai){if(dC(e),ss){Go=!1;try{process.stderr.write(e)}finally{Go=!0}}}else ss&&process.stderr.write(e)}a(nh,"logStdErr");function dC(e){ug(),Fo?Yi.appendFileSync(Fo,e):lg||console.log(e)}a(dC,"logToFile");function _g(){try{Yi.closeSync(Fo)}catch{}Fo=null}a(_g,"closeLogFile");function ug(){if(!Fo){try{Fo=Yi.openSync(th,"a")}catch(e){lg||(lg=!0,console.error(e))}setTimeout(()=>{_g()},Az).unref()}}a(ug,"openLogFile");function _C(...e){dr[Nr]<=dr.info&&Dd(Bs("info",e))}a(_C,"info");function fC(...e){dr[Nr]<=dr.trace&&Dd(Bs("trace",e))}a(fC,"trace");function rh(...e){dr[Nr]<=dr.error&&nh(Bs("error",e))}a(rh,"error");function EC(...e){dr[Nr]<=dr.debug&&Dd(Bs("debug",e))}a(EC,"debug");function hC(...e){dr[Nr]<=dr.notify&&Dd(Bs("notify",e))}a(hC,"notify");function mC(...e){dr[Nr]<=dr.fatal&&nh(Bs("fatal",e))}a(mC,"fatal");function pC(...e){dr[Nr]<=dr.warn&&nh(Bs("warn",e))}a(pC,"warn");function wz(e,t,...r){t===lC.STDERR?nh(Bs(e,r)):Dd(Bs(e,r))}a(wz,"logCustomLevel");function Cz(){let e;try{e=Sz.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=ci.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return Yi.existsSync(t)||(t=ci.join(dg,"utility/hdb_boot_properties.file")),t}a(Cz,"getPropsFilePath");function Dz(e){Nr=e}a(Dz,"setLogLevel");function oC(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(oC,"autoCastBoolean");function Pz(e){try{if(e.includes("config/settings.js")){let o=cC(e);return{level:o.get(Wt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:ci.dirname(o.get(Wt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=aC.parseDocument(Yi.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),n=t.getIn(["logging","root"]),s=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:n,to_file:s,to_stream:i}}catch(t){if(t.code===Wt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(Pz,"getLogConfig");function Lz(){try{let e=aC.parseDocument(Yi.readFileSync(Rz,"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(Lz,"getDefaultConfig");function Mz(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(Mz,"AuthAuditLog")});var fg=b(($ge,gC)=>{"use strict";var Uz=require("util"),vz=require("path"),Bz=require("child_process"),Hz=Uz.promisify(Bz.execFile),xz=1e3*1e3*10;gC.exports={findPs:kz};async function kz(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await Hz("ps",["wwxo",`pid,${r}`],{maxBuffer:xz});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:vz.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(kz,"findPs")});var Bt=b((Yge,AC)=>{"use strict";var Fz="__dbis__",Gz="__txns__",qz="__environment_name__",$z="__dbi_defintion__",Vz={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"},Yz=["__createdtime__","__updatedtime__"],Kz="\uFFFF",RC={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},Wz=Object.values(RC);AC.exports={AUDIT_STORE_NAME:Gz,INTERNAL_DBIS_NAME:Fz,DBI_DEFINITION_NAME:$z,SEARCH_TYPES:Vz,TIMESTAMP_NAMES:Yz,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:qz,TRANSACTIONS_DBI_NAMES_ENUM:RC,TRANSACTIONS_DBIS:Wz,OVERFLOW_MARKER:Kz}});var Nn=b((Kge,PC)=>{"use strict";var bC=M(),yC=Bt(),OC={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},NC=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),IC={500:NC("There was an error processing your request."),400:"Invalid request"},jz=IC[OC.INTERNAL_SERVER_ERROR],Qz={OP_NOT_SUPPORTED_FOR_FS:e=>`${e} is not available for this instance because it uses the File System data store.`,MISSING_VALUE:e=>`${e} is missing.`,INVALID_VALUE:e=>`${e} is invalid.`,NOT_FOUND:e=>`${e} not found.`},zz={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},Jz={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:e=>`There was an error downloading '${e}'.`,INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,INVALID_FILE_EXT_ERR:e=>`Error selecting correct parser - valid file type not found in json - ${e}`,MAX_FILE_SIZE_ERR:(e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:e=>`There was an error downloading '${e}' from AWS.`,WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},Xz={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 ${yC.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${yC.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"},Zz={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${bC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${bC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},wC={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"},e2={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:e=>`Operation '${e}' is restricted to 'super_user' roles`,OP_NOT_FOUND:e=>`Operation '${e}' not found`,SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:(e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,USER_HAS_NO_PERMS:e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},t2={ATTR_PERM_MISSING:(e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:(e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:e=>`Invalid attribute '${e}' in 'attribute_permissions'`,INVALID_PERM_KEY:e=>`Invalid table permission key value '${e}'`,INVALID_ATTR_PERM_KEY:e=>`Invalid attribute permission key value '${e}'`,INVALID_ROLE_JSON_KEYS:e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,MISMATCHED_TABLE_ATTR_PERMS:e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:e=>`A role with name '${e}' already exists`,ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:e=>`Your role does not have permission to view database metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:e=>`Value for '${e}' permission must be a boolean`,STRUCTURE_USER_ROLE_TYPE_ERROR:e=>`Value for '${e}' permission must be a boolean or Array`,SU_CU_ROLE_NO_PERMS_ALLOWED:e=>`Roles with '${e}' set to true cannot have other permissions set.`,SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:e=>`Missing table ${e.toUpperCase()} permission`,TABLE_PERM_NOT_BOOLEAN:e=>`Table ${e.toUpperCase()} permission must be a boolean`},r2={ATTR_NOT_FOUND:(e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,ATTR_EXISTS_ERR:(e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:e=>`Invalid table ${JSON.stringify(e)}`,SCHEMA_NOT_FOUND:e=>`database '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`database '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in '${e}'`,SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},n2={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},s2={ALTER_USER_DUP_ROLES:e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,ALTER_USER_ROLE_NOT_FOUND:e=>`Update failed. Requested '${e}' role not found.`,DUP_ROLES_FOUND:e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,ROLE_NAME_NOT_FOUND:e=>`${e} role not found`,USER_ALREADY_EXISTS:e=>`User ${e} already exists`,USER_NOT_EXIST:e=>`User ${e} does not exist`},CC={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`},DC={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:e=>`ITC server received invalid event type: ${e}`},i2={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"},o2={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},a2={...wC,...Jz,...Qz,...e2,...t2,...r2,...n2,...s2,...Zz,...CC,...DC,...i2,...o2,...zz};PC.exports={CHECK_LOGS_WRAPPER:NC,HDB_ERROR_MSGS:a2,DEFAULT_ERROR_MSGS:IC,DEFAULT_ERROR_RESP:jz,HTTP_STATUS_CODES:OC,LMDB_ERRORS_ENUM:Xz,AUTHENTICATION_ERROR_MSGS:wC,VALIDATION_ERROR_MSGS:CC,ITC_ERRORS:DC}});var fe=b((jge,UC)=>{"use strict";var Rl=Nn(),c2=V(),l2=M(),sh=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,LC),this.statusCode=n||Rl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Rl.DEFAULT_ERROR_MSGS[n]?Rl.DEFAULT_ERROR_MSGS[n]:Rl.DEFAULT_ERROR_MSGS[Rl.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&&c2[s](i)}},Eg=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}},hg=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function LC(e,t,r,n=l2.LOG_LEVELS.ERROR,s=null,i=!1){if(MC(e))return e;let o=new sh(e,t,r,n,s);return i&&delete o.stack,o}a(LC,"handleHDBError");function MC(e){return e.__proto__.constructor.name===sh.name}a(MC,"isHDBError");UC.exports={isHDBError:MC,handleHDBError:LC,ClientError:Eg,ServerError:hg,hdb_errors:Rl}});var gt=b((zge,GC)=>{"use strict";var vd=M(),u2=J(),rn=te(),Bd=require("path"),d2=require("minimist"),vC=require("fs-extra"),BC=require("lodash");rn.initSync();var{CONFIG_PARAMS:qo,DATABASES_PARAM_CONFIG:Pd,SYSTEM_SCHEMA_NAME:ih}=vd,Ld,Md,Ud;function HC(){if(Ld!==void 0)return Ld;if(rn.getHdbBasePath()!==void 0)return Ld=rn.get(qo.STORAGE_PATH)||Bd.join(rn.getHdbBasePath(),vd.DATABASES_DIR_NAME),Ld}a(HC,"getBaseSchemaPath");function xC(){if(Md!==void 0)return Md;if(rn.getHdbBasePath()!==void 0)return Md=FC(ih),Md}a(xC,"getSystemSchemaPath");function kC(){if(Ud!==void 0)return Ud;if(rn.getHdbBasePath()!==void 0)return Ud=rn.get(vd.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Bd.join(rn.getHdbBasePath(),vd.TRANSACTIONS_DIR_NAME),Ud}a(kC,"getTransactionAuditStoreBasePath");function _2(e,t){let r=rn.get(qo.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Bd.join(kC(),e.toString())}a(_2,"getTransactionAuditStorePath");function FC(e,t){e=e.toString(),t=t&&t.toString();let r=rn.get(vd.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Bd.join(HC(),e)}a(FC,"getSchemaPath");function f2(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,d2(process.argv));let n=r[qo.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!u2.isObject(n))throw o;i=n}for(let o of i){let c=o[ih];if(!c)continue;let l=rn.get(qo.DATABASES);l=l??{};let d=c?.tables?.[t]?.[Pd.PATH];if(d)return BC.set(l,[ih,Pd.TABLES,t,Pd.PATH],d),rn.setProperty(qo.DATABASES,l),d;let u=c?.[Pd.PATH];if(u)return BC.set(l,[ih,Pd.PATH],u),rn.setProperty(qo.DATABASES,l),u}}let s=r[qo.STORAGE_PATH.toUpperCase()];if(s){if(!vC.pathExistsSync(s))throw new Error(s+" does not exist");let i=Bd.join(s,e);return vC.mkdirsSync(i),rn.setProperty(qo.STORAGE_PATH,s),i}return xC()}a(f2,"initSystemSchemaPaths");function E2(){Ld=void 0,Md=void 0,Ud=void 0}a(E2,"resetPaths");GC.exports={getBaseSchemaPath:HC,getSystemSchemaPath:xC,getTransactionAuditStorePath:_2,getTransactionAuditStoreBasePath:kC,getSchemaPath:FC,initSystemSchemaPaths:f2,resetPaths:E2}});var nn=b((eRe,KC)=>{"use strict";var h2=Nn().LMDB_ERRORS_ENUM,Xge=require("lmdb"),m2=Bt(),Zge=require("buffer").Buffer,{OVERFLOW_MARKER:qC,MAX_SEARCH_KEY_LENGTH:oh}=m2,$C=["number","string","symbol","boolean","bigint"];function p2(e){if(e=e?.primaryStore||e,!e)throw new Error(h2.ENV_REQUIRED)}a(p2,"validateEnv");function S2(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(S2,"stringifyData");function T2(e){return e instanceof Date?e.valueOf():e}a(T2,"convertKeyValueToWrite");function g2(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if($C.includes(typeof e))return e.length>oh?[e.slice(0,oh)+qC]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if($C.includes(typeof i))i.length>oh?r.push(i.slice(0,oh)+qC):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(g2,"getIndexedValues");var ah=0,VC=0;function YC(){VC=Date.now()-performance.now()}a(YC,"adjustStartTime");YC();var R2=6e4;setInterval(YC,R2).unref();function A2(){let e=performance.now()+VC;return e>ah?(ah=e,e):(ah+=488e-6,ah)}a(A2,"getNextMonotonicTime");KC.exports={validateEnv:p2,stringifyData:S2,convertKeyValueToWrite:T2,getNextMonotonicTime:A2,getIndexedValues:g2}});var Hd=b((rRe,WC)=>{"use strict";var b2=M().OPERATIONS_ENUM,mg=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=b2.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};WC.exports=mg});var xd=b((iRe,JC)=>{"use strict";var sRe=Hd(),ch=M(),pg=J(),jC=V(),y2=require("uuid"),{handleHDBError:lh,hdb_errors:O2}=fe(),{HDB_ERROR_MSGS:uh,HTTP_STATUS_CODES:dh}=O2;JC.exports=QC;function QC(e,t,r){for(let s=0;s<t.length;s++)zC(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];N2(i,r,e.operation)}}a(QC,"processRows");QC.validateAttribute=zC;function zC(e){if(Buffer.byteLength(String(e))>ch.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw lh(new Error,uh.ATTR_NAME_LENGTH_ERR(e),dh.BAD_REQUEST,void 0,void 0,!0);if(pg.isEmptyOrZeroLength(e)||pg.isEmpty(e.trim()))throw lh(new Error,uh.ATTR_NAME_NULLISH_ERR,dh.BAD_REQUEST,void 0,void 0,!0)}a(zC,"validateAttribute");function N2(e,t,r){if(!e.hasOwnProperty(t)||pg.isEmptyOrZeroLength(e[t])){if(r===ch.OPERATIONS_ENUM.INSERT||r===ch.OPERATIONS_ENUM.UPSERT){e[t]=y2.v4();return}throw jC.error("Update transaction aborted due to record with no hash value:",e),lh(new Error,uh.RECORD_MISSING_HASH_ERR,dh.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>ch.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw jC.error(e),lh(new Error,uh.HASH_VAL_LENGTH_ERR,dh.BAD_REQUEST,void 0,void 0,!0)}a(N2,"validateHash")});var XC,In,Sg,Al=De(()=>{XC=require("events"),In=class extends XC.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new Sg;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)}},Sg=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var $a={};et($a,{server:()=>st});var ZC,st,$r=De(()=>{ZC=v(Vi()),st={};(0,ZC._assignPackageExport)("server",st)});var Rg={};et(Rg,{loadGQLSchema:()=>C2,start:()=>gg,startOnMainThread:()=>w2});function gg({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:d,StringValueNode:u}=await import("graphql"),_=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let R of _.definitions)switch(R.kind){case l.OBJECT_TYPE_DEFINITION:let x=function(q){if(q.kind==="NonNullType"){let X=x(q.type);return X.nullable=!1,X}if(q.kind==="ListType")return{type:"array",elements:x(q.type)};let _e={type:q.name?.value};return Object.defineProperty(_e,"location",{value:q.loc.startToken}),_e};a(x,"getProperty");let p=R.name.value,y=[],O={table:null,database:null,properties:y};E.set(p,O);for(let q of R.directives){if(q.name.value==="table"){for(let _e of q.arguments)O[_e.name.value]=_e.value.value;O.schema&&(O.database=O.schema),O.table||(O.table=p),O.audit&&(O.audit=O.audit!=="false"),O.attributes=O.properties,f.push(O)}if(q.name.value==="sealed"&&(O.sealed=!0),q.name.value==="splitSegments"&&(O.splitSegments=!0),q.name.value==="replicate"&&(O.replicate=!0),q.name.value==="export"){O.export=!0;for(let _e of q.arguments)typeof O.export!="object"&&(O.export={}),O.export[_e.name.value]=_e.value.value}}let B=!1,W={};for(let q of R.fields){let z=x(q.type);z.name=q.name.value,y.push(z),W[z.name]=void 0;for(let _e of q.directives){let X=_e.name.value;if(X==="primaryKey")B?console.warn("Can not define two attributes as a primary key at",_e.loc):(z.isPrimaryKey=!0,B=!0);else if(X==="indexed")z.indexed=!0;else if(X==="computed"){for(let ue of _e.arguments||[])if(ue.name.value==="from"){let j=ue.value.value;z.computed={from:S(j,ue,W)},z.version==null&&(z.version=j)}else ue.name.value==="version"&&(z.version=ue.value.value);z.computed=z.computed||!0}else if(X==="relationship"){let ue={};for(let j of _e.arguments)ue[j.name.value]=j.value.value;z.relationship=ue}else if(X==="createdTime")z.assignCreatedTime=!0;else if(X==="updatedTime")z.assignUpdatedTime=!0;else if(X==="expiresAt")z.expiresAt=!0;else if(X==="allow"){let ue=z.authorizedRoles=[];for(let j of _e.arguments)j.name.value==="role"&&ue.push(j.value.value)}else server.knownGraphQLDirectives.includes(X)&&console.warn(`@${X} is an unknown directive, at`,_e.loc)}}O.type=p,p==="Query"&&(h=O)}function T(R){let p=E.get(R.type);p?(Object.defineProperty(R,"properties",{value:p.properties}),Object.defineProperty(R,"definition",{value:p})):R.type==="array"?T(R.elements):I2.includes(R.type)||(0,tD.getWorkerIndex)()===0&&console.error(`The type ${R.type} is unknown at line ${R.location.line}, column ${R.location.column}, in ${s}`)}a(T,"connectPropertyType");for(let R of E.values())for(let p of R.properties)T(p);for(let R of f)R.tableClass=e(R),R.export&&(R.export.name===""?i.set((0,Tg.dirname)(n),R.tableClass):i.set((0,Tg.dirname)(n)+"/"+(R.export.name||R.type),R.tableClass,R.export));function S(R,p,y){return new eD.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${R}; } } } } computed;`,{filename:s,lineOffset:p.loc.startToken.line-1,columnOffset:p.loc.startToken.column}).runInThisContext()(y)}a(S,"createComputedFrom")}}var Tg,eD,tD,I2,w2,C2,rD=De(()=>{Tg=require("path"),eD=require("node:vm");Le();tD=v(it()),I2=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(gg,"start");w2=gg,C2=gg({ensureTable:Et}).handleFile});async function _h(e){let t=(0,iD.pathToFileURL)(e).toString();return D2?(kd||(kd=P2(M2)),(await(await kd).import(t)).namespace):import(t)}async function P2(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),kd=new Compartment({console,Math,Date,fetch:L2,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,sD.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Ir,tables:wn,databases:We})}};let n=await(0,nD.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),kd}function L2(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 M2(){return{Resource:Ir,tables:wn}}var nD,sD,iD,D2,kd,Ag=De(()=>{Hs();Le();nD=require("fs/promises"),sD=require("path"),iD=require("url"),D2=!1;a(_h,"secureImport");a(P2,"getCompartment");a(L2,"secureOnlyFetch");a(M2,"getGlobalVars")});var yg={};et(yg,{handleFile:()=>U2});async function U2(e,t,r,n){let s=new Map,i=await _h(r);c(i.default)&&n.set((0,bg.dirname)(t),i.default),o(i,(0,bg.dirname)(t));function o(l,d){for(let u in l){let _=l[u];c(_)?n.set(d+"/"+u,_):typeof _=="object"&&o(_,d+"/"+u)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var bg,oD=De(()=>{Ag();bg=require("path");a(U2,"handleFile")});var Ng={};et(Ng,{start:()=>v2});function v2({resources:e}){e.set("login",Og),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Og,aD=De(()=>{Hs();a(v2,"start");Og=class extends Ir{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 ED={};et(ED,{parse:()=>wg,streamAsJSON:()=>Fd,stringify:()=>Va});function Fd(e){return new Ig({value:e})}function cD(e){return console.error(e),JSON.stringify(e.toString())}function lD(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Va(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===_D)return fD(e);if(t.resolution)return t.resolution.then(()=>Va(e));throw t}}function fD(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+=fD(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Va(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function wg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),x2.test(e)?B2.parse(e):JSON.parse(e)):null}var uD,dD,B2,H2,_D,Ig,x2,Cg=De(()=>{uD=require("stream"),dD=v(require("json-bigint-fixes")),B2=(0,dD.default)({useNativeBigInt:!0}),H2=1e4,_D={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw _D};a(Fd,"streamAsJSON");Ig=class extends uD.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:()=>({done:!0})},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:()=>({done:!0})}}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),cD)}catch(s){yield cD(s)}else yield Va(t)}else yield Va(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);lD(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>H2?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 lD(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(cD,"handleError");a(lD,"when");a(Va,"stringify");a(fD,"jsStringify");x2=/[[,:]\s*-?\d{16,}/;a(wg,"parse")});var ID=b((RRe,ND)=>{"use strict";var Dg=require("recursive-iterator"),k2=require("alasql"),Pg=require("clone"),hD=J(),{handleHDBError:mD,hdb_errors:F2}=fe(),{HDB_ERROR_MSGS:pD,HTTP_STATUS_CODES:SD}=F2,{getDatabases:G2}=(Le(),oe(lt)),q2=["DISTINCT_ARRAY"],TD=Symbol("validateTables"),Lg=Symbol("validateTable"),gRe=Symbol("getAllColumns"),gD=Symbol("validateAllColumns"),fh=Symbol("findColumn"),RD=Symbol("validateOrderBy"),Gd=Symbol("validateSegment"),Mg=Symbol("validateColumn"),AD=Symbol("setColumnsForTable"),bD=Symbol("checkColumnsForAsterisk"),yD=Symbol("validateGroupBy"),OD=Symbol("hasColumns"),Ug=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[TD](),this[bD](),this[gD]()}[TD](){if(this[OD]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Lg](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Lg](t.table)})}}[OD](){let t=!1,r=new Dg(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Lg](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=G2();if(!r[t.databaseid])throw mD(new Error,pD.SCHEMA_NOT_FOUND(t.databaseid),SD.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw mD(new Error,pD.TABLE_NOT_FOUND(t.databaseid,t.tableid),SD.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Pg(s);i.table=Pg(t),this.attributes.push(i)})}[fh](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)}[bD](){let t=new Dg(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[AD](r.tableid)}[AD](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new k2.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[gD](){this[Gd](this.statement.columns,!1),this[Gd](this.statement.joins,!1),this[Gd](this.statement.where,!1),this[yD](this.statement.group,!1),this[Gd](this.statement.order,!0)}[Gd](t,r){if(!t)return;let n=new Dg(t),s=[];for(let{node:i,path:o}of n)!hD.isEmpty(i)&&!hD.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[RD](i):s.push(this[Mg](i)));return s}[yD](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&q2.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Pg(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[fh](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[fh](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`}[RD](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[Mg](t)}[Mg](t){let r=this[fh](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]}};ND.exports=Ug});var CD=b((bRe,wD)=>{"use strict";var vg=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")}};wD.exports=vg});var PD=b((ORe,DD)=>{"use strict";var Bg=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};DD.exports=Bg});var vD={};et(vD,{HAS_EXPIRATION:()=>mh,HAS_RESIDENCY_ID:()=>Vg,HAS_STRUCTURE_UPDATE:()=>ph,LAST_TIMESTAMP_PLACEHOLDER:()=>Yd,LOCAL_TIMESTAMP:()=>$2,METADATA:()=>qd,NO_TIMESTAMP:()=>xg,PENDING_LOCAL_TIME:()=>Yg,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>$g,RecordEncoder:()=>qg,TIMESTAMP_ASSIGN_LAST:()=>Y2,TIMESTAMP_ASSIGN_NEW:()=>MD,TIMESTAMP_ASSIGN_PREVIOUS:()=>UD,TIMESTAMP_PLACEHOLDER:()=>Eh,TIMESTAMP_RECORD_PREVIOUS:()=>kg,getUpdateRecord:()=>Kg,handleLocalTimeForGets:()=>Sh});function W2(){return Vd[0]=Vd[0]^64,V2.getFloat64(0)}function Sh(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,d=l?.[qd];return d>=0&&(c.metadataFlags=d,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[qd]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,d=l[qd];return d>=0&&(c.metadataFlags=d,c.localTime=l.localTime,c.value=l.value,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Ya.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<Ya.length;l++){let d=Ya[l].deref();(!d||d.isDone||d.isCommitted)&&Ya.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Kg(e,t,r){return function(n,s,i,o,c=-1,l,d,u="put",_,E){_||l==null?bl=i?.localTime?kg|UD:xg:bl=l?i?.localTime?kg|16384:MD|16384:xg;let f=d?.expiresAt;if(f>=0&&(c|=mh),$d=c,Fg=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:bl>0},T,S=0;try{let R=i?.residencyId,p=d?.residencyId;p&&(Gg=p,$d|=Vg,S|=Ka),R!==p&&(S|=Wa,R||(R=0)),c&mh&&(S|=Wd),d?.originatingOperation&&(S|=Kd),_&&(h.ifVersion=T=i?.version??null);let y=e.put(n,s,h);if(l){let O=d?.user?.username;if(E&&(hh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(S|=ph,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let B=i?.localTime,x=r.get(B);if(x){let W=Ht(x).previousLocalTime;return r.put(B,yl(o,t,n,W,d?.nodeId??server.replication.getThisNodeId(r)??0,O,u,hh,S,p,R,f),{ifVersion:T}),y}}r.put(Yd,yl(o,t,n,i?.localTime?1:0,d?.nodeId??server.replication?.getThisNodeId(r)??0,O,u,hh,S,p,R,f,d?.originatingOperation),{append:u!=="invalidate",instructedWrite:!0,ifVersion:T})}return y}catch(R){throw R.message+=" id: "+n+" options: "+h,R}}}var LD,Hg,Eh,Yd,$g,$2,qd,Vd,V2,xg,MD,Y2,UD,kg,mh,Vg,Yg,ph,K2,hh,bl,$d,Fg,Gg,qg,Ya,Ol=De(()=>{LD=require("msgpackr");Ki();Hg=v(V()),Eh=new Uint8Array([1,1,1,1,4,64,0,0]),Yd=new Uint8Array([1,1,1,1,1,0,0,0]),$g=new Uint8Array([1,1,1,1,3,64,0,0]),$2=Symbol("local-timestamp"),qd=Symbol("metadata"),Vd=new Uint8Array(8),V2=new DataView(Vd.buffer,0,8),xg=0,MD=0,Y2=1,UD=3,kg=4,mh=16,Vg=32,Yg=1,ph=256,bl=0,$d=-1,Fg=-1,Gg=0,qg=class extends LD.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(bl||$d>=0){let o=0,c=bl;c&&(o+=8,bl=0);let l=$d,d=Fg,u=Gg;l>=0&&(o+=2,$d=-1,d>=0&&(o+=8,Fg=-1),u&&(o+=4,Gg=0));let _=K2=r.call(this,s,i|2048|o);hh=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(Eh[4]=c,Eh[5]=c>>8,_.set(Eh,E),E+=8),l>=0&&(_[E++]=l&31,_[E++]=l>>5,d>=0&&((_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(E,d),E+=8),u&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setUint32(E,u)),_}else return r.call(this,s,i)};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(Vd,0,c),c+=8;else for(let E=0;E<8;E++)Vd[E]=t[c++];l=W2(),i=t[c]}let d,u;i<32&&(o=i|t[c+1]<<5,c+=2,o&mh&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&Vg&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let _=r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c);return{localTime:l,value:_,[qd]:o,expiresAt:d,residencyId:u}}return r?.valueAsBuffer?t:super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(W2,"getTimestamp");a(Sh,"handleLocalTimeForGets");Ya=[];setInterval(()=>{for(let e=0;e<Ya.length;e++){let t=Ya[e].deref();!t||t.isDone||t.isCommitted?Ya.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Hg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Hg.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(Kg,"getUpdateRecord")});var jd=b((DRe,HD)=>{"use strict";var BD=te(),j2=M(),{RecordEncoder:Q2}=(Ol(),oe(vD)),CRe=require("fs");BD.initSync();var z2=BD.get(j2.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Wg=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=z2&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:Q2})}};HD.exports=Wg});var Qd=b((LRe,xD)=>{"use strict";var Cn=te(),is=M();Cn.initSync();var Th=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=Cn.get(is.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Cn.get(is.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Cn.get(is.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Cn.get(is.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Cn.get(is.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Cn.get(is.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Cn.get(is.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Cn.get(is.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Cn.get(is.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Cn.get(is.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Cn.get(is.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Cn.get(is.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};xD.exports=Th;Th.MAX_DBS=1e4});var ht=b((URe,jD)=>{"use strict";var Qg=require("lmdb"),xs=require("fs-extra"),Dn=require("path"),gh=nn(),GD=V(),sn=Nn().LMDB_ERRORS_ENUM,Rh=PD(),zg=jd(),qD=Qd(),$o=Bt(),kD=M(),{table:J2,resetDatabases:X2}=(Le(),oe(lt)),FD=te(),ks=$o.INTERNAL_DBIS_NAME,$D=$o.DBI_DEFINITION_NAME,Z2="data.mdb",e4="lock.mdb",zd=".mdb",t4="-lock",jg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=os(t,r),this.key_type=this.dbi[$o.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[$o.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new Qg.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Ah(e,t){if(e===void 0)throw new Error(sn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(sn.ENV_NAME_REQUIRED)}a(Ah,"pathEnvNameValidation");async function Jg(e,t,r=!0){try{await xs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(sn.INVALID_BASE_PATH):n}try{let n=Dn.join(e,t+zd);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(Dn.join(e,t,Z2),xs.constants.R_OK|xs.constants.F_OK),Dn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(sn.INVALID_ENVIRONMENT)}else throw new Error(sn.INVALID_ENVIRONMENT);throw n}}a(Jg,"validateEnvironmentPath");function bh(e,t){if(gh.validateEnv(e),t===void 0)throw new Error(sn.DBI_NAME_REQUIRED)}a(bh,"validateEnvDBIName");async function r4(e,t,r=!1,n=!1){Ah(e,t);let s=Dn.basename(e);t=t.toString();let i=FD.get(kD.CONFIG_PARAMS.DATABASES);i||FD.setProperty(kD.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Jg(e,t,n),VD(e,t,r)}catch(o){if(o.message===sn.INVALID_ENVIRONMENT){let c=Dn.join(e,t);await xs.mkdirp(n?c:e);let l=new qD(n?c:c+zd,!1),d=Qg.open(l);d.dbis=Object.create(null);let u=new zg(!1);d.openDB(ks,u),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=Xg(e,t,r);return d[$o.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=d,d}throw o}}a(r4,"createEnvironment");async function n4(e,t,r,n=!0){Ah(e,t),t=t.toString();let s=Dn.join(e,t);return J2({table:t,database:Dn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(n4,"copyEnvironment");async function VD(e,t,r=!1){Ah(e,t),t=t.toString();let n=Xg(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 Jg(e,t),i=Dn.join(e,t+zd),o=s!=i,c=new qD(s,o),l=Qg.open(c);l.dbis=Object.create(null);let d=KD(l);for(let u=0;u<d.length;u++)os(l,d[u]);return l[$o.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(VD,"openEnvironment");async function s4(e,t,r=!1){Ah(e,t),t=t.toString();let n=Dn.join(e,t+zd),s=await Jg(e,t);if(global.lmdb_map!==void 0){let i=Xg(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await YD(o),delete global.lmdb_map[i]}}await xs.remove(s),await xs.remove(s===n?s+t4:Dn.join(Dn.dirname(s),e4))}a(s4,"deleteEnvironment");async function YD(e){gh.validateEnv(e);let t=e[$o.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(YD,"closeEnvironment");function Xg(e,t,r=!1){let s=`${Dn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(Xg,"getCachedEnvironmentName");function i4(e){gh.validateEnv(e);let t=Object.create(null),r=os(e,ks);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==ks)try{t[n]=Object.assign(new Rh,s)}catch{GD.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(i4,"listDBIDefinitions");function KD(e){gh.validateEnv(e);let t=[],r=os(e,ks);for(let{key:n}of r.getRange({start:!1}))n!==ks&&t.push(n);return t}a(KD,"listDBIs");function o4(e,t){let n=os(e,ks).getEntry(t),s=new Rh;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{GD.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(o4,"getDBIDefinition");function WD(e,t,r,n=!r){if(bh(e,t),t=t.toString(),t===ks)throw new Error(sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return os(e,t)}catch(s){if(s.message===sn.DBI_DOES_NOT_EXIST){let i=new zg(r,n===!0),o=e.openDB(t,i),c=new Rh(r===!0,n);return o[$D]=c,os(e,ks).putSync(t,c),e.dbis[t]=o,o}throw s}}a(WD,"createDBI");function os(e,t){if(bh(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==ks?r=o4(e,t):r=new Rh,r===void 0)throw new Error(sn.DBI_DOES_NOT_EXIST);let n;try{let s=new zg(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(sn.DBI_DOES_NOT_EXIST):s}return n[$D]=r,e.dbis[t]=n,n}a(os,"openDBI");function a4(e,t){bh(e,t),t=t.toString();let r=os(e,t),n=r.getStats();return r[$o.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(a4,"statDBI");async function c4(e,t){try{let r=Dn.join(e,t+zd);return(await xs.stat(r)).size}catch{throw new Error(sn.INVALID_ENVIRONMENT)}}a(c4,"environmentDataSize");function l4(e,t){if(bh(e,t),t=t.toString(),t===ks)throw new Error(sn.CANNOT_DROP_INTERNAL_DBIS_NAME);os(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],os(e,ks).removeSync(t)}a(l4,"dropDBI");function u4(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{os(e,i)}catch(o){if(o.message===sn.DBI_DOES_NOT_EXIST)WD(e,i,i!==t,i===t),n=!0;else throw o}}n&&X2()}a(u4,"initializeDBIs");jD.exports={openDBI:os,openEnvironment:VD,createEnvironment:r4,listDBIs:KD,listDBIDefinitions:i4,createDBI:WD,dropDBI:l4,statDBI:a4,deleteEnvironment:s4,initializeDBIs:u4,TransactionCursor:jg,environmentDataSize:c4,copyEnvironment:n4,closeEnvironment:YD}});var zD=b((BRe,QD)=>{"use strict";var Zg=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};QD.exports=Zg});var XD=b((xRe,JD)=>{"use strict";var eR=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}};JD.exports=eR});var eP=b((FRe,ZD)=>{"use strict";var tR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};ZD.exports=tR});var Qa=b((YRe,nP)=>{"use strict";var d4=ht(),_4=zD(),f4=XD(),E4=eP(),li=nn(),Jd=Nn().LMDB_ERRORS_ENUM,h4=Bt(),Wi=M(),m4=J(),p4=require("uuid"),qRe=require("lmdb"),{handleHDBError:S4,hdb_errors:T4}=fe(),{OVERFLOW_MARKER:$Re,MAX_SEARCH_KEY_LENGTH:VRe}=h4,tP=te();tP.initSync();var yh=tP.get(Wi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),rR=Wi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,ja=Wi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function g4(e,t,r,n,s=li.getNextMonotonicTime()){oR(e,t,r,n),nR(e,t,r);let i=new _4,o=[],c=[];for(let l=0;l<n.length;l++){let d=n[l];rP(d,!0,s);let u=R4(e,t,r,d),_=d[t];o.push(u),c.push(_)}return sR(o,c,n,i,s)}a(g4,"insertRecords");function R4(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 u=c([[{}]]);Array.isArray(u)&&(c=u[0][Wi.FUNC_VAL],n[o]=c)}let l=li.getIndexedValues(c),d=e.dbis[o];if(l){yh&&d.prefetch(l.map(u=>({key:u,value:s})),Oh);for(let u=0,_=l.length;u<_;u++)d.put(l[u],s)}}yh&&e.dbis[t].prefetch([s],Oh),e.dbis[t].put(s,n,n[ja])})}a(R4,"insertRecord");function A4(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(A4,"removeSkippedRecords");function rP(e,t,r){let n=r>0;(n||!Number.isInteger(e[ja]))&&(e[ja]=r||(r=li.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[rR]))&&(e[rR]=r||li.getNextMonotonicTime()):delete e[rR]}a(rP,"setTimestamps");function nR(e,t,r){r.indexOf(Wi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Wi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Wi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Wi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),d4.initializeDBIs(e,t,r)}a(nR,"initializeTransaction");async function b4(e,t,r,n,s=li.getNextMonotonicTime()){oR(e,t,r,n),nR(e,t,r);let i=new f4,o=[],c=[],l=[];for(let d=0;d<n.length;d++){let u=n[d],_=u[t],E;try{E=iR(e,t,u,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(d);continue}c.push(E),l.push(_)}return sR(c,l,n,i,s,o)}a(b4,"updateRecords");async function y4(e,t,r,n,s=li.getNextMonotonicTime()){try{oR(e,t,r,n)}catch(l){throw S4(l,l.message,T4.HTTP_STATUS_CODES.BAD_REQUEST)}nR(e,t,r);let i=new E4,o=[],c=[];for(let l=0;l<n.length;l++){let d=n[l],u;m4.isEmpty(d[t])?(u=p4.v4(),d[t]=u):u=d[t];let _=iR(e,t,d,u,i,!1,s);o.push(_),c.push(u)}return sR(o,c,n,i,s)}a(y4,"upsertRecords");async function sR(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(),A4(r,i),n}a(sR,"finalizeWrite");function iR(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),d=l?.value,u=d;if(!d){if(i)return!1;d={}}if(rP(r,!u,o),Number.isInteger(r[ja])&&d[ja]>r[ja])return!1;u&&s.original_records.push(d);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let T=r[h],S=e.dbis[h];if(S===void 0)continue;let R=d[h];if(typeof T=="function"){let y=T([[d]]);Array.isArray(y)&&(T=y[0][Wi.FUNC_VAL],r[h]=T)}if(T===R)continue;let p=li.getIndexedValues(R);if(p){yh&&S.prefetch(p.map(y=>({key:y,value:n})),Oh);for(let y=0,O=p.length;y<O;y++)S.remove(p[y],n)}if(p=li.getIndexedValues(T),p){yh&&S.prefetch(p.map(y=>({key:y,value:n})),Oh);for(let y=0,O=p.length;y<O;y++)S.put(p[y],n)}}let f={...d,...r};c.put(n,f,f[ja])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:iR(e,t,r,n,s,i,o))}a(iR,"updateUpsertRecord");function O4(e,t,r){if(li.validateEnv(e),t===void 0)throw new Error(Jd.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Jd.WRITE_ATTRIBUTES_REQUIRED):new Error(Jd.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(O4,"validateBasic");function oR(e,t,r,n){if(O4(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Jd.RECORDS_REQUIRED):new Error(Jd.RECORDS_MUST_BE_ARRAY)}a(oR,"validateWrite");function Oh(){}a(Oh,"noop");nP.exports={insertRecords:g4,updateRecords:b4,upsertRecords:y4}});var ji=b((WRe,N4)=>{N4.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:"__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"}]},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 di=b((jRe,oP)=>{"use strict";var iP=J(),sP=M(),Nl=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,ui=require("joi"),Vo={schema_format:{pattern:Nl,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},I4=ui.alternatives(ui.string().min(1).max(Vo.schema_length.maximum).pattern(Nl).messages({"string.pattern.base":"{:#label} "+Vo.schema_format.message}),ui.number(),ui.array()).required(),w4=ui.alternatives(ui.string().min(1).max(Vo.schema_length.maximum).pattern(Nl).messages({"string.pattern.base":"{:#label} "+Vo.schema_format.message}),ui.number()),C4=ui.alternatives(ui.string().min(1).max(Vo.schema_length.maximum).pattern(Nl).messages({"string.pattern.base":"{:#label} "+Vo.schema_format.message}),ui.number()).required();function D4(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Vo.schema_length.maximum?`'${e}' maximum of 250 characters`:Nl.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(D4,"checkValidTable");function P4(e,t){return iP.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(P4,"validateSchemaExists");function L4(e,t){let r=t.state.ancestors[0].schema;return iP.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(L4,"validateTableExists");function M4(e,t){return e.toLowerCase()===sP.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${sP.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(M4,"validateSchemaName");oP.exports={common_validators:Vo,schema_regex:Nl,hdb_schema_table:I4,validateSchemaExists:P4,validateTableExists:L4,validateSchemaName:M4,checkValidTable:D4,hdb_database:w4,hdb_table:C4}});var ut=b((zRe,aP)=>{"use strict";var on=require("validate.js");on.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||on.validators.type.checks[t](e)?null:` must be a '${t}' value`};on.validators.type.checks={Object:function(e){return on.isObject(e)&&!on.isArray(e)},Array:on.isArray,Integer:on.isInteger,Number:on.isNumber,String:on.isString,Date:on.isDate,Boolean:function(e){return typeof e=="boolean"}};on.validators.hasValidFileExt=function(e,t){return on.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};aP.exports={validateObject:U4,validateObjectAsync:v4,validateBySchema:B4};function U4(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=on(e,t,{format:"flat"});return r?new Error(r):null}a(U4,"validateObject");async function v4(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await on.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(v4,"validateObjectAsync");function B4(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(B4,"validateBySchema")});var Nh=b((XRe,cP)=>{var{common_validators:_i}=di(),Zd=ut(),Xd="is required",rr={database:{presence:!1,format:_i.schema_format,length:_i.schema_length},schema:{presence:!1,format:_i.schema_format,length:_i.schema_length},table:{presence:!0,format:_i.schema_format,length:_i.schema_length},attribute:{presence:!0,format:_i.schema_format,length:_i.schema_length},hash_attribute:{presence:!0,format:_i.schema_format,length:_i.schema_length}};function e_(e){for(let t in e)e[t]=e[t]===null||e[t]===void 0||typeof e[t]=="object"?e[t]:e[t].toString();return e}a(e_,"makeAttributesStrings");function H4(e){return e=e_(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,Zd.validateObject(e,rr)}a(H4,"schema_object");function x4(e){return e=e_(e),rr.table.presence={message:Xd},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,Zd.validateObject(e,rr)}a(x4,"table_object");function k4(e){return e=e_(e),rr.table.presence={message:Xd},rr.attribute.presence=!1,Zd.validateObject(e,rr)}a(k4,"create_table_object");function F4(e){return e=e_(e),rr.table.presence={message:Xd},rr.attribute.presence={message:Xd},rr.hash_attribute.presence=!1,Zd.validateObject(e,rr)}a(F4,"attribute_object");function G4(e){return e=e_(e),rr.table.presence={message:Xd},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,Zd.validateObject(e,rr)}a(G4,"describe_table");function q4(e){if(e){if(!Array.isArray(e))throw new Error("residence must be a string array");if(e.length===0)throw new Error("residence cannot be an empty array");for(let t=0;t<e.length;t++)if(typeof e[t]!="string")throw new Error(`residence must be a string array, item '${e[t]}' is not a string`)}}a(q4,"validateTableResidence");cP.exports={schema_object:H4,create_table_object:k4,table_object:x4,attribute_object:F4,describe_table:G4,validateTableResidence:q4}});var uP=b((eAe,lP)=>{"use strict";var $4=require("uuid"),aR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||$4.v4(),this.schema_table=`${this.schema}.${this.table}`}};lP.exports=aR});var Ih=b((rAe,dP)=>{"use strict";var V4=uP(),cR=class extends V4{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}};dP.exports=cR});var fP=b((sAe,_P)=>{"use strict";_P.exports=K4;var Y4="inserted";function K4(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===Y4?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(K4,"returnObject")});var wh=b((aAe,pP)=>{"use strict";var W4=M(),lR=ht(),j4=Qa(),{getSystemSchemaPath:Q4,getSchemaPath:z4}=gt(),oAe=ji(),J4=Nh(),X4=Ih(),Z4=fP(),{handleHDBError:EP,hdb_errors:mP}=fe(),hP=J(),{HTTP_STATUS_CODES:eJ}=mP,tJ="inserted";pP.exports=rJ;async function rJ(e){let t=J4.attribute_object(e);if(t)throw EP(new Error,t.message,mP.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&hP.checkGlobalSchemaTable(e.schema,e.table);if(r)throw EP(new Error,r,eJ.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=hP.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 X4(e.schema,e.table,e.attribute,e.id);try{let i=await lR.openEnvironment(z4(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}`);lR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await lR.openEnvironment(Q4(),W4.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await j4.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return Z4(tJ,c,{records:[s]},l)}catch(i){throw i}}a(rJ,"lmdbCreateAttribute")});var dR=b((lAe,TP)=>{var{hdb_table:nJ,hdb_database:SP}=di(),sJ=ut(),uR=require("joi"),iJ={undefined:"undefined",null:"null"},oJ=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||iJ[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"),aJ=uR.object({database:SP,schema:SP,table:nJ,records:uR.array().items(uR.object().custom(oJ)).required()});TP.exports=function(e){return sJ.validateBySchema(e,aJ)}});var t_=b((_Ae,RP)=>{"use strict";var Qi=J(),gP=V(),dAe=dR(),{getDatabases:cJ}=(Le(),oe(lt)),{ClientError:za}=fe();RP.exports=lJ;function lJ(e){if(Qi.isEmpty(e))throw new za("invalid update parameters defined.");if(Qi.isEmptyOrZeroLength(e.schema))throw new za("invalid schema specified.");if(Qi.isEmptyOrZeroLength(e.table))throw new za("invalid table specified.");if(!Array.isArray(e.records))throw new za("records must be an array");let t=cJ()[e.schema]?.[e.table];if(Qi.isEmpty(t))throw new za(`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&&Qi.isEmptyOrZeroLength(o[r]))throw gP.error("a valid hash attribute must be provided with update record:",o),new za("a valid hash attribute must be provided with update record, check log for more info");if(!Qi.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw gP.error(`a valid hash value must be provided with ${e.operation} record:`,o),new za(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!Qi.isEmpty(o[r])&&o[r]!==""&&n.has(Qi.autoCast(o[r]))&&(o.skip=!0),n.add(Qi.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(lJ,"insertUpdateValidate")});var bP=b((EAe,AP)=>{"use strict";var _R=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};AP.exports=_R});var NP=b((mAe,OP)=>{"use strict";var fR=ht(),uJ=V(),yP=Nn().LMDB_ERRORS_ENUM;OP.exports=dJ;async function dJ(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 fR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==yP.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await fR.closeEnvironment(global.lmdb_map[n]),await fR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==yP.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){uJ.error(t)}}a(dJ,"cleanLMDBMap")});var zi=b((SAe,DP)=>{"use strict";var r_=require("crypto"),_J=te(),{CONFIG_PARAMS:fJ}=M(),wP="aes-256-cbc",EJ=32,hJ=16,ER=64,CP=32,mJ=ER+CP,IP=new Map;DP.exports={encrypt:pJ,decrypt:SJ,createNatsTableStreamName:TJ};function pJ(e){let t=r_.randomBytes(EJ),r=r_.randomBytes(hJ),n=r_.createCipheriv(wP,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(pJ,"encrypt");function SJ(e){let t=e.substr(0,ER),r=e.substr(ER,CP),n=e.substr(mJ,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=r_.createDecipheriv(wP,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(SJ,"decrypt");function TJ(e,t){let r=_J.get(fJ.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=IP.get(r);return n||(n=r_.createHash("md5").update(r).digest("hex"),IP.set(r,n)),n}a(TJ,"createNatsTableStreamName")});var fi=b((RAe,LP)=>{"use strict";var gAe=Vr(),n_=V(),PP=Nh(),gJ=zi(),Ch=J(),{handleHDBError:Dh,hdb_errors:RJ}=fe(),{HDB_ERROR_MSGS:Ph,HTTP_STATUS_CODES:hR}=RJ,AJ=te();AJ.initSync();var{getDatabases:mR}=(Le(),oe(lt)),bJ=require("fs-extra");LP.exports={describeAll:yJ,describeTable:Lh,describeSchema:OJ};async function yJ(e={}){try{let t=Ch.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=mR(),o={},c={},l=[],d=e?.exact_count;for(let _ in i){o[_]=!0,!t&&!s&&!r&&(c[_]=e.hdb_user?.role?.permission[_]?.describe);let E=i[_];for(let f in E)try{let h;if(t||s||r)h=await Lh({schema:_,table:f,exact_count:d});else if(n&&n[_].describe&&n[_].tables[f].describe){let T=n[_].tables[f].attribute_permissions;h=await Lh({schema:_,table:f,exact_count:d},T)}h&&l.push(h)}catch(h){n_.error(h)}}let u={};for(let _ in l)t||s||r?(u[l[_].schema]==null&&(u[l[_].schema]={}),u[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]):c[l[_].schema]&&(u[l[_].schema]==null&&(u[l[_].schema]={}),u[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]);for(let _ in o)t||s||r?u[_]={}:c[_]&&(u[_]={});return u}catch(t){return n_.error("Got an error in describeAll"),n_.error(t),Dh(new Error,Ph.DESCRIBE_ALL_ERR)}}a(yJ,"describeAll");async function Lh(e,t){Ch.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=PP.describe_table(e);if(i)throw i;let c=mR()[r];if(!c)throw Dh(new Error,Ph.SCHEMA_NOT_FOUND(e.schema),hR.NOT_FOUND);let l=c[n];if(!l)throw Dh(new Error,Ph.TABLE_NOT_FOUND(e.schema,e.table),hR.NOT_FOUND);function d(f){u.push({attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(d,"pushAtt");let u=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&d(h)})}else l.attributes?.forEach(f=>d(f));let _;try{_=(await bJ.stat(l.primaryStore.env.path)).size}catch(f){n_.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:u,db_size:_};E.clustering_stream_name=gJ.createNatsTableStreamName(E.schema,E.name);try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let T of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=T[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let T of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=T}catch(f){n_.warn(`unable to stat table dbi due to ${f}`)}return E}a(Lh,"descTable");async function OJ(e){Ch.transformReq(e);let t=PP.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=mR()[n];if(!i)throw Dh(new Error,Ph.SCHEMA_NOT_FOUND(e.schema),hR.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Ch.isEmpty(l)||l.describe){let d=await Lh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);d&&(o[d.name]=d)}}return o}a(OJ,"describeSchema")});var as=b((OAe,HP)=>{var NJ=ji(),{callbackify:UP,promisify:IJ}=require("util"),{getDatabases:vP}=(Le(),oe(lt));HP.exports={setSchemaDataToGlobal:MP,getTableSchema:wJ,getSystemSchema:CJ,setSchemaDataToGlobalAsync:IJ(MP)};var BP=fi(),bAe=UP(BP.describeAll),yAe=UP(BP.describeTable);function MP(e){global.hdb_schema=vP(),e&&e()}a(MP,"setSchemaDataToGlobal");function wJ(e,t,r){let n=vP()[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(wJ,"getTableSchema");function CJ(){return NJ}a(CJ,"getSystemSchema")});var Yr=b((IAe,GP)=>{"use strict";var Uh=dR(),wr=J(),DJ=require("util"),vh=Pn(),PJ=as(),xP=V(),{handleHDBError:Ja,hdb_errors:LJ}=fe(),{HTTP_STATUS_CODES:Xa}=LJ,MJ=DJ.promisify(PJ.getTableSchema),UJ="updated",kP="inserted",FP="upserted";GP.exports={insert:BJ,update:HJ,upsert:xJ,validation:vJ,flush:kJ};async function vJ(e){if(wr.isEmpty(e))throw new Error("invalid update parameters defined.");if(wr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(wr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await MJ(e.schema,e.table),r=Uh(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&&wr.isEmptyOrZeroLength(c[n]))throw xP.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(!wr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw xP.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!wr.isEmpty(c[n])&&c[n]!==""&&s.has(wr.autoCast(c[n]))&&(c.skip=!0),s.add(wr.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(vJ,"validation");async function BJ(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=Uh(e);if(t)throw Ja(new Error,t.message,Xa.BAD_REQUEST);wr.transformReq(e);let r=wr.checkSchemaTableExist(e.schema,e.table);if(r)throw Ja(new Error,r,Xa.BAD_REQUEST);let n=await vh.createRecords(e);return Mh(kP,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(BJ,"insertData");async function HJ(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=Uh(e);if(t)throw Ja(new Error,t.message,Xa.BAD_REQUEST);wr.transformReq(e);let r=wr.checkSchemaTableExist(e.schema,e.table);if(r)throw Ja(new Error,r,Xa.BAD_REQUEST);let n=await vh.updateRecords(e);return wr.isEmpty(n.existing_rows)?Mh(UJ,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Mh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(HJ,"updateData");async function xJ(e){if(e.operation!=="upsert")throw Ja(new Error,"invalid operation, must be upsert",Xa.INTERNAL_SERVER_ERROR);let t=Uh(e);if(t)throw Ja(new Error,t.message,Xa.BAD_REQUEST);wr.transformReq(e);let r=wr.checkSchemaTableExist(e.schema,e.table);if(r)throw Ja(new Error,r,Xa.BAD_REQUEST);let n=await vh.upsertRecords(e);return Mh(FP,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(xJ,"upsertData");function Mh(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===kP?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===FP?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Mh,"returnObject");function kJ(e){return wr.transformReq(e),vh.flush(e.schema,e.table)}a(kJ,"flush")});var SR=b((CAe,VP)=>{var FJ=ut(),pR=require("joi"),{hdb_table:GJ,hdb_database:qP}=di(),$P={schema:qP,database:qP,table:GJ},qJ={date:pR.date().iso().required()},$J={timestamp:pR.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};VP.exports=function(e,t){let r=t==="timestamp"?{...$P,...$J}:{...$P,...qJ},n=pR.object(r);return FJ.validateBySchema(e,n)}});var WP=b((DAe,KP)=>{var VJ=ut(),TR=require("joi"),{hdb_table:YJ,hdb_database:YP}=di(),KJ=TR.object({schema:YP,database:YP,table:YJ,hash_values:TR.array().required(),ids:TR.array()});KP.exports=function(e){return VJ.validateBySchema(e,KJ)}});var bR=b((PAe,jP)=>{"use strict";var gR=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}},RR=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}},AR=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};jP.exports={InsertObject:gR,NoSQLSeachObject:RR,DeleteResponseObject:AR}});var Wo=b((MAe,ZP)=>{"use strict";var zP=SR(),WJ=WP(),Za=J(),QP=require("moment"),JP=V(),{promisify:jJ,callbackify:QJ}=require("util"),ec=M(),zJ=as(),yR=jJ(zJ.getTableSchema),OR=Pn(),{DeleteResponseObject:JJ}=bR(),{handleHDBError:Yo,hdb_errors:XJ}=fe(),{HDB_ERROR_MSGS:Bh,HTTP_STATUS_CODES:Ko}=XJ,ZJ="records successfully deleted",e3=QJ(XP);ZP.exports={delete:e3,deleteRecord:XP,deleteFilesBefore:t3,deleteAuditLogsBefore:r3};async function t3(e){let t=zP(e,"date");if(t)throw Yo(t,t.message,Ko.BAD_REQUEST,void 0,void 0,!0);if(Za.transformReq(e),!QP(e.date,QP.ISO_8601).isValid())throw Yo(new Error,Bh.INVALID_DATE,Ko.BAD_REQUEST,ec.LOG_LEVELS.ERROR,Bh.INVALID_DATE,!0);let n=Za.checkSchemaTableExist(e.schema,e.table);if(n)throw Yo(new Error,n,Ko.NOT_FOUND,ec.LOG_LEVELS.ERROR,n,!0);let s=await OR.deleteRecordsBefore(e);if(await yR(e.schema,e.table),JP.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(t3,"deleteFilesBefore");async function r3(e){let t=zP(e,"timestamp");if(t)throw Yo(t,t.message,Ko.BAD_REQUEST,void 0,void 0,!0);if(Za.transformReq(e),isNaN(e.timestamp))throw Yo(new Error,Bh.INVALID_VALUE("Timestamp"),Ko.BAD_REQUEST,ec.LOG_LEVELS.ERROR,Bh.INVALID_VALUE("Timestamp"),!0);let r=Za.checkSchemaTableExist(e.schema,e.table);if(r)throw Yo(new Error,r,Ko.NOT_FOUND,ec.LOG_LEVELS.ERROR,r,!0);let n=await OR.deleteAuditLogsBefore(e);return await yR(e.schema,e.table),JP.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(r3,"deleteAuditLogsBefore");async function XP(e){e.ids&&(e.hash_values=e.ids);let t=WJ(e);if(t)throw Yo(t,t.message,Ko.BAD_REQUEST,void 0,void 0,!0);Za.transformReq(e);let r=Za.checkSchemaTableExist(e.schema,e.table);if(r)throw Yo(new Error,r,Ko.NOT_FOUND,ec.LOG_LEVELS.ERROR,r,!0);try{await yR(e.schema,e.table);let n=await OR.deleteRecords(e);return Za.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${ZJ}`),n}catch(n){if(n.message===ec.SEARCH_NOT_FOUND_MESSAGE){let s=new JJ;return s.message=ec.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(XP,"deleteRecord")});var Hh=b((vAe,rL)=>{var n3=require("crypto"),eL=9;function s3(e){let t=o3(eL),r=tL(e+t);return t+r}a(s3,"createHash");function i3(e,t){let r=e?.substr(0,eL),n=r+tL(t+r);return e===n}a(i3,"validateHash");function o3(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(o3,"generateSalt");function tL(e){return n3.createHash("md5").update(e).digest("hex")}a(tL,"md5");rL.exports={hash:s3,validate:i3}});var sL=b((HAe,nL)=>{var NR=ut(),Kr={username:{presence:!0,format:"[\\w\\-\\_]+",exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function a3(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,NR.validateObject(e,Kr)}a(a3,"addUserValidation");function c3(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,NR.validateObject(e,Kr)}a(c3,"alterUserValidation");function l3(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,NR.validateObject(e,Kr)}a(l3,"dropUserValidation");nL.exports={addUserValidation:a3,alterUserValidation:c3,dropUserValidation:l3}});var dt=b((FAe,oL)=>{"use strict";var{platform:kAe}=require("os"),u3="nats-server.zip",IR="nats-server",d3=process.platform==="win32"?`${IR}.exe`:IR,_3=/^[^\s.,*>]+$/,iL="__request__",f3=a(e=>`${e}.${iL}`,"REQUEST_SUBJECT"),E3={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},h3={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},m3={HUB:"hub.pid",LEAF:"leaf.pid"},p3={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},S3={SUCCESS:"success",ERROR:"error"},T3={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},g3={TXN:"txn",MSGID:"msgid"},Il={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},R3={[Il.ERR]:1,[Il.WRN]:2,[Il.INF]:3,[Il.DBG]:4,[Il.TRC]:5},A3={debug:"-D",trace:"-DVV"};oL.exports={NATS_SERVER_ZIP:u3,NATS_SERVER_NAME:IR,NATS_BINARY_NAME:d3,PID_FILES:m3,NATS_CONFIG_FILES:h3,SERVER_SUFFIX:p3,NATS_TERM_CONSTRAINTS_RX:_3,REQUEST_SUFFIX:iL,UPDATE_REMOTE_RESPONSE_STATUSES:S3,CLUSTER_STATUS_STATUSES:T3,REQUEST_SUBJECT:f3,SUBJECT_PREFIXES:g3,MSG_HEADERS:E3,LOG_LEVELS:Il,LOG_LEVEL_FLAGS:A3,LOG_LEVEL_HIERARCHY:R3}});var wR=b(aL=>{"use strict";var b3={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
|
|
7
9
|
`),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
|
|
8
|
-
`)},aj="certificate.pem",cj="privateKey.pem",lj="caCertificate.pem",uj="natsCertificate.pem",dj="natsCaCertificate.pem",St={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},_j={tls_certificate:St.SERVER,tls_certificateAuthority:St.CA,customFunctions_tls_certificate:St.SERVER,customFunctions_tls_certificateAuthority:St.CA,operationsApi_tls_certificate:St["OPERATIONS-API"],operationsApi_tls_certificateAuthority:St["OPERATIONS-CA"]},fj={[St.SERVER]:2,[St.DEFAULT]:1},Ej={[St["OPERATIONS-API"]]:3,[St.SERVER]:2,[St.DEFAULT]:1},hj={[St["OPERATIONS-API"]]:3,[St.SERVER]:2,[St.DEFAULT]:1},mj={[St["OPERATIONS-CA"]]:3,[St.CA]:2,[St["DEFAULT-CA"]]:1},pj={[St["OPERATIONS-CA"]]:3,[St.CA]:2,[St["DEFAULT-CA"]]:1},Sj={[St.CA]:2,[St["DEFAULT-CA"]]:1};Object.assign(NC,{CERTIFICATE_PEM_NAME:aj,PRIVATEKEY_PEM_NAME:cj,CA_PEM_NAME:lj,CERT_NAME:St,CERT_CONFIG_NAME_MAP:_j,CERT_PREFERENCE_APP:fj,CERT_PREFERENCE_OPS:Ej,CERT_PREFERENCE_REP:hj,CA_CERT_PREFERENCE_REP:mj,CA_CERT_PREFERENCE_OPS:pj,CA_CERT_PREFERENCE_APP:Sj,CERTIFICATE_VALUES:oj,NATS_CERTIFICATE_PEM_NAME:uj,NATS_CA_PEM_NAME:dj})});var NT=N((Phe,PC)=>{"use strict";var DC=require("fs-extra"),de=require("joi"),Tj=require("os"),{boolean:Ge,string:Tt,number:yt,array:Pu}=de.types(),{totalmem:IC}=require("os"),ea=require("path"),gj=j(),OT=te(),Lhe=yT(),wC=M(),Rj=ct(),CC="log",Aj="components",bj="Invalid logging.rotation.maxSize unit. Available units are G, M or K",yj="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",Oj="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",Nj="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",Ij="rootPath config parameter is undefined",io=de.alternatives([yt.min(0),Tt]).required(),eE=de.alternatives([Pu.items(Tt,{host:Tt.required(),port:io},{hostname:Tt.required(),port:io}).empty(null),Pu.items(Tt)]),ks,LC=!1;PC.exports={configValidator:wj,routesValidator:Uj,route_constraints:eE};function wj(e,t=!1){if(LC=t,ks=e.rootPath,OT.isEmpty(ks))throw Ij;let r=Ge.optional(),n=yt.min(0).max(1e3).empty(null).default(Mj),s=Tt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Lu),i=Tt.optional().empty(null),o=Tt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=de.string().empty(null).default(Lu),l=de.custom(Dj).empty(null).default(Lu),d=e.clustering?.enabled,u=de.object({certificate:i,certificateAuthority:i,privateKey:i}),_;return d===!0?_=de.object({enabled:r,hubServer:de.object({cluster:de.object({name:de.required().empty(null),network:de.object({port:io,routes:eE}).required()}).required(),leafNodes:de.object({network:de.object({port:io}).required()}).required(),network:de.object({port:io}).required()}).required(),leafServer:de.object({network:de.object({port:io,routes:eE}).required(),streams:de.object({maxAge:yt.min(120).allow(null).optional(),maxBytes:yt.min(1).allow(null).optional(),maxMsgs:yt.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:de.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:Ge.optional(),databaseLevel:Ge.optional(),tls:de.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Ge.required(),verify:Ge.optional()}),user:Tt.optional().empty(null)}).optional():_=de.object({enabled:r,tls:de.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Ge.optional()})}).optional(),de.object({authentication:de.object({authorizeLocal:Ge,cacheTTL:yt.required(),enableSessions:Ge}),analytics:de.object({aggregatePeriod:yt}),componentsRoot:s.optional(),clustering:_,localStudio:de.object({enabled:r}).required(),logging:de.object({auditAuthEvents:de.object({logFailed:Ge,logSuccessful:Ge}),file:Ge.required(),level:de.valid("notify","fatal","error","warn","info","debug","trace"),rotation:de.object({enabled:Ge.optional(),compress:Ge.optional(),interval:Tt.custom(Pj).optional().empty(null),maxSize:Tt.custom(Lj).optional().empty(null),path:Tt.optional().empty(null).default(Lu)}).required(),root:s,stdStreams:Ge.required(),auditLog:Ge.required()}).required(),operationsApi:de.object({network:de.object({cors:Ge.optional(),corsAccessList:Pu.optional(),headersTimeout:yt.min(1).optional(),keepAliveTimeout:yt.min(1).optional(),port:de.alternatives([yt.min(0),Tt]).optional().empty(null),domainSocket:de.optional().empty("hdb/operations-server").default(Lu),securePort:de.alternatives([yt.min(0),Tt]).optional().empty(null),timeout:yt.min(1).optional()}).optional(),tls:de.alternatives([de.array().items(u),u])}).required(),rootPath:Tt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:de.object({network:de.object({port:io,securePort:io,mtls:de.alternatives([Ge.optional(),de.object({user:Tt.optional(),certificateAuthority:i,required:Ge.optional()})])}).required(),webSocket:Ge.optional(),requireAuthentication:Ge.optional()}),http:de.object({compressionThreshold:yt.optional(),cors:Ge.optional(),corsAccessList:Pu.optional(),headersTimeout:yt.min(1).optional(),port:de.alternatives([yt.min(0),Tt]).optional().empty(null),securePort:de.alternatives([yt.min(0),Tt]).optional().empty(null),maxHeaderSize:yt.optional(),mtls:de.alternatives([Ge.optional(),de.object({user:Tt.optional(),certificateAuthority:i,required:Ge.optional()})]),threadRange:de.alternatives([Pu.optional(),Tt.optional()])}).required(),threads:de.alternatives(n.optional(),de.object({count:n.optional(),debug:de.alternatives(Ge.optional(),de.object({startingPort:yt.min(1).optional(),host:Tt.optional(),waitForDebugger:Ge.optional()})),maxHeapMemory:yt.min(0).optional()})),storage:de.object({writeAsync:Ge.required(),overlappingSync:Ge.optional(),caching:Ge.optional(),compression:de.alternatives([Ge.optional(),de.object({dictionary:Tt.optional(),threshold:yt.optional()})]),compactOnStart:Ge.optional(),compactOnStartKeepBackup:Ge.optional(),noReadAhead:Ge.optional(),path:l,prefetchWrites:Ge.optional(),maxFreeSpaceToLoad:yt.optional(),maxFreeSpaceToRetain:yt.optional()}).required(),ignoreScripts:Ge.optional(),tls:de.alternatives([de.array().items(u),u])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(wj,"configValidator");function Cj(e){return LC||DC.existsSync(e)?null:`Specified path ${e} does not exist.`}a(Cj,"doesPathExist");function Dj(e,t){de.assert(e,Tt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=Cj(e);if(r)return t.message(r)}a(Dj,"validatePath");function Lj(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(bj);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(Oj):e}a(Lj,"validateRotationMaxSize");function Pj(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(yj);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(Nj):e}a(Pj,"validateRotationInterval");function Mj(e,t){let r=t.state.path.join("."),n=Tj.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||IC();return i=Math.round(Math.min(i,IC())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),gj.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(Mj,"setDefaultThreads");function Lu(e,t){let r=t.state.path.join(".");if(!OT.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(OT.isEmpty(ks))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return ea.join(ks,Aj);case"logging.root":return ea.join(ks,CC);case"clustering.leafServer.streams.path":return ea.join(ks,"clustering","leaf");case"storage.path":let n=ea.join(ks,wC.LEGACY_DATABASES_DIR_NAME);return DC.existsSync(n)?n:ea.join(ks,wC.DATABASES_DIR_NAME);case"logging.rotation.path":return ea.join(ks,CC);case"operationsApi.network.domainSocket":return r==null?null:ea.join(ks,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Lu,"setDefaultRoot");function Uj(e){let t=de.object({routes:eE});return Rj.validateBySchema({routes:e},t)}a(Uj,"routesValidator")});var dr=N((Uhe,qC)=>{"use strict";var Yr=M(),sr=te(),ir=j(),{configValidator:vj,routesValidator:MC}=NT(),Mr=require("fs-extra"),vC=require("yaml"),bn=require("path"),xj=require("is-number"),xC=require("properties-reader"),Bj=require("lodash"),{handleHDBError:Hj}=ce(),{HTTP_STATUS_CODES:kj,HDB_ERROR_MSGS:hc}=En(),{server:Fj}=(Lr(),ae(qo)),{DATABASES_PARAM_CONFIG:Mu,CONFIG_PARAMS:An,CONFIG_PARAM_MAP:Es}=Yr,Gj="Unable to get config value because config is uninitialized",qj="Config successfully initialized",Vj="Error backing up config file",$j="Empty parameter sent to getConfigValue",BC=bn.join(Yr.PACKAGE_ROOT,"config","yaml",Yr.HDB_DEFAULT_CONFIG_FILE),Yj=bn.join(Yr.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),Kj="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",UC={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"},tE,or,rE;qC.exports={createConfigFile:Wj,getDefaultConfig:Qj,getConfigValue:kC,initConfig:CT,flattenConfig:mc,updateConfigValue:FC,updateConfigObject:jj,getConfiguration:Zj,setConfiguration:e2,readConfigFile:LT,getClusteringRoutes:t2,initOldConfig:GC,getConfigFromFile:r2,getConfigFilePath:ta,addConfig:n2,deleteConfigFromFile:s2,getConfigObj:i2,resolvePath:IT};function IT(e){if(e?.startsWith("~/"))return bn.join(sr.getHomeDir(),e.slice(1));let t=ne();return bn.resolve(t.getHdbBasePath(),e)}a(IT,"resolvePath");function Wj(e,t=!1){let r=oo(BC);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=vC.parseDocument(Mr.readFileSync(Yj,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}tE=mc(r.toJSON());let n;for(let c in e){let l=Es[c.toLowerCase()];if(l===An.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(d=>({[d]:e[c][d]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let d=l.split("_"),u=wT(l,e[c]);l==="rootPath"&&u?.endsWith("/")&&(u=u.slice(0,-1));try{r.setIn([...d],u)}catch(_){ir.error(_)}}}n&&HC(r,n),DT(r,t);let s=r.toJSON();or=mc(s);let i=r.getIn(["rootPath"]),o=bn.join(i,Yr.HDB_CONFIG_FILE);Mr.createFileSync(o),Mr.writeFileSync(o,String(r)),ir.trace(`Config file written to ${o}`)}a(Wj,"createConfigFile");function HC(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(Mu.TABLES))for(let i in n[s][Mu.TABLES])for(let o in n[s][Mu.TABLES][i]){let c=n[s][Mu.TABLES][i][o],l=[An.DATABASES,s,Mu.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=[An.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){ir.error("Error parsing schemas CLI/env config arguments",n)}}a(HC,"setSchemasConfig");function Qj(e){if(tE===void 0){let r=oo(BC);tE=mc(r.toJSON())}let t=Es[e.toLowerCase()];if(t!==void 0)return tE[t.toLowerCase()]}a(Qj,"getDefaultConfig");function kC(e){if(e==null){ir.info($j);return}if(or===void 0){ir.trace(Gj);return}let t=Es[e.toLowerCase()];if(t!==void 0)return or[t.toLowerCase()]}a(kC,"getConfigValue");function ta(e=sr.getPropsFilePath()){let t=sr.getEnvCliRootPath();if(t)return IT(bn.join(t,Yr.HDB_CONFIG_FILE));let r=xC(e);return IT(r.get(Yr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(ta,"getConfigFilePath");function CT(e=!1){if(or===void 0||e){let t;if(!sr.noBootFile()){t=sr.getPropsFilePath();try{Mr.accessSync(t,Mr.constants.F_OK|Mr.constants.R_OK)}catch(i){throw ir.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=ta(t),n;if(r.includes("config/settings.js"))try{GC(r);return}catch(i){if(i.code!==Yr.NODE_ERROR_CODES.ENOENT)throw i}try{n=oo(r)}catch(i){if(i.code===Yr.NODE_ERROR_CODES.ENOENT){ir.trace(`HarperDB config file not found at ${r}.
|
|
9
|
-
This can occur during early stages of install where the config file has not yet been created`);return}else throw ir.error(i),new Error(`Error reading HarperDB config file at ${r}`)}zj(n,r),DT(n);let s=n.toJSON();if(Fj.config=s,or=mc(s),or.logging_rotation_rotate)for(let i in UC)or[i]&&ir.error(`Config ${UC[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);ir.trace(qj)}}a(CT,"initConfig");function zj(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],bn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],bn.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&&(ir.trace("Updating config file with missing config params"),Mr.writeFileSync(t,String(e)))}a(zj,"checkForUpdatedConfig");function DT(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 hc.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 hc.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=vj(r,t);if(n.error)throw hc.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(DT,"validateConfig");function jj(e,t){or===void 0&&(or={});let r=Es[e.toLowerCase()];if(r===void 0){ir.trace(`Unable to update config object because config param '${e}' does not exist`);return}or[r.toLowerCase()]=t}a(jj,"updateConfigObject");function FC(e,t,r=void 0,n=!1,s=!1,i=!1){or===void 0&&CT();let o=kC(Es.hdb_root),c=bn.join(o,Yr.HDB_CONFIG_FILE),l=oo(c),d;if(r===void 0&&e.toLowerCase()===An.DATABASES)d=t;else if(r===void 0){let E;if(i)E=e;else if(E=Es[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=wT(E,t);l.setIn([...f],h)}else for(let E in r){let f=Es[E.toLowerCase()];if(f===An.HTTP_SECUREPORT&&r[E]===or[An.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===An.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===or[An.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===An.DATABASES){d=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),p=Yr.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&l.hasIn(p.split("_"))&&(f=p,h=p.split("_"));let S=wT(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],S)}catch(g){ir.error(g)}}}d&&HC(l,d),DT(l);let u=l.getIn(["rootPath"]),_=bn.join(u,Yr.HDB_CONFIG_FILE);n===!0&&Jj(c,u),Mr.writeFileSync(_,String(l)),s&&(or=mc(l.toJSON())),ir.trace(`Config parameter: ${e} updated with value: ${t}`)}a(FC,"updateConfigValue");function Jj(e,t){try{let r=bn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${Yr.HDB_CONFIG_FILE}.bak`);Mr.copySync(e,r),ir.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){ir.error(Vj),ir.error(r)}}a(Jj,"backupConfigFile");var Xj=["databases"];function mc(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network=Object.assign({},e.http,e.operationsApi.network)),e?.operationsApi&&(e.operationsApi.tls=Object.assign({},e.tls,e.operationsApi.tls)),rE=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])&&!Xj.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;!An[l.toUpperCase()]&&Es[l]&&(s[Es[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(mc,"flattenConfig");function wT(e,t){if(e===An.CLUSTERING_NODENAME||e===An.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(xj(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(wT,"castConfigValue");function Zj(){let e=sr.getPropsFilePath(),t=ta(e);return oo(t).toJSON()}a(Zj,"getConfiguration");async function e2(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return FC(void 0,void 0,s,!0),Kj}catch(i){throw typeof i=="string"||i instanceof String?Hj(i,i,kj.BAD_REQUEST,void 0,void 0,!0):i}}a(e2,"setConfiguration");function LT(){let e=sr.getPropsFilePath();try{Mr.accessSync(e,Mr.constants.F_OK|Mr.constants.R_OK)}catch(n){if(!sr.noBootFile())throw ir.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=ta(e);return oo(t).toJSON()}a(LT,"readConfigFile");function oo(e){return vC.parseDocument(Mr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(oo,"parseYamlDoc");function t2(){let e=LT(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=sr.isEmptyOrZeroLength(t)?[]:t;let r=MC(t);if(r)throw hc.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=sr.isEmptyOrZeroLength(n)?[]:n;let s=MC(n);if(s)throw hc.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 hc.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(t2,"getClusteringRoutes");function GC(e){let t=xC(e);or={};for(let r in Es){let n=t.get(r.toUpperCase());if(sr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Es[r].toLowerCase();s===An.LOGGING_ROOT?or[s]=bn.dirname(n):or[s]=n}return or}a(GC,"initOldConfig");function r2(e){let t=LT();return Bj.get(t,e.replaceAll("_","."))}a(r2,"getConfigFromFile");async function n2(e,t){let r=oo(ta());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await Mr.writeFile(ta(),String(r))}a(n2,"addConfig");function s2(e){let t=ta(sr.getPropsFilePath()),r=oo(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=bn.join(n,Yr.HDB_CONFIG_FILE);Mr.writeFileSync(s,String(r))}a(s2,"deleteConfigFromFile");function i2(){return rE||(CT(),rE)}a(i2,"getConfigObj")});var $C=N((xhe,VC)=>{"use strict";var nE=M(),sE=class{static{a(this,"BaseLicense")}constructor(t=0,r=nE.RAM_ALLOCATION_ENUM.DEFAULT,n=nE.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},PT=class extends sE{static{a(this,"ExtendedLicense")}constructor(t=0,r=nE.RAM_ALLOCATION_ENUM.DEFAULT,n=nE.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};VC.exports={BaseLicense:sE,ExtendedLicense:PT}});var ra=N((Hhe,JC)=>{"use strict";var Sc=require("fs-extra"),KC=Zf(),WC=require("crypto"),o2=require("moment"),a2=require("uuid").v4,Ur=j(),UT=require("path"),c2=te(),ao=M(),{totalmem:YC}=require("os"),l2=$C().ExtendedLicense,pc="invalid license key format",u2="061183",d2="mofi25",_2="aes-256-cbc",f2=16,E2=32,QC=ne(),{resolvePath:zC}=dr();QC.initSync();var MT;JC.exports={validateLicense:jC,generateFingerPrint:m2,licenseSearch:BT,getLicense:T2,checkMemoryLimit:g2};function vT(){return UT.join(QC.getHdbBasePath(),ao.LICENSE_KEY_DIR_NAME,ao.LICENSE_FILE_NAME)}a(vT,"getLicenseDirPath");function h2(){let e=vT();return zC(UT.join(e,ao.LICENSE_FILE_NAME))}a(h2,"getLicenseFilePath");function xT(){let e=vT();return zC(UT.join(e,ao.REG_KEY_FILE_NAME))}a(xT,"getFingerPrintFilePath");async function m2(){let e=xT();try{return await Sc.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await p2();throw Ur.error(`Error writing fingerprint file to ${e}`),Ur.error(t),new Error("There was an error generating the fingerprint")}}a(m2,"generateFingerPrint");async function p2(){let e=a2(),t=KC.hash(e),r=xT();try{await Sc.mkdirp(vT()),await Sc.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Ur.error(`Error writing fingerprint file to ${r}`),Ur.error(n),new Error("There was an error generating the fingerprint")}return t}a(p2,"writeFingerprint");function jC(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:ao.RAM_ALLOCATION_ENUM.DEFAULT,version:ao.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Ur.error("empty license key passed to validate."),r;let n=xT(),s=!1;try{s=Sc.statSync(n)}catch(i){Ur.error(i)}if(s){let i;try{i=Sc.readFileSync(n,"utf8")}catch{Ur.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(d2),c=o[1];c=Buffer.concat([Buffer.from(c)],f2);let l=Buffer.concat([Buffer.from(i)],E2),d=WC.createDecipheriv(_2,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=d.update(o[0],"hex","utf8"),u.trim(),u+=d.final("utf8")}catch{let f=S2(o[0],i);if(f)u=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(pc),Ur.error(pc),new Error(pc)}let _;if(isNaN(u))try{_=JSON.parse(u),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(pc),Ur.error(pc),new Error(pc)}else r.exp_date=u;r.exp_date<o2().valueOf()&&(r.valid_date=!1),KC.validate(o[1],`${u2}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Ur.error("Invalid licence"),r}a(jC,"validateLicense");function S2(e,t){try{let r=WC.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Ur.warn("Check old license failed")}}a(S2,"checkOldLicense");function BT(){let e=new l2,t=[];try{t=Sc.readFileSync(h2(),"utf-8").split(ao.NEW_LINE)}catch(r){r.code==="ENOENT"?Ur.debug("no license file found"):Ur.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(c2.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=jC(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){Ur.error("There was an error parsing the license string."),Ur.error(s),e.ram_allocation=ao.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return MT=e,e}a(BT,"licenseSearch");async function T2(){return MT||await BT(),MT}a(T2,"getLicense");function g2(){let e=BT().ram_allocation,t=process.constrainedMemory?.()||YC();if(t=Math.round(Math.min(t,YC())/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(g2,"checkMemoryLimit")});var $n=N((Vhe,fD)=>{"use strict";var tD="username is required",rD="nothing to update, must supply active, role or password to update",nD="password cannot be an empty string",sD="If role is specified, it cannot be empty.",iD="active must be true or false";fD.exports={addUser:C2,alterUser:D2,dropUser:P2,getSuperUser:x2,userInfo:M2,listUsers:oE,listUsersExternal:U2,setUsersToGlobal:gc,findAndValidateUser:dD,getClusterUser:B2,USERNAME_REQUIRED:tD,ALTERUSER_NOTHING_TO_UPDATE:rD,EMPTY_PASSWORD:nD,EMPTY_ROLE:sD,ACTIVE_BOOLEAN:iD};var oD=Rn(),R2=so(),FT=Zf(),aD=bC(),cD=gn(),GT=gi(),yn=te(),lD=require("validate.js"),ke=j(),{promisify:A2}=require("util"),qT=pi(),XC=M(),ZC=lt(),b2=dr(),Fhe=ne(),Ghe=ra(),y2=Qo(),{table:qhe}=(Ne(),ae(ot)),{handleHDBError:Fs,hdb_errors:O2}=ce(),{HTTP_STATUS_CODES:Gs,AUTHENTICATION_ERROR_MSGS:HT,HDB_ERROR_MSGS:Tc}=O2,{UserEventMsg:VT}=hs(),kT=require("lodash"),{server:$T}=(Lr(),ae(qo)),N2=j();$T.getUser=(e,t)=>dD(e,t,t!=null);var uD={username:!0,active:!0,role:!0,password:!0},eD=new Map,iE=cD.searchByValue,I2=cD.searchByHash,w2=A2(R2.delete);async function C2(e){let t=lD.cleanAttributes(e,uD),r=aD.addUserValidation(t);if(r)throw Fs(new Error,r.message,Gs.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await iE(n),s=s&&Array.from(s)}catch(l){throw ke.error("There was an error searching for a role in add user"),ke.error(l),l}if(!s||s.length<1)throw Fs(new Error,Tc.ROLE_NAME_NOT_FOUND(t.role),Gs.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Fs(new Error,Tc.DUP_ROLES_FOUND(t.role),Gs.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=qT.encrypt(t.password)),t.password=FT.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await oD.insert(i)}catch(l){throw ke.error("There was an error searching for a user."),ke.error(l),l}ke.debug(o);try{await gc()}catch(l){throw ke.error("Got an error setting users to global"),ke.error(l),l}if(o.skipped_hashes.length===1)throw Fs(new Error,Tc.USER_ALREADY_EXISTS(t.username),Gs.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],GT.signalUserChange(new VT(process.pid)),`${c.username} successfully added`}a(C2,"addUser");async function D2(e){let t=lD.cleanAttributes(e,uD);if(yn.isEmptyOrZeroLength(t.username))throw new Error(tD);if(yn.isEmptyOrZeroLength(t.password)&&yn.isEmptyOrZeroLength(t.role)&&yn.isEmptyOrZeroLength(t.active))throw new Error(rD);if(!yn.isEmpty(t.password)&&yn.isEmptyOrZeroLength(t.password.trim()))throw new Error(nD);if(!yn.isEmpty(t.active)&&!yn.isBoolean(t.active))throw new Error(iD);let r=L2(t.username);if(!yn.isEmpty(t.password)&&!yn.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=qT.encrypt(t.password)),t.password=FT.hash(t.password)),t.role==="")throw new Error(sD);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await iE(i)||[])}catch(c){throw ke.error("Got an error searching for a role."),ke.error(c),c}if(!o||o.length===0){let c=Tc.ALTER_USER_ROLE_NOT_FOUND(t.role);throw ke.error(c),Fs(new Error,c,Gs.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Tc.ALTER_USER_DUP_ROLES(t.role);throw ke.error(c),Fs(new Error,c,Gs.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await oD.update(n)}catch(i){throw ke.error("Error during update."),ke.error(i),i}try{await gc()}catch(i){throw ke.error("Got an error setting users to global"),ke.error(i),i}return GT.signalUserChange(new VT(process.pid)),s}a(D2,"alterUser");function L2(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(L2,"isClusterUser");async function P2(e){try{let t=aD.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(yn.isEmpty(global.hdb_users.get(e.username)))throw Fs(new Error,Tc.USER_NOT_EXIST(e.username),Gs.NOT_FOUND,void 0,void 0,!0);let n;try{n=await w2(r)}catch(s){throw ke.error("Got an error deleting a user."),ke.error(s),s}ke.debug(n);try{await gc()}catch(s){throw ke.error("Got an error setting users to global."),ke.error(s),s}return GT.signalUserChange(new VT(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(P2,"dropUser");async function M2(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=kT.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await I2(r)}catch(s){throw ke.error("Got an error searching for a role."),ke.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw ke.error(r),r}return t}a(M2,"userInfo");async function U2(){let e;try{e=await oE()}catch(t){throw ke.error("Got an error listing users."),ke.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(U2,"listUsersExternal");async function oE(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await iE(e)}catch(o){throw ke.error("Got an error searching for roles."),ke.error(o),o}let r={};for(let o of t)r[o.id]=kT.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await iE(n)}catch(o){throw ke.error("Got an error searching for users."),ke.error(o),o}let i=new Map;for(let o of s)o=kT.cloneDeep(o),o.role=r[o.role],v2(o.role),i.set(o.username,o);return i}catch(e){throw ke.error("got an error listing users"),ke.error(e),yn.errorizeMessage(e)}return null}a(oE,"listUsers");function v2(e){try{if(!e){ke.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(y2)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){ke.error("Got an error trying to set system permissions."),ke.error(t)}}a(v2,"appendSystemTablesToRole");async function gc(){try{let e=await oE();global.hdb_users=e}catch(e){throw ke.error(e),e}}a(gc,"setUsersToGlobal");async function dD(e,t,r=!0){global.hdb_users||await gc();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Fs(new Error,HT.GENERIC_AUTH_FAIL,Gs.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Fs(new Error,HT.USER_INACTIVE,Gs.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(eD.get(t)===n.password)return s;if(FT.validate(n.password,t))eD.set(t,n.password);else throw Fs(new Error,HT.GENERIC_AUTH_FAIL,Gs.UNAUTHORIZED,void 0,void 0,!0)}return s}a(dD,"findAndValidateUser");async function x2(){global.hdb_users||await gc();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(x2,"getSuperUser");async function B2(){let e=await oE(),t=b2.getConfigFromFile(XC.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!yn.isEmpty(r)&&r?.role?.role===XC.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=qT.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+ZC.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+ZC.SERVER_SUFFIX.ADMIN,r}a(B2,"getClusterUser");var _D=[];$T.invalidateUser=function(e){for(let t of _D)try{t(e)}catch(r){N2.error("Error invalidating user",r)}};$T.onInvalidatedUser=function(e){_D.push(e)}});var vu=N((Whe,pD)=>{"use strict";var na=j(),On=M(),H2=$w(),Yhe=Ti(),Khe=Si(),k2=$n(),{validateEvent:ED}=hs(),Uu=Vn(),F2=require("process"),{resetDatabases:G2}=(Ne(),ae(ot)),q2={[On.ITC_EVENT_TYPES.SCHEMA]:V2,[On.ITC_EVENT_TYPES.USER]:mD};async function V2(e){let t=ED(e);if(t){na.error(t);return}na.trace("ITC schemaHandler received schema event:",e),await H2(e.message),await $2(e.message)}a(V2,"schemaHandler");async function $2(e){try{Uu.resetReadTxn(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Uu.resetReadTxn(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Uu.resetReadTxn(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=G2();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){na.error(t)}}a($2,"syncSchemaMetadata");var hD=[];async function mD(e){try{try{Uu.resetReadTxn(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Uu.resetReadTxn(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){na.warn(r)}let t=ED(e);if(t){na.error(t);return}na.trace(`ITC userHandler ${On.HDB_ITC_CLIENT_PREFIX}${F2.pid} received user event:`,e),await k2.setUsersToGlobal();for(let r of hD)r()}catch(t){na.error(t)}}a(mD,"userHandler");mD.addListener=function(e){hD.push(e)};pD.exports=q2});var hs=N((Zhe,TD)=>{"use strict";var zhe=j(),YT=te(),Y2=M(),{ITC_ERRORS:xu}=En(),{parentPort:jhe,threadId:K2,isMainThread:W2,workerData:Jhe}=require("worker_threads"),{onMessageFromWorkers:Q2,broadcast:Xhe,broadcastWithAcknowledgement:z2}=et();TD.exports={sendItcEvent:j2,validateEvent:SD,SchemaEventMsg:J2,UserEventMsg:X2};var aE;Q2(async(e,t)=>{aE=aE||vu(),SD(e),aE[e.type]&&await aE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function j2(e){return!W2&&e.message&&(e.message.originator=K2),z2(e)}a(j2,"sendItcEvent");function SD(e){if(typeof e!="object")return xu.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||YT.isEmpty(e.type))return xu.MISSING_TYPE;if(!e.hasOwnProperty("message")||YT.isEmpty(e.message))return xu.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||YT.isEmpty(e.message.originator))return xu.MISSING_ORIGIN;if(Y2.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return xu.INVALID_EVENT(e.type)}a(SD,"validateEvent");function J2(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(J2,"SchemaEventMsg");function X2(e){this.originator=e}a(X2,"UserEventMsg")});var gi=N((rme,bD)=>{"use strict";var gD=M(),tme=te(),cE=j(),RD=Gw(),Rc,{sendItcEvent:AD}=hs();function Z2(e){try{cE.info("signalSchemaChange called with message:",e),Rc=Rc||vu();let t=new RD(gD.ITC_EVENT_TYPES.SCHEMA,e);return Rc.schema(t),AD(t)}catch(t){cE.error(t)}}a(Z2,"signalSchemaChange");function e4(e){try{cE.trace("signalUserChange called with message:",e),Rc=Rc||vu();let t=new RD(gD.ITC_EVENT_TYPES.USER,e);return Rc.user(t),AD(t)}catch(t){cE.error(t)}}a(e4,"signalUserChange");bD.exports={signalSchemaChange:Z2,signalUserChange:e4}});var lE=N((sme,OD)=>{"use strict";var yD=te(),t4=M(),r4=j(),n4=Ff(),s4=kf(),i4=gi(),{SchemaEventMsg:o4}=hs(),a4="already exists in";OD.exports=c4;async function c4(e,t,r){if(yD.isEmptyOrZeroLength(r))return r;let n=[];yD.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 l4(e,t.schema,t.name,i)})),s}a(c4,"lmdbCheckForNewAttributes");async function l4(e,t,r,n){let s=new s4(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await u4(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(a4))r4.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(l4,"createNewAttribute");async function u4(e){let t;return t=await n4(e),i4.signalSchemaChange(new o4(process.pid,t4.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(u4,"createAttribute")});var Ac=N((ome,ND)=>{"use strict";var KT=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}};ND.exports=KT});var wD=N((cme,ID)=>{"use strict";var d4=Ac(),_4=M().OPERATIONS_ENUM,WT=class extends d4{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(_4.INSERT,r,n,s,i),this.records=t}};ID.exports=WT});var DD=N((ume,CD)=>{"use strict";var f4=Ac(),E4=M().OPERATIONS_ENUM,QT=class extends f4{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(E4.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};CD.exports=QT});var PD=N((_me,LD)=>{"use strict";var h4=Ac(),m4=M().OPERATIONS_ENUM,zT=class extends h4{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(m4.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};LD.exports=zT});var UD=N((Eme,MD)=>{"use strict";var p4=Ac(),S4=M().OPERATIONS_ENUM,jT=class extends p4{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(S4.DELETE,n,s,t,i),this.original_records=r}};MD.exports=jT});var Bu=N((pme,HD)=>{"use strict";var mme=require("path"),vD=Et(),T4=wD(),g4=DD(),R4=PD(),A4=UD(),bc=Gt(),xD=te(),{CONFIG_PARAMS:b4}=M(),BD=ne();BD.initSync();var uE=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:y4}=pt();HD.exports=O4;async function O4(e,t){if(BD.get(b4.LOGGING_AUDITLOG)===!1)return;let r=y4(e.schema,e.table),n=await vD.openEnvironment(r,e.table,!0),s=N4(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){vD.initializeDBIs(n,bc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,bc.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[bc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[bc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),xD.isEmpty(s.user_name)||n.dbis[bc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[bc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(O4,"writeTransaction");function N4(e,t){let r=xD.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===uE.INSERT)return new T4(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===uE.UPDATE)return new g4(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===uE.UPSERT)return new R4(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===uE.DELETE)return new A4(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(N4,"createTransactionObject")});var JT=N((gme,kD)=>{"use strict";var I4=Nu(),Tme=Iu(),Hu=M(),w4=wu(),C4=_c().insertRecords,D4=Et(),L4=j(),P4=lE(),{getSchemaPath:M4}=pt(),U4=Bu();kD.exports=v4;async function v4(e){try{let{schema_table:t,attributes:r}=I4(e);w4(e,r,t.hash_attribute),e.schema!==Hu.SYSTEM_SCHEMA_NAME&&(r.includes(Hu.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Hu.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Hu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Hu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await P4(e.hdb_auth_header,t,r),s=M4(e.schema,e.table),i=await D4.openEnvironment(s,e.table),o=await C4(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await U4(e,o)}catch(c){L4.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(v4,"lmdbCreateRecords")});var qD=N((Ame,GD)=>{"use strict";var FD=M(),x4=JT(),B4=Iu(),H4=require("fs-extra"),{getSchemaPath:k4}=pt();GD.exports=F4;async function F4(e){let t=[{name:e.schema,createddate:Date.now()}],r=new B4(FD.SYSTEM_SCHEMA_NAME,FD.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await x4(r),await H4.mkdirp(k4(e.schema))}a(F4,"lmdbCreateSchema")});var $D=N((yme,VD)=>{"use strict";var XT=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}};VD.exports=XT});var QD=N((Cme,WD)=>{"use strict";var YD=Et(),ZT=hn(),eg=En().LMDB_ERRORS_ENUM,G4=Gt(),KD=j(),Nme=te(),q4=require("lmdb"),V4=$D(),$4=M(),{OVERFLOW_MARKER:Ime,MAX_SEARCH_KEY_LENGTH:wme}=G4,Y4=$4.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function K4(e,t,r,n){if(ZT.validateEnv(e),t===void 0)throw new Error(eg.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(eg.IDS_REQUIRED):new Error(eg.IDS_MUST_BE_ITERABLE);try{let s=YD.listDBIs(e);YD.initializeDBIs(e,t,s);let i=new V4,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[Y4]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,q4.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let g=s[S];if(!h.hasOwnProperty(g)||g===t)continue;let T=e.dbis[g],A=h[g];if(A!=null)try{let I=ZT.getIndexedValues(A);if(I)for(let V=0,x=I.length;V<x;V++)T.remove(I[V],o)}catch{KD.warn(`cannot delete from attribute: ${g}, ${A}:${o}`)}}});c.push(p),l.push(o),i.original_records.push(h)}catch(h){KD.warn(h),i.skipped.push(o)}let d=[],u=await Promise.all(c);for(let E=0,f=u.length;E<f;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),d.push(E));let _=0;for(let E=0;E<d.length;E++){let f=d[E];i.original_records.splice(f-_,1),_++}return i.txn_time=ZT.getNextMonotonicTime(),i}catch(s){throw s}}a(K4,"deleteRecords");WD.exports={deleteRecords:K4}});var ku=N((Lme,jD)=>{"use strict";var yc=te(),W4=QD(),Q4=Et(),{getSchemaPath:z4}=pt(),j4=Bu(),J4=j();jD.exports=X4;async function X4(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(yc.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(yc.isEmptyOrZeroLength(e.hash_values)&&!yc.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];yc.isEmpty(l)||e.hash_values.push(l)}}if(yc.isEmptyOrZeroLength(e.hash_values))return zD([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(yc.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=z4(e.schema,e.table),i=await Q4.openEnvironment(s,e.table),o=await W4.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await j4(e,o)}catch(c){J4.error(`unable to write transaction due to ${c.message}`)}return zD(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(X4,"lmdbDeleteRecords");function zD(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(zD,"createDeleteResponse")});var rg=N((Ume,JD)=>{"use strict";var Z4=M(),Mme=hn();function tg(e,t){let r=Object.create(null);if(t.length===1&&Z4.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(tg,"parseRow");function eJ(e,t,r,n){let s=tg(r,e);n.push(s)}a(eJ,"searchAll");function tJ(e,t,r,n){let s=tg(r,e);n[t]=s}a(tJ,"searchAllToMap");function rJ(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(rJ,"iterateDBI");function sa(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(sa,"pushResults");function nJ(e,t,r,n,s,i){t.toString().endsWith(e)&&sa(t,r,n,s,i)}a(nJ,"endsWith");function sJ(e,t,r,n,s,i){t.toString().includes(e)&&sa(t,r,n,s,i)}a(sJ,"contains");function iJ(e,t,r,n,s,i){t>e&&sa(t,r,n,s,i)}a(iJ,"greaterThanCompare");function oJ(e,t,r,n,s,i){t>=e&&sa(t,r,n,s,i)}a(oJ,"greaterThanEqualCompare");function aJ(e,t,r,n,s,i){t<e&&sa(t,r,n,s,i)}a(aJ,"lessThanCompare");function cJ(e,t,r,n,s,i){t<=e&&sa(t,r,n,s,i)}a(cJ,"lessThanEqualCompare");JD.exports={parseRow:tg,searchAll:eJ,searchAllToMap:tJ,iterateDBI:rJ,endsWith:nJ,contains:sJ,greaterThanCompare:iJ,greaterThanEqualCompare:oJ,lessThanCompare:aJ,lessThanEqualCompare:cJ,pushResults:sa}});var Oc=N((kme,sL)=>{"use strict";var co=Et(),xme=j(),Nn=hn(),dE=Gt(),qt=En().LMDB_ERRORS_ENUM,Bme=te(),lJ=M(),_E=rg(),{parseRow:uJ}=_E,Hme=require("lmdb"),{OVERFLOW_MARKER:XD,MAX_SEARCH_KEY_LENGTH:dJ}=dE;function ZD(e,t,r,n=!1,s=void 0,i=void 0){return ia(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(ZD,"iterateFullIndex");function Fu(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,d=!1){return ia(e,t,r,(u,_,E,f)=>{let T={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!d,exclusiveStart:i===!0?d:l};return f===r?(T.values=!1,_.getRange(T).map(A=>({value:A}))):_.getRange(T)})}a(Fu,"iterateRangeBetween");function ia(e,t,r,n){let s=e.database||e,i=co.openDBI(s,r);i[dE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&co.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(ia,"setupTransaction");function eL(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(XD)){if(!s)if(r)s=co.openDBI(e,r);else{let l=co.listDBIs(e);for(let d=0,u=l.length;d<u&&(s=co.openDBI(e,l[d]),!s[dE.DBI_DEFINITION_NAME].is_hash_attribute);d++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(eL,"getOverflowCheck");function _J(e,t,r,n=!1,s=void 0,i=void 0){if(Nn.validateEnv(e),t===void 0)throw new Error(qt.HASH_ATTRIBUTE_REQUIRED);return ia(e,t,t,(o,c,l)=>(fE(r),r=Gu(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(d=>uJ(d.value,r))))}a(_J,"searchAll");function fJ(e,t,r,n=!1,s=void 0,i=void 0){if(Nn.validateEnv(e),t===void 0)throw new Error(qt.HASH_ATTRIBUTE_REQUIRED);fE(r),r=Gu(e.database||e,r);let o=new Map;for(let{key:c,value:l}of ZD(e,t,t,n,s,i))o.set(c,_E.parseRow(l,r));return o}a(fJ,"searchAllToMap");function EJ(e,t,r=!1,n=void 0,s=void 0){if(Nn.validateEnv(e),t===void 0)throw new Error(qt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=ZD(e,void 0,t,r,n,s),c=o.transaction,l=eL(c.database,c,void 0,t);for(let{key:d,value:u}of o){let _=l(d,u);i[_]===void 0&&(i[_]=[]),i[_].push(u)}return i}a(EJ,"iterateDBI");function hJ(e,t){if(Nn.validateEnv(e),t===void 0)throw new Error(qt.HASH_ATTRIBUTE_REQUIRED);return co.statDBI(e,t).entryCount}a(hJ,"countAll");function mJ(e,t,r,n,s=!1,i=void 0,o=void 0){return lo(e,r,n),ia(e,t,r,(c,l,d,u)=>(n=Nn.convertKeyValueToWrite(n),u===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(_=>({key:n,value:_}))))}a(mJ,"equals");function pJ(e,t,r){return lo(e,t,r),co.openDBI(e,t).getValuesCount(r)}a(pJ,"count");function SJ(e,t,r,n,s=!1,i=void 0,o=void 0){return lo(e,r,n),ia(e,null,r,(c,l)=>{n=Nn.convertKeyValueToWrite(n);let d=!0;typeof n=="number"&&(d=!1);let u;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(d===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(d===!0)return u.DONE}),d?u:u.filter(_=>_)})}a(SJ,"startsWith");function TJ(e,t,r,n,s=!1,i=void 0,o=void 0){return tL(e,t,r,n,s,i,o,!0)}a(TJ,"endsWith");function tL(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return lo(e,r,n),ia(e,null,r,(l,d,u,_)=>{let E=eL(u,l,_,r);return o=Number.isInteger(o)?o:0,d.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(XD)?d.getValues(f,{transaction:l}).map(p=>{let S=E(f,p);if(c?S.endsWith(n):S.includes(n))return{key:S,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?d[dE.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:d.getValues(f,{transaction:l}).map(p=>({key:f,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(tL,"contains");function gJ(e,t,r,n,s=!1,i=void 0,o=void 0){lo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Fu(e,t,r,n,l,s,i,o,!0,!1)}a(gJ,"greaterThan");function RJ(e,t,r,n,s=!1,i=void 0,o=void 0){lo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Fu(e,t,r,n,l,s,i,o,!1,!1)}a(RJ,"greaterThanEqual");function AJ(e,t,r,n,s=!1,i=void 0,o=void 0){lo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Fu(e,t,r,l,n,s,i,o,!1,!0)}a(AJ,"lessThan");function bJ(e,t,r,n,s=!1,i=void 0,o=void 0){lo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Fu(e,t,r,l,n,s,i,o,!1,!1)}a(bJ,"lessThanEqual");function yJ(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Nn.validateEnv(e),r===void 0)throw new Error(qt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(qt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(qt.END_VALUE_REQUIRED);if(n=Nn.convertKeyValueToWrite(n),s=Nn.convertKeyValueToWrite(s),n>s)throw new Error(qt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Fu(e,t,r,n,s,i,o,c)}a(yJ,"between");function OJ(e,t,r,n){Nn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(qt.HASH_ATTRIBUTE_REQUIRED);if(fE(r),r=Gu(s,r),n===void 0)throw new Error(qt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=_E.parseRow(c,r)),o}a(OJ,"searchByHash");function NJ(e,t,r){Nn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(qt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(qt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(NJ,"checkHashExists");function IJ(e,t,r,n,s=[]){return nL(e,t,r,n,s),rL(e,t,r,n,s).map(i=>i[1])}a(IJ,"batchSearchByHash");function wJ(e,t,r,n,s=[]){nL(e,t,r,n,s);let i=new Map;for(let[o,c]of rL(e,t,r,n,s))i.set(o,c);return i}a(wJ,"batchSearchByHashToMap");function rL(e,t,r,n,s=[]){return ia(e,t,t,(i,o,c)=>{r=Gu(c,r);let l=r.length<3;return n.map(d=>{let u=c.dbis[t].get(d,{transaction:i,lazy:l});if(u)return[d,_E.parseRow(u,r)];s.push(d)}).filter(d=>d)})}a(rL,"batchHashSearch");function nL(e,t,r,n,s){if(Nn.validateEnv(e),t===void 0)throw new Error(qt.HASH_ATTRIBUTE_REQUIRED);if(fE(r),n==null)throw new Error(qt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(qt.IDS_MUST_BE_ITERABLE)}a(nL,"initializeBatchSearchByHash");function fE(e){if(!Array.isArray(e))throw e===void 0?new Error(qt.FETCH_ATTRIBUTES_REQUIRED):new Error(qt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(fE,"validateFetchAttributes");function lo(e,t,r){if(Nn.validateEnv(e),t===void 0)throw new Error(qt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(qt.SEARCH_VALUE_REQUIRED);if(r?.length>dJ)throw new Error(qt.SEARCH_VALUE_TOO_LARGE)}a(lo,"validateComparisonFunctions");function Gu(e,t){return t.length===1&&lJ.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=co.listDBIs(e)),t}a(Gu,"setGetWholeRowAttributes");sL.exports={searchAll:_J,searchAllToMap:fJ,count:pJ,countAll:hJ,equals:mJ,startsWith:SJ,endsWith:TJ,contains:tL,searchByHash:OJ,setGetWholeRowAttributes:Gu,batchSearchByHash:IJ,batchSearchByHashToMap:wJ,checkHashExists:NJ,iterateDBI:EJ,greaterThan:gJ,greaterThanEqual:RJ,lessThan:AJ,lessThanEqual:bJ,between:yJ}});var Nc=N((Gme,lL)=>{var iL=require("lodash"),oL=ct(),Le=require("joi"),CJ=te(),{hdb_schema_table:qu,checkValidTable:aL,hdb_table:cL,hdb_database:EE}=Bs(),{handleHDBError:DJ,hdb_errors:LJ}=ce(),{getDatabases:PJ}=(Ne(),ae(ot)),{HTTP_STATUS_CODES:MJ}=LJ,UJ=Le.object({database:EE,schema:EE,table:cL,search_attribute:qu,search_value:Le.any().required(),get_attributes:Le.array().min(1).items(Le.alternatives(qu,Le.object())).optional(),desc:Le.bool(),limit:Le.number().integer().min(1),offset:Le.number().integer().min(0)}),vJ=Le.object({database:EE,schema:EE,table:cL,operator:Le.string().valid("and","or").default("and").lowercase(),offset:Le.number().integer().min(0),limit:Le.number().integer().min(1),get_attributes:Le.array().min(1).items(Le.alternatives(qu,Le.object())).optional(),sort:Le.object({attribute:Le.alternatives(qu,Le.array().min(1)),descending:Le.bool().optional()}).optional(),conditions:Le.array().min(1).items(Le.alternatives(Le.object({operator:Le.string().valid("and","or").default("and").lowercase(),conditions:Le.array()}),Le.object({search_attribute:Le.alternatives(qu,Le.array().min(1)),search_type:Le.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:Le.when("search_type",{switch:[{is:"equals",then:Le.any()},{is:"between",then:Le.array().items(Le.alternatives([Le.string(),Le.number()])).length(2)}],otherwise:Le.alternatives(Le.string(),Le.number())}).required()}))).required()});lL.exports=function(e,t){let r=null;switch(t){case"value":r=oL.validateBySchema(e,UJ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(aL("database",e.schema)),i(aL("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=oL.validateBySchema(e,vJ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=CJ.checkGlobalSchemaTable(e.schema,e.table);if(s)return DJ(new Error,s,MJ.NOT_FOUND);let o=PJ()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let _=0,E=u.conditions.length;_<E;_++){let f=u.conditions[_];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let d=iL.filter(c,u=>u!=="*"&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!iL.some(o,_=>_===u||_.attribute===u||_.attribute===u.attribute));if(d&&d.length>0){let u=d.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var ng=N((Vme,uL)=>{"use strict";var xJ=Et(),BJ=Nc(),{getSchemaPath:HJ}=pt();uL.exports=kJ;function kJ(e){let t=BJ(e,"hashes");if(t)throw t;let r=HJ(e.schema,e.table);return xJ.openEnvironment(r,e.table)}a(kJ,"initialize")});var sg=N((Yme,dL)=>{"use strict";var FJ=Oc(),GJ=ng();dL.exports=qJ;async function qJ(e){let t=await GJ(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return FJ.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(qJ,"lmdbGetDataByHash")});var Ic=N((Wme,_L)=>{"use strict";var ig=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};_L.exports=ig});var EL=N((jme,fL)=>{"use strict";var zme=Ic(),VJ=Oc(),$J=ng();fL.exports=YJ;async function YJ(e){let t=await $J(e),r=global.hdb_schema[e.schema][e.table];return VJ.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(YJ,"lmdbSearchByHash")});var qs=N((Xme,hL)=>{"use strict";var og=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,d=void 0,u=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=d,this.offset=u}};hL.exports=og});var hE=N((epe,RL)=>{"use strict";var vr=Oc(),KJ=Et(),WJ=te(),Pe=Gt(),oa=M(),QJ=Qo(),mL=En().LMDB_ERRORS_ENUM,{getSchemaPath:zJ}=pt(),Ri=oa.SEARCH_WILDCARDS;async function jJ(e,t,r){let n;e.schema===oa.SYSTEM_SCHEMA_NAME?n=QJ[e.table]:n=global.hdb_schema[e.schema][e.table];let s=gL(e,n.hash_attribute,r,t);return SL(e,s,n.hash_attribute,r)}a(jJ,"prepSearch");async function SL(e,t,r,n){let s=zJ(e.schema,e.table),i=await KJ.openEnvironment(s,e.table),o=TL(i,e,t,r),c=o.transaction||i;if([Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Pe.SEARCH_TYPES.SEARCH_ALL,Pe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(JJ(e,r)===!1){let u=e.search_attribute;if(u===r)return n?pL(o,()=>!0):o.map(E=>({[r]:E.key}));let _=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?pL(o,_):o.map(_)}let d=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?vr.batchSearchByHashToMap(c,r,e.get_attributes,d):vr.batchSearchByHash(c,r,e.get_attributes,d)}a(SL,"executeSearch");function TL(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 Pe.SEARCH_TYPES.EQUALS:s=vr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.CONTAINS:s=vr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.ENDS_WITH:case Pe.SEARCH_TYPES._ENDS_WITH:s=vr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.STARTS_WITH:case Pe.SEARCH_TYPES._STARTS_WITH:s=vr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return vr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return vr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Pe.SEARCH_TYPES.SEARCH_ALL:return vr.searchAll(e,n,t.get_attributes,o,c,l);case Pe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return vr.searchAllToMap(e,n,t.get_attributes,o,c,l);case Pe.SEARCH_TYPES.BETWEEN:s=vr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case Pe.SEARCH_TYPES.GREATER_THAN:case Pe.SEARCH_TYPES._GREATER_THAN:s=vr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.GREATER_THAN_EQUAL:case Pe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=vr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.LESS_THAN:case Pe.SEARCH_TYPES._LESS_THAN:s=vr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Pe.SEARCH_TYPES.LESS_THAN_EQUAL:case Pe.SEARCH_TYPES._LESS_THAN_EQUAL:s=vr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(TL,"searchByType");function pL(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(pL,"createMapFromIterable");function JJ(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(JJ,"checkToFetchMore");function gL(e,t,r,n){if(WJ.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),Ri.indexOf(s)>-1)return r===!0?Pe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Pe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Ri[0])<0&&s.indexOf(Ri[1])<0)return c===!0?r===!0?Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Pe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Pe.SEARCH_TYPES.EQUALS;if(Ri.indexOf(i)>=0&&Ri.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Pe.SEARCH_TYPES.CONTAINS;if(Ri.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Pe.SEARCH_TYPES.ENDS_WITH;if(Ri.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Pe.SEARCH_TYPES.STARTS_WITH;if(s.includes(Ri[0])||s.includes(Ri[1]))return Pe.SEARCH_TYPES.EQUALS;throw new Error(mL.UNKNOWN_SEARCH_TYPE)}else switch(n){case oa.VALUE_SEARCH_COMPARATORS.BETWEEN:return Pe.SEARCH_TYPES.BETWEEN;case oa.VALUE_SEARCH_COMPARATORS.GREATER:return Pe.SEARCH_TYPES.GREATER_THAN;case oa.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Pe.SEARCH_TYPES.GREATER_THAN_EQUAL;case oa.VALUE_SEARCH_COMPARATORS.LESS:return Pe.SEARCH_TYPES.LESS_THAN;case oa.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Pe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(mL.UNKNOWN_SEARCH_TYPE)}}a(gL,"createSearchTypeFromSearchObject");RL.exports={executeSearch:SL,createSearchTypeFromSearchObject:gL,prepSearch:jJ,searchByType:TL}});var bL=N((npe,AL)=>{"use strict";var rpe=qs(),XJ=Nc(),ZJ=te(),e3=M(),t3=hE();AL.exports=r3;function r3(e,t){if(!ZJ.isEmpty(t)&&e3.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=XJ(e,"value");if(n)throw n;return t3.prepSearch(e,t,!0)}a(r3,"lmdbGetDataByValue")});var Vu=N((ope,yL)=>{"use strict";var ipe=qs(),n3=Nc(),s3=te(),i3=M(),o3=hE();yL.exports=a3;async function a3(e,t){if(!s3.isEmpty(t)&&i3.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=n3(e,"value");if(n)throw n;return o3.prepSearch(e,t,!1)}a(a3,"lmdbSearchByValue")});var NL=N((lpe,OL)=>{"use strict";var cpe=Gt(),ag=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}},cg=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},lg=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};OL.exports={SearchByConditionsObject:ag,SearchCondition:cg,SortAttribute:lg}});var LL=N((fpe,DL)=>{"use strict";var dpe=NL().SearchByConditionsObject,c3=qs(),l3=Nc(),ug=Oc(),mE=Gt(),{Resource:_pe}=(us(),ae(dg)),CL=hE(),u3=rg(),d3=require("lodash"),{getSchemaPath:_3}=pt(),IL=Et(),{handleHDBError:f3,hdb_errors:E3}=ce(),{HTTP_STATUS_CODES:h3}=E3,m3=1e8;DL.exports=p3;async function p3(e){let t=l3(e,"conditions");if(t)throw f3(t,t.message,h3.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=_3(e.schema,e.table),n=await IL.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let d of e.conditions)IL.openDBI(n,d.search_attribute);let i=d3.sortBy(e.conditions,d=>{if(d.estimated_count===void 0){let u=d.search_type;u===mE.SEARCH_TYPES.EQUALS?d.estimated_count=ug.count(n,d.search_attribute,d.search_value):u===mE.SEARCH_TYPES.CONTAINS||u===mE.SEARCH_TYPES.ENDS_WITH?d.estimated_count=1/0:d.estimated_count=m3}return d.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await wL(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let d=n.dbis[s.hash_attribute],u=i.slice(1).map(CL.filterByType),_=u.length,E=ug.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>d.get(f,{transaction:o,lazy:!0})),_>0&&(l=l.filter(f=>{for(let h=0;h<_;h++)if(!u[h](f))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(f=>u3.parseRow(f,E))}else{for(let _=1;_<i.length;_++){let E=i[_],f=await wL(o,e,E,s.hash_attribute);c=c.concat(f)}let d=new Set,u=e.offset||0;c=c.filter(_=>d.has(_)?!1:(d.add(_),!0)).slice(u,e.limit&&e.limit+u),l=ug.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(p3,"lmdbSearchByConditions");async function wL(e,t,r,n){let s=new c3(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===mE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,CL.searchByType(e,s,i,n).map(o=>o.value)}a(wL,"executeConditionSearch")});var wc=N((hpe,PL)=>{"use strict";var S3=M().OPERATIONS_ENUM,_g=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=S3.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};PL.exports=_g});var fg=N((ppe,FL)=>{"use strict";var xL=qs(),BL=wc(),HL=Vu(),kL=ku(),Kr=M(),ML=te(),UL=Et(),{getTransactionAuditStorePath:T3,getSchemaPath:g3}=pt(),vL=j();FL.exports=R3;async function R3(e){try{if(ML.isEmpty(global.hdb_schema[e.schema])||ML.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await A3(e),await b3(e);let t=g3(e.schema,e.table);try{await UL.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")vL.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=T3(e.schema,e.table);await UL.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")vL.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(R3,"lmdbDropTable");async function A3(e){let t=new xL(Kr.SYSTEM_SCHEMA_NAME,Kr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await HL(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 BL(Kr.SYSTEM_SCHEMA_NAME,Kr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await kL(s)}a(A3,"deleteAttributesFromSystem");async function b3(e){let t=new xL(Kr.SYSTEM_SCHEMA_NAME,Kr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Kr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await HL(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 BL(Kr.SYSTEM_SCHEMA_NAME,Kr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await kL(s)}catch(i){throw i}}a(b3,"dropTableFromSystem")});var qL=N((Tpe,GL)=>{"use strict";var y3=require("fs-extra"),O3=qs(),N3=Ic(),I3=wc(),w3=fg(),C3=ku(),D3=sg(),L3=Vu(),Ai=M(),{getSchemaPath:P3}=pt(),{handleHDBError:M3,hdb_errors:U3}=ce(),{HDB_ERROR_MSGS:v3,HTTP_STATUS_CODES:x3}=U3;GL.exports=B3;async function B3(e){let t;try{t=await H3(e.schema);let r=new O3(Ai.SYSTEM_SCHEMA_NAME,Ai.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ai.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ai.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await L3(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await w3(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new I3(Ai.SYSTEM_SCHEMA_NAME,Ai.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await C3(s);let i=P3(t);await y3.remove(i)}catch(r){throw r}}a(B3,"lmdbDropSchema");async function H3(e){let t=new N3(Ai.SYSTEM_SCHEMA_NAME,Ai.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ai.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await D3(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw M3(new Error,v3.SCHEMA_NOT_FOUND(e),x3.NOT_FOUND,void 0,void 0,!0);return n}a(H3,"validateDropSchema")});var pE=N((Rpe,VL)=>{"use strict";var Eg=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};VL.exports=Eg});var YL=N((ype,$L)=>{"use strict";var k3=require("fs-extra"),SE=Et(),{getTransactionAuditStorePath:F3}=pt(),hg=Gt(),bpe=pE();$L.exports=G3;async function G3(e){let t;try{let r=F3(e.schema,e.table);await k3.mkdirp(r),t=await SE.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{SE.createDBI(t,hg.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),SE.createDBI(t,hg.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),SE.createDBI(t,hg.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(G3,"createTransactionsAuditEnvironment")});var QL=N((Ipe,WL)=>{"use strict";var mg=M(),KL=Et(),q3=_c(),{getSystemSchemaPath:V3,getSchemaPath:$3}=pt(),Npe=Qo(),Y3=Ff(),pg=kf(),K3=j(),W3=YL();WL.exports=Q3;async function Q3(e,t){let r=$3(t.schema,t.table),n=new pg(t.schema,t.table,mg.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new pg(t.schema,t.table,mg.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new pg(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await KL.createEnvironment(r,t.table),e!==void 0){let o=await KL.openEnvironment(V3(),mg.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await q3.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 Sg(n),await Sg(s),await Sg(i)}await W3(t)}catch(o){throw o}}a(Q3,"lmdbCreateTable");async function Sg(e){try{await Y3(e)}catch(t){K3.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Sg,"createAttribute")});var jL=N((Cpe,zL)=>{"use strict";var z3=Nu(),j3=wu(),J3=lE(),$u=M(),X3=_c().updateRecords,Z3=Et(),{getSchemaPath:eX}=pt(),tX=Bu(),rX=j();zL.exports=nX;async function nX(e){try{let{schema_table:t,attributes:r}=z3(e);j3(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 J3(e.hdb_auth_header,t,r),s=eX(e.schema,e.table),i=await Z3.openEnvironment(s,e.table),o=await X3(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await tX(e,o)}catch(c){rX.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(nX,"lmdbUpdateRecords")});var XL=N((Lpe,JL)=>{"use strict";var sX=M().OPERATIONS_ENUM,Tg=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=sX.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};JL.exports=Tg});var eP=N((Upe,ZL)=>{"use strict";var Mpe=XL(),iX=Nu(),oX=wu(),aX=lE(),Yu=M(),cX=_c().upsertRecords,lX=Et(),{getSchemaPath:uX}=pt(),dX=Bu(),_X=j(),{handleHDBError:fX,hdb_errors:EX}=ce();ZL.exports=hX;async function hX(e){let t;try{t=iX(e)}catch(l){throw fX(l,l.message,EX.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;oX(e,n,r.hash_attribute),e.schema!==Yu.SYSTEM_SCHEMA_NAME&&(n.includes(Yu.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Yu.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Yu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Yu.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await aX(e.hdb_auth_header,r,n),i=uX(e.schema,e.table),o=await lX.openEnvironment(i,e.table),c=await cX(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await dX(e,c)}catch(l){_X.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(hX,"lmdbUpsertRecords")});var rP=N((xpe,tP)=>{"use strict";var gg=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};tP.exports=gg});var sP=N((Hpe,nP)=>{"use strict";var Rg=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}};nP.exports=Rg});var aP=N((Gpe,oP)=>{"use strict";var Ag=Et(),{getTransactionAuditStorePath:mX}=pt(),Fpe=rP(),Ku=Gt(),pX=te(),iP=sP(),SX=require("util").promisify,TX=SX(setTimeout),gX=1e4,RX=100;oP.exports=AX;async function AX(e){let t=mX(e.schema,e.table),r=await Ag.openEnvironment(t,e.table,!0),n=Ag.listDBIs(r);Ag.initializeDBIs(r,Ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new iP;do s=await bX(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 TX(RX);while(s.transactions_deleted>0);return i}a(AX,"deleteAuditLogsBefore");async function bX(e,t){let r=new iP;try{let n=e.dbis[Ku.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[Ku.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];pX.isEmpty(c)||(s=e.dbis[Ku.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[Ku.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>gX)break}return await s,r}catch(n){throw n}}a(bX,"deleteTransactions")});var lP=N((Vpe,cP)=>{"use strict";var bg=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};cP.exports=bg});var dP=N((Kpe,uP)=>{"use strict";var yX=qs(),OX=wc(),Ype=lP(),Vs=M(),NX=te(),yg=Et(),IX=Qo(),wX=Vu(),CX=ku(),{getSchemaPath:DX}=pt();uP.exports=LX;async function LX(e,t=!0){let r;e.schema===Vs.SYSTEM_SCHEMA_NAME?r=IX[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await MX(e),s=DX(e.schema,e.table),i=await yg.openEnvironment(s,e.table);return t===!0&&await PX(e,i,r.hash_attribute),yg.dropDBI(i,e.attribute),n}a(LX,"lmdbDropAttribute");async function PX(e,t,r){let n=yg.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let d={};for(let u in c)u!==i&&(d[u]=c[u]);s=t.dbis[r].put(o,d,l)}await s}a(PX,"removeAttributeFromAllObjects");async function MX(e){let t=new yX(Vs.SYSTEM_SCHEMA_NAME,Vs.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Vs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Vs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Vs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await wX(t)).filter(o=>o[Vs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(NX.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Vs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new OX(Vs.SYSTEM_SCHEMA_NAME,Vs.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return CX(i)}a(MX,"dropAttributeFromSystem")});var pP=N((zpe,mP)=>{"use strict";var Og=Et(),Cc=Gt(),Qpe=hn(),Ng=M(),_P=te(),{getTransactionAuditStorePath:UX}=pt(),vX=Oc(),TE=Ac(),xX=j();mP.exports=BX;async function BX(e){let t=UX(e.schema,e.table),r=await Og.openEnvironment(t,e.table,!0),n=Og.listDBIs(r);Og.initializeDBIs(r,Cc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Ng.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return fP(r,e.search_values);case Ng.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,kX(r,e.search_values,s);case Ng.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return HX(r,e.search_values);default:return fP(r)}}a(BX,"readAuditLog");function fP(e,t=[0,Date.now()]){_P.isEmpty(t[0])&&(t[0]=0),_P.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Cc.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 TE,s))}a(fP,"searchTransactionsByTimestamp");function HX(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[Cc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,hP(e,i))}return Object.fromEntries(r)}a(HX,"searchTransactionsByUsername");function kX(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let d=t[c],u=vX.equals(e,Cc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Cc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,d);for(let{value:_}of u){let E=Number(_);n.has(E)?n.get(E).push(d.toString()):n.set(E,[d.toString()])}}let s=Array.from(n.keys()),i=hP(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],d=l.timestamp,u=n.get(d);EP(l,"records",r,u,o),EP(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(kX,"searchTransactionsByHashValues");function EP(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 d=s.get(l),u=d[d.length-1];if(u.timestamp===i)u[t]=[c];else{let _=new TE(e.operation,e.user_name,i,void 0);_[t]=[c],d.push(_)}}else{let d=new TE(e.operation,e.user_name,i,void 0);d[t]=[c],s.set(l,[d])}}}a(EP,"loopRecords");function hP(e,t){let r=[];try{let n=e.dbis[Cc.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 TE,i);r.push(o)}}catch(i){xX.warn(i)}return r}catch(n){throw n}}a(hP,"batchSearchTransactions")});var TP=N((Zpe,SP)=>{"use strict";var{getSchemaPath:Jpe}=pt(),Xpe=Et(),{database:FX}=(Ne(),ae(ot));SP.exports={writeTransaction:GX};async function GX(e,t,r){return FX({database:e,table:t}).transaction(r)}a(GX,"writeTransaction")});var bP=N((tSe,AP)=>{"use strict";var{getSchemaPath:gP}=pt(),RP=Et();AP.exports={flush:qX,resetReadTxn:VX};async function qX(e,t){return(await RP.openEnvironment(gP(e,t),t.toString())).flushed}a(qX,"flush");async function VX(e,t){try{(await RP.openEnvironment(gP(e,t),t.toString())).resetReadTxn()}catch{}}a(VX,"resetReadTxn")});var IP=N((nSe,NP)=>{"use strict";var{Readable:$X}=require("stream"),{getDatabases:YX}=(Ne(),ae(ot)),{readSync:KX,openSync:WX,createReadStream:yP}=require("fs"),{open:QX}=require("lmdb"),OP=Tu(),zX=gu(),{AUDIT_STORE_OPTIONS:jX}=(Ei(),ae(wP)),{INTERNAL_DBIS_NAME:JX,AUDIT_STORE_NAME:XX}=Gt();NP.exports=eZ;var Ig=32768,ZX=100;async function eZ(e){let t=e.database||e.schema||"data",r=YX()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let d=r[s[0]];if(!d)throw new Error(`Can not find table ${s[0]}`);let u=d.dbisDB,_=QX({noSync:!0,maxDbs:zX.MAX_DBS}),E,f=_.openDB(JX,new OP(!1)),h=u.useReadTransaction(),p=0,S=a(async function(T,A){A.encoding="binary",A.encoder=void 0;let I=_.openDB(T,A),V=u.openDB(T,A);for(let{key:x,version:X,value:$}of V.getRange({start:null,transaction:h,versions:V.useVersions}))E=I.put(x,$,X),p++%ZX===0&&(await new Promise(F=>setTimeout(F,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:T,value:A}of u.getRange({transaction:h,start:!1}))if(s.some(I=>T.startsWith?.(I+"/"))){f.put(T,A);let[,I]=T.split("/"),V=!I,x=new OP(!V,V);await S(T,x)}e.include_audit&&await S(XX,Object.assign({},jX)),await E;let g=yP(_.path);return g.headers=l(),g.on("close",()=>{h.done(),_.close()}),g}let o=r[Object.keys(r)[0]].primaryStore,c=WX(o.path);return o.transaction(()=>{let d=Buffer.alloc(Ig);KX(c,d,0,Ig),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let _=yP(null,{fd:c,start:Ig}),E=new $X.from(async function*(){yield d;for await(let f of _)u.openTimer&&(u.openTimer=0),yield f;u.done()}());return E.headers=l(),E});function l(){let d=new Map;return d.set("content-type","application/octet-stream"),d.set("content-disposition",`attachment; filename="${t}"`),d.set("date",n),d}}a(eZ,"getBackup")});var LP=N((iSe,DP)=>{"use strict";var tZ=j(),{handleHDBError:rZ}=ce(),nZ=$I(),sZ=Ff(),iZ=JT(),oZ=qD(),aZ=ku(),cZ=sg(),lZ=EL(),uZ=bL(),dZ=Vu(),_Z=LL(),fZ=qL(),EZ=QL(),hZ=jL(),mZ=eP(),pZ=aP(),SZ=fg(),TZ=dP(),gZ=pP(),RZ=TP(),CP=bP(),AZ=IP(),wg=class extends nZ{static{a(this,"LMDBBridge")}async searchByConditions(t){return _Z(t)}async getDataByHash(t){return await cZ(t)}async searchByHash(t){return await lZ(t)}async getDataByValue(t,r){return await uZ(t,r)}async searchByValue(t){return await dZ(t)}async createSchema(t){return await oZ(t)}async dropSchema(t){return await fZ(t)}async createTable(t,r){return await EZ(t,r)}async dropTable(t){return await SZ(t)}async createAttribute(t){return await sZ(t)}async createRecords(t){return await iZ(t)}async updateRecords(t){return await hZ(t)}async upsertRecords(t){try{return await mZ(t)}catch(r){throw rZ(r,null,null,tZ.ERR,r)}}async deleteRecords(t){return await aZ(t)}async dropAttribute(t){return await TZ(t)}async deleteAuditLogsBefore(t){return await pZ(t)}async readAuditLog(t){return await gZ(t)}writeTransaction(t,r,n){return RZ.writeTransaction(t,r,n)}flush(t,r){return CP.flush(t,r)}resetReadTxn(t,r){return CP.resetReadTxn(t,r)}getBackup(t){return AZ(t)}};DP.exports=wg});function kP(e){Dg=e}function NZ(){OZ=setInterval(function(){for(let e of Cg)if(e.stale){let t=e[Me]?.url;vP.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},yZ).unref()}var Lg,UP,vP,xP,BP,HP,PP,Cg,bZ,Wu,MP,Dg,aa,gE,yZ,OZ,RE=Oe(()=>{Lg=v(hn()),UP=v(ce()),vP=v(j());us();xP=v(ne()),BP=v(M()),HP=v(te()),PP=100,Cg=new Set,bZ=(0,HP.convertToMS)(xP.get(BP.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(kP,"replicationConfirmation");aa=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxnsUsed=1,this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxn.openTimer&&(this.readTxn.openTimer=0),Cg.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(Cg.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(Wu&&!this.overloadChecked&&performance.now()-MP>bZ)throw new UP.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=t.timestamp||(0,Lg.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let _=this.validated;this.validated=this.writes.length;for(let f=_;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=_;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let p=_;p<this.validated;p++){let S=this.writes[p];if(!S)continue;let g=S[f===0?"before":"beforeIntermediate"];if(g){let T=g();h?h.push?h.push(T):h=[h,T]:h=T}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(_){throw this.abort(),_}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(_=>_);let c=a(_=>{_.commit(r,_.entry,n)},"doWrite"),l=a(()=>{let _=this.writes[o++];if(_)if(_.key){n>0&&(_.entry=_.store.getEntry(_.key));let E=_.store.ifVersion(_.key,_.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),d=this.lmdbDb;if(this.writes.length>0&&(d?.retryRisk&&(d.retryRisk*=.99),this.writes.length+(d?.retryRisk||0)<PP>>n?l():s=this.writes[0].store.transaction(()=>{for(let _ of this.writes)_.entry=_.store.getEntry(_.key),c(_);return!0})),s)return Wu||(Wu=s,MP=performance.now(),Wu.then(()=>{Wu=null})),s.then(_=>{if(_){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let E=this.writes[0].store.rootStore.databaseName,f=this.writes[this.writes.length-1];Dg&&f&&i.push(Dg(E,f.store.getEntry(f.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return d&&(d.retryRisk=(d.retryRisk||0)+PP/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let u={txnTime:r};if(this.next){let _=this.next?.commit(t);if(_?.then)return _?.then(E=>({txnTime:r,next:E}));u.next=_}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},gE=class extends aa{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,Lg.getNextMonotonicTime)())}getReadTxn(){}},yZ=3e4;a(NZ,"startMonitoringTxns");NZ()});function gt(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 aa;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[Me]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var FP,ca=Oe(()=>{FP=require("../index");us();RE();a(gt,"transaction");(0,FP._assignPackageExport)("transaction",gt);gt.commit=function(e){let t=(e[Me]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};gt.abort=function(e){let t=(e[Me]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var zP={};Ze(zP,{ResourceBridge:()=>Ug});function vg({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 qP(e,t){let r=$s(e),n=vg(e,r);if(!r)throw new ms.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user},o;gt(i,()=>new Promise(d=>o=d));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let d=c[l++],u=await r.get({id:d,lazy:s,select:n},i);return u=u&&bE(u),t?{value:{key:d,value:u}}:{value:u}}else return o(),{done:!0}},return(d){return o(),{value:d,done:!0}},throw(d){return o(),{done:!0}}}}}}function $s(e){let t=e.database||e.schema||wZ,r=ut()[t];if(!r)throw(0,ms.handleHDBError)(new Error,IZ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function VP(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*$P(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:d,value:u}=o;if(s?.timestamp===d)s.hash_values.push(l),s.records.push(u);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:d,hash_values:[l],records:[u]}}}s&&(yield s)}var YP,AE,ms,KP,WP,ps,Pg,Mg,QP,IZ,wZ,CZ,DZ,GP,Ug,jP=Oe(()=>{"use strict";YP=v(LP()),AE=v(Nc()),ms=v(ce());Ne();KP=v(Nu()),WP=v(wu()),ps=v(M()),Pg=v(gi()),Mg=v(hs()),QP=v(te());ca();yE();({HDB_ERROR_MSGS:IZ}=ms.hdb_errors),wZ="data",CZ=1e4,DZ=10,Ug=class extends YP.default{static{a(this,"ResourceBridge")}constructor(t){super(t),GP=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,AE.default)(t,"conditions");if(r)throw(0,ms.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=$s(t);if(!n)throw new ms.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:vg(t,n),sort:t.sort,allowFullScan:!0})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new ms.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})}async createAttribute(t){return await $s(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=$s(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(d=>{if(!d){let{value:u,version:_}=r.primaryStore.getEntry(o);return i(o,u,_)}})),"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(d=>setImmediate(d));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){$s(t).dropTable()}createSchema(t){return Dc({database:t.schema,table:null}),Pg.signalSchemaChange(new Mg.SchemaEventMsg(process.pid,ps.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await xg(t.schema),Pg.signalSchemaChange(new Mg.SchemaEventMsg(process.pid,ps.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,GP.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,KP.default)(t);(0,WP.default)(t,n,r.primaryKey);let s,i=ut()[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),gt(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],d=[];for(let u of t.records){let _=await i.get(u[i.primaryKey],o);if(t.requires_existing&&!_||t.requires_no_existing&&_){d.push(u[i.primaryKey]);continue}_&&(_=bE(_));for(let E in u)if(Object.prototype.hasOwnProperty.call(u,E)){let f=u[E];if(typeof f=="function")try{let h=f([[_]]);Array.isArray(h)&&(f=h[0].func_val,u[E]=f)}catch(h){throw h.message+="Trying to set key "+E+" on object"+JSON.stringify(u),h}}if(_)for(let E in _)Object.prototype.hasOwnProperty.call(u,E)||(u[E]=_[E]);await i.put(u,o),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:d}})}async deleteRecords(t){let r=ut()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),gt(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 VP(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=ut()[t.schema][t.table];if(!r.createdTimeProperty)throw new ms.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:ps.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],d=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,QP.async_set_timeout)(DZ),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%CZ===0&&await d();return l.length>0&&await d(),s?VP(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,AE.default)(t,"hashes");if(r)throw r;return qP(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of qP(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&ps.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,AE.default)(t,"value");if(n)throw n;let s=$s(t);if(!s)throw new ms.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===ps.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:vg(t,s)})}async getDataByValue(t,r){let n=new Map,s=$s(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){$s({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return $s(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=$s(t),n={};switch(t.search_type){case ps.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.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 ps.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of $P(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return $P(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(vg,"getSelect");a(qP,"getRecords");a($s,"getTable");a(VP,"createDeleteResponse");a($P,"groupRecordsInHistory")});var Vn=N((gSe,JP)=>{"use strict";var{ResourceBridge:LZ}=(jP(),ae(zP)),PZ=ne();PZ.initSync();var OE;function MZ(){return OE||(OE=new LZ,OE)}a(MZ,"getBridge");JP.exports=MZ()});var tM=N((ASe,eM)=>{"use strict";var XP=require("lodash"),Qu=require("mathjs"),UZ=require("jsonata"),ZP=te();eM.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?XP.uniqWith(e,XP.isEqual):e,searchJSON:vZ,mad:zu.bind(null,Qu.mad),mean:zu.bind(null,Qu.mean),mode:zu.bind(null,Qu.mode),prod:zu.bind(null,Qu.prod),median:zu.bind(null,Qu.median)};function zu(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(zu,"aggregateFunction");function vZ(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(ZP.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),ZP.isEmpty(this.__ala__.res[r])){let n=UZ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(vZ,"searchJSON")});var nM=N((ySe,rM)=>{"use strict";var jt=require("moment"),Bg="YYYY-MM-DDTHH:mm:ss.SSSZZ";jt.suppressDeprecationWarnings=!0;rM.exports={current_date:()=>jt().utc().format("YYYY-MM-DD"),current_time:()=>jt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return jt(e).utc().format("YYYY");case"month":return jt(e).utc().format("MM");case"day":return jt(e).utc().format("DD");case"hour":return jt(e).utc().format("HH");case"minute":return jt(e).utc().format("mm");case"second":return jt(e).utc().format("ss");case"millisecond":return jt(e).utc().format("SSS");default:break}},date:e=>jt(e).utc().format(Bg),date_format:(e,t)=>jt(e).utc().format(t),date_add:(e,t,r)=>jt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>jt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=jt(e).utc(),s=jt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>jt().utc().valueOf(),get_server_time:()=>jt().format(Bg),offset_utc:(e,t)=>jt(e).utc().utcOffset(t).format(Bg)}});var aM=N((OSe,oM)=>{"use strict";var xZ=require("@turf/area"),BZ=require("@turf/length"),HZ=require("@turf/circle"),kZ=require("@turf/difference"),FZ=require("@turf/distance"),GZ=require("@turf/boolean-contains"),qZ=require("@turf/boolean-equal"),VZ=require("@turf/boolean-disjoint"),$Z=require("@turf/helpers"),sM=M(),Be=te(),bi=j();oM.exports={geoArea:YZ,geoLength:KZ,geoCircle:WZ,geoDifference:QZ,geoDistance:iM,geoNear:zZ,geoContains:jZ,geoEqual:JZ,geoCrosses:XZ,geoConvert:ZZ};function YZ(e){if(Be.isEmpty(e))return NaN;typeof e=="string"&&(e=Be.autoCastJSON(e));try{return xZ.default(e)}catch(t){return bi.trace(t,e),NaN}}a(YZ,"geoArea");function KZ(e,t){if(Be.isEmpty(e))return NaN;typeof e=="string"&&(e=Be.autoCastJSON(e));try{return BZ.default(e,{units:t||"kilometers"})}catch(r){return bi.trace(r,e),NaN}}a(KZ,"geoLength");function WZ(e,t,r){if(Be.isEmpty(e))return NaN;if(Be.isEmpty(t))return NaN;typeof e=="string"&&(e=Be.autoCastJSON(e));try{return HZ.default(e,t,{units:r||"kilometers"})}catch(n){return bi.trace(n,e,t),NaN}}a(WZ,"geoCircle");function QZ(e,t){if(Be.isEmpty(e))return NaN;if(Be.isEmpty(t))return NaN;typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t));try{return kZ(e,t)}catch(r){return bi.trace(r,e,t),NaN}}a(QZ,"geoDifference");function iM(e,t,r){if(Be.isEmpty(e))return NaN;if(Be.isEmpty(t))return NaN;typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t));try{return FZ.default(e,t,{units:r||"kilometers"})}catch(n){return bi.trace(n,e,t),NaN}}a(iM,"geoDistance");function zZ(e,t,r,n){if(Be.isEmpty(e)||Be.isEmpty(t))return!1;if(Be.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return iM(e,t,n)<=r}catch(s){return bi.trace(s,e,t),!1}}a(zZ,"geoNear");function jZ(e,t){if(Be.isEmpty(e)||Be.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t));try{return GZ.default(e,t)}catch(r){return bi.trace(r,e,t),!1}}a(jZ,"geoContains");function JZ(e,t){if(Be.isEmpty(e)||Be.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t));try{return qZ.default(e,t)}catch(r){return bi.trace(r,e,t),!1}}a(JZ,"geoEqual");function XZ(e,t){if(Be.isEmpty(e)||Be.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Be.autoCastJSON(e)),typeof t=="string"&&(t=Be.autoCastJSON(t));try{return!VZ.default(e,t)}catch(r){return bi.trace(r,e,t),!1}}a(XZ,"geoCrosses");function ZZ(e,t,r){if(Be.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Be.isEmpty(t))throw new Error("geo_type is required");if(Be.isEmpty(sM.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(sM.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Be.autoCastJSON(e)),$Z[t](e,r)}a(ZZ,"geoConvert")});var NE=N((ISe,cM)=>{var la=tM(),In=nM(),Ys=aM();cM.exports=e=>{e.aggr.mad=e.aggr.MAD=la.mad,e.aggr.mean=e.aggr.MEAN=la.mean,e.aggr.mode=e.aggr.MODE=la.mode,e.aggr.prod=e.aggr.PROD=la.prod,e.aggr.median=e.aggr.MEDIAN=la.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=la.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=la.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=In.current_date,e.fn.current_time=e.fn.CURRENT_TIME=In.current_time,e.fn.extract=e.fn.EXTRACT=In.extract,e.fn.date=e.fn.DATE=In.date,e.fn.date_format=e.fn.DATE_FORMAT=In.date_format,e.fn.date_add=e.fn.DATE_ADD=In.date_add,e.fn.date_sub=e.fn.DATE_SUB=In.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=In.date_diff,e.fn.now=e.fn.NOW=In.now,e.fn.offset_utc=e.fn.OFFSET_UTC=In.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=In.get_server_time,e.fn.getdate=e.fn.GETDATE=In.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=In.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ys.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ys.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ys.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ys.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ys.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ys.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ys.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ys.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ys.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ys.geoNear}});var _M=N((wSe,dM)=>{"use strict";var ju=require("lodash"),Wr=require("alasql");Wr.options.cache=!1;var e5=NE(),lM=require("clone"),IE=require("recursive-iterator"),we=j(),Qe=te(),Lc=Vn(),t5=M(),{hdb_errors:r5}=ce(),{getDatabases:uM}=(Ne(),ae(ot)),n5="IS NULL",Ss="There was a problem performing this search. Please check the logs and try again.";e5(Wr);var Hg=class{static{a(this,"SQLSearch")}constructor(t,r){if(Qe.isEmpty(t))throw we.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(),Qe.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Qe.isEmptyOrZeroLength(n))return we.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw we.error("Error thrown from checkEmptySQL in SQLSearch class method search."),we.error(n),new Error(Ss)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw we.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),we.error(n),new Error(Ss)}if(Object.keys(this.data).length===0)return we.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw we.error("Error thrown from processJoins in SQLSearch class method search."),we.error(n),new Error(Ss)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw we.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),we.error(n),new Error(Ss)}try{return t=await this._finalSQL(),t}catch(n){throw we.error("Error thrown from finalSQL in SQLSearch class method search."),we.error(n),new Error(Ss)}}_getColumns(){let t=new IE(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(lM(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=ju.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=uM()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Qe.isEmpty(this.statement.where)){we.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new IE(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Qe.isEmpty(r)&&r.right)if(Qe.isNotEmptyAndHasValue(r.right.value)){let n=Qe.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Wr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Qe.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Wr.yy.LogicValue({value:i}):n instanceof Wr.yy.StringValue&&Qe.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Wr.yy.NumValue({value:i}))});if(t){we.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new IE(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(!Qe.isEmpty(t5.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Qe.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Qe.isEmptyOrZeroLength(r.left.columnid)||Qe.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(Qe.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"=":!Qe.isEmpty(r.right.value)||!Qe.isEmpty(r.left.value)?n.add(Qe.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 d=0;d<l.length;d++)if(l[d].value)n.add(l[d].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(Qe.isEmptyOrZeroLength(this.all_table_attributes)&&Qe.isEmptyOrZeroLength(this.statement.from)&&Qe.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&&ju.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(Qe.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Qe.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(Qe.isEmptyOrZeroLength(this.all_table_attributes)&&!Qe.isEmptyOrZeroLength(this.columns.columns))return t;if(Qe.isEmptyOrZeroLength(this.all_table_attributes)&&Qe.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Wr.promise(r)}catch(r){throw we.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),we.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(lM(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(Qe.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(n5)>-1&&this.tables.forEach(s=>{let i={columnid:uM()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=ju.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,d=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!Qe.isEmpty(this.exact_search_values[d])&&!this.exact_search_values[d].ignore&&!Qe.isEmptyOrZeroLength(this.exact_search_values[d].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[d].values);let u=await Lc.getDataByHash(c);for(let _ of c.hash_values)u.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(u){throw we.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),we.error(u),new Error(Ss)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[d].values).map(async u=>{let _=Object.assign({},c);_.search_value=u;let E=await Lc.getDataByValue(_);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(u){throw we.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),we.error(u),new Error(Ss)}else if(!Qe.isEmpty(this.comparator_search_values[d])&&!this.comparator_search_values[d].ignore&&!Qe.isEmptyOrZeroLength(this.comparator_search_values[d].comparators))try{let u=this.comparator_search_values[d].comparators;for(let _=0,E=u.length;_<E;_++){let f=u[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await Lc.getDataByValue(c,f.operation);if(l)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(u){throw we.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),we.error(u),new Error(Ss)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await Lc.getDataByValue(c);if(l)for(let[_]of u)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of u)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(u){throw we.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),we.error(u),new Error(Ss)}}}_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 Wr.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 Wr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Wr.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 Wr.yy.FuncValue:new Wr.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,p=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${p}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${p}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let d="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(d="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let u="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",_=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${d} ${u} ${_}`,h=this._convertColumnsToIndexes(f,s);E=await Wr.promise(h,t),t=null}catch(f){throw we.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),we.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let p=E[f];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),p=ju.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,g=p.length;S<g;S++){let T=p[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[T]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new IE(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=ju.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 we.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),we.error(i),new Error(Ss)}}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 u in i)o.push(i[u][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 Lc.getDataByHash(c),d=s.columns.length;for(let u=0,_=o.length;u<_;u++){let E=o[u],f=l.get(E);for(let h=0;h<d;h++){let p=s.columns[h],S=f[p]===void 0?null:f[p];this.data[n].__merged_data[E].push(S)}}}}catch(r){throw we.error("Error thrown from getDataByHash function in SQLSearch class method getData."),we.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();we.trace(`Final SQL: ${s}`),n=await Wr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),we.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw we.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),we.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 we.error(r5.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),we.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],d=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(d,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),d=`[${c}]`;n=n.replace(l,d)});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 Lc.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]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw we.error("There was an error when processing this SQL operation. Check your logs"),we.error(o),new Error(Ss)}}return Object.values(Object.values(this.data)[0].__merged_data)}};dM.exports=Hg});var gn=N((DSe,fM)=>{"use strict";var s5=qI();fM.exports={searchByConditions:o5,searchByHash:a5,searchByValue:c5,search:l5};var kg=Vn(),{transformReq:Fg}=te(),i5=_M();async function o5(e){return Fg(e),kg.searchByConditions(e)}a(o5,"searchByConditions");async function a5(e){Fg(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of kg.searchByHash(e))r&&t.push(r);return t}a(a5,"searchByHash");async function c5(e){Fg(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of kg.searchByValue(e))t.push(r);return t}a(c5,"searchByValue");function l5(e,t){try{let r=new s5(e);r.validate(),new i5(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(l5,"search")});var wE=N((PSe,EM)=>{"use strict";var u5=Vn();EM.exports={writeTransaction:d5};function d5(e,t,r){return u5.writeTransaction(e,t,r)}a(d5,"writeTransaction")});var SM=N((vSe,pM)=>{"use strict";var _5=gn(),f5=Ti(),hM=j(),E5=Rn(),USe=wE(),h5=require("clone"),qg=require("alasql"),m5=NE(),mM=require("util"),p5=mM.promisify(f5.getTableSchema),S5=mM.promisify(_5.search),T5=M(),Gg=te();m5(qg);pM.exports={update:R5};var g5="There was a problem performing this update. Please check the logs and try again.";async function R5({statement:e,hdb_user:t}){let r=await p5(e.table.databaseid,e.table.tableid),n=A5(e.columns);Gg.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=h5(s),c=Gg.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,d=qg.parse(l).statements[0],u=await S5(d),_=b5(n,u);return y5(o,_,t)}a(R5,"update");function A5(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=qg.compile(`SELECT ${r.expression.toString()} AS [${T5.FUNC_VAL}] FROM ?`)}),t}catch(t){throw hM.error(t),new Error(g5)}}a(A5,"createUpdateRecord");function b5(e,t){return Gg.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(b5,"buildUpdateRecords");async function y5(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await E5.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){hM.error(`Error delete new_attributes from update response: ${i}`)}return s}a(y5,"updateRecords")});var gM=N((kSe,TM)=>{var O5=require("alasql"),N5=gn(),I5=j(),w5=Vn(),$g=require("util"),Vg=te(),C5=M(),D5=Ti(),BSe=wE(),HSe=Rn(),L5="record",P5="successfully deleted",M5=$g.callbackify(B5),U5=$g.promisify(N5.search),v5=$g.promisify(D5.getTableSchema);TM.exports={convertDelete:M5};function x5(e){return`${e.deleted_hashes.length} ${L5}${e.deleted_hashes.length===1?"":"s"} ${P5}`}a(x5,"generateReturnMessage");async function B5({statement:e,hdb_user:t}){let r=await v5(e.table.databaseid,e.table.tableid);Vg.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=Vg.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=O5.parse(o).statements[0],l={operation:C5.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await U5(c);let d=await w5.deleteRecords(l);return Vg.isEmptyOrZeroLength(d.message)&&(d.message=x5(d)),delete d.txn_time,d}catch(d){throw I5.error(d),d.hdb_code?d.message:d}}a(B5,"convertDelete")});var OM=N((GSe,yM)=>{"use strict";var H5=Si(),{hdb_errors:RM}=ce(),{getDatabases:AM}=(Ne(),ae(ot));yM.exports={checkSchemaExists:bM,checkSchemaTableExists:k5,schema_describe:H5};async function bM(e){if(!AM()[e])return RM.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(bM,"checkSchemaExists");async function k5(e,t){let r=await bM(e);if(r)return r;if(!AM()[e][t])return RM.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(k5,"checkSchemaTableExists")});var Ju=N((VSe,F5)=>{F5.exports={name:"harperdb",version:"4.4.0-alpha.1",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc --no-clean --reporter=lcovonly npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:replication && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.6.0",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.28.1","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.9.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.0.14",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.0",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.1",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^0.18.0","serve-static":"1.15.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.23.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.5.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^10.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.8.4",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.4.2","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var rd={};Ze(rd,{addAnalyticsListener:()=>td,recordAction:()=>Qr,recordActionBinary:()=>wn,setAnalyticsEnabled:()=>G5});function G5(e){UM=e}function Qr(e,t,r,n,s){if(!UM)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=LE.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let d=c;o.values=c=new Float32Array(l*2),c.set(d),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},LE.set(i,o)}CE||q5()}function wn(e,t,r,n,s){Qr(!!e,t,r,n,s)}function td(e){BM.push(e)}function q5(){CE=performance.now(),setTimeout(async()=>{let e=performance.now()-CE;CE=0;let t=[],r={time:Date.now(),period:e,threadId:ua.threadId,metrics:t};for(let[s,i]of LE){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,d=[],u;for(let _ of HM){let E=Math.floor(c*_),f=o[E-1];if(E>l){let h=E-l;if(f===u){let p=d[d.length-1];typeof p=="number"?d[d.length-1]={value:p,count:1+h}:p.count+=h}else d.push(h>1?{value:f,count:h}:f),u=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:d,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 kM()}let n=process.memoryUsage();t.push({metric:"memory",threadId:ua.threadId,byThread:!0,...n});for(let s of BM)s(t);LE=new Map,ua.parentPort?ua.parentPort.postMessage({type:xM,report:r}):qM({report:r})},vM).unref()}async function V5(e,t=6e4){let r=Wg(),n=FM(),s=new Promise(p=>{let S=performance.now();setImmediate(()=>{let g=performance.now();g-S>5e3&&(0,Xu.warn)("Unusually high event queue latency on the main thread of "+Math.round(g-S)+"ms"),S=performance.now()}),n.primaryStore.prefetch([1],()=>{let g=performance.now();g-S>5e3&&(0,Xu.warn)("Unusually high task queue latency on the main thread of "+Math.round(g-S)+"ms"),p(g-S)})}),i;for(let p of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(p.value?.time){i=p.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,d=[],u;for(let{key:p,value:S}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!S)continue;if(o){if(p>o+t)break}else o=p;u=p;let{metrics:g,threadId:T}=S;for(let A of g||[]){let{path:I,method:V,type:x,metric:X,count:$,total:F,distribution:se,threads:ee,...Z}=A;$||($=1);let le=X+(I?"-"+I:"");V!==void 0&&(le+="-"+V),x!==void 0&&(le+="-"+x);let _e=c.get(le);if(_e){if(_e.threads){let ye=_e.threads[T];if(ye)_e=ye;else{_e.threads[T]=Object.assign({},Z);continue}}_e.count||(_e.count=1);let je=_e.count;for(let ye in Z){let kt=Z[ye];typeof kt=="number"&&(_e[ye]=(_e[ye]*je+kt*$)/(je+$))}_e.count+=$,F>=0&&(_e.total+=F,_e.ratio=_e.total/_e.count)}else _e=Object.assign({period:t},A),delete _e.distribution,c.set(le,_e),_e.byThread&&(_e.threads=[],_e.threads[T]=Object.assign({},Z),d.push(_e));if(se){se=se.map(ye=>typeof ye=="number"?{value:ye,count:1}:ye);let je=l.get(le);je?je.push(...se):l.set(le,se)}}await kM()}for(let p of d){let{path:S,method:g,type:T,metric:A,count:I,total:V,distribution:x,threads:X,...$}=p;X=X.filter(F=>F);for(let F in $){if(typeof p[F]!="number")continue;let se=0;for(let ee of X){let Z=ee[F];typeof Z=="number"&&(se+=Z)}p[F]=se}p.count=X.length,delete p.threads,delete p.byThread}for(let[p,S]of l){let g=c.get(p);S.sort((ye,kt)=>ye.value>kt.value?1:-1);let T=g.count-1,A=[],I=0,V=0,x;for(let ye of HM){let kt=T*ye;for(;I<kt;)x=S[V++],I+=x.count,V===1&&I--;let Fo=S[V>1?V-2:0];x||(x=S[0]),A.push(x.value-(x.value-Fo.value)*(I-kt)/x.count)}let[X,$,F,se,ee,Z,le,_e,je]=A;Object.assign(g,{p1:X,p10:$,p25:F,median:se,p75:ee,p90:Z,p95:le,p99:_e,p999:je})}let _;for(let[p,S]of c)S.id=(0,DE.getNextMonotonicTime)(),S.time=u,n.primaryStore.put(S.id,S,{append:!0}).then(g=>{g||n.primaryStore.put(S.id,S)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let p=(0,DE.getNextMonotonicTime)(),S={id:p,metric:"main-thread-utilization",idle:f-NM,active:h-IM,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(p,S,{append:!0}).then(g=>{g||n.primaryStore.put(p,S)})}NM=f,IM=h}async function wM(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Wg(){return CM||(CM=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function FM(){return DM||(DM=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function K5(){GM=!0;let e=(0,ed.get)(Kg.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await V5(vM,e),await wM(Wg(),$5),await wM(FM(),Y5)},Math.min(e/2,2147483647)).unref()}function qM(e,t){let r=e.report;r.threadId=t?.threadId||ua.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(LM+=n.mean*n.count);r.totalBytesProcessed=LM,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(PM.get(t))}),PM.set(t,t.performance.eventLoopUtilization())),r.id=(0,DE.getNextMonotonicTime)(),Wg().primaryStore.put(r.id,r),GM||K5(),W5&&(VM=z5(r))}async function z5(e){if(await VM,!uo){let r=(0,Zu.dirname)((0,Xu.getLogFilePath)());try{uo=await(0,Yg.open)((0,Zu.join)(r,"analytics.log"),"r+")}catch{uo=await(0,Yg.open)((0,Zu.join)(r,"analytics.log"),"w+")}}let t=(await uo.stat()).size;if(t>Q5){let r=Buffer.alloc(t);await uo.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await uo.write(r,{position:0}),await uo.truncate(r.length),t=r.length}await uo.write(JSON.stringify(e)+`
|
|
10
|
-
`,t)}var
|
|
10
|
+
`)},y3="certificate.pem",O3="privateKey.pem",N3="caCertificate.pem",I3="natsCertificate.pem",w3="natsCaCertificate.pem",yt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},C3={tls_certificate:yt.SERVER,tls_certificateAuthority:yt.CA,customFunctions_tls_certificate:yt.SERVER,customFunctions_tls_certificateAuthority:yt.CA,operationsApi_tls_certificate:yt["OPERATIONS-API"],operationsApi_tls_certificateAuthority:yt["OPERATIONS-CA"]},D3={[yt.SERVER]:2,[yt.DEFAULT]:1},P3={[yt["OPERATIONS-API"]]:3,[yt.SERVER]:2,[yt.DEFAULT]:1},L3={[yt["OPERATIONS-API"]]:3,[yt.SERVER]:2,[yt.DEFAULT]:1},M3={[yt["OPERATIONS-CA"]]:3,[yt.CA]:2,[yt["DEFAULT-CA"]]:1},U3={[yt["OPERATIONS-CA"]]:3,[yt.CA]:2,[yt["DEFAULT-CA"]]:1},v3={[yt.CA]:2,[yt["DEFAULT-CA"]]:1};Object.assign(aL,{CERTIFICATE_PEM_NAME:y3,PRIVATEKEY_PEM_NAME:O3,CA_PEM_NAME:N3,CERT_NAME:yt,CERT_CONFIG_NAME_MAP:C3,CERT_PREFERENCE_APP:D3,CERT_PREFERENCE_OPS:P3,CERT_PREFERENCE_REP:L3,CA_CERT_PREFERENCE_REP:M3,CA_CERT_PREFERENCE_OPS:U3,CA_CERT_PREFERENCE_APP:v3,CERTIFICATE_VALUES:b3,NATS_CERTIFICATE_PEM_NAME:I3,NATS_CA_PEM_NAME:w3})});var DR=b((VAe,fL)=>{"use strict";var dL=require("fs-extra"),pe=require("joi"),B3=require("os"),{boolean:Ve,string:It,number:xt,array:rc}=pe.types(),{totalmem:cL}=require("os"),tc=require("path"),H3=V(),CR=J(),$Ae=wR(),lL=M(),x3=ut(),uL="log",k3="components",F3="Invalid logging.rotation.maxSize unit. Available units are G, M or K",G3="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",q3="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",$3="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",V3="rootPath config parameter is undefined",cs=pe.alternatives([xt.min(0),It]).optional().empty(null),xh=pe.alternatives([rc.items(It,{host:It.required(),port:cs},{hostname:It.required(),port:cs}).empty(null),rc.items(It)]),Ei,_L=!1;fL.exports={configValidator:Y3,routesValidator:J3,route_constraints:xh};function Y3(e,t=!1){if(_L=t,Ei=e.rootPath,CR.isEmpty(Ei))throw V3;let r=Ve.optional(),n=xt.min(0).max(1e3).empty(null).default(z3),s=It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(s_),i=It.optional().empty(null),o=It.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=pe.string().empty(null).default(s_),l=pe.custom(W3).empty(null).default(s_),d=e.clustering?.enabled,u=pe.object({certificate:i,certificateAuthority:i,privateKey:i}),_;return d===!0?_=pe.object({enabled:r,hubServer:pe.object({cluster:pe.object({name:pe.required().empty(null),network:pe.object({port:cs,routes:xh}).required()}).required(),leafNodes:pe.object({network:pe.object({port:cs}).required()}).required(),network:pe.object({port:cs}).required()}).required(),leafServer:pe.object({network:pe.object({port:cs,routes:xh}).required(),streams:pe.object({maxAge:xt.min(120).allow(null).optional(),maxBytes:xt.min(1).allow(null).optional(),maxMsgs:xt.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:pe.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:Ve.optional(),databaseLevel:Ve.optional(),tls:pe.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Ve.required(),verify:Ve.optional()}),user:It.optional().empty(null)}).optional():_=pe.object({enabled:r,tls:pe.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Ve.optional()})}).optional(),pe.object({authentication:pe.object({authorizeLocal:Ve,cacheTTL:xt.required(),enableSessions:Ve}),analytics:pe.object({aggregatePeriod:xt}),replication:pe.object({hostname:pe.alternatives(It,xt).optional().empty(null),url:It.optional().empty(null),port:xt.optional().empty(null),securePort:xt.optional().empty(null),routes:rc.optional().empty(null),databases:pe.alternatives(It,rc),enableRootCAs:Ve.optional()}),componentsRoot:s.optional(),clustering:_,localStudio:pe.object({enabled:r}).required(),logging:pe.object({auditAuthEvents:pe.object({logFailed:Ve,logSuccessful:Ve}),file:Ve.required(),level:pe.valid("notify","fatal","error","warn","info","debug","trace"),rotation:pe.object({enabled:Ve.optional(),compress:Ve.optional(),interval:It.custom(Q3).optional().empty(null),maxSize:It.custom(j3).optional().empty(null),path:It.optional().empty(null).default(s_)}).required(),root:s,stdStreams:Ve.required(),auditLog:Ve.required()}).required(),operationsApi:pe.object({network:pe.object({cors:Ve.optional(),corsAccessList:rc.optional(),headersTimeout:xt.min(1).optional(),keepAliveTimeout:xt.min(1).optional(),port:cs,domainSocket:pe.optional().empty("hdb/operations-server").default(s_),securePort:cs,timeout:xt.min(1).optional()}).optional(),tls:pe.alternatives([pe.array().items(u),u])}).required(),rootPath:It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:pe.object({network:pe.object({port:cs,securePort:cs,mtls:pe.alternatives([Ve.optional(),pe.object({user:It.optional(),certificateAuthority:i,required:Ve.optional()})])}).required(),webSocket:Ve.optional(),requireAuthentication:Ve.optional()}),http:pe.object({compressionThreshold:xt.optional(),cors:Ve.optional(),corsAccessList:rc.optional(),headersTimeout:xt.min(1).optional(),port:cs,securePort:cs,maxHeaderSize:xt.optional(),mtls:pe.alternatives([Ve.optional(),pe.object({user:It.optional(),certificateAuthority:i,required:Ve.optional()})]),threadRange:pe.alternatives([rc.optional(),It.optional()])}).required(),threads:pe.alternatives(n.optional(),pe.object({count:n.optional(),debug:pe.alternatives(Ve.optional(),pe.object({startingPort:xt.min(1).optional(),host:It.optional(),waitForDebugger:Ve.optional()})),maxHeapMemory:xt.min(0).optional()})),storage:pe.object({writeAsync:Ve.required(),overlappingSync:Ve.optional(),caching:Ve.optional(),compression:pe.alternatives([Ve.optional(),pe.object({dictionary:It.optional(),threshold:xt.optional()})]),compactOnStart:Ve.optional(),compactOnStartKeepBackup:Ve.optional(),noReadAhead:Ve.optional(),path:l,prefetchWrites:Ve.optional(),maxFreeSpaceToLoad:xt.optional(),maxFreeSpaceToRetain:xt.optional()}).required(),ignoreScripts:Ve.optional(),tls:pe.alternatives([pe.array().items(u),u])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(Y3,"configValidator");function K3(e){return _L||dL.existsSync(e)?null:`Specified path ${e} does not exist.`}a(K3,"doesPathExist");function W3(e,t){pe.assert(e,It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=K3(e);if(r)return t.message(r)}a(W3,"validatePath");function j3(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(F3);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(q3):e}a(j3,"validateRotationMaxSize");function Q3(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(G3);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message($3):e}a(Q3,"validateRotationInterval");function z3(e,t){let r=t.state.path.join("."),n=B3.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||cL();return i=Math.round(Math.min(i,cL())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),H3.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(z3,"setDefaultThreads");function s_(e,t){let r=t.state.path.join(".");if(!CR.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(CR.isEmpty(Ei))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return tc.join(Ei,k3);case"logging.root":return tc.join(Ei,uL);case"clustering.leafServer.streams.path":return tc.join(Ei,"clustering","leaf");case"storage.path":let n=tc.join(Ei,lL.LEGACY_DATABASES_DIR_NAME);return dL.existsSync(n)?n:tc.join(Ei,lL.DATABASES_DIR_NAME);case"logging.rotation.path":return tc.join(Ei,uL);case"operationsApi.network.domainSocket":return r==null?null:tc.join(Ei,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(s_,"setDefaultRoot");function J3(e){let t=pe.object({routes:xh});return x3.validateBySchema({routes:e},t)}a(J3,"routesValidator")});var wt=b(bL=>{"use strict";var an=M(),_r=J(),fr=V(),{configValidator:X3,routesValidator:EL}=DR(),Wr=require("fs-extra"),mL=require("yaml"),Mn=require("path"),Z3=require("is-number"),pL=require("properties-reader"),eX=require("lodash"),{handleHDBError:tX}=fe(),{HTTP_STATUS_CODES:rX,HDB_ERROR_MSGS:wl}=Nn(),{server:nX}=($r(),oe($a)),{DATABASES_PARAM_CONFIG:i_,CONFIG_PARAMS:Ln,CONFIG_PARAM_MAP:Fs}=an,sX="Unable to get config value because config is uninitialized",iX="Config successfully initialized",oX="Error backing up config file",aX="Empty parameter sent to getConfigValue",SL=Mn.join(an.PACKAGE_ROOT,"config","yaml",an.HDB_DEFAULT_CONFIG_FILE),cX=Mn.join(an.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),lX="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",hL={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"},kh,jt,Fh;Object.assign(bL,{createConfigFile:uX,getDefaultConfig:dX,getConfigValue:gL,initConfig:Gh,flattenConfig:Cl,updateConfigValue:RL,updateConfigObject:fX,getConfiguration:mX,setConfiguration:pX,readConfigFile:UR,getClusteringRoutes:SX,initOldConfig:AL,getConfigFromFile:TX,getConfigFilePath:nc,addConfig:gX,deleteConfigFromFile:RX,getConfigObj:AX,resolvePath:PR,getFlatConfigObj:bX});function PR(e){if(e?.startsWith("~/"))return Mn.join(_r.getHomeDir(),e.slice(1));let t=te();return Mn.resolve(t.getHdbBasePath(),e)}a(PR,"resolvePath");function uX(e,t=!1){let r=jo(SL);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=mL.parseDocument(Wr.readFileSync(cX,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}kh=Cl(r.toJSON());let n;for(let c in e){let l=Fs[c.toLowerCase()];if(l===Ln.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(d=>({[d]:e[c][d]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let d=l.split("_"),u=LR(l,e[c]);l==="rootPath"&&u?.endsWith("/")&&(u=u.slice(0,-1));try{r.setIn([...d],u)}catch(_){fr.error(_)}}}n&&TL(r,n),MR(r,t);let s=r.toJSON();jt=Cl(s);let i=r.getIn(["rootPath"]),o=Mn.join(i,an.HDB_CONFIG_FILE);Wr.createFileSync(o),Wr.writeFileSync(o,String(r)),fr.trace(`Config file written to ${o}`)}a(uX,"createConfigFile");function TL(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!_r.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(i_.TABLES))for(let i in n[s][i_.TABLES])for(let o in n[s][i_.TABLES][i]){let c=n[s][i_.TABLES][i][o],l=[Ln.DATABASES,s,i_.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=[Ln.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){fr.error("Error parsing schemas CLI/env config arguments",n)}}a(TL,"setSchemasConfig");function dX(e){if(kh===void 0){let r=jo(SL);kh=Cl(r.toJSON())}let t=Fs[e.toLowerCase()];if(t!==void 0)return kh[t.toLowerCase()]}a(dX,"getDefaultConfig");function gL(e){if(e==null){fr.info(aX);return}if(jt===void 0){fr.trace(sX);return}let t=Fs[e.toLowerCase()];if(t!==void 0)return jt[t.toLowerCase()]}a(gL,"getConfigValue");function nc(e=_r.getPropsFilePath()){let t=_r.getEnvCliRootPath();if(t)return PR(Mn.join(t,an.HDB_CONFIG_FILE));let r=pL(e);return PR(r.get(an.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(nc,"getConfigFilePath");function Gh(e=!1){if(jt===void 0||e){let t;if(!_r.noBootFile()){t=_r.getPropsFilePath();try{Wr.accessSync(t,Wr.constants.F_OK|Wr.constants.R_OK)}catch(i){throw fr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=nc(t),n;if(r.includes("config/settings.js"))try{AL(r);return}catch(i){if(i.code!==an.NODE_ERROR_CODES.ENOENT)throw i}try{n=jo(r)}catch(i){if(i.code===an.NODE_ERROR_CODES.ENOENT){fr.trace(`HarperDB config file not found at ${r}.
|
|
11
|
+
This can occur during early stages of install where the config file has not yet been created`);return}else throw fr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}_X(n,r),MR(n);let s=n.toJSON();if(nX.config=s,jt=Cl(s),jt.logging_rotation_rotate)for(let i in hL)jt[i]&&fr.error(`Config ${hL[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);fr.trace(iX)}}a(Gh,"initConfig");function _X(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Mn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Mn.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&&(fr.trace("Updating config file with missing config params"),Wr.writeFileSync(t,String(e)))}a(_X,"checkForUpdatedConfig");function MR(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 wl.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 wl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=X3(r,t);if(n.error)throw wl.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(MR,"validateConfig");function fX(e,t){jt===void 0&&(jt={});let r=Fs[e.toLowerCase()];if(r===void 0){fr.trace(`Unable to update config object because config param '${e}' does not exist`);return}jt[r.toLowerCase()]=t}a(fX,"updateConfigObject");function RL(e,t,r=void 0,n=!1,s=!1,i=!1){jt===void 0&&Gh();let o=gL(Fs.hdb_root),c=Mn.join(o,an.HDB_CONFIG_FILE),l=jo(c),d;if(r===void 0&&e.toLowerCase()===Ln.DATABASES)d=t;else if(r===void 0){let E;if(i)E=e;else if(E=Fs[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=LR(E,t);l.setIn([...f],h)}else for(let E in r){let f=Fs[E.toLowerCase()];if(f===Ln.HTTP_SECUREPORT&&r[E]===jt[Ln.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Ln.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Ln.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Ln.DATABASES){d=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),T=an.LEGACY_CONFIG_PARAMS[E.toUpperCase()];T&&T.startsWith("customFunctions")&&l.hasIn(T.split("_"))&&(f=T,h=T.split("_"));let S=LR(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],S)}catch(R){fr.error(R)}}}d&&TL(l,d),MR(l);let u=l.getIn(["rootPath"]),_=Mn.join(u,an.HDB_CONFIG_FILE);n===!0&&EX(c,u),Wr.writeFileSync(_,String(l)),s&&(jt=Cl(l.toJSON())),fr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(RL,"updateConfigValue");function EX(e,t){try{let r=Mn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${an.HDB_CONFIG_FILE}.bak`);Wr.copySync(e,r),fr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){fr.error(oX),fr.error(r)}}a(EX,"backupConfigFile");var hX=["databases"];function Cl(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}),Fh=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])&&!hX.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;!Ln[l.toUpperCase()]&&Fs[l]&&(s[Fs[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Cl,"flattenConfig");function LR(e,t){if(e===Ln.CLUSTERING_NODENAME||e===Ln.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(Z3(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||_r.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 _r.autoCast(t)}a(LR,"castConfigValue");function mX(){let e=_r.getPropsFilePath(),t=nc(e);return jo(t).toJSON()}a(mX,"getConfiguration");async function pX(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return RL(void 0,void 0,s,!0),lX}catch(i){throw typeof i=="string"||i instanceof String?tX(i,i,rX.BAD_REQUEST,void 0,void 0,!0):i}}a(pX,"setConfiguration");function UR(){let e=_r.getPropsFilePath();try{Wr.accessSync(e,Wr.constants.F_OK|Wr.constants.R_OK)}catch(n){if(!_r.noBootFile())throw fr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=nc(e);return jo(t).toJSON()}a(UR,"readConfigFile");function jo(e){return mL.parseDocument(Wr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(jo,"parseYamlDoc");function SX(){let e=UR(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=_r.isEmptyOrZeroLength(t)?[]:t;let r=EL(t);if(r)throw wl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=_r.isEmptyOrZeroLength(n)?[]:n;let s=EL(n);if(s)throw wl.CONFIG_VALIDATION(s.message);if(!_r.isEmptyOrZeroLength(n)&&!_r.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!_r.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw wl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(SX,"getClusteringRoutes");function AL(e){let t=pL(e);jt={};for(let r in Fs){let n=t.get(r.toUpperCase());if(_r.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Fs[r].toLowerCase();s===Ln.LOGGING_ROOT?jt[s]=Mn.dirname(n):jt[s]=n}return jt}a(AL,"initOldConfig");function TX(e){let t=UR();return eX.get(t,e.replaceAll("_","."))}a(TX,"getConfigFromFile");async function gX(e,t){let r=jo(nc());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await Wr.writeFile(nc(),String(r))}a(gX,"addConfig");function RX(e){let t=nc(_r.getPropsFilePath()),r=jo(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Mn.join(n,an.HDB_CONFIG_FILE);Wr.writeFileSync(s,String(r))}a(RX,"deleteConfigFromFile");function AX(){return Fh||(Gh(),Fh)}a(AX,"getConfigObj");function bX(){return jt||Gh(),jt}a(bX,"getFlatConfigObj")});var OL=b((jAe,yL)=>{"use strict";var qh=M(),$h=class{static{a(this,"BaseLicense")}constructor(t=0,r=qh.RAM_ALLOCATION_ENUM.DEFAULT,n=qh.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},vR=class extends $h{static{a(this,"ExtendedLicense")}constructor(t=0,r=qh.RAM_ALLOCATION_ENUM.DEFAULT,n=qh.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};yL.exports={BaseLicense:$h,ExtendedLicense:vR}});var sc=b((zAe,LL)=>{"use strict";var Pl=require("fs-extra"),IL=Hh(),wL=require("crypto"),yX=require("moment"),OX=require("uuid").v4,jr=V(),HR=require("path"),NX=J(),Qo=M(),{totalmem:NL}=require("os"),IX=OL().ExtendedLicense,Dl="invalid license key format",wX="061183",CX="mofi25",DX="aes-256-cbc",PX=16,LX=32,CL=te(),{resolvePath:DL}=wt();CL.initSync();var BR;LL.exports={validateLicense:PL,generateFingerPrint:UX,licenseSearch:FR,getLicense:HX,checkMemoryLimit:xX};function xR(){return HR.join(CL.getHdbBasePath(),Qo.LICENSE_KEY_DIR_NAME,Qo.LICENSE_FILE_NAME)}a(xR,"getLicenseDirPath");function MX(){let e=xR();return DL(HR.join(e,Qo.LICENSE_FILE_NAME))}a(MX,"getLicenseFilePath");function kR(){let e=xR();return DL(HR.join(e,Qo.REG_KEY_FILE_NAME))}a(kR,"getFingerPrintFilePath");async function UX(){let e=kR();try{return await Pl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await vX();throw jr.error(`Error writing fingerprint file to ${e}`),jr.error(t),new Error("There was an error generating the fingerprint")}}a(UX,"generateFingerPrint");async function vX(){let e=OX(),t=IL.hash(e),r=kR();try{await Pl.mkdirp(xR()),await Pl.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw jr.error(`Error writing fingerprint file to ${r}`),jr.error(n),new Error("There was an error generating the fingerprint")}return t}a(vX,"writeFingerprint");function PL(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Qo.RAM_ALLOCATION_ENUM.DEFAULT,version:Qo.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return jr.error("empty license key passed to validate."),r;let n=kR(),s=!1;try{s=Pl.statSync(n)}catch(i){jr.error(i)}if(s){let i;try{i=Pl.readFileSync(n,"utf8")}catch{jr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(CX),c=o[1];c=Buffer.concat([Buffer.from(c)],PX);let l=Buffer.concat([Buffer.from(i)],LX),d=wL.createDecipheriv(DX,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=d.update(o[0],"hex","utf8"),u.trim(),u+=d.final("utf8")}catch{let f=BX(o[0],i);if(f)u=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Dl),jr.error(Dl),new Error(Dl)}let _;if(isNaN(u))try{_=JSON.parse(u),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(Dl),jr.error(Dl),new Error(Dl)}else r.exp_date=u;r.exp_date<yX().valueOf()&&(r.valid_date=!1),IL.validate(o[1],`${wX}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||jr.error("Invalid licence"),r}a(PL,"validateLicense");function BX(e,t){try{let r=wL.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{jr.warn("Check old license failed")}}a(BX,"checkOldLicense");function FR(){let e=new IX,t=[];try{t=Pl.readFileSync(MX(),"utf-8").split(Qo.NEW_LINE)}catch(r){r.code==="ENOENT"?jr.debug("no license file found"):jr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(NX.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=PL(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){jr.error("There was an error parsing the license string."),jr.error(s),e.ram_allocation=Qo.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return BR=e,e}a(FR,"licenseSearch");async function HX(){return BR||await FR(),BR}a(HX,"getLicense");function xX(){let e=FR().ram_allocation,t=process.constrainedMemory?.()||NL();if(t=Math.round(Math.min(t,NL())/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(xX,"checkMemoryLimit")});var vn=b((tbe,jL)=>{"use strict";var BL="username is required",HL="nothing to update, must supply active, role or password to update",xL="password cannot be an empty string",kL="If role is specified, it cannot be empty.",FL="active must be true or false";jL.exports={addUser:WX,alterUser:jX,dropUser:zX,getSuperUser:eZ,userInfo:JX,listUsers:Yh,listUsersExternal:XX,setUsersToGlobal:Ml,findAndValidateUser:KL,getClusterUser:tZ,USERNAME_REQUIRED:BL,ALTERUSER_NOTHING_TO_UPDATE:HL,EMPTY_PASSWORD:xL,EMPTY_ROLE:kL,ACTIVE_BOOLEAN:FL};var GL=Yr(),kX=Wo(),$R=Hh(),qL=sL(),$L=Vr(),VR=Ji(),Un=J(),VL=require("validate.js"),Ye=V(),{promisify:FX}=require("util"),YR=zi(),ML=M(),UL=dt(),GX=wt(),XAe=te(),ZAe=sc(),qX=ji(),{table:ebe}=(Le(),oe(lt)),{handleHDBError:hi,hdb_errors:$X}=fe(),{HTTP_STATUS_CODES:mi,AUTHENTICATION_ERROR_MSGS:GR,HDB_ERROR_MSGS:Ll}=$X,{UserEventMsg:KR}=Gs(),qR=require("lodash"),{server:WR}=($r(),oe($a)),VX=V();WR.getUser=(e,t)=>KL(e,t,t!=null);var YL={username:!0,active:!0,role:!0,password:!0},vL=new Map,Vh=$L.searchByValue,YX=$L.searchByHash,KX=FX(kX.delete);async function WX(e){let t=VL.cleanAttributes(e,YL),r=qL.addUserValidation(t);if(r)throw hi(new Error,r.message,mi.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await Vh(n),s=s&&Array.from(s)}catch(l){throw Ye.error("There was an error searching for a role in add user"),Ye.error(l),l}if(!s||s.length<1)throw hi(new Error,Ll.ROLE_NAME_NOT_FOUND(t.role),mi.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw hi(new Error,Ll.DUP_ROLES_FOUND(t.role),mi.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=YR.encrypt(t.password)),t.password=$R.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await GL.insert(i)}catch(l){throw Ye.error("There was an error searching for a user."),Ye.error(l),l}Ye.debug(o);try{await Ml()}catch(l){throw Ye.error("Got an error setting users to global"),Ye.error(l),l}if(o.skipped_hashes.length===1)throw hi(new Error,Ll.USER_ALREADY_EXISTS(t.username),mi.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],VR.signalUserChange(new KR(process.pid)),`${c.username} successfully added`}a(WX,"addUser");async function jX(e){let t=VL.cleanAttributes(e,YL);if(Un.isEmptyOrZeroLength(t.username))throw new Error(BL);if(Un.isEmptyOrZeroLength(t.password)&&Un.isEmptyOrZeroLength(t.role)&&Un.isEmptyOrZeroLength(t.active))throw new Error(HL);if(!Un.isEmpty(t.password)&&Un.isEmptyOrZeroLength(t.password.trim()))throw new Error(xL);if(!Un.isEmpty(t.active)&&!Un.isBoolean(t.active))throw new Error(FL);let r=QX(t.username);if(!Un.isEmpty(t.password)&&!Un.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=YR.encrypt(t.password)),t.password=$R.hash(t.password)),t.role==="")throw new Error(kL);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await Vh(i)||[])}catch(c){throw Ye.error("Got an error searching for a role."),Ye.error(c),c}if(!o||o.length===0){let c=Ll.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ye.error(c),hi(new Error,c,mi.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Ll.ALTER_USER_DUP_ROLES(t.role);throw Ye.error(c),hi(new Error,c,mi.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await GL.update(n)}catch(i){throw Ye.error("Error during update."),Ye.error(i),i}try{await Ml()}catch(i){throw Ye.error("Got an error setting users to global"),Ye.error(i),i}return VR.signalUserChange(new KR(process.pid)),s}a(jX,"alterUser");function QX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(QX,"isClusterUser");async function zX(e){try{let t=qL.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Un.isEmpty(global.hdb_users.get(e.username)))throw hi(new Error,Ll.USER_NOT_EXIST(e.username),mi.NOT_FOUND,void 0,void 0,!0);let n;try{n=await KX(r)}catch(s){throw Ye.error("Got an error deleting a user."),Ye.error(s),s}Ye.debug(n);try{await Ml()}catch(s){throw Ye.error("Got an error setting users to global."),Ye.error(s),s}return VR.signalUserChange(new KR(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(zX,"dropUser");async function JX(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=qR.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await YX(r)}catch(s){throw Ye.error("Got an error searching for a role."),Ye.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Ye.error(r),r}return t}a(JX,"userInfo");async function XX(){let e;try{e=await Yh()}catch(t){throw Ye.error("Got an error listing users."),Ye.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(XX,"listUsersExternal");async function Yh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await Vh(e)}catch(o){throw Ye.error("Got an error searching for roles."),Ye.error(o),o}let r={};for(let o of t)r[o.id]=qR.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await Vh(n)}catch(o){throw Ye.error("Got an error searching for users."),Ye.error(o),o}let i=new Map;for(let o of s)o=qR.cloneDeep(o),o.role=r[o.role],ZX(o.role),i.set(o.username,o);return i}catch(e){throw Ye.error("got an error listing users"),Ye.error(e),Un.errorizeMessage(e)}return null}a(Yh,"listUsers");function ZX(e){try{if(!e){Ye.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(qX)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Ye.error("Got an error trying to set system permissions."),Ye.error(t)}}a(ZX,"appendSystemTablesToRole");async function Ml(){try{let e=await Yh();global.hdb_users=e}catch(e){throw Ye.error(e),e}}a(Ml,"setUsersToGlobal");async function KL(e,t,r=!0){global.hdb_users||await Ml();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw hi(new Error,GR.GENERIC_AUTH_FAIL,mi.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw hi(new Error,GR.USER_INACTIVE,mi.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(vL.get(t)===n.password)return s;if($R.validate(n.password,t))vL.set(t,n.password);else throw hi(new Error,GR.GENERIC_AUTH_FAIL,mi.UNAUTHORIZED,void 0,void 0,!0)}return s}a(KL,"findAndValidateUser");async function eZ(){global.hdb_users||await Ml();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(eZ,"getSuperUser");async function tZ(){let e=await Yh(),t=GX.getConfigFromFile(ML.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Un.isEmpty(r)&&r?.role?.role===ML.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=YR.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+UL.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+UL.SERVER_SUFFIX.ADMIN,r}a(tZ,"getClusterUser");var WL=[];WR.invalidateUser=function(e){for(let t of WL)try{t(e)}catch(r){VX.error("Error invalidating user",r)}};WR.onInvalidatedUser=function(e){WL.push(e)}});var a_=b((ibe,XL)=>{"use strict";var ic=V(),Bn=M(),rZ=NP(),nbe=as(),sbe=fi(),nZ=vn(),{validateEvent:QL}=Gs(),o_=Pn(),sZ=require("process"),{resetDatabases:iZ}=(Le(),oe(lt)),oZ={[Bn.ITC_EVENT_TYPES.SCHEMA]:aZ,[Bn.ITC_EVENT_TYPES.USER]:JL};async function aZ(e){let t=QL(e);if(t){ic.error(t);return}ic.trace("ITC schemaHandler received schema event:",e),await rZ(e.message),await cZ(e.message)}a(aZ,"schemaHandler");async function cZ(e){try{o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=iZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){ic.error(t)}}a(cZ,"syncSchemaMetadata");var zL=[];async function JL(e){try{try{o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){ic.warn(r)}let t=QL(e);if(t){ic.error(t);return}ic.trace(`ITC userHandler ${Bn.HDB_ITC_CLIENT_PREFIX}${sZ.pid} received user event:`,e),await nZ.setUsersToGlobal();for(let r of zL)r()}catch(t){ic.error(t)}}a(JL,"userHandler");JL.addListener=function(e){zL.push(e)};XL.exports=oZ});var Gs=b((dbe,eM)=>{"use strict";var abe=V(),jR=J(),lZ=M(),{ITC_ERRORS:c_}=Nn(),{parentPort:cbe,threadId:uZ,isMainThread:dZ,workerData:lbe}=require("worker_threads"),{onMessageFromWorkers:_Z,broadcast:ube,broadcastWithAcknowledgement:fZ}=it();eM.exports={sendItcEvent:EZ,validateEvent:ZL,SchemaEventMsg:hZ,UserEventMsg:mZ};var Kh;_Z(async(e,t)=>{Kh=Kh||a_(),ZL(e),Kh[e.type]&&await Kh[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function EZ(e){return!dZ&&e.message&&(e.message.originator=uZ),fZ(e)}a(EZ,"sendItcEvent");function ZL(e){if(typeof e!="object")return c_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||jR.isEmpty(e.type))return c_.MISSING_TYPE;if(!e.hasOwnProperty("message")||jR.isEmpty(e.message))return c_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||jR.isEmpty(e.message.originator))return c_.MISSING_ORIGIN;if(lZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return c_.INVALID_EVENT(e.type)}a(ZL,"validateEvent");function hZ(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(hZ,"SchemaEventMsg");function mZ(e){this.originator=e}a(mZ,"UserEventMsg")});var Ji=b((Ebe,sM)=>{"use strict";var tM=M(),fbe=J(),Wh=V(),rM=bP(),Ul,{sendItcEvent:nM}=Gs();function pZ(e){try{Wh.info("signalSchemaChange called with message:",e),Ul=Ul||a_();let t=new rM(tM.ITC_EVENT_TYPES.SCHEMA,e);return Ul.schema(t),nM(t)}catch(t){Wh.error(t)}}a(pZ,"signalSchemaChange");function SZ(e){try{Wh.trace("signalUserChange called with message:",e),Ul=Ul||a_();let t=new rM(tM.ITC_EVENT_TYPES.USER,e);return Ul.user(t),nM(t)}catch(t){Wh.error(t)}}a(SZ,"signalUserChange");sM.exports={signalSchemaChange:pZ,signalUserChange:SZ}});var jh=b((mbe,oM)=>{"use strict";var iM=J(),TZ=M(),gZ=V(),RZ=wh(),AZ=Ih(),bZ=Ji(),{SchemaEventMsg:yZ}=Gs(),OZ="already exists in";oM.exports=NZ;async function NZ(e,t,r){if(iM.isEmptyOrZeroLength(r))return r;let n=[];iM.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 IZ(e,t.schema,t.name,i)})),s}a(NZ,"lmdbCheckForNewAttributes");async function IZ(e,t,r,n){let s=new AZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await wZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(OZ))gZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(IZ,"createNewAttribute");async function wZ(e){let t;return t=await RZ(e),bZ.signalSchemaChange(new yZ(process.pid,TZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(wZ,"createAttribute")});var vl=b((Sbe,aM)=>{"use strict";var QR=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}};aM.exports=QR});var lM=b((gbe,cM)=>{"use strict";var CZ=vl(),DZ=M().OPERATIONS_ENUM,zR=class extends CZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(DZ.INSERT,r,n,s,i),this.records=t}};cM.exports=zR});var dM=b((Abe,uM)=>{"use strict";var PZ=vl(),LZ=M().OPERATIONS_ENUM,JR=class extends PZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(LZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};uM.exports=JR});var fM=b((ybe,_M)=>{"use strict";var MZ=vl(),UZ=M().OPERATIONS_ENUM,XR=class extends MZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(UZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};_M.exports=XR});var hM=b((Nbe,EM)=>{"use strict";var vZ=vl(),BZ=M().OPERATIONS_ENUM,ZR=class extends vZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(BZ.DELETE,n,s,t,i),this.original_records=r}};EM.exports=ZR});var l_=b((Cbe,TM)=>{"use strict";var wbe=require("path"),mM=ht(),HZ=lM(),xZ=dM(),kZ=fM(),FZ=hM(),Bl=Bt(),pM=J(),{CONFIG_PARAMS:GZ}=M(),SM=te();SM.initSync();var Qh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:qZ}=gt();TM.exports=$Z;async function $Z(e,t){if(SM.get(GZ.LOGGING_AUDITLOG)===!1)return;let r=qZ(e.schema,e.table),n=await mM.openEnvironment(r,e.table,!0),s=VZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){mM.initializeDBIs(n,Bl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Bl.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Bl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Bl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),pM.isEmpty(s.user_name)||n.dbis[Bl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Bl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a($Z,"writeTransaction");function VZ(e,t){let r=pM.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Qh.INSERT)return new HZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.UPDATE)return new xZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.UPSERT)return new kZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.DELETE)return new FZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(VZ,"createTransactionObject")});var eA=b((Lbe,gM)=>{"use strict";var YZ=t_(),Pbe=Hd(),u_=M(),KZ=xd(),WZ=Qa().insertRecords,jZ=ht(),QZ=V(),zZ=jh(),{getSchemaPath:JZ}=gt(),XZ=l_();gM.exports=ZZ;async function ZZ(e){try{let{schema_table:t,attributes:r}=YZ(e);KZ(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 zZ(e.hdb_auth_header,t,r),s=JZ(e.schema,e.table),i=await jZ.openEnvironment(s,e.table),o=await WZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await XZ(e,o)}catch(c){QZ.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(ZZ,"lmdbCreateRecords")});var bM=b((Ube,AM)=>{"use strict";var RM=M(),e5=eA(),t5=Hd(),r5=require("fs-extra"),{getSchemaPath:n5}=gt();AM.exports=s5;async function s5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new t5(RM.SYSTEM_SCHEMA_NAME,RM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await e5(r),await r5.mkdirp(n5(e.schema))}a(s5,"lmdbCreateSchema")});var OM=b((Bbe,yM)=>{"use strict";var tA=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}};yM.exports=tA});var CM=b((Gbe,wM)=>{"use strict";var NM=ht(),rA=nn(),nA=Nn().LMDB_ERRORS_ENUM,i5=Bt(),IM=V(),xbe=J(),o5=require("lmdb"),a5=OM(),c5=M(),{OVERFLOW_MARKER:kbe,MAX_SEARCH_KEY_LENGTH:Fbe}=i5,l5=c5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function u5(e,t,r,n){if(rA.validateEnv(e),t===void 0)throw new Error(nA.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(nA.IDS_REQUIRED):new Error(nA.IDS_MUST_BE_ITERABLE);try{let s=NM.listDBIs(e);NM.initializeDBIs(e,t,s);let i=new a5,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[l5]>n){i.skipped.push(o);continue}let T=e.dbis[t].ifVersion(o,o5.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let R=s[S];if(!h.hasOwnProperty(R)||R===t)continue;let p=e.dbis[R],y=h[R];if(y!=null)try{let O=rA.getIndexedValues(y);if(O)for(let B=0,x=O.length;B<x;B++)p.remove(O[B],o)}catch{IM.warn(`cannot delete from attribute: ${R}, ${y}:${o}`)}}});c.push(T),l.push(o),i.original_records.push(h)}catch(h){IM.warn(h),i.skipped.push(o)}let d=[],u=await Promise.all(c);for(let E=0,f=u.length;E<f;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),d.push(E));let _=0;for(let E=0;E<d.length;E++){let f=d[E];i.original_records.splice(f-_,1),_++}return i.txn_time=rA.getNextMonotonicTime(),i}catch(s){throw s}}a(u5,"deleteRecords");wM.exports={deleteRecords:u5}});var d_=b(($be,PM)=>{"use strict";var Hl=J(),d5=CM(),_5=ht(),{getSchemaPath:f5}=gt(),E5=l_(),h5=V();PM.exports=m5;async function m5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Hl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Hl.isEmptyOrZeroLength(e.hash_values)&&!Hl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Hl.isEmpty(l)||e.hash_values.push(l)}}if(Hl.isEmptyOrZeroLength(e.hash_values))return DM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Hl.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=f5(e.schema,e.table),i=await _5.openEnvironment(s,e.table),o=await d5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await E5(e,o)}catch(c){h5.error(`unable to write transaction due to ${c.message}`)}return DM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(m5,"lmdbDeleteRecords");function DM(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(DM,"createDeleteResponse")});var iA=b((Kbe,LM)=>{"use strict";var p5=M(),Ybe=nn();function sA(e,t){let r=Object.create(null);if(t.length===1&&p5.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(sA,"parseRow");function S5(e,t,r,n){let s=sA(r,e);n.push(s)}a(S5,"searchAll");function T5(e,t,r,n){let s=sA(r,e);n[t]=s}a(T5,"searchAllToMap");function g5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(g5,"iterateDBI");function oc(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(oc,"pushResults");function R5(e,t,r,n,s,i){t.toString().endsWith(e)&&oc(t,r,n,s,i)}a(R5,"endsWith");function A5(e,t,r,n,s,i){t.toString().includes(e)&&oc(t,r,n,s,i)}a(A5,"contains");function b5(e,t,r,n,s,i){t>e&&oc(t,r,n,s,i)}a(b5,"greaterThanCompare");function y5(e,t,r,n,s,i){t>=e&&oc(t,r,n,s,i)}a(y5,"greaterThanEqualCompare");function O5(e,t,r,n,s,i){t<e&&oc(t,r,n,s,i)}a(O5,"lessThanCompare");function N5(e,t,r,n,s,i){t<=e&&oc(t,r,n,s,i)}a(N5,"lessThanEqualCompare");LM.exports={parseRow:sA,searchAll:S5,searchAllToMap:T5,iterateDBI:g5,endsWith:R5,contains:A5,greaterThanCompare:b5,greaterThanEqualCompare:y5,lessThanCompare:O5,lessThanEqualCompare:N5,pushResults:oc}});var xl=b((Jbe,kM)=>{"use strict";var zo=ht(),jbe=V(),Hn=nn(),zh=Bt(),Qt=Nn().LMDB_ERRORS_ENUM,Qbe=J(),I5=M(),Jh=iA(),{parseRow:w5}=Jh,zbe=require("lmdb"),{OVERFLOW_MARKER:MM,MAX_SEARCH_KEY_LENGTH:C5}=zh;function UM(e,t,r,n=!1,s=void 0,i=void 0){return ac(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(UM,"iterateFullIndex");function __(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,d=!1){return ac(e,t,r,(u,_,E,f)=>{let p={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!d,exclusiveStart:i===!0?d:l};return f===r?(p.values=!1,_.getRange(p).map(y=>({value:y}))):_.getRange(p)})}a(__,"iterateRangeBetween");function ac(e,t,r,n){let s=e.database||e,i=zo.openDBI(s,r);i[zh.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&zo.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(ac,"setupTransaction");function vM(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(MM)){if(!s)if(r)s=zo.openDBI(e,r);else{let l=zo.listDBIs(e);for(let d=0,u=l.length;d<u&&(s=zo.openDBI(e,l[d]),!s[zh.DBI_DEFINITION_NAME].is_hash_attribute);d++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(vM,"getOverflowCheck");function D5(e,t,r,n=!1,s=void 0,i=void 0){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return ac(e,t,t,(o,c,l)=>(Xh(r),r=f_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(d=>w5(d.value,r))))}a(D5,"searchAll");function P5(e,t,r,n=!1,s=void 0,i=void 0){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);Xh(r),r=f_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of UM(e,t,t,n,s,i))o.set(c,Jh.parseRow(l,r));return o}a(P5,"searchAllToMap");function L5(e,t,r=!1,n=void 0,s=void 0){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=UM(e,void 0,t,r,n,s),c=o.transaction,l=vM(c.database,c,void 0,t);for(let{key:d,value:u}of o){let _=l(d,u);i[_]===void 0&&(i[_]=[]),i[_].push(u)}return i}a(L5,"iterateDBI");function M5(e,t){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return zo.statDBI(e,t).entryCount}a(M5,"countAll");function U5(e,t,r,n,s=!1,i=void 0,o=void 0){return Jo(e,r,n),ac(e,t,r,(c,l,d,u)=>(n=Hn.convertKeyValueToWrite(n),u===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(_=>({key:n,value:_}))))}a(U5,"equals");function v5(e,t,r){return Jo(e,t,r),zo.openDBI(e,t).getValuesCount(r)}a(v5,"count");function B5(e,t,r,n,s=!1,i=void 0,o=void 0){return Jo(e,r,n),ac(e,null,r,(c,l)=>{n=Hn.convertKeyValueToWrite(n);let d=!0;typeof n=="number"&&(d=!1);let u;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(d===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(d===!0)return u.DONE}),d?u:u.filter(_=>_)})}a(B5,"startsWith");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){return BM(e,t,r,n,s,i,o,!0)}a(H5,"endsWith");function BM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Jo(e,r,n),ac(e,null,r,(l,d,u,_)=>{let E=vM(u,l,_,r);return o=Number.isInteger(o)?o:0,d.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(MM)?d.getValues(f,{transaction:l}).map(T=>{let S=E(f,T);if(c?S.endsWith(n):S.includes(n))return{key:S,value:T}}).filter(T=>T):(c?h.endsWith(n):h.includes(n))?d[zh.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:d.getValues(f,{transaction:l}).map(T=>({key:f,value:T})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(BM,"contains");function x5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),__(e,t,r,n,l,s,i,o,!0,!1)}a(x5,"greaterThan");function k5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),__(e,t,r,n,l,s,i,o,!1,!1)}a(k5,"greaterThanEqual");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),__(e,t,r,l,n,s,i,o,!1,!0)}a(F5,"lessThan");function G5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),__(e,t,r,l,n,s,i,o,!1,!1)}a(G5,"lessThanEqual");function q5(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Hn.validateEnv(e),r===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Qt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Qt.END_VALUE_REQUIRED);if(n=Hn.convertKeyValueToWrite(n),s=Hn.convertKeyValueToWrite(s),n>s)throw new Error(Qt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return __(e,t,r,n,s,i,o,c)}a(q5,"between");function $5(e,t,r,n){Hn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(Xh(r),r=f_(s,r),n===void 0)throw new Error(Qt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=Jh.parseRow(c,r)),o}a($5,"searchByHash");function V5(e,t,r){Hn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(V5,"checkHashExists");function Y5(e,t,r,n,s=[]){return xM(e,t,r,n,s),HM(e,t,r,n,s).map(i=>i[1])}a(Y5,"batchSearchByHash");function K5(e,t,r,n,s=[]){xM(e,t,r,n,s);let i=new Map;for(let[o,c]of HM(e,t,r,n,s))i.set(o,c);return i}a(K5,"batchSearchByHashToMap");function HM(e,t,r,n,s=[]){return ac(e,t,t,(i,o,c)=>{r=f_(c,r);let l=r.length<3;return n.map(d=>{let u=c.dbis[t].get(d,{transaction:i,lazy:l});if(u)return[d,Jh.parseRow(u,r)];s.push(d)}).filter(d=>d)})}a(HM,"batchHashSearch");function xM(e,t,r,n,s){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(Xh(r),n==null)throw new Error(Qt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Qt.IDS_MUST_BE_ITERABLE)}a(xM,"initializeBatchSearchByHash");function Xh(e){if(!Array.isArray(e))throw e===void 0?new Error(Qt.FETCH_ATTRIBUTES_REQUIRED):new Error(Qt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(Xh,"validateFetchAttributes");function Jo(e,t,r){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.SEARCH_VALUE_REQUIRED);if(r?.length>C5)throw new Error(Qt.SEARCH_VALUE_TOO_LARGE)}a(Jo,"validateComparisonFunctions");function f_(e,t){return t.length===1&&I5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=zo.listDBIs(e)),t}a(f_,"setGetWholeRowAttributes");kM.exports={searchAll:D5,searchAllToMap:P5,count:v5,countAll:M5,equals:U5,startsWith:B5,endsWith:H5,contains:BM,searchByHash:$5,setGetWholeRowAttributes:f_,batchSearchByHash:Y5,batchSearchByHashToMap:K5,checkHashExists:V5,iterateDBI:L5,greaterThan:x5,greaterThanEqual:k5,lessThan:F5,lessThanEqual:G5,between:q5}});var kl=b((Zbe,VM)=>{var FM=require("lodash"),GM=ut(),Be=require("joi"),W5=J(),{hdb_schema_table:E_,checkValidTable:qM,hdb_table:$M,hdb_database:Zh}=di(),{handleHDBError:j5,hdb_errors:Q5}=fe(),{getDatabases:z5}=(Le(),oe(lt)),{HTTP_STATUS_CODES:J5}=Q5,X5=Be.object({database:Zh,schema:Zh,table:$M,search_attribute:E_,search_value:Be.any().required(),get_attributes:Be.array().min(1).items(Be.alternatives(E_,Be.object())).optional(),desc:Be.bool(),limit:Be.number().integer().min(1),offset:Be.number().integer().min(0)}),Z5=Be.object({database:Zh,schema:Zh,table:$M,operator:Be.string().valid("and","or").default("and").lowercase(),offset:Be.number().integer().min(0),limit:Be.number().integer().min(1),get_attributes:Be.array().min(1).items(Be.alternatives(E_,Be.object())).optional(),sort:Be.object({attribute:Be.alternatives(E_,Be.array().min(1)),descending:Be.bool().optional()}).optional(),conditions:Be.array().min(1).items(Be.alternatives(Be.object({operator:Be.string().valid("and","or").default("and").lowercase(),conditions:Be.array()}),Be.object({search_attribute:Be.alternatives(E_,Be.array().min(1)),search_type:Be.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:Be.when("search_type",{switch:[{is:"equals",then:Be.any()},{is:"between",then:Be.array().items(Be.alternatives([Be.string(),Be.number()])).length(2)}],otherwise:Be.alternatives(Be.string(),Be.number())}).required()}))).required()});VM.exports=function(e,t){let r=null;switch(t){case"value":r=GM.validateBySchema(e,X5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(qM("database",e.schema)),i(qM("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=GM.validateBySchema(e,Z5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=W5.checkGlobalSchemaTable(e.schema,e.table);if(s)return j5(new Error,s,J5.NOT_FOUND);let o=z5()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let _=0,E=u.conditions.length;_<E;_++){let f=u.conditions[_];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let d=FM.filter(c,u=>u!=="*"&&!u.startsWith?.("$")&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!FM.some(o,_=>_===u||_.attribute===u||_.attribute===u.attribute));if(d&&d.length>0){let u=d.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var oA=b((tye,YM)=>{"use strict";var e6=ht(),t6=kl(),{getSchemaPath:r6}=gt();YM.exports=n6;function n6(e){let t=t6(e,"hashes");if(t)throw t;let r=r6(e.schema,e.table);return e6.openEnvironment(r,e.table)}a(n6,"initialize")});var aA=b((nye,KM)=>{"use strict";var s6=xl(),i6=oA();KM.exports=o6;async function o6(e){let t=await i6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return s6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(o6,"lmdbGetDataByHash")});var Fl=b((iye,WM)=>{"use strict";var cA=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};WM.exports=cA});var QM=b((cye,jM)=>{"use strict";var aye=Fl(),a6=xl(),c6=oA();jM.exports=l6;async function l6(e){let t=await c6(e),r=global.hdb_schema[e.schema][e.table];return a6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(l6,"lmdbSearchByHash")});var qs=b((uye,zM)=>{"use strict";var lA=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,d=void 0,u=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=d,this.offset=u}};zM.exports=lA});var em=b((_ye,rU)=>{"use strict";var Qr=xl(),u6=ht(),d6=J(),He=Bt(),cc=M(),_6=ji(),JM=Nn().LMDB_ERRORS_ENUM,{getSchemaPath:f6}=gt(),Xi=cc.SEARCH_WILDCARDS;async function E6(e,t,r){let n;e.schema===cc.SYSTEM_SCHEMA_NAME?n=_6[e.table]:n=global.hdb_schema[e.schema][e.table];let s=tU(e,n.hash_attribute,r,t);return ZM(e,s,n.hash_attribute,r)}a(E6,"prepSearch");async function ZM(e,t,r,n){let s=f6(e.schema,e.table),i=await u6.openEnvironment(s,e.table),o=eU(i,e,t,r),c=o.transaction||i;if([He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,He.SEARCH_TYPES.SEARCH_ALL,He.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(h6(e,r)===!1){let u=e.search_attribute;if(u===r)return n?XM(o,()=>!0):o.map(E=>({[r]:E.key}));let _=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?XM(o,_):o.map(_)}let d=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?Qr.batchSearchByHashToMap(c,r,e.get_attributes,d):Qr.batchSearchByHash(c,r,e.get_attributes,d)}a(ZM,"executeSearch");function eU(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 He.SEARCH_TYPES.EQUALS:s=Qr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.CONTAINS:s=Qr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.ENDS_WITH:case He.SEARCH_TYPES._ENDS_WITH:s=Qr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.STARTS_WITH:case He.SEARCH_TYPES._STARTS_WITH:s=Qr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Qr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Qr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case He.SEARCH_TYPES.SEARCH_ALL:return Qr.searchAll(e,n,t.get_attributes,o,c,l);case He.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Qr.searchAllToMap(e,n,t.get_attributes,o,c,l);case He.SEARCH_TYPES.BETWEEN:s=Qr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case He.SEARCH_TYPES.GREATER_THAN:case He.SEARCH_TYPES._GREATER_THAN:s=Qr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.GREATER_THAN_EQUAL:case He.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Qr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.LESS_THAN:case He.SEARCH_TYPES._LESS_THAN:s=Qr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.LESS_THAN_EQUAL:case He.SEARCH_TYPES._LESS_THAN_EQUAL:s=Qr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(eU,"searchByType");function XM(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(XM,"createMapFromIterable");function h6(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(h6,"checkToFetchMore");function tU(e,t,r,n){if(d6.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),Xi.indexOf(s)>-1)return r===!0?He.SEARCH_TYPES.SEARCH_ALL_TO_MAP:He.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Xi[0])<0&&s.indexOf(Xi[1])<0)return c===!0?r===!0?He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:He.SEARCH_TYPES.EQUALS;if(Xi.indexOf(i)>=0&&Xi.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),He.SEARCH_TYPES.CONTAINS;if(Xi.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),He.SEARCH_TYPES.ENDS_WITH;if(Xi.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),He.SEARCH_TYPES.STARTS_WITH;if(s.includes(Xi[0])||s.includes(Xi[1]))return He.SEARCH_TYPES.EQUALS;throw new Error(JM.UNKNOWN_SEARCH_TYPE)}else switch(n){case cc.VALUE_SEARCH_COMPARATORS.BETWEEN:return He.SEARCH_TYPES.BETWEEN;case cc.VALUE_SEARCH_COMPARATORS.GREATER:return He.SEARCH_TYPES.GREATER_THAN;case cc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return He.SEARCH_TYPES.GREATER_THAN_EQUAL;case cc.VALUE_SEARCH_COMPARATORS.LESS:return He.SEARCH_TYPES.LESS_THAN;case cc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return He.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(JM.UNKNOWN_SEARCH_TYPE)}}a(tU,"createSearchTypeFromSearchObject");rU.exports={executeSearch:ZM,createSearchTypeFromSearchObject:tU,prepSearch:E6,searchByType:eU}});var sU=b((hye,nU)=>{"use strict";var Eye=qs(),m6=kl(),p6=J(),S6=M(),T6=em();nU.exports=g6;function g6(e,t){if(!p6.isEmpty(t)&&S6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=m6(e,"value");if(n)throw n;return T6.prepSearch(e,t,!0)}a(g6,"lmdbGetDataByValue")});var h_=b((Sye,iU)=>{"use strict";var pye=qs(),R6=kl(),A6=J(),b6=M(),y6=em();iU.exports=O6;async function O6(e,t){if(!A6.isEmpty(t)&&b6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R6(e,"value");if(n)throw n;return y6.prepSearch(e,t,!1)}a(O6,"lmdbSearchByValue")});var aU=b((Rye,oU)=>{"use strict";var gye=Bt(),uA=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}},dA=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},_A=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};oU.exports={SearchByConditionsObject:uA,SearchCondition:dA,SortAttribute:_A}});var _U=b((Oye,dU)=>{"use strict";var bye=aU().SearchByConditionsObject,N6=qs(),I6=kl(),fA=xl(),tm=Bt(),{Resource:yye}=(Hs(),oe(EA)),uU=em(),w6=iA(),C6=require("lodash"),{getSchemaPath:D6}=gt(),cU=ht(),{handleHDBError:P6,hdb_errors:L6}=fe(),{HTTP_STATUS_CODES:M6}=L6,U6=1e8;dU.exports=v6;async function v6(e){let t=I6(e,"conditions");if(t)throw P6(t,t.message,M6.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=D6(e.schema,e.table),n=await cU.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let d of e.conditions)cU.openDBI(n,d.search_attribute);let i=C6.sortBy(e.conditions,d=>{if(d.estimated_count===void 0){let u=d.search_type;u===tm.SEARCH_TYPES.EQUALS?d.estimated_count=fA.count(n,d.search_attribute,d.search_value):u===tm.SEARCH_TYPES.CONTAINS||u===tm.SEARCH_TYPES.ENDS_WITH?d.estimated_count=1/0:d.estimated_count=U6}return d.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await lU(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let d=n.dbis[s.hash_attribute],u=i.slice(1).map(uU.filterByType),_=u.length,E=fA.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>d.get(f,{transaction:o,lazy:!0})),_>0&&(l=l.filter(f=>{for(let h=0;h<_;h++)if(!u[h](f))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(f=>w6.parseRow(f,E))}else{for(let _=1;_<i.length;_++){let E=i[_],f=await lU(o,e,E,s.hash_attribute);c=c.concat(f)}let d=new Set,u=e.offset||0;c=c.filter(_=>d.has(_)?!1:(d.add(_),!0)).slice(u,e.limit&&e.limit+u),l=fA.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(v6,"lmdbSearchByConditions");async function lU(e,t,r,n){let s=new N6(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===tm.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,uU.searchByType(e,s,i,n).map(o=>o.value)}a(lU,"executeConditionSearch")});var Gl=b((Iye,fU)=>{"use strict";var B6=M().OPERATIONS_ENUM,hA=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=B6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};fU.exports=hA});var mA=b((Cye,RU)=>{"use strict";var pU=qs(),SU=Gl(),TU=h_(),gU=d_(),cn=M(),EU=J(),hU=ht(),{getTransactionAuditStorePath:H6,getSchemaPath:x6}=gt(),mU=V();RU.exports=k6;async function k6(e){try{if(EU.isEmpty(global.hdb_schema[e.schema])||EU.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await F6(e),await G6(e);let t=x6(e.schema,e.table);try{await hU.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")mU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=H6(e.schema,e.table);await hU.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")mU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(k6,"lmdbDropTable");async function F6(e){let t=new pU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await TU(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 SU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await gU(s)}a(F6,"deleteAttributesFromSystem");async function G6(e){let t=new pU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await TU(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 SU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await gU(s)}catch(i){throw i}}a(G6,"dropTableFromSystem")});var bU=b((Pye,AU)=>{"use strict";var q6=require("fs-extra"),$6=qs(),V6=Fl(),Y6=Gl(),K6=mA(),W6=d_(),j6=aA(),Q6=h_(),Zi=M(),{getSchemaPath:z6}=gt(),{handleHDBError:J6,hdb_errors:X6}=fe(),{HDB_ERROR_MSGS:Z6,HTTP_STATUS_CODES:e8}=X6;AU.exports=t8;async function t8(e){let t;try{t=await r8(e.schema);let r=new $6(Zi.SYSTEM_SCHEMA_NAME,Zi.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Zi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Zi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Q6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await K6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Y6(Zi.SYSTEM_SCHEMA_NAME,Zi.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await W6(s);let i=z6(t);await q6.remove(i)}catch(r){throw r}}a(t8,"lmdbDropSchema");async function r8(e){let t=new V6(Zi.SYSTEM_SCHEMA_NAME,Zi.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Zi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await j6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw J6(new Error,Z6.SCHEMA_NOT_FOUND(e),e8.NOT_FOUND,void 0,void 0,!0);return n}a(r8,"validateDropSchema")});var ql=b((Mye,yU)=>{"use strict";var pA=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};yU.exports=pA});var TA=b((Bye,OU)=>{"use strict";var n8=require("fs-extra"),rm=ht(),{getTransactionAuditStorePath:s8}=gt(),SA=Bt(),vye=ql();OU.exports=i8;async function i8(e){let t;try{let r=s8(e.schema,e.table);await n8.mkdirp(r),t=await rm.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{rm.createDBI(t,SA.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),rm.createDBI(t,SA.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),rm.createDBI(t,SA.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(i8,"createTransactionsAuditEnvironment")});var wU=b((kye,IU)=>{"use strict";var gA=M(),NU=ht(),o8=Qa(),{getSystemSchemaPath:a8,getSchemaPath:c8}=gt(),xye=ji(),l8=wh(),RA=Ih(),u8=V(),d8=TA();IU.exports=_8;async function _8(e,t){let r=c8(t.schema,t.table),n=new RA(t.schema,t.table,gA.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new RA(t.schema,t.table,gA.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new RA(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await NU.createEnvironment(r,t.table),e!==void 0){let o=await NU.openEnvironment(a8(),gA.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await o8.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 AA(n),await AA(s),await AA(i)}await d8(t)}catch(o){throw o}}a(_8,"lmdbCreateTable");async function AA(e){try{await l8(e)}catch(t){u8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(AA,"createAttribute")});var DU=b((Gye,CU)=>{"use strict";var f8=t_(),E8=xd(),h8=jh(),m_=M(),m8=Qa().updateRecords,p8=ht(),{getSchemaPath:S8}=gt(),T8=l_(),g8=V();CU.exports=R8;async function R8(e){try{let{schema_table:t,attributes:r}=f8(e);E8(e,r,t.hash_attribute),e.schema!==m_.SYSTEM_SCHEMA_NAME&&(r.includes(m_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(m_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(m_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(m_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await h8(e.hdb_auth_header,t,r),s=S8(e.schema,e.table),i=await p8.openEnvironment(s,e.table),o=await m8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await T8(e,o)}catch(c){g8.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(R8,"lmdbUpdateRecords")});var LU=b(($ye,PU)=>{"use strict";var A8=M().OPERATIONS_ENUM,bA=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=A8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};PU.exports=bA});var UU=b((Kye,MU)=>{"use strict";var Yye=LU(),b8=t_(),y8=xd(),O8=jh(),p_=M(),N8=Qa().upsertRecords,I8=ht(),{getSchemaPath:w8}=gt(),C8=l_(),D8=V(),{handleHDBError:P8,hdb_errors:L8}=fe();MU.exports=M8;async function M8(e){let t;try{t=b8(e)}catch(l){throw P8(l,l.message,L8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;y8(e,n,r.hash_attribute),e.schema!==p_.SYSTEM_SCHEMA_NAME&&(n.includes(p_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(p_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(p_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(p_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await O8(e.hdb_auth_header,r,n),i=w8(e.schema,e.table),o=await I8.openEnvironment(i,e.table),c=await N8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await C8(e,c)}catch(l){D8.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(M8,"lmdbUpsertRecords")});var BU=b((jye,vU)=>{"use strict";var yA=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};vU.exports=yA});var xU=b((zye,HU)=>{"use strict";var OA=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}};HU.exports=OA});var GU=b((Zye,FU)=>{"use strict";var NA=ht(),{getTransactionAuditStorePath:U8}=gt(),Xye=BU(),S_=Bt(),v8=J(),kU=xU(),B8=require("util").promisify,H8=B8(setTimeout),x8=1e4,k8=100;FU.exports=F8;async function F8(e){let t=U8(e.schema,e.table),r=await NA.openEnvironment(t,e.table,!0),n=NA.listDBIs(r);NA.initializeDBIs(r,S_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new kU;do s=await G8(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 H8(k8);while(s.transactions_deleted>0);return i}a(F8,"deleteAuditLogsBefore");async function G8(e,t){let r=new kU;try{let n=e.dbis[S_.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[S_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];v8.isEmpty(c)||(s=e.dbis[S_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[S_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>x8)break}return await s,r}catch(n){throw n}}a(G8,"deleteTransactions")});var $U=b((tOe,qU)=>{"use strict";var IA=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};qU.exports=IA});var YU=b((sOe,VU)=>{"use strict";var q8=qs(),$8=Gl(),nOe=$U(),pi=M(),V8=J(),wA=ht(),Y8=ji(),K8=h_(),W8=d_(),{getSchemaPath:j8}=gt();VU.exports=Q8;async function Q8(e,t=!0){let r;e.schema===pi.SYSTEM_SCHEMA_NAME?r=Y8[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await J8(e),s=j8(e.schema,e.table),i=await wA.openEnvironment(s,e.table);return t===!0&&await z8(e,i,r.hash_attribute),wA.dropDBI(i,e.attribute),n}a(Q8,"lmdbDropAttribute");async function z8(e,t,r){let n=wA.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let d={};for(let u in c)u!==i&&(d[u]=c[u]);s=t.dbis[r].put(o,d,l)}await s}a(z8,"removeAttributeFromAllObjects");async function J8(e){let t=new q8(pi.SYSTEM_SCHEMA_NAME,pi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await K8(t)).filter(o=>o[pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(V8.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new $8(pi.SYSTEM_SCHEMA_NAME,pi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return W8(i)}a(J8,"dropAttributeFromSystem")});var JU=b((aOe,zU)=>{"use strict";var CA=ht(),$l=Bt(),oOe=nn(),DA=M(),KU=J(),{getTransactionAuditStorePath:X8}=gt(),Z8=xl(),nm=vl(),e9=V();zU.exports=t9;async function t9(e){let t=X8(e.schema,e.table),r=await CA.openEnvironment(t,e.table,!0),n=CA.listDBIs(r);CA.initializeDBIs(r,$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case DA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return WU(r,e.search_values);case DA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,n9(r,e.search_values,s);case DA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return r9(r,e.search_values);default:return WU(r)}}a(t9,"readAuditLog");function WU(e,t=[0,Date.now()]){KU.isEmpty(t[0])&&(t[0]=0),KU.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[$l.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 nm,s))}a(WU,"searchTransactionsByTimestamp");function r9(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[$l.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,QU(e,i))}return Object.fromEntries(r)}a(r9,"searchTransactionsByUsername");function n9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let d=t[c],u=Z8.equals(e,$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,$l.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,d);for(let{value:_}of u){let E=Number(_);n.has(E)?n.get(E).push(d.toString()):n.set(E,[d.toString()])}}let s=Array.from(n.keys()),i=QU(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],d=l.timestamp,u=n.get(d);jU(l,"records",r,u,o),jU(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(n9,"searchTransactionsByHashValues");function jU(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 d=s.get(l),u=d[d.length-1];if(u.timestamp===i)u[t]=[c];else{let _=new nm(e.operation,e.user_name,i,void 0);_[t]=[c],d.push(_)}}else{let d=new nm(e.operation,e.user_name,i,void 0);d[t]=[c],s.set(l,[d])}}}a(jU,"loopRecords");function QU(e,t){let r=[];try{let n=e.dbis[$l.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 nm,i);r.push(o)}}catch(i){e9.warn(i)}return r}catch(n){throw n}}a(QU,"batchSearchTransactions")});var ZU=b((dOe,XU)=>{"use strict";var{getSchemaPath:lOe}=gt(),uOe=ht(),{database:s9}=(Le(),oe(lt));XU.exports={writeTransaction:i9};async function i9(e,t,r){return s9({database:e,table:t}).transaction(r)}a(i9,"writeTransaction")});var nv=b((fOe,rv)=>{"use strict";var{getSchemaPath:ev}=gt(),tv=ht();rv.exports={flush:o9,resetReadTxn:a9};async function o9(e,t){return(await tv.openEnvironment(ev(e,t),t.toString())).flushed}a(o9,"flush");async function a9(e,t){try{(await tv.openEnvironment(ev(e,t),t.toString())).resetReadTxn()}catch{}}a(a9,"resetReadTxn")});var av=b((hOe,ov)=>{"use strict";var{Readable:c9}=require("stream"),{getDatabases:l9}=(Le(),oe(lt)),{readSync:u9,openSync:d9,createReadStream:sv}=require("fs"),{open:_9}=require("lmdb"),iv=jd(),f9=Qd(),{AUDIT_STORE_OPTIONS:E9}=(Ki(),oe(cv)),{INTERNAL_DBIS_NAME:h9,AUDIT_STORE_NAME:m9}=Bt();ov.exports=S9;var PA=32768,p9=100;async function S9(e){let t=e.database||e.schema||"data",r=l9()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let d=r[s[0]];if(!d)throw new Error(`Can not find table ${s[0]}`);let u=d.dbisDB,_=_9({noSync:!0,maxDbs:f9.MAX_DBS}),E,f=_.openDB(h9,new iv(!1)),h=u.useReadTransaction(),T=0,S=a(async function(p,y){y.encoding="binary",y.encoder=void 0;let O=_.openDB(p,y),B=u.openDB(p,y);for(let{key:x,version:W,value:q}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=O.put(x,q,W),T++%p9===0&&(await new Promise(z=>setTimeout(z,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:p,value:y}of u.getRange({transaction:h,start:!1}))if(s.some(O=>p.startsWith?.(O+"/"))){f.put(p,y);let[,O]=p.split("/"),B=!O,x=new iv(!B,B);await S(p,x)}e.include_audit&&await S(m9,{...E9}),await E;let R=sv(_.path);return R.headers=l(),R.on("close",()=>{h.done(),_.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=d9(o.path);return o.transaction(()=>{let d=Buffer.alloc(PA);u9(c,d,0,PA),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let _=sv(null,{fd:c,start:PA}),E=new c9.from(async function*(){yield d;for await(let f of _)u.openTimer&&(u.openTimer=0),yield f;u.done()}());return E.headers=l(),E});function l(){let d=new Map;return d.set("content-type","application/octet-stream"),d.set("content-disposition",`attachment; filename="${t}"`),d.set("date",n),d}}a(S9,"getBackup")});var dv=b((pOe,uv)=>{"use strict";var T9=V(),{handleHDBError:g9}=fe(),R9=CD(),A9=wh(),b9=eA(),y9=bM(),O9=d_(),N9=aA(),I9=QM(),w9=sU(),C9=h_(),D9=_U(),P9=bU(),L9=wU(),M9=DU(),U9=UU(),v9=GU(),B9=mA(),H9=YU(),x9=JU(),k9=ZU(),lv=nv(),F9=av(),LA=class extends R9{static{a(this,"LMDBBridge")}async searchByConditions(t){return D9(t)}async getDataByHash(t){return await N9(t)}async searchByHash(t){return await I9(t)}async getDataByValue(t,r){return await w9(t,r)}async searchByValue(t){return await C9(t)}async createSchema(t){return await y9(t)}async dropSchema(t){return await P9(t)}async createTable(t,r){return await L9(t,r)}async dropTable(t){return await B9(t)}async createAttribute(t){return await A9(t)}async createRecords(t){return await b9(t)}async updateRecords(t){return await M9(t)}async upsertRecords(t){try{return await U9(t)}catch(r){throw g9(r,null,null,T9.ERR,r)}}async deleteRecords(t){return await O9(t)}async dropAttribute(t){return await H9(t)}async deleteAuditLogsBefore(t){return await v9(t)}async readAuditLog(t){return await x9(t)}writeTransaction(t,r,n){return k9.writeTransaction(t,r,n)}flush(t,r){return lv.flush(t,r)}resetReadTxn(t,r){return lv.resetReadTxn(t,r)}getBackup(t){return F9(t)}};uv.exports=LA});function Tv(e){UA=e}function V9(){$9=setInterval(function(){for(let e of MA)if(e.stale){let t=e[xe]?.url;hv.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},q9).unref()}var vA,Ev,hv,mv,pv,Sv,_v,MA,G9,T_,fv,UA,lc,sm,q9,$9,im=De(()=>{vA=v(nn()),Ev=v(fe()),hv=v(V());Hs();mv=v(te()),pv=v(M()),Sv=v(J()),_v=100,MA=new Set,G9=(0,Sv.convertToMS)(mv.get(pv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(Tv,"replicationConfirmation");lc=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),MA.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(MA.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(T_&&!this.overloadChecked&&performance.now()-fv>G9)throw new Ev.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=t.timestamp||(0,vA.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let _=this.validated;this.validated=this.writes.length;for(let f=_;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=_;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let T=_;T<this.validated;T++){let S=this.writes[T];if(!S)continue;let R=S[f===0?"before":"beforeIntermediate"];if(R){let p=R();h?h.push?h.push(p):h=[h,p]:h=p}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(_){throw this.abort(),_}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(_=>_);let c=a(_=>{_.commit(r,_.entry,n)},"doWrite"),l=a(()=>{let _=this.writes[o++];if(_)if(_.key){n>0&&(_.entry=_.store.getEntry(_.key));let E=_.store.ifVersion(_.key,_.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),d=this.lmdbDb;if(this.writes.length>0&&(d?.retryRisk&&(d.retryRisk*=.99),this.writes.length+(d?.retryRisk||0)<_v>>n?l():s=this.writes[0].store.transaction(()=>{for(let _ of this.writes)_.entry=_.store.getEntry(_.key),c(_);return!0})),s)return T_||(T_=s,fv=performance.now(),T_.then(()=>{T_=null})),s.then(_=>{if(_){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let E=this.writes[0].store.rootStore.databaseName,f=this.writes[this.writes.length-1];UA&&f&&i.push(UA(E,f.store.getEntry(f.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return d&&(d.retryRisk=(d.retryRisk||0)+_v/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let u={txnTime:r};if(this.next){let _=this.next?.commit(t);if(_?.then)return _?.then(E=>({txnTime:r,next:E}));u.next=_}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},sm=class extends lc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,vA.getNextMonotonicTime)())}getReadTxn(){}},q9=3e4;a(V9,"startMonitoringTxns");V9()});function Ct(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 lc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[xe]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var gv,uc=De(()=>{gv=v(Vi());Hs();im();a(Ct,"transaction");(0,gv._assignPackageExport)("transaction",Ct);Ct.commit=function(e){let t=(e[xe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ct.abort=function(e){let t=(e[xe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var wv={};et(wv,{ResourceBridge:()=>xA});function kA({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 Av(e,t){let r=Si(e),n=kA(e,r);if(!r)throw new $s.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache},o;Ct(i,()=>new Promise(d=>o=d));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let d=c[l++],u;try{u=await r.get({id:d,lazy:s,select:n},i),u=u&&am(u)}catch(_){u={message:_.toString()}}return t?{value:{key:d,value:u}}:{value:u}}else return o(),{done:!0}},return(d){return o(),{value:d,done:!0}},throw(d){return o(),{done:!0}}}}}}function Si(e){let t=e.database||e.schema||K9,r=mt()[t];if(!r)throw(0,$s.handleHDBError)(new Error,Y9.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function bv(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*yv(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:d,value:u}=o;if(s?.timestamp===d)s.hash_values.push(l),s.records.push(u);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:d,hash_values:[l],records:[u]}}}s&&(yield s)}var Ov,om,$s,Nv,Vs,BA,HA,Iv,Y9,K9,W9,j9,Rv,xA,Cv=De(()=>{"use strict";Ov=v(dv()),om=v(kl()),$s=v(fe());Le();Nv=v(t_()),Vs=v(M()),BA=v(Ji()),HA=v(Gs()),Iv=v(J());uc();cm();({HDB_ERROR_MSGS:Y9}=$s.hdb_errors),K9="data",W9=1e4,j9=10,xA=class extends Ov.default{static{a(this,"ResourceBridge")}constructor(t){super(t),Rv=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,om.default)(t,"conditions");if(r)throw(0,$s.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Si(t);if(!n)throw new $s.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:kA(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new $s.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}Et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await Si(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Si(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(d=>{if(!d){let{value:u,version:_}=r.primaryStore.getEntry(o);return i(o,u,_)}})),"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(d=>setImmediate(d));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Si(t).dropTable()}createSchema(t){return Vl({database:t.schema,table:null}),BA.signalSchemaChange(new HA.SchemaEventMsg(process.pid,Vs.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await FA(t.schema),BA.signalSchemaChange(new HA.SchemaEventMsg(process.pid,Vs.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,Rv.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,Nv.default)(t),s,i=mt()[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),Ct(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],d=[];for(let u of t.records){let _=u[i.primaryKey],E=_!=null&&await i.get(_,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){d.push(u[i.primaryKey]);continue}E&&(E=am(E));for(let f in u)if(Object.prototype.hasOwnProperty.call(u,f)){let h=u[f];if(typeof h=="function")try{let T=h([[E]]);Array.isArray(T)&&(h=T[0].func_val,u[f]=h)}catch(T){throw T.message+="Trying to set key "+f+" on object"+JSON.stringify(u),T}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(u,f)||(u[f]=E[f]);await(_==null?i.create(u,o):i.put(u,o)),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:d}})}async deleteRecords(t){let r=mt()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Ct(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 bv(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=mt()[t.schema][t.table];if(!r.createdTimeProperty)throw new $s.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:Vs.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],d=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,Iv.async_set_timeout)(j9),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%W9===0&&await d();return l.length>0&&await d(),s?bv(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,om.default)(t,"hashes");if(r)throw r;return Av(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of Av(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Vs.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,om.default)(t,"value");if(n)throw n;let s=Si(t);if(!s)throw new $s.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===Vs.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:kA(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async getDataByValue(t,r){let n=new Map,s=Si(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){Si({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Si(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=Si(t),n={};switch(t.search_type){case Vs.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.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 Vs.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of yv(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return yv(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(kA,"getSelect");a(Av,"getRecords");a(Si,"getTable");a(bv,"createDeleteResponse");a(yv,"groupRecordsInHistory")});var Pn=b((LOe,Dv)=>{"use strict";var{ResourceBridge:Q9}=(Cv(),oe(wv)),z9=te();z9.initSync();var lm;function J9(){return lm||(lm=new Q9,lm)}a(J9,"getBridge");Dv.exports=J9()});var Uv=b((UOe,Mv)=>{"use strict";var Pv=require("lodash"),g_=require("mathjs"),X9=require("jsonata"),Lv=J();Mv.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?Pv.uniqWith(e,Pv.isEqual):e,searchJSON:Z9,mad:R_.bind(null,g_.mad),mean:R_.bind(null,g_.mean),mode:R_.bind(null,g_.mode),prod:R_.bind(null,g_.prod),median:R_.bind(null,g_.median)};function R_(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(R_,"aggregateFunction");function Z9(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=X9(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(Z9,"searchJSON")});var Bv=b((BOe,vv)=>{"use strict";var nr=require("moment"),GA="YYYY-MM-DDTHH:mm:ss.SSSZZ";nr.suppressDeprecationWarnings=!0;vv.exports={current_date:()=>nr().utc().format("YYYY-MM-DD"),current_time:()=>nr().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return nr(e).utc().format("YYYY");case"month":return nr(e).utc().format("MM");case"day":return nr(e).utc().format("DD");case"hour":return nr(e).utc().format("HH");case"minute":return nr(e).utc().format("mm");case"second":return nr(e).utc().format("ss");case"millisecond":return nr(e).utc().format("SSS");default:break}},date:e=>nr(e).utc().format(GA),date_format:(e,t)=>nr(e).utc().format(t),date_add:(e,t,r)=>nr(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>nr(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=nr(e).utc(),s=nr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>nr().utc().valueOf(),get_server_time:()=>nr().format(GA),offset_utc:(e,t)=>nr(e).utc().utcOffset(t).format(GA)}});var Fv=b((HOe,kv)=>{"use strict";var e7=require("@turf/area"),t7=require("@turf/length"),r7=require("@turf/circle"),n7=require("@turf/difference"),s7=require("@turf/distance"),i7=require("@turf/boolean-contains"),o7=require("@turf/boolean-equal"),a7=require("@turf/boolean-disjoint"),c7=require("@turf/helpers"),Hv=M(),qe=J(),eo=V();kv.exports={geoArea:l7,geoLength:u7,geoCircle:d7,geoDifference:_7,geoDistance:xv,geoNear:f7,geoContains:E7,geoEqual:h7,geoCrosses:m7,geoConvert:p7};function l7(e){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return e7.default(e)}catch(t){return eo.trace(t,e),NaN}}a(l7,"geoArea");function u7(e,t){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return t7.default(e,{units:t||"kilometers"})}catch(r){return eo.trace(r,e),NaN}}a(u7,"geoLength");function d7(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return r7.default(e,t,{units:r||"kilometers"})}catch(n){return eo.trace(n,e,t),NaN}}a(d7,"geoCircle");function _7(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 n7(e,t)}catch(r){return eo.trace(r,e,t),NaN}}a(_7,"geoDifference");function xv(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 s7.default(e,t,{units:r||"kilometers"})}catch(n){return eo.trace(n,e,t),NaN}}a(xv,"geoDistance");function f7(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 xv(e,t,n)<=r}catch(s){return eo.trace(s,e,t),!1}}a(f7,"geoNear");function E7(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 i7.default(e,t)}catch(r){return eo.trace(r,e,t),!1}}a(E7,"geoContains");function h7(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 o7.default(e,t)}catch(r){return eo.trace(r,e,t),!1}}a(h7,"geoEqual");function m7(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!a7.default(e,t)}catch(r){return eo.trace(r,e,t),!1}}a(m7,"geoCrosses");function p7(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)),c7[t](e,r)}a(p7,"geoConvert")});var um=b((kOe,Gv)=>{var dc=Uv(),xn=Bv(),Ti=Fv();Gv.exports=e=>{e.aggr.mad=e.aggr.MAD=dc.mad,e.aggr.mean=e.aggr.MEAN=dc.mean,e.aggr.mode=e.aggr.MODE=dc.mode,e.aggr.prod=e.aggr.PROD=dc.prod,e.aggr.median=e.aggr.MEDIAN=dc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=dc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=dc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=xn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=xn.current_time,e.fn.extract=e.fn.EXTRACT=xn.extract,e.fn.date=e.fn.DATE=xn.date,e.fn.date_format=e.fn.DATE_FORMAT=xn.date_format,e.fn.date_add=e.fn.DATE_ADD=xn.date_add,e.fn.date_sub=e.fn.DATE_SUB=xn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=xn.date_diff,e.fn.now=e.fn.NOW=xn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=xn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=xn.get_server_time,e.fn.getdate=e.fn.GETDATE=xn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=xn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ti.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ti.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ti.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ti.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ti.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ti.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ti.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ti.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ti.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ti.geoNear}});var Yv=b((FOe,Vv)=>{"use strict";var A_=require("lodash"),ln=require("alasql");ln.options.cache=!1;var S7=um(),qv=require("clone"),dm=require("recursive-iterator"),Ue=V(),Ze=J(),Yl=Pn(),T7=M(),{hdb_errors:g7}=fe(),{getDatabases:$v}=(Le(),oe(lt)),R7="IS NULL",Ys="There was a problem performing this search. Please check the logs and try again.";S7(ln);var qA=class{static{a(this,"SQLSearch")}constructor(t,r){if(Ze.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(),Ze.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Ze.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(Ys)}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(Ys)}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(Ys)}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(Ys)}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(Ys)}}_getColumns(){let t=new dm(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=A_.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(Ze.isEmpty(this.statement.where)){Ue.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new dm(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 ln.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 ln.yy.LogicValue({value:i}):n instanceof ln.yy.StringValue&&Ze.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new ln.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 dm(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(T7.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 d=0;d<l.length;d++)if(l[d].value)n.add(l[d].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&&A_.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 ln.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(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(R7)>-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=A_.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,d=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!Ze.isEmpty(this.exact_search_values[d])&&!this.exact_search_values[d].ignore&&!Ze.isEmptyOrZeroLength(this.exact_search_values[d].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[d].values);let u=await Yl.getDataByHash(c);for(let _ of c.hash_values)u.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(u){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(u),new Error(Ys)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[d].values).map(async u=>{let _={...c};_.search_value=u;let E=await Yl.getDataByValue(_);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(u){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(u),new Error(Ys)}else if(!Ze.isEmpty(this.comparator_search_values[d])&&!this.comparator_search_values[d].ignore&&!Ze.isEmptyOrZeroLength(this.comparator_search_values[d].comparators))try{let u=this.comparator_search_values[d].comparators;for(let _=0,E=u.length;_<E;_++){let f=u[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await Yl.getDataByValue(c,f.operation);if(l)for(let[T]of h)this.data[i].__merged_data[T]||(this.data[i].__merged_data[T]=[...n[i]],this._setMergedHashAttribute(i,T));else for(let[T,S]of h)this.data[i].__merged_data[T]?this._updateMergedAttribute(i,T,s.attribute,S[s.attribute]):(this.data[i].__merged_data[T]=[...n[i]],this._updateMergedAttribute(i,T,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,T))}}catch(u){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(u),new Error(Ys)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await Yl.getDataByValue(c);if(l)for(let[_]of u)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of u)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(u){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(u),new Error(Ys)}}}_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 ln.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 ln.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new ln.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 ln.yy.FuncValue:new ln.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,T=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${T}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${T}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let d="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(d="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let u="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",_=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${d} ${u} ${_}`,h=this._convertColumnsToIndexes(f,s);E=await ln.promise(h,t),t=null}catch(f){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let T=E[f];o.forEach(S=>{T[S.key]!==null&&T[S.key]!==void 0&&S.keys.add(T[S.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),T=A_.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,R=T.length;S<R;S++){let p=T[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[p]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new dm(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=A_.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(Ys)}}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 u in i)o.push(i[u][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 Yl.getDataByHash(c),d=s.columns.length;for(let u=0,_=o.length;u<_;u++){let E=o[u],f=l.get(E);for(let h=0;h<d;h++){let T=s.columns[h],S=f[T]===void 0?null:f[T];this.data[n].__merged_data[E].push(S)}}}}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 ln.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(g7.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],d=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(d,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),d=`[${c}]`;n=n.replace(l,d)});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 Yl.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(Ys)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Vv.exports=qA});var Vr=b((qOe,Kv)=>{"use strict";var A7=ID();Kv.exports={searchByConditions:y7,searchByHash:O7,searchByValue:N7,search:I7};var $A=Pn(),{transformReq:VA}=J(),b7=Yv();async function y7(e){return VA(e),$A.searchByConditions(e)}a(y7,"searchByConditions");async function O7(e){VA(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of $A.searchByHash(e))r&&t.push(r);return t}a(O7,"searchByHash");async function N7(e){VA(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of $A.searchByValue(e))t.push(r);return t}a(N7,"searchByValue");function I7(e,t){try{let r=new A7(e);r.validate(),new b7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(I7,"search")});var _m=b((VOe,Wv)=>{"use strict";var w7=Pn();Wv.exports={writeTransaction:C7};function C7(e,t,r){return w7.writeTransaction(e,t,r)}a(C7,"writeTransaction")});var Jv=b((WOe,zv)=>{"use strict";var D7=Vr(),P7=as(),jv=V(),L7=Yr(),KOe=_m(),M7=require("clone"),KA=require("alasql"),U7=um(),Qv=require("util"),v7=Qv.promisify(P7.getTableSchema),B7=Qv.promisify(D7.search),H7=M(),YA=J();U7(KA);zv.exports={update:k7};var x7="There was a problem performing this update. Please check the logs and try again.";async function k7({statement:e,hdb_user:t}){let r=await v7(e.table.databaseid,e.table.tableid),n=F7(e.columns);YA.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=M7(s),c=YA.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,d=KA.parse(l).statements[0],u=await B7(d),_=G7(n,u);return q7(o,_,t)}a(k7,"update");function F7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=KA.compile(`SELECT ${r.expression.toString()} AS [${H7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw jv.error(t),new Error(x7)}}a(F7,"createUpdateRecord");function G7(e,t){return YA.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(G7,"buildUpdateRecords");async function q7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await L7.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){jv.error(`Error delete new_attributes from update response: ${i}`)}return s}a(q7,"updateRecords")});var Zv=b((JOe,Xv)=>{var $7=require("alasql"),V7=Vr(),Y7=V(),K7=Pn(),jA=require("util"),WA=J(),W7=M(),j7=as(),QOe=_m(),zOe=Yr(),Q7="record",z7="successfully deleted",J7=jA.callbackify(tee),X7=jA.promisify(V7.search),Z7=jA.promisify(j7.getTableSchema);Xv.exports={convertDelete:J7};function eee(e){return`${e.deleted_hashes.length} ${Q7}${e.deleted_hashes.length===1?"":"s"} ${z7}`}a(eee,"generateReturnMessage");async function tee({statement:e,hdb_user:t}){let r=await Z7(e.table.databaseid,e.table.tableid);WA.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=WA.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=$7.parse(o).statements[0],l={operation:W7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await X7(c);let d=await K7.deleteRecords(l);return WA.isEmptyOrZeroLength(d.message)&&(d.message=eee(d)),delete d.txn_time,d}catch(d){throw Y7.error(d),d.hdb_code?d.message:d}}a(tee,"convertDelete")});var s0=b((ZOe,n0)=>{"use strict";var ree=fi(),{hdb_errors:e0}=fe(),{getDatabases:t0}=(Le(),oe(lt));n0.exports={checkSchemaExists:r0,checkSchemaTableExists:nee,schema_describe:ree};async function r0(e){if(!t0()[e])return e0.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(r0,"checkSchemaExists");async function nee(e,t){let r=await r0(e);if(r)return r;if(!t0()[e][t])return e0.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(nee,"checkSchemaTableExists")});var Kl=b((tNe,see)=>{see.exports={name:"harperdb",version:"4.4.0-beta.2",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc --no-clean --reporter=lcovonly npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:replication && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test",format:"prettier .","format:fix":"npm run format -- --write",lint:"eslint .","lint:fix":"npm run lint -- --fix"},dependencies:{"@aws-sdk/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.6.0",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.28.1","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.9.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.1.3",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.0",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.2",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^1.1.0","serve-static":"2.1.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.23.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.5.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^7.18.0","@typescript-eslint/parser":"^7.18.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",eslint:"^8.57.0","eslint-config-prettier":"8.3.0","eslint-plugin-sonarjs":"^2.0.2",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^10.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"3.3.3",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.4.2","why-is-node-still-running":"^1.0.0"},overrides:{alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var I_={};et(I_,{addAnalyticsListener:()=>N_,recordAction:()=>gr,recordActionBinary:()=>kn,setAnalyticsEnabled:()=>iee});function iee(e){f0=e}function gr(e,t,r,n,s){if(!f0)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=hm.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let d=c;o.values=c=new Float32Array(l*2),c.set(d),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},hm.set(i,o)}fm||oee()}function kn(e,t,r,n,s){gr(!!e,t,r,n,s)}function N_(e){m0.push(e)}function oee(){fm=performance.now(),setTimeout(async()=>{let e=performance.now()-fm;fm=0;let t=[],r={time:Date.now(),period:e,threadId:_c.threadId,metrics:t};for(let[s,i]of hm){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,d=[],u;for(let _ of p0){let E=Math.floor(c*_),f=o[E-1];if(E>l){let h=E-l;if(f===u){let T=d[d.length-1];typeof T=="number"?d[d.length-1]={value:T,count:1+h}:T.count+=h}else d.push(h>1?{value:f,count:h}:f),u=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:d,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 S0()}let n=process.memoryUsage();t.push({metric:"memory",threadId:_c.threadId,byThread:!0,...n});for(let s of m0)s(t);hm=new Map,_c.parentPort?_c.parentPort.postMessage({type:h0,report:r}):R0({report:r})},E0).unref()}async function aee(e,t=6e4){let r=JA(),n=T0(),s=new Promise(T=>{let S=performance.now();setImmediate(()=>{let R=performance.now();R-S>5e3&&(0,b_.warn)("Unusually high event queue latency on the main thread of "+Math.round(R-S)+"ms"),S=performance.now()}),n.primaryStore.prefetch([1],()=>{let R=performance.now();R-S>5e3&&(0,b_.warn)("Unusually high task queue latency on the main thread of "+Math.round(R-S)+"ms"),T(R-S)})}),i;for(let T of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(T.value?.time){i=T.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,d=[],u;for(let{key:T,value:S}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!S)continue;if(o){if(T>o+t)break}else o=T;u=T;let{metrics:R,threadId:p}=S;for(let y of R||[]){let{path:O,method:B,type:x,metric:W,count:q,total:z,distribution:_e,threads:X,...ue}=y;q||(q=1);let j=W+(O?"-"+O:"");B!==void 0&&(j+="-"+B),x!==void 0&&(j+="-"+x);let ie=c.get(j);if(ie){if(ie.threads){let Ie=ie.threads[p];if(Ie)ie=Ie;else{ie.threads[p]={...ue};continue}}ie.count||(ie.count=1);let ye=ie.count;for(let Ie in ue){let Me=ue[Ie];typeof Me=="number"&&(ie[Ie]=(ie[Ie]*ye+Me*q)/(ye+q))}ie.count+=q,z>=0&&(ie.total+=z,ie.ratio=ie.total/ie.count)}else ie={period:t,...y},delete ie.distribution,c.set(j,ie),ie.byThread&&(ie.threads=[],ie.threads[p]={...ue},d.push(ie));if(_e){_e=_e.map(Ie=>typeof Ie=="number"?{value:Ie,count:1}:Ie);let ye=l.get(j);ye?ye.push(..._e):l.set(j,_e)}}await S0()}for(let T of d){let{path:S,method:R,type:p,metric:y,count:O,total:B,distribution:x,threads:W,...q}=T;W=W.filter(z=>z);for(let z in q){if(typeof T[z]!="number")continue;let _e=0;for(let X of W){let ue=X[z];typeof ue=="number"&&(_e+=ue)}T[z]=_e}T.count=W.length,delete T.threads,delete T.byThread}for(let[T,S]of l){let R=c.get(T);S.sort((Ie,Me)=>Ie.value>Me.value?1:-1);let p=R.count-1,y=[],O=0,B=0,x;for(let Ie of p0){let Me=p*Ie;for(;O<Me;)x=S[B++],O+=x.count,B===1&&O--;let tn=S[B>1?B-2:0];x||(x=S[0]),y.push(x.value-(x.value-tn.value)*(O-Me)/x.count)}let[W,q,z,_e,X,ue,j,ie,ye]=y;Object.assign(R,{p1:W,p10:q,p25:z,median:_e,p75:X,p90:ue,p95:j,p99:ie,p999:ye})}let _;for(let[T,S]of c)S.id=(0,Em.getNextMonotonicTime)(),S.time=u,n.primaryStore.put(S.id,S,{append:!0}).then(R=>{R||n.primaryStore.put(S.id,S)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let T=(0,Em.getNextMonotonicTime)(),S={id:T,metric:"main-thread-utilization",idle:f-i0,active:h-o0,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(T,S,{append:!0}).then(R=>{R||n.primaryStore.put(T,S)})}i0=f,o0=h}async function a0(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function JA(){return c0||(c0=Et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function T0(){return l0||(l0=Et({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function uee(){g0=!0;let e=(0,O_.get)(zA.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await aee(E0,e),await a0(JA(),cee),await a0(T0(),lee)},Math.min(e/2,2147483647)).unref()}function R0(e,t){let r=e.report;r.threadId=t?.threadId||_c.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(u0+=n.mean*n.count);r.totalBytesProcessed=u0,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(d0.get(t))}),d0.set(t,t.performance.eventLoopUtilization())),r.id=(0,Em.getNextMonotonicTime)(),JA().primaryStore.put(r.id,r),g0||uee(),dee&&(A0=fee(r))}async function fee(e){if(await A0,!Xo){let r=(0,y_.dirname)((0,b_.getLogFilePath)());try{Xo=await(0,QA.open)((0,y_.join)(r,"analytics.log"),"r+")}catch{Xo=await(0,QA.open)((0,y_.join)(r,"analytics.log"),"w+")}}let t=(await Xo.stat()).size;if(t>_ee){let r=Buffer.alloc(t);await Xo.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Xo.write(r,{position:0}),await Xo.truncate(r.length),t=r.length}await Xo.write(JSON.stringify(e)+`
|
|
12
|
+
`,t)}var _c,_0,b_,y_,QA,Em,O_,zA,hm,f0,fm,E0,h0,m0,p0,i0,o0,S0,cee,lee,c0,l0,g0,u0,d0,dee,A0,Xo,_ee,gi=De(()=>{_c=require("worker_threads"),_0=v(it());Le();b_=v(V()),y_=require("path"),QA=require("fs/promises"),Em=v(nn()),O_=v(te()),zA=v(M());$r();(0,O_.initSync)();hm=new Map,f0=(0,O_.get)(zA.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(iee,"setAnalyticsEnabled");a(gr,"recordAction");st.recordAnalytics=gr;a(kn,"recordActionBinary");fm=0,E0=1e3,h0="analytics-report",m0=[];a(N_,"addAnalyticsListener");p0=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(oee,"sendAnalytics");a(aee,"aggregation");i0=0,o0=0,S0=a(()=>new Promise(setImmediate),"rest");a(a0,"cleanup");cee=36e5,lee=31536e6;a(JA,"getRawAnalyticsTable");a(T0,"getAnalyticsTable");(0,_0.setChildListenerByType)(h0,R0);a(uee,"startScheduledTasks");u0=0,d0=new Map,dee=!1;a(R0,"recordAnalytics");_ee=1e6;a(fee,"logAnalytics")});var rb=b((ENe,U0)=>{"use strict";var{decode:Eee}=require("msgpackr"),{isMainThread:dNe,parentPort:_Ne,threadId:fNe}=require("worker_threads"),Sm=kt(),Wl=dt(),eb=M(),zr=V(),ZA=te(),hee=M(),{onMessageByType:mee}=it(),N0=zi(),{recordAction:b0,recordActionBinary:pee}=(gi(),oe(I_)),{publishToStream:See}=Sm,{ConsumerEvents:y0}=require("nats"),Tee=Vr(),{promisify:gee}=require("util"),I0=gee(setTimeout),Tm=1e4,gm,pm,Ree,Aee,w0,w_=new Map,jl=new Map;U0.exports={initialize:C0,ingestConsumer:tb,setSubscription:bee,setIgnoreOrigin:Nee,getDatabaseSubscriptions:Oee,updateConsumer:D0};async function C0(){mee(eb.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await D0(n)}),w0=!0,zr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await Sm.getNATSReferences();gm=e,pm=e.info.server_name,Ree=t,Aee=r}a(C0,"initialize");async function D0(e){if(e.status==="start"){let{js:t,jsm:r}=await P0(e.node_domain_name);tb(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=w_.get(e.stream_name+e.node_domain_name);t&&(zr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),w_.set(e.stream_name+e.node_domain_name,"close")),jl.get(e.node_domain_name)==="failed"&&jl.set(e.node_domain_name,"close")}}a(D0,"updateConsumer");var Rm=new Map;function bee(e,t,r){let n=Rm.get(e);n||Rm.set(e,n=new Map),n.set(t,r),w0||C0().then(yee)}a(bee,"setSubscription");async function yee(){let e=await Tee.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Wl.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await P0(r),!n))break;let{schema:o,table:c}=i,l=N0.createNatsTableStreamName(o,c);tb(l,n,s,r)}}}a(yee,"accessConsumers");async function P0(e){let t,r,n=1;for(;!r;)try{t=await gm.jetstream({domain:e}),r=await gm.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(jl.get(e)==="close")break;jl.set(e,"failed"),n%10===1&&zr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<Tm?n++*100:Tm;await I0(i)}return{js:t,jsm:r}}a(P0,"connectToRemoteJS");function Oee(){return Rm}a(Oee,"getDatabaseSubscriptions");var L0;function Nee(e){L0=e}a(Nee,"setIgnoreOrigin");var M0=100,O0=new Array(M0),mm=0;async function tb(e,t,r,n){let{connection:s}=await Sm.getNATSReferences();gm=s,pm=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,pm),zr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(d){if(jl.get(n)==="close")break;o%10===1&&zr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",d.message),d.code==="404"&&(zr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await Sm.createConsumer(r,e,pm,new Date(Date.now()).toISOString()));let u=o++*100<Tm?o++*100:Tm;await I0(u)}let c=!1,l;for(;!c;){if(w_.get(e+n)==="close"||jl.get(n)==="close"){w_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:ZA.get(eb.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),w_.set(e+n,l);let d=!1;(async()=>{for await(let u of await l.status())if(u.type===y0.ConsumerDeleted&&(await l.close(),c=!0),u.type===y0.HeartbeatsMissed){let _=u.data;zr.trace(`${_} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),_===100&&(zr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),d=!0)}})();try{for await(let u of l)await O0[mm],O0[mm]=Iee(u).catch(_=>{zr.error(_)}),++mm>=M0&&(mm=0)}catch(u){u.message==="consumer deleted"?(zr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):zr.error("Error consuming clustering ingest, restarting consumer",u)}}}a(tb,"ingestConsumer");async function Iee(e){let t=Eee(e.data);b0(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),zr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=ZA.get(eb.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Wl.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Wl.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Wl.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!L0),pee(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Wl.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:d,records:u,hash_values:_,__origin:E,expiresAt:f}=t;zr.trace("processing message:",o,c,d,(u?"records: "+u.map(B=>B?.id):"")+(_?"ids: "+_:""),"with sequence:",e.seq),zr.trace(`messageProcessor nats msg id: ${e.headers.get(Wl.MSG_HEADERS.NATS_MSG_ID)}`);let h;u||(u=_);let T=new Promise(B=>h=B),{timestamp:S,user:R,node_name:p}=E||{},y=Rm.get(c)?.get(d);if(!y)throw new Error(`Missing table for replication message: ${d}`);if(o==="define_schema")t.type=o,t.onCommit=h,y.send(t);else if(u.length===1&&!l)y.send({type:XA(o),value:u[0],id:_?.[0],expiresAt:f,timestamp:S,table:d,onCommit:h,user:R,nodeName:p});else{let B=u.map((x,W)=>({type:XA(o),value:x,expiresAt:f,id:_?.[W],table:d}));for(;l;)B.push({type:XA(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;y.send({type:"transaction",writes:B,table:d,timestamp:S,onCommit:h,user:R,nodeName:p})}ZA.get(hee.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&See(e.subject.split(".").slice(0,-1).join("."),N0.createNatsTableStreamName(c,d),e.headers,e.data),await T;let O=Date.now()-S;S&&b0(O,"replication-latency",e.subject,o,"ingest")}catch(o){zr.error(o)}e.ack()}a(Iee,"messageProcessor");function XA(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(XA,"convertOperation")});var kt=b((RNe,J0)=>{"use strict";var Rr=te();Rr.initSync();var wee=require("fs-extra"),Cee=require("semver"),P_=require("path"),{monotonicFactory:Dee}=require("ulidx"),B0=Dee(),Pee=require("util"),H0=require("child_process"),Lee=Pee.promisify(H0.exec),Mee=H0.spawn,Cr=dt(),Qe=M(),Am=J(),Ks=V(),bm=zi(),Uee=_m(),C_=wt(),{broadcast:vee,onMessageByType:Bee,getWorkerIndex:Hee}=it(),{isMainThread:x0}=require("worker_threads"),{Encoder:xee,decode:ob}=require("msgpackr"),k0=new xee,{isEmpty:mc}=Am,F0=vn(),mNe=48*36e11;x0&&Bee(Qe.ITC_EVENT_TYPES.RESTART,()=>{un=void 0,hc=void 0});var{connect:kee,StorageType:Fee,RetentionPolicy:Gee,AckPolicy:ab,DeliverPolicy:cb,DiscardPolicy:qee,NatsConnection:pNe,JetStreamManager:SNe,JetStreamClient:TNe,StringCodec:gNe,JSONCodec:$ee,createInbox:lb,headers:Vee,ErrorCode:v0}=require("nats"),{PACKAGE_ROOT:Yee}=M(),Kee=Kl(),{recordAction:Wee}=(gi(),oe(I_)),G0=$ee(),jee="clustering",Qee=Kee.engines[Cr.NATS_SERVER_NAME],zee=P_.join(Yee,"dependencies"),ib=P_.join(zee,`${process.platform}-${process.arch}`,Cr.NATS_BINARY_NAME),nb,sb,D_,fc,Ec;J0.exports={runCommand:q0,checkNATSServerInstalled:Jee,createConnection:ub,getConnection:L_,getJetStreamManager:M_,getJetStream:V0,getNATSReferences:Ri,getServerList:Zee,createLocalStream:db,listStreams:Y0,deleteLocalStream:ete,getServerConfig:Ql,listRemoteStreams:tte,viewStream:rte,viewStreamIterator:nte,publishToStream:ste,request:ate,reloadNATS:_b,reloadNATSHub:cte,reloadNATSLeaf:lte,extractServerName:ote,requestErrorHandler:ute,createLocalTableStream:Q0,createTableStreams:fte,purgeTableStream:z0,purgeSchemaTableStreams:Ete,getStreamInfo:hte,updateLocalStreams:pte,closeConnection:Xee,getJsmServerName:ym,addNatsMsgHeader:K0,clearClientCache:$0,updateRemoteConsumer:dte,createConsumer:W0,updateConsumerIterator:_te};async function q0(e,t=void 0){let{stdout:r,stderr:n}=await Lee(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
11
13
|
`,""));return r.replace(`
|
|
12
|
-
`,"")}a(cU,"runCommand");async function U8(){try{await d8.access(tR)}catch{return!1}let e=await cU(`${tR} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return _8.eq(t,P8)}a(U8,"checkNATSServerInstalled");async function oR(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await oU.getClusterUser();if(Ea(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Ts.trace("create nats connection called");let i=await A8({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:_r.get($e.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:_r.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:_r.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Ts.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Ts.error("Error with Nats client connection, connection closed",o),lU()}),i}a(oR,"createConnection");function lU(){zr=void 0,da=void 0,_a=void 0,fa=void 0}a(lU,"clearClientCache");async function v8(){zr&&(await zr.drain(),zr=void 0,da=void 0,_a=void 0,fa=void 0)}a(v8,"closeConnection");var zr,fa;async function ad(){return fa||(fa=oR(_r.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),zr=await fa),zr||fa}a(ad,"getConnection");async function cd(){if(da)return da;Ea(zr)&&await ad();let{domain:e}=Uc($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Ea(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return da=await zr.jetstreamManager({domain:e,timeout:6e4}),da}a(cd,"getJetStreamManager");async function uU(){if(_a)return _a;Ea(zr)&&await ad();let{domain:e}=Uc($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Ea(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return _a=zr.jetstream({domain:e,timeout:6e4}),_a}a(uU,"getJetStream");async function Ks(){let e=zr||await ad(),t=da||await cd(),r=_a||await uU();return{connection:e,jsm:t,js:r}}a(Ks,"getNATSReferences");async function x8(e){let t=_r.get($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await oU.getClusterUser(),s=await oR(t,r,n),i=iR(),o=s.subscribe(i),c=[],l,d=(async()=>{for await(let u of o){let _=aU.decode(u.data);_.response_time=Date.now()-l,c.push(_)}})();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 HE.async_set_timeout(e),await o.drain(),await s.close(),await d,c}a(x8,"getServerList");async function aR(e,t){let{jsm:r}=await Ks(),n=_r.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=_r.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=_r.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:b8.File,retention:y8.Limits,subjects:t,discard:O8.Old,max_msgs:s,max_bytes:i,max_age:n})}a(aR,"createLocalStream");async function dU(){let{jsm:e}=await Ks(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(dU,"listStreams");async function B8(e){let{jsm:t}=await Ks();await t.streams.delete(e)}a(B8,"deleteLocalStream");async function H8(e){let{connection:t}=await Ks(),r=[],n=iR(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(aU.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(H8,"listRemoteStreams");async function k8(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ks(),i=rU(),o={durable_name:i,ack_policy:nR.Explicit};t&&(o.deliver_policy=sR.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 d=[];for await(let u of l){let _=rR(u.data),E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:_};if(u.headers&&(E.origin=u.headers.get(Tr.MSG_HEADERS.ORIGIN)),d.push(E),u.ack(),u.info.pending===0)break}return await c.delete(),d}a(k8,"viewStream");async function*F8(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ks(),i=rU(),o={durable_name:i,ack_policy:nR.Explicit};t&&(o.deliver_policy=sR.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 d of l){let u=rR(d.data);u[0]||(u=[u]);for(let _ of u){let E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:_};d.headers&&(E.origin=d.headers.get(Tr.MSG_HEADERS.ORIGIN)),yield E}if(d.ack(),d.info.pending===0)break}await c.delete()}a(F8,"viewStreamIterator");async function G8(e,t,r,n){Ts.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=_U(n,r);let{js:s}=await Ks(),i=await FE(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:iU.encode(n);try{Ts.trace(`publishToStream publishing to subject: ${o}`),D8(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 EU(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){Ts.trace(`publishToStream creating stream: ${t}`);let u=o.split(".");u[2]="*",await aR(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(G8,"publishToStream");function _U(e,t){t===void 0&&(t=I8());let r=_r.get($e.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Tr.MSG_HEADERS.ORIGIN)&&r&&t.append(Tr.MSG_HEADERS.ORIGIN,r),t}a(_U,"addNatsMsgHeader");function Uc(e){e=e.toLowerCase();let t=od.join(_r.get($e.CONFIG_PARAMS.ROOTPATH),L8);if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return Ea(eR)&&(eR={port:sd.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:sd.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Tr.SERVER_SUFFIX.HUB,config_file:Tr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:od.join(t,Tr.PID_FILES.HUB),hdb_nats_path:t}),eR;if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return Ea(Zg)&&(Zg={port:sd.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:sd.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Tr.SERVER_SUFFIX.LEAF,config_file:Tr.NATS_CONFIG_FILES.LEAF_SERVER,domain:sd.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Tr.SERVER_SUFFIX.LEAF,pid_file_path:od.join(t,Tr.PID_FILES.LEAF),hdb_nats_path:t}),Zg;Ts.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Uc,"getServerConfig");async function fU(e,t,r,n){try{await e.consumers.add(t,{ack_policy:nR.Explicit,durable_name:r,deliver_policy:sR.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(fU,"createConsumer");async function q8(e,t,r){await e.consumers.delete(t,r)}a(q8,"removeConsumer");function V8(e){return e.split(".")[1]}a(V8,"extractServerName");async function $8(e,t,r=6e4,n=iR()){if(!HE.isObject(t))throw new Error("data param must be an object");let s=iU.encode(t),{connection:i}=await Ks(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return rR(c.data)}a($8,"request");function cR(e){return new Promise(async(t,r)=>{let n=m8(tR,["--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(cR,"reloadNATS");async function Y8(){let{pid_file_path:e}=Uc($e.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await cR(e)}a(Y8,"reloadNATSHub");async function K8(){let{pid_file_path:e}=Uc($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await cR(e)}a(K8,"reloadNATSLeaf");function W8(e,t,r){let n;switch(e.code){case tU.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case tU.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(W8,"requestErrorHandler");async function Q8(e,t){let r=t+Tr.SERVER_SUFFIX.LEAF,{connection:n}=await Ks(),{jsm:s}=await r6(r),{schema:i,table:o}=e,c=kE.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await EU(async()=>{if(e.subscribe===!0)await fU(s,c,n.info.server_name,l);else try{await q8(s,c,n.info.server_name)}catch(d){Ts.trace(d)}})}a(Q8,"updateRemoteConsumer");async function z8(e,t,r,n){let s=kE.createNatsTableStreamName(e,t),i=r+Tr.SERVER_SUFFIX.LEAF,o={type:$e.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!sU&&g8()<_r.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=Xg();await c(o)}await S8(o),n==="stop"&&await HE.async_set_timeout(1e3)}a(z8,"updateConsumerIterator");function EU(e){return p8.writeTransaction($e.SYSTEM_SCHEMA_NAME,$e.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(EU,"exclusiveLock");async function hU(e,t){let r=kE.createNatsTableStreamName(e,t),n=await FE(),s=Z8(e,t,n);await aR(r,[s])}a(hU,"createLocalTableStream");async function j8(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await hU(n,s)}}a(j8,"createTableStreams");async function mU(e,t,r=void 0){if(_r.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=kE.createNatsTableStreamName(e,t),{domain:s}=Uc($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await ad()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")Ts.warn(n);else throw n}}a(mU,"purgeTableStream");async function J8(e,t){if(_r.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await mU(e,t[r])}a(J8,"purgeSchemaTableStreams");async function X8(e){return(await cd()).streams.info(e)}a(X8,"getStreamInfo");function Z8(e,t,r){return`${Tr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(Z8,"createSubjectName");async function FE(){if(id)return id;if(id=(await cd())?.nc?.info?.server_name,id===void 0)throw new Error("Unable to get jetstream manager server name");return id}a(FE,"getJsmServerName");async function e6(){let e=await cd(),t=await FE(),r=await dU();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=t6(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let d=i.split(".");d[d.length-1]=t;let u=d.join(".");Ts.trace(`Updating stream subject name from: ${i} to: ${u}`),s.subjects[0]=u,await e.streams.update(s.name,s)}}a(e6,"updateLocalStreams");function t6(e){let{config:t}=e,r=!1,n=_r.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=_r.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=_r.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(t6,"updateStreamLimits");async function r6(e){let t,r;try{t=await zr.jetstream({domain:e}),r=await zr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw Ts.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(r6,"connectToRemoteJS")});var ld=N((_Te,RU)=>{"use strict";var vc=Hf(),xc=OM(),n6=j(),s6=require("uuid").v4,dTe=require("clone"),qE=gi(),Bc=M(),i6=require("util"),_o=Vn(),{handleHDBError:jr,hdb_errors:o6}=ce(),{HDB_ERROR_MSGS:GE,HTTP_STATUS_CODES:Jr}=o6,{SchemaEventMsg:VE}=hs(),SU=Mt(),{getDatabases:a6}=(Ne(),ae(ot)),{transformReq:Hc}=te();RU.exports={createSchema:c6,createSchemaStructure:TU,createTable:l6,createTableStructure:gU,createAttribute:E6,dropSchema:u6,dropTable:d6,dropAttribute:_6,getBackup:h6};async function c6(e){let t=await TU(e);return qE.signalSchemaChange(new VE(process.pid,e.operation,e.schema)),t}a(c6,"createSchema");async function TU(e){let t=vc.schema_object(e);if(t)throw jr(t,t.message,Jr.BAD_REQUEST,void 0,void 0,!0);if(Hc(e),!await xc.checkSchemaExists(e.schema))throw jr(new Error,GE.SCHEMA_EXISTS_ERR(e.schema),Jr.BAD_REQUEST,Bc.LOG_LEVELS.ERROR,GE.SCHEMA_EXISTS_ERR(e.schema),!0);return await _o.createSchema(e),`database '${e.schema}' successfully created`}a(TU,"createSchemaStructure");async function l6(e){return Hc(e),e.hash_attribute=e.primary_key??e.hash_attribute,await gU(e)}a(l6,"createTable");async function gU(e){let t=vc.create_table_object(e);if(t)throw jr(t,t.message,Jr.BAD_REQUEST,void 0,void 0,!0);if(vc.validateTableResidence(e.residence),!await xc.checkSchemaTableExists(e.schema,e.table))throw jr(new Error,GE.TABLE_EXISTS_ERR(e.schema,e.table),Jr.BAD_REQUEST,Bc.LOG_LEVELS.ERROR,GE.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:s6(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await _o.createTable(n,e);else throw jr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Jr.BAD_REQUEST);else await _o.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(gU,"createTableStructure");async function u6(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=vc.schema_object(e),n=t??r;if(n)throw jr(n,n.message,Jr.BAD_REQUEST,void 0,void 0,!0);Hc(e);let s=await xc.checkSchemaExists(e.schema);if(s)throw jr(new Error,s,Jr.NOT_FOUND,Bc.LOG_LEVELS.ERROR,s,!0);let i=await xc.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await _o.dropSchema(e),qE.signalSchemaChange(new VE(process.pid,e.operation,e.schema)),await SU.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(u6,"dropSchema");async function d6(e){let t=vc.table_object(e);if(t)throw jr(t,t.message,Jr.BAD_REQUEST,void 0,void 0,!0);Hc(e);let r=await xc.checkSchemaTableExists(e.schema,e.table);if(r)throw jr(new Error,r,Jr.NOT_FOUND,Bc.LOG_LEVELS.ERROR,r,!0);return await _o.dropTable(e),await SU.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(d6,"dropTable");async function _6(e){let t=vc.attribute_object(e);if(t)throw jr(t,t.message,Jr.BAD_REQUEST,void 0,void 0,!0);Hc(e);let r=await xc.checkSchemaTableExists(e.schema,e.table);if(r)throw jr(new Error,r,Jr.NOT_FOUND,Bc.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw jr(new Error,"You cannot drop a hash attribute",Jr.BAD_REQUEST,void 0,void 0,!0);if(Bc.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw jr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Jr.BAD_REQUEST,void 0,void 0,!0);try{return await _o.dropAttribute(e),f6(e),qE.signalSchemaChange(new VE(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw n6.error(`Got an error deleting attribute ${i6.inspect(e)}.`),n}}a(_6,"dropAttribute");function f6(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(f6,"dropAttributeFromGlobal");async function E6(e){Hc(e);let t=a6()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw jr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Jr.BAD_REQUEST,void 0,void 0,!0);return await _o.createAttribute(e),qE.signalSchemaChange(new VE(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(E6,"createAttribute");function h6(e){return _o.getBackup(e)}a(h6,"getBackup")});var bU=N((ETe,AU)=>{"use strict";var{OPERATIONS_ENUM:m6}=M(),lR=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=m6.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};AU.exports=lR});var uR=N((pTe,wU)=>{"use strict";var p6=Vn(),mTe=bU(),$E=te(),YE=M(),S6=ne(),{handleHDBError:yU,hdb_errors:T6}=ce(),{HDB_ERROR_MSGS:OU,HTTP_STATUS_CODES:NU}=T6,g6=Object.values(YE.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),IU="To use this operation audit log must be enabled in harperdb-config.yaml";wU.exports=R6;async function R6(e){if($E.isEmpty(e.schema))throw new Error(OU.SCHEMA_REQUIRED_ERR);if($E.isEmpty(e.table))throw new Error(OU.TABLE_REQUIRED_ERR);if(!S6.get(YE.CONFIG_PARAMS.LOGGING_AUDITLOG))throw yU(new Error,IU,NU.BAD_REQUEST,YE.LOG_LEVELS.ERROR,IU,!0);let t=$E.checkSchemaTableExist(e.schema,e.table);if(t)throw yU(new Error,t,NU.NOT_FOUND,YE.LOG_LEVELS.ERROR,t,!0);if(!$E.isEmpty(e.search_type)&&g6.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await p6.readAuditLog(e)}a(R6,"readAuditLog")});var DU=N((TTe,CU)=>{"use strict";var{OPERATIONS_ENUM:A6}=M(),dR=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=A6.GET_BACKUP,this.schema=t,this.table=r}};CU.exports=dR});var MU=N((bTe,PU)=>{"use strict";var b6=Vn(),RTe=DU(),_R=te(),y6=M(),ATe=ne(),{handleHDBError:O6,hdb_errors:N6}=ce(),{HDB_ERROR_MSGS:LU,HTTP_STATUS_CODES:I6}=N6;PU.exports=w6;async function w6(e){if(_R.isEmpty(e.schema))throw new Error(LU.SCHEMA_REQUIRED_ERR);if(_R.isEmpty(e.table))throw new Error(LU.TABLE_REQUIRED_ERR);let t=_R.checkSchemaTableExist(e.schema,e.table);if(t)throw O6(new Error,t,I6.NOT_FOUND,y6.LOG_LEVELS.ERROR,t,!0);return await b6.getBackup(read_audit_log_object)}a(w6,"getBackup")});var kU=N((OTe,HU)=>{var fo=require("validate.js"),vU=ct(),kc=M(),{handleHDBError:C6,hdb_errors:D6}=ce(),{HDB_ERROR_MSGS:Vt,HTTP_STATUS_CODES:L6}=D6,fR=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),P6={STRUCTURE_USER:"structure_user"},UU=Object.values(kc.ROLE_TYPES_ENUM),M6="attribute_permissions",U6="attribute_name",{PERMS_CRUD_ENUM:Fc}=kc,v6=[M6,...Object.values(Fc)],xU=[Fc.READ,Fc.INSERT,Fc.UPDATE],x6=[U6,...xU];function B6(e){let t=fR();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,BU(e,t)}a(B6,"addRoleValidation");function H6(e){let t=fR();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,BU(e,t)}a(H6,"alterRoleValidation");function k6(e){let t=fR();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,vU.validateObject(e,t)}a(k6,"dropRoleValidation");var F6=["operation","role","id","permission","hdb_user","hdb_auth_header"];function BU(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)F6.includes(n[o])||s.push(n[o]);s.length>0&&Jt(Vt.INVALID_ROLE_JSON_KEYS(s),r);let i=vU.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{Jt(o,r)}),e.permission){let o=G6(e);o&&Jt(o,r),UU.forEach(c=>{e.permission[c]&&!fo.isBoolean(e.permission[c])&&Jt(Vt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(UU.indexOf(o)<0){if(o===P6.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let d=0,u=l.length;d<u;d++){let _=l[d];global.hdb_schema[_]||Jt(Vt.SCHEMA_NOT_FOUND(_),r)}continue}Jt(Vt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){Jt(Vt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let d=c.tables[l];if(!l||!global.hdb_schema[o][l]){Jt(Vt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(d).forEach(u=>{v6.includes(u)||Jt(Vt.INVALID_PERM_KEY(u),r,o,l)}),Object.values(Fc).forEach(u=>{fo.isDefined(d[u])?fo.isBoolean(d[u])||Jt(Vt.TABLE_PERM_NOT_BOOLEAN(u),r,o,l):Jt(Vt.TABLE_PERM_MISSING(u),r,o,l)}),fo.isDefined(d.attribute_permissions)){if(!fo.isArray(d.attribute_permissions)){Jt(Vt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}}else{Jt(Vt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}if(d.attribute_permissions){let u=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),_={read:!1,insert:!1,update:!1};for(let E in d.attribute_permissions){let f=d.attribute_permissions[E];if(Object.keys(f).forEach(p=>{!x6.includes(p)&&p!==Fc.DELETE&&Jt(Vt.INVALID_ATTR_PERM_KEY(p),r,o,l)}),!fo.isDefined(f.attribute_name)){Jt(Vt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!u.includes(h)){Jt(Vt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}xU.forEach(p=>{fo.isDefined(f[p])?fo.isBoolean(f[p])||Jt(Vt.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,l):Jt(Vt.ATTR_PERM_MISSING(p,h),r,o,l)}),!_.read&&f.read===!0&&(_.read=!0),!_.insert&&f.insert===!0&&(_.insert=!0),!_.update&&f.update===!0&&(_.update=!0)}if(d.read===!1&&_.read===!0||d.insert===!1&&_.insert===!0||d.update===!1&&_.update===!0){let E=`${o}.${l}`;Jt(Vt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return q6(r)}a(BU,"customValidate");HU.exports={addRoleValidation:B6,alterRoleValidation:H6,dropRoleValidation:k6};function G6(e){let{operation:t,permission:r}=e;if(t===kc.OPERATIONS_ENUM.ADD_ROLE||t===kc.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 Vt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?kc.ROLE_TYPES_ENUM.SUPER_USER:kc.ROLE_TYPES_ENUM.CLUSTER_USER;return Vt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(G6,"validateNoSUPerms");function q6(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Vt.ROLE_PERMS_ERROR,...e};return C6(new Error,n,L6.BAD_REQUEST)}else return null}a(q6,"generateRolePermResponse");function Jt(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(Jt,"addPermError")});var TR=N((wTe,VU)=>{"use strict";var FU=Rn(),GU=gn(),V6=so(),hR=kU(),mR=gi(),ITe=require("uuid").v4,$6=require("util"),KE=M(),Y6=te(),pR=GU.searchByValue,K6=GU.searchByHash,W6=$6.promisify(V6.delete),Q6=qs(),z6=Ic(),{hdb_errors:j6,handleHDBError:ha}=ce(),{HDB_ERROR_MSGS:qU,HTTP_STATUS_CODES:ud}=j6,{UserEventMsg:SR}=hs();VU.exports={addRole:J6,alterRole:X6,dropRole:Z6,listRoles:e9};function ER(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(ER,"scrubRoleDetails");async function J6(e){let t=hR.addRoleValidation(e);if(t)throw t;e=ER(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 pR(r)||[])}catch(i){throw ha(i)}if(n&&n.length>0)throw ha(new Error,qU.ROLE_ALREADY_EXISTS(e.role),ud.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 FU.insert(s),mR.signalUserChange(new SR(process.pid)),e=ER(e),e}a(J6,"addRole");async function X6(e){let t=hR.alterRoleValidation(e);if(t)throw t;e=ER(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await FU.update(r)}catch(s){throw ha(s)}if(n&&n?.message==="updated 0 of 1 records")throw ha(new Error,"Invalid role id",ud.BAD_REQUEST,void 0,void 0,!0);return await mR.signalUserChange(new SR(process.pid)),e}a(X6,"alterRole");async function Z6(e){let t=hR.dropRoleValidation(e);if(t)throw ha(new Error,t,ud.BAD_REQUEST,void 0,void 0,!0);let r=new z6(KE.SYSTEM_SCHEMA_NAME,KE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await K6(r));if(n.length===0)throw ha(new Error,qU.ROLE_NOT_FOUND,ud.NOT_FOUND,void 0,void 0,!0);let s=new Q6(KE.SYSTEM_SCHEMA_NAME,KE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await pR(s)),o=!1;if(Y6.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw ha(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,ud.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await W6(c),mR.signalUserChange(new SR(process.pid)),`${n[0].role} successfully deleted`}a(Z6,"dropRole");async function e9(){return pR({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(e9,"listRoles")});var WU=N((DTe,KU)=>{"use strict";var t9=ne(),Eo=require("joi"),r9=ct(),$U=require("moment"),n9=require("fs-extra"),gR=require("path"),s9=require("lodash"),dd=M(),{LOG_LEVELS:ma}=M(),i9="YYYY-MM-DD hh:mm:ss",o9=gR.resolve(__dirname,"../logs");KU.exports=function(e){return r9.validateBySchema(e,a9)};var a9=Eo.object({from:Eo.custom(YU),until:Eo.custom(YU),level:Eo.valid(ma.NOTIFY,ma.FATAL,ma.ERROR,ma.WARN,ma.INFO,ma.DEBUG,ma.TRACE),order:Eo.valid("asc","desc"),limit:Eo.number().min(1),start:Eo.number().min(0),log_name:Eo.custom(c9)});function YU(e,t){if($U(e,$U.ISO_8601).format(i9)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(YU,"validateDatetime");function c9(e,t){if(s9.invert(dd.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=t9.get(dd.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?dd.LOG_NAMES.HDB:e,i=s===dd.LOG_NAMES.INSTALL?gR.join(o9,dd.LOG_NAMES.INSTALL):gR.join(n,s);return n9.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(c9,"validateReadLogPath")});var AR=N((PTe,zU)=>{"use strict";var WE=M(),l9=j(),u9=ne(),d9=WU(),RR=require("path"),QU=require("fs-extra"),{once:_9}=require("events"),{handleHDBError:f9,hdb_errors:E9}=ce(),{PACKAGE_ROOT:h9}=M(),m9=RR.join(h9,"logs"),p9=1e3,S9=200;zU.exports=T9;async function T9(e){let t=d9(e);if(t)throw f9(t,t.message,E9.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=u9.get(WE.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?WE.LOG_NAMES.HDB:e.log_name,s=n===WE.LOG_NAMES.INSTALL?RR.join(m9,WE.LOG_NAMES.INSTALL):RR.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,d=e.until!==void 0,u=d?new Date(e.until):void 0,_=e.limit===void 0?p9:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+_,p=0;E==="desc"&&!l&&!u&&(p=Math.max(QU.statSync(s).size-(h+5)*S9,0));let S=QU.createReadStream(s,{start:p});S.on("error",x=>{l9.error(x)});let g=0,T=[],A="",I;S.on("data",x=>{let X=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;x=A+x;let $=0,F;for(;(F=X.exec(x))&&!S.destroyed;){I&&(I.message=x.slice($,F.index),V(I));let[se,ee,Z]=F,le=Z.split("] ["),_e=le[0],je=le[1];le.splice(0,2),I={timestamp:ee,thread:_e,level:je,tags:le,message:""},$=F.index+se.length}A=x.slice($)}),S.on("end",x=>{S.destroyed||I&&(I.message=A.trim(),V(I))}),S.resume();function V(x){let X,$,F;switch(!0){case(i&&c&&d):X=new Date(x.timestamp),$=new Date(l),F=new Date(u),x.level===o&&X>=$&&X<=F&&g<f?g++:x.level===o&&X>=$&&X<=F&&(ho(x,E,T),g++,g===h&&S.destroy());break;case(i&&c):X=new Date(x.timestamp),$=new Date(l),x.level===o&&X>=$&&g<f?g++:x.level===o&&X>=$&&(ho(x,E,T),g++,g===h&&S.destroy());break;case(i&&d):X=new Date(x.timestamp),F=new Date(u),x.level===o&&X<=F&&g<f?g++:x.level===o&&X<=F&&(ho(x,E,T),g++,g===h&&S.destroy());break;case(c&&d):X=new Date(x.timestamp),$=new Date(l),F=new Date(u),X>=$&&X<=F&&g<f?g++:X>=$&&X<=F&&(ho(x,E,T),g++,g===h&&S.destroy());break;case i:x.level===o&&g<f?g++:x.level===o&&(ho(x,E,T),g++,g===h&&S.destroy());break;case c:X=new Date(x.timestamp),$=new Date(l),X>=$&&g<f?g++:X>=$&&g>=f&&(ho(x,E,T),g++,g===h&&S.destroy());break;case d:X=new Date(x.timestamp),F=new Date(u),X<=F&&g<f?g++:X<=F&&g>=f&&(ho(x,E,T),g++,g===h&&S.destroy());break;default:g<f?g++:(ho(x,E,T),g++,g===h&&S.destroy())}}return a(V,"onLogMessage"),await _9(S,"close"),T}a(T9,"readLog");function ho(e,t,r){t==="desc"?g9(e,r):t==="asc"?R9(e,r):r.push(e)}a(ho,"pushLineToResult");function g9(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(g9,"insertDescending");function R9(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(R9,"insertAscending")});var QE=N((HTe,ZU)=>{"use strict";var bR=require("joi"),{string:Gc,boolean:jU,date:A9}=bR.types(),b9=ct(),{validateSchemaExists:UTe,validateTableExists:vTe,validateSchemaName:xTe}=Bs(),y9=M(),O9=lt(),JU=ne();JU.initSync();var BTe=Gc.invalid(JU.get(y9.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(O9.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),XU={operation:Gc.valid("add_node","update_node","set_node_replication"),node_name:Gc.optional(),subscriptions:bR.array().items({table:Gc.optional(),schema:Gc.optional(),database:Gc.optional(),subscribe:jU.required(),publish:jU.required().custom(I9),start_time:A9.iso()})};function N9(e){return b9.validateBySchema(e,bR.object(XU))}a(N9,"addUpdateNodeValidator");function I9(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(I9,"checkForFalsy");ZU.exports={addUpdateNodeValidator:N9,validation_schema:XU}});var tv=N((FTe,ev)=>{var w9=ct(),C9={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};ev.exports=function(e){return w9.validateObject(e,C9)}});var zE=N((GTe,rv)=>{"use strict";var D9=M().OPERATIONS_ENUM,yR=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=D9.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};rv.exports=yR});var sv=N((VTe,nv)=>{"use strict";var L9={OPERATION:"operation",REFRESH:"refresh"},OR=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},NR=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};nv.exports={JWTTokens:OR,TOKEN_TYPE_ENUM:L9,JWTRSAKeys:NR}});var Ed=N((YTe,cv)=>{"use strict";var fd=require("jsonwebtoken"),IR=require("fs-extra"),wR=te(),Yn=M(),{handleHDBError:Xr,hdb_errors:P9}=ce(),{HTTP_STATUS_CODES:Zr,AUTHENTICATION_ERROR_MSGS:en}=P9,_d=j(),iv=Zf(),LR=$n(),M9=Rn().update,U9=zE(),v9=gi(),{UserEventMsg:x9}=hs(),mo=ne();mo.initSync();var CR=require("path"),{JWTTokens:B9,JWTRSAKeys:H9,TOKEN_TYPE_ENUM:jE}=sv(),k9=mo.get(Yn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?mo.get(Yn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",F9=mo.get(Yn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?mo.get(Yn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",JE="RS256",DR;cv.exports={createTokens:G9,validateOperationToken:V9,refreshOperationToken:q9,validateRefreshToken:av};async function G9(e){if(wR.isEmpty(e)||typeof e!="object")throw Xr(new Error,en.INVALID_AUTH_OBJECT,Zr.BAD_REQUEST,void 0,void 0,!0);if(wR.isEmpty(e.username))throw Xr(new Error,en.USERNAME_REQUIRED,Zr.BAD_REQUEST,void 0,void 0,!0);if(wR.isEmpty(e.password))throw Xr(new Error,en.PASSWORD_REQUIRED,Zr.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await LR.findAndValidateUser(e.username,e.password),!t)throw Xr(new Error,en.INVALID_CREDENTIALS,Zr.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw _d.error(E),Xr(new Error,en.INVALID_CREDENTIALS,Zr.UNAUTHORIZED,void 0,void 0,!0)}let r=await XE(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await ov(i,r.private_key,r.passphrase),c=await fd.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:F9,algorithm:JE,subject:jE.REFRESH}),l=iv.hash(c),d=new U9(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),u,_;try{u=await M9(d)}catch(E){_d.error(E),_=E}if(_!==void 0||u.skipped_hashes.length>0)throw Xr(new Error,en.REFRESH_TOKEN_SAVE_FAILED,Zr.INTERNAL_SERVER_ERROR);return v9.signalUserChange(new x9(process.pid)),new B9(o,c)}a(G9,"createTokens");async function ov(e,t,r){return await fd.sign(e,{key:t,passphrase:r},{expiresIn:k9,algorithm:JE,subject:jE.OPERATION})}a(ov,"signOperationToken");async function XE(){if(DR===void 0)try{let e=CR.join(mo.getHdbBasePath(),Yn.LICENSE_KEY_DIR_NAME,Yn.JWT_ENUM.JWT_PASSPHRASE_NAME),t=CR.join(mo.getHdbBasePath(),Yn.LICENSE_KEY_DIR_NAME,Yn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=CR.join(mo.getHdbBasePath(),Yn.LICENSE_KEY_DIR_NAME,Yn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await IR.readFile(e)).toString(),s=(await IR.readFile(t)).toString(),i=(await IR.readFile(r)).toString();DR=new H9(i,s,n)}catch(e){throw _d.error(e),Xr(new Error,en.NO_ENCRYPTION_KEYS,Zr.INTERNAL_SERVER_ERROR)}return DR}a(XE,"getJWTRSAKeys");async function q9(e){if(!e)throw Xr(new Error,en.INVALID_BODY,Zr.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Xr(new Error,en.REFRESH_TOKEN_REQUIRED,Zr.BAD_REQUEST,void 0,void 0,!0);await av(e.refresh_token);let t=await XE(),r=await fd.decode(e.refresh_token);return{operation_token:await ov({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(q9,"refreshOperationToken");async function V9(e){try{let t=await XE(),r=await fd.verify(e,t.public_key,{algorithms:JE,subject:jE.OPERATION});return await LR.findAndValidateUser(r.username,void 0,!1)}catch(t){throw _d.warn(t),t.name&&t.name==="TokenExpiredError"?Xr(new Error,en.TOKEN_EXPIRED,Zr.FORBIDDEN):Xr(new Error,en.INVALID_TOKEN,Zr.UNAUTHORIZED)}}a(V9,"validateOperationToken");async function av(e){let t;try{let r=await XE(),n=await fd.verify(e,r.public_key,{algorithms:JE,subject:jE.REFRESH});t=await LR.findAndValidateUser(n.username,void 0,!1)}catch(r){throw _d.warn(r),r.name&&r.name==="TokenExpiredError"?Xr(new Error,en.TOKEN_EXPIRED,Zr.FORBIDDEN):Xr(new Error,en.INVALID_TOKEN,Zr.UNAUTHORIZED)}if(!iv.validate(t.refresh_token,e))throw Xr(new Error,en.INVALID_TOKEN,Zr.UNAUTHORIZED);return t}a(av,"validateRefreshToken")});var PR=N((QTe,dv)=>{"use strict";var $9=tv(),qc=require("passport"),Y9=require("passport-local").Strategy,K9=require("passport-http").BasicStrategy,W9=require("util"),Q9=$n(),uv=W9.callbackify(Q9.findAndValidateUser),WTe=En(),z9=M(),lv=Ed();qc.use(new Y9(function(e,t,r){uv(e,t,r)}));qc.use(new K9(function(e,t,r){uv(e,t,r)}));qc.serializeUser(function(e,t){t(null,e)});qc.deserializeUser(function(e,t){t(null,e)});function j9(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":qc.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===z9.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?lv.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):lv.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:qc.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(j9,"authorize");function J9(e,t){let r=$9(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(J9,"checkPermissions");dv.exports={authorize:j9,checkPermissions:J9}});var po=N((jTe,_v)=>{"use strict";var MR=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},UR=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};_v.exports={Node:MR,NodeSubscription:UR}});var Ev=N((XTe,fv)=>{"use strict";var X9=M().OPERATIONS_ENUM,vR=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=X9.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};fv.exports=vR});var hd=N((ege,hv)=>{"use strict";var xR=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},BR=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)}};hv.exports={RemotePayloadObject:xR,RemotePayloadSubscription:BR}});var pv=N((rge,mv)=>{"use strict";var HR=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}};mv.exports=HR});var Tv=N((cge,Sv)=>{"use strict";var Z9=pv(),sge=Gt(),ige=Et(),e7=j(),{getSchemaPath:oge,getTransactionAuditStorePath:age}=pt(),{getDatabases:t7}=(Ne(),ae(ot));Sv.exports=r7;async function r7(e){let t=new Z9;try{let r=t7()[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){e7.warn(`unable to stat table dbi due to ${r}`)}return t}a(r7,"lmdbGetTableSize")});var Rv=N((uge,gv)=>{"use strict";var kR=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}};gv.exports=kR});var Vc=N((mge,Ov)=>{"use strict";var n7=require("fs-extra"),s7=require("path"),Br=require("systeminformation"),So=j(),Av=Mt(),_ge=lt(),eh=M(),i7=Tv(),o7=Si(),{getThreadInfo:bv}=et(),jR=ne();jR.initSync();var a7=Rv(),{openEnvironment:fge}=Et(),{getSchemaPath:Ege}=pt(),{database:hge,databases:FR}=(Ne(),ae(ot)),ZE;Ov.exports={getHDBProcessInfo:$R,getNetworkInfo:KR,getDiskInfo:YR,getMemoryInfo:VR,getCPUInfo:qR,getTimeInfo:GR,getSystemInformation:WR,systemInformation:c7,getTableSize:QR,getMetrics:zR};function GR(){return Br.time()}a(GR,"getTimeInfo");async function qR(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:d,...u}=await Br.cpu();u.cpu_speed=await Br.cpuCurrentSpeed();let{raw_currentload:_,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:p,raw_currentload_user:S,cpus:g,...T}=await Br.currentLoad();return T.cpus=[],g.forEach(A=>{let{raw_load:I,raw_load_idle:V,raw_load_irq:x,raw_load_nice:X,raw_load_system:$,raw_load_user:F,...se}=A;T.cpus.push(se)}),u.current_load=T,u}catch(e){return So.error(`error in getCPUInfo: ${e}`),{}}}a(qR,"getCPUInfo");async function VR(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Br.mem();return Object.assign(s,process.memoryUsage())}catch(e){return So.error(`error in getMemoryInfo: ${e}`),{}}}a(VR,"getMemoryInfo");async function $R(){let e={core:[],clustering:[]};try{let t=await Br.processes(),r;try{r=Number.parseInt(await n7.readFile(s7.join(jR.get(eh.CONFIG_PARAMS.ROOTPATH),eh.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===eh.NODE_ERROR_CODES.ENOENT)So.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 So.error(`error in getHDBProcessInfo: ${t}`),e}}a($R,"getHDBProcessInfo");async function YR(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Br.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...d}=await Br.fsStats();return e.read_write=d,e.size=await Br.fsSize(),e}catch(t){return So.error(`error in getDiskInfo: ${t}`),e}}a(YR,"getDiskInfo");async function KR(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await Br.networkInterfaceDefault(),e.latency=await Br.inetChecksite("google.com"),(await Br.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:d,ieee8021xState:u,carrier_changes:_,...E}=n;e.interfaces.push(E)}),(await Br.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return So.error(`error in getNetworkInfo: ${t}`),e}}a(KR,"getNetworkInfo");async function WR(){if(ZE!==void 0)return ZE;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Br.osInfo();e=c;let l=await Br.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,ZE=e,ZE}catch(t){return So.error(`error in getSystemInformation: ${t}`),e}}a(WR,"getSystemInformation");async function QR(){let e=[],t=await o7.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await i7(n));return e}a(QR,"getTableSize");async function zR(){let e={};for(let t in FR){let r=e[t]={},n=r.tables={};for(let s in FR[t])try{let i=FR[t][s];r.readers||(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[d,u,_]=l.trim().split(" ");return{pid:d,thread:u,txnid:_}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){So.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(zR,"getMetrics");async function yv(){if(jR.get(eh.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await Av.getNATSReferences(),t=await Av.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(yv,"getNatsStreamInfo");async function c7(e){let t=new a7;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await WR(),t.time=GR(),t.cpu=await qR(),t.memory=await VR(),t.disk=await YR(),t.network=await KR(),t.harperdb_processes=await $R(),t.table_size=await QR(),t.metrics=await zR(),t.threads=await bv(),t.replication=await yv(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await WR();break;case"time":t.time=GR();break;case"cpu":t.cpu=await qR();break;case"memory":t.memory=await VR();break;case"disk":t.disk=await YR();break;case"network":t.network=await KR();break;case"harperdb_processes":t.harperdb_processes=await $R();break;case"table_size":t.table_size=await QR();break;case"database_metrics":case"metrics":t.metrics=await zR();break;case"threads":t.threads=await bv();break;case"replication":t.replication=await yv();break;default:break}return t}a(c7,"systemInformation")});var rh=N((Sge,Nv)=>{"use strict";Nv.exports={version:l7,printVersion:u7};var th=Ju();function l7(){if(th)return th.version}a(l7,"version");function u7(){th&&console.log(`HarperDB Version ${th.version}`)}a(u7,"printVersion")});var Kn=N((Age,Dv)=>{"use strict";var d7=Rn(),JR=te(),_7=require("util"),pa=M(),Iv=ne();Iv.initSync();var f7=PR(),wv=gn(),{Node:gge,NodeSubscription:Rge}=po(),E7=Ic(),h7=Ev(),{RemotePayloadObject:m7,RemotePayloadSubscription:p7}=hd(),{handleHDBError:S7,hdb_errors:T7}=ce(),{HTTP_STATUS_CODES:g7,HDB_ERROR_MSGS:R7}=T7,A7=qs(),b7=Vc(),y7=rh(),{getDatabases:O7}=(Ne(),ae(ot)),N7=_7.promisify(f7.authorize),I7=wv.searchByHash,w7=wv.searchByValue;Dv.exports={authHeaderToUser:C7,isEmpty:D7,getNodeRecord:L7,upsertNodeRecord:P7,buildNodePayloads:M7,checkClusteringEnabled:U7,getAllNodeRecords:v7,getSystemInfo:x7,reverseSubscription:Cv};async function C7(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await N7(t,null),e}a(C7,"authHeaderToUser");function D7(e){return e==null}a(D7,"isEmpty");async function L7(e){let t=new E7(pa.SYSTEM_SCHEMA_NAME,pa.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return I7(t)}a(L7,"getNodeRecord");async function P7(e){let t=new h7(pa.SYSTEM_SCHEMA_NAME,pa.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return d7.upsert(t)}a(P7,"upsertNodeRecord");function Cv(e){if(JR.isEmpty(e.subscribe)||JR.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(Cv,"reverseSubscription");function M7(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:d}=c,u=JR.getTableHashAttribute(l,d),{subscribe:_,publish:E}=Cv(c),f=O7()[l]?.[d],h=new p7(l,d,u,E,_,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new m7(r,t,s,n)}a(M7,"buildNodePayloads");function U7(){if(!Iv.get(pa.CONFIG_PARAMS.CLUSTERING_ENABLED))throw S7(new Error,R7.CLUSTERING_NOT_ENABLED,g7.BAD_REQUEST,void 0,void 0,!0)}a(U7,"checkClusteringEnabled");async function v7(){let e=new A7(pa.SYSTEM_SCHEMA_NAME,pa.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await w7(e))}a(v7,"getAllNodeRecords");async function x7(){let e=await b7.getSystemInformation();return{hdb_version:y7.version(),node_version:e.node_version,platform:e.platform}}a(x7,"getSystemInfo")});var XR=N((yge,Hv)=>{"use strict";var nh=Mt(),Lv=te(),Pv=lt(),Mv=M(),sh=j(),Uv=ld(),B7=pE(),{RemotePayloadObject:H7}=hd(),{handleHDBError:vv,hdb_errors:k7}=ce(),{HTTP_STATUS_CODES:xv}=k7,{NodeSubscription:Bv}=po();Hv.exports=F7;async function F7(e,t){let r;try{r=await nh.request(`${t}.${Pv.REQUEST_SUFFIX}`,new H7(Mv.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),sh.trace("Response from remote describe all request:",r)}catch(o){sh.error(`addNode received error from describe all request to remote node: ${o}`);let c=nh.requestErrorHandler(o,"add_node",t);throw vv(new Error,c,xv.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===Pv.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw vv(new Error,o,xv.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===Mv.SYSTEM_SCHEMA_NAME){await nh.createLocalTableStream(l,c);let h=new Bv(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let d=Lv.doesSchemaExist(l),u=n[l]!==void 0,_=c?Lv.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!d&&!u||!_&&!E){s.push(o);continue}if(!d&&u&&(sh.trace(`addNode creating schema: ${l}`),await Uv.createSchema({operation:"create_schema",schema:l})),!_&&E){sh.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new B7(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await Uv.createTable(h)}await nh.createLocalTableStream(l,c);let f=new Bv(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(F7,"reviewSubscriptions")});var md=N(oh=>{var ih=j();for(let e of["trace","debug","info","warn","error","fatal","notify"])ih.logsAtLevel(e)&&(oh[e]=ih[e]);oh.loggerWithTag=e=>ih.loggerWithTag(e,!0);oh.setLogLevel=ih.setLogLevel});function ZR(e){let t=e.idMapping;if(!t){let r=e.get(Symbol.for("remote-ids"));e.idMapping=t=r?(0,$c.unpack)(r):null}return t||(t={nodeName:at(),remoteNameToId:{[at()]:0}},e.putSync(Symbol.for("remote-ids"),(0,$c.pack)(t))),t}function pd(e){return ZR(e).remoteNameToId}function Fv(e,t,r){let n=ZR(r),s=n.remoteNameToId,i=new Map,o=!1;t[e]=0;for(let c in t){let l=t[c],d=s[c];if(d==null){let u=0;for(let _ in s){let E=s[_];E>u&&(u=E)}d=u+1,s[c]=d,o=!0}i.set(l,d)}return o&&r.putSync(Symbol.for("remote-ids"),(0,$c.pack)(n)),i}function eA(e,t){let r=ZR(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(Symbol.for("remote-ids"),(0,$c.pack)(r))}return kv.info?.("The remote node name map",e,n,s),s}var kv,$c,tA=Oe(()=>{kv=v(md());Oi();$c=require("msgpackr");a(ZR,"getIdMappingRecord");a(pd,"exportIdMapping");a(Fv,"remoteToLocalNodeId");a(eA,"getIdOfRemoteNode")});var Gv={};Ze(Gv,{Resources:()=>ah,keyArrayToString:()=>Yc,resetResources:()=>G7,resources:()=>To});function G7(){return To=new ah}function Yc(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var ah,To,Sd=Oe(()=>{ca();ah=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)throw new Error(`Conflicting paths for ${t}`);super.set(t,i);for(let[c,l]of this){let d=2;for(;(d=c.indexOf("/",d))>-1;){let u=this.get(c.slice(0,d));u&&(u.hasSubPaths=!0),d+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(l&&(!r||l.exportTypes?.[r]!==!1)){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),s&&(!r||s.exportTypes?.[r]!==!1)?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(!r||s.exportTypes?.[r]!==!1)&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return gt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(G7,"resetResources");a(Yc,"keyArrayToString")});function sA(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Vv,q7(e.primaryStore,e.auditStore)):(c=qv,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{$v(qv[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 d=l[o];d||(d=l[o]=new Map,d.envs=l,d.tableId=o,d.store=e.primaryStore),t=Yc(t);let u=new nA(r);u.startTime=n;let _=d.get(t);return _?_.push(u):(d.set(t,_=[u]),_.tables=d,_.key=t),u.subscriptions=_,u}function $v(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),Yv(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Pt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Yc(c),d=0;do{let u=o.get(l);if(u){for(let E of u)if(!(d>0&&!(E.includeDescendants&&!(E.onlyChildren&&d>1)))){if(E.startTime>=n){(0,rA.info)("omitting",c,E.startTime,n);continue}try{let f;E.supportsTransactions&&E.txnInProgress!==i.version&&(f=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,f)}catch(f){console.error(f),(0,rA.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_>-1?l=l.slice(0,_):l=null,d++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function q7(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=Vv[s];if(!l)return;let d=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{$v(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",d)&&d()})}}function Yv(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function Kv(e){return e.nextTransaction||(sA({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),Yv(e)),e.nextTransaction}var rA,qv,Vv,nA,iA=Oe(()=>{rA=v(j());cc();Sd();Ei();qv=Object.create(null),Vv=Object.create(null);a(sA,"addSubscription");nA=class extends mn{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($v,"notifyFromTransactionData");a(q7,"listenToCommits");a(Yv,"nextTransaction");a(Kv,"whenNextTransaction")});function Hr(){return Wv||(Wv=ft({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"replicates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function gd(e){Hr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;server.nodes=server.nodes.filter(s=>s!==n),r.type==="put"&&n!==at()&&server.nodes.push(n),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function ch(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&Hr().primaryStore.get(at())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function V7(){gd(e=>{go({},(t,r)=>{let n=e.name,s=Qv.get(n);if(s||Qv.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=new Float64Array(i.getUserSharedBuffer(["replicated",r,n],new ArrayBuffer(8),{callback:()=>{let c=o[0],l=o.lastTime;for(let{txnTime:d,onConfirm:u}of Td.get(r)||[])d>l&&d<=c&&u();o.lastTime=c}}));o.lastTime=0,s.set(r,o)}})})}function*lh(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=Kc.default.get(Wc.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!Kc.default.get(Wc.CONFIG_PARAMS.REPLICATION_PORT)&&Kc.default.get(Wc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||Kc.default.get(Wc.CONFIG_PARAMS.REPLICATION_PORT)||Kc.default.get(Wc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){zv.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{url:r,subscription:t.subscriptions,routes:t.routes}}}var zv,Kc,Wc,Wv,Qv,Td,Rd=Oe(()=>{Ne();Oi();RE();zv=require("worker_threads"),Kc=v(ne()),Wc=v(M());server.nodes=[];a(Hr,"getHDBNodeTable");a(gd,"subscribeToNodeUpdates");a(ch,"shouldReplicateToNode");Qv=new Map;kP((e,t,r)=>{Td||(Td=new Map,V7());let n=Td.get(e);return n||Td.set(e,n=[]),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:()=>{++i===r&&s()}})})});a(V7,"startSubscriptionToReplications");a(lh,"iterateRoutes")});var Jv={};Ze(Jv,{connectedToNode:()=>Ta,disconnectedFromNode:()=>zc,ensureNode:()=>Ii,requestClusterStatus:()=>jv,startOnMainThread:()=>aA});async function aA(e){let t=[],r,n=0;Ws.whenThreadsStarted.then(async()=>{let o=[];for await(let c of ut().system.hdb_nodes.search([]))o.push(c);for(let c of lh(e))try{let l=!c.subscriptions;if(l){let u=at();Hr().primaryStore.get(u)===void 0&&await Ii(u,{name:u,url:e.url??Ro(),replicates:!0})}let d=c.trusted!==!1;if(l&&c.replicates==null&&(c.replicates=!0),o.find(u=>u.url===c.url))continue;i(c)}catch(l){console.error(l)}gd(i)});let s;function i(o,c=o?.name){let l=at()&&c===at()||Ro()&&o?.url===Ro();if(l){let E=!!o?.replicates;if(s!==void 0&&s!==E)for(let f of Hr().search([]))f.replicates&&f.name!==c&&i(f,f.name);s=E}if(gr.trace("Setting up node replication for",o),!o){for(let[E,f]of Ni){let h;for(let[p,{worker:S,nodes:g}]of f){let T=g[0];if(T&&T.name==c){h=!0;for(let[A,{worker:I}]of f)f.delete(A),I?.postMessage({type:"unsubscribe-from-node",node:c,database:A,url:E});break}}if(h){Ni.get(E).iterator.remove(),Ni.delete(E);return}}return}if(l)return;if(!o.url){gr.info(`Node ${o.name} is missing url`);return}let d=Ni.get(o.url);if(d&&d.iterator.remove(),!(o.replicates===!0||o.replicates?.sends)&&!o.subscriptions?.length&&!d)return;if(gr.info(`Added node ${o.name} at ${o.url} for process ${at()}`),o.name){for(let[E,f]of Sa)if(o.url===f.url){Sa.delete(E);break}Sa.set(o.name,o)}let u=ut();if(d||(d=new Map,Ni.set(o.url,d)),d.iterator=go(e,(E,f,h)=>{h?_(f,!0):_(f,!1)}),o.subscriptions)for(let E of o.subscriptions){let f=E.database||E.schema;u[f]||(gr.warn(`Database ${f} not found for node ${o.name}, making a subscription anyway`),_(f,!1))}function _(E,f){gr.trace("Setting up replication for database",E,"on node",o.name);let h=d.get(E),p,S=[Object.assign({replicateByDefault:f},o)],g=ch(o,E),T=Ws.workers.filter(A=>A.name==="http");if(h?(p=h.worker,h.nodes=S):g&&(n=n%T.length,p=T[n++],d.set(E,{worker:p,nodes:S,url:o.url}),p?.on("exit",()=>{d.get(E)?.worker===p&&(d.delete(E),_(E,f))})),g)setTimeout(()=>{let A={type:"subscribe-to-node",database:E,nodes:S};p?p.postMessage(A):Qc(A)},$7);else{Hr().primaryStore.get(at())?.replicates||(s=!1);let A={type:"unsubscribe-from-node",database:E,url:o.url};p?p.postMessage(A):dh(A)}}a(_,"onDatabase")}a(i,"onNodeUpdate"),zc=a(function(o){let c=Array.from(Sa.keys()).sort(),l=c.indexOf(o.name||Qs(o.url));if(l===-1){gr.warn("Disconnected node not found in node map",o.name,Sa.keys());return}let d=Ni.get(o.url),u=d?.get(o.database);if(!u){gr.warn("Disconnected node not found in replication map",o.database,d);return}if(u.connected=!1,o.finished)return;let _=u.nodes[0];if(!(_.replicates===!0||_.replicates?.sends||_.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let f=c[E],h=Sa.get(f);d=Ni.get(h.url);let p=d?.get(o.database);if(!p){E=(E+1)%c.length;continue}let{worker:S,nodes:g}=p,T=!1;for(let A of u.nodes){if(g.some(I=>I.name===A.name)){gr.info(`Disconnected node is already failing over to ${f} for ${o.database}`);continue}g.push(A),T=!0}if(!T)return;u.redirectingTo=p,gr.info(`Failing over ${o.database} from ${o.name} to ${f}`),S?S.postMessage({type:"subscribe-to-node",database:o.database,nodes:g}):Qc({database:o.database,nodes:g});break}},"disconnectedFromNode"),Ta=a(function(o){let c=Ni.get(o.url),l=c?.get(o.database);if(!l){gr.warn("Connected node not found in replication map, this may be because the node is being removed",o.database,c);return}if(l.connected=!0,l.latency=o.latency,l.redirectingTo){let{worker:d,nodes:u}=l.redirectingTo,_=u.find(E=>E.name===o.name);l.redirectingTo=null,_&&(u.splice(u.indexOf(_),1),d?d.postMessage({type:"subscribe-to-node",database:o.database,nodes:u}):Qc({database:o.database,nodes:u}))}},"connectedToNode"),(0,Ws.onMessageByType)("disconnected-from-node",zc),(0,Ws.onMessageByType)("connected-to-node",Ta),(0,Ws.onMessageByType)("request-cluster-status",jv)}function jv(e,t){let r=[];for(let[,n]of Sa)try{let s=Ni.get(n.url),i=[];if(s){for(let[c,{worker:l,connected:d,nodes:u,latency:_}]of s)i.push({database:c,connected:d,latency:_,threadId:l?.threadId,nodes:u.map(E=>E.name)});let o=(0,oA.cloneDeep)(n);o.database_sockets=i,delete o.ca,delete o.node_name,delete o.__updatedtime__,delete o.__createdtime__,r.push(o)}}catch(s){gr.warn("Error getting cluster status for",n?.url,s)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Ii(e,t){let r=Hr();e=e??Qs(t.url),t.name=e;let n=r.primaryStore.get(e);if(gr.info(`Ensuring node ${e} at ${t.url}, existing record:`,n),!n)await r.put(t);else{t.replicates&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,oA.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let d of o)if((c.database??c.schema)===(d.database??d.schema)&&c.table===d.table){d.publish=c.publish,d.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}gr.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Ws,uh,gr,oA,$7,Ni,zc,Ta,Sa,Ad=Oe(()=>{Ne();Ws=v(et());Oi();uh=require("worker_threads");Rd();gr=v(j()),oA=require("lodash"),$7=200,Ni=new Map,Sa=new Map;a(aA,"startOnMainThread");a(jv,"requestClusterStatus");uh.parentPort&&(zc=a(e=>{uh.parentPort.postMessage(Object.assign({type:"disconnected-from-node"},e))},"disconnectedFromNode"),Ta=a(e=>{uh.parentPort.postMessage(Object.assign({type:"connected-to-node"},e))},"connectedToNode"),(0,Ws.onMessageByType)("subscribe-to-node",e=>{Qc(e)}),(0,Ws.onMessageByType)("unsubscribe-from-node",e=>{dh(e)}));a(Ii,"ensureNode")});async function fA(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=at(),i;if(e.includes("wss://")){if(!lA){let l=(0,_0.createTLSSelector)("operations-api"),d={secureContexts:null};await l.initialize(d),lA=d.secureContexts}if(i=lA.get(s),i&&fe.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,E0.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,ALPNProtocols:["http/1.1","harperdb-replication"],rejectUnauthorized:n!==!1,secureContext:void 0};return n!==!1&&i&&(c.secureContext=f0.createSecureContext(Object.assign({},i.options,{ca:Array.from(Ra)}))),new u0.WebSocket(e,"harperdb-replication-v1",c)}function ph(e,t,r){let n=t.port||t.securePort,s=_A.pid%1e3+"-"+d0.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),d=t.database,u=t.databaseSubscriptions||ga,_,E,f=!1,h=t.subscription;h?.then&&h.then(re=>h=re);let p=t.tables||d&&ut()[d];if(!r){fe.error?.("No authorization provided"),dn(1008,"Unauthorized");return}let S=new Map,g=[],T=r.name;T&&t.connection&&(t.connection.nodeName=T);let A,I,V=l0.default.get("replication_url"),x,X,$,F;if(t.url){let re=a(()=>{$?e.terminate():($=performance.now(),e.ping())},"send_ping");x=setInterval(re,c0).unref(),re()}else se();function se(){clearTimeout(X),X=setTimeout(()=>{fe.warn?.(`Timeout waiting for ping from ${T}, terminating connection and reconnecting`),e.terminate()},c0*2).unref()}a(se,"resetPingTimer"),d&&ve(d);let ee,Z,le=[],_e=[],je,ye=[],kt=[],Fo=[],sc=150,Gr=0,zl=0,Ki,Wi,Ds,Ls,Dt;e.on("message",re=>{try{let me=re.dataView=new Jc(re.buffer,re.byteOffset,re.byteLength);if(re[0]>127){let Fe=(0,tt.decode)(re),[rt,Ee,Lt]=Fe;switch(rt){case Zv:{if(Ee){if(T){if(T!==Ee){fe.error?.(s,`Node name mismatch, expecting to connect to ${T}, but peer reported name as ${Ee}, disconnecting`),e.send((0,tt.encode)([jc])),dn(1008,"Node name mismatch");return}}else if(T=Ee,t.connection?.tentativeNode){let B=t.connection.tentativeNode;B.name=T,t.connection.tentativeNode=null,Ii(T,B)}if(t.connection&&(t.connection.nodeName=T),fe.info?.(s,"received node id",T,d),!d)try{ve(d=Fe[2]),d==="system"&&(ee=go(t,(B,k)=>{jl(k)&&Qi(k)}),e.on("close",()=>{ee?.remove()}))}catch(B){fe.warn?.(s,"Error setting database",B),e.send((0,tt.encode)([jc])),dn(1008,B.message);return}fe.info?.(s,"setDatabase",d,p&&Object.keys(p)),cf()}break}case o0:{fe.info?.(s,"Received table definitions for",Ee.map(B=>B.table));for(let B of Ee){let k=Fe[2];B.database=k;let ie;jl(k)&&(k==="system"?Ve[k]?.[B.table]||(ie=uA(B,Ve[k]?.[B.table])):ie=uA(B,Ve[k]?.[B.table]),_||(_=ie.auditStore),p||(p=ut()?.[k]))}break}case jc:dn();break;case n0:try{let B=r?.replicates||r?.subscribers||r?.name;server.operation(Ee,{user:r},!B).then(k=>{k.requestId=Ee.requestId,e.send((0,tt.encode)([fh,k]))},k=>{e.send((0,tt.encode)([fh,{requestId:Ee.requestId,error:k instanceof Error?k.toString():k}]))})}catch(B){e.send((0,tt.encode)([fh,{requestId:Ee.requestId,error:B instanceof Error?B.toString():B}]))}break;case fh:let{resolve:q,reject:m}=S.get(Ee.requestId);Ee.error?m(new Error(Ee.error)):q(Ee),S.delete(Ee.requestId);break;case cA:let R=Fe[3];p||(d?fe.error?.(s,"No tables found for",d):fe.error?.(s,"Database name never received"));let w=p[R];w=uA({table:R,database:d,attributes:Ee.attributes,schemaDefined:Ee.schemaDefined},w),le[Lt]={name:R,decoder:new tt.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:Ee.typedStructs,structures:Ee.structures}),getEntry(B){return w.primaryStore.getEntry(B)},rootStore:w.primaryStore.rootStore};break;case e0:Dt=_?Fv(T,Ee,_):new Map,je=Fe[2],fe.info?.(s,`Acknowledged subscription request, receiving messages for nodes: ${je}`);break;case t0:let b=Lt;Fo[b]=Ee;break;case i0:let y=["replicated",d,T];E||(E=new Float64Array(_.getUserSharedBuffer(y,new ArrayBuffer(8)))),E[0]=Ee,fe.info?.(s,"received and broadcasting committed update",Ee),E.buffer.notify();break;case s0:A=Ee,h.send({type:"end_txn",localTime:A,remoteNodeIds:g});break;case r0:{let B=Ee,k;try{let ie=Fe[3],ue=_e[Lt]||(_e[Lt]=p[Fe[4]]);if(!ue)return fe.warn?.("Unknown table id trying to handle record request",Lt);let pe=ue.primaryStore.getBinaryFast(Symbol.for("structures")),nt=pe.length;if(nt!==zl){zl=nt;let He=(0,tt.decode)(pe);e.send((0,tt.encode)([cA,{typedStructs:He.typed,structures:He.named},Lt,ue.tableName]))}let xe=ue.primaryStore.getBinaryFast(ie);if(xe){let He=ue.primaryStore.decoder.decode(xe,{valueAsBuffer:!0});k=(0,tt.encode)([_h,B,{value:He.value,expiresAt:He.expiresAt,version:He.version,residencyId:He.residencyId,nodeId:He.nodeId,user:He.user}])}else k=(0,tt.encode)([_h,B])}catch(ie){k=(0,tt.encode)([_h,B,{error:ie.message}])}e.send(k);break}case _h:{let{resolve:B,reject:k,tableId:ie,key:ue}=S.get(Fe[1]),pe=Fe[2];if(pe?.error)k(new Error(pe.error));else if(pe){let nt=le[ie].decoder.decode(pe.value);pe.value=nt,pe.key=ue,B(pe)}else B();S.delete(Fe[1]);break}case Xv:Ls=Ee;let C,O,P=!1;if(h){if(d!==h.databaseName&&!h.then){fe.error?.("Subscription request for wrong database",d,h.databaseName);return}}else h=u.get(d);if(fe.info?.(s,"received subscription request for",d,"at",Ls),!h){let B;h=new Promise(k=>{fe.info?.("Waiting for subscription to database "+d),B=k}),h.ready=B,ga.set(d,h)}if(r.name)O=Hr().subscribe(r.name),O.then(async B=>{C=B;for await(let k of C){let ie=k.value;if(!(ie?.replicates===!0||ie?.replicates?.receives||ie?.subscriptions?.some(ue=>(ue.database||ue.schema)===d&&ue.publish!==!1))){P=!0,e.send((0,tt.encode)([jc])),dn(1008,`Unauthorized database subscription to ${d}`);return}}},B=>{fe.error?.(s,"Error subscribing to HDB nodes",B)});else if(!(r?.permissions?.super_user||r.replicates)){e.send((0,tt.encode)([jc])),dn(1008,`Unauthorized database subscription to ${d}`);return}if(Ds&&(fe.info?.(s,"stopping previous subscription",d),Ds.emit("close")),Ls.length===0)return;let U,L=Ls[0],H=a(B=>{if(B&&(L.replicateByDefault?!L.tables.includes(B.tableName):L.tables.includes(B.tableName)))return U=B,{table:B}},"tableToTableEntry"),Y={txnTime:0},K,Te,J=1/0,Ie,he=a((B,k)=>{if(J=k,B.type==="end_txn"){Y.txnTime&&(o[i]!==66&&fe.error?.("Invalid encoding of message"),di(9),di(mh),Dr(Ie=k),De()),i=c,Y.txnTime=0;return}let ie=B.nodeId,ue=B.tableId,pe=Te[ue];if(!pe&&(pe=Te[ue]=H(h.tableById[ue]),!pe))return fe.trace?.("Not subscribed to table",ue);let nt=pe.table,xe=nt.primaryStore,He=xe.encoder;if(B.extendedType&Cf||!He.typedStructs){let zi=B.getValue(xe,!0);JSON.stringify(zi)}if(K[ie]>=k)return bd&&fe.info?.(s,"skipping replication update",B.recordId,"to:",T,"from:",ie,"subscribed:",K),_i();bd&&fe.info?.(s,"sending replication update",B.recordId,"to:",T,"from:",ie,"subscribed:",K);let st=B.version;Y.txnTime!==st&&(Y.txnTime&&(bd&&fe.info?.(s,"new txn time, sending queued txn",Y.txnTime),o[i]!==66&&fe.error?.("Invalid encoding of message"),De()),Y.txnTime=st,i=c,Dr(st));let rr=B.residencyId,Ft=lf(rr,nt),_n;if(Ft&&!Ft.includes(T)){let zi=lf(B.previousResidencyId,nt);if(zi&&!zi.includes(T)&&(B.type==="put"||B.type==="patch")||nt.getResidencyById)return _i();let Jl=B.recordId;fe.info?.(s,"sending invalidation",Jl,T,"from",ie);let eS=0;rr&&(eS|=Yo),B.previousResidencyId&&(eS|=Ko);let tS,uf=null;for(let tN in nt.indices){if(!uf){if(tS=B.getValue(xe,!0),!tS)break;uf={}}uf[tN]=tS[tN]}_n=uc(B.version,ue,Jl,null,ie,B.user,B.type==="put"||B.type==="patch"?"invalidate":B.type,He.encode(uf),eS,rr,B.previousResidencyId,B.expiresAt)}function _i(){F||(F=setTimeout(()=>{F=null,(Ie||0)+a0/2<J&&(bd&&fe.info?.(s,"sending skipped sequence update",J),e.send((0,tt.encode)([s0,J])))},a0).unref())}a(_i,"skipAuditRecord");let Xp=He.typedStructs,Zp=He.structures;if((Xp?.length!=pe.typed_length||Zp?.length!=pe.structure_length)&&(pe.typed_length=Xp?.length,pe.structure_length=Zp.length,fe.info?.(s,"send table struct",pe.typed_length,pe.structure_length),pe.sentName||(pe.sentName=!0),e.send((0,tt.encode)([cA,{typedStructs:Xp,structures:Zp,attributes:nt.attributes,schemaDefined:nt.schemaDefined},ue,pe.table.tableName]))),rr&&!kt[rr]&&(e.send((0,tt.encode)([t0,Ft,rr])),kt[rr]=!0),_n)di(_n.length),oc(_n);else{let zi=B.encoded,Jl=zi[0]===66?8:0;di(zi.length-Jl),oc(zi,Jl)}},"sendAuditRecord"),De=a(()=>{e.send(o.subarray(i,c))},"sendQueuedData");Ds=new dA.EventEmitter,Ds.once("close",()=>{P=!0,C?.end()});for(let{startTime:B}of Ls)B<J&&(J=B);(O||Promise.resolve()).then(async()=>{h=await h,_=h.auditStore,Te=h.tableById.map(H),K=[];for(let{name:k,startTime:ie}of Ls){let ue=eA(k,_);fe.info?.("subscription to",k,"using local id",ue,"starting",ie),K[ue]=ie}Qi(d),ee||(ee=Aa(k=>{k.databaseName===d&&Qi(d)}),Z=yd(k=>{k===d&&(e.send((0,tt.encode)([jc])),dn())}),e.on("close",()=>{ee?.remove(),Z?.remove()})),e.send((0,tt.encode)([e0,pd(h.auditStore),Ls.map(({name:k})=>k)]));let B=!0;do{isFinite(J)||(fe.warn?.("Invalid sequence id "+J),dn(1008,"Invalid sequence id"+J));let k;if(B&&!P&&(B=!1,EA(_)>J&&server.nodes[0]===T)){let pe=J,nt=Sh(_);for(let xe in p){let He=p[xe];for(let st of He.primaryStore.getRange({snapshot:!1})){if(P)return;st.localTime>=J&&(fe.info?.(s,"Copying record from",d,xe,st.key,st.localTime),pe=Math.max(st.localTime,pe),k=!0,he({recordId:st.key,tableId:He.tableId,type:"put",getValue(){return st.value},encoded:He.primaryStore.getBinary(st.key),version:st.version,residencyId:st.residencyId,nodeId:nt},st.localTime))}}J=pe}for(let{key:ue,value:pe}of _.getRange({start:(J||1)+1/4096,snapshot:!1})){if(P)return;let nt=Pt(pe);he(nt,ue),e._socket.writableNeedDrain&&await new Promise(xe=>e._socket.once("drain",xe)),Ds.startTime=ue,k=!0}k&&he({type:"end_txn"},J);let ie=Eh.get(U);ie||Eh.set(U,ie=[]),ie.push(ue=>{}),await Kv(_)}while(!P)}).catch(B=>{fe.error?.(s,"Error handling subscription to node",B),dn(1008,"Error handling subscription to node")});break}return}me.position=8;let Je=!0,Ae;do{let Fe=me.readInt();if(Fe===9&&me.getUint8(me.position)==mh){me.position++,A=Ae=me.readFloat64(),fe.info?.("received remote sequence update",A,d);break}let rt=me.position,Ee=Pt(re.subarray(rt,rt+Fe)),Lt=le[Ee.tableId];Lt||fe.error?.(`No table found with an id of ${Ee.tableId}`);let q;Ee.residencyId&&(q=Fo[Ee.residencyId],fe.info?.(s,"received residency list",q,Ee.type,Ee.recordId));let m={table:Lt.name,id:Ee.recordId,type:Ee.type,nodeId:Dt.get(Ee.nodeId),residencyList:q,timestamp:Ee.version,value:Ee.getValue(Lt),user:Ee.user,beginTxn:Je,expiresAt:Ee.expiresAt};Je=!1,bd&&fe.info?.(s,"received replication message",Ee.type,"id",m.id,"version",Ee.version,"nodeId",m.nodeId,"name",m.value?.name),h.send(m),me.position=rt+Fe}while(me.position<re.byteLength);Gr++,Gr>sc&&!Ki&&(Ki=!0,e.pause()),h.send({type:"end_txn",localTime:A,remoteNodeIds:g,onCommit(){Gr--,Ki&&(Ki=!1,e.resume()),!I&&Ae&&(fe.info?.(s,"queuing confirmation of a commit at",Ae),setTimeout(()=>{e.send((0,tt.encode)([i0,I])),fe.info?.(s,"sent confirmation of a commit at",I),I=null},Y7)),I=Ae}})}catch(me){fe.error?.(s,"Error handling incoming replication message",me)}}),e.on("ping",se),e.on("pong",()=>{t.connection&&Ta({name:T,database:d,url:t.url,latency:performance.now()-$}),$=null}),e.on("close",(re,me)=>{clearInterval(x),clearTimeout(X),Ds&&Ds.emit("close"),Wi&&Wi.end();for(let[Je,{reject:Ae}]of S)Ae(new Error("Connection closed"));fe.info?.(s,"closed",re,me?.toString())});function jp(){}a(jp,"recordRemoteNodeSequence");function dn(re,me){e.isFinished=!0,e.close(re,me)}a(dn,"close");function cf(){if(f||(f=!0,t.connection?.on("subscriptions-updated",cf)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let re=new Map;try{for(let Ae of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let Fe of Ae.value.nodes||[])Fe.seqId>(re.get(Fe.id)??0)&&re.set(Fe.id,Fe.seqId)}catch(Ae){if(!Ae.message.includes("Can not re"))throw Ae}let me=t.connection?.nodeSubscriptions?.[0];g=[];let Je=t.connection?.nodeSubscriptions.map((Ae,Fe)=>{let rt=[],{replicateByDefault:Ee}=Ae;if(Ae.subscriptions){for(let R of Ae.subscriptions)if(R.subscribe&&(R.schema||R.database)===d){let w=R.table;p?.[w]?.replicate!==!1&&rt.push(w)}Ee=!1}else for(let R in p)(Ee?p[R].replicate===!1:p[R].replicate)&&rt.push(R);let Lt=_&&eA(Ae.name,_),q=h?.dbisDB?.get([Symbol.for("seq"),Lt])??1,m=q?.seqId??(typeof Ae.start_time=="string"?new Date(Ae.start_time).getTime():Ae.start_time)??1;if(me!==Ae){m>5e3&&(m-=5e3);for(let R of q?.nodes||[])R.name===Ae.name&&(m=R.seqId)}return g.push(Lt),re.get(Lt)>m&&(m=re.get(Lt)),{name:Ae.name,replicateByDefault:Ee,tables:rt,startTime:m}});fe.info?.(s,"sending subscription request",Je,h?.dbisDB?.path),Je&&(Je.length>0?e.send((0,tt.encode)([Xv,Je])):dn(1008,"No nodes to subscribe to"))}a(cf,"sendSubscriptionRequestUpdate");function lf(re,me){if(!re)return;let Je=ye[re];return Je||(Je=me.getResidencyRecord(re),ye[re]=Je),Je}a(lf,"getResidence");function jl(re){return!(Ao&&Ao!="*"&&!Ao[re]&&!Ao.includes?.(re)&&!Ao.some?.(me=>me.name===re))}a(jl,"checkDatabaseAccess");function ve(re){if(h=h||u.get(re),!jl(re))throw new Error(`Access to database "${re}" is not permitted`);h||fe.warn?.(`No database named "${re}" was declared and registered`),_=h?.auditStore,_||fe.warn?.("No audit store found in "+re+" creating it"),p||(p=ut()?.[re]);let me=at();if(me===T)throw me?new Error("Should not connect to self",me):new Error("Node name not defined");return Jp(me,re),!0}a(ve,"setDatabase");function Jp(re,me){let Je=ut()?.[me],Ae=[];for(let Fe in Je){let rt=Je[Fe];Ae.push({table:Fe,schemaDefined:rt.schemaDefined,attributes:rt.attributes.map(Ee=>({name:Ee.name,type:Ee.type,isPrimaryKey:Ee.isPrimaryKey}))})}fe.trace?.("Sending database info for node",re,"database name",me),e.send((0,tt.encode)([Zv,re,me,Ae]))}a(Jp,"sendNodeDBName");function Qi(re){let me=ut()?.[re],Je=[];for(let Ae in me){if(Ls&&!Ls.some(rt=>rt.replicateByDefault?!rt.tables.includes(Ae):rt.tables.includes(Ae)))continue;let Fe=me[Ae];Je.push({table:Ae,schemaDefined:Fe.schemaDefined,attributes:Fe.attributes.map(rt=>({name:rt.name,type:rt.type,isPrimaryKey:rt.isPrimaryKey}))})}e.send((0,tt.encode)([o0,Je,re]))}a(Qi,"sendDBSchema");let ui=1,ic=[];return{end(){Wi&&Wi.end(),Ds&&Ds.emit("close")},getRecord(re){let me=ui++;return new Promise((Je,Ae)=>{let Fe=[r0,me,re.table.tableId,re.id];ic[re.table.tableId]||(Fe.push(re.table.tableName),ic[re.table.tableId]=!0),e.send((0,tt.encode)(Fe)),S.set(me,{tableId:re.table.tableId,key:re.id,resolve(rt){let{table:Ee,entry:Lt}=re;Je(rt),rt&&Ee._recordRelocate(Lt,rt)},reject:Ae})})},sendOperation(re){let me=ui++;return re.requestId=me,e.send((0,tt.encode)([n0,re])),new Promise((Je,Ae)=>{S.set(me,{resolve:Je,reject:Ae})})}};function di(re){Go(5),re<128?o[c++]=re:re<16384?(l.setUint16(c,re|32768),c+=2):re<1056964608?(l.setUint32(c,re|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,re),c+=5)}function oc(re,me=0,Je=re.length){let Ae=Je-me;Go(Ae),re.copy(o,c,me,Je),c+=Ae}function Dr(re){Go(8),l.setFloat64(c,re),c+=8}function Go(re){if(re+16>o.length-c){let me=Buffer.allocUnsafeSlow(c+re-i+65536>>10<<11);o.copy(me,0,i,c),c=c-i,i=0,o=me,l=new DataView(o.buffer,0,o.length)}}}function uA(e,t){t||(t={});let r=!1,n=e.schemaDefined,s=t.attributes||[];for(let i=0;i<e.attributes?.length;i++){let o=e.attributes[i],c=s[i];(!c||c.name!==o.name||c.type!==o.type)&&(r=!0,n||(o.indexed=!0),s[i]=o)}return r?(fe.info?.("(Re)creating",e),ft({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:s,...t})):t}var l0,tt,u0,d0,fe,dA,_0,f0,_A,E0,Xv,Zv,e0,jc,t0,cA,r0,_h,n0,fh,s0,i0,o0,Eh,ga,bd,a0,Y7,c0,lA,hh,h0=Oe(()=>{Ne();Ei();tA();iA();Oi();l0=v(ne());dc();tt=require("msgpackr"),u0=require("ws"),d0=require("worker_threads"),fe=v(md());Ad();dA=require("events"),_0=v(bo()),f0=v(require("node:tls"));Rd();_A=v(require("node:process")),E0=require("node:net"),Xv=129,Zv=140,e0=141,jc=142,t0=130,cA=132,r0=133,_h=134,n0=136,fh=137,s0=143,i0=144,o0=145,Eh=new Map,ga=new Map,bd=!0,a0=300,Y7=2,c0=3e5;a(fA,"createWebSocket");hh=class extends dA.EventEmitter{constructor(r,n,s){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=Qs(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=2e3;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];replicateTablesByDefault;session;sessionResolve;sessionReject;nodeName;async connect(){this.session||this.resetSession();let r=[];this.socket=await fA(this.url,{serverName:this.nodeName});let n;fe.info?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${_A.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),fe.info?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=2e3,Ta({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=ph(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"?(fe.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"?fe.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`):fe.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(zc({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();fe.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(ph,"replicateOverWS");a(uA,"ensureTableIfChanged")});var Nd={};Ze(Nd,{clearThisNodeName:()=>J7,disableReplication:()=>Q7,enabled_databases:()=>Ao,forEachReplicatedDatabase:()=>go,getThisNodeId:()=>Sh,getThisNodeName:()=>at,getThisNodeUrl:()=>Ro,hostnameToUrl:()=>bh,replication_certificate_authorities:()=>Ra,sendOperationToNode:()=>Ah,servers:()=>R0,setReplicator:()=>b0,start:()=>W7,startOnMainThread:()=>aA,subscribeToNode:()=>Qc,unsubscribeFromNode:()=>dh,urlToNodeName:()=>Qs});function W7(e){if(e.port||(e.port=zs.default.get(Od.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=zs.default.get(Od.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!at())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of lh(e))t.set(Qs(n.url),n);z7(e),e=Object.assign({subProtocol:"harperdb-replication-v1",mtls:!0,isOperationsServer:!0},e);let r=it.ws(async(n,s,i)=>{await i,n._socket.unref(),ph(n,e,s?.user),n.on("error",o=>{o.code!=="ECONNREFUSED"&&Rr.error("Error in connection to "+this.url,o.message)})},e);e.runFirst=!0,it.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&Rr.error(`Incoming client connection from ${n.ip} did not have valid certificate `,n._nodeRequest.socket.authorizationError);let i=Hr().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));c?n.user=c:Rr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:Rr.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(R0.push(n),n.secureContexts){let s=0,i=a(()=>{let o=new Set(n.secureContexts.values());n.defaultContext&&o.add(n.defaultContext);for(let c of o)try{let l=Array.from(Ra);c.options.ca&&l.push(...c.options.ca);let d=Object.assign({},c.options,{ca:l});c.replicationContext=Rh.createSecureContext(d)}catch(l){Rr.error("Error creating replication TLS config",l)}},"updateContexts");n.secureContextsListeners.push(i),gd(o=>{o?.ca&&(Ra.add(o.ca),Ra.size!==s&&(s=Ra.size,i()))})}}function Q7(e=!0){g0=e}function z7(e){g0||(ut(),Ao=e.databases,go(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||ga;for(let[s,i]of gh){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];b0(r,s,e),Eh.get(s)?.forEach(i=>i(s))}}))}function b0(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 A0 extends pr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||ga,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(Rr.trace("Setting up replicator subscription to database",e,o&&Object.keys(o)),!o?.auditStore)return this.subscription=o=new mn,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;for(let d of c)try{let u=Hr().primaryStore.get(d);if(u){let _=y0(u.url,A0.subscription,e),E={requestId:K7++,table:t,entry:i,id:i.key};return await _.getRecord(E)}}catch(u){Rr.warn("Error in load from node",d,u),l||(l=u)}if(l)throw l}}}static isReplicator=!0},{intermediateSource:!0})}function y0(e,t,r){let n=gh.get(e);n||gh.set(e,n=new Map);let s=n.get(r);if(s)return s;if(t)return n.set(r,s=new hh(e,t,r)),s.connect(),s.once("finished",()=>n.delete(r)),s}async function Ah(e,t,r){r||(r={}),r.serverName=e.name;let n=await fA(e.url,r),s=ph(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{Rr.error("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function Qc(e){try{T0.isMainThread&&Rr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=ga.get(e.database);if(!t){let n;t=new Promise(s=>{Rr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,ga.set(e.database,t)}let r=y0(e.nodes[0].url,t,e.database);e.nodes[0].name===void 0&&(r.tentativeNode=e.nodes[0]),r.subscribe(e.nodes.filter(n=>ch(n,e.database)),e.replicateByDefault)}catch(t){Rr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function dh({url:e,database:t}){let r=gh.get(e);if(r){let n=r.get(t);n&&(n.unsubscribe(),r.delete(t))}}function j7(){if(hA!==void 0)return hA;let e=zs.default.get(Od.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||zs.default.get(Od.CONFIG_PARAMS.TLS_CERTIFICATE);if(e)return hA=new p0.X509Certificate((0,S0.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function at(){return mA||(mA=zs.default.get("replication_hostname")??Qs(zs.default.get("replication_url"))??j7()??m0("operationsapi_network_secureport")??m0("operationsapi_network_port")??"127.0.0.1")}function J7(){mA=void 0}function m0(e){let t=zs.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Th(e){let t=zs.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Sh(e){return pd(e)?.[at()]}function Ro(){let e=zs.default.get("replication_url");return e||bh(at())}function bh(e){let t=Th("replication_port");if(t)return`ws://${e}:${t}`;if(t=Th("replication_secureport"),t)return`wss://${e}:${t}`;if(t=Th("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=Th("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function Qs(e){if(e)return new URL(e).hostname}function go(e,t){for(let n of Object.getOwnPropertyNames(Ve))r(n);return yd(n=>{r(n)}),Aa((n,s)=>{r(n.databaseName)});function r(n){let s=Ve[n];Rr.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):X7(n)&&t(s,n,!1)}a(r,"forDatabase")}function X7(e){let t=Ve[e];for(let r in t)if(t[r].replicate)return!0}var zs,Rr,p0,S0,Od,Rh,T0,g0,K7,R0,Ra,Ao,gh,hA,mA,Oi=Oe(()=>{Ne();us();cc();h0();Lr();zs=v(ne()),Rr=v(j()),p0=require("crypto"),S0=require("fs");Ad();Rd();Od=v(M());tA();Rh=v(require("node:tls")),T0=require("worker_threads"),K7=1,R0=[],Ra=new Set(Rh.rootCertificates);a(W7,"start");a(Q7,"disableReplication");a(z7,"assignReplicationSource");a(b0,"setReplicator");gh=new Map;a(y0,"getConnection");a(Ah,"sendOperationToNode");a(Qc,"subscribeToNode");a(dh,"unsubscribeFromNode");a(j7,"getCommonNameFromCert");a(at,"getThisNodeName");a(J7,"clearThisNodeName");Object.defineProperty(it,"hostname",{get(){return at()}});a(m0,"getHostFromListeningPort");a(Th,"getPortFromListeningPort");a(Sh,"getThisNodeId");it.replication={getThisNodeId:Sh,exportIdMapping:pd};a(Ro,"getThisNodeUrl");a(bh,"hostnameToUrl");a(Qs,"urlToNodeName");a(go,"forEachReplicatedDatabase");a(X7,"hasExplicitlyReplicatedTable")});var bo=N(W0=>{"use strict";var fr=require("path"),Wn=require("fs-extra"),Zc=require("node-forge"),D0=require("net"),{generateKeyPair:SA,X509Certificate:yo,createPrivateKey:L0}=require("crypto"),Z7=require("util");SA=Z7.promisify(SA);var Ot=Zc.pki,wi=require("joi"),{v4:eee}=require("uuid"),{validateBySchema:P0}=ct(),ht=j(),gs=ne(),Rs=M(),{CONFIG_PARAMS:el}=Rs,js=yT(),{ClientError:Id}=ce(),ya=require("node:tls"),{relative:tee,join:ree}=require("node:path"),{CERT_PREFERENCE_APP:TRe,CERTIFICATE_VALUES:nee}=js,see=hf(),TA=dr(),O0=parseInt(process.version.slice(1))<20,{table:iee,getDatabases:oee,databases:pA}=(Ne(),ae(ot));Object.assign(W0,{generateKeys:k0,updateConfigCert:q0,createCsr:Eee,signCertificate:hee,setCertTable:tl,loadCertificates:B0,reviewSelfSignedCert:G0,createTLSSelector:Y0,listCertificates:K0,addCertificate:gee,removeCertificate:Aee,createNatsCerts:See,generateCertsKeys:pee,getReplicationCert:Cd,getReplicationCertAuth:fee});var{urlToNodeName:M0,getThisNodeUrl:aee,getThisNodeName:Oh,clearThisNodeName:cee}=(Oi(),ae(Nd)),{readFileSync:lee,watchFile:uee,statSync:U0}=require("node:fs"),gRe=ne(),{getTicketKeys:dee,onMessageFromWorkers:_ee}=et(),ba=j(),{isMainThread:v0}=require("worker_threads"),{TLSSocket:x0,createSecureContext:RRe}=require("node:tls"),RA=3650,wd=["127.0.0.1","localhost","::1"],AA=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];_ee(async e=>{e.type===Rs.ITC_EVENT_TYPES.RESTART&&(gs.initSync(!0),await G0())});var tn;function Na(){return tn||(tn=oee().system.hdb_certificate,tn||(tn=iee({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__"}]}))),tn}a(Na,"getCertTable");async function Cd(){let e=Y0("operations-api"),t={secureContexts:null,setSecureContext:s=>{}};await e.initialize(t);let r=t.secureContexts.get(Oh());if(!r)return;let n=new yo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(Cd,"getReplicationCert");async function fee(){Na();let e=(await Cd()).options.cert,r=new yo(e).issuer.match(/CN=(.*)/)?.[1];return tn.get(r)}a(fee,"getReplicationCertAuth");var N0,Oa=new Map;function B0(){if(N0)return;N0=!0;let e=[{configKey:el.TLS},{configKey:el.OPERATIONSAPI_TLS}];Na();let t=fr.dirname(TA.getConfigFilePath()),r;for(let{configKey:n}of e){let s=TA.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&tee(ree(t,"keys"),o);c&&I0(o,l=>{Oa.set(c,l)},"private key");for(let l of[!1,!0]){let d=i[l?"certificateAuthority":"certificate"];if(d&&v0){let u;I0(d,_=>{if(nee.cert===_)return;let E=i.hostname??i.hostnames??i.host??i.hosts;E&&!Array.isArray(E)&&(E=[E]);let f=V0(d),h=new yo(f),p;try{p=yA(h)}catch(A){ht.error("error extracting common name from certificate",A);return}if(p==null){ht.error("error extracting common name from certificate");return}let S=tn.primaryStore.get(p),g=U0(d).mtimeMs,T=!S||S.is_self_signed?1:S.file_timestamp??S.__updatedtime__;if(S&&g<=T){g<T&&ht.info(`Certificate ${p} at ${d} is older (${new Date(g)}) than the certificate in the database (${T>1?new Date(T):"only self signed certificate available"})`);return}r=tn.put({name:p,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:f,private_key_name:c,is_authority:l,hostnames:E,file_timestamp:g,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(B0,"loadCertificates");function I0(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&v0&&ht.warn(`Reloading ${r}:`,e),n=c,t(V0(e)))}catch(c){ht.error(`Error loading ${r}:`,e,c)}},"loadFile");Wn.existsSync(e)?s(U0(e)):ht.error(`${r} file not found:`,e),uee(e,{persistent:!1},s)}a(I0,"loadAndWatch");function w0(){let e=aee();if(e==null){let t=wd[0];return ht.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return M0(e)}a(w0,"getHost");function yh(){let e=Oh();if(e==null){let t=wd[0];return ht.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(yh,"getCommonName");async function Eee(){let e=await Cd(),t=Ot.certificateFromPem(e.options.cert),r=Ot.privateKeyFromPem(e.options.key);ht.info("Creating CSR with cert named:",e.name);let n=Ot.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:yh()},...AA];ht.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:H0()}];return ht.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),Zc.pki.certificationRequestToPem(n)}a(Eee,"createCsr");function H0(){let e=wd.includes(yh())?wd:[...wd,yh()];return e.includes(w0())||e.push(w0()),[{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=>D0.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(H0,"certExtensions");async function hee(e){let t={},r=fr.join(gs.getHdbBasePath(),Rs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;Na();for await(let u of tn.search([]))if(u.is_authority&&!u.details.issuer.includes("HarperDB-Certificate-Authority")){if(Oa.has(u.private_key_name)){n=Oa.get(u.private_key_name),s=u;break}else if(u.private_key_name&&await Wn.exists(fr.join(r,u.private_key_name))){n=Wn.readFile(fr.join(r,u.private_key_name)),s=u;break}}if(!n){let u=await gA();s=u.ca,n=u.private_key}n=Ot.privateKeyFromPem(n),t.signingCA=s.certificate;let i=Ot.certificateFromPem(s.certificate);ht.info("Signing CSR with cert named",s.name);let o=Ot.certificationRequestFromPem(e.csr);try{o.verify()}catch(u){return ht.error(u),new Error("Error verifying CSR: "+u.message)}let c=Zc.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()+RA),ht.info("sign cert setting validity:",c.validity),ht.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),ht.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let d=o.getAttribute({name:"extensionRequest"}).extensions;ht.info("sign cert adding extensions from CSR:",d),c.setExtensions(d),c.publicKey=o.publicKey,c.sign(n,Zc.md.sha256.create()),t.certificate=Ot.certificateToPem(c)}else ht.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(hee,"signCertificate");async function mee(e,t){await tl({name:Oh(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await tl({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:Ot.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(mee,"createCertificateTable");async function tl(e){let t=new yo(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},Na(),await tn.patch(e)}a(tl,"setCertTable");async function k0(){let e=await SA("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:Ot.publicKeyFromPem(e.publicKey),private_key:Ot.privateKeyFromPem(e.privateKey)}}a(k0,"generateKeys");async function bA(e,t,r){let n=Ot.createCertificate();if(!t){let o=await Cd();t=Ot.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()+RA);let i=[{name:"commonName",value:yh()},...AA];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(H0()),n.sign(e,Zc.md.sha256.create()),Ot.certificateToPem(n)}a(bA,"generateCertificates");async function gA(){let e=await K0(),t;for(let r of e){if(!r.is_authority)continue;let n=Oa.get(r.private_key_name);if(r.private_key_name&&n){let s=new yo(r.certificate).checkPrivateKey(L0(n));if(ht.trace(`CA named: ${r.name} found with matching private key`),s){t={ca:r,private_key:n};break}}}if(t)return t;ht.trace("No CA found with matching private key")}a(gA,"getCertAuthority");async function F0(e,t){let r=Ot.createCertificate();r.publicKey=t,r.serialNumber=Math.random().toString().slice(2,10),r.validity.notBefore=new Date;let n=new Date;r.validity.notAfter=n,r.validity.notAfter.setDate(n.getDate()+RA);let s=[{name:"commonName",value:`HarperDB-Certificate-Authority-${gs.get(el.REPLICATION_HOSTNAME)??M0(gs.get(el.REPLICATION_URL))??eee().split("-")[0]}`},...AA];r.setSubject(s),r.setIssuer(s),r.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),r.sign(e,Zc.md.sha256.create());let i=fr.join(gs.getHdbBasePath(),Rs.LICENSE_KEY_DIR_NAME),o=fr.join(i,js.PRIVATEKEY_PEM_NAME);return await Wn.writeFile(o,Ot.privateKeyToPem(e)),r}a(F0,"generateCertAuthority");async function pee(){let{private_key:e,public_key:t}=await k0(),r=await F0(e,t),n=await bA(e,t,r);await mee(n,r),q0()}a(pee,"generateCertsKeys");async function See(){let e=await bA(Ot.privateKeyFromPem(js.CERTIFICATE_VALUES.key),void 0,Ot.certificateFromPem(js.CERTIFICATE_VALUES.cert)),t=fr.join(gs.getHdbBasePath(),Rs.LICENSE_KEY_DIR_NAME),r=fr.join(t,js.NATS_CERTIFICATE_PEM_NAME);await Wn.exists(r)||await Wn.writeFile(r,e);let n=fr.join(t,js.NATS_CA_PEM_NAME);await Wn.exists(n)||await Wn.writeFile(n,js.CERTIFICATE_VALUES.cert)}a(See,"createNatsCerts");async function G0(){cee(),await B0(),Na();let e,t=gs.get(el.TLS_PRIVATEKEY),r=a(async()=>e||(e=Ot.privateKeyFromPem(await Wn.readFile(t)),e),"getPrivateKey"),n,s=await gA();if(!s){n=!0,ht.info("No self signed Cert Authority found, generating new self signed CA"),await r();let o=await F0(e,Ot.setRsaPublicKey(e.n,e.e));await tl({name:o.subject.getField("CN").value,uses:["https","wss"],certificate:Ot.certificateToPem(o),private_key_name:fr.basename(t),is_authority:!0,is_self_signed:!0})}if(!await Cd()||n){let o=Oh();ht.info(`A suitable replication certificate was not found, creating new self singed cert named: ${o}`),s=s??await gA();let c=Ot.certificateFromPem(s.ca.certificate),l=c.publicKey,d=await bA(Ot.privateKeyFromPem(s.private_key),l,c);await tl({name:o,uses:["https","operations","wss"],certificate:d,is_authority:!1,private_key_name:s.ca.private_key_name})}}a(G0,"reviewSelfSignedCert");function q0(){let e=see(Object.keys(Rs.CONFIG_PARAM_MAP),!0),t=fr.join(gs.getHdbBasePath(),Rs.LICENSE_KEY_DIR_NAME),r=fr.join(t,js.PRIVATEKEY_PEM_NAME),n=fr.join(t,js.NATS_CERTIFICATE_PEM_NAME),s=fr.join(t,js.NATS_CA_PEM_NAME),i=Rs.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),TA.updateConfigValue(void 0,void 0,o,!1,!0)}a(q0,"updateConfigCert");function V0(e){return e.startsWith("-----BEGIN")?e:lee(e,"utf8")}a(V0,"readPEM");var C0=ya.createSecureContext;ya.createSecureContext=function(e){if(!e.cert||!e.key)return C0(e);let t={...e};delete t.key,delete t.cert;let r=C0(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var $0=ya.Server;ya.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),$0.call(this,e,t)};ya.Server.prototype=$0.prototype;var Tee=x0.prototype._init;x0.prototype._init=function(e,t){Tee.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 Xc=new Map;function Y0(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 d(){try{r.clear(),Xc.clear();let u=0;for await(let _ of pA.system.hdb_certificate.search([])){if(e!=="operations-api"&&_.uses?.includes?.("operations"))continue;let E=_.certificate,f=new yo(E);_.is_authority&&(f.asString=E,Xc.set(f.subject,E))}for await(let _ of pA.system.hdb_certificate.search([]))try{if(_.is_authority||!(e==="operations-api")&&_.uses?.includes?.("operations"))continue;let f=_.is_self_signed?1:2,h=Oa.get(_.private_key_name);!h&&_.private_key_name&&(h=await Wn.readFile(fr.join(gs.get(el.ROOTPATH),Rs.LICENSE_KEY_DIR_NAME,_.private_key_name)));let p=_.certificate,S=new yo(p);if(Xc.has(S.issuer)&&(p+=`
|
|
13
|
-
`+Xc.get(S.issuer)),!h||!p)throw new Error("Missing private key or certificate for secure server");let g={ciphers:_.ciphers,ticketKeys:dee(),ca:t&&Array.from(Xc.values()),cert:p,key:h,key_file:_.private_key_name,is_self_signed:_.is_self_signed};o&&(g.sessionIdContext=o.sessionIdContext);let T=ya.createSecureContext(g);T.name=_.name,T.options=g,T.quality=f,T.certificateAuthorities=Array.from(Xc),T.certStart=p.toString().slice(0,100);let A=_.hostnames??(S.subjectAltName?S.subjectAltName.split(",").map(V=>{let x=V.indexOf(":");return V.slice(x+1)}):[yA(S)]);Array.isArray(A)||(A=[A]);let I;for(let V of A)if(V){V[0]==="*"&&(s=!0,V=V.slice(1)),D0.isIP(V)&&(I=!0);let x=r.get(V)?.quality??0;f>x&&r.set(V,T)}else ba.error("No hostname found for certificate at",ya.certificate);f>u&&(i.defaultContext=n=T,u=f,o&&(o.defaultContext=T,ba.trace("Applying default TLS",T.name,"for",o.ports,"cert named",_.name)))}catch(E){ba.error("Error applying TLS for",_.name,E)}o?.secureContextsListeners.forEach(_=>_()),c(n)}catch(u){l(u)}}a(d,"updateTLS"),pA.system.hdb_certificate.subscribe({listener:d,omitCurrent:!0}),d()})),i;function i(o,c){ba.info("TLS requested for",o,this.isReplicationConnection);let l=o;for(;;){let u=r.get(l);if(u)return ba.debug("Found certificate for",o,u.certStart),u.replicationContext&&(this.isReplicationConnection||O0)&&(u=u.replicationContext),c(null,u);if(s&&l){let _=l.indexOf(".",1);_<0?l="":l=l.slice(_)}else break}o?ba.debug("No certificate found to match",o,"using the default certificate"):ba.debug("No SNI, using the default certificate");let d=n;d.replicationContext&&(this.isReplicationConnection||O0)&&(d=d.replicationContext),c(null,d)}a(i,"SNICallback")}a(Y0,"createTLSSelector");async function K0(){Na();let e=[];for await(let t of tn.search([]))e.push(t);return e}a(K0,"listCertificates");async function gee(e){let t=P0(e,wi.object({name:wi.string().required(),certificate:wi.string().required(),is_authority:wi.boolean().required(),private_key:wi.string(),hosts:wi.array(),uses:wi.array()}));if(t)throw new Id(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new yo(n),c=!1,l=!1,d;for(let[f,h]of Oa)!s&&!c&&o.checkPrivateKey(L0(h))&&(c=!0,d=f),s&&s===h&&(l=!0,d=f);if(!i&&!s&&!c)throw new Id("A suitable private key was not found for this certificate");let u;if(!r){try{u=yA(o)}catch(f){ht.error(f)}if(u==null)throw new Id("Error extracting certificate common name, please provide a name parameter")}let _=Ree(r??u);s&&!c&&!l&&(await Wn.writeFile(fr.join(gs.getHdbBasePath(),Rs.LICENSE_KEY_DIR_NAME,_+".pem"),s),Oa.set(_,s));let E={name:r??u,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&d||i&&s)&&(E.private_key_name=d??_+".pem"),await tl(E),"Successfully added certificate: "+_}a(gee,"addCertificate");function Ree(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(Ree,"sanitizeName");async function Aee(e){let t=P0(e,wi.object({name:wi.string().required()}));if(t)throw new Id(t.message);let{name:r}=e;Na();let n=await tn.get(r);if(!n)throw new Id(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await tn.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(ht.info("Removing private key named",s),await Wn.remove(fr.join(gs.getHdbBasePath(),Rs.LICENSE_KEY_DIR_NAME,s)))}return await tn.delete(r),"Successfully removed "+r}a(Aee,"removeCertificate");function yA(e){return e.subject.match(/CN=(.*)/)?.[1]}a(yA,"extractCommonName")});var Ia={};Ze(Ia,{addNodeBack:()=>Iee,removeNodeBack:()=>wee,setNode:()=>Nee});async function Nee(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=Qs(t)):t=bh(r);let n=(0,z0.validateBySchema)(e,Oee);if(n)throw(0,Js.handleHDBError)(n,n.message,yee.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Js.ClientError("url or hostname is required for remove_node operation");let _=r,E=Hr(),f=await E.get(_);if(!f)throw new Js.ClientError(_+" does not exist");try{await Ah({url:f.url},{operation:Dd.OPERATIONS_ENUM.REMOVE_NODE_BACK,name:f?.subscriptions?.length>0?at():_},void 0)}catch(h){Qn.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:`,h)}return await E.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Js.ClientError("url required for this operation");let s=Ro();if(s==null)throw new Js.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){if(e.operation==="add_node"&&!e.authorization)throw new Js.ClientError("authorization parameter is required");i=await(0,zn.getReplicationCert)();let _=await(0,zn.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,zn.createCsr)(),Qn.info("Sending CSR to target node:",t)):(c=_?.certificate,Qn.info("Sending CA named",_?.name,"to target node",t))}let l={operation:Dd.OPERATIONS_ENUM.ADD_NODE_BACK,hostname:(0,j0.get)(Dd.CONFIG_PARAMS.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c};if(e.subscriptions&&(l.subscriptions=e.subscriptions.map(Q0)),e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=Q0(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 d;try{d=await Ah({url:t},l,e)}catch(_){throw _.message=`Error returned from ${t}: `+_.message,_}if(o&&(!d?.certificate||!d?.certificate?.includes?.("BEGIN CERTIFICATE")))throw new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(d)}`);o&&(Qn.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,zn.setCertTable)({name:bee.certificateFromPem(d.signingCA).issuer.getField("CN").value,certificate:d.signingCA,is_authority:!0}),d.certificate&&await(0,zn.setCertTable)({name:at(),uses:["https","operations","wss"],certificate:d.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=d.signingCA);let u={url:t,ca:d.usingCA};if(e.hostname&&(u.name=e.hostname),e.subscriptions?u.subscriptions=e.subscriptions:u.replicates=!0,e.start_time&&(u.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),u.replicates){let _={url:s,ca:c,replicates:!0};e.start_time&&(_.start_time=e.start_time),await Ii(at(),_)}return await Ii(d.nodeName,u),e.operation==="update_node"?`Successfully updated '${t}'`:`Successfully added '${t}' to cluster`}async function Iee(e){Qn.trace("addNodeBack received request:",e);let t=await(0,zn.signCertificate)(e),r;e.csr?(r=t.signingCA,Qn.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,Qn.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:n.replicates=!0,e.start_time&&(n.start_time=e.start_time);let s=await(0,zn.getReplicationCertAuth)();if(n.replicates){let i={url:Ro(),ca:s?.certificate,replicates:!0};e.start_time&&(i.start_time=e.start_time),await Ii(at(),i)}return await Ii(e.hostname,n),t.nodeName=at(),t.usingCA=s?.certificate,Qn.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function wee(e){Qn.trace("removeNodeBack received request:",e),await Hr().delete(e.name)}function Q0(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var zn,z0,rl,j0,Dd,Qn,Js,bee,yee,Oee,wa=Oe(()=>{zn=v(bo()),z0=v(ct()),rl=v(require("joi")),j0=v(ne()),Dd=v(M());Ad();Rd();Oi();Qn=v(j()),Js=v(ce()),{pki:bee}=require("node-forge"),{HTTP_STATUS_CODES:yee}=Js.hdb_errors,Oee=rl.default.object({hostname:rl.default.string(),verify_tls:rl.default.boolean(),replicates:rl.default.boolean(),subscriptions:rl.default.array()});a(Nee,"setNode");a(Iee,"addNodeBack");a(wee,"removeNodeBack");a(Q0,"reverseSubscription")});var Dh=N((DRe,X0)=>{"use strict";var{handleHDBError:Nh,hdb_errors:Cee}=ce(),{HTTP_STATUS_CODES:Ih}=Cee,{addUpdateNodeValidator:Dee}=QE(),wh=j(),Ch=M(),J0=lt(),Lee=te(),Ld=Mt(),Pd=Kn(),OA=ne(),Pee=XR(),{Node:Mee,NodeSubscription:Uee}=po(),{broadcast:vee}=et(),{setNode:xee}=(wa(),ae(Ia)),wRe=ne(),CRe=M(),Bee="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Hee="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",kee=OA.get(Ch.CONFIG_PARAMS.CLUSTERING_NODENAME);X0.exports=Fee;async function Fee(e,t=!1){if(wh.trace("addNode called with:",e),OA.get(Ch.CONFIG_PARAMS.REPLICATION_URL)||OA.get(Ch.CONFIG_PARAMS.REPLICATION_HOSTNAME))return xee(e);Pd.checkClusteringEnabled();let r=Dee(e);if(r)throw Nh(r,r.message,Ih.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let _=await Pd.getNodeRecord(n);if(!Lee.isEmptyOrZeroLength(_))throw Nh(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Ih.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Pee(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Bee,o;let c=Pd.buildNodePayloads(s,kee,Ch.OPERATIONS_ENUM.ADD_NODE,await Pd.getSystemInfo()),l=[];for(let _=0,E=s.length;_<E;_++){let f=s[_];s[_].start_time===void 0&&delete s[_].start_time,l.push(new Uee(f.schema,f.table,f.publish,f.subscribe))}wh.trace("addNode sending remote payload:",c);let d;try{d=await Ld.request(`${n}.${J0.REQUEST_SUFFIX}`,c)}catch(_){wh.error(`addNode received error from request: ${_}`);for(let f=0,h=s.length;f<h;f++){let p=s[f];p.publish=!1,p.subscribe=!1,await Ld.updateRemoteConsumer(p,n)}let E=Ld.requestErrorHandler(_,"add_node",n);throw Nh(new Error,E,Ih.INTERNAL_SERVER_ERROR,"error",E)}if(d.status===J0.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let _=`Error returned from remote node ${n}: ${d.message}`;throw Nh(new Error,_,Ih.INTERNAL_SERVER_ERROR,"error",_)}wh.trace(d);for(let _=0,E=s.length;_<E;_++){let f=s[_];await Ld.updateRemoteConsumer(f,n),f.subscribe===!0&&await Ld.updateConsumerIterator(f.schema,f.table,n,"start")}let u=new Mee(n,l,d.system_info);return await Pd.upsertNodeRecord(u),vee({type:"nats_update"}),i.length>0?o.message=Hee:o.message=`Successfully added '${n}' to manifest`,o}a(Fee,"addNode")});var CA=N((MRe,ex)=>{"use strict";var{handleHDBError:NA,hdb_errors:Gee}=ce(),{HTTP_STATUS_CODES:IA}=Gee,{addUpdateNodeValidator:qee}=QE(),Md=j(),Lh=M(),Z0=lt(),PRe=te(),Ud=Mt(),vd=Kn(),wA=ne(),{cloneDeep:Vee}=require("lodash"),$ee=XR(),{Node:Yee,NodeSubscription:Kee}=po(),{broadcast:Wee}=et(),{setNode:Qee}=(wa(),ae(Ia)),zee="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",jee="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Jee=wA.get(Lh.CONFIG_PARAMS.CLUSTERING_NODENAME);ex.exports=Xee;async function Xee(e){if(Md.trace("updateNode called with:",e),wA.get(Lh.CONFIG_PARAMS.REPLICATION_URL)??wA.get(Lh.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Qee(e);vd.checkClusteringEnabled();let t=qee(e);if(t)throw NA(t,t.message,IA.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await vd.getNodeRecord(r);s.length>0&&(n=Vee(s));let{added:i,skipped:o}=await $ee(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=zee,c;let l=vd.buildNodePayloads(i,Jee,Lh.OPERATIONS_ENUM.UPDATE_NODE,await vd.getSystemInfo());for(let u=0,_=i.length;u<_;u++){let E=i[u];Md.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[u].start_time===void 0&&delete i[u].start_time}Md.trace("updateNode sending remote payload:",l);let d;try{d=await Ud.request(`${r}.${Z0.REQUEST_SUFFIX}`,l)}catch(u){Md.error(`updateNode received error from request: ${u}`);let _=Ud.requestErrorHandler(u,"update_node",r);throw NA(new Error,_,IA.INTERNAL_SERVER_ERROR,"error",_)}if(d.status===Z0.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${d.message}`;throw NA(new Error,u,IA.INTERNAL_SERVER_ERROR,"error",u)}Md.trace(d);for(let u=0,_=i.length;u<_;u++){let E=i[u];await Ud.updateRemoteConsumer(E,r),E.subscribe===!0?await Ud.updateConsumerIterator(E.schema,E.table,r,"start"):await Ud.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new Yee(r,[],d.system_info)]),await Zee(n[0],i,d.system_info),o.length>0?c.message=jee:c.message=`Successfully updated '${r}'`,c}a(Xee,"updateNode");async function Zee(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,d=e.subscriptions.length;l<d;l++){let u=n.subscriptions[l];if(u.schema===o.schema&&u.table===o.table){u.publish=o.publish,u.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new Kee(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await vd.upsertNodeRecord(n),Wee({type:"nats_update"})}a(Zee,"updateNodeTable")});var ix=N((vRe,sx)=>{"use strict";var nx=require("joi"),{string:tx}=nx.types(),ete=ct(),rx=M(),tte=ne(),rte=lt();sx.exports=nte;function nte(e){let t=tx.invalid(tte.get(rx.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(rte.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=nx.object({operation:tx.valid(rx.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return ete.validateBySchema(e,r)}a(nte,"removeNodeValidator")});var Ph=N((BRe,ux)=>{"use strict";var{handleHDBError:ox,hdb_errors:ste}=ce(),{HTTP_STATUS_CODES:ax}=ste,ite=ix(),xd=j(),cx=Kn(),ote=te(),nl=M(),lx=lt(),DA=Mt(),LA=ne(),{RemotePayloadObject:ate}=hd(),{NodeSubscription:cte}=po(),lte=wc(),ute=so(),{broadcast:dte}=et(),{setNode:_te}=(wa(),ae(Ia)),fte=LA.get(nl.CONFIG_PARAMS.CLUSTERING_NODENAME);ux.exports=Ete;async function Ete(e){if(xd.trace("removeNode called with:",e),LA.get(nl.CONFIG_PARAMS.REPLICATION_URL)??LA.get(nl.CONFIG_PARAMS.REPLICATION_HOSTNAME))return _te(e);cx.checkClusteringEnabled();let t=ite(e);if(t)throw ox(t,t.message,ax.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await cx.getNodeRecord(r);if(ote.isEmptyOrZeroLength(n))throw ox(new Error,`Node '${r}' was not found.`,ax.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new ate(nl.OPERATIONS_ENUM.REMOVE_NODE,fte,[]),i,o=!1;for(let l=0,d=n.subscriptions.length;l<d;l++){let u=n.subscriptions[l];u.subscribe===!0&&await DA.updateConsumerIterator(u.schema,u.table,r,"stop");try{await DA.updateRemoteConsumer(new cte(u.schema,u.table,!1,!1),r)}catch(_){xd.error(_)}}try{i=await DA.request(`${r}.${lx.REQUEST_SUFFIX}`,s),xd.trace("Remove node reply from remote node:",r,i)}catch(l){xd.error("removeNode received error from request:",l),o=!0}let c=new lte(nl.SYSTEM_SCHEMA_NAME,nl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await ute.deleteRecord(c),dte({type:"nats_update"}),i?.status===lx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(xd.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(Ete,"removeNode")});var fx=N((kRe,_x)=>{"use strict";var dx=require("joi"),{string:hte,array:mte}=dx.types(),pte=ct(),Ste=QE();_x.exports=Tte;function Tte(e){let t=dx.object({operation:hte.valid("configure_cluster").required(),connections:mte.items(Ste.validation_schema).required()});return pte.validateBySchema(e,t)}a(Tte,"configureClusterValidator")});var PA=N((GRe,Sx)=>{"use strict";var Ex=M(),Mh=j(),gte=te(),Rte=ne(),Ate=Ph(),bte=Dh(),yte=Kn(),Ote=fx(),{handleHDBError:hx,hdb_errors:Nte}=ce(),{HTTP_STATUS_CODES:mx}=Nte,Ite="Configure cluster complete.",wte="Failed to configure the cluster. Check the logs for more details.",Cte="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";Sx.exports=Dte;async function Dte(e){Mh.trace("configure cluster called with:",e);let t=Ote(e);if(t)throw hx(t,t.message,mx.BAD_REQUEST,void 0,void 0,!0);let r=await yte.getAllNodeRecords(),n=[];if(Rte.get(Ex.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let u=0,_=r.length;u<_;u++){let E=await px(Ate,{operation:Ex.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[u].name},r[u].name);n.push(E)}Mh.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let u=0;u<i;u++){let _=e.connections[u],E=await px(bte,_,_.node_name);s.push(E)}Mh.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,d=n.concat(s);for(let u=0,_=d.length;u<_;u++){let E=d[u];E.status==="rejected"&&(Mh.error(E.node_name,E?.error?.message,E?.error?.stack),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,response:E?.result})}if(gte.isEmptyOrZeroLength(o))return{message:Ite,connections:c};if(l)return{message:Cte,failed_nodes:o,connections:c};throw hx(new Error,wte,mx.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Dte,"configureCluster");async function px(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(px,"functionWrapper")});var Ax=N((VRe,Rx)=>{"use strict";var Bd=require("joi"),Lte=ct(),{validateSchemaExists:Tx,validateTableExists:Pte,validateSchemaName:gx}=Bs(),Mte=Bd.object({operation:Bd.string().valid("purge_stream"),schema:Bd.string().custom(Tx).custom(gx).optional(),database:Bd.string().custom(Tx).custom(gx).optional(),table:Bd.string().custom(Pte).required()});function Ute(e){return Lte.validateBySchema(e,Mte)}a(Ute,"purgeStreamValidator");Rx.exports=Ute});var MA=N((YRe,bx)=>{"use strict";var{handleHDBError:vte,hdb_errors:xte}=ce(),{HTTP_STATUS_CODES:Bte}=xte,Hte=Ax(),kte=Mt(),Fte=Kn();bx.exports=Gte;async function Gte(e){e.schema=e.schema??e.database;let t=Hte(e);if(t)throw vte(t,t.message,Bte.BAD_REQUEST,void 0,void 0,!0);Fte.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await kte.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(Gte,"purgeStream")});var xA=N((WRe,Dx)=>{"use strict";var vA=Kn(),qte=Mt(),Uh=ne(),sl=M(),Ca=lt(),Vte=te(),UA=j(),{RemotePayloadObject:$te}=hd(),{ErrorCode:yx}=require("nats"),{parentPort:Ox}=require("worker_threads"),{onMessageByType:Yte}=et(),{getThisNodeName:Kte}=(Oi(),ae(Nd)),{requestClusterStatus:Wte}=(Ad(),ae(Jv)),Nx=Uh.get(sl.CONFIG_PARAMS.CLUSTERING_ENABLED),Ix=Uh.get(sl.CONFIG_PARAMS.CLUSTERING_NODENAME);Dx.exports={clusterStatus:Qte,buildNodeStatus:Cx};var wx;Yte("cluster-status",async e=>{wx(e)});async function Qte(){if(Uh.get(sl.CONFIG_PARAMS.REPLICATION_URL)||Uh.get(sl.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;return Ox?(Ox.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{wx=s})):n=await Wte(),n.node_name=Kte(),n.is_enabled=!0,n}let e={node_name:Ix,is_enabled:Nx,connections:[]};if(!Nx)return e;let t=await vA.getAllNodeRecords();if(Vte.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Cx(t[n],e.connections));return await Promise.allSettled(r),e}a(Qte,"clusterStatus");async function Cx(e,t){let r=e.name,n=new $te(sl.OPERATIONS_ENUM.CLUSTER_STATUS,Ix,void 0,await vA.getSystemInfo()),s,i,o=Ca.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await qte.request(Ca.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Ca.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Ca.CLUSTER_STATUS_STATUSES.CLOSED,UA.error(`Error getting node status from ${r} `,s))}catch(l){UA.warn(`Error getting node status from ${r}`,l),l.code===yx.NoResponders?o=Ca.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===yx.Timeout?o=Ca.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Ca.CLUSTER_STATUS_STATUSES.CLOSED}let c=new zte(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!==sl.PRE_4_0_0_VERSION&&await vA.upsertNodeRecord(l)}catch(l){UA.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Cx,"buildNodeStatus");function zte(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(zte,"NodeStatusObject")});var HA=N((zRe,Lx)=>{"use strict";var{handleHDBError:jte,hdb_errors:Jte}=ce(),{HTTP_STATUS_CODES:Xte}=Jte,Zte=Mt(),ere=Kn(),BA=te(),vh=require("joi"),tre=ct(),rre=2e3,nre=vh.object({timeout:vh.number().min(1),connected_nodes:vh.boolean(),routes:vh.boolean()});Lx.exports=sre;async function sre(e){ere.checkClusteringEnabled();let t=tre.validateBySchema(e,nre);if(t)throw jte(t,t.message,Xte.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||BA.autoCastBoolean(n),o=s===void 0||BA.autoCastBoolean(s),c={nodes:[]},l=await Zte.getServerList(r??rre),d={};if(i)for(let u=0,_=l.length;u<_;u++){let E=l[u].statsz;E&&(d[l[u].server.name]=E.routes)}for(let u=0,_=l.length;u<_;u++){if(l[u].statsz)continue;let E=l[u].server,f=l[u].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[u].response_time};i&&(h.connected_nodes=[],d[E.name]&&d[E.name].forEach(p=>{h.connected_nodes.includes(p.name.slice(0,-4))||h.connected_nodes.push(p.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(p=>({host:p.split(":")[0],port:BA.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(sre,"clusterNetwork")});var vx=N((JRe,Ux)=>{"use strict";var kA=require("joi"),Px=ct(),{route_constraints:Mx}=NT();Ux.exports={setRoutesValidator:ire,deleteRoutesValidator:ore};function ire(e){let t=kA.object({server:kA.valid("hub","leaf"),routes:Mx.required()});return Px.validateBySchema(e,t)}a(ire,"setRoutesValidator");function ore(e){let t=kA.object({routes:Mx.required()});return Px.validateBySchema(e,t)}a(ore,"deleteRoutesValidator")});var GA=N((ZRe,qx)=>{"use strict";var Ci=dr(),FA=te(),jn=M(),il=ne(),xx=vx(),{handleHDBError:Bx,hdb_errors:are}=ce(),{HTTP_STATUS_CODES:Hx}=are,kx="cluster routes successfully set",Fx="cluster routes successfully deleted";qx.exports={setRoutes:lre,getRoutes:ure,deleteRoutes:dre};function cre(e){let t=Ci.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=FA.autoCast(l.port);let d=r.some(_=>_.host===l.host&&_.port===l.port),u=n.some(_=>_.host===l.host&&_.port===l.port);d||u?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?Ci.updateConfigValue(jn.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):Ci.updateConfigValue(jn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:kx,set:i,skipped:s}}a(cre,"setRoutesNats");function lre(e){let t=xx.setRoutesValidator(e);if(t)throw Bx(t,t.message,Hx.BAD_REQUEST,void 0,void 0,!0);if(il.get(jn.CONFIG_PARAMS.CLUSTERING_ENABLED))return cre(e);let r=[],n=[],s=il.get(jn.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Gx(s,i)?n.push(i):(s.push(i),r.push(i))}),Ci.updateConfigValue(jn.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:kx,set:r,skipped:n}}a(lre,"setRoutes");function Gx(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(Gx,"existsInArray");function ure(){if(il.get(jn.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=Ci.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return il.get(jn.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(ure,"getRoutes");function dre(e){let t=xx.deleteRoutesValidator(e);if(t)throw Bx(t,t.message,Hx.BAD_REQUEST,void 0,void 0,!0);if(il.get(jn.CONFIG_PARAMS.CLUSTERING_ENABLED))return _re(e);let r=[],n=[],s=il.get(jn.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Gx(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),Ci.updateConfigValue(jn.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Fx,deleted:r,skipped:n}}a(dre,"deleteRoutes");function _re(e){let t=Ci.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,d=e.routes.length;l<d;l++){let u=e.routes[l],_=!1;for(let E=0,f=r.length;E<f;E++){let h=r[E];if(u.host===h.host&&u.port===h.port){r.splice(E,1),_=!0,o=!0,s.push(u);break}}if(!_){let E=!0;for(let f=0,h=n.length;f<h;f++){let p=n[f];if(u.host===p.host&&u.port===p.port){n.splice(f,1),c=!0,E=!1,s.push(u);break}}E&&i.push(u)}}return o&&(r=FA.isEmptyOrZeroLength(r)?null:r,Ci.updateConfigValue(jn.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=FA.isEmptyOrZeroLength(n)?null:n,Ci.updateConfigValue(jn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Fx,deleted:s,skipped:i}}a(_re,"deleteRoutesNats")});var $x=N((tAe,Vx)=>{"use strict";var Hd=require("alasql"),Da=require("recursive-iterator"),As=j(),fre=te(),kd=M(),qA=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,hre(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=>kd.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=>!kd.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][kd.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Ere(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(d=>({attribute_name:d.attribute}));let l=this.affected_attributes.get(i).get(o).filter(d=>!kd.SEARCH_WILDCARDS.includes(d));c.forEach(({attribute_name:d})=>{let u=new Hd.yy.Column({columnid:d});s.tableid&&(u.tableid=s.tableid),this.ast.columns.push(u),l.includes(d)||l.push(d)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function Ere(e){return e.filter(t=>t[kd.PERMS_CRUD_ENUM.READ])}a(Ere,"filterReadRestrictedAttrs");function hre(e,t,r,n,s){mre(e,t,r,n,s)}a(hre,"interpretAST");function Fd(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(Fd,"addSchemaTableToMap");function mre(e,t,r,n,s){if(!e){As.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Hd.yy.Insert?gre(e,t,r):e instanceof Hd.yy.Select?pre(e,t,r,n,s):e instanceof Hd.yy.Update?Sre(e,t,r):e instanceof Hd.yy.Delete?Tre(e,t,r):As.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(mre,"getRecordAttributesAST");function pre(e,t,r,n,s){if(!e){As.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(fre.isEmptyOrZeroLength(i)){As.error("No schema specified");return}e.from.forEach(c=>{Fd(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Fd(c.table,t,r,n,s)});let o=new Da(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,d=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(d).has(l))if(r.has(l))l=r.get(l);else{As.info(`table specified as ${l} not found.`);return}t.get(d).get(l).indexOf(c.columnid)<0&&t.get(d).get(l).push(c.columnid)}if(e.where){let c=new Da(e.where),l=e.from[0].tableid;for(let{node:d}of c)if(d&&d.columnid){let u=d.tableid?d.tableid:l;if(!t.get(i).has(u))if(r.has(u))u=r.get(u);else{As.info(`table specified as ${u} not found.`);continue}t.get(i).get(u).indexOf(d.columnid)<0&&t.get(i).get(u).push(d.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Da(c.on);for(let{node:d}of l)if(d&&d.columnid){let u=d.tableid,_=s.get(u);if(!t.get(_).has(u))if(r.has(u))u=r.get(u);else{As.info(`table specified as ${u} not found.`);continue}t.get(_).get(u).indexOf(d.columnid)<0&&t.get(_).get(u).push(d.columnid)}}),e.order){let c=new Da(e.order);for(let{node:l}of c)if(l&&l.columnid){let d=l.tableid,u=n.has(d)?n.get(d):i;if(d||(d=e.from[0].tableid),!t.get(u).has(d))if(r.has(d))d=r.get(d);else{As.info(`table specified as ${d} not found.`);return}t.get(u).get(d).indexOf(l.columnid)<0&&t.get(u).get(d).push(l.columnid)}}}a(pre,"getSelectAttributes");function Sre(e,t,r){if(!e){As.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Da(e.columns),s=e.table.databaseid;Fd(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&VA(e.table.tableid,s,i.columnid,t,r)}a(Sre,"getUpdateAttributes");function Tre(e,t,r){if(!e){As.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Da(e.where),s=e.table.databaseid;Fd(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&VA(e.table.tableid,s,i.columnid,t,r)}a(Tre,"getDeleteAttributes");function gre(e,t,r){if(!e){As.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Da(e.columns),s=e.into.databaseid;Fd(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&VA(e.into.tableid,s,i.columnid,t,r)}a(gre,"getInsertAttributes");function VA(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(VA,"pushAttribute");Vx.exports=qA});var KA=N((nAe,Qx)=>{var xh=ra(),Yx=require("chalk"),Cn=j(),Kx=require("prompt"),{promisify:Rre}=require("util"),$A=M(),Are=require("fs-extra"),bre=require("path"),yre=te(),Ore=rh(),Wx=ne();Wx.initSync();var Nre=require("moment"),Ire=Rre(Kx.get),wre=bre.join(Wx.getHdbBasePath(),$A.LICENSE_KEY_DIR_NAME,$A.LICENSE_FILE_NAME,$A.LICENSE_FILE_NAME);Qx.exports={getFingerprint:Dre,setLicense:Cre,parseLicense:YA,register:Lre,getRegistrationInfo:Mre};async function Cre(e){if(e&&e.key&&e.company){try{Cn.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await YA(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Cn.error(r),Cn.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(Cre,"setLicense");async function Dre(){let e={};try{e=await xh.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Cn.error(r),Cn.error(t),new Error(r)}return e}a(Dre,"getFingerprint");async function YA(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Cn.info("Validating license input...");let r=xh.validateLicense(e,t);if(Cn.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Cn.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Cn.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Cn.info("writing license to disk"),await Are.writeFile(wre,JSON.stringify({license_key:e,company:t}))}catch(n){throw Cn.error("Failed to write License"),n}return"Registration successful."}a(YA,"parseLicense");async function Lre(){let e=await Pre();return YA(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Lre,"register");async function Pre(){let e=await xh.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Yx.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Yx.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{Kx.start()}catch(n){Cn.error(n)}let r;try{r=await Ire(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(Pre,"promptForRegistration");async function Mre(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await xh.getLicense()}catch(r){throw Cn.error(`There was an error when searching licenses due to: ${r.message}`),r}if(yre.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=Ore.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=Nre.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(Mre,"getRegistrationInfo")});var jx=N((iAe,zx)=>{"use strict";var Ure=lt(),WA=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,d,u,_,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+Ure.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:d,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:_,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};zx.exports=WA});var Zx=N((aAe,Xx)=>{"use strict";var Jx=lt(),QA=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,d,u,_){this.port=t,_===null&&(_=void 0),this.server_name=r+Jx.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+Jx.SERVER_SUFFIX.LEAF},this.tls={cert_file:d,key_file:u,ca_file:_,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:_,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:_,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};Xx.exports=QA});var tB=N((lAe,eB)=>{"use strict";var zA=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};eB.exports=zA});var nB=N((dAe,rB)=>{"use strict";var vre=lt(),jA=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+vre.SERVER_SUFFIX.ADMIN,this.password=r}};rB.exports=jA});var ZA=N((fAe,oB)=>{"use strict";var ol=require("path"),al=require("fs-extra"),xre=jx(),Bre=Zx(),Hre=tB(),kre=nB(),JA=$n(),ll=te(),rn=dr(),Hh=M(),Gd=lt(),{CONFIG_PARAMS:$t}=Hh,ul=j(),qd=ne(),sB=pi(),XA=Mt(),Fre=bo(),cl="clustering",Gre=1e4,iB=50;oB.exports={generateNatsConfig:Vre,removeNatsConfig:$re,getHubConfigPath:qre};function qre(){let e=qd.get($t.ROOTPATH);return ol.join(e,cl,Gd.NATS_CONFIG_FILES.HUB_SERVER)}a(qre,"getHubConfigPath");async function Vre(e=!1,t=void 0){qd.initSync();let r=rn.getConfigFromFile($t.CLUSTERING_TLS_CERT_AUTH),n=rn.getConfigFromFile($t.CLUSTERING_TLS_PRIVATEKEY),s=rn.getConfigFromFile($t.CLUSTERING_TLS_CERTIFICATE);!await al.exists(s)&&!await al.exists(!r)&&await Fre.createNatsCerts();let i=qd.get($t.ROOTPATH),o=ol.join(i,cl,Gd.PID_FILES.HUB),c=ol.join(i,cl,Gd.PID_FILES.LEAF),l=rn.getConfigFromFile($t.CLUSTERING_LEAFSERVER_STREAMS_PATH),d=ol.join(i,cl,Gd.NATS_CONFIG_FILES.HUB_SERVER),u=ol.join(i,cl,Gd.NATS_CONFIG_FILES.LEAF_SERVER),_=rn.getConfigFromFile($t.CLUSTERING_TLS_INSECURE),E=rn.getConfigFromFile($t.CLUSTERING_TLS_VERIFY),f=rn.getConfigFromFile($t.CLUSTERING_NODENAME),h=rn.getConfigFromFile($t.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await XA.checkNATSServerInstalled()||kh("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await JA.listUsers(),S=rn.getConfigFromFile($t.CLUSTERING_USER),g=await JA.getClusterUser();(ll.isEmpty(g)||g.active!==!0)&&kh(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Bh($t.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Bh($t.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Bh($t.CLUSTERING_HUBSERVER_NETWORK_PORT),await Bh($t.CLUSTERING_LEAFSERVER_NETWORK_PORT));let T=[],A=[];for(let[se,ee]of p.entries())ee.role.role===Hh.ROLE_TYPES_ENUM.CLUSTER_USER&&ee.active&&(T.push(new kre(ee.username,sB.decrypt(ee.hash))),A.push(new Hre(ee.username,sB.decrypt(ee.hash))));let I=[],{hub_routes:V}=rn.getClusteringRoutes();if(!ll.isEmptyOrZeroLength(V))for(let se of V)I.push(`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@${se.host}:${se.port}`);let x=new xre(rn.getConfigFromFile($t.CLUSTERING_HUBSERVER_NETWORK_PORT),f,o,s,n,r,_,E,h,rn.getConfigFromFile($t.CLUSTERING_HUBSERVER_CLUSTER_NAME),rn.getConfigFromFile($t.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,T,A);r==null&&(delete x.tls.ca_file,delete x.leafnodes.tls.ca_file),t=ll.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Hh.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await al.writeJson(d,x),ul.trace(`Hub server config written to ${d}`));let X=`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,$=`tls://${g.uri_encoded_name}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,F=new Bre(rn.getConfigFromFile($t.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,c,l,[X],[$],T,A,s,n,r,_);r==null&&delete F.tls.ca_file,(t===void 0||t===Hh.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await al.writeJson(u,F),ul.trace(`Leaf server config written to ${u}`))}a(Vre,"generateNatsConfig");async function Bh(e){let t=qd.get(e);return ll.isEmpty(t)&&kh(`port undefined for '${e}'`),await ll.isPortTaken(t)&&kh(`'${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(Bh,"isPortAvailable");function kh(e){let t=`Error generating clustering config: ${e}`;ul.error(t),console.error(t),process.exit(1)}a(kh,"generateNatsConfigError");async function $re(e){let{port:t,config_file:r}=XA.getServerConfig(e),{username:n,decrypt_hash:s}=await JA.getClusterUser(),i=0,o=2e3;for(;i<iB;){try{let u=await XA.createConnection(t,n,s,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){ul.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=iB)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 d=o*(i*2);d>3e4&&ul.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await ll.async_set_timeout(d)}let c="0".repeat(Gre),l=ol.join(qd.get($t.ROOTPATH),cl,r);await al.writeFile(l,c),await al.remove(l),ul.notify(e,"started.")}a($re,"removeNatsConfig")});var _B=N((hAe,dB)=>{"use strict";var Dn=ne(),Yre=ra(),Ue=M(),Vd=lt(),Di=require("path"),{PACKAGE_ROOT:Gh}=M(),aB=ne(),Fh=te(),dl="/dev/null",Kre=Di.join(Gh,"launchServiceScripts"),cB=Di.join(Gh,"utility/scripts"),Wre=Di.join(cB,Ue.HDB_RESTART_SCRIPT),lB=Di.resolve(Gh,"dependencies",`${process.platform}-${process.arch}`,Vd.NATS_BINARY_NAME);function uB(){let t=Yre.licenseSearch().ram_allocation||Ue.RAM_ALLOCATION_ENUM.DEFAULT,r=Ue.MEM_SETTING_KEY+t,n={[Ue.PROCESS_NAME_ENV_PROP]:Ue.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Fh.noBootFile()&&(n[Ue.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Fh.getEnvCliRootPath()),{name:Ue.PROCESS_DESCRIPTORS.HDB,script:Ue.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:Gh}}a(uB,"generateMainServerConfig");var Qre=9930;function zre(){Dn.initSync(!0);let e=Dn.get(Ue.CONFIG_PARAMS.ROOTPATH),t=Di.join(e,"clustering",Vd.NATS_CONFIG_FILES.HUB_SERVER),r=Di.join(Dn.get(Ue.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ue.LOG_NAMES.HDB),n=aB.get(Ue.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Vd.LOG_LEVEL_FLAGS[Dn.get(Ue.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ue.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Qre?"-"+n:""),script:lB,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ue.PROCESS_NAME_ENV_PROP]:Ue.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Dn.get(Ue.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=dl,i.error_file=dl),i}a(zre,"generateNatsHubServerConfig");var jre=9940;function Jre(){Dn.initSync(!0);let e=Dn.get(Ue.CONFIG_PARAMS.ROOTPATH),t=Di.join(e,"clustering",Vd.NATS_CONFIG_FILES.LEAF_SERVER),r=Di.join(Dn.get(Ue.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ue.LOG_NAMES.HDB),n=aB.get(Ue.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Vd.LOG_LEVEL_FLAGS[Dn.get(Ue.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ue.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==jre?"-"+n:""),script:lB,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ue.PROCESS_NAME_ENV_PROP]:Ue.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Dn.get(Ue.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=dl,i.error_file=dl),i}a(Jre,"generateNatsLeafServerConfig");function Xre(){Dn.initSync();let e=Di.join(Dn.get(Ue.CONFIG_PARAMS.LOGGING_ROOT),Ue.LOG_NAMES.HDB),t={name:Ue.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ue.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ue.PROCESS_NAME_ENV_PROP]:Ue.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Kre,autorestart:!1};return Dn.get(Ue.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=dl,t.error_file=dl),t}a(Xre,"generateClusteringUpgradeV4ServiceConfig");function Zre(){let e={[Ue.PROCESS_NAME_ENV_PROP]:Ue.PROCESS_DESCRIPTORS.RESTART_HDB};return Fh.noBootFile()&&(e[Ue.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Fh.getEnvCliRootPath()),{...{name:Ue.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:cB},script:Wre}}a(Zre,"generateRestart");function ene(){return{apps:[uB()]}}a(ene,"generateAllServiceConfigs");dB.exports={generateAllServiceConfigs:ene,generateMainServerConfig:uB,generateRestart:Zre,generateNatsHubServerConfig:zre,generateNatsLeafServerConfig:Jre,generateClusteringUpgradeV4ServiceConfig:Xre}});var NB=N((SAe,OB)=>{"use strict";var Xe=M(),tne=te(),Pi=ZA(),qh=Mt(),Li=lt(),Oo=_B(),Vh=ne(),La=j(),rne=Kn(),{startWorker:fB,onMessageFromWorkers:nne}=et(),sne=Vc(),pAe=require("util"),ine=require("child_process"),one=require("fs"),{execFile:ane}=ine,Ye;OB.exports={enterPM2Mode:cne,start:No,stop:eb,reload:hB,restart:mB,list:tb,describe:SB,connect:Mi,kill:fne,startAllServices:Ene,startService:rb,getUniqueServicesList:TB,restartAllServices:hne,isServiceRegistered:gB,reloadStopStart:RB,restartHdb:pB,deleteProcess:dne,startClusteringProcesses:bB,startClusteringThreads:yB,isHdbRestartRunning:_ne,isClusteringRunning:pne,stopClustering:mne,reloadClustering:Sne};var $d=!1;nne(e=>{e.type==="restart"&&Vh.initSync(!0)});function cne(){$d=!0}a(cne,"enterPM2Mode");function Mi(){return Ye||(Ye=require("pm2")),new Promise((e,t)=>{Ye.connect((r,n)=>{r&&t(r),e(n)})})}a(Mi,"connect");var nn,lne=10,EB;function No(e,t=!1){if($d)return une(e);let r=ane(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=nn.indexOf(r);o>-1&&nn.splice(o,1),!EB&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<lne&&(one.existsSync(Pi.getHubConfigPath())?No(e):(await Pi.generateNatsConfig(!0),No(e),await new Promise(c=>setTimeout(c,3e3)),await Pi.removeNatsConfig(Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Pi.removeNatsConfig(Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Vh.get(Xe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,d=0,u;for(;l=c.exec(i);){if(l.index&&Li.LOG_LEVEL_HIERARCHY[o]>=Li.LOG_LEVEL_HIERARCHY[u||"info"]){let f=u===Li.LOG_LEVELS.ERR||u===Li.LOG_LEVELS.WRN?La.OUTPUTS.STDERR:La.OUTPUTS.STDOUT;La.logCustomLevel(u||"info",f,n,i.slice(d,l.index).trim())}let[_,E]=l;d=l.index+_.length,u=Li.LOG_LEVELS[E]}if(Li.LOG_LEVEL_HIERARCHY[o]>=Li.LOG_LEVEL_HIERARCHY[u||"info"]){let _=u===Li.LOG_LEVELS.ERR||u===Li.LOG_LEVELS.WRN?La.OUTPUTS.STDERR:La.OUTPUTS.STDOUT;La.logCustomLevel(u||"info",_,n,i.slice(d).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),nn=[],!nn&&!t){let i=a(()=>{EB=!0,nn&&(nn.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)}nn.push(r)}a(No,"start");function une(e){return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ye.start(e,(n,s)=>{n&&(Ye.disconnect(),r(n)),Ye.disconnect(),t(s)})})}a(une,"startWithPM2");function eb(e){if(!$d){for(let t of nn||[])t.name===e&&(nn.splice(nn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ye.stop(e,async(n,s)=>{n&&(Ye.disconnect(),r(n)),Ye.delete(e,(i,o)=>{i&&(Ye.disconnect(),r(n)),Ye.disconnect(),t(o)})})})}a(eb,"stop");function hB(e){return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ye.reload(e,(n,s)=>{n&&(Ye.disconnect(),r(n)),Ye.disconnect(),t(s)})})}a(hB,"reload");function mB(e){if(!$d)for(let t of nn||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ye.restart(e,(n,s)=>{Ye.disconnect(),t(s)})})}a(mB,"restart");function dne(e){return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ye.delete(e,(n,s)=>{n&&(Ye.disconnect(),r(n)),Ye.disconnect(),t(s)})})}a(dne,"deleteProcess");async function pB(){await No(Oo.generateRestart())}a(pB,"restartHdb");async function _ne(){let e=await tb();for(let t in e)if(e[t].name===Xe.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(_ne,"isHdbRestartRunning");function tb(){return new Promise(async(e,t)=>{try{await Mi()}catch(r){t(r)}Ye.list((r,n)=>{r&&(Ye.disconnect(),t(r)),Ye.disconnect(),e(n)})})}a(tb,"list");function SB(e){return new Promise(async(t,r)=>{try{await Mi()}catch(n){r(n)}Ye.describe(e,(n,s)=>{n&&(Ye.disconnect(),r(n)),Ye.disconnect(),t(s)})})}a(SB,"describe");function fne(){if(!$d){for(let e of nn||[])e.kill();nn=[];return}return new Promise(async(e,t)=>{try{await Mi()}catch(r){t(r)}Ye.killDaemon((r,n)=>{r&&(Ye.disconnect(),t(r)),Ye.disconnect(),e(n)})})}a(fne,"kill");async function Ene(){try{await bB(),await yB(),await No(Oo.generateAllServiceConfigs())}catch(e){throw Ye?.disconnect(),e}}a(Ene,"startAllServices");async function rb(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Xe.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Oo.generateMainServerConfig();break;case Xe.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Oo.generateNatsIngestServiceConfig();break;case Xe.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Oo.generateNatsReplyServiceConfig();break;case Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Oo.generateNatsHubServerConfig(),await No(r,t),await Pi.removeNatsConfig(e);return;case Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Oo.generateNatsLeafServerConfig(),await No(r,t),await Pi.removeNatsConfig(e);return;case Xe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Oo.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await No(r)}catch(r){throw Ye?.disconnect(),r}}a(rb,"startService");async function TB(){try{let e=await tb(),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 Ye?.disconnect(),e}}a(TB,"getUniqueServicesList");async function hne(e=[]){try{let t=!1,r=await TB();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===Xe.PROCESS_DESCRIPTORS.HDB?t=!0:await mB(o))}t&&await RB(Xe.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ye?.disconnect(),t}}a(hne,"restartAllServices");async function gB(e){if(nn?.find(r=>r.name===e))return!0;let t=await sne.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(gB,"isServiceRegistered");async function RB(e){let t=Vh.get(Xe.CONFIG_PARAMS.THREADS_COUNT)??Vh.get(Xe.CONFIG_PARAMS.THREADS),r=await SB(e),n=tne.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await eb(e),await rb(e)):e===Xe.PROCESS_DESCRIPTORS.HDB?await pB():await hB(e)}a(RB,"reloadStopStart");var AB;async function bB(e=!1){for(let t in Xe.CLUSTERING_PROCESSES){let r=Xe.CLUSTERING_PROCESSES[t];await rb(r,e)}}a(bB,"startClusteringProcesses");async function yB(){AB=fB(Xe.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Xe.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await qh.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await qh.updateLocalStreams();let e=await rne.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Xe.PRE_4_0_0_VERSION){La.info("Starting clustering upgrade 4.0.0 process"),fB(Xe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(yB,"startClusteringThreads");async function mne(){for(let e in Xe.CLUSTERING_PROCESSES)if(e!==Xe.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===Xe.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await AB.terminate();else{let t=Xe.CLUSTERING_PROCESSES[e];await eb(t)}}a(mne,"stopClustering");async function pne(){for(let e in Xe.CLUSTERING_PROCESSES){let t=Xe.CLUSTERING_PROCESSES[e];if(await gB(t)===!1)return!1}return!0}a(pne,"isClusteringRunning");async function Sne(){await Pi.generateNatsConfig(!0),await qh.reloadNATSHub(),await qh.reloadNATSLeaf(),await Pi.removeNatsConfig(Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Pi.removeNatsConfig(Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Sne,"reloadClustering")});var MB={};Ze(MB,{compactOnStart:()=>Tne,copyDb:()=>PB});async function Tne(){Kd.notify("Running compact on start"),console.log("Running compact on start");let e=(0,nb.get)(Io.CONFIG_PARAMS.ROOTPATH),t=new Map,r=ut();try{for(let n in r){if(n==="system")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,$h.join)(e,"backup",n+".mdb"),o=(0,$h.join)(e,Io.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await IB(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await PB(n,o),console.log("Backing up",n,"to",i),await(0,Pa.move)(s,i,{overwrite:!0})}Yd();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,Pa.move)(i,s,{overwrite:!0}),await(0,Pa.remove)((0,$h.join)(e,Io.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));Yd()}catch(n){Kd.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,sb.updateConfigValue)(Io.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,Pa.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Yd(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await IB(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}.
|
|
14
|
+
`,"")}a(q0,"runCommand");async function Jee(){try{await wee.access(ib)}catch{return!1}let e=await q0(`${ib} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Cee.eq(t,Qee)}a(Jee,"checkNATSServerInstalled");async function ub(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await F0.getClusterUser();if(mc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Ks.trace("create nats connection called");let i=await kee({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Ks.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Ks.error("Error with Nats client connection, connection closed",o),$0()}),i}a(ub,"createConnection");function $0(){un=void 0,fc=void 0,Ec=void 0,hc=void 0}a($0,"clearClientCache");async function Xee(){un&&(await un.drain(),un=void 0,fc=void 0,Ec=void 0,hc=void 0)}a(Xee,"closeConnection");var un,hc;async function L_(){return hc||(hc=ub(Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),un=await hc),un||hc}a(L_,"getConnection");async function M_(){if(fc)return fc;mc(un)&&await L_();let{domain:e}=Ql(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(mc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return fc=await un.jetstreamManager({domain:e,timeout:6e4}),fc}a(M_,"getJetStreamManager");async function V0(){if(Ec)return Ec;mc(un)&&await L_();let{domain:e}=Ql(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(mc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ec=un.jetstream({domain:e,timeout:6e4}),Ec}a(V0,"getJetStream");async function Ri(){let e=un||await L_(),t=fc||await M_(),r=Ec||await V0();return{connection:e,jsm:t,js:r}}a(Ri,"getNATSReferences");async function Zee(e){let t=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await F0.getClusterUser(),s=await ub(t,r,n),i=lb(),o=s.subscribe(i),c=[],l,d=(async()=>{for await(let u of o){let _=G0.decode(u.data);_.response_time=Date.now()-l,c.push(_)}})();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 Am.async_set_timeout(e),await o.drain(),await s.close(),await d,c}a(Zee,"getServerList");async function db(e,t){let{jsm:r}=await Ri(),n=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Fee.File,retention:Gee.Limits,subjects:t,discard:qee.Old,max_msgs:s,max_bytes:i,max_age:n})}a(db,"createLocalStream");async function Y0(){let{jsm:e}=await Ri(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Y0,"listStreams");async function ete(e){let{jsm:t}=await Ri();await t.streams.delete(e)}a(ete,"deleteLocalStream");async function tte(e){let{connection:t}=await Ri(),r=[],n=lb(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(G0.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(tte,"listRemoteStreams");async function rte(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ri(),i=B0(),o={durable_name:i,ack_policy:ab.Explicit};t&&(o.deliver_policy=cb.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 d=[];for await(let u of l){let _=ob(u.data),E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:_};if(u.headers&&(E.origin=u.headers.get(Cr.MSG_HEADERS.ORIGIN)),d.push(E),u.ack(),u.info.pending===0)break}return await c.delete(),d}a(rte,"viewStream");async function*nte(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ri(),i=B0(),o={durable_name:i,ack_policy:ab.Explicit};t&&(o.deliver_policy=cb.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 d of l){let u=ob(d.data);u[0]||(u=[u]);for(let _ of u){let E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:_};d.headers&&(E.origin=d.headers.get(Cr.MSG_HEADERS.ORIGIN)),yield E}if(d.ack(),d.info.pending===0)break}await c.delete()}a(nte,"viewStreamIterator");async function ste(e,t,r,n){Ks.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=K0(n,r);let{js:s}=await Ri(),i=await ym(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:k0.encode(n);try{Ks.trace(`publishToStream publishing to subject: ${o}`),Wee(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 j0(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){Ks.trace(`publishToStream creating stream: ${t}`);let u=o.split(".");u[2]="*",await db(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(ste,"publishToStream");function K0(e,t){t===void 0&&(t=Vee());let r=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Cr.MSG_HEADERS.ORIGIN)&&r&&t.append(Cr.MSG_HEADERS.ORIGIN,r),t}a(K0,"addNatsMsgHeader");function Ql(e){e=e.toLowerCase();let t=P_.join(Rr.get(Qe.CONFIG_PARAMS.ROOTPATH),jee);if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return mc(sb)&&(sb={port:C_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:C_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Cr.SERVER_SUFFIX.HUB,config_file:Cr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:P_.join(t,Cr.PID_FILES.HUB),hdb_nats_path:t}),sb;if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return mc(nb)&&(nb={port:C_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:C_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Cr.SERVER_SUFFIX.LEAF,config_file:Cr.NATS_CONFIG_FILES.LEAF_SERVER,domain:C_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Cr.SERVER_SUFFIX.LEAF,pid_file_path:P_.join(t,Cr.PID_FILES.LEAF),hdb_nats_path:t}),nb;Ks.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Ql,"getServerConfig");async function W0(e,t,r,n){try{await e.consumers.add(t,{ack_policy:ab.Explicit,durable_name:r,deliver_policy:cb.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(W0,"createConsumer");async function ite(e,t,r){await e.consumers.delete(t,r)}a(ite,"removeConsumer");function ote(e){return e.split(".")[1]}a(ote,"extractServerName");async function ate(e,t,r=6e4,n=lb()){if(!Am.isObject(t))throw new Error("data param must be an object");let s=k0.encode(t),{connection:i}=await Ri(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return ob(c.data)}a(ate,"request");function _b(e){return new Promise(async(t,r)=>{let n=Mee(ib,["--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(_b,"reloadNATS");async function cte(){let{pid_file_path:e}=Ql(Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await _b(e)}a(cte,"reloadNATSHub");async function lte(){let{pid_file_path:e}=Ql(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await _b(e)}a(lte,"reloadNATSLeaf");function ute(e,t,r){let n;switch(e.code){case v0.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case v0.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(ute,"requestErrorHandler");async function dte(e,t){let r=t+Cr.SERVER_SUFFIX.LEAF,{connection:n}=await Ri(),{jsm:s}=await Tte(r),{schema:i,table:o}=e,c=bm.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await j0(async()=>{if(e.subscribe===!0)await W0(s,c,n.info.server_name,l);else try{await ite(s,c,n.info.server_name)}catch(d){Ks.trace(d)}})}a(dte,"updateRemoteConsumer");async function _te(e,t,r,n){let s=bm.createNatsTableStreamName(e,t),i=r+Cr.SERVER_SUFFIX.LEAF,o={type:Qe.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!x0&&Hee()<Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=rb();await c(o)}await vee(o),n==="stop"&&await Am.async_set_timeout(1e3)}a(_te,"updateConsumerIterator");function j0(e){return Uee.writeTransaction(Qe.SYSTEM_SCHEMA_NAME,Qe.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(j0,"exclusiveLock");async function Q0(e,t){let r=bm.createNatsTableStreamName(e,t),n=await ym(),s=mte(e,t,n);await db(r,[s])}a(Q0,"createLocalTableStream");async function fte(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await Q0(n,s)}}a(fte,"createTableStreams");async function z0(e,t,r=void 0){if(Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=bm.createNatsTableStreamName(e,t),{domain:s}=Ql(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await L_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")Ks.warn(n);else throw n}}a(z0,"purgeTableStream");async function Ete(e,t){if(Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await z0(e,t[r])}a(Ete,"purgeSchemaTableStreams");async function hte(e){return(await M_()).streams.info(e)}a(hte,"getStreamInfo");function mte(e,t,r){return`${Cr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(mte,"createSubjectName");async function ym(){if(D_)return D_;if(D_=(await M_())?.nc?.info?.server_name,D_===void 0)throw new Error("Unable to get jetstream manager server name");return D_}a(ym,"getJsmServerName");async function pte(){let e=await M_(),t=await ym(),r=await Y0();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=Ste(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let d=i.split(".");d[d.length-1]=t;let u=d.join(".");Ks.trace(`Updating stream subject name from: ${i} to: ${u}`),s.subjects[0]=u,await e.streams.update(s.name,s)}}a(pte,"updateLocalStreams");function Ste(e){let{config:t}=e,r=!1,n=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Rr.get(Qe.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(Ste,"updateStreamLimits");async function Tte(e){let t,r;try{t=await un.jetstream({domain:e}),r=await un.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw Ks.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Tte,"connectToRemoteJS")});var zl=b(Nm=>{var Om=V();for(let e of["trace","debug","info","warn","error","fatal","notify"])Om.logsAtLevel(e)&&(Nm[e]=Om[e]);Nm.loggerWithTag=e=>Om.loggerWithTag(e,!0);Nm.setLogLevel=Om.setLogLevel});function fb(e){let t=e.get(Im),r=t?(0,Jl.unpack)(t):null;r||(r={remoteNameToId:{}});let n=at(),s=!1;r.nodeName=at();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let d=i[l];d===0?c=l:d>o&&(o=d)}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:v_(e)??1,nodes:[]})})}i[n]=0,e.putSync(Im,(0,Jl.pack)(r))}return r}function U_(e){return fb(e).remoteNameToId}function Z0(e,t,r){let n=fb(r),s=n.remoteNameToId,i=new Map,o=!1;for(let c in t){let l=t[c],d=s[c];if(d==null){let u=0;for(let _ in s){let E=s[_];E>u&&(u=E)}d=u+1,s[c]=d,o=!0}i.set(l,d)}return o&&r.putSync(Im,(0,Jl.pack)(n)),i}function wm(e,t){let r=fb(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(Im,(0,Jl.pack)(r))}return X0.info?.("The remote node name map",e,n,s),s}var X0,Jl,Im,Eb=De(()=>{X0=v(zl());ls();Jl=require("msgpackr"),Im=Symbol.for("remote-ids");a(fb,"getIdMappingRecord");a(U_,"exportIdMapping");a(Z0,"remoteToLocalNodeId");a(wm,"getIdOfRemoteNode")});var Zo,hb=De(()=>{Zo=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 rB={};et(rB,{Resources:()=>Cm,keyArrayToString:()=>Xl,resetResources:()=>gte,resources:()=>ea});function gte(){return ea=new Cm}function Xl(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var eB,tB,Cm,ea,B_=De(()=>{uc();hb();eB=v(V()),tB=v(fe()),Cm=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new tB.ServerError(`Conflicting paths for ${t}`);eB.default.error(c),i.Resource=new Zo(c)}super.set(t,i);for(let[c,l]of this){let d=2;for(;(d=c.indexOf("/",d))>-1;){let u=this.get(c.slice(0,d));u&&(u.hasSubPaths=!0),d+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(!l&&c.indexOf(".")>-1){let d=c.split(".");l=this.get(d[0])}if(l&&(!r||l.exportTypes?.[r]!==!1)){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),s&&(!r||s.exportTypes?.[r]!==!1)?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(!r||s.exportTypes?.[r]!==!1)&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Ct(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(gte,"resetResources");a(Xl,"keyArrayToString")});function Sb(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=sB,Rte(e.primaryStore,e.auditStore)):(c=nB,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{iB(nB[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 d=l[o];d||(d=l[o]=new Map,d.envs=l,d.tableId=o,d.store=e.primaryStore),t=Xl(t);let u=new pb(r);u.startTime=n;let _=d.get(t);return _?_.push(u):(d.set(t,_=[u]),_.tables=d,_.key=t),u.subscriptions=_,u}function iB(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),oB(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ht(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Xl(c),d=0;do{let u=o.get(l);if(u){for(let E of u)if(!(d>0&&!(E.includeDescendants&&!(E.onlyChildren&&d>1)))){if(E.startTime>=n){(0,mb.info)("omitting",c,E.startTime,n);continue}try{let f;E.supportsTransactions&&E.txnInProgress!==i.version&&(f=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,f)}catch(f){console.error(f),(0,mb.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_>-1?l=l.slice(0,_):l=null,d++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function Rte(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=sB[s];if(!l)return;let d=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{iB(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",d)&&d()})}}function oB(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function aB(e){return e.nextTransaction||(Sb({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),oB(e)),e.nextTransaction}var mb,nB,sB,pb,Tb=De(()=>{mb=v(V());Al();B_();Ki();nB=Object.create(null),sB=Object.create(null);a(Sb,"addSubscription");pb=class extends In{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;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(iB,"notifyFromTransactionData");a(Rte,"listenToCommits");a(oB,"nextTransaction");a(aB,"whenNextTransaction")});var dB={};et(dB,{commits_awaiting_replication:()=>tu,getHDBNodeTable:()=>Er,iterateRoutes:()=>x_,shouldReplicateToNode:()=>H_,subscribeToNodeUpdates:()=>ru});function Er(){return cB||(cB=Et({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:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function ru(e){Er().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==at()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r)),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function H_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&Er().primaryStore.get(at())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function Ate(){ru(e=>{ta({},(t,r)=>{let n=e.name,s=lB.get(n);if(s||lB.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=new Float64Array(i.getUserSharedBuffer(["replicated",r,n],new ArrayBuffer(8),{callback:()=>{let c=o[0],l=o.lastTime;for(let{txnTime:d,onConfirm:u}of tu.get(r)||[])d>l&&d<=c&&u();o.lastTime=c}}));o.lastTime=0,s.set(r,o)}})})}function*x_(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=Zl.default.get(eu.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!Zl.default.get(eu.CONFIG_PARAMS.REPLICATION_PORT)&&Zl.default.get(eu.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||Zl.default.get(eu.CONFIG_PARAMS.REPLICATION_PORT)||Zl.default.get(eu.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){uB.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{url:r,subscription:t.subscriptions,routes:t.routes}}}var uB,Zl,eu,cB,lB,tu,nu=De(()=>{Le();ls();im();uB=require("worker_threads"),Zl=v(te()),eu=v(M());server.nodes=[];a(Er,"getHDBNodeTable");a(ru,"subscribeToNodeUpdates");a(H_,"shouldReplicateToNode");lB=new Map;Tv((e,t,r)=>{tu||(tu=new Map,Ate());let n=tu.get(e);return n||tu.set(e,n=[]),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:()=>{++i===r&&s()}})})});a(Ate,"startSubscriptionToReplications");a(x_,"iterateRoutes")});var mB={};et(mB,{connectedToNode:()=>pc,disconnectedFromNode:()=>ou,ensureNode:()=>ro,requestClusterStatus:()=>hB,startOnMainThread:()=>Rb});async function Rb(e){let t=0,r=mt();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){Dm.set(i,v_(l.auditStore));break}}}Ai.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes.search([]))i.push(o);for(let o of x_(e))try{let c=!o.subscriptions;if(c){let d=at();Er().primaryStore.get(d)===void 0&&await ro(d,{name:d,url:e.url??ra(),replicates:!0})}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(d=>d.url===o.url))continue;s(o)}catch(c){console.error(c)}ru(s)});let n;function s(i,o=i?.name){let c=at()&&o===at()||ra()&&i?.url===ra();if(c){let _=!!i?.replicates;if(n!==void 0&&n!==_)for(let E of Er().search([]))E.replicates&&E.name!==o&&s(E,E.name);n=_}if(_t.trace("Setting up node replication for",i),!i){for(let[_,E]of to){let f;for(let[h,{worker:T,nodes:S}]of E){let R=S[0];if(R&&R.name==o){f=!0;for(let[p,{worker:y}]of E)E.delete(p),_t.warn("Node was deleted, unsubscribing from node",o,p,_),y?.postMessage({type:"unsubscribe-from-node",node:o,database:p,url:_});break}}if(f){to.get(_).iterator.remove(),to.delete(_);return}}return}if(c)return;if(!i.url){_t.info(`Node ${i.name} is missing url`);return}let l=to.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(_t.info(`Added node ${i.name} at ${i.url} for process ${at()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[_,E]of su)if(i.url===E.url){su.delete(_);break}su.set(i.name,i)}let d=mt();if(l||(l=new Map,to.set(i.url,l)),l.iterator=ta(e,(_,E,f)=>{f?u(E,!0):u(E,!1)}),i.subscriptions)for(let _ of i.subscriptions){let E=_.database||_.schema;d[E]||(_t.warn(`Database ${E} not found for node ${i.name}, making a subscription anyway`),u(E,!1))}function u(_,E){_t.trace("Setting up replication for database",_,"on node",i.name);let f=l.get(_),h,T=[{replicateByDefault:E,...i}];Dm.has(_)&&(T.push({replicateByDefault:E,name:at(),start_time:Dm.get(_),end_time:Date.now(),replicates:!0}),Dm.delete(_));let S=H_(i,_),R=Ai.workers.filter(p=>p.name==="http");if(f?(h=f.worker,f.nodes=T):S&&(t=t%R.length,h=R[t++],l.set(_,{worker:h,nodes:T,url:i.url}),h?.on("exit",()=>{l.get(_)?.worker===h&&(l.delete(_),u(_,E))})),S)setTimeout(()=>{let p={type:"subscribe-to-node",database:_,nodes:T};h?h.postMessage(p):iu(p)},bte);else{_t.info("Node no longer should be used, unsubscribing from node",i.replicates,!!d[_],Er().primaryStore.get(at())?.replicates),Er().primaryStore.get(at())?.replicates||(n=!1);let p={type:"unsubscribe-from-node",database:_,url:i.url,name:i.name};h?h.postMessage(p):Lm(p)}}a(u,"onDatabase")}a(s,"onNodeUpdate"),ou=a(function(i){try{_t.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(su.keys()),c=o.sort(),l=c.indexOf(i.name||bi(i.url));if(l===-1){_t.warn("Disconnected node not found in node map",i.name,o);return}let d=to.get(i.url),u=d?.get(i.database);if(!u){_t.warn("Disconnected node not found in replication map",i.database,d);return}if(u.connected=!1,i.finished)return;let _=u.nodes[0];if(!(_.replicates===!0||_.replicates?.sends||_.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let f=c[E],h=su.get(f);d=to.get(h.url);let T=d?.get(i.database);if(!T){E=(E+1)%c.length;continue}let{worker:S,nodes:R}=T,p=!1;for(let y of u.nodes){if(R.some(O=>O.name===y.name)){_t.info(`Disconnected node is already failing over to ${f} for ${i.database}`);continue}R.push(y),p=!0}if(!p){_t.info(`Disconnected node ${i.name} has no nodes to fail over to ${f}`);return}u.redirectingTo=T,_t.info(`Failing over ${i.database} from ${i.name} to ${f}`),S?S.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):iu({database:i.database,nodes:R});return}_t.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){_t.error("Error failing over node",o)}},"disconnectedFromNode"),pc=a(function(i){let o=to.get(i.url),c=o?.get(i.database);if(!c){_t.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.catchingUpFrom=i.lastSendTime,c.redirectingTo){let{worker:l,nodes:d}=c.redirectingTo,u=d.find(_=>_.name===i.name);c.redirectingTo=null,u&&(d.splice(d.indexOf(u),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:d}):iu({database:i.database,nodes:d}))}},"connectedToNode"),(0,Ai.onMessageByType)("disconnected-from-node",ou),(0,Ai.onMessageByType)("connected-to-node",pc),(0,Ai.onMessageByType)("request-cluster-status",hB)}function hB(e,t){let r=[];for(let[n,s]of su)try{let i=to.get(s.url);_t.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:d,connected:u,nodes:_,latency:E,catchingUpFrom:f}]of i)o.push({database:l,connected:u,latency:E,catching_up_from:f?new Date(f).toISOString():"up-to-date",thread_id:d?.threadId,nodes:_.map(h=>h.name)});let c=(0,gb.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){_t.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function ro(e,t){let r=Er();e=e??bi(t.url),t.name=e;try{if(t.ca){let s=new EB.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){_t.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(_t.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!_B.default.get(fB.CONFIG_PARAMS.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,gb.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let d of o)if((c.database??c.schema)===(d.database??d.schema)&&c.table===d.table){d.publish=c.publish,d.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}_t.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Ai,Pm,_t,gb,_B,fB,EB,bte,to,ou,pc,su,Dm,k_=De(()=>{Le();Ai=v(it());ls();Pm=require("worker_threads");nu();_t=v(V()),gb=require("lodash"),_B=v(te()),fB=v(M()),EB=require("crypto"),bte=200,to=new Map,su=new Map,Dm=new Map;a(Rb,"startOnMainThread");a(hB,"requestClusterStatus");Pm.parentPort&&(ou=a(e=>{Pm.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),pc=a(e=>{Pm.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Ai.onMessageByType)("subscribe-to-node",e=>{iu(e)}),(0,Ai.onMessageByType)("unsubscribe-from-node",e=>{Lm(e)}));a(ro,"ensureNode")});var js=b(GB=>{"use strict";var Pr=require("path"),us=require("fs-extra"),au=require("node-forge"),AB=require("net"),{generateKeyPair:bb,X509Certificate:io,createPrivateKey:bB}=require("crypto"),yte=require("util");bb=yte.promisify(bb);var Dt=au.pki,so=require("joi"),{v4:Ote}=require("uuid"),{validateBySchema:yB}=ut(),Rt=V(),ds=te(),Ws=M(),{CONFIG_PARAMS:Tc}=Ws,yi=wR(),{ClientError:F_}=fe(),gc=require("node:tls"),{relative:OB,join:NB}=require("node:path"),{CERT_PREFERENCE_APP:QNe,CERTIFICATE_VALUES:pB}=yi,Nte=qa(),yb=wt(),SB=parseInt(process.version.slice(1))<20,{table:Ite,getDatabases:wte,databases:Ab}=(Le(),oe(lt));Object.assign(GB,{generateKeys:MB,updateConfigCert:vB,createCsr:Bte,signCertificate:Hte,setCertTable:cu,loadCertificates:PB,reviewSelfSignedCert:Db,createTLSSelector:xB,listCertificates:kB,addCertificate:$te,removeCertificate:Yte,createNatsCerts:Fte,generateCertsKeys:kte,getReplicationCert:q_,getReplicationCertAuth:vte,renewSelfSigned:Gte,hostnamesFromCert:FB});var{urlToNodeName:IB,getThisNodeUrl:Cte,getThisNodeName:Um,clearThisNodeName:Dte}=(ls(),oe(sa)),{readFileSync:Pte,watchFile:Lte,statSync:wB}=require("node:fs"),zNe=te(),{getTicketKeys:Mte,onMessageFromWorkers:Ute}=it(),no=V(),{isMainThread:CB}=require("worker_threads"),{TLSSocket:DB,createSecureContext:JNe}=require("node:tls"),Ib=3650,G_=["127.0.0.1","localhost","::1"],wb=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Ute(async e=>{e.type===Ws.ITC_EVENT_TYPES.RESTART&&(ds.initSync(!0),await Db())});var Dr;function na(){return Dr||(Dr=wte().system.hdb_certificate,Dr||(Dr=Ite({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__"}]}))),Dr}a(na,"getCertTable");async function q_(){let e=xB("operations-api"),t={secureContexts:null,setSecureContext:s=>{}};await e.initialize(t);let r=t.secureContexts.get(Um());if(!r)return;let n=new io(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(q_,"getReplicationCert");async function vte(){na();let e=(await q_()).options.cert,r=new io(e).issuer.match(/CN=(.*)/)?.[1];return Dr.get(r)}a(vte,"getReplicationCertAuth");var TB,Rc=new Map;function PB(){if(TB)return;TB=!0;let e=[{configKey:Tc.TLS},{configKey:Tc.OPERATIONSAPI_TLS}];na();let t=Pr.dirname(yb.getConfigFilePath()),r;for(let{configKey:n}of e){let s=yb.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&OB(NB(t,"keys"),o);c&&gB(o,l=>{Rc.set(c,l)},"private key");for(let l of[!1,!0]){let d=i[l?"certificateAuthority":"certificate"];if(d&&CB){let u;gB(d,_=>{if(pB.cert===_)return;let E=i.hostname??i.hostnames??i.host??i.hosts;E&&!Array.isArray(E)&&(E=[E]);let f=BB(d),h=new io(f),T;try{T=Pb(h)}catch(y){Rt.error("error extracting common name from certificate",y);return}if(T==null){Rt.error("error extracting common name from certificate");return}if(h.checkIssued(new io(pB.cert)))return;let S=Dr.primaryStore.get(T),R=wB(d).mtimeMs,p=!S||S.is_self_signed?1:S.file_timestamp??S.__updatedtime__;if(S&&R<=p){R<p&&Rt.info(`Certificate ${T} at ${d} is older (${new Date(R)}) than the certificate in the database (${p>1?new Date(p):"only self signed certificate available"})`);return}r=Dr.put({name:T,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:f,private_key_name:c,is_authority:l,hostnames:E,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(PB,"loadCertificates");function gB(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&CB&&Rt.warn(`Reloading ${r}:`,e),n=c,t(BB(e)))}catch(c){Rt.error(`Error loading ${r}:`,e,c)}},"loadFile");us.existsSync(e)?s(wB(e)):Rt.error(`${r} file not found:`,e),Lte(e,{persistent:!1},s)}a(gB,"loadAndWatch");function Ob(){let e=Cte();if(e==null){let t=G_[0];return Rt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return IB(e)}a(Ob,"getHost");function Mm(){let e=Um();if(e==null){let t=G_[0];return Rt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Mm,"getCommonName");async function Bte(){let e=await q_(),t=Dt.certificateFromPem(e.options.cert),r=Dt.privateKeyFromPem(e.options.key);Rt.info("Creating CSR with cert named:",e.name);let n=Dt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Mm()},...wb];Rt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:LB()}];return Rt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),au.pki.certificationRequestToPem(n)}a(Bte,"createCsr");function LB(){let e=G_.includes(Mm())?G_:[...G_,Mm()];return e.includes(Ob())||e.push(Ob()),[{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=>AB.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(LB,"certExtensions");async function Hte(e){let t={},r=Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;na();for await(let u of Dr.search([]))if(u.is_authority&&!u.details.issuer.includes("HarperDB-Certificate-Authority")){if(Rc.has(u.private_key_name)){n=Rc.get(u.private_key_name),s=u;break}else if(u.private_key_name&&await us.exists(Pr.join(r,u.private_key_name))){n=us.readFile(Pr.join(r,u.private_key_name)),s=u;break}}if(!n){let u=await Nb();s=u.ca,n=u.private_key}n=Dt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=Dt.certificateFromPem(s.certificate);Rt.info("Signing CSR with cert named",s.name);let o=Dt.certificationRequestFromPem(e.csr);try{o.verify()}catch(u){return Rt.error(u),new Error("Error verifying CSR: "+u.message)}let c=au.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()+Ib),Rt.info("sign cert setting validity:",c.validity),Rt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),Rt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let d=o.getAttribute({name:"extensionRequest"}).extensions;Rt.info("sign cert adding extensions from CSR:",d),c.setExtensions(d),c.publicKey=o.publicKey,c.sign(n,au.md.sha256.create()),t.certificate=Dt.certificateToPem(c)}else Rt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Hte,"signCertificate");async function xte(e,t){await cu({name:Um(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await cu({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:Dt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(xte,"createCertificateTable");async function cu(e){let t=new io(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},na(),await Dr.patch(e)}a(cu,"setCertTable");async function MB(){let e=await bb("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:Dt.publicKeyFromPem(e.publicKey),private_key:Dt.privateKeyFromPem(e.privateKey)}}a(MB,"generateKeys");async function Cb(e,t,r){let n=Dt.createCertificate();if(!t){let o=await q_();t=Dt.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()+Ib);let i=[{name:"commonName",value:Mm()},...wb];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(LB()),n.sign(e,au.md.sha256.create()),Dt.certificateToPem(n)}a(Cb,"generateCertificates");async function Nb(){let e=await kB(),t;for(let r of e){if(!r.is_authority)continue;let n=Rc.get(r.private_key_name);if(r.private_key_name&&n&&new io(r.certificate).checkPrivateKey(bB(n))){Rt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;Rt.trace("No CA found with matching private key")}a(Nb,"getCertAuthority");async function UB(e,t){let r=Dt.createCertificate();r.publicKey=t,r.serialNumber=Math.random().toString().slice(2,10),r.validity.notBefore=new Date;let n=new Date;r.validity.notAfter=n,r.validity.notAfter.setDate(n.getDate()+Ib);let s=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ds.get(Tc.REPLICATION_HOSTNAME)??IB(ds.get(Tc.REPLICATION_URL))??Ote().split("-")[0]}`},...wb];r.setSubject(s),r.setIssuer(s),r.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),r.sign(e,au.md.sha256.create());let i=Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME),o=Pr.join(i,yi.PRIVATEKEY_PEM_NAME);return await us.writeFile(o,Dt.privateKeyToPem(e)),r}a(UB,"generateCertAuthority");async function kte(){let{private_key:e,public_key:t}=await MB(),r=await UB(e,t),n=await Cb(e,t,r);await xte(n,r),vB()}a(kte,"generateCertsKeys");async function Fte(){let e=await Cb(Dt.privateKeyFromPem(yi.CERTIFICATE_VALUES.key),void 0,Dt.certificateFromPem(yi.CERTIFICATE_VALUES.cert)),t=Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME),r=Pr.join(t,yi.NATS_CERTIFICATE_PEM_NAME);await us.exists(r)||await us.writeFile(r,e);let n=Pr.join(t,yi.NATS_CA_PEM_NAME);await us.exists(n)||await us.writeFile(n,yi.CERTIFICATE_VALUES.cert)}a(Fte,"createNatsCerts");async function Gte(){na();for await(let e of Dr.search([{attribute:"is_self_signed",value:!0}]))await Dr.delete(e.name);await Db()}a(Gte,"renewSelfSigned");async function Db(){Dte(),await PB(),na();let e,t=ds.get(Tc.TLS_PRIVATEKEY),r=a(async()=>e||(e=Dt.privateKeyFromPem(await us.readFile(t)),e),"getPrivateKey"),n=await Nb();if(!n){Rt.info("No self signed Cert Authority found, generating new self signed CA"),await r();let i=await UB(e,Dt.setRsaPublicKey(e.n,e.e));await cu({name:i.subject.getField("CN").value,uses:["https","wss"],certificate:Dt.certificateToPem(i),private_key_name:OB(NB(ds.get(Tc.ROOTPATH),"keys"),t),is_authority:!0,is_self_signed:!0})}if(!await q_()){let i=Um();Rt.info(`A suitable replication certificate was not found, creating new self singed cert named: ${i}`),n=n??await Nb();let o=Dt.certificateFromPem(n.ca.certificate),c=o.publicKey,l=await Cb(Dt.privateKeyFromPem(n.private_key),c,o);await cu({name:i,uses:["https","operations","wss"],certificate:l,is_authority:!1,private_key_name:n.ca.private_key_name,is_self_signed:!0})}}a(Db,"reviewSelfSignedCert");function vB(){let e=Nte(Object.keys(Ws.CONFIG_PARAM_MAP),!0),t=Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME),r=Pr.join(t,yi.PRIVATEKEY_PEM_NAME),n=Pr.join(t,yi.NATS_CERTIFICATE_PEM_NAME),s=Pr.join(t,yi.NATS_CA_PEM_NAME),i=Ws.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),yb.updateConfigValue(void 0,void 0,o,!1,!0)}a(vB,"updateConfigCert");function BB(e){return e.startsWith("-----BEGIN")?e:Pte(e,"utf8")}a(BB,"readPEM");var RB=gc.createSecureContext;gc.createSecureContext=function(e){if(!e.cert||!e.key)return RB(e);let t={...e};delete t.key,delete t.cert;let r=RB(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var HB=gc.Server;gc.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),HB.call(this,e,t)};gc.Server.prototype=HB.prototype;var qte=DB.prototype._init;DB.prototype._init=function(e,t){qte.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 Sc=new Map;function xB(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 d(){try{r.clear(),Sc.clear();let u=0;for await(let _ of Ab.system.hdb_certificate.search([])){if(e!=="operations-api"&&_.uses?.includes?.("operations"))continue;let E=_.certificate,f=new io(E);_.is_authority&&(f.asString=E,Sc.set(f.subject,E))}for await(let _ of Ab.system.hdb_certificate.search([]))try{if(_.is_authority)continue;if(!(e==="operations-api")&&_.uses?.includes?.("operations")){no.trace("Skipping cert",_.name,"for",e,o.ports||"client","because it is for operations");continue}let f=_.is_self_signed?1:2,h=Rc.get(_.private_key_name);!h&&_.private_key_name&&(h=await us.readFile(Pr.join(ds.get(Tc.ROOTPATH),Ws.LICENSE_KEY_DIR_NAME,_.private_key_name)));let T=_.certificate,S=new io(T);if(Sc.has(S.issuer)&&(T+=`
|
|
15
|
+
`+Sc.get(S.issuer)),!h||!T)throw new Error("Missing private key or certificate for secure server");let R={ciphers:_.ciphers,ticketKeys:Mte(),availableCAs:Sc,ca:t&&Array.from(Sc.values()),cert:T,key:h,key_file:_.private_key_name,is_self_signed:_.is_self_signed};o&&(R.sessionIdContext=o.sessionIdContext);let p=gc.createSecureContext(R);p.name=_.name,p.options=R,p.quality=f,p.certificateAuthorities=Array.from(Sc),p.certStart=T.toString().slice(0,100);let y=_.hostnames??FB(S);Array.isArray(y)||(y=[y]);let O;for(let B of y)if(B){B[0]==="*"&&(s=!0,B=B.slice(1)),B===Ob()&&(f+=2),AB.isIP(B)&&(O=!0);let x=r.get(B)?.quality??0;f>x&&r.set(B,p)}else no.error("No hostname found for certificate at",gc.certificate);no.trace("Adding TLS",p.name,"for",o.ports||"client","cert named",_.name,"hostnames",y,"quality",f,"best quality",u),f>u&&(i.defaultContext=n=p,u=f,o&&(o.defaultContext=p))}catch(E){no.error("Error applying TLS for",_.name,E)}o?.secureContextsListeners.forEach(_=>_()),c(n)}catch(u){l(u)}}a(d,"updateTLS"),Ab.system.hdb_certificate.subscribe({listener:d,omitCurrent:!0}),d()})),i;function i(o,c){no.info("TLS requested for",o||"(no SNI)",this.isReplicationConnection);let l=o;for(;;){let u=r.get(l);if(u)return no.debug("Found certificate for",o,u.certStart),u.replicationContext&&(this.isReplicationConnection||SB)&&(u=u.replicationContext),c(null,u);if(s&&l){let _=l.indexOf(".",1);_<0?l="":l=l.slice(_)}else break}o?no.debug("No certificate found to match",o,"using the default certificate"):no.debug("No SNI, using the default certificate",n.name);let d=n;d?d.replicationContext&&(this.isReplicationConnection||SB)&&(d=d.replicationContext):no.info("No default certificate found"),c(null,d)}a(i,"SNICallback")}a(xB,"createTLSSelector");async function kB(){na();let e=[];for await(let t of Dr.search([]))e.push(t);return e}a(kB,"listCertificates");async function $te(e){let t=yB(e,so.object({name:so.string().required(),certificate:so.string().required(),is_authority:so.boolean().required(),private_key:so.string(),hosts:so.array(),uses:so.array()}));if(t)throw new F_(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new io(n),c=!1,l=!1,d;for(let[f,h]of Rc)!s&&!c&&o.checkPrivateKey(bB(h))&&(c=!0,d=f),s&&s===h&&(l=!0,d=f);if(!i&&!s&&!c)throw new F_("A suitable private key was not found for this certificate");let u;if(!r){try{u=Pb(o)}catch(f){Rt.error(f)}if(u==null)throw new F_("Error extracting certificate common name, please provide a name parameter")}let _=Vte(r??u);s&&!c&&!l&&(await us.writeFile(Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME,_+".pem"),s),Rc.set(_,s));let E={name:r??u,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&d||i&&s)&&(E.private_key_name=d??_+".pem"),await cu(E),"Successfully added certificate: "+_}a($te,"addCertificate");function Vte(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(Vte,"sanitizeName");async function Yte(e){let t=yB(e,so.object({name:so.string().required()}));if(t)throw new F_(t.message);let{name:r}=e;na();let n=await Dr.get(r);if(!n)throw new F_(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Dr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(Rt.info("Removing private key named",s),await us.remove(Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME,s)))}return await Dr.delete(r),"Successfully removed "+r}a(Yte,"removeCertificate");function Pb(e){return e.subject.match(/CN=(.*)/)?.[1]}a(Pb,"extractCommonName");function FB(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):[Pb(e)]}a(FB,"hostnamesFromCert")});async function Hb(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=at(),i;if(e.includes("wss://")){if(!Mb){let l=(0,rH.createTLSSelector)("operations-api"),d={secureContexts:null};await l.initialize(d),Mb=d.secureContexts}if(i=Mb.get(s),i&&Ee.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,sH.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,ALPNProtocols:["http/1.1","harperdb-replication"],rejectUnauthorized:n!==!1,secureContext:void 0};return n!==!1&&i&&(c.secureContext=nH.createSecureContext({...i.options,ca:Array.from(oa)})),new eH.WebSocket(e,"harperdb-replication-v1",c)}function Fm(e,t,r){let n=t.port||t.securePort,s=Bb.pid%1e3+"-"+tH.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),d=t.database,u=t.databaseSubscriptions||Ac,_,E,f=!1,h=t.subscription;h?.then&&h.then(se=>h=se);let T=t.tables||d&&mt()[d];if(!r){Ee.error?.("No authorization provided"),rs(1008,"Unauthorized");return}let S=new Map,R=[],p=r.name;p&&t.connection&&(t.connection.nodeName=p);let y,O,B,x,W,q,z=1e3,_e,X=0,ue=0;if(t.url){let se=a(()=>{W?e.terminate():(W=performance.now(),e.ping())},"send_ping");B=setInterval(se,XB).unref(),se()}else j();function j(){clearTimeout(x),x=setTimeout(()=>{Ee.warn?.(`Timeout waiting for ping from ${p}, terminating connection and reconnecting`),e.terminate()},XB*2).unref()}a(j,"resetPingTimer"),d&&$i(d);let ie,ye,Ie=[],Me=[],tn,gd=[],ka=[],yn=[],YE=150,Fa=0,zT=0,Rd,bt,es,ts,KE;e.on("message",se=>{X=performance.now();try{let Se=se.dataView=new uu(se.buffer,se.byteOffset,se.byteLength);if(se[0]>127){let k=(0,ct.decode)(se),[m,g,D]=k;switch(m){case $B:{if(g){if(p){if(p!==g){Ee.error?.(s,`Node name mismatch, expecting to connect to ${p}, but peer reported name as ${g}, disconnecting`),e.send((0,ct.encode)([lu])),rs(1008,"Node name mismatch");return}}else if(p=g,t.connection?.tentativeNode){let C=t.connection.tentativeNode;C.name=p,t.connection.tentativeNode=null,ro(p,C)}if(t.connection&&(t.connection.nodeName=p),Ee.debug?.(s,"received node name:",p,"db:",d),!d)try{$i(d=k[2]),d==="system"&&(ie=ta(t,(C,L)=>{Mo(L)&&Uo(L)}),e.on("close",()=>{ie?.remove()}))}catch(C){Ee.warn?.(s,"Error setting database",C),e.send((0,ct.encode)([lu])),rs(1008,C.message);return}Ge()}break}case zB:{Ee.debug?.(s,"Received table definitions for",g.map(C=>C.table));for(let C of g){let L=k[2];C.database=L;let F;Mo(L)&&(L==="system"?We[L]?.[C.table]||(F=Ub(C,We[L]?.[C.table])):F=Ub(C,We[L]?.[C.table]),_||(_=F?.auditStore),T||(T=mt()?.[L]))}break}case lu:rs();break;case WB:try{let C=r?.replicates||r?.subscribers||r?.name;server.operation(g,{user:r},!C).then(L=>{Array.isArray(L)&&(L={results:L}),L.requestId=g.requestId,e.send((0,ct.encode)([Bm,L]))},L=>{e.send((0,ct.encode)([Bm,{requestId:g.requestId,error:L instanceof Error?L.toString():L}]))})}catch(C){e.send((0,ct.encode)([Bm,{requestId:g.requestId,error:C instanceof Error?C.toString():C}]))}break;case Bm:let{resolve:A,reject:I}=S.get(g.requestId);g.error?I(new Error(g.error)):A(g),S.delete(g.requestId);break;case Lb:let w=k[3];T||(d?Ee.error?.(s,"No tables found for",d):Ee.error?.(s,"Database name never received"));let N=T[w];N=Ub({table:w,database:d,attributes:g.attributes,schemaDefined:g.schemaDefined},N),Ie[D]={name:w,decoder:new ct.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:g.typedStructs,structures:g.structures}),getEntry(C){return N.primaryStore.getEntry(C)},rootStore:N.primaryStore.rootStore};break;case VB:KE=_?Z0(p,g,_):new Map,tn=k[2],Ee.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${tn}`);break;case YB:let H=D;yn[H]=g;break;case QB:let U=["replicated",d,p];E||(E=new Float64Array(_.getUserSharedBuffer(U,new ArrayBuffer(8)))),E[0]=g,Ee.trace?.(s,"received and broadcasting committed update",g),E.buffer.notify();break;case jB:y=g,h.send({type:"end_txn",localTime:y,remoteNodeIds:R});break;case KB:{let C=g,L;try{let F=k[3],G=Me[D]||(Me[D]=T[k[4]]);if(!G)return Ee.warn?.("Unknown table id trying to handle record request",D);let ce=G.primaryStore.getBinaryFast(Symbol.for("structures")),re=ce.length;if(re!==zT){zT=re;let de=(0,ct.decode)(ce);e.send((0,ct.encode)([Lb,{typedStructs:de.typed,structures:de.named},D,G.tableName]))}let Te=G.primaryStore.getBinaryFast(F);if(Te){let de=G.primaryStore.decoder.decode(Te,{valueAsBuffer:!0});L=(0,ct.encode)([vm,C,{value:de.value,expiresAt:de.expiresAt,version:de.version,residencyId:de.residencyId,nodeId:de.nodeId,user:de.user}])}else L=(0,ct.encode)([vm,C])}catch(F){L=(0,ct.encode)([vm,C,{error:F.message}])}e.send(L);break}case vm:{let{resolve:C,reject:L,tableId:F,key:G}=S.get(k[1]),ce=k[2];if(ce?.error)L(new Error(ce.error));else if(ce){let re=Ie[F].decoder.decode(ce.value);ce.value=re,ce.key=G,C(ce)}else C();S.delete(k[1]);break}case qB:{ts=g;let C,L,F=!1;if(h){if(d!==h.databaseName&&!h.then){Ee.error?.("Subscription request for wrong database",d,h.databaseName);return}}else h=u.get(d);if(Ee.debug?.(s,"received subscription request for",d,"at",ts),!h){let ne;h=new Promise(we=>{Ee.debug?.("Waiting for subscription to database "+d),ne=we}),h.ready=ne,Ac.set(d,h)}if(r.name)L=Er().subscribe(r.name),L.then(async ne=>{C=ne;for await(let we of C){let nt=we.value;if(!(nt?.replicates===!0||nt?.replicates?.receives||nt?.subscriptions?.some(Xe=>(Xe.database||Xe.schema)===d&&Xe.publish!==!1))){F=!0,e.send((0,ct.encode)([lu])),rs(1008,`Unauthorized database subscription to ${d}`);return}}},ne=>{Ee.error?.(s,"Error subscribing to HDB nodes",ne)});else if(!(r?.permissions?.super_user||r.replicates)){e.send((0,ct.encode)([lu])),rs(1008,`Unauthorized database subscription to ${d}`);return}if(es&&(Ee.debug?.(s,"stopping previous subscription",d),es.emit("close")),ts.length===0)return;let G,ce=ts[0],re=a(ne=>{if(ne&&(ce.replicateByDefault?!ce.tables.includes(ne.tableName):ce.tables.includes(ne.tableName)))return G=ne,{table:ne}},"tableToTableEntry"),Te={txnTime:0},de,Oe,Z=1/0,ee,ge=a((ne,we)=>{if(Z=we,ne.type==="end_txn"){Te.txnTime&&(o[i]!==66&&Ee.error?.("Invalid encoding of message"),vo(9),vo(km),Bo(ee=we),Ke()),i=c,Te.txnTime=0;return}let nt=ne.nodeId,Xe=ne.tableId,$e=Oe[Xe];if(!$e&&($e=Oe[Xe]=re(h.tableById[Xe]),!$e))return Ee.debug?.("Not subscribed to table",Xe);let Kt=$e.table,Or=Kt.primaryStore,ii=Or.encoder;if(ne.extendedType&ph||!ii.typedStructs){let Ho=ne.getValue(Or,!0);JSON.stringify(Ho)}let qr=de[nt];if(!(qr&&qr.startTime<we&&(!qr.endTime||qr.endTime>we)))return $_&&Ee.trace?.(s,"skipping replication update",ne.recordId,"to:",p,"from:",nt,"subscribed:",de),vw();$_&&Ee.trace?.(s,"sending replication update",ne.recordId,"to:",p,"from:",nt,"subscribed:",de);let JT=ne.version;Te.txnTime!==JT&&(Te.txnTime&&($_&&Ee.trace?.(s,"new txn time, sending queued txn",Te.txnTime),o[i]!==66&&Ee.error?.("Invalid encoding of message"),Ke()),Te.txnTime=JT,i=c,Bo(JT));let Ga=ne.residencyId,XT=WE(Ga,Kt),jE;if(XT&&!XT.includes(p)){let Ho=WE(ne.previousResidencyId,Kt);if(Ho&&!Ho.includes(p)&&(ne.type==="put"||ne.type==="patch")||Kt.getResidencyById)return vw();let yd=ne.recordId;Ee.trace?.(s,"sending invalidation",yd,p,"from",nt);let tg=0;Ga&&(tg|=Ka),ne.previousResidencyId&&(tg|=Wa);let rg,QE=null;for(let Bw in Kt.indices){if(!QE){if(rg=ne.getValue(Or,!0),!rg)break;QE={}}QE[Bw]=rg[Bw]}jE=yl(ne.version,Xe,yd,null,nt,ne.user,ne.type==="put"||ne.type==="patch"?"invalidate":ne.type,ii.encode(QE),tg,Ga,ne.previousResidencyId,ne.expiresAt)}function vw(){Ee.trace?.(s,"skipping audit record",ne.recordId),q||(q=setTimeout(()=>{q=null,(ee||0)+JB/2<Z&&($_&&Ee.trace?.(s,"sending skipped sequence update",Z),e.send((0,ct.encode)([jB,Z])))},JB).unref())}a(vw,"skipAuditRecord");let ZT=ii.typedStructs,eg=ii.structures;if((ZT?.length!=$e.typed_length||eg?.length!=$e.structure_length)&&($e.typed_length=ZT?.length,$e.structure_length=eg.length,Ee.debug?.(s,"send table struct",$e.typed_length,$e.structure_length),$e.sentName||($e.sentName=!0),e.send((0,ct.encode)([Lb,{typedStructs:ZT,structures:eg,attributes:Kt.attributes,schemaDefined:Kt.schemaDefined},Xe,$e.table.tableName]))),Ga&&!ka[Ga]&&(e.send((0,ct.encode)([YB,XT,Ga])),ka[Ga]=!0),jE)vo(jE.length),bd(jE);else{let Ho=ne.encoded,yd=Ho[0]===66?8:0;vo(Ho.length-yd),bd(Ho,yd)}},"sendAuditRecord"),Ke=a(()=>{c-i>8?(e.send(o.subarray(i,c)),Ee.debug?.(s,"Sent message, size:",c-i)):Ee.debug?.(s,"skipping empty transaction")},"sendQueuedData");es=new vb.EventEmitter,es.once("close",()=>{F=!0,C?.end()});for(let{startTime:ne}of ts)ne<Z&&(Z=ne);(L||Promise.resolve()).then(async()=>{h=await h,_=h.auditStore,Oe=h.tableById.map(re),de=[];for(let{name:we,startTime:nt,endTime:Xe}of ts){let $e=wm(we,_);Ee.debug?.("subscription to",we,"using local id",$e,"starting",nt),de[$e]={startTime:nt,endTime:Xe}}Uo(d),ie||(ie=bc(we=>{we.databaseName===d&&Uo(d)}),ye=V_(we=>{we===d&&(e.send((0,ct.encode)([lu])),rs())}),e.on("close",()=>{ie?.remove(),ye?.remove()})),e.send((0,ct.encode)([VB,U_(h.auditStore),ts.map(({name:we})=>we)]));let ne=!0;do{isFinite(Z)||(Ee.warn?.("Invalid sequence id "+Z),rs(1008,"Invalid sequence id"+Z));let we;if(ne&&!F&&(ne=!1,!(xb(_)<=Z)&&server.nodes[0]?.name===p)){Ee.info?.("Replicating all tables to",p);let $e=Z,Kt=Gm(_);for(let Or in T){let ii=T[Or];for(let qr of ii.primaryStore.getRange({snapshot:!1})){if(F)return;qr.localTime>=Z&&(Ee.trace?.(s,"Copying record from",d,Or,qr.key,qr.localTime),$e=Math.max(qr.localTime,$e),we=!0,ge({recordId:qr.key,tableId:ii.tableId,type:"put",getValue(){return qr.value},encoded:ii.primaryStore.getBinary(qr.key),version:qr.version,residencyId:qr.residencyId,nodeId:Kt},qr.localTime))}}Z=$e}for(let{key:Xe,value:$e}of _.getRange({start:Z||1,exclusiveStart:!0,snapshot:!1})){if(F)return;ue=Xe;let Kt=Ht($e);ge(Kt,Xe),e._socket.writableNeedDrain&&await new Promise(Or=>e._socket.once("drain",Or)),es.startTime=Xe,we=!0}we&&ge({type:"end_txn"},Z);let nt=Hm.get(G);nt||Hm.set(G,nt=[]),nt.push(Xe=>{}),ue=0,await aB(_)}while(!F)}).catch(ne=>{Ee.error?.(s,"Error handling subscription to node",ne),rs(1008,"Error handling subscription to node")});break}}return}Se.position=8;let rt=!0,Re,ft;do{let k=Se.readInt();if(k===9&&Se.getUint8(Se.position)==km){Se.position++,y=ft=Se.readFloat64(),Ee.trace?.("received remote sequence update",y,d);break}let m=Se.position,g=Ht(se,m,m+k),D=Ie[g.tableId];D||Ee.error?.(`No table found with an id of ${g.tableId}`);let A;g.residencyId&&(A=yn[g.residencyId],Ee.trace?.(s,"received residency list",A,g.type,g.recordId)),Re={table:D.name,id:g.recordId,type:g.type,nodeId:KE.get(g.nodeId),residencyList:A,timestamp:g.version,value:g.getValue(D),user:g.user,beginTxn:rt,expiresAt:g.expiresAt},rt=!1,$_&&Ee.trace?.(s,"received replication message",g.type,"id",Re.id,"version",g.version,"nodeId",Re.nodeId,"value",Re.value),h.send(Re),Se.position=m+k}while(Se.position<se.byteLength);Fa++,gr(se.byteLength,"bytes-received",p+"."+d+"."+Re.table,"replication","ingest"),Fa>YE&&!Rd&&(Rd=!0,e.pause()),h.send({type:"end_txn",localTime:y,remoteNodeIds:R,onCommit(){if(Re){let k=Date.now()-Re.timestamp;gr(k,"replication-latency",p+"."+d+"."+Re.table,Re.type,"ingest")}Fa--,Rd&&(Rd=!1,e.resume()),!O&&ft&&(Ee.trace?.(s,"queuing confirmation of a commit at",ft),setTimeout(()=>{e.send((0,ct.encode)([QB,O])),Ee.trace?.(s,"sent confirmation of a commit at",O),O=null},Kte)),O=ft}})}catch(Se){Ee.error?.(s,"Error handling incoming replication message",Se)}}),e.on("ping",j),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-W,pc({name:p,database:d,url:t.url,lastSendTime:ue,latency:t.connection.latency})),W=null}),e.on("close",(se,Se)=>{clearInterval(B),clearTimeout(x),es&&es.emit("close"),bt&&bt.end();for(let[rt,{reject:Re}]of S)Re(new Error(`Connection closed ${Se?.toString()} ${se}`));Ee.debug?.(s,"closed",se,Se?.toString())});function Uw(){}a(Uw,"recordRemoteNodeSequence");function rs(se,Se){e.isFinished=!0,e.close(se,Se)}a(rs,"close");function Ge(){if(f||(f=!0,t.connection?.on("subscriptions-updated",Ge)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let se=new Map;try{for(let Re of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let ft of Re.value.nodes||[])ft.seqId>(se.get(ft.id)??0)&&se.set(ft.id,ft.seqId)}catch(Re){if(!Re.message.includes("Can not re"))throw Re}let Se=t.connection?.nodeSubscriptions?.[0];R=[];let rt=t.connection?.nodeSubscriptions.map((Re,ft)=>{let k=[],{replicateByDefault:m}=Re;if(Re.subscriptions){for(let I of Re.subscriptions)if(I.subscribe&&(I.schema||I.database)===d){let w=I.table;T?.[w]?.replicate!==!1&&k.push(w)}m=!1}else for(let I in T)(m?T[I].replicate===!1:T[I].replicate)&&k.push(I);let g=_&&wm(Re.name,_),D=h?.dbisDB?.get([Symbol.for("seq"),g])??1,A=Math.max(D?.seqId??1,(typeof Re.start_time=="string"?new Date(Re.start_time).getTime():Re.start_time)??1);if(Ee.debug?.("Starting time recorded in db",Re.name,g,d,D?.seqId,"start time:",A),Se!==Re){A>5e3&&(A-=5e3);let I=_&&wm(Se.name,_),w=h?.dbisDB?.get([Symbol.for("seq"),I])??1;for(let N of w?.nodes||[])N.name===Re.name&&(A=N.seqId,Ee.debug?.("Using sequence id from proxy node",Se.name,A))}return R.push(g),se.get(g)>A&&(A=se.get(g),Ee.debug?.("Updating start time from more recent txn recorded",Se.name,A)),{name:Re.name,replicateByDefault:m,tables:k,startTime:A,endTime:Re.end_time}});if(rt)if(Ee.debug?.(s,"sending subscription request",rt,h?.dbisDB?.path),clearTimeout(_e),rt.length>0)e.send((0,ct.encode)([qB,rt]));else{let Re=a(()=>{let ft=performance.now();_e=setTimeout(()=>{X<=ft?rs(1008,"No nodes to subscribe to"):Re()},z)},"schedule_close");Re()}}a(Ge,"sendSubscriptionRequestUpdate");function WE(se,Se){if(!se)return;let rt=gd[se];return rt||(rt=Se.getResidencyRecord(se),gd[se]=rt),rt}a(WE,"getResidence");function Mo(se){return!(ia&&ia!="*"&&!ia[se]&&!ia.includes?.(se)&&!ia.some?.(Se=>Se.name===se))}a(Mo,"checkDatabaseAccess");function $i(se){if(h=h||u.get(se),!Mo(se))throw new Error(`Access to database "${se}" is not permitted`);h||Ee.warn?.(`No database named "${se}" was declared and registered`),_=h?.auditStore,T||(T=mt()?.[se]);let Se=at();if(Se===p)throw Se?new Error("Should not connect to self",Se):new Error("Node name not defined");return Ad(Se,se),!0}a($i,"setDatabase");function Ad(se,Se){let rt=mt()?.[Se],Re=[];for(let ft in rt){let k=rt[ft];Re.push({table:ft,schemaDefined:k.schemaDefined,attributes:k.attributes.map(m=>({name:m.name,type:m.type,isPrimaryKey:m.isPrimaryKey}))})}Ee.trace?.("Sending database info for node",se,"database name",Se),e.send((0,ct.encode)([$B,se,Se,Re]))}a(Ad,"sendNodeDBName");function Uo(se){let Se=mt()?.[se],rt=[];for(let Re in Se){if(ts&&!ts.some(k=>k.replicateByDefault?!k.tables.includes(Re):k.tables.includes(Re)))continue;let ft=Se[Re];rt.push({table:Re,schemaDefined:ft.schemaDefined,attributes:ft.attributes.map(k=>({name:k.name,type:k.type,isPrimaryKey:k.isPrimaryKey}))})}e.send((0,ct.encode)([zB,rt,se]))}a(Uo,"sendDBSchema");let Tl=1,Gr=[];return{end(){bt&&bt.end(),es&&es.emit("close")},getRecord(se){let Se=Tl++;return new Promise((rt,Re)=>{let ft=[KB,Se,se.table.tableId,se.id];Gr[se.table.tableId]||(ft.push(se.table.tableName),Gr[se.table.tableId]=!0),e.send((0,ct.encode)(ft)),S.set(Se,{tableId:se.table.tableId,key:se.id,resolve(k){let{table:m,entry:g}=se;rt(k),k&&m._recordRelocate(g,k)},reject:Re})})},sendOperation(se){let Se=Tl++;return se.requestId=Se,e.send((0,ct.encode)([WB,se])),new Promise((rt,Re)=>{S.set(Se,{resolve:rt,reject:Re})})}};function vo(se){gl(5),se<128?o[c++]=se:se<16384?(l.setUint16(c,se|32768),c+=2):se<1056964608?(l.setUint32(c,se|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,se),c+=5)}function bd(se,Se=0,rt=se.length){let Re=rt-Se;gl(Re),se.copy(o,c,Se,rt),c+=Re}function Bo(se){gl(8),l.setFloat64(c,se),c+=8}function gl(se){if(se+16>o.length-c){let Se=Buffer.allocUnsafeSlow(c+se-i+65536>>10<<11);o.copy(Se,0,i,c),c=c-i,i=0,o=Se,l=new DataView(o.buffer,0,o.length)}}}function Ub(e,t){let r=e.database??"data";if(r!=="data"&&!We[r]){Ee.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?(Ee.debug?.("(Re)creating",e),Et({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var ct,eH,tH,Ee,vb,rH,nH,Bb,sH,qB,$B,VB,lu,YB,Lb,KB,vm,WB,Bm,jB,QB,zB,Hm,Ac,$_,JB,Kte,XB,Mb,ZB,xm,iH=De(()=>{Le();Ki();Eb();Tb();ls();Ol();ct=require("msgpackr"),eH=require("ws"),tH=require("worker_threads"),Ee=v(zl());k_();vb=require("events"),rH=v(js()),nH=v(require("node:tls"));nu();Bb=v(require("node:process")),sH=require("node:net");gi();qB=129,$B=140,VB=141,lu=142,YB=130,Lb=132,KB=133,vm=134,WB=136,Bm=137,jB=143,QB=144,zB=145,Hm=new Map,Ac=new Map,$_=!0,JB=300,Kte=2,XB=3e4;a(Hb,"createWebSocket");ZB=1e3,xm=class extends vb.EventEmitter{constructor(r,n,s){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=bi(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=ZB;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;nodeName;async connect(){this.session||this.resetSession();let r=[];this.socket=await Hb(this.url,{serverName:this.nodeName});let n;Ee.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${Bb.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),Ee.info?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=ZB,pc({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=Fm(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"?(Ee.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"?Ee.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`):Ee.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(ou({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();Ee.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(Fm,"replicateOverWS");a(Ub,"ensureTableIfChanged")});var sa={};et(sa,{clearThisNodeName:()=>Zte,disableReplication:()=>Qte,enabled_databases:()=>ia,forEachReplicatedDatabase:()=>ta,getThisNodeId:()=>Gm,getThisNodeName:()=>at,getThisNodeUrl:()=>ra,hostnameToUrl:()=>Vm,lastTimeInAuditStore:()=>v_,monitorNodeCAs:()=>EH,replicateOperation:()=>tre,replication_certificate_authorities:()=>oa,sendOperationToNode:()=>W_,servers:()=>fH,setReplicator:()=>mH,start:()=>jte,startOnMainThread:()=>Rb,subscribeToNode:()=>iu,unsubscribeFromNode:()=>Lm,urlToNodeName:()=>bi});function jte(e){if(e.port||(e.port=_s.default.get(yc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=_s.default.get(yc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!at())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of x_(e))t.set(bi(n.url),n);zte(e),e={subProtocol:"harperdb-replication-v1",mtls:!0,isOperationsServer:!0,...e};let r=st.ws(async(n,s,i)=>{await i,n._socket.unref(),Fm(n,e,s?.user),n.on("error",o=>{o.code!=="ECONNREFUSED"&&hr.error("Error in connection to "+this.url,o.message)})},e);e.runFirst=!0,st.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&hr.error(`Incoming client connection from ${n.ip} did not have valid certificate `,n._nodeRequest.socket.authorizationError);let i=Er().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));c?n.user=c:hr.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:hr.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(fH.push(n),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(oa);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.replicationContext=K_.createSecureContext(l)}catch(c){hr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),EH(s)}}function EH(e){let t=0;ru(r=>{if(r?.ca){if(oa.add(r.ca),oa.size!==t)t=oa.size,e?.();else if(_s.default.get(yc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1)for(let n of K_.rootCertificates)oa.add(n)}})}function Qte(e=!0){_H=e}function zte(e){_H||(mt(),ia=e.databases,ta(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Ac;for(let[s,i]of Y_){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];mH(r,s,e),Hm.get(s)?.forEach(i=>i(s))}}))}function mH(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 hH extends Ir{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Ac,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(hr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new In,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,d=new Set;do{let u;for(let E of c){let f=Jte(E,hH.subscription,e);f?.isConnected&&!d.has(f)&&(!u||f.latency<u.latency)&&(u=f)}if(!u)throw l||new uH.ServerError("No connection to any other nodes are available",502);let _={requestId:Wte++,table:t,entry:i,id:i.key};d.add(u);try{return await u.getRecord(_)}catch(E){if(u.isConnected)throw E;hr.warn("Error in load from node",$m,E),l||(l=E)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function pH(e,t,r){let n=Y_.get(e);n||Y_.set(e,n=new Map);let s=n.get(r);if(s)return s;if(t)return n.set(r,s=new xm(e,t,r)),s.connect(),s.once("finished",()=>n.delete(r)),s}function Jte(e,t,r){let n=oH.get(e)?.get(r);if(n)return n;let s=Er().primaryStore.get(e);return s?.url&&(n=pH(s.url,t,r),oH.set(e,Y_.get(s.url))),n}async function W_(e,t,r){r||(r={}),r.serverName=e.name;let n=await Hb(e.url,r),s=Fm(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{hr.error("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function iu(e){try{dH.isMainThread&&hr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Ac.get(e.database);if(!t){let n;t=new Promise(s=>{hr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Ac.set(e.database,t)}let r=pH(e.nodes[0].url,t,e.database);e.nodes[0].name===void 0&&(r.tentativeNode=e.nodes[0]),r.subscribe(e.nodes.filter(n=>H_(n,e.database)),e.replicateByDefault)}catch(t){hr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Lm({name:e,url:t,database:r}){hr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(Er().primaryStore.getRange({})));let n=Y_.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Xte(){if(kb!==void 0)return kb;let e=_s.default.get(yc.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||_s.default.get(yc.CONFIG_PARAMS.TLS_CERTIFICATE);if(e)return kb=new cH.X509Certificate((0,lH.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function at(){return $m||($m=_s.default.get("replication_hostname")??bi(_s.default.get("replication_url"))??Xte()??aH("operationsapi_network_secureport")??aH("operationsapi_network_port")??"127.0.0.1")}function Zte(){$m=void 0}function aH(e){let t=_s.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function qm(e){let t=_s.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Gm(e){return U_(e)?.[at()]}function ra(){let e=_s.default.get("replication_url");return e||Vm(at())}function Vm(e){let t=qm("replication_port");if(t)return`ws://${e}:${t}`;if(t=qm("replication_secureport"),t)return`wss://${e}:${t}`;if(t=qm("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=qm("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function bi(e){if(e)return new URL(e).hostname}function ta(e,t){for(let n of Object.getOwnPropertyNames(We))r(n);return V_(n=>{r(n)}),bc((n,s)=>{r(n.databaseName)});function r(n){let s=We[n];hr.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):ere(n)&&t(s,n,!1)}a(r,"forDatabase")}function ere(e){let t=We[e];for(let r in t)if(t[r].replicate)return!0}function v_(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function tre(e){let t={message:""};if(e.replicated){e.replicated=!1,hr.trace?.("Replicating operation",e,"to nodes",st.nodes.map(n=>n.name));let r=await Promise.allSettled(st.nodes.map(n=>W_(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=st.nodes[s]?.name,i})}return t}var _s,hr,cH,lH,yc,K_,uH,dH,_H,Wte,fH,oa,ia,Y_,oH,kb,$m,ls=De(()=>{Le();Hs();Al();iH();$r();_s=v(te()),hr=v(V()),cH=require("crypto"),lH=require("fs");k_();nu();yc=v(M());Eb();K_=v(require("node:tls")),uH=v(fe()),dH=require("worker_threads"),Wte=1,fH=[],oa=_s.default.get(yc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)===!0?new Set(K_.rootCertificates):new Set;a(jte,"start");a(EH,"monitorNodeCAs");a(Qte,"disableReplication");a(zte,"assignReplicationSource");a(mH,"setReplicator");Y_=new Map;a(pH,"getConnection");oH=new Map;a(Jte,"getConnectionByName");a(W_,"sendOperationToNode");a(iu,"subscribeToNode");a(Lm,"unsubscribeFromNode");a(Xte,"getCommonNameFromCert");a(at,"getThisNodeName");a(Zte,"clearThisNodeName");Object.defineProperty(st,"hostname",{get(){return at()}});a(aH,"getHostFromListeningPort");a(qm,"getPortFromListeningPort");a(Gm,"getThisNodeId");st.replication={getThisNodeId:Gm,exportIdMapping:U_};a(ra,"getThisNodeUrl");a(Vm,"hostnameToUrl");a(bi,"urlToNodeName");a(ta,"forEachReplicatedDatabase");a(ere,"hasExplicitlyReplicatedTable");a(v_,"lastTimeInAuditStore");a(tre,"replicateOperation")});var j_=b((NIe,AH)=>{"use strict";var du=Nh(),_u=s0(),rre=V(),nre=require("uuid").v4,OIe=require("clone"),Km=Ji(),fu=M(),sre=require("util"),aa=Pn(),{handleHDBError:dn,hdb_errors:ire}=fe(),{HDB_ERROR_MSGS:Ym,HTTP_STATUS_CODES:_n}=ire,{SchemaEventMsg:Wm}=Gs(),SH=kt(),{getDatabases:ore}=(Le(),oe(lt)),{transformReq:Eu}=J(),{replicateOperation:TH}=(ls(),oe(sa));AH.exports={createSchema:are,createSchemaStructure:gH,createTable:cre,createTableStructure:RH,createAttribute:fre,dropSchema:lre,dropTable:ure,dropAttribute:dre,getBackup:Ere};async function are(e){let t=await gH(e);return Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema)),t}a(are,"createSchema");async function gH(e){let t=du.schema_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);if(Eu(e),!await _u.checkSchemaExists(e.schema))throw dn(new Error,Ym.SCHEMA_EXISTS_ERR(e.schema),_n.BAD_REQUEST,fu.LOG_LEVELS.ERROR,Ym.SCHEMA_EXISTS_ERR(e.schema),!0);return await aa.createSchema(e),`database '${e.schema}' successfully created`}a(gH,"createSchemaStructure");async function cre(e){return Eu(e),e.hash_attribute=e.primary_key??e.hash_attribute,await RH(e)}a(cre,"createTable");async function RH(e){let t=du.create_table_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);if(du.validateTableResidence(e.residence),!await _u.checkSchemaTableExists(e.schema,e.table))throw dn(new Error,Ym.TABLE_EXISTS_ERR(e.schema,e.table),_n.BAD_REQUEST,fu.LOG_LEVELS.ERROR,Ym.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:nre(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await aa.createTable(n,e);else throw dn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",_n.BAD_REQUEST);else await aa.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(RH,"createTableStructure");async function lre(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=du.schema_object(e),n=t??r;if(n)throw dn(n,n.message,_n.BAD_REQUEST,void 0,void 0,!0);Eu(e);let s=await _u.checkSchemaExists(e.schema);if(s)throw dn(new Error,s,_n.NOT_FOUND,fu.LOG_LEVELS.ERROR,s,!0);let i=await _u.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await aa.dropSchema(e),Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema)),await SH.purgeSchemaTableStreams(e.schema,o);let c=await TH(e);return c.message=`successfully deleted '${e.schema}'`,c}a(lre,"dropSchema");async function ure(e){let t=du.table_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);Eu(e);let r=await _u.checkSchemaTableExists(e.schema,e.table);if(r)throw dn(new Error,r,_n.NOT_FOUND,fu.LOG_LEVELS.ERROR,r,!0);await aa.dropTable(e),await SH.purgeTableStream(e.schema,e.table);let n=await TH(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(ure,"dropTable");async function dre(e){let t=du.attribute_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);Eu(e);let r=await _u.checkSchemaTableExists(e.schema,e.table);if(r)throw dn(new Error,r,_n.NOT_FOUND,fu.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw dn(new Error,"You cannot drop a hash attribute",_n.BAD_REQUEST,void 0,void 0,!0);if(fu.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw dn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,_n.BAD_REQUEST,void 0,void 0,!0);try{return await aa.dropAttribute(e),_re(e),Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw rre.error(`Got an error deleting attribute ${sre.inspect(e)}.`),n}}a(dre,"dropAttribute");function _re(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(_re,"dropAttributeFromGlobal");async function fre(e){Eu(e);let t=ore()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw dn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,_n.BAD_REQUEST,void 0,void 0,!0);return await aa.createAttribute(e),Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(fre,"createAttribute");function Ere(e){return aa.getBackup(e)}a(Ere,"getBackup")});var yH=b((wIe,bH)=>{"use strict";var{OPERATIONS_ENUM:hre}=M(),Fb=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=hre.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};bH.exports=Fb});var Gb=b((PIe,CH)=>{"use strict";var mre=Pn(),DIe=yH(),jm=J(),Qm=M(),pre=te(),{handleHDBError:OH,hdb_errors:Sre}=fe(),{HDB_ERROR_MSGS:NH,HTTP_STATUS_CODES:IH}=Sre,Tre=Object.values(Qm.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),wH="To use this operation audit log must be enabled in harperdb-config.yaml";CH.exports=gre;async function gre(e){if(jm.isEmpty(e.schema))throw new Error(NH.SCHEMA_REQUIRED_ERR);if(jm.isEmpty(e.table))throw new Error(NH.TABLE_REQUIRED_ERR);if(!pre.get(Qm.CONFIG_PARAMS.LOGGING_AUDITLOG))throw OH(new Error,wH,IH.BAD_REQUEST,Qm.LOG_LEVELS.ERROR,wH,!0);let t=jm.checkSchemaTableExist(e.schema,e.table);if(t)throw OH(new Error,t,IH.NOT_FOUND,Qm.LOG_LEVELS.ERROR,t,!0);if(!jm.isEmpty(e.search_type)&&Tre.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await mre.readAuditLog(e)}a(gre,"readAuditLog")});var PH=b((MIe,DH)=>{"use strict";var{OPERATIONS_ENUM:Rre}=M(),qb=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Rre.GET_BACKUP,this.schema=t,this.table=r}};DH.exports=qb});var UH=b((HIe,MH)=>{"use strict";var Are=Pn(),vIe=PH(),$b=J(),bre=M(),BIe=te(),{handleHDBError:yre,hdb_errors:Ore}=fe(),{HDB_ERROR_MSGS:LH,HTTP_STATUS_CODES:Nre}=Ore;MH.exports=Ire;async function Ire(e){if($b.isEmpty(e.schema))throw new Error(LH.SCHEMA_REQUIRED_ERR);if($b.isEmpty(e.table))throw new Error(LH.TABLE_REQUIRED_ERR);let t=$b.checkSchemaTableExist(e.schema,e.table);if(t)throw yre(new Error,t,Nre.NOT_FOUND,bre.LOG_LEVELS.ERROR,t,!0);return await Are.getBackup(read_audit_log_object)}a(Ire,"getBackup")});var FH=b((kIe,kH)=>{var ca=require("validate.js"),BH=ut(),hu=M(),{handleHDBError:wre,hdb_errors:Cre}=fe(),{HDB_ERROR_MSGS:zt,HTTP_STATUS_CODES:Dre}=Cre,Vb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Pre={STRUCTURE_USER:"structure_user"},vH=Object.values(hu.ROLE_TYPES_ENUM),Lre="attribute_permissions",Mre="attribute_name",{PERMS_CRUD_ENUM:mu}=hu,Ure=[Lre,...Object.values(mu)],HH=[mu.READ,mu.INSERT,mu.UPDATE],vre=[Mre,...HH];function Bre(e){let t=Vb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,xH(e,t)}a(Bre,"addRoleValidation");function Hre(e){let t=Vb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,xH(e,t)}a(Hre,"alterRoleValidation");function xre(e){let t=Vb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,BH.validateObject(e,t)}a(xre,"dropRoleValidation");var kre=["operation","role","id","permission","hdb_user","hdb_auth_header"];function xH(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)kre.includes(n[o])||s.push(n[o]);s.length>0&&sr(zt.INVALID_ROLE_JSON_KEYS(s),r);let i=BH.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{sr(o,r)}),e.permission){let o=Fre(e);o&&sr(o,r),vH.forEach(c=>{e.permission[c]&&!ca.isBoolean(e.permission[c])&&sr(zt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(vH.indexOf(o)<0){if(o===Pre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let d=0,u=l.length;d<u;d++){let _=l[d];global.hdb_schema[_]||sr(zt.SCHEMA_NOT_FOUND(_),r)}continue}sr(zt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){sr(zt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let d=c.tables[l];if(!l||!global.hdb_schema[o][l]){sr(zt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(d).forEach(u=>{Ure.includes(u)||sr(zt.INVALID_PERM_KEY(u),r,o,l)}),Object.values(mu).forEach(u=>{ca.isDefined(d[u])?ca.isBoolean(d[u])||sr(zt.TABLE_PERM_NOT_BOOLEAN(u),r,o,l):sr(zt.TABLE_PERM_MISSING(u),r,o,l)}),ca.isDefined(d.attribute_permissions)){if(!ca.isArray(d.attribute_permissions)){sr(zt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}}else{sr(zt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}if(d.attribute_permissions){let u=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),_={read:!1,insert:!1,update:!1};for(let E in d.attribute_permissions){let f=d.attribute_permissions[E];if(Object.keys(f).forEach(T=>{!vre.includes(T)&&T!==mu.DELETE&&sr(zt.INVALID_ATTR_PERM_KEY(T),r,o,l)}),!ca.isDefined(f.attribute_name)){sr(zt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!u.includes(h)){sr(zt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}HH.forEach(T=>{ca.isDefined(f[T])?ca.isBoolean(f[T])||sr(zt.ATTR_PERM_NOT_BOOLEAN(T,h),r,o,l):sr(zt.ATTR_PERM_MISSING(T,h),r,o,l)}),!_.read&&f.read===!0&&(_.read=!0),!_.insert&&f.insert===!0&&(_.insert=!0),!_.update&&f.update===!0&&(_.update=!0)}if(d.read===!1&&_.read===!0||d.insert===!1&&_.insert===!0||d.update===!1&&_.update===!0){let E=`${o}.${l}`;sr(zt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return Gre(r)}a(xH,"customValidate");kH.exports={addRoleValidation:Bre,alterRoleValidation:Hre,dropRoleValidation:xre};function Fre(e){let{operation:t,permission:r}=e;if(t===hu.OPERATIONS_ENUM.ADD_ROLE||t===hu.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?hu.ROLE_TYPES_ENUM.SUPER_USER:hu.ROLE_TYPES_ENUM.CLUSTER_USER;return zt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Fre,"validateNoSUPerms");function Gre(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 wre(new Error,n,Dre.BAD_REQUEST)}else return null}a(Gre,"generateRolePermResponse");function sr(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(sr,"addPermError")});var Jm=b((qIe,VH)=>{"use strict";var GH=Yr(),qH=Vr(),qre=Wo(),Kb=FH(),Wb=Ji(),GIe=require("uuid").v4,$re=require("util"),zm=M(),Vre=J(),jb=qH.searchByValue,Yre=qH.searchByHash,Kre=$re.promisify(qre.delete),Wre=qs(),jre=Fl(),{hdb_errors:Qre,handleHDBError:Oc}=fe(),{HDB_ERROR_MSGS:$H,HTTP_STATUS_CODES:Q_}=Qre,{UserEventMsg:Qb}=Gs();VH.exports={addRole:zre,alterRole:Jre,dropRole:Xre,listRoles:Zre};function Yb(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(Yb,"scrubRoleDetails");async function zre(e){let t=Kb.addRoleValidation(e);if(t)throw t;e=Yb(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 jb(r)||[])}catch(i){throw Oc(i)}if(n&&n.length>0)throw Oc(new Error,$H.ROLE_ALREADY_EXISTS(e.role),Q_.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 GH.insert(s),Wb.signalUserChange(new Qb(process.pid)),e=Yb(e),e}a(zre,"addRole");async function Jre(e){let t=Kb.alterRoleValidation(e);if(t)throw t;e=Yb(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await GH.update(r)}catch(s){throw Oc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Oc(new Error,"Invalid role id",Q_.BAD_REQUEST,void 0,void 0,!0);return await Wb.signalUserChange(new Qb(process.pid)),e}a(Jre,"alterRole");async function Xre(e){let t=Kb.dropRoleValidation(e);if(t)throw Oc(new Error,t,Q_.BAD_REQUEST,void 0,void 0,!0);let r=new jre(zm.SYSTEM_SCHEMA_NAME,zm.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Yre(r));if(n.length===0)throw Oc(new Error,$H.ROLE_NOT_FOUND,Q_.NOT_FOUND,void 0,void 0,!0);let s=new Wre(zm.SYSTEM_SCHEMA_NAME,zm.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await jb(s)),o=!1;if(Vre.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Oc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,Q_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Kre(c),Wb.signalUserChange(new Qb(process.pid)),`${n[0].role} successfully deleted`}a(Xre,"dropRole");async function Zre(){return jb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Zre,"listRoles")});var jH=b((VIe,WH)=>{"use strict";var ene=te(),la=require("joi"),tne=ut(),YH=require("moment"),rne=require("fs-extra"),zb=require("path"),nne=require("lodash"),z_=M(),{LOG_LEVELS:Nc}=M(),sne="YYYY-MM-DD hh:mm:ss",ine=zb.resolve(__dirname,"../logs");WH.exports=function(e){return tne.validateBySchema(e,one)};var one=la.object({from:la.custom(KH),until:la.custom(KH),level:la.valid(Nc.NOTIFY,Nc.FATAL,Nc.ERROR,Nc.WARN,Nc.INFO,Nc.DEBUG,Nc.TRACE),order:la.valid("asc","desc"),limit:la.number().min(1),start:la.number().min(0),log_name:la.custom(ane)});function KH(e,t){if(YH(e,YH.ISO_8601).format(sne)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(KH,"validateDatetime");function ane(e,t){if(nne.invert(z_.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=ene.get(z_.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?z_.LOG_NAMES.HDB:e,i=s===z_.LOG_NAMES.INSTALL?zb.join(ine,z_.LOG_NAMES.INSTALL):zb.join(n,s);return rne.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(ane,"validateReadLogPath")});var Xb=b((KIe,zH)=>{"use strict";var Xm=M(),cne=V(),lne=te(),une=jH(),Jb=require("path"),QH=require("fs-extra"),{once:dne}=require("events"),{handleHDBError:_ne,hdb_errors:fne}=fe(),{PACKAGE_ROOT:Ene}=M(),hne=Jb.join(Ene,"logs"),mne=1e3,pne=200;zH.exports=Sne;async function Sne(e){let t=une(e);if(t)throw _ne(t,t.message,fne.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=lne.get(Xm.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Xm.LOG_NAMES.HDB:e.log_name,s=n===Xm.LOG_NAMES.INSTALL?Jb.join(hne,Xm.LOG_NAMES.INSTALL):Jb.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,d=e.until!==void 0,u=d?new Date(e.until):void 0,_=e.limit===void 0?mne:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+_,T=0;E==="desc"&&!l&&!u&&(T=Math.max(QH.statSync(s).size-(h+5)*pne,0));let S=QH.createReadStream(s,{start:T});S.on("error",x=>{cne.error(x)});let R=0,p=[],y="",O;S.on("data",x=>{let W=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;x=y+x;let q=0,z;for(;(z=W.exec(x))&&!S.destroyed;){O&&(O.message=x.slice(q,z.index),B(O));let[_e,X,ue]=z,j=ue.split("] ["),ie=j[0],ye=j[1];j.splice(0,2),O={timestamp:X,thread:ie,level:ye,tags:j,message:""},q=z.index+_e.length}y=x.slice(q)}),S.on("end",x=>{S.destroyed||O&&(O.message=y.trim(),B(O))}),S.resume();function B(x){let W,q,z;switch(!0){case(i&&c&&d):W=new Date(x.timestamp),q=new Date(l),z=new Date(u),x.level===o&&W>=q&&W<=z&&R<f?R++:x.level===o&&W>=q&&W<=z&&(ua(x,E,p),R++,R===h&&S.destroy());break;case(i&&c):W=new Date(x.timestamp),q=new Date(l),x.level===o&&W>=q&&R<f?R++:x.level===o&&W>=q&&(ua(x,E,p),R++,R===h&&S.destroy());break;case(i&&d):W=new Date(x.timestamp),z=new Date(u),x.level===o&&W<=z&&R<f?R++:x.level===o&&W<=z&&(ua(x,E,p),R++,R===h&&S.destroy());break;case(c&&d):W=new Date(x.timestamp),q=new Date(l),z=new Date(u),W>=q&&W<=z&&R<f?R++:W>=q&&W<=z&&(ua(x,E,p),R++,R===h&&S.destroy());break;case i:x.level===o&&R<f?R++:x.level===o&&(ua(x,E,p),R++,R===h&&S.destroy());break;case c:W=new Date(x.timestamp),q=new Date(l),W>=q&&R<f?R++:W>=q&&R>=f&&(ua(x,E,p),R++,R===h&&S.destroy());break;case d:W=new Date(x.timestamp),z=new Date(u),W<=z&&R<f?R++:W<=z&&R>=f&&(ua(x,E,p),R++,R===h&&S.destroy());break;default:R<f?R++:(ua(x,E,p),R++,R===h&&S.destroy())}}return a(B,"onLogMessage"),await dne(S,"close"),p}a(Sne,"readLog");function ua(e,t,r){t==="desc"?Tne(e,r):t==="asc"?gne(e,r):r.push(e)}a(ua,"pushLineToResult");function Tne(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(Tne,"insertDescending");function gne(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(gne,"insertAscending")});var Zm=b((XIe,ex)=>{"use strict";var Zb=require("joi"),{string:pu,boolean:JH,date:Rne}=Zb.types(),Ane=ut(),{validateSchemaExists:jIe,validateTableExists:QIe,validateSchemaName:zIe}=di(),bne=M(),yne=dt(),XH=te();XH.initSync();var JIe=pu.invalid(XH.get(bne.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(yne.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),ZH={operation:pu.valid("add_node","update_node","set_node_replication"),node_name:pu.optional(),subscriptions:Zb.array().items({table:pu.optional(),schema:pu.optional(),database:pu.optional(),subscribe:JH.required(),publish:JH.required().custom(Nne),start_time:Rne.iso()})};function One(e){return Ane.validateBySchema(e,Zb.object(ZH))}a(One,"addUpdateNodeValidator");function Nne(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(Nne,"checkForFalsy");ex.exports={addUpdateNodeValidator:One,validation_schema:ZH}});var rx=b((ewe,tx)=>{var Ine=ut(),wne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};tx.exports=function(e){return Ine.validateObject(e,wne)}});var J_=b((twe,nx)=>{"use strict";var Cne=M().OPERATIONS_ENUM,ey=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Cne.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};nx.exports=ey});var ix=b((nwe,sx)=>{"use strict";var Dne={OPERATION:"operation",REFRESH:"refresh"},ty=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},ry=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};sx.exports={JWTTokens:ty,TOKEN_TYPE_ENUM:Dne,JWTRSAKeys:ry}});var ef=b((iwe,lx)=>{"use strict";var Z_=require("jsonwebtoken"),ny=require("fs-extra"),sy=J(),Es=M(),{handleHDBError:fn,hdb_errors:Pne}=fe(),{HTTP_STATUS_CODES:En,AUTHENTICATION_ERROR_MSGS:hn}=Pne,X_=V(),ox=Hh(),ay=vn(),Lne=Yr().update,Mne=J_(),Une=Ji(),{UserEventMsg:vne}=Gs(),da=te();da.initSync();var iy=require("path"),{JWTTokens:Bne,JWTRSAKeys:Hne,TOKEN_TYPE_ENUM:ep}=ix(),xne=da.get(Es.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?da.get(Es.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",kne=da.get(Es.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?da.get(Es.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",tp="RS256",oy;lx.exports={createTokens:Fne,validateOperationToken:qne,refreshOperationToken:Gne,validateRefreshToken:cx};async function Fne(e){if(sy.isEmpty(e)||typeof e!="object")throw fn(new Error,hn.INVALID_AUTH_OBJECT,En.BAD_REQUEST,void 0,void 0,!0);if(sy.isEmpty(e.username))throw fn(new Error,hn.USERNAME_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);if(sy.isEmpty(e.password))throw fn(new Error,hn.PASSWORD_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await ay.findAndValidateUser(e.username,e.password),!t)throw fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw X_.error(E),fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}let r=await rp(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await ax(i,r.private_key,r.passphrase),c=await Z_.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:kne,algorithm:tp,subject:ep.REFRESH}),l=ox.hash(c),d=new Mne(Es.SYSTEM_SCHEMA_NAME,Es.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),u,_;try{u=await Lne(d)}catch(E){X_.error(E),_=E}if(_!==void 0||u.skipped_hashes.length>0)throw fn(new Error,hn.REFRESH_TOKEN_SAVE_FAILED,En.INTERNAL_SERVER_ERROR);return Une.signalUserChange(new vne(process.pid)),new Bne(o,c)}a(Fne,"createTokens");async function ax(e,t,r){return await Z_.sign(e,{key:t,passphrase:r},{expiresIn:xne,algorithm:tp,subject:ep.OPERATION})}a(ax,"signOperationToken");async function rp(){if(oy===void 0)try{let e=iy.join(da.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,Es.JWT_ENUM.JWT_PASSPHRASE_NAME),t=iy.join(da.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,Es.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=iy.join(da.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,Es.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await ny.readFile(e)).toString(),s=(await ny.readFile(t)).toString(),i=(await ny.readFile(r)).toString();oy=new Hne(i,s,n)}catch(e){throw X_.error(e),fn(new Error,hn.NO_ENCRYPTION_KEYS,En.INTERNAL_SERVER_ERROR)}return oy}a(rp,"getJWTRSAKeys");async function Gne(e){if(!e)throw fn(new Error,hn.INVALID_BODY,En.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw fn(new Error,hn.REFRESH_TOKEN_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);await cx(e.refresh_token);let t=await rp(),r=await Z_.decode(e.refresh_token);return{operation_token:await ax({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(Gne,"refreshOperationToken");async function qne(e){try{let t=await rp(),r=await Z_.verify(e,t.public_key,{algorithms:tp,subject:ep.OPERATION});return await ay.findAndValidateUser(r.username,void 0,!1)}catch(t){throw X_.warn(t),t.name&&t.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}}a(qne,"validateOperationToken");async function cx(e){let t;try{let r=await rp(),n=await Z_.verify(e,r.public_key,{algorithms:tp,subject:ep.REFRESH});t=await ay.findAndValidateUser(n.username,void 0,!1)}catch(r){throw X_.warn(r),r.name&&r.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}if(!ox.validate(t.refresh_token,e))throw fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED);return t}a(cx,"validateRefreshToken")});var cy=b((cwe,_x)=>{"use strict";var $ne=rx(),Su=require("passport"),Vne=require("passport-local").Strategy,Yne=require("passport-http").BasicStrategy,Kne=require("util"),Wne=vn(),dx=Kne.callbackify(Wne.findAndValidateUser),awe=Nn(),jne=M(),ux=ef();Su.use(new Vne(function(e,t,r){dx(e,t,r)}));Su.use(new Yne(function(e,t,r){dx(e,t,r)}));Su.serializeUser(function(e,t){t(null,e)});Su.deserializeUser(function(e,t){t(null,e)});function Qne(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":Su.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===jne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?ux.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):ux.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Su.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Qne,"authorize");function zne(e,t){let r=$ne(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(zne,"checkPermissions");_x.exports={authorize:Qne,checkPermissions:zne}});var _a=b((uwe,fx)=>{"use strict";var ly=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},uy=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};fx.exports={Node:ly,NodeSubscription:uy}});var hx=b((_we,Ex)=>{"use strict";var Jne=M().OPERATIONS_ENUM,dy=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Jne.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Ex.exports=dy});var tf=b((Ewe,mx)=>{"use strict";var _y=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},fy=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)}};mx.exports={RemotePayloadObject:_y,RemotePayloadSubscription:fy}});var Sx=b((mwe,px)=>{"use strict";var Ey=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}};px.exports=Ey});var gx=b((Awe,Tx)=>{"use strict";var Xne=Sx(),Swe=Bt(),Twe=ht(),Zne=V(),{getSchemaPath:gwe,getTransactionAuditStorePath:Rwe}=gt(),{getDatabases:ese}=(Le(),oe(lt));Tx.exports=tse;async function tse(e){let t=new Xne;try{let r=ese()[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){Zne.warn(`unable to stat table dbi due to ${r}`)}return t}a(tse,"lmdbGetTableSize")});var Ax=b((ywe,Rx)=>{"use strict";var hy=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}};Rx.exports=hy});var gu=b((Dwe,Nx)=>{"use strict";var rse=require("fs-extra"),nse=require("path"),Jr=require("systeminformation"),fa=V(),bx=kt(),Nwe=dt(),Tu=M(),sse=gx(),ise=fi(),{getThreadInfo:yx}=it(),rf=te();rf.initSync();var ose=Ax(),{openEnvironment:Iwe}=ht(),{getSchemaPath:wwe}=gt(),{database:Cwe,databases:my}=(Le(),oe(lt)),np;Nx.exports={getHDBProcessInfo:gy,getNetworkInfo:Ay,getDiskInfo:Ry,getMemoryInfo:Ty,getCPUInfo:Sy,getTimeInfo:py,getSystemInformation:by,systemInformation:ase,getTableSize:yy,getMetrics:Oy};function py(){return Jr.time()}a(py,"getTimeInfo");async function Sy(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:d,...u}=await Jr.cpu();u.cpu_speed=await Jr.cpuCurrentSpeed();let{raw_currentload:_,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:T,raw_currentload_user:S,cpus:R,...p}=await Jr.currentLoad();return p.cpus=[],R.forEach(y=>{let{raw_load:O,raw_load_idle:B,raw_load_irq:x,raw_load_nice:W,raw_load_system:q,raw_load_user:z,..._e}=y;p.cpus.push(_e)}),u.current_load=p,u}catch(e){return fa.error(`error in getCPUInfo: ${e}`),{}}}a(Sy,"getCPUInfo");async function Ty(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Jr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return fa.error(`error in getMemoryInfo: ${e}`),{}}}a(Ty,"getMemoryInfo");async function gy(){let e={core:[],clustering:[]};try{let t=await Jr.processes(),r;try{r=Number.parseInt(await rse.readFile(nse.join(rf.get(Tu.CONFIG_PARAMS.ROOTPATH),Tu.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Tu.NODE_ERROR_CODES.ENOENT)fa.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 fa.error(`error in getHDBProcessInfo: ${t}`),e}}a(gy,"getHDBProcessInfo");async function Ry(){let e={};try{if(!rf.get(Tu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Jr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...d}=await Jr.fsStats();return e.read_write=d,e.size=await Jr.fsSize(),e}catch(t){return fa.error(`error in getDiskInfo: ${t}`),e}}a(Ry,"getDiskInfo");async function Ay(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return rf.get(Tu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Jr.networkInterfaceDefault(),e.latency=await Jr.inetChecksite("google.com"),(await Jr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:d,ieee8021xState:u,carrier_changes:_,...E}=n;e.interfaces.push(E)}),(await Jr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return fa.error(`error in getNetworkInfo: ${t}`),e}}a(Ay,"getNetworkInfo");async function by(){if(np!==void 0)return np;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Jr.osInfo();e=c;let l=await Jr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,np=e,np}catch(t){return fa.error(`error in getSystemInformation: ${t}`),e}}a(by,"getSystemInformation");async function yy(){let e=[],t=await ise.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await sse(n));return e}a(yy,"getTableSize");async function Oy(){let e={};for(let t in my){let r=e[t]={},n=r.tables={};for(let s in my[t])try{let i=my[t][s];r.readers||(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[d,u,_]=l.trim().split(" ");return{pid:d,thread:u,txnid:_}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){fa.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(Oy,"getMetrics");async function Ox(){if(rf.get(Tu.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await bx.getNATSReferences(),t=await bx.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(Ox,"getNatsStreamInfo");async function ase(e){let t=new ose;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await by(),t.time=py(),t.cpu=await Sy(),t.memory=await Ty(),t.disk=await Ry(),t.network=await Ay(),t.harperdb_processes=await gy(),t.table_size=await yy(),t.metrics=await Oy(),t.threads=await yx(),t.replication=await Ox(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await by();break;case"time":t.time=py();break;case"cpu":t.cpu=await Sy();break;case"memory":t.memory=await Ty();break;case"disk":t.disk=await Ry();break;case"network":t.network=await Ay();break;case"harperdb_processes":t.harperdb_processes=await gy();break;case"table_size":t.table_size=await yy();break;case"database_metrics":case"metrics":t.metrics=await Oy();break;case"threads":t.threads=await yx();break;case"replication":t.replication=await Ox();break;default:break}return t}a(ase,"systemInformation")});var Ic=b((Lwe,Ix)=>{"use strict";Ix.exports={version:cse,printVersion:lse};var sp=Kl();function cse(){if(sp)return sp.version}a(cse,"version");function lse(){sp&&console.log(`HarperDB Version ${sp.version}`)}a(lse,"printVersion")});var hs=b((Bwe,Px)=>{"use strict";var use=Yr(),Ny=J(),dse=require("util"),wc=M(),wx=te();wx.initSync();var _se=cy(),Cx=Vr(),{Node:Uwe,NodeSubscription:vwe}=_a(),fse=Fl(),Ese=hx(),{RemotePayloadObject:hse,RemotePayloadSubscription:mse}=tf(),{handleHDBError:pse,hdb_errors:Sse}=fe(),{HTTP_STATUS_CODES:Tse,HDB_ERROR_MSGS:gse}=Sse,Rse=qs(),Ase=gu(),bse=Ic(),{getDatabases:yse}=(Le(),oe(lt)),Ose=dse.promisify(_se.authorize),Nse=Cx.searchByHash,Ise=Cx.searchByValue;Px.exports={authHeaderToUser:wse,isEmpty:Cse,getNodeRecord:Dse,upsertNodeRecord:Pse,buildNodePayloads:Lse,checkClusteringEnabled:Mse,getAllNodeRecords:Use,getSystemInfo:vse,reverseSubscription:Dx};async function wse(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Ose(t,null),e}a(wse,"authHeaderToUser");function Cse(e){return e==null}a(Cse,"isEmpty");async function Dse(e){let t=new fse(wc.SYSTEM_SCHEMA_NAME,wc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Nse(t)}a(Dse,"getNodeRecord");async function Pse(e){let t=new Ese(wc.SYSTEM_SCHEMA_NAME,wc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return use.upsert(t)}a(Pse,"upsertNodeRecord");function Dx(e){if(Ny.isEmpty(e.subscribe)||Ny.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(Dx,"reverseSubscription");function Lse(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:d}=c,u=Ny.getTableHashAttribute(l,d),{subscribe:_,publish:E}=Dx(c),f=yse()[l]?.[d],h=new mse(l,d,u,E,_,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new hse(r,t,s,n)}a(Lse,"buildNodePayloads");function Mse(){if(!wx.get(wc.CONFIG_PARAMS.CLUSTERING_ENABLED))throw pse(new Error,gse.CLUSTERING_NOT_ENABLED,Tse.BAD_REQUEST,void 0,void 0,!0)}a(Mse,"checkClusteringEnabled");async function Use(){let e=new Rse(wc.SYSTEM_SCHEMA_NAME,wc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Ise(e))}a(Use,"getAllNodeRecords");async function vse(){let e=await Ase.getSystemInformation();return{hdb_version:bse.version(),node_version:e.node_version,platform:e.platform}}a(vse,"getSystemInfo")});var Iy=b((xwe,kx)=>{"use strict";var ip=kt(),Lx=J(),Mx=dt(),Ux=M(),op=V(),vx=j_(),Bse=ql(),{RemotePayloadObject:Hse}=tf(),{handleHDBError:Bx,hdb_errors:xse}=fe(),{HTTP_STATUS_CODES:Hx}=xse,{NodeSubscription:xx}=_a();kx.exports=kse;async function kse(e,t){let r;try{r=await ip.request(`${t}.${Mx.REQUEST_SUFFIX}`,new Hse(Ux.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),op.trace("Response from remote describe all request:",r)}catch(o){op.error(`addNode received error from describe all request to remote node: ${o}`);let c=ip.requestErrorHandler(o,"add_node",t);throw Bx(new Error,c,Hx.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===Mx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw Bx(new Error,o,Hx.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===Ux.SYSTEM_SCHEMA_NAME){await ip.createLocalTableStream(l,c);let h=new xx(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let d=Lx.doesSchemaExist(l),u=n[l]!==void 0,_=c?Lx.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!d&&!u||!_&&!E){s.push(o);continue}if(!d&&u&&(op.trace(`addNode creating schema: ${l}`),await vx.createSchema({operation:"create_schema",schema:l})),!_&&E){op.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Bse(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await vx.createTable(h)}await ip.createLocalTableStream(l,c);let f=new xx(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(kse,"reviewSubscriptions")});var Cc={};et(Cc,{addNodeBack:()=>Vse,removeNodeBack:()=>Yse,setNode:()=>$se});async function $se(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=bi(t)):t=Vm(r);let n=(0,Gx.validateBySchema)(e,qse);if(n)throw(0,Oi.handleHDBError)(n,n.message,Gse.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Oi.ClientError("url or hostname is required for remove_node operation");let _=r,E=Er(),f=await E.get(_);if(!f)throw new Oi.ClientError(_+" does not exist");try{await W_({url:f.url},{operation:nf.OPERATIONS_ENUM.REMOVE_NODE_BACK,name:f?.subscriptions?.length>0?at():_},void 0)}catch(h){ms.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:`,h)}return await E.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Oi.ClientError("url required for this operation");let s=ra();if(s==null)throw new Oi.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){if(e.operation==="add_node"&&!e.authorization)throw new Oi.ClientError("authorization parameter is required");i=await(0,ps.getReplicationCert)();let _=await(0,ps.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ps.createCsr)(),ms.info("Sending CSR to target node:",t)):(c=_?.certificate,ms.info("Sending CA named",_?.name,"to target node",t))}let l={operation:nf.OPERATIONS_ENUM.ADD_NODE_BACK,hostname:(0,qx.get)(nf.CONFIG_PARAMS.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c};if(e.subscriptions?l.subscriptions=e.subscriptions.map(Fx):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=Fx(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 d;try{d=await W_({url:t},l,e)}catch(_){throw _.message=`Error returned from ${t}: `+_.message,_}if(o&&(!d?.certificate||!d?.certificate?.includes?.("BEGIN CERTIFICATE")))throw new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(d)}`);o&&(ms.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,ps.setCertTable)({name:Fse.certificateFromPem(d.signingCA).issuer.getField("CN").value,certificate:d.signingCA,is_authority:!0}),d.certificate&&await(0,ps.setCertTable)({name:at(),uses:["https","operations","wss"],certificate:d.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=d.signingCA);let u={url:t,ca:d.usingCA};if(e.hostname&&(u.name=e.hostname),e.subscriptions?u.subscriptions=e.subscriptions:u.replicates=!0,e.start_time&&(u.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),u.replicates){let _={url:s,ca:c,replicates:!0,subscriptions:null};e.start_time&&(_.start_time=e.start_time),await ro(at(),_)}return await ro(d.nodeName,u),e.operation==="update_node"?`Successfully updated '${t}'`:`Successfully added '${t}' to cluster`}async function Vse(e){ms.trace("addNodeBack received request:",e);let t=await(0,ps.signCertificate)(e),r;e.csr?(r=t.signingCA,ms.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,ms.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);let s=await(0,ps.getReplicationCertAuth)();if(n.replicates){let i={url:ra(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),await ro(at(),i)}return await ro(e.hostname,n),t.nodeName=at(),t.usingCA=s?.certificate,ms.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Yse(e){ms.trace("removeNodeBack received request:",e),await Er().delete(e.name)}function Fx(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var ps,Gx,Ru,qx,nf,ms,Oi,Fse,Gse,qse,Dc=De(()=>{ps=v(js()),Gx=v(ut()),Ru=v(require("joi")),qx=v(te()),nf=v(M());k_();nu();ls();ms=v(V()),Oi=v(fe()),{pki:Fse}=require("node-forge"),{HTTP_STATUS_CODES:Gse}=Oi.hdb_errors,qse=Ru.default.object({hostname:Ru.default.string(),verify_tls:Ru.default.boolean(),replicates:Ru.default.boolean(),subscriptions:Ru.default.array()});a($se,"setNode");a(Vse,"addNodeBack");a(Yse,"removeNodeBack");a(Fx,"reverseSubscription")});var dp=b((Kwe,Vx)=>{"use strict";var{handleHDBError:ap,hdb_errors:Kse}=fe(),{HTTP_STATUS_CODES:cp}=Kse,{addUpdateNodeValidator:Wse}=Zm(),lp=V(),up=M(),$x=dt(),jse=J(),sf=kt(),of=hs(),wy=te(),Qse=Iy(),{Node:zse,NodeSubscription:Jse}=_a(),{broadcast:Xse}=it(),{setNode:Zse}=(Dc(),oe(Cc)),Vwe=te(),Ywe=M(),eie="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",tie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",rie=wy.get(up.CONFIG_PARAMS.CLUSTERING_NODENAME);Vx.exports=nie;async function nie(e,t=!1){if(lp.trace("addNode called with:",e),wy.get(up.CONFIG_PARAMS.REPLICATION_URL)||wy.get(up.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Zse(e);of.checkClusteringEnabled();let r=Wse(e);if(r)throw ap(r,r.message,cp.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let _=await of.getNodeRecord(n);if(!jse.isEmptyOrZeroLength(_))throw ap(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,cp.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Qse(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=eie,o;let c=of.buildNodePayloads(s,rie,up.OPERATIONS_ENUM.ADD_NODE,await of.getSystemInfo()),l=[];for(let _=0,E=s.length;_<E;_++){let f=s[_];s[_].start_time===void 0&&delete s[_].start_time,l.push(new Jse(f.schema,f.table,f.publish,f.subscribe))}lp.trace("addNode sending remote payload:",c);let d;try{d=await sf.request(`${n}.${$x.REQUEST_SUFFIX}`,c)}catch(_){lp.error(`addNode received error from request: ${_}`);for(let f=0,h=s.length;f<h;f++){let T=s[f];T.publish=!1,T.subscribe=!1,await sf.updateRemoteConsumer(T,n)}let E=sf.requestErrorHandler(_,"add_node",n);throw ap(new Error,E,cp.INTERNAL_SERVER_ERROR,"error",E)}if(d.status===$x.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let _=`Error returned from remote node ${n}: ${d.message}`;throw ap(new Error,_,cp.INTERNAL_SERVER_ERROR,"error",_)}lp.trace(d);for(let _=0,E=s.length;_<E;_++){let f=s[_];await sf.updateRemoteConsumer(f,n),f.subscribe===!0&&await sf.updateConsumerIterator(f.schema,f.table,n,"start")}let u=new zse(n,l,d.system_info);return await of.upsertNodeRecord(u),Xse({type:"nats_update"}),i.length>0?o.message=tie:o.message=`Successfully added '${n}' to manifest`,o}a(nie,"addNode")});var Ly=b((Qwe,Kx)=>{"use strict";var{handleHDBError:Cy,hdb_errors:sie}=fe(),{HTTP_STATUS_CODES:Dy}=sie,{addUpdateNodeValidator:iie}=Zm(),af=V(),_p=M(),Yx=dt(),jwe=J(),cf=kt(),lf=hs(),Py=te(),{cloneDeep:oie}=require("lodash"),aie=Iy(),{Node:cie,NodeSubscription:lie}=_a(),{broadcast:uie}=it(),{setNode:die}=(Dc(),oe(Cc)),_ie="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",fie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Eie=Py.get(_p.CONFIG_PARAMS.CLUSTERING_NODENAME);Kx.exports=hie;async function hie(e){if(af.trace("updateNode called with:",e),Py.get(_p.CONFIG_PARAMS.REPLICATION_URL)??Py.get(_p.CONFIG_PARAMS.REPLICATION_HOSTNAME))return die(e);lf.checkClusteringEnabled();let t=iie(e);if(t)throw Cy(t,t.message,Dy.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await lf.getNodeRecord(r);s.length>0&&(n=oie(s));let{added:i,skipped:o}=await aie(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=_ie,c;let l=lf.buildNodePayloads(i,Eie,_p.OPERATIONS_ENUM.UPDATE_NODE,await lf.getSystemInfo());for(let u=0,_=i.length;u<_;u++){let E=i[u];af.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[u].start_time===void 0&&delete i[u].start_time}af.trace("updateNode sending remote payload:",l);let d;try{d=await cf.request(`${r}.${Yx.REQUEST_SUFFIX}`,l)}catch(u){af.error(`updateNode received error from request: ${u}`);let _=cf.requestErrorHandler(u,"update_node",r);throw Cy(new Error,_,Dy.INTERNAL_SERVER_ERROR,"error",_)}if(d.status===Yx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${d.message}`;throw Cy(new Error,u,Dy.INTERNAL_SERVER_ERROR,"error",u)}af.trace(d);for(let u=0,_=i.length;u<_;u++){let E=i[u];await cf.updateRemoteConsumer(E,r),E.subscribe===!0?await cf.updateConsumerIterator(E.schema,E.table,r,"start"):await cf.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new cie(r,[],d.system_info)]),await mie(n[0],i,d.system_info),o.length>0?c.message=fie:c.message=`Successfully updated '${r}'`,c}a(hie,"updateNode");async function mie(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,d=e.subscriptions.length;l<d;l++){let u=n.subscriptions[l];if(u.schema===o.schema&&u.table===o.table){u.publish=o.publish,u.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new lie(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await lf.upsertNodeRecord(n),uie({type:"nats_update"})}a(mie,"updateNodeTable")});var Jx=b((Jwe,zx)=>{"use strict";var Qx=require("joi"),{string:Wx}=Qx.types(),pie=ut(),jx=M(),Sie=te(),Tie=dt();zx.exports=gie;function gie(e){let t=Wx.invalid(Sie.get(jx.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Tie.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=Qx.object({operation:Wx.valid(jx.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return pie.validateBySchema(e,r)}a(gie,"removeNodeValidator")});var fp=b((Zwe,rk)=>{"use strict";var{handleHDBError:Xx,hdb_errors:Rie}=fe(),{HTTP_STATUS_CODES:Zx}=Rie,Aie=Jx(),uf=V(),ek=hs(),bie=J(),Au=M(),tk=dt(),My=kt(),Uy=te(),{RemotePayloadObject:yie}=tf(),{NodeSubscription:Oie}=_a(),Nie=Gl(),Iie=Wo(),{broadcast:wie}=it(),{setNode:Cie}=(Dc(),oe(Cc)),Die=Uy.get(Au.CONFIG_PARAMS.CLUSTERING_NODENAME);rk.exports=Pie;async function Pie(e){if(uf.trace("removeNode called with:",e),Uy.get(Au.CONFIG_PARAMS.REPLICATION_URL)??Uy.get(Au.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Cie(e);ek.checkClusteringEnabled();let t=Aie(e);if(t)throw Xx(t,t.message,Zx.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await ek.getNodeRecord(r);if(bie.isEmptyOrZeroLength(n))throw Xx(new Error,`Node '${r}' was not found.`,Zx.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new yie(Au.OPERATIONS_ENUM.REMOVE_NODE,Die,[]),i,o=!1;for(let l=0,d=n.subscriptions.length;l<d;l++){let u=n.subscriptions[l];u.subscribe===!0&&await My.updateConsumerIterator(u.schema,u.table,r,"stop");try{await My.updateRemoteConsumer(new Oie(u.schema,u.table,!1,!1),r)}catch(_){uf.error(_)}}try{i=await My.request(`${r}.${tk.REQUEST_SUFFIX}`,s),uf.trace("Remove node reply from remote node:",r,i)}catch(l){uf.error("removeNode received error from request:",l),o=!0}let c=new Nie(Au.SYSTEM_SCHEMA_NAME,Au.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Iie.deleteRecord(c),wie({type:"nats_update"}),i?.status===tk.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(uf.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(Pie,"removeNode")});var ik=b((tCe,sk)=>{"use strict";var nk=require("joi"),{string:Lie,array:Mie}=nk.types(),Uie=ut(),vie=Zm();sk.exports=Bie;function Bie(e){let t=nk.object({operation:Lie.valid("configure_cluster").required(),connections:Mie.items(vie.validation_schema).required()});return Uie.validateBySchema(e,t)}a(Bie,"configureClusterValidator")});var vy=b((nCe,uk)=>{"use strict";var ok=M(),Ep=V(),Hie=J(),xie=te(),kie=fp(),Fie=dp(),Gie=hs(),qie=ik(),{handleHDBError:ak,hdb_errors:$ie}=fe(),{HTTP_STATUS_CODES:ck}=$ie,Vie="Configure cluster complete.",Yie="Failed to configure the cluster. Check the logs for more details.",Kie="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";uk.exports=Wie;async function Wie(e){Ep.trace("configure cluster called with:",e);let t=qie(e);if(t)throw ak(t,t.message,ck.BAD_REQUEST,void 0,void 0,!0);let r=await Gie.getAllNodeRecords(),n=[];if(xie.get(ok.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let u=0,_=r.length;u<_;u++){let E=await lk(kie,{operation:ok.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[u].name},r[u].name);n.push(E)}Ep.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let u=0;u<i;u++){let _=e.connections[u],E=await lk(Fie,_,_.node_name);s.push(E)}Ep.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,d=n.concat(s);for(let u=0,_=d.length;u<_;u++){let E=d[u];E.status==="rejected"&&(Ep.error(E.node_name,E?.error?.message,E?.error?.stack),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,response:E?.result})}if(Hie.isEmptyOrZeroLength(o))return{message:Vie,connections:c};if(l)return{message:Kie,failed_nodes:o,connections:c};throw ak(new Error,Yie,ck.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Wie,"configureCluster");async function lk(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(lk,"functionWrapper")});var Ek=b((iCe,fk)=>{"use strict";var df=require("joi"),jie=ut(),{validateSchemaExists:dk,validateTableExists:Qie,validateSchemaName:_k}=di(),zie=df.object({operation:df.string().valid("purge_stream"),schema:df.string().custom(dk).custom(_k).optional(),database:df.string().custom(dk).custom(_k).optional(),table:df.string().custom(Qie).required()});function Jie(e){return jie.validateBySchema(e,zie)}a(Jie,"purgeStreamValidator");fk.exports=Jie});var By=b((aCe,hk)=>{"use strict";var{handleHDBError:Xie,hdb_errors:Zie}=fe(),{HTTP_STATUS_CODES:eoe}=Zie,toe=Ek(),roe=kt(),noe=hs();hk.exports=soe;async function soe(e){e.schema=e.schema??e.database;let t=toe(e);if(t)throw Xie(t,t.message,eoe.BAD_REQUEST,void 0,void 0,!0);noe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await roe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(soe,"purgeStream")});var ky=b((lCe,Ak)=>{"use strict";var xy=hs(),ioe=kt(),hp=te(),bu=M(),Pc=dt(),ooe=J(),Hy=V(),{RemotePayloadObject:aoe}=tf(),{ErrorCode:mk}=require("nats"),{parentPort:pk}=require("worker_threads"),{onMessageByType:coe}=it(),{getThisNodeName:loe}=(ls(),oe(sa)),{requestClusterStatus:uoe}=(k_(),oe(mB)),Sk=hp.get(bu.CONFIG_PARAMS.CLUSTERING_ENABLED),Tk=hp.get(bu.CONFIG_PARAMS.CLUSTERING_NODENAME);Ak.exports={clusterStatus:doe,buildNodeStatus:Rk};var gk;coe("cluster-status",async e=>{gk(e)});async function doe(){if(hp.get(bu.CONFIG_PARAMS.REPLICATION_URL)||hp.get(bu.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;return pk?(pk.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{gk=s})):n=uoe(),n.node_name=loe(),n.is_enabled=!0,n}let e={node_name:Tk,is_enabled:Sk,connections:[]};if(!Sk)return e;let t=await xy.getAllNodeRecords();if(ooe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Rk(t[n],e.connections));return await Promise.allSettled(r),e}a(doe,"clusterStatus");async function Rk(e,t){let r=e.name,n=new aoe(bu.OPERATIONS_ENUM.CLUSTER_STATUS,Tk,void 0,await xy.getSystemInfo()),s,i,o=Pc.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await ioe.request(Pc.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Pc.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Pc.CLUSTER_STATUS_STATUSES.CLOSED,Hy.error(`Error getting node status from ${r} `,s))}catch(l){Hy.warn(`Error getting node status from ${r}`,l),l.code===mk.NoResponders?o=Pc.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===mk.Timeout?o=Pc.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Pc.CLUSTER_STATUS_STATUSES.CLOSED}let c=new _oe(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!==bu.PRE_4_0_0_VERSION&&await xy.upsertNodeRecord(l)}catch(l){Hy.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Rk,"buildNodeStatus");function _oe(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(_oe,"NodeStatusObject")});var Gy=b((dCe,bk)=>{"use strict";var{handleHDBError:foe,hdb_errors:Eoe}=fe(),{HTTP_STATUS_CODES:hoe}=Eoe,moe=kt(),poe=hs(),Fy=J(),mp=require("joi"),Soe=ut(),Toe=2e3,goe=mp.object({timeout:mp.number().min(1),connected_nodes:mp.boolean(),routes:mp.boolean()});bk.exports=Roe;async function Roe(e){poe.checkClusteringEnabled();let t=Soe.validateBySchema(e,goe);if(t)throw foe(t,t.message,hoe.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||Fy.autoCastBoolean(n),o=s===void 0||Fy.autoCastBoolean(s),c={nodes:[]},l=await moe.getServerList(r??Toe),d={};if(i)for(let u=0,_=l.length;u<_;u++){let E=l[u].statsz;E&&(d[l[u].server.name]=E.routes)}for(let u=0,_=l.length;u<_;u++){if(l[u].statsz)continue;let E=l[u].server,f=l[u].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[u].response_time};i&&(h.connected_nodes=[],d[E.name]&&d[E.name].forEach(T=>{h.connected_nodes.includes(T.name.slice(0,-4))||h.connected_nodes.push(T.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(T=>({host:T.split(":")[0],port:Fy.autoCast(T.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(Roe,"clusterNetwork")});var Ik=b((fCe,Nk)=>{"use strict";var qy=require("joi"),yk=ut(),{route_constraints:Ok}=DR();Nk.exports={setRoutesValidator:Aoe,deleteRoutesValidator:boe};function Aoe(e){let t=qy.object({server:qy.valid("hub","leaf"),routes:Ok.required()});return yk.validateBySchema(e,t)}a(Aoe,"setRoutesValidator");function boe(e){let t=qy.object({routes:Ok.required()});return yk.validateBySchema(e,t)}a(boe,"deleteRoutesValidator")});var pp=b((hCe,Uk)=>{"use strict";var oo=wt(),$y=J(),Ss=M(),yu=te(),wk=Ik(),{handleHDBError:Ck,hdb_errors:yoe}=fe(),{HTTP_STATUS_CODES:Dk}=yoe,Pk="cluster routes successfully set",Lk="cluster routes successfully deleted";Uk.exports={setRoutes:Noe,getRoutes:Ioe,deleteRoutes:woe};function Ooe(e){let t=oo.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=$y.autoCast(l.port);let d=r.some(_=>_.host===l.host&&_.port===l.port),u=n.some(_=>_.host===l.host&&_.port===l.port);d||u?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?oo.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):oo.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:Pk,set:i,skipped:s}}a(Ooe,"setRoutesNats");function Noe(e){let t=wk.setRoutesValidator(e);if(t)throw Ck(t,t.message,Dk.BAD_REQUEST,void 0,void 0,!0);if(yu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ooe(e);let r=[],n=[],s=yu.get(Ss.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Mk(s,i)?n.push(i):(s.push(i),r.push(i))}),oo.updateConfigValue(Ss.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:Pk,set:r,skipped:n}}a(Noe,"setRoutes");function Mk(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(Mk,"existsInArray");function Ioe(){if(yu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=oo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return yu.get(Ss.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Ioe,"getRoutes");function woe(e){let t=wk.deleteRoutesValidator(e);if(t)throw Ck(t,t.message,Dk.BAD_REQUEST,void 0,void 0,!0);if(yu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED))return Coe(e);let r=[],n=[],s=yu.get(Ss.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Mk(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),oo.updateConfigValue(Ss.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Lk,deleted:r,skipped:n}}a(woe,"deleteRoutes");function Coe(e){let t=oo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,d=e.routes.length;l<d;l++){let u=e.routes[l],_=!1;for(let E=0,f=r.length;E<f;E++){let h=r[E];if(u.host===h.host&&u.port===h.port){r.splice(E,1),_=!0,o=!0,s.push(u);break}}if(!_){let E=!0;for(let f=0,h=n.length;f<h;f++){let T=n[f];if(u.host===T.host&&u.port===T.port){n.splice(f,1),c=!0,E=!1,s.push(u);break}}E&&i.push(u)}}return o&&(r=$y.isEmptyOrZeroLength(r)?null:r,oo.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=$y.isEmptyOrZeroLength(n)?null:n,oo.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Lk,deleted:s,skipped:i}}a(Coe,"deleteRoutesNats")});var Bk=b((pCe,vk)=>{"use strict";var _f=require("alasql"),Lc=require("recursive-iterator"),Qs=V(),Doe=J(),ff=M(),Vy=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,Loe(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=>ff.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=>!ff.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][ff.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Poe(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(d=>({attribute_name:d.attribute}));let l=this.affected_attributes.get(i).get(o).filter(d=>!ff.SEARCH_WILDCARDS.includes(d));c.forEach(({attribute_name:d})=>{let u=new _f.yy.Column({columnid:d});s.tableid&&(u.tableid=s.tableid),this.ast.columns.push(u),l.includes(d)||l.push(d)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function Poe(e){return e.filter(t=>t[ff.PERMS_CRUD_ENUM.READ])}a(Poe,"filterReadRestrictedAttrs");function Loe(e,t,r,n,s){Moe(e,t,r,n,s)}a(Loe,"interpretAST");function Ef(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(Ef,"addSchemaTableToMap");function Moe(e,t,r,n,s){if(!e){Qs.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof _f.yy.Insert?Hoe(e,t,r):e instanceof _f.yy.Select?Uoe(e,t,r,n,s):e instanceof _f.yy.Update?voe(e,t,r):e instanceof _f.yy.Delete?Boe(e,t,r):Qs.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(Moe,"getRecordAttributesAST");function Uoe(e,t,r,n,s){if(!e){Qs.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Doe.isEmptyOrZeroLength(i)){Qs.error("No schema specified");return}e.from.forEach(c=>{Ef(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Ef(c.table,t,r,n,s)});let o=new Lc(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,d=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(d).has(l))if(r.has(l))l=r.get(l);else{Qs.info(`table specified as ${l} not found.`);return}t.get(d).get(l).indexOf(c.columnid)<0&&t.get(d).get(l).push(c.columnid)}if(e.where){let c=new Lc(e.where),l=e.from[0].tableid;for(let{node:d}of c)if(d&&d.columnid){let u=d.tableid?d.tableid:l;if(!t.get(i).has(u))if(r.has(u))u=r.get(u);else{Qs.info(`table specified as ${u} not found.`);continue}t.get(i).get(u).indexOf(d.columnid)<0&&t.get(i).get(u).push(d.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Lc(c.on);for(let{node:d}of l)if(d&&d.columnid){let u=d.tableid,_=s.get(u);if(!t.get(_).has(u))if(r.has(u))u=r.get(u);else{Qs.info(`table specified as ${u} not found.`);continue}t.get(_).get(u).indexOf(d.columnid)<0&&t.get(_).get(u).push(d.columnid)}}),e.order){let c=new Lc(e.order);for(let{node:l}of c)if(l&&l.columnid){let d=l.tableid,u=n.has(d)?n.get(d):i;if(d||(d=e.from[0].tableid),!t.get(u).has(d))if(r.has(d))d=r.get(d);else{Qs.info(`table specified as ${d} not found.`);return}t.get(u).get(d).indexOf(l.columnid)<0&&t.get(u).get(d).push(l.columnid)}}}a(Uoe,"getSelectAttributes");function voe(e,t,r){if(!e){Qs.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Lc(e.columns),s=e.table.databaseid;Ef(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Yy(e.table.tableid,s,i.columnid,t,r)}a(voe,"getUpdateAttributes");function Boe(e,t,r){if(!e){Qs.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Lc(e.where),s=e.table.databaseid;Ef(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Yy(e.table.tableid,s,i.columnid,t,r)}a(Boe,"getDeleteAttributes");function Hoe(e,t,r){if(!e){Qs.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Lc(e.columns),s=e.into.databaseid;Ef(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&Yy(e.into.tableid,s,i.columnid,t,r)}a(Hoe,"getInsertAttributes");function Yy(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(Yy,"pushAttribute");vk.exports=Vy});var jy=b((TCe,Fk)=>{var Sp=sc(),Hk=require("chalk"),Fn=V(),xk=require("prompt"),{promisify:xoe}=require("util"),Ky=M(),koe=require("fs-extra"),Foe=require("path"),Goe=J(),qoe=Ic(),kk=te();kk.initSync();var $oe=require("moment"),Voe=xoe(xk.get),Yoe=Foe.join(kk.getHdbBasePath(),Ky.LICENSE_KEY_DIR_NAME,Ky.LICENSE_FILE_NAME,Ky.LICENSE_FILE_NAME);Fk.exports={getFingerprint:Woe,setLicense:Koe,parseLicense:Wy,register:joe,getRegistrationInfo:zoe};async function Koe(e){if(e&&e.key&&e.company){try{Fn.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Wy(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Fn.error(r),Fn.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(Koe,"setLicense");async function Woe(){let e={};try{e=await Sp.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Fn.error(r),Fn.error(t),new Error(r)}return e}a(Woe,"getFingerprint");async function Wy(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Fn.info("Validating license input...");let r=Sp.validateLicense(e,t);if(Fn.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Fn.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Fn.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Fn.info("writing license to disk"),await koe.writeFile(Yoe,JSON.stringify({license_key:e,company:t}))}catch(n){throw Fn.error("Failed to write License"),n}return"Registration successful."}a(Wy,"parseLicense");async function joe(){let e=await Qoe();return Wy(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(joe,"register");async function Qoe(){let e=await Sp.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Hk.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Hk.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{xk.start()}catch(n){Fn.error(n)}let r;try{r=await Voe(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(Qoe,"promptForRegistration");async function zoe(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Sp.getLicense()}catch(r){throw Fn.error(`There was an error when searching licenses due to: ${r.message}`),r}if(Goe.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=qoe.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=$oe.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(zoe,"getRegistrationInfo")});var qk=b((RCe,Gk)=>{"use strict";var Joe=dt(),Qy=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,d,u,_,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+Joe.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:d,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:_,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};Gk.exports=Qy});var Yk=b((bCe,Vk)=>{"use strict";var $k=dt(),zy=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,d,u,_){this.port=t,_===null&&(_=void 0),this.server_name=r+$k.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+$k.SERVER_SUFFIX.LEAF},this.tls={cert_file:d,key_file:u,ca_file:_,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:_,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:_,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};Vk.exports=zy});var Wk=b((OCe,Kk)=>{"use strict";var Jy=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};Kk.exports=Jy});var Qk=b((ICe,jk)=>{"use strict";var Xoe=dt(),Xy=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+Xoe.SERVER_SUFFIX.ADMIN,this.password=r}};jk.exports=Xy});var Ap=b((CCe,Xk)=>{"use strict";var Mc=require("path"),Uc=require("fs-extra"),Zoe=qk(),eae=Yk(),tae=Wk(),rae=Qk(),Zy=vn(),Nu=J(),mn=wt(),gp=M(),hf=dt(),{CONFIG_PARAMS:Jt}=gp,Iu=V(),mf=te(),zk=zi(),eO=kt(),nae=js(),Ou="clustering",sae=1e4,Jk=50;Xk.exports={generateNatsConfig:oae,removeNatsConfig:aae,getHubConfigPath:iae};function iae(){let e=mf.get(Jt.ROOTPATH);return Mc.join(e,Ou,hf.NATS_CONFIG_FILES.HUB_SERVER)}a(iae,"getHubConfigPath");async function oae(e=!1,t=void 0){let r=mf.get(Jt.ROOTPATH);Uc.ensureDirSync(Mc.join(r,"clustering","leaf")),mf.initSync();let n=mn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),s=mn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),i=mn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await Uc.exists(i)&&!await Uc.exists(!n)&&await nae.createNatsCerts();let o=Mc.join(r,Ou,hf.PID_FILES.HUB),c=Mc.join(r,Ou,hf.PID_FILES.LEAF),l=mn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),d=Mc.join(r,Ou,hf.NATS_CONFIG_FILES.HUB_SERVER),u=Mc.join(r,Ou,hf.NATS_CONFIG_FILES.LEAF_SERVER),_=mn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),E=mn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),f=mn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await eO.checkNATSServerInstalled()||Rp("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let T=await Zy.listUsers(),S=mn.getConfigFromFile(Jt.CLUSTERING_USER),R=await Zy.getClusterUser();(Nu.isEmpty(R)||R.active!==!0)&&Rp(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Tp(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Tp(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Tp(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Tp(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let p=[],y=[];for(let[_e,X]of T.entries())X.role?.role===gp.ROLE_TYPES_ENUM.CLUSTER_USER&&X.active&&(p.push(new rae(X.username,zk.decrypt(X.hash))),y.push(new tae(X.username,zk.decrypt(X.hash))));let O=[],{hub_routes:B}=mn.getClusteringRoutes();if(!Nu.isEmptyOrZeroLength(B))for(let _e of B)O.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${_e.host}:${_e.port}`);let x=new Zoe(mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,o,i,s,n,_,E,h,mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),O,p,y);n==null&&(delete x.tls.ca_file,delete x.leafnodes.tls.ca_file),t=Nu.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===gp.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Uc.writeJson(d,x),Iu.trace(`Hub server config written to ${d}`));let W=`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,q=`tls://${R.uri_encoded_name}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,z=new eae(mn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,c,l,[W],[q],p,y,i,s,n,_);n==null&&delete z.tls.ca_file,(t===void 0||t===gp.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Uc.writeJson(u,z),Iu.trace(`Leaf server config written to ${u}`))}a(oae,"generateNatsConfig");async function Tp(e){let t=mf.get(e);return Nu.isEmpty(t)&&Rp(`port undefined for '${e}'`),await Nu.isPortTaken(t)&&Rp(`'${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(Tp,"isPortAvailable");function Rp(e){let t=`Error generating clustering config: ${e}`;Iu.error(t),console.error(t),process.exit(1)}a(Rp,"generateNatsConfigError");async function aae(e){let{port:t,config_file:r}=eO.getServerConfig(e),{username:n,decrypt_hash:s}=await Zy.getClusterUser(),i=0,o=2e3;for(;i<Jk;){try{let u=await eO.createConnection(t,n,s,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){Iu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=Jk)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 d=o*(i*2);d>3e4&&Iu.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Nu.async_set_timeout(d)}let c="0".repeat(sae),l=Mc.join(mf.get(Jt.ROOTPATH),Ou,r);await Uc.writeFile(l,c),await Uc.remove(l),Iu.notify(e,"started.")}a(aae,"removeNatsConfig")});var sF=b((PCe,nF)=>{"use strict";var Gn=te(),cae=sc(),ke=M(),pf=dt(),ao=require("path"),{PACKAGE_ROOT:yp}=M(),Zk=te(),bp=J(),wu="/dev/null",lae=ao.join(yp,"launchServiceScripts"),eF=ao.join(yp,"utility/scripts"),uae=ao.join(eF,ke.HDB_RESTART_SCRIPT),tF=ao.resolve(yp,"dependencies",`${process.platform}-${process.arch}`,pf.NATS_BINARY_NAME);function rF(){let t=cae.licenseSearch().ram_allocation||ke.RAM_ALLOCATION_ENUM.DEFAULT,r=ke.MEM_SETTING_KEY+t,n={[ke.PROCESS_NAME_ENV_PROP]:ke.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return bp.noBootFile()&&(n[ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=bp.getEnvCliRootPath()),{name:ke.PROCESS_DESCRIPTORS.HDB,script:ke.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:yp}}a(rF,"generateMainServerConfig");var dae=9930;function _ae(){Gn.initSync(!0);let e=Gn.get(ke.CONFIG_PARAMS.ROOTPATH),t=ao.join(e,"clustering",pf.NATS_CONFIG_FILES.HUB_SERVER),r=ao.join(Gn.get(ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),ke.LOG_NAMES.HDB),n=Zk.get(ke.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=pf.LOG_LEVEL_FLAGS[Gn.get(ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:ke.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==dae?"-"+n:""),script:tF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[ke.PROCESS_NAME_ENV_PROP]:ke.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Gn.get(ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wu,i.error_file=wu),i}a(_ae,"generateNatsHubServerConfig");var fae=9940;function Eae(){Gn.initSync(!0);let e=Gn.get(ke.CONFIG_PARAMS.ROOTPATH),t=ao.join(e,"clustering",pf.NATS_CONFIG_FILES.LEAF_SERVER),r=ao.join(Gn.get(ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),ke.LOG_NAMES.HDB),n=Zk.get(ke.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=pf.LOG_LEVEL_FLAGS[Gn.get(ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:ke.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==fae?"-"+n:""),script:tF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[ke.PROCESS_NAME_ENV_PROP]:ke.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Gn.get(ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wu,i.error_file=wu),i}a(Eae,"generateNatsLeafServerConfig");function hae(){Gn.initSync();let e=ao.join(Gn.get(ke.CONFIG_PARAMS.LOGGING_ROOT),ke.LOG_NAMES.HDB),t={name:ke.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:ke.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[ke.PROCESS_NAME_ENV_PROP]:ke.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:lae,autorestart:!1};return Gn.get(ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=wu,t.error_file=wu),t}a(hae,"generateClusteringUpgradeV4ServiceConfig");function mae(){let e={[ke.PROCESS_NAME_ENV_PROP]:ke.PROCESS_DESCRIPTORS.RESTART_HDB};return bp.noBootFile()&&(e[ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=bp.getEnvCliRootPath()),{...{name:ke.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:eF},script:uae}}a(mae,"generateRestart");function pae(){return{apps:[rF()]}}a(pae,"generateAllServiceConfigs");nF.exports={generateAllServiceConfigs:pae,generateMainServerConfig:rF,generateRestart:mae,generateNatsHubServerConfig:_ae,generateNatsLeafServerConfig:Eae,generateClusteringUpgradeV4ServiceConfig:hae}});var Tf=b((UCe,pF)=>{"use strict";var ot=M(),Sae=J(),lo=Ap(),Op=kt(),co=dt(),Ea=sF(),Np=te(),vc=V(),Tae=hs(),{startWorker:iF,onMessageFromWorkers:gae}=it(),Rae=gu(),MCe=require("util"),Aae=require("child_process"),bae=require("fs"),{execFile:yae}=Aae,ze;pF.exports={enterPM2Mode:Oae,start:ha,stop:tO,reload:aF,restart:cF,list:rO,describe:uF,connect:uo,kill:Dae,startAllServices:Pae,startService:nO,getUniqueServicesList:dF,restartAllServices:Lae,isServiceRegistered:_F,reloadStopStart:fF,restartHdb:lF,deleteProcess:wae,startClusteringProcesses:hF,startClusteringThreads:mF,isHdbRestartRunning:Cae,isClusteringRunning:Uae,stopClustering:Mae,reloadClustering:vae};var Sf=!1;gae(e=>{e.type==="restart"&&Np.initSync(!0)});function Oae(){Sf=!0}a(Oae,"enterPM2Mode");function uo(){return ze||(ze=require("pm2")),new Promise((e,t)=>{ze.connect((r,n)=>{r&&t(r),e(n)})})}a(uo,"connect");var pn,Nae=10,oF;function ha(e,t=!1){if(Sf)return Iae(e);let r=yae(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=pn.indexOf(r);o>-1&&pn.splice(o,1),!oF&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Nae&&(bae.existsSync(lo.getHubConfigPath())?ha(e):(await lo.generateNatsConfig(!0),ha(e),await new Promise(c=>setTimeout(c,3e3)),await lo.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await lo.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Np.get(ot.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,d=0,u;for(;l=c.exec(i);){if(l.index&&co.LOG_LEVEL_HIERARCHY[o]>=co.LOG_LEVEL_HIERARCHY[u||"info"]){let f=u===co.LOG_LEVELS.ERR||u===co.LOG_LEVELS.WRN?vc.OUTPUTS.STDERR:vc.OUTPUTS.STDOUT;vc.logCustomLevel(u||"info",f,n,i.slice(d,l.index).trim())}let[_,E]=l;d=l.index+_.length,u=co.LOG_LEVELS[E]}if(co.LOG_LEVEL_HIERARCHY[o]>=co.LOG_LEVEL_HIERARCHY[u||"info"]){let _=u===co.LOG_LEVELS.ERR||u===co.LOG_LEVELS.WRN?vc.OUTPUTS.STDERR:vc.OUTPUTS.STDOUT;vc.logCustomLevel(u||"info",_,n,i.slice(d).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),pn=[],!pn&&!t){let i=a(()=>{oF=!0,pn&&(pn.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)}pn.push(r)}a(ha,"start");function Iae(e){return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.start(e,(n,s)=>{n&&(ze.disconnect(),r(n)),ze.disconnect(),t(s)})})}a(Iae,"startWithPM2");function tO(e){if(!Sf){for(let t of pn||[])t.name===e&&(pn.splice(pn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.stop(e,async(n,s)=>{n&&(ze.disconnect(),r(n)),ze.delete(e,(i,o)=>{i&&(ze.disconnect(),r(n)),ze.disconnect(),t(o)})})})}a(tO,"stop");function aF(e){return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.reload(e,(n,s)=>{n&&(ze.disconnect(),r(n)),ze.disconnect(),t(s)})})}a(aF,"reload");function cF(e){if(!Sf)for(let t of pn||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.restart(e,(n,s)=>{ze.disconnect(),t(s)})})}a(cF,"restart");function wae(e){return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.delete(e,(n,s)=>{n&&(ze.disconnect(),r(n)),ze.disconnect(),t(s)})})}a(wae,"deleteProcess");async function lF(){await ha(Ea.generateRestart())}a(lF,"restartHdb");async function Cae(){let e=await rO();for(let t in e)if(e[t].name===ot.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Cae,"isHdbRestartRunning");function rO(){return new Promise(async(e,t)=>{try{await uo()}catch(r){t(r)}ze.list((r,n)=>{r&&(ze.disconnect(),t(r)),ze.disconnect(),e(n)})})}a(rO,"list");function uF(e){return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.describe(e,(n,s)=>{n&&(ze.disconnect(),r(n)),ze.disconnect(),t(s)})})}a(uF,"describe");function Dae(){if(!Sf){for(let e of pn||[])e.kill();pn=[];return}return new Promise(async(e,t)=>{try{await uo()}catch(r){t(r)}ze.killDaemon((r,n)=>{r&&(ze.disconnect(),t(r)),ze.disconnect(),e(n)})})}a(Dae,"kill");async function Pae(){try{await hF(),await mF(),await ha(Ea.generateAllServiceConfigs())}catch(e){throw ze?.disconnect(),e}}a(Pae,"startAllServices");async function nO(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case ot.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ea.generateMainServerConfig();break;case ot.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ea.generateNatsIngestServiceConfig();break;case ot.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ea.generateNatsReplyServiceConfig();break;case ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ea.generateNatsHubServerConfig(),await ha(r,t),await lo.removeNatsConfig(e);return;case ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ea.generateNatsLeafServerConfig(),await ha(r,t),await lo.removeNatsConfig(e);return;case ot.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ea.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await ha(r)}catch(r){throw ze?.disconnect(),r}}a(nO,"startService");async function dF(){try{let e=await rO(),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 ze?.disconnect(),e}}a(dF,"getUniqueServicesList");async function Lae(e=[]){try{let t=!1,r=await dF();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===ot.PROCESS_DESCRIPTORS.HDB?t=!0:await cF(o))}t&&await fF(ot.PROCESS_DESCRIPTORS.HDB)}catch(t){throw ze?.disconnect(),t}}a(Lae,"restartAllServices");async function _F(e){if(pn?.find(r=>r.name===e))return!0;let t=await Rae.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(_F,"isServiceRegistered");async function fF(e){let t=Np.get(ot.CONFIG_PARAMS.THREADS_COUNT)??Np.get(ot.CONFIG_PARAMS.THREADS),r=await uF(e),n=Sae.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await tO(e),await nO(e)):e===ot.PROCESS_DESCRIPTORS.HDB?await lF():await aF(e)}a(fF,"reloadStopStart");var EF;async function hF(e=!1){for(let t in ot.CLUSTERING_PROCESSES){let r=ot.CLUSTERING_PROCESSES[t];await nO(r,e)}}a(hF,"startClusteringProcesses");async function mF(){EF=iF(ot.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:ot.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await Op.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await Op.updateLocalStreams();let e=await Tae.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===ot.PRE_4_0_0_VERSION){vc.info("Starting clustering upgrade 4.0.0 process"),iF(ot.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(mF,"startClusteringThreads");async function Mae(){for(let e in ot.CLUSTERING_PROCESSES)if(e!==ot.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===ot.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await EF.terminate();else{let t=ot.CLUSTERING_PROCESSES[e];await tO(t)}}a(Mae,"stopClustering");async function Uae(){for(let e in ot.CLUSTERING_PROCESSES){let t=ot.CLUSTERING_PROCESSES[e];if(await _F(t)===!1)return!1}return!0}a(Uae,"isClusteringRunning");async function vae(){await lo.generateNatsConfig(!0),await Op.reloadNATSHub(),await Op.reloadNATSLeaf(),await lo.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await lo.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(vae,"reloadClustering")});var oO={};et(oO,{compactOnStart:()=>Bae,copyDb:()=>bF});async function Bae(){gf.notify("Running compact on start"),console.log("Running compact on start");let e=(0,sO.get)(ma.CONFIG_PARAMS.ROOTPATH),t=new Map,r=mt();try{for(let n in r){if(n==="system")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,Ip.join)(e,"backup",n+".mdb"),o=(0,Ip.join)(e,ma.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await SF(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await bF(n,o),console.log("Backing up",n,"to",i),await(0,Bc.move)(s,i,{overwrite:!0})}Cu();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,Bc.move)(i,s,{overwrite:!0}),await(0,Bc.remove)((0,Ip.join)(e,ma.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));Cu()}catch(n){gf.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,iO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,Bc.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Cu(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await SF(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}.
|
|
14
16
|
Total record count before compaction: ${i}, total after: ${c}.
|
|
15
|
-
Database backup has not been removed and can be found here: ${s}`;
|
|
16
|
-
${r.stack}`;throw lb.error(n),GB(new Error)}}}a(Une,"getRolePermissions");function vne(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[sn.SYSTEM_SCHEMA_NAME]=n[sn.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]=xne(t[i]);return}r[i]=YB(),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],d=Bne(c,l);r[i].describe||WB.forEach(u=>{d[u]&&(r[i].describe=!0)}),r[i].tables[o]=d}else r[i].tables[o]=ub()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=ub()})}),r}a(vne,"translateRolePermissions");function xne(e){let t=YB(!0);return Object.keys(e).forEach(r=>{t.tables[r]=ub(!0,!0,!0,!0,!0)}),t}a(xne,"createStructureUserPermissions");function Bne(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s=Object.assign({},e);s.attribute_permissions=[];let i=r.reduce((d,u)=>{let{attribute_name:_}=u,E=u;return sn.TIME_STAMP_NAMES.includes(_)&&(E=VB(_,u[Xd])),d[_]=E,d},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=qB(o);return t.attributes.forEach(({attribute:d})=>{if(i[d]){let u=i[d];u.describe=zB(u),s.attribute_permissions.push(u),c||Hne(u,l)}else if(d!==o){let u;sn.TIME_STAMP_NAMES.includes(d)?u=VB(d):u=qB(d),s.attribute_permissions.push(u)}}),c||s.attribute_permissions.push(l),s.describe=$B(s),s}else return e.describe=$B(e),e}a(Bne,"getTableAttrPerms");function $B(e){return WB.filter(t=>e[t]).length>0}a($B,"getSchemaTableDescribePerm");function zB(e){return QB.filter(t=>e[t]).length>0}a(zB,"getAttributeDescribePerm");function Hne(e,t){QB.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(Hne,"checkForHashPerms")});var XB={};Ze(XB,{Headers:()=>Ui,appendHeader:()=>fb,mergeHeaders:()=>Eb});function fb(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 Eb(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new Ui(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 Ui,Zd=Oe(()=>{Ui=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(fb,"appendHeader");a(Eb,"mergeHeaders")});var e_={};Ze(e_,{authentication:()=>iH,bypassAuth:()=>Yne,login:()=>Wne,logout:()=>Qne,start:()=>Kne});function Yne(){sH=!0}async function iH(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?qne?Gne:[]:Fne?kne:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new Ui([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return jh&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),jh&&o.push("Access-Control-Allow-Credentials","true")}}let l,d;if(jh){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let p of h)if(p.startsWith(f)){let S=p.indexOf(";");l=p.slice(f.length,S===-1?p.length:S),d=await ZB.get(l);break}e.session=d||(d={})}let u=a((f,h,p)=>{let S=new El.AuthAuditLog(f,h,Er.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);S.auth_strategy=p,l&&(S.session_id=l),r.referer&&(S.referer=r.referer),r.origin&&(S.origin=r.origin),h===Er.AUTH_AUDIT_STATUS.SUCCESS?hb.notify(S):hb.error(S)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&hb.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await it.getUser(f,null,null),u(f,Er.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,El.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=Ua.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),p=n.slice(f+1),S,g;try{switch(h){case"Basic":let T=atob(p),A=T.indexOf(":");S=T.slice(0,A),g=T.slice(A+1),_=S||g?await it.getUser(S,g,e):null;break;case"Bearer":try{_=await(0,Jh.validateOperationToken)(p)}catch(I){if(I.message==="invalid token")try{return await(0,Jh.validateRefreshToken)(p),c({status:-1})}catch{throw I}}break}}catch(T){return $ne&&(Ua.get(p)||(Ua.set(p,p),u(S,Er.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:va({error:T.message},e)})}Ua.set(n,_),Vne&&u(_.username,Er.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=_}else d?.user?e.user=await it.getUser(d.user,null,e):(sH&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,tH.getSuperUser)());jh&&(e.session.update=function(f){if(!l){l=(0,rH.v4)();let p=`${(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",p):E?.headers?.set&&E.headers.set("Set-Cookie",p)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,ZB.put(f)},e.login=async function(f,h){e.user=await it.getUser(f,h,e),e.session.update({user:e.user.username})},(_&&!d||d?.user?.username!==_?.username)&&r["user-agent"]?.startsWith("Mozilla")&&e.session.update({user:e.user.username}));let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&To.loginPath?(E.status=302,E.headers.set("Location",To.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let d=o.length;if(d>0){let u=l.headers;u||(l.headers=u=new Ui);for(let _=0;_<d;){let E=o[_++];u.set(E,o[_++])}}return o=null,l}a(c,"applyResponseHeaders")}function Kne({server:e,port:t}){e.http(iH,{port:t||"all"}),eH||(eH=!0,setInterval(()=>{Ua=new Map},Xn.get(Er.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),nH.user.addListener(()=>{Ua=new Map}))}async function Wne(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 Qne(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var tH,Jh,rH,Xn,Er,El,nH,hb,kne,Fne,Gne,qne,ZB,jh,sH,Vne,$ne,Ua,eH,Xh=Oe(()=>{tH=v($n());Lr();Sd();Jh=v(Ed());Ne();rH=require("uuid"),Xn=v(ne()),Er=v(M()),El=v(j()),nH=v(vu());Zd();hl();hb=(0,El.loggerWithTag)("auth-event");Xn.initSync();kne=Xn.get(Er.CONFIG_PARAMS.HTTP_CORSACCESSLIST),Fne=Xn.get(Er.CONFIG_PARAMS.HTTP_CORS),Gne=Xn.get(Er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),qne=Xn.get(Er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),ZB=ft({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),jh=Xn.get(Er.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,sH=process.env.AUTHENTICATION_AUTHORIZELOCAL??Xn.get(Er.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,Vne=Xn.get(Er.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,$ne=Xn.get(Er.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Ua=new Map;it.onInvalidatedUser(()=>{Ua=new Map});a(Yne,"bypassAuth");a(iH,"authentication");a(Kne,"start");a(Wne,"login");a(Qne,"logout")});var _H=N((BAe,dH)=>{"use strict";var ge=require("joi"),oH=require("fs-extra"),aH=require("path"),Ln=ct(),cH=ne(),lH=M(),uH=j(),{hdb_errors:zne}=ce(),{HDB_ERROR_MSGS:Ar}=zne,vi=/^[a-zA-Z0-9-_]+$/,jne=/^[a-zA-Z0-9-_]+$/;dH.exports={getDropCustomFunctionValidator:Xne,setCustomFunctionValidator:Zne,addComponentValidator:nse,dropCustomFunctionProjectValidator:sse,packageComponentValidator:ise,deployComponentValidator:ose,setComponentFileValidator:ese,getComponentFileValidator:rse,dropComponentFileValidator:tse,addSSHKeyValidator:ase,updateSSHKeyValidator:cse,deleteSSHKeyValidator:lse,setSSHKnownHostsValidator:use};function Zh(e,t,r){try{let n=cH.get(lH.CONFIG_PARAMS.COMPONENTSROOT),s=aH.join(n,t);return oH.existsSync(s)?e?t:r.message(Ar.PROJECT_EXISTS):e?r.message(Ar.NO_PROJECT):t}catch(n){return uH.error(n),r.message(Ar.VALIDATION_ERR)}}a(Zh,"checkProjectExists");function t_(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(t_,"checkFilePath");function Jne(e,t,r,n){try{let s=cH.get(lH.CONFIG_PARAMS.COMPONENTSROOT),i=aH.join(s,e,t,r+".js");return oH.existsSync(i)?r:n.message(Ar.NO_FILE)}catch(s){return uH.error(s),n.message(Ar.VALIDATION_ERR)}}a(Jne,"checkFileExists");function Xne(e){let t=ge.object({project:ge.string().pattern(vi).custom(Zh.bind(null,!0)).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),type:ge.string().valid("helpers","routes").required(),file:ge.string().pattern(vi).custom(Jne.bind(null,e.project,e.type)).custom(t_).required().messages({"string.pattern.base":Ar.BAD_FILE_NAME})});return Ln.validateBySchema(e,t)}a(Xne,"getDropCustomFunctionValidator");function Zne(e){let t=ge.object({project:ge.string().pattern(vi).custom(Zh.bind(null,!0)).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),type:ge.string().valid("helpers","routes").required(),file:ge.string().custom(t_).required(),function_content:ge.string().required()});return Ln.validateBySchema(e,t)}a(Zne,"setCustomFunctionValidator");function ese(e){let t=ge.object({project:ge.string().pattern(vi).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),file:ge.string().custom(t_).required(),payload:ge.string().allow("").optional(),encoding:ge.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ln.validateBySchema(e,t)}a(ese,"setComponentFileValidator");function tse(e){let t=ge.object({project:ge.string().pattern(vi).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),file:ge.string().custom(t_).optional()});return Ln.validateBySchema(e,t)}a(tse,"dropComponentFileValidator");function rse(e){let t=ge.object({project:ge.string().required(),file:ge.string().custom(t_).required(),encoding:ge.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ln.validateBySchema(e,t)}a(rse,"getComponentFileValidator");function nse(e){let t=ge.object({project:ge.string().pattern(vi).custom(Zh.bind(null,!1)).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME})});return Ln.validateBySchema(e,t)}a(nse,"addComponentValidator");function sse(e){let t=ge.object({project:ge.string().pattern(vi).custom(Zh.bind(null,!0)).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME})});return Ln.validateBySchema(e,t)}a(sse,"dropCustomFunctionProjectValidator");function ise(e){let t=ge.object({project:ge.string().pattern(vi).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),skip_node_modules:ge.boolean()});return Ln.validateBySchema(e,t)}a(ise,"packageComponentValidator");function ose(e){let t=ge.object({project:ge.string().pattern(vi).required().messages({"string.pattern.base":Ar.BAD_PROJECT_NAME}),payload:ge.string().optional().messages({"string.pattern.base":Ar.BAD_PACKAGE}),package:ge.string().optional(),restart:ge.boolean().optional()});return Ln.validateBySchema(e,t)}a(ose,"deployComponentValidator");function ase(e){let t=ge.object({name:ge.string().pattern(jne).required().messages({"string.pattern.base":Ar.BAD_SSH_KEY_NAME}),key:ge.string().required(),host:ge.string().required(),hostname:ge.string().required(),known_hosts:ge.string().optional()});return Ln.validateBySchema(e,t)}a(ase,"addSSHKeyValidator");function cse(e){let t=ge.object({name:ge.string().required(),key:ge.string().required()});return Ln.validateBySchema(e,t)}a(cse,"updateSSHKeyValidator");function lse(e){let t=ge.object({name:ge.string().required()});return Ln.validateBySchema(e,t)}a(lse,"deleteSSHKeyValidator");function use(e){let t=ge.object({known_hosts:ge.string().required()});return Ln.validateBySchema(e,t)}a(use,"setSSHKnownHostsValidator")});var sm=N((kAe,SH)=>{"use strict";var em=require("joi"),xa=require("path"),rm=require("fs-extra"),{exec:dse}=require("child_process"),_se=require("util"),fH=_se.promisify(dse),Sl=M(),{handleHDBError:ml,hdb_errors:fse}=ce(),{HTTP_STATUS_CODES:pl}=fse,gl=ne(),Ese=ct(),Tl=j();gl.initSync();var mb=gl.get(Sl.CONFIG_PARAMS.COMPONENTSROOT),EH="npm install --omit=dev --json",hse=`${EH} --dry-run`,mse=gl.get(Sl.CONFIG_PARAMS.ROOTPATH),tm=xa.join(mse,"ssh");SH.exports={installModules:gse,auditModules:Rse,installAllRootModules:pse,uninstallRootModule:Sse,linkHarperdb:Tse};async function pse(e=!1){await nm();let t=!1,r=process.env;rm.pathExistsSync(tm)&&rm.readdirSync(tm).forEach(n=>{n.includes(".key")&&!t&&(r=Object.assign({GIT_SSH_COMMAND:"ssh -F "+xa.join(tm,"config")+" -o UserKnownHostsFile="+xa.join(tm,"known_hosts")},process.env),t=!0)}),await r_(e?"npm install --ignore-scripts":"npm install",gl.get(Sl.CONFIG_PARAMS.ROOTPATH),r)}a(pse,"installAllRootModules");async function Sse(e){await r_(`npm uninstall ${e}`,gl.get(Sl.CONFIG_PARAMS.ROOTPATH))}a(Sse,"uninstallRootModule");async function Tse(){await nm(),await r_(`npm link ${Sl.PACKAGE_ROOT}`,gl.get(Sl.CONFIG_PARAMS.ROOTPATH))}a(Tse,"linkHarperdb");async function r_(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await fH(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
|
|
17
|
-
`,""))}return s&&!s.includes("Debugger listening")&&
|
|
18
|
-
`,"")}a(
|
|
19
|
-
`,""):null,
|
|
20
|
-
`,""):null}catch(
|
|
21
|
-
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(hH,"parseNPMStdErr");async function Rse(e){Tl.info(`starting auditModules for request: ${e}`);let t=pH(e);if(t)throw ml(t,t.message,pl.BAD_REQUEST);let{projects:r}=e;await nm(),await mH(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=xa.join(mb,o);n[o]={npm_output:null,npm_error:null};try{let l=await r_("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=hH(l.stderr)}}return Tl.info(`finished auditModules with response ${n}`),n}a(Rse,"auditModules");async function nm(){try{return await r_("npm -v"),!0}catch{throw ml(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",pl.BAD_REQUEST,void 0,void 0,!0)}}a(nm,"checkNPMInstalled");async function mH(e){if(!Array.isArray(e)||e.length===0)throw ml(new Error,"projects argument must be an array with at least 1 element",pl.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=xa.join(mb,i.toString());if(!await rm.pathExists(o)){t.push(i);continue}let l=xa.join(o,"package.json");await rm.pathExists(l)||r.push(i)}if(t.length>0)throw ml(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,pl.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw ml(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,pl.BAD_REQUEST,void 0,void 0,!0)}a(mH,"checkProjectPaths");function pH(e){let t=em.object({projects:em.array().min(1).items(em.string()).required(),dry_run:em.boolean().default(!1)});return Ese.validateBySchema(e,t)}a(pH,"modulesValidator")});var Sb=N((GAe,bH)=>{"use strict";var Rl=require("fs-extra"),pb=require("path"),im=j(),TH=te(),om=M(),AH=ne(),Ase=dr();bH.exports=bse;async function bse(){let e=yse(),t=AH.get(om.CONFIG_PARAMS.ROOTPATH),r=pb.join(t,"package.json"),n={dependencies:{harperdb:"file:"+om.PACKAGE_ROOT}},s=pb.join(t,"node_modules");Rl.ensureDirSync(s);let i,o=!0,c=!1;try{i=Rl.readJsonSync(r)}catch(l){if(TH.isEmptyOrZeroLength(e))return;if(l.code!==om.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!TH.isEmptyOrZeroLength(e)){for(let{name:l,package:d}of e){let u=gH(d);n.dependencies[l]=u+d}if(!o){im.notify("Installing components"),await RH(r,n,null);return}for(let{name:l,package:d}of e){let u=i.dependencies[l],_=gH(d);if(u===void 0||u!==_+d){c=!0;break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(im.notify("Removing component",l),c=!0);c&&(im.notify("Updating components."),await RH(r,n,i))}a(bse,"installComponents");function yse(){let e=Ase.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(yse,"getComponentsConfig");function gH(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":pb.extname(e)||Rl.existsSync(e)?"file:":"github:"}a(gH,"getPkgPrefix");async function RH(e,t,r){im.trace("npm installing components package.json",t),Rl.writeFileSync(e,JSON.stringify(t,null," "));try{await sm().installAllRootModules(AH.get(om.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Rl.writeFileSync(e,JSON.stringify(r,null," ")):Rl.unlinkSync(e),n}}a(RH,"installPackages")});var Rb=N(IH=>{"use strict";var Se=require("fs-extra"),Tb=require("fast-glob"),Re=require("path"),OH=require("tar-fs"),Ose=require("gunzip-maybe"),VAe=require("uuid").v4,gb=require("normalize-path"),on=_H(),Ut=j(),dt=M(),Yt=ne(),n_=dr(),Nse=te(),{PACKAGE_ROOT:Ise}=M(),{handleHDBError:vt,hdb_errors:wse}=ce(),{basename:Cse}=require("path"),Dse=Sb(),NH=ne(),Lse=M(),{Readable:Pse}=require("stream"),{isMainThread:Mse}=require("worker_threads"),{HDB_ERROR_MSGS:Ba,HTTP_STATUS_CODES:xt}=wse,Use=et(),vse=Re.join(Ise,"application-template"),yH=Re.join(Yt.get(dt.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp"),xse=Yt.get(dt.CONFIG_PARAMS.ROOTPATH),wo=Re.join(xse,"ssh"),xi=Re.join(wo,"known_hosts");function Bse(){Ut.trace("getting custom api status");let e={};try{e={port:Yt.get(dt.CONFIG_PARAMS.HTTP_PORT),directory:Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw vt(new Error,Ba.FUNCTION_STATUS,xt.INTERNAL_SERVER_ERROR,Ut.ERR,t)}return e}a(Bse,"customFunctionsStatus");function Hse(){Ut.trace("getting custom api endpoints");let e={},t=Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT);try{Tb.sync(gb(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:Tb.sync(gb(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:Tb.sync(gb(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw vt(new Error,Ba.GET_FUNCTIONS,xt.INTERNAL_SERVER_ERROR,Ut.ERR,r)}return e}a(Hse,"getCustomFunctions");function kse(e){e.project&&(e.project=Re.parse(e.project).name),e.file&&(e.file=Re.parse(e.file).name);let t=on.getDropCustomFunctionValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);Ut.trace("getting custom api endpoint file content");let r=Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=Re.join(r,n,s,i+".js");try{return Se.readFileSync(o,{encoding:"utf8"})}catch(c){throw vt(new Error,Ba.GET_FUNCTION,xt.INTERNAL_SERVER_ERROR,Ut.ERR,c)}}a(kse,"getCustomFunction");function Fse(e){e.project&&(e.project=Re.parse(e.project).name),e.file&&(e.file=Re.parse(e.file).name);let t=on.setCustomFunctionValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);Ut.trace("setting custom function file content");let r=Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{return Se.outputFileSync(Re.join(r,n,s,i+".js"),o),`Successfully updated custom function: ${i}.js`}catch(c){throw vt(new Error,Ba.SET_FUNCTION,xt.INTERNAL_SERVER_ERROR,Ut.ERR,c)}}a(Fse,"setCustomFunction");function Gse(e){e.project&&(e.project=Re.parse(e.project).name),e.file&&(e.file=Re.parse(e.file).name);let t=on.getDropCustomFunctionValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);Ut.trace("dropping custom function file");let r=Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{return Se.unlinkSync(Re.join(r,n,s,i+".js")),`Successfully deleted custom function: ${i}.js`}catch(o){throw vt(new Error,Ba.DROP_FUNCTION,xt.INTERNAL_SERVER_ERROR,Ut.ERR,o)}}a(Gse,"dropCustomFunction");function qse(e){e.project&&(e.project=Re.parse(e.project).name);let t=on.addComponentValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);Ut.trace("adding component");let r=Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=Re.join(r,n);return Se.mkdirSync(s,{recursive:!0}),Se.copySync(vse,s),`Successfully added project: ${n}`}catch(s){throw vt(new Error,Ba.ADD_FUNCTION,xt.INTERNAL_SERVER_ERROR,Ut.ERR,s)}}a(qse,"addComponent");function Vse(e){e.project&&(e.project=Re.parse(e.project).name);let t=on.dropCustomFunctionProjectValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);Ut.trace("dropping custom function project");let r=Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Yt.get(dt.CONFIG_PARAMS.APPS);if(!Nse.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 n_.updateConfigValue(dt.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=Re.join(r,n);return Se.rmSync(i,{recursive:!0}),`Successfully deleted project: ${n}`}catch(i){throw vt(new Error,Ba.DROP_FUNCTION_PROJECT,xt.INTERNAL_SERVER_ERROR,Ut.ERR,i)}}a(Vse,"dropCustomFunctionProject");async function $se(e){e.project&&(e.project=Re.parse(e.project).name);let t=on.packageComponentValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);let r=Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ut.trace("packaging component",n);let s;try{s=await Se.realpath(Re.join(r,n))}catch(l){if(l.code!==dt.NODE_ERROR_CODES.ENOENT)throw l;try{s=await Se.realpath(Re.join(Yt.get(dt.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(d){if(d.code===dt.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}await Se.ensureDir(yH);let i=Re.join(yH,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:l=>l.includes(Re.join(s,"node_modules"))}),OH.pack(s,o).pipe(Se.createWriteStream(i,{overwrite:!0})),await new Promise(l=>setTimeout(l,2e3));let c=Se.readFileSync(i,{encoding:"base64"});return await Se.remove(i),{project:n,payload:c}}a($se,"packageComponent");async function Yse(e){e.project&&(e.project=Re.parse(e.project).name);let t=on.deployComponentValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);let r=Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i}=e;if(Ut.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let o;if(s){o=Re.join(r,n),i="file:"+o,await Se.emptyDir(o);let E=Pse.from(Buffer.from(s,"base64"));await new Promise((h,p)=>{E.pipe(Ose()).pipe(OH.extract(o,{finish:h})).on("error",p)});let f=await Se.readdir(o);f.length===1&&f[0]==="package"&&(await Se.copy(Re.join(o,"package"),o),await Se.remove(Re.join(o,"package")))}if(await n_.addConfig(n,{package:i}),!s){await Dse();let E=NH.get(Lse.CONFIG_PARAMS.ROOTPATH);o=Re.join(E,"node_modules",n)}if(Mse)return;let c=new Map;c.isWorker=!0;let l=(cm(),ae(am)),d;l.setErrorReporter(E=>d=E);let u=Cse(o),_=l.component_errors.get(u);try{await l.loadComponent(o,c)}finally{l.component_errors.set(u,_)}if(d)throw d;return Ut.info("Installed component"),e.restart===!0?(Use.restartWorkers("http"),`Successfully deployed: ${n}, restarting HarperDB`):`Successfully deployed: ${n}`}a(Yse,"deployComponent");async function Kse(){let e=n_.getConfiguration(),t=[];for(let o in e)if(e[o]?.package){if(e[o].package.startsWith("file:"))continue;t.push(Object.assign({},e[o],{name:o}))}let r=a(async(o,c)=>{try{let l=await Se.readdir(o,{withFileTypes:!0});for(let d of l){let u=d.name;if(u.startsWith(".")||u==="node_modules")continue;let _=Re.join(o,u);if(d.isDirectory()||d.isSymbolicLink()){let E={name:u,entries:[]};c.entries.push(E),await r(_,E)}else{let E=await Se.stat(_),f={name:Re.basename(u),mtime:E.mtime,size:E.size};c.entries.push(f)}}return c}catch(l){return Ut.warn("Error loading package",l),{error:l.toString(),entries:[]}}},"walk_dir"),n=await r(Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),{name:Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT).split(Re.sep).slice(-1).pop(),entries:t});for(let o of n.entries)if(o.package){let c=await r(Re.join(Yt.get(dt.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(cm(),ae(am)).component_errors;for(let o of t){let c=i.get(o.name);c?o.error=i.get(o.name):c===void 0&&(o.error="The component has not been loaded yet (may need a restart)")}return n}a(Kse,"getComponents");async function Wse(e){let t=on.getComponentFileValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);let n=n_.getConfigObj()[e.project]||e.project==="harperdb"?Re.join(NH.get(dt.CONFIG_PARAMS.ROOTPATH),"node_modules"):Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Se.stat(Re.join(n,e.project,e.file));return{message:await Se.readFile(Re.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===dt.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${Re.join(e.project,e.file)}'`):i}}a(Wse,"getComponentFile");async function Qse(e){let t=on.setComponentFileValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=Re.join(Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);return e.payload!==void 0?(await Se.ensureFile(n),await Se.outputFile(n,e.payload,r)):await Se.ensureDir(n),"Successfully set component: "+e.file}a(Qse,"setComponentFile");async function zse(e){let t=on.dropComponentFileValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);let r=e.file?Re.join(e.project,e.file):e.project,n=Re.join(Yt.get(dt.CONFIG_PARAMS.COMPONENTSROOT),r);return await Se.pathExists(n)&&await Se.remove(n),n_.deleteConfigFromFile([e.project]),"Successfully dropped: "+r}a(zse,"dropComponent");async function jse(e){let t=on.addSSHKeyValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Ut.trace("adding ssh key",r);let c=Re.join(wo,r+".key"),l=Re.join(wo,"config");if(await Se.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Se.outputFile(c,n),await Se.chmod(c,"0600");let d=`#${r}
|
|
17
|
+
Database backup has not been removed and can be found here: ${s}`;gf.error(l),console.error(l)}(0,sO.get)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Bc.remove)(s))}(0,iO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1)}async function SF(e){let t=await(0,AF.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function bF(e,t){console.log("copyDb start");let r=mt()[e],n;for(let _ in r){n=r[_].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,TF.open)(new gF.default(t)),c=o.openDB(wp.INTERNAL_DBIS_NAME),l,d=0,u=s.useReadTransaction();try{for(let{key:f,value:h}of s.getRange({transaction:u})){let T=h.is_hash_attribute||h.isPrimaryKey,S,R;if(T&&(S=h.compression,R=Cp(),R?h.compression=R:delete h.compression,S?.dictionary?.toString()===R?.dictionary?.toString()&&(S=null,R=null)),c.put(f,h),!(T||h.indexed))continue;let p=new RF.default(!T,T);p.encoding="binary",p.compression=S;let y=n.openDB(f,p);y.decoder=null,p.compression=R;let O=o.openDB(f,p);O.encoder=null,console.log("copying",f,"from",e,"to",t),await E(y,O,T,u)}let _=n.openDB(wp.AUDIT_STORE_NAME,Rf);console.log("copying audit log"),E(i,_,!1,u);async function E(f,h,T,S){let R=0,p=0;for(let{key:y,value:O,version:B}of f.getRange({start:null,versions:T,transaction:S}))l=h.put(y,O,B),R++,S.openTimer&&(S.openTimer=0),p+=(y?.length||10)+O.length,d++>5e3&&(await l,console.log("copied",R,"entries",p,"bytes"),d=0);console.log("finish copying, copied",R,"entries",p,"bytes")}a(E,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{u.done(),o.close()}}var TF,Ip,Bc,sO,gF,RF,wp,ma,AF,iO,gf,aO=De(()=>{Le();TF=require("lmdb"),Ip=require("path"),Bc=require("fs-extra"),sO=v(te()),gF=v(Qd()),RF=v(jd()),wp=v(Bt()),ma=v(M());Ki();AF=v(fi()),iO=v(wt()),gf=v(V());a(Bae,"compactOnStart");a(SF,"getTotalDBRecordCount");a(bF,"copyDb")});var Lu=b((qCe,DF)=>{"use strict";var Hae=require("minimist"),{isMainThread:lO,parentPort:bf,threadId:kCe}=require("worker_threads"),Pt=M(),{PROCESS_DESCRIPTORS_VALIDATE:Du}=Pt,Ni=V(),uO=J(),Pp=Ap(),Dp=kt(),FCe=dt(),IF=wt(),Ii=Tf(),yF=gu(),{compactOnStart:xae}=(aO(),oe(oO)),kae=qa(),{restartWorkers:Lp,onMessageByType:Fae}=it(),{handleHDBError:Gae,hdb_errors:qae}=fe(),{HTTP_STATUS_CODES:$ae}=qae,yf=te(),{sendOperationToNode:OF,getThisNodeName:Vae,monitorNodeCAs:Yae}=(ls(),oe(sa)),{getHDBNodeTable:GCe}=(nu(),oe(dB));yf.initSync();var Af=`Restarting HarperDB. This may take up to ${Pt.RESTART_TIMEOUT_MS/1e3} seconds.`,Kae="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",NF="Clustering is not enabled so cannot be restarted",Wae="Invalid service",Pu,Ts;DF.exports={restart:wF,restartService:dO};lO&&Fae(Pt.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await dO({service:e.workerType}):wF({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function wF(e){Ts=Object.keys(e).length===0,Pu=await Ii.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR);let t=Hae(process.argv);if(t.service){await dO(t);return}if(Ts&&!Pu){console.error(Kae);return}if(Ts&&console.log(Af),Pu){Ii.enterPM2Mode(),Ni.notify(Af);let r=kae(Object.keys(Pt.CONFIG_PARAM_MAP),!0);return uO.isEmptyOrZeroLength(Object.keys(r))||IF.updateConfigValue(void 0,void 0,r,!0,!0),jae(),Af}return lO?(Ni.notify(Af),yf.get(Pt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await xae(),setTimeout(()=>{Lp()},50)):bf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART}),Af}a(wF,"restart");async function dO(e){let{service:t}=e;if(Pt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw Gae(new Error,Wae,$ae.BAD_REQUEST,void 0,void 0,!0);if(Pu=await Ii.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR),!lO){e.replicated&&Yae(),bf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART,workerType:t}),bf.ref(),await new Promise(s=>{bf.on("message",i=>{i.type==="restart-complete"&&(s(),bf.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===Vae())continue;let{job_id:i}=await OF(s,e);n.push(await new Promise((o,c)=>{let d=2400,u=setInterval(async()=>{if(d--<=0){clearInterval(u);let f=new Error("Timed out waiting for restart job to complete");f.replicated=n,c(f)}let E=(await OF(s,{operation:"get_job",id:i})).results[0];if(E.status==="COMPLETE"&&(clearInterval(u),o({node:s.name,message:E.message})),E.status==="ERROR"){clearInterval(u);let f=new Error(E.message);f.replicated=n,c(f)}},250)}))}return{replicated:n}}return}let r;switch(t){case Du.clustering:if(!yf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=NF;break}Ts&&console.log("Restarting clustering"),Ni.notify("Restarting clustering"),await CF();break;case Du.clustering_config:case Du["clustering config"]:if(!yf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=NF;break}Ts&&console.log("Restarting clustering_config"),Ni.notify("Restarting clustering_config"),await Ii.reloadClustering();break;case"custom_functions":case"custom functions":case Du.harperdb:case Du.http_workers:case Du.http:if(Ts&&!Pu){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}Ts&&console.log("Restarting http_workers"),Ni.notify("Restarting http_workers"),Ts?await Ii.restart(Pt.HDB_PROC_DESCRIPTOR):await Lp("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Ni.error(r),Ts&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(dO,"restartService");async function jae(){await CF(),await Ii.restart(Pt.HDB_PROC_DESCRIPTOR),await uO.async_set_timeout(2e3),yf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await cO(),Ts&&(await Dp.closeConnection(),process.exit(0))}a(jae,"restartPM2Mode");async function CF(){if(!IF.getConfigFromFile(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await yF.getHDBProcessInfo()).clustering.length===0)Ni.trace("Clustering not running, restart will start clustering services"),await Pp.generateNatsConfig(!0),await Ii.startClusteringProcesses(),await Ii.startClusteringThreads(),await cO(),Ts&&await Dp.closeConnection();else{await Pp.generateNatsConfig(!0),Pu?(Ni.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await Ii.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Ii.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await yF.getHDBProcessInfo()).clustering.forEach(s=>{Ni.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await uO.async_set_timeout(3e3),await cO(),await Dp.updateLocalStreams(),Ts&&await Dp.closeConnection(),Ni.trace("Restart clustering restarting ingest and reply service threads");let t=Lp(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=Lp(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(CF,"restartClustering");async function cO(){await Pp.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Pp.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(cO,"removeNatsConfig")});var GF=b((YCe,FF)=>{"use strict";var VCe=require("lodash"),Sn=M(),{handleHDBError:PF,hdb_errors:Qae}=fe(),{HDB_ERROR_MSGS:zae,HTTP_STATUS_CODES:Jae}=Qae,_O=V();FF.exports={getRolePermissions:Zae};var Hc=Object.create(null),Xae=a(e=>({key:e,perms:{}}),"perms_template_obj"),vF=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),BF=a((e=!1,t=!1,r=!1,n=!1)=>({[Sn.PERMS_CRUD_ENUM.READ]:e,[Sn.PERMS_CRUD_ENUM.INSERT]:t,[Sn.PERMS_CRUD_ENUM.UPDATE]:r,[Sn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),fO=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...BF(t,r,n,s)}),"table_perms_template"),LF=a((e,t=BF())=>({attribute_name:e,describe:kF(t),[Of]:t[Of],[EO]:t[EO],[hO]:t[hO]}),"attr_perms_template"),MF=a((e,t=!1)=>({attribute_name:e,describe:t,[Of]:t}),"timestamp_attr_perms_template"),{READ:Of,INSERT:EO,UPDATE:hO}=Sn.PERMS_CRUD_ENUM,HF=Object.values(Sn.PERMS_CRUD_ENUM),xF=[Of,EO,hO];function Zae(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[Sn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Hc[t]&&Hc[t].key===n)return Hc[t].perms;let s=ece(e,r);return Hc[t]?Hc[t].key=n:Hc[t]=Xae(n),Hc[t].perms=s,s}catch(r){if(!e[Sn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Sn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Sn.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 _O.error(n),_O.debug(r),PF(new Error,zae.OUTDATED_PERMS_TRANSLATION_ERROR,Jae.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
18
|
+
${r.stack}`;throw _O.error(n),PF(new Error)}}}a(Zae,"getRolePermissions");function ece(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Sn.SYSTEM_SCHEMA_NAME]=n[Sn.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]=tce(t[i]);return}r[i]=vF(),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],d=rce(c,l);r[i].describe||HF.forEach(u=>{d[u]&&(r[i].describe=!0)}),r[i].tables[o]=d}else r[i].tables[o]=fO()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=fO()})}),r}a(ece,"translateRolePermissions");function tce(e){let t=vF(!0);return Object.keys(e).forEach(r=>{t.tables[r]=fO(!0,!0,!0,!0,!0)}),t}a(tce,"createStructureUserPermissions");function rce(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((d,u)=>{let{attribute_name:_}=u,E=u;return Sn.TIME_STAMP_NAMES.includes(_)&&(E=MF(_,u[Of])),d[_]=E,d},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=LF(o);return t.attributes.forEach(({attribute:d})=>{if(i[d]){let u=i[d];u.describe=kF(u),s.attribute_permissions.push(u),c||nce(u,l)}else if(d!==o){let u;Sn.TIME_STAMP_NAMES.includes(d)?u=MF(d):u=LF(d),s.attribute_permissions.push(u)}}),c||s.attribute_permissions.push(l),s.describe=UF(s),s}else return e.describe=UF(e),e}a(rce,"getTableAttrPerms");function UF(e){return HF.filter(t=>e[t]).length>0}a(UF,"getSchemaTableDescribePerm");function kF(e){return xF.filter(t=>e[t]).length>0}a(kF,"getAttributeDescribePerm");function nce(e,t){xF.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(nce,"checkForHashPerms")});var qF={};et(qF,{Headers:()=>_o,appendHeader:()=>mO,mergeHeaders:()=>pO});function mO(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 _o(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 _o,Nf=De(()=>{_o=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(mO,"appendHeader");a(pO,"mergeHeaders")});var If={};et(If,{authentication:()=>QF,bypassAuth:()=>uce,login:()=>_ce,logout:()=>fce,start:()=>dce});function uce(){jF=!0}async function QF(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?ace?oce:[]:ice?sce:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new _o([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Mp&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Mp&&o.push("Access-Control-Allow-Credentials","true")}}let l,d;if(Mp){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let T of h)if(T.startsWith(f)){let S=T.indexOf(";");l=T.slice(f.length,S===-1?T.length:S),d=await $F.get(l);break}e.session=d||(d={})}let u=a((f,h,T)=>{let S=new Mu.AuthAuditLog(f,h,Ar.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);S.auth_strategy=T,l&&(S.session_id=l),r.referer&&(S.referer=r.referer),r.origin&&(S.origin=r.origin),h===Ar.AUTH_AUDIT_STATUS.SUCCESS?SO.notify(S):SO.error(S)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&SO.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await st.getUser(f,null,null),u(f,Ar.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,Mu.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=xc.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),T=n.slice(f+1),S,R;try{switch(h){case"Basic":let p=atob(T),y=p.indexOf(":");S=p.slice(0,y),R=p.slice(y+1),_=S||R?await st.getUser(S,R,e):null;break;case"Bearer":try{_=await(0,Up.validateOperationToken)(T)}catch(O){if(O.message==="invalid token")try{return await(0,Up.validateRefreshToken)(T),c({status:-1})}catch{throw O}}break}}catch(p){return lce&&(xc.get(T)||(xc.set(T,T),u(S,Ar.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:kc({error:p.message},e)})}xc.set(n,_),cce&&u(_.username,Ar.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=_}else d?.user?e.user=await st.getUser(d.user,null,e):(jF&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,YF.getSuperUser)());Mp&&(e.session.update=function(f){if(!l){l=(0,KF.v4)();let T=`${(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",T):E?.headers?.set&&E.headers.set("Set-Cookie",T)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,$F.put(f)},e.login=async function(f,h){e.user=await st.getUser(f,h,e),e.session.update({user:e.user.username})});let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&ea.loginPath?(E.status=302,E.headers.set("Location",ea.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let d=o.length;if(d>0){let u=l.headers;u||(l.headers=u=new _o);for(let _=0;_<d;){let E=o[_++];u.set(E,o[_++])}}return o=null,l}a(c,"applyResponseHeaders")}function dce({server:e,port:t}){e.http(QF,{port:t||"all"}),VF||(VF=!0,setInterval(()=>{xc=new Map},gs.get(Ar.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),WF.user.addListener(()=>{xc=new Map}))}async function _ce(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 fce(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var YF,Up,KF,gs,Ar,Mu,WF,SO,sce,ice,oce,ace,$F,Mp,jF,cce,lce,xc,VF,vp=De(()=>{YF=v(vn());$r();B_();Up=v(ef());Le();KF=require("uuid"),gs=v(te()),Ar=v(M()),Mu=v(V()),WF=v(a_());Nf();Uu();SO=(0,Mu.loggerWithTag)("auth-event");gs.initSync();sce=gs.get(Ar.CONFIG_PARAMS.HTTP_CORSACCESSLIST),ice=gs.get(Ar.CONFIG_PARAMS.HTTP_CORS),oce=gs.get(Ar.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),ace=gs.get(Ar.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),$F=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Mp=gs.get(Ar.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,jF=process.env.AUTHENTICATION_AUTHORIZELOCAL??gs.get(Ar.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,cce=gs.get(Ar.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,lce=gs.get(Ar.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,xc=new Map;st.onInvalidatedUser(()=>{xc=new Map});a(uce,"bypassAuth");a(QF,"authentication");a(dce,"start");a(_ce,"login");a(fce,"logout")});var rG=b((eDe,tG)=>{"use strict";var be=require("joi"),zF=require("fs-extra"),JF=require("path"),qn=ut(),XF=te(),ZF=M(),eG=V(),{hdb_errors:Ece}=fe(),{HDB_ERROR_MSGS:Lr}=Ece,fo=/^[a-zA-Z0-9-_]+$/,hce=/^[a-zA-Z0-9-_]+$/;tG.exports={getDropCustomFunctionValidator:pce,setCustomFunctionValidator:Sce,addComponentValidator:Ace,dropCustomFunctionProjectValidator:bce,packageComponentValidator:yce,deployComponentValidator:Oce,setComponentFileValidator:Tce,getComponentFileValidator:Rce,dropComponentFileValidator:gce,addSSHKeyValidator:Nce,updateSSHKeyValidator:Ice,deleteSSHKeyValidator:wce,setSSHKnownHostsValidator:Cce};function Bp(e,t,r){try{let n=XF.get(ZF.CONFIG_PARAMS.COMPONENTSROOT),s=JF.join(n,t);return zF.existsSync(s)?e?t:r.message(Lr.PROJECT_EXISTS):e?r.message(Lr.NO_PROJECT):t}catch(n){return eG.error(n),r.message(Lr.VALIDATION_ERR)}}a(Bp,"checkProjectExists");function wf(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(wf,"checkFilePath");function mce(e,t,r,n){try{let s=XF.get(ZF.CONFIG_PARAMS.COMPONENTSROOT),i=JF.join(s,e,t,r+".js");return zF.existsSync(i)?r:n.message(Lr.NO_FILE)}catch(s){return eG.error(s),n.message(Lr.VALIDATION_ERR)}}a(mce,"checkFileExists");function pce(e){let t=be.object({project:be.string().pattern(fo).custom(Bp.bind(null,!0)).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),type:be.string().valid("helpers","routes").required(),file:be.string().pattern(fo).custom(mce.bind(null,e.project,e.type)).custom(wf).required().messages({"string.pattern.base":Lr.BAD_FILE_NAME})});return qn.validateBySchema(e,t)}a(pce,"getDropCustomFunctionValidator");function Sce(e){let t=be.object({project:be.string().pattern(fo).custom(Bp.bind(null,!0)).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),type:be.string().valid("helpers","routes").required(),file:be.string().custom(wf).required(),function_content:be.string().required()});return qn.validateBySchema(e,t)}a(Sce,"setCustomFunctionValidator");function Tce(e){let t=be.object({project:be.string().pattern(fo).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),file:be.string().custom(wf).required(),payload:be.string().allow("").optional(),encoding:be.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return qn.validateBySchema(e,t)}a(Tce,"setComponentFileValidator");function gce(e){let t=be.object({project:be.string().pattern(fo).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),file:be.string().custom(wf).optional()});return qn.validateBySchema(e,t)}a(gce,"dropComponentFileValidator");function Rce(e){let t=be.object({project:be.string().required(),file:be.string().custom(wf).required(),encoding:be.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return qn.validateBySchema(e,t)}a(Rce,"getComponentFileValidator");function Ace(e){let t=be.object({project:be.string().pattern(fo).custom(Bp.bind(null,!1)).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME})});return qn.validateBySchema(e,t)}a(Ace,"addComponentValidator");function bce(e){let t=be.object({project:be.string().pattern(fo).custom(Bp.bind(null,!0)).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME})});return qn.validateBySchema(e,t)}a(bce,"dropCustomFunctionProjectValidator");function yce(e){let t=be.object({project:be.string().pattern(fo).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),skip_node_modules:be.boolean()});return qn.validateBySchema(e,t)}a(yce,"packageComponentValidator");function Oce(e){let t=be.object({project:be.string().pattern(fo).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),payload:be.string().optional().messages({"string.pattern.base":Lr.BAD_PACKAGE}),package:be.string().optional(),restart:be.boolean().optional()});return qn.validateBySchema(e,t)}a(Oce,"deployComponentValidator");function Nce(e){let t=be.object({name:be.string().pattern(hce).required().messages({"string.pattern.base":Lr.BAD_SSH_KEY_NAME}),key:be.string().required(),host:be.string().required(),hostname:be.string().required(),known_hosts:be.string().optional()});return qn.validateBySchema(e,t)}a(Nce,"addSSHKeyValidator");function Ice(e){let t=be.object({name:be.string().required(),key:be.string().required()});return qn.validateBySchema(e,t)}a(Ice,"updateSSHKeyValidator");function wce(e){let t=be.object({name:be.string().required()});return qn.validateBySchema(e,t)}a(wce,"deleteSSHKeyValidator");function Cce(e){let t=be.object({known_hosts:be.string().required()});return qn.validateBySchema(e,t)}a(Cce,"setSSHKnownHostsValidator")});var Gp=b((rDe,cG)=>{"use strict";var Hp=require("joi"),Fc=require("path"),kp=require("fs-extra"),{exec:Dce}=require("child_process"),Pce=require("util"),nG=Pce.promisify(Dce),Hu=M(),{handleHDBError:vu,hdb_errors:Lce}=fe(),{HTTP_STATUS_CODES:Bu}=Lce,ku=te(),Mce=ut(),xu=V();ku.initSync();var TO=ku.get(Hu.CONFIG_PARAMS.COMPONENTSROOT),sG="npm install --omit=dev --json",Uce=`${sG} --dry-run`,vce=ku.get(Hu.CONFIG_PARAMS.ROOTPATH),xp=Fc.join(vce,"ssh");cG.exports={installModules:kce,auditModules:Fce,installAllRootModules:Bce,uninstallRootModule:Hce,linkHarperdb:xce};async function Bce(e=!1){await Fp();let t=!1,r=process.env;kp.pathExistsSync(xp)&&kp.readdirSync(xp).forEach(n=>{n.includes(".key")&&!t&&(r={GIT_SSH_COMMAND:"ssh -F "+Fc.join(xp,"config")+" -o UserKnownHostsFile="+Fc.join(xp,"known_hosts"),...process.env},t=!0)}),await Cf(e?"npm install --ignore-scripts":"npm install",ku.get(Hu.CONFIG_PARAMS.ROOTPATH),r)}a(Bce,"installAllRootModules");async function Hce(e){await Cf(`npm uninstall ${e}`,ku.get(Hu.CONFIG_PARAMS.ROOTPATH))}a(Hce,"uninstallRootModule");async function xce(){await Fp(),await Cf(`npm link ${Hu.PACKAGE_ROOT}`,ku.get(Hu.CONFIG_PARAMS.ROOTPATH))}a(xce,"linkHarperdb");async function Cf(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await nG(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
|
|
19
|
+
`,""))}return s&&!s.includes("Debugger listening")&&xu.error("Error running NPM command:",e,s),xu.trace(n,s),n?.replace(`
|
|
20
|
+
`,"")}a(Cf,"runCommand");async function kce(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";xu.warn(t,e);let r=aG(e);if(r)throw vu(r,r.message,Bu.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?Uce:sG;await Fp(),await oG(n);let o={};for(let c=0,l=n.length;c<l;c++){let d=n[c];o[d]={npm_output:null,npm_error:null};let u=Fc.join(TO,d),_,E=null;try{let{stdout:f,stderr:h}=await nG(i,{cwd:u});_=f?f.replace(`
|
|
21
|
+
`,""):null,E=h?h.replace(`
|
|
22
|
+
`,""):null}catch(f){f.stderr?o[d].npm_error=iG(f.stderr):o[d].npm_error=f.message;continue}try{o[d].npm_output=JSON.parse(_)}catch{o[d].npm_output=_}try{o[d].npm_error=JSON.parse(E)}catch{o[d].npm_error=E}}return xu.info(`finished installModules with response ${o}`),o.warning=t,o}a(kce,"installModules");function iG(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
|
|
23
|
+
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(iG,"parseNPMStdErr");async function Fce(e){xu.info(`starting auditModules for request: ${e}`);let t=aG(e);if(t)throw vu(t,t.message,Bu.BAD_REQUEST);let{projects:r}=e;await Fp(),await oG(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=Fc.join(TO,o);n[o]={npm_output:null,npm_error:null};try{let l=await Cf("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=iG(l.stderr)}}return xu.info(`finished auditModules with response ${n}`),n}a(Fce,"auditModules");async function Fp(){try{return await Cf("npm -v"),!0}catch{throw vu(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Bu.BAD_REQUEST,void 0,void 0,!0)}}a(Fp,"checkNPMInstalled");async function oG(e){if(!Array.isArray(e)||e.length===0)throw vu(new Error,"projects argument must be an array with at least 1 element",Bu.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=Fc.join(TO,i.toString());if(!await kp.pathExists(o)){t.push(i);continue}let l=Fc.join(o,"package.json");await kp.pathExists(l)||r.push(i)}if(t.length>0)throw vu(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Bu.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw vu(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Bu.BAD_REQUEST,void 0,void 0,!0)}a(oG,"checkProjectPaths");function aG(e){let t=Hp.object({projects:Hp.array().min(1).items(Hp.string()).required(),dry_run:Hp.boolean().default(!1)});return Mce.validateBySchema(e,t)}a(aG,"modulesValidator")});var RO=b((sDe,fG)=>{"use strict";var pa=require("fs-extra"),gO=require("path"),Df=V(),lG=J(),qp=M(),_G=te(),Gce=wt();fG.exports=qce;async function qce(){let e=$ce(),t=_G.get(qp.CONFIG_PARAMS.ROOTPATH),r=gO.join(t,"package.json"),n={dependencies:{harperdb:"file:"+qp.PACKAGE_ROOT}},s=gO.join(t,"node_modules");pa.ensureDirSync(s);let i,o=!0,c=!1;try{i=pa.readJsonSync(r)}catch(l){if(lG.isEmptyOrZeroLength(e))return;if(l.code!==qp.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!lG.isEmptyOrZeroLength(e)){for(let{name:l,package:d}of e){let u=uG(d);n.dependencies[l]=u+d}if(!o){Df.notify("Installing components"),await dG(r,n,null);return}for(let{name:l,package:d}of e){let u=i.dependencies[l],_=uG(d);if(u===void 0||u!==_+d){c=!0;break}if(d.startsWith("file:"))try{if(pa.statSync(new URL(d+"/package.json")).mtimeMs>pa.statSync(r).mtimeMs){c=!0;break}}catch(E){Df.info(`Error checking ${d}/package.json modification time`,E);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Df.notify("Removing component",l),c=!0);c&&(Df.notify("Updating components."),await dG(r,n,i))}a(qce,"installComponents");function $ce(){let e=Gce.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a($ce,"getComponentsConfig");function uG(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":gO.extname(e)||pa.existsSync(e)?"file:":"github:"}a(uG,"getPkgPrefix");async function dG(e,t,r){Df.trace("npm installing components package.json",t),pa.writeFileSync(e,JSON.stringify(t,null," "));try{await Gp().installAllRootModules(_G.get(qp.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?pa.writeFileSync(e,JSON.stringify(r,null," ")):pa.unlinkSync(e),n}}a(dG,"installPackages")});var yO=b(pG=>{"use strict";var Ae=require("fs-extra"),AO=require("fast-glob"),Ce=require("path"),hG=require("tar-fs"),Vce=require("gunzip-maybe"),oDe=require("uuid").v4,bO=require("normalize-path"),Tn=rG(),Ft=V(),pt=M(),Xt=te(),Pf=wt(),Yce=J(),{PACKAGE_ROOT:Kce}=M(),{handleHDBError:Gt,hdb_errors:Wce}=fe(),{basename:jce}=require("path"),Qce=RO(),mG=te(),zce=M(),{Readable:Jce}=require("stream"),{isMainThread:Xce}=require("worker_threads"),{HDB_ERROR_MSGS:Gc,HTTP_STATUS_CODES:qt}=Wce,Zce=it(),{replicateOperation:zs}=(ls(),oe(sa)),ele=Ce.join(Kce,"application-template"),EG=Ce.join(Xt.get(pt.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp"),tle=Xt.get(pt.CONFIG_PARAMS.ROOTPATH),Sa=Ce.join(tle,"ssh"),Eo=Ce.join(Sa,"known_hosts");function rle(){Ft.trace("getting custom api status");let e={};try{e={port:Xt.get(pt.CONFIG_PARAMS.HTTP_PORT),directory:Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Gt(new Error,Gc.FUNCTION_STATUS,qt.INTERNAL_SERVER_ERROR,Ft.ERR,t)}return e}a(rle,"customFunctionsStatus");function nle(){Ft.trace("getting custom api endpoints");let e={},t=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT);try{AO.sync(bO(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:AO.sync(bO(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:AO.sync(bO(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Gt(new Error,Gc.GET_FUNCTIONS,qt.INTERNAL_SERVER_ERROR,Ft.ERR,r)}return e}a(nle,"getCustomFunctions");function sle(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Tn.getDropCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("getting custom api endpoint file content");let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=Ce.join(r,n,s,i+".js");try{return Ae.readFileSync(o,{encoding:"utf8"})}catch(c){throw Gt(new Error,Gc.GET_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,c)}}a(sle,"getCustomFunction");async function ile(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Tn.setCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("setting custom function file content");let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Ae.outputFileSync(Ce.join(r,n,s,i+".js"),o);let c=await zs(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Gt(new Error,Gc.SET_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,c)}}a(ile,"setCustomFunction");async function ole(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Tn.getDropCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("dropping custom function file");let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Ae.unlinkSync(Ce.join(r,n,s,i+".js"));let o=await zs(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Gt(new Error,Gc.DROP_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,o)}}a(ole,"dropCustomFunction");async function ale(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Tn.addComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("adding component");let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=Ce.join(r,n);Ae.mkdirSync(s,{recursive:!0}),Ae.copySync(ele,s);let i=await zs(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Gt(new Error,Gc.ADD_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,s)}}a(ale,"addComponent");async function cle(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Tn.dropCustomFunctionProjectValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("dropping custom function project");let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Xt.get(pt.CONFIG_PARAMS.APPS);if(!Yce.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 Pf.updateConfigValue(pt.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=Ce.join(r,n);Ae.rmSync(i,{recursive:!0});let o=await zs(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Gt(new Error,Gc.DROP_FUNCTION_PROJECT,qt.INTERNAL_SERVER_ERROR,Ft.ERR,i)}}a(cle,"dropCustomFunctionProject");async function lle(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Tn.packageComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ft.trace("packaging component",n);let s;try{s=await Ae.realpath(Ce.join(r,n))}catch(l){if(l.code!==pt.NODE_ERROR_CODES.ENOENT)throw l;try{s=await Ae.realpath(Ce.join(Xt.get(pt.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(d){if(d.code===pt.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}await Ae.ensureDir(EG);let i=Ce.join(EG,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:l=>l.includes(Ce.join(s,"node_modules"))}),hG.pack(s,o).pipe(Ae.createWriteStream(i,{overwrite:!0})),await new Promise(l=>setTimeout(l,2e3));let c=Ae.readFileSync(i,{encoding:"base64"});return await Ae.remove(i),{project:n,payload:c}}a(lle,"packageComponent");async function ule(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Tn.deployComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i}=e;if(Ft.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let o;if(s){o=Ce.join(r,n),i="file:"+o,await Ae.emptyDir(o);let h=Jce.from(Buffer.from(s,"base64"));await new Promise((S,R)=>{h.pipe(Vce()).pipe(hG.extract(o,{finish:S})).on("error",R)});let T=await Ae.readdir(o);T.length===1&&T[0]==="package"&&(await Ae.copy(Ce.join(o,"package"),o),await Ae.remove(Ce.join(o,"package")))}await Pf.addConfig(n,{package:i}),await Qce();let c=mG.get(zce.CONFIG_PARAMS.ROOTPATH);if(o=Ce.join(c,"node_modules",n),Xce)return;let l=new Map;l.isWorker=!0;let d=(Mf(),oe(Lf)),u;d.setErrorReporter(h=>u=h);let _=jce(o),E=d.component_errors.get(_);try{await d.loadComponent(o,l)}finally{d.component_errors.set(_,E)}if(u)throw u;Ft.info("Installed component");let f=await zs(e);return e.restart===!0?(Zce.restartWorkers("http"),f.message=`Successfully deployed: ${n}, restarting HarperDB`):f.message=`Successfully deployed: ${n}`,f}a(ule,"deployComponent");async function dle(){let e=Pf.getConfiguration(),t=[];for(let o in e)if(e[o]?.package){if(e[o].package.startsWith("file:"))continue;t.push({...e[o],name:o})}let r=a(async(o,c)=>{try{let l=await Ae.readdir(o,{withFileTypes:!0});for(let d of l){let u=d.name;if(u.startsWith(".")||u==="node_modules")continue;let _=Ce.join(o,u);if(d.isDirectory()||d.isSymbolicLink()){let E={name:u,entries:[]};c.entries.push(E),await r(_,E)}else{let E=await Ae.stat(_),f={name:Ce.basename(u),mtime:E.mtime,size:E.size};c.entries.push(f)}}return c}catch(l){return Ft.warn("Error loading package",l),{error:l.toString(),entries:[]}}},"walk_dir"),n=await r(Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{name:Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT).split(Ce.sep).slice(-1).pop(),entries:t});for(let o of n.entries)if(o.package){let c=await r(Ce.join(Xt.get(pt.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(Mf(),oe(Lf)).component_errors;for(let o of t){let c=i.get(o.name);c?o.error=i.get(o.name):c===void 0&&(o.error="The component has not been loaded yet (may need a restart)")}return n}a(dle,"getComponents");async function _le(e){let t=Tn.getComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let n=Pf.getConfigObj()[e.project]||e.project==="harperdb"?Ce.join(mG.get(pt.CONFIG_PARAMS.ROOTPATH),"node_modules"):Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Ae.stat(Ce.join(n,e.project,e.file));return{message:await Ae.readFile(Ce.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===pt.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${Ce.join(e.project,e.file)}'`):i}}a(_le,"getComponentFile");async function fle(e){let t=Tn.setComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=Ce.join(Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Ae.ensureFile(n),await Ae.outputFile(n,e.payload,r)):await Ae.ensureDir(n);let s=await zs(e);return s.message="Successfully set component: "+e.file,s}a(fle,"setComponentFile");async function Ele(e){let t=Tn.dropComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=e.file?Ce.join(e.project,e.file):e.project,n=Ce.join(Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),r);await Ae.pathExists(n)&&await Ae.remove(n),Pf.deleteConfigFromFile([e.project]);let s=await zs(e);return s.message="Successfully dropped: "+r,s}a(Ele,"dropComponent");async function hle(e){let t=Tn.addSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Ft.trace("adding ssh key",r);let c=Ce.join(Sa,r+".key"),l=Ce.join(Sa,"config");if(await Ae.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Ae.outputFile(c,n),await Ae.chmod(c,"0600");let d=`#${r}
|
|
22
24
|
Host ${s}
|
|
23
25
|
HostName ${i}
|
|
24
26
|
User git
|
|
25
27
|
IdentityFile ${c}
|
|
26
|
-
IdentitiesOnly yes`;await
|
|
27
|
-
`+d):await
|
|
28
|
-
`)}catch{u=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}return o&&await Se.appendFile(xi,o),`Added ssh key: ${r}${u}`}a(jse,"addSSHKey");async function Jse(e){let t=on.updateSSHKeyValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);let{name:r,key:n}=e;Ut.trace("updating ssh key",r);let s=Re.join(wo,r+".key");if(!await Se.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");return await Se.outputFile(s,n),`Updated ssh key: ${r}`}a(Jse,"updateSSHKey");async function Xse(e){let t=on.deleteSSHKeyValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);let{name:r}=e;Ut.trace("deleting ssh key",r);let n=Re.join(wo,r+".key"),s=Re.join(wo,"config");if(!await Se.pathExists(n))throw new Error("Key does not exist");let i=await Se.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");return i=i.replace(o,""),await Se.outputFile(s,i),Se.removeSync(n),`Deleted ssh key: ${r}`}a(Xse,"deleteSSHKey");async function Zse(e){let t=[];return await Se.pathExists(wo)&&(await Se.readdir(wo)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(Zse,"listSSHKeys");async function eie(e){let t=on.setSSHKnownHostsValidator(e);if(t)throw vt(t,t.message,xt.BAD_REQUEST);let{known_hosts:r}=e;return await Se.outputFile(xi,r),"Known hosts successfully set"}a(eie,"setSSHKnownHosts");async function tie(e){return await Se.pathExists(xi)?{known_hosts:await Se.readFile(xi,"utf8")}:{known_hosts:null}}a(tie,"getSSHKnownHosts");Object.assign(IH,{customFunctionsStatus:Bse,getCustomFunctions:Hse,getCustomFunction:kse,setCustomFunction:Fse,dropCustomFunction:Gse,addComponent:qse,dropCustomFunctionProject:Vse,packageComponent:$se,deployComponent:Yse,getComponents:Kse,getComponentFile:Wse,setComponentFile:Qse,dropComponent:zse,addSSHKey:jse,updateSSHKey:Jse,deleteSSHKey:Xse,listSSHKeys:Zse,setSSHKnownHosts:eie,getSSHKnownHosts:tie})});var Ab=N((KAe,CH)=>{"use strict";var Zn=require("joi"),wH=ct();CH.exports={readTransactionLogValidator:rie,deleteTransactionLogsBeforeValidator:nie};function rie(e){let t=Zn.object({schema:Zn.string(),database:Zn.string(),table:Zn.string().required(),from:Zn.date().timestamp(),to:Zn.date().timestamp(),limit:Zn.number().min(1)});return wH.validateBySchema(e,t)}a(rie,"readTransactionLogValidator");function nie(e){let t=Zn.object({schema:Zn.string(),database:Zn.string(),table:Zn.string().required(),timestamp:Zn.date().timestamp().required()});return wH.validateBySchema(e,t)}a(nie,"deleteTransactionLogsBeforeValidator")});var dm=N((QAe,vH)=>{"use strict";var bb=M(),s_=Mt(),DH=te(),LH=ne(),PH=pi(),MH=j(),{handleHDBError:lm,hdb_errors:sie}=ce(),{HTTP_STATUS_CODES:um}=sie,{readTransactionLogValidator:iie,deleteTransactionLogsBeforeValidator:oie}=Ab(),UH=Vn(),aie="Logs successfully deleted from transaction log.",cie="All logs successfully deleted from transaction log.";vH.exports={readTransactionLog:lie,deleteTransactionLogsBefore:die};async function lie(e){let t=iie(e);if(t)throw lm(t,t.message,um.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=DH.checkSchemaTableExist(e.database,e.table);if(r)throw lm(new Error,r,um.NOT_FOUND,void 0,void 0,!0);return LH.get(bb.CONFIG_PARAMS.CLUSTERING_ENABLED)?await uie(e):(MH.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)),UH.readAuditLog(e))}a(lie,"readTransactionLog");async function*uie(e){let t=PH.createNatsTableStreamName(e.database,e.table),r=await s_.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===bb.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(uie,"readTransactionLogNats");async function die(e){let t=oie(e);if(t)throw lm(t,t.message,um.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!LH.get(bb.CONFIG_PARAMS.CLUSTERING_ENABLED))return MH.info("Delete transaction logs called for Plexus"),UH.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=DH.checkSchemaTableExist(r,n);if(i)throw lm(new Error,i,um.NOT_FOUND,void 0,void 0,!0);let o=PH.createNatsTableStreamName(r,n),{jsm:c}=await s_.getNATSReferences(),l=await s_.getStreamInfo(o),d=new Date(l.state.first_ts).getTime();if(s<=d)return`No transactions exist before: ${s}`;let u=aie,_,E=new Date(l.state.last_ts).getTime();return s>E?(_=l.state.last_seq+1,u=cie):_=(await s_.viewStream(o,parseInt(s),1))[0].nats_sequence,await s_.purgeTableStream(r,n,{seq:_}),u}a(die,"deleteTransactionLogsBefore")});var BH=N((jAe,xH)=>{"use strict";var yb=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}};xH.exports=yb});var kH=N((XAe,HH)=>{"use strict";var Ob=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};HH.exports=Ob});var Ib=N((ebe,GH)=>{"use strict";var FH=BH(),_ie=kH(),{HDB_ERROR_MSGS:fie}=En(),Nb=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=fie.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 FH(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new _ie(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 FH(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}};GH.exports=Nb});var hm=N((sbe,sk)=>{"use strict";var wb=Rn(),_m=gn(),ts=ld(),a_=Si(),Cb=so(),Eie=uR(),hie=MU(),c_=$n(),fm=TR(),ar=j(),mie=AR(),pie=Dh(),Sie=CA(),Tie=Ph(),gie=PA(),Rie=MA(),Aie=xA(),bie=HA(),Db=GA(),Bi=te(),yie=$x(),Lb=KA(),$H=Jd(),es=M(),YH=JB(),Oie=Vc(),KH=Ed(),WH=(Xh(),ae(e_)),QH=dr(),Xt=Rb(),Nie=require("alasql"),zH=dm(),jH=sm(),l_=bo(),JH=(wa(),ae(Ia)),XH=Ib(),{handleHDBError:an,hdb_errors:ZH}=ce(),{addNodeBack:rbe,removeNodeBack:nbe}=(wa(),ae(Ia)),{HDB_ERROR_MSGS:br,HTTP_STATUS_CODES:i_}=ZH,W=new Map,ek="delete",Co="insert",Hi="read",Ha="update",o_="describe",qH=a_.describeSchema.name,VH=a_.describeTable.name,tk={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},Iie="catchup",wie="handleGetJob",Cie="handleGetJobsByStartDate",Em={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},Die=[ts.createTable.name,ts.createAttribute.name,ts.dropTable.name,ts.dropAttribute.name],rk={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},z=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};W.set(wb.insert.name,new z(!1,[Co]));W.set(wb.update.name,new z(!1,[Ha]));W.set(wb.upsert.name,new z(!1,[Co,Ha]));W.set(_m.searchByConditions.name,new z(!1,[Hi]));W.set(_m.searchByHash.name,new z(!1,[Hi]));W.set(_m.searchByValue.name,new z(!1,[Hi]));W.set(_m.search.name,new z(!1,[Hi]));W.set(ts.createSchema.name,new z(!0,[]));W.set(ts.createTable.name,new z(!0,[]));W.set(ts.createAttribute.name,new z(!1,[Co]));W.set(ts.dropSchema.name,new z(!0,[]));W.set(ts.dropTable.name,new z(!0,[]));W.set(ts.dropAttribute.name,new z(!0,[]));W.set(a_.describeSchema.name,new z(!1,[Hi]));W.set(a_.describeTable.name,new z(!1,[Hi]));W.set(Cb.deleteRecord.name,new z(!1,[ek]));W.set(c_.addUser.name,new z(!0,[]));W.set(c_.alterUser.name,new z(!0,[]));W.set(c_.dropUser.name,new z(!0,[]));W.set(c_.listUsersExternal.name,new z(!0,[]));W.set(fm.listRoles.name,new z(!0,[]));W.set(fm.addRole.name,new z(!0,[]));W.set(fm.alterRole.name,new z(!0,[]));W.set(fm.dropRole.name,new z(!0,[]));W.set(mie.name,new z(!0,[]));W.set(pie.name,new z(!0,[]));W.set(Sie.name,new z(!0,[]));W.set(Tie.name,new z(!0,[]));W.set(gie.name,new z(!0,[]));W.set(Rie.name,new z(!0,[]));W.set(Db.setRoutes.name,new z(!0,[]));W.set(Db.getRoutes.name,new z(!0,[]));W.set(Db.deleteRoutes.name,new z(!0,[]));W.set(QH.setConfiguration.name,new z(!0,[]));W.set(Aie.clusterStatus.name,new z(!0,[]));W.set(bie.name,new z(!0,[]));W.set(Lb.getFingerprint.name,new z(!0,[]));W.set(Lb.setLicense.name,new z(!0,[]));W.set(Cb.deleteFilesBefore.name,new z(!0,[]));W.set(Cb.deleteAuditLogsBefore.name,new z(!0,[]));W.set($H.restart.name,new z(!0,[]));W.set($H.restartService.name,new z(!0,[]));W.set(Eie.name,new z(!0,[]));W.set(hie.name,new z(!0,[Hi]));W.set(Oie.systemInformation.name,new z(!0,[]));W.set(QH.getConfiguration.name,new z(!0,[]));W.set(zH.readTransactionLog.name,new z(!0,[]));W.set(zH.deleteTransactionLogsBefore.name,new z(!0,[]));W.set(jH.installModules.name,new z(!0,[]));W.set(jH.auditModules.name,new z(!0,[]));W.set(l_.createCsr.name,new z(!0,[]));W.set(l_.signCertificate.name,new z(!0,[]));W.set(l_.listCertificates.name,new z(!0,[]));W.set(l_.addCertificate.name,new z(!0,[]));W.set(l_.removeCertificate.name,new z(!0,[]));W.set(JH.addNodeBack.name,new z(!0,[]));W.set(JH.removeNodeBack.name,new z(!0,[]));W.set(KH.createTokens.name,new z(!1,[]));W.set(KH.refreshOperationToken.name,new z(!1,[]));W.set(WH.login.name,new z(!1,[]));W.set(WH.logout.name,new z(!1,[]));W.set(Xt.customFunctionsStatus.name,new z(!0,[]));W.set(Xt.getCustomFunctions.name,new z(!0,[]));W.set(Xt.getComponents.name,new z(!0,[]));W.set(Xt.getComponentFile.name,new z(!0,[]));W.set(Xt.setComponentFile.name,new z(!0,[]));W.set(Xt.dropComponent.name,new z(!0,[]));W.set(Xt.getCustomFunction.name,new z(!0,[]));W.set(Xt.setCustomFunction.name,new z(!0,[]));W.set(Xt.dropCustomFunction.name,new z(!0,[]));W.set(Xt.addComponent.name,new z(!0,[]));W.set(Xt.dropCustomFunctionProject.name,new z(!0,[]));W.set(Xt.packageComponent.name,new z(!0,[]));W.set(Xt.deployComponent.name,new z(!0,[]));W.set(Xt.addSSHKey.name,new z(!0,[]));W.set(Xt.updateSSHKey.name,new z(!0,[]));W.set(Xt.deleteSSHKey.name,new z(!0,[]));W.set(Xt.listSSHKeys.name,new z(!0,[]));W.set(Xt.setSSHKnownHosts.name,new z(!0,[]));W.set(Xt.getSSHKnownHosts.name,new z(!0,[]));W.set(Lb.getRegistrationInfo.name,new z(!1,[]));W.set(c_.userInfo.name,new z(!1,[]));W.set(a_.describeAll.name,new z(!1,[]));W.set(wie,new z(!1,[]));W.set(Cie,new z(!0,[]));W.set(Iie,new z(!0,[]));W.set(Em.CSV_DATA_LOAD,new z(!1,[Co,Ha]));W.set(Em.CSV_URL_LOAD,new z(!1,[Co,Ha]));W.set(Em.CSV_FILE_LOAD,new z(!1,[Co,Ha]));W.set(Em.IMPORT_FROM_S3,new z(!1,[Co,Ha]));W.set(rk.EXPORT_TO_S3,new z(!0,[]));W.set(rk.EXPORT_LOCAL,new z(!0,[]));W.set(es.VALID_SQL_OPS_ENUM.DELETE,new z(!1,[ek]));W.set(es.VALID_SQL_OPS_ENUM.SELECT,new z(!1,[Hi]));W.set(es.VALID_SQL_OPS_ENUM.INSERT,new z(!1,[Co]));W.set(es.VALID_SQL_OPS_ENUM.UPDATE,new z(!1,[Ha]));sk.exports={verifyPerms:Pie,verifyPermsAst:Lie,verifyBulkLoadAttributePerms:Uie};function Lie(e,t,r){if(Bi.isEmptyOrZeroLength(e))throw ar.info("verify_perms_ast has an empty user parameter"),an(new Error);if(Bi.isEmptyOrZeroLength(t))throw ar.info("verify_perms_ast has an empty user parameter"),an(new Error);if(Bi.isEmptyOrZeroLength(r))throw ar.info("verify_perms_ast has a null operation parameter"),an(new Error);try{let n=new XH,s=new yie(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw ar.info("No schemas defined in verifyPermsAst(), will not continue."),an(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&tk[r])throw an(new Error,br.DROP_SYSTEM,i_.FORBIDDEN);if(c&&!l)return null;let d=YH.getRolePermissions(t.role);t.role.permission=d,!c&&e instanceof Nie.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(d));for(let _=0;_<i.length;_++){let E=s.getTablesBySchemaName(i[_]);E&&o.set(i[_],E)}let u=nk(t,r,o,n);return u||(o.forEach((_,E)=>{for(let f=0;f<_.length;f++){let h=s.getAttributesBySchemaTableName(E,_[f]),p=Mb(t.role.permission,E,_[f]);Pb(h,p,r,_[f],E,n)}}),n.getPermsResponse())}catch(n){throw an(n)}}a(Lie,"verifyPermsAst");function Pie(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw ar.info("null required parameter in verifyPerms"),an(new Error,br.DEFAULT_INVALID_REQUEST,i_.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 XH;if(Bi.isEmptyOrZeroLength(e.hdb_user.role)||Bi.isEmptyOrZeroLength(e.hdb_user.role.permission))return ar.info(`User ${e.hdb_user.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(br.USER_HAS_NO_PERMS(e.hdb_user.username));let l=!!e.hdb_user.role.permission.super_user,d=e.hdb_user.role.permission.structure_user,u=o.has(es.SYSTEM_SCHEMA_NAME)||s===es.SYSTEM_SCHEMA_NAME;if(u&&tk[r])throw an(new Error,br.DROP_SYSTEM,i_.FORBIDDEN);if(l&&!u||d===!0&&(r===ts.createSchema.name||r===ts.dropSchema.name))return null;if(Die.indexOf(r)>=0&&(d===!0||Array.isArray(d)))return d===!0||d.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let _=YH.getRolePermissions(e.hdb_user.role);if(e.hdb_user.role.permission=_,r===qH||r===VH){if(s===es.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(br.SCHEMA_PERM_ERROR(s));if(!_.super_user){if(r===qH&&(!_[s]||!_[s][o_]))return c.handleInvalidItem(br.SCHEMA_NOT_FOUND(s));if(r===VH&&(!_[s]||!_[s].tables[i]||!_[s].tables[i][o_]))return c.handleInvalidItem(br.TABLE_NOT_FOUND(s,i))}}let E=nk(e.hdb_user,r,o,c,n);if(E)return E;if(W.get(r)&&W.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&es.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let p=[],S=_[s].tables[i];S[es.PERMS_CRUD_ENUM.READ]&&(S.attribute_permissions.length>0?S.attribute_permissions.filter(T=>T[es.PERMS_CRUD_ENUM.READ]).forEach(T=>{p.push(T.attribute_name)}):p=global.hdb_schema[s][i].attributes.map(g=>g.attribute),e.get_attributes=p)}let f=Mie(e),h=Mb(e.hdb_user.role.permission,s,i);return Pb(f,h,r,i,s,c,n),c.getPermsResponse()}a(Pie,"verifyPerms");function nk(e,t,r,n,s){if(Bi.arrayHasEmptyValues([e,t,r]))throw ar.info("hasPermissions has an invalid parameter"),an(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||W.get(t).requires_su))return null;if(!W.get(t))throw ar.info(`operation ${t} not found.`),an(new Error,br.OP_NOT_FOUND(t),i_.BAD_REQUEST);if(W.get(t)&&W.get(t).requires_su)return ar.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(br.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][o_]===!1){n.addInvalidItem(br.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(br.SCHEMA_NOT_FOUND(l));continue}let d=r.get(l);for(let u of d){let _=o[l].tables[u];if(!_||_[o_]===!1)n.addInvalidItem(br.TABLE_NOT_FOUND(l,u));else try{let E=[],f=W.get(t).perms;!Bi.isEmpty(s)&&f.includes(s)&&(f=[s]);for(let h=0;h<f.length;h++){let p=f[h],S=_[p];(S==null||S===!1)&&(ar.info(`Required ${p} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),E.push(p))}E.length>0&&n.addUnauthorizedTable(l,u,E)}catch(E){let f=br.UNKNOWN_OP_AUTH_ERROR(t,l,u);throw ar.error(f),ar.error(E),an(ZH.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(nk,"hasPermissions");function Pb(e,t,r,n,s,i,o){if(!e||!t)throw ar.info("no attributes specified in checkAttributePerms."),an(new Error);let c=W.get(r).perms;if(!c||c==="")throw ar.info(`no permissions found for ${r} in checkAttributePerms().`),an(new Error);if(Bi.isEmptyOrZeroLength(t))return ar.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let u of e){let _=t.get(u);if(_){if(_[o_]===!1){i.addInvalidItem(br.ATTR_NOT_FOUND(s,n,u),s,n);continue}if(c)for(let E of c){if(es.TIME_STAMP_NAMES.includes(_.attribute_name)&&E!==Hi)throw an(new Error,br.SYSTEM_TIMESTAMP_PERMS_ERR,i_.FORBIDDEN);_[E]===!1&&(l[_.attribute_name]?l[_.attribute_name].push(E):l[_.attribute_name]=[E])}}else i.addInvalidItem(br.ATTR_NOT_FOUND(s,n,u),s,n)}let d=Object.keys(l);d.length>0&&i.addUnauthorizedAttributes(d,s,n,l)}a(Pb,"checkAttributePerms");function Mie(e){let t=new Set;try{if(e.action)return t;if(e.operation===es.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){ar.info(r)}return t}a(Mie,"getRecordAttributes");function Mb(e,t,r){let n=new Map;if(Bi.isEmpty(e))return ar.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{ar.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(Mb,"getAttributePermissions");function Uie(e,t,r,n,s,i,o){let c=new Set(i),l=Mb(e,n,s);Pb(c,l,t,s,n,o,r)}a(Uie,"verifyBulkLoadAttributePerms")});var pm=N((obe,lk)=>{"use strict";lk.exports={evaluateSQL:Wie,processAST:ck,convertSQLToAST:ak,checkASTPermissions:ok};var vie=Rn(),ik=require("util"),xie=ik.callbackify(vie.insert),Bie=gn().search,Hie=SM().update,kie=ik.callbackify(Hie),Fie=gM().convertDelete,Do=require("alasql"),Gie=hm(),mm=j(),qie=NE(),Vie=te(),u_=M(),{hdb_errors:$ie,handleHDBError:Ub}=ce(),{HTTP_STATUS_CODES:vb}=$ie;qie(Do);var Yie=403,Kie="There was a problem performing this insert. Please check the logs and try again.",xb=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function Wie(e,t){let r=e.parsed_sql_object;if(!r){r=ak(e.sql);let n,s=r.ast.statements[0];if(s instanceof Do.yy.Insert?n=s.into.databaseid:s instanceof Do.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Do.yy.Update||s instanceof Do.yy.Delete?n=s.table.databaseid:mm.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Do.yy.Select)&&Vie.isEmptyOrZeroLength(n))return t("No schema specified",null)}ck(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(Wie,"evaluateSQL");function ok(e,t){let r;try{r=Gie.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(ok,"checkASTPermissions");function ak(e){let t=new xb;if(!e)throw Ub(new Error,"The 'sql' parameter is missing from the request body",vb.BAD_REQUEST);try{let r=e.trim(),n=Do.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
29
|
-
`);throw n[1]?Ub(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,vb.BAD_REQUEST):Ub(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",vb.BAD_REQUEST)}return t}a(ak,"convertSQLToAST");function ck(e,t,r){try{let n=Qie;if(!e.bypass_auth&&!t.permissions_checked){let i=ok(e,t);if(i&&i.length>0)return r(Yie,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case u_.VALID_SQL_OPS_ENUM.SELECT:n=Bie,s=t.ast.statements[0];break;case u_.VALID_SQL_OPS_ENUM.INSERT:n=zie;break;case u_.VALID_SQL_OPS_ENUM.UPDATE:n=kie;break;case u_.VALID_SQL_OPS_ENUM.DELETE:n=Fie;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(ck,"processAST");function Qie(e,t){mm.info(e),t("unknown sql statement")}a(Qie,"nullFunction");function zie({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=jie(i,e.values)}catch(o){return r(o)}xie(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){mm.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(zie,"convertInsert");function jie(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]]=Do.compile(`SELECT ${s.toString()} AS [${u_.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw mm.error(r),new Error(Kie)}}a(jie,"createDataObjects")});var Bb=N((cbe,dk)=>{"use strict";var{S3:Jie,GetObjectCommand:Xie}=require("@aws-sdk/client-s3");dk.exports={getFileStreamFromS3:Zie,getS3AuthObj:uk};async function Zie(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await uk(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new Xie(r))).Body}a(Zie,"getFileStreamFromS3");function uk(e,t,r){return new Jie({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(uk,"getS3AuthObj")});var Sm=N((ube,gk)=>{"use strict";var kb=gn(),eoe=pm(),toe=Bb(),{AsyncParser:roe,Transform:noe}=require("json2csv"),__=require("stream"),Pn=te(),Hb=require("fs-extra"),soe=require("path"),rs=j(),{promisify:Ek}=require("util"),d_=te(),{handleHDBError:Zt,hdb_errors:ioe}=ce(),{HDB_ERROR_MSGS:cn,HTTP_STATUS_CODES:er}=ioe,{streamAsJSON:ooe}=(yS(),ae(CI)),{Upload:aoe}=require("@aws-sdk/lib-storage"),_k=["search_by_value","search_by_hash","sql","search_by_conditions"],fk=["json","csv"],hk="json",mk="csv",coe="Successfully exported JSON locally.",loe="Successfully exported CSV locally.",uoe=1e3,doe=kb.searchByHash,_oe=kb.searchByValue,foe=Ek(eoe.evaluateSQL),Eoe=Ek(__.finished);gk.exports={export_to_s3:Soe,export_local:hoe,toCsvStream:pk};async function hoe(e){rs.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=Sk(e);if(!Pn.isEmpty(t))throw rs.error(t),Zt(new Error,t,er.BAD_REQUEST,void 0,void 0,!0);if(Pn.isEmpty(e.path))throw rs.error(cn.MISSING_VALUE("path")),Zt(new Error,cn.MISSING_VALUE("path"),er.BAD_REQUEST,void 0,void 0,!0);let r=(Pn.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(soe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=Pn.buildFolderPath(e.path,r);await moe(e.path);let s=await Tk(e);return await poe(n,e.format,s)}a(hoe,"export_local");async function moe(e){if(rs.trace("in confirmPath"),Pn.isEmptyOrZeroLength(e))throw Zt(new Error,`Invalid path: ${e}`,er.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await Hb.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,rs.error(n),Zt(new Error,n,er.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 rs.error(r),Zt(new Error,r,er.BAD_REQUEST,void 0,void 0,!0)}return!0}a(moe,"confirmPath");async function poe(e,t,r){if(rs.trace("in saveToLocal"),d_.isEmptyOrZeroLength(e))throw Zt(new Error,cn.INVALID_VALUE("file_path"),er.BAD_REQUEST,void 0,void 0,!0);if(d_.isEmptyOrZeroLength(t))throw Zt(new Error,cn.INVALID_VALUE("Source format"),er.BAD_REQUEST,void 0,void 0,!0);if(d_.isEmpty(r))throw Zt(new Error,cn.NOT_FOUND("Data"),er.BAD_REQUEST,void 0,void 0,!0);if(t===hk){let n=Hb.createWriteStream(e);return ooe(r).pipe(n),await Eoe(n),{message:coe,path:e}}else if(t===mk){let n=Hb.createWriteStream(e),s=__.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(u=>({label:u,value:u})));let c={objectMode:!0};return await new roe(i,c).fromInput(s).toOutput(n).promise(!1),{message:loe,path:e}}throw Zt(new Error,cn.INVALID_VALUE("format"),er.BAD_REQUEST)}a(poe,"saveToLocal");async function Soe(e){if(!e.s3||Object.keys(e.s3).length===0)throw Zt(new Error,cn.MISSING_VALUE("S3 object"),er.BAD_REQUEST);if(Pn.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw Zt(new Error,cn.MISSING_VALUE("aws_access_key_id"),er.BAD_REQUEST);if(Pn.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw Zt(new Error,cn.MISSING_VALUE("aws_secret_access_key"),er.BAD_REQUEST);if(Pn.isEmptyOrZeroLength(e.s3.bucket))throw Zt(new Error,cn.MISSING_VALUE("bucket"),er.BAD_REQUEST);if(Pn.isEmptyOrZeroLength(e.s3.key))throw Zt(new Error,cn.MISSING_VALUE("key"),er.BAD_REQUEST);if(Pn.isEmptyOrZeroLength(e.s3.region))throw Zt(new Error,cn.MISSING_VALUE("region"),er.BAD_REQUEST);let t=Sk(e);if(!Pn.isEmpty(t))throw Zt(new Error,t,er.BAD_REQUEST);rs.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await Tk(e)}catch(l){throw rs.error(l),l}let n,s=await toe.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new __.PassThrough;if(e.format===mk){i=e.s3.key+".csv";let l=pk(r,r.getColumns?.());l.on("error",d=>{throw d}),l.pipe(o)}else if(e.format===hk){i=e.s3.key+".json";let l=new __.Readable;l.pipe(o),l.on("error",_=>{throw _}),l.push("[");let d=r.length,u="";for(let[_,E]of r.entries()){let f=_===d-1?JSON.stringify(E):JSON.stringify(E)+",";u+=f,_!==0&&_%uoe===0&&(l.push(u),u="")}u.length!==0&&l.push(u),l.push("]"),l.push(null)}else throw Zt(new Error,cn.INVALID_VALUE("format"),er.BAD_REQUEST);return new aoe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(Soe,"export_to_s3");function pk(e,t){let r=__.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 noe(n,s);return r.pipe(i)}a(pk,"toCsvStream");function Sk(e){if(rs.trace("in exportCoreValidation"),Pn.isEmpty(e.format))return"format missing";if(fk.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${fk.join(", ")}`;let t=e.search_operation.operation;if(Pn.isEmpty(t))return"search_operation.operation missing";if(_k.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${_k.join(", ")}`}a(Sk,"exportCoreValidation");async function Tk(e){rs.trace("in getRecords");let t,r;if(d_.isEmpty(e.search_operation)||d_.isEmptyOrZeroLength(e.search_operation.operation))throw Zt(new Error,cn.INVALID_VALUE("Search operation"),er.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=_oe;break;case"search_by_hash":t=doe;break;case"search_by_conditions":t=kb.searchByConditions;break;case"sql":t=foe;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,rs.error(r),Zt(new Error,r,er.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(Tk,"getRecords")});var Ck={};Ze(Ck,{contentTypes:()=>Vb,findBestSerializer:()=>Rm,getDeserializer:()=>Fa,registerContentHandlers:()=>$b,serialize:()=>h_,serializeMessage:()=>va});function Toe(e){try{return e?.[0]===123?qb(e):e}catch{return e}}function $b(e){e.register(Roe,{serializers:[{regex:/^application\/json$/,serializer:du},{regex:/^application\/cbor$/,serializer:function(t){return new ka.EncoderStream(E_).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?gm.Readable.from((0,ei.encodeIter)(t,E_)):(0,ei.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,Tm.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,ei.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,ka.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function Rm(e){let r=(e.headers.asObject||e.headers).accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[d,...u]=l.split(/\s*;\s*/),_=1,E={q:1};for(let h of u){let p=h.indexOf("=");E[h.substring(0,p)]=h.substring(p+1)}_=+E.q;let f=hr.get(d);if(f){let h=(f.q||1)*_;h>s&&(n=f,i=f.type||d,s=h,o=E)}}if(!n){if(r)throw new yk.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(hr.keys()).join(", "),406);n=hr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function h_(e,t,r){let n=Ak&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=Rm(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,ki.createBrotliCompress)({params:{[ki.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?ki.constants.BROTLI_MODE_TEXT:ki.constants.BROTLI_MODE_GENERIC,[ki.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>Ak?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,ki.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function va(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return f_(e);let r=t.serialize;if(r)return r(e);let n=Rm(t);return r=t.serialize=n.serializer.serialize,r(e)}function Aoe(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 Fa(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=hr.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=hr.get(e)?.deserialize||bk(e,n);return o=>Aoe(o).then(i)}return e&&hr.get(e)?.deserialize||bk(e,n)}function bk(e,t){if(e.startsWith("text/")){let r=t?.match(/charset=(.+)/)?.[1]||"utf-8";return n=>({contentType:e,data:n.toString(r)})}else return e==="application/octet-stream"?r=>r:r=>{if(!e)try{if(r?.[0]===123)return qb(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function boe(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}var Tm,ei,ka,ki,yk,gm,Ok,Fb,Gb,Nk,Ik,f_,qb,E_,hr,Vb,Rk,wk,goe,Roe,Ak,hl=Oe(()=>{yS();Tm=v(Sm()),ei=require("msgpackr"),ka=require("cbor-x"),ki=require("zlib"),yk=v(ce()),gm=require("stream");Lr();Ok=require("../index"),Fb=v(ne()),Gb=v(M()),Nk=v(require("yaml")),Ik=Fb.default.get(Gb.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,f_=Ik?Vo:JSON.stringify,qb=Ik?bS:JSON.parse,E_={useRecords:!1,useToJSON:!0},hr=new Map,Vb=hr;it.contentTypes=Vb;(0,Ok._assignPackageExport)("contentTypes",Vb);hr.set("application/json",{serializeStream:du,serialize:f_,deserialize:qb,q:.8});Rk=new ka.Encoder(E_);hr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new ka.EncoderStream(E_).end(e)},serialize:Rk.encode,deserialize:Rk.decode,q:1});hr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?gm.Readable.from((0,ei.encodeIter)(e,E_)):(0,ei.pack)(e)},serialize:ei.pack,deserialize:ei.unpack,q:.9});hr.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,Tm.toCsvStream)(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),(0,Tm.toCsvStream)(e,e?.getColumns?.())},q:.1});hr.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});hr.set("text/yaml",{serialize(e){return Nk.stringify(e,{aliasDuplicateObjects:!1})},q:.7});hr.set("text/event-stream",{serializeStream:function(e){return gm.Readable.from(boe(e,this.serialize))},serialize:function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
|
|
30
|
-
`),e.data){let r=e.data;typeof r=="object"&&(r
|
|
28
|
+
IdentitiesOnly yes`;await Ae.pathExists(l)?await Ae.appendFile(l,`
|
|
29
|
+
`+d):await Ae.outputFile(l,d);let u="";if(await Ae.pathExists(Eo)||(await Ae.writeFile(Eo,""),await Ae.chmod(Eo,"0600")),i=="github.com"&&!(await Ae.readFile(Eo,"utf8")).includes("github.com"))try{let T=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let S of T)Ae.appendFile(Eo,"github.com "+S+`
|
|
30
|
+
`)}catch{u=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Ae.appendFile(Eo,o);let _=await zs(e);return _.message=`Added ssh key: ${r}${u}`,_}a(hle,"addSSHKey");async function mle(e){let t=Tn.updateSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r,key:n}=e;Ft.trace("updating ssh key",r);let s=Ce.join(Sa,r+".key");if(!await Ae.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Ae.outputFile(s,n);let i=await zs(e);return i.message=`Updated ssh key: ${r}`,i}a(mle,"updateSSHKey");async function ple(e){let t=Tn.deleteSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r}=e;Ft.trace("deleting ssh key",r);let n=Ce.join(Sa,r+".key"),s=Ce.join(Sa,"config");if(!await Ae.pathExists(n))throw new Error("Key does not exist");let i=await Ae.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Ae.outputFile(s,i),Ae.removeSync(n);let c=await zs(e);return c.message=`Deleted ssh key: ${r}`,c}a(ple,"deleteSSHKey");async function Sle(e){let t=[];return await Ae.pathExists(Sa)&&(await Ae.readdir(Sa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(Sle,"listSSHKeys");async function Tle(e){let t=Tn.setSSHKnownHostsValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{known_hosts:r}=e;await Ae.outputFile(Eo,r);let n=await zs(e);return n.message="Known hosts successfully set",n}a(Tle,"setSSHKnownHosts");async function gle(e){return await Ae.pathExists(Eo)?{known_hosts:await Ae.readFile(Eo,"utf8")}:{known_hosts:null}}a(gle,"getSSHKnownHosts");Object.assign(pG,{customFunctionsStatus:rle,getCustomFunctions:nle,getCustomFunction:sle,setCustomFunction:ile,dropCustomFunction:ole,addComponent:ale,dropCustomFunctionProject:cle,packageComponent:lle,deployComponent:ule,getComponents:dle,getComponentFile:_le,setComponentFile:fle,dropComponent:Ele,addSSHKey:hle,updateSSHKey:mle,deleteSSHKey:ple,listSSHKeys:Sle,setSSHKnownHosts:Tle,getSSHKnownHosts:gle})});var OO=b((lDe,TG)=>{"use strict";var Rs=require("joi"),SG=ut();TG.exports={readTransactionLogValidator:Rle,deleteTransactionLogsBeforeValidator:Ale};function Rle(e){let t=Rs.object({schema:Rs.string(),database:Rs.string(),table:Rs.string().required(),from:Rs.date().timestamp(),to:Rs.date().timestamp(),limit:Rs.number().min(1)});return SG.validateBySchema(e,t)}a(Rle,"readTransactionLogValidator");function Ale(e){let t=Rs.object({schema:Rs.string(),database:Rs.string(),table:Rs.string().required(),timestamp:Rs.date().timestamp().required()});return SG.validateBySchema(e,t)}a(Ale,"deleteTransactionLogsBeforeValidator")});var Yp=b((dDe,OG)=>{"use strict";var NO=M(),Uf=kt(),gG=J(),RG=te(),AG=zi(),bG=V(),{handleHDBError:$p,hdb_errors:ble}=fe(),{HTTP_STATUS_CODES:Vp}=ble,{readTransactionLogValidator:yle,deleteTransactionLogsBeforeValidator:Ole}=OO(),yG=Pn(),Nle="Logs successfully deleted from transaction log.",Ile="All logs successfully deleted from transaction log.";OG.exports={readTransactionLog:wle,deleteTransactionLogsBefore:Dle};async function wle(e){let t=yle(e);if(t)throw $p(t,t.message,Vp.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=gG.checkSchemaTableExist(e.database,e.table);if(r)throw $p(new Error,r,Vp.NOT_FOUND,void 0,void 0,!0);return RG.get(NO.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Cle(e):(bG.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)),yG.readAuditLog(e))}a(wle,"readTransactionLog");async function*Cle(e){let t=AG.createNatsTableStreamName(e.database,e.table),r=await Uf.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===NO.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Cle,"readTransactionLogNats");async function Dle(e){let t=Ole(e);if(t)throw $p(t,t.message,Vp.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!RG.get(NO.CONFIG_PARAMS.CLUSTERING_ENABLED))return bG.info("Delete transaction logs called for Plexus"),yG.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=gG.checkSchemaTableExist(r,n);if(i)throw $p(new Error,i,Vp.NOT_FOUND,void 0,void 0,!0);let o=AG.createNatsTableStreamName(r,n),{jsm:c}=await Uf.getNATSReferences(),l=await Uf.getStreamInfo(o),d=new Date(l.state.first_ts).getTime();if(s<=d)return`No transactions exist before: ${s}`;let u=Nle,_,E=new Date(l.state.last_ts).getTime();return s>E?(_=l.state.last_seq+1,u=Ile):_=(await Uf.viewStream(o,parseInt(s),1))[0].nats_sequence,await Uf.purgeTableStream(r,n,{seq:_}),u}a(Dle,"deleteTransactionLogsBefore")});var IG=b((fDe,NG)=>{"use strict";var IO=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}};NG.exports=IO});var CG=b((hDe,wG)=>{"use strict";var wO=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};wG.exports=wO});var DO=b((pDe,PG)=>{"use strict";var DG=IG(),Ple=CG(),{HDB_ERROR_MSGS:Lle}=Nn(),CO=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=Lle.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 DG(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new Ple(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 DG(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}};PG.exports=CO});var Qp=b((RDe,jG)=>{"use strict";var PO=Yr(),Kp=Vr(),bs=j_(),Hf=fi(),LO=Wo(),Mle=Gb(),Ule=UH(),xf=vn(),Wp=Jm(),mr=V(),vle=Xb(),Ble=dp(),Hle=Ly(),xle=fp(),kle=vy(),Fle=By(),Gle=ky(),qle=Gy(),MO=pp(),ho=J(),$le=Bk(),UO=jy(),UG=Lu(),As=M(),vG=GF(),Vle=gu(),BG=ef(),HG=(vp(),oe(If)),xG=wt(),ir=yO(),Yle=require("alasql"),kG=Yp(),FG=Gp(),kf=js(),GG=(Dc(),oe(Cc)),qG=DO(),{handleHDBError:gn,hdb_errors:$G}=fe(),{addNodeBack:TDe,removeNodeBack:gDe}=(Dc(),oe(Cc)),{HDB_ERROR_MSGS:Mr,HTTP_STATUS_CODES:vf}=$G,Y=new Map,VG="delete",Ta="insert",mo="read",qc="update",Bf="describe",LG=Hf.describeSchema.name,MG=Hf.describeTable.name,YG={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},Kle="catchup",Wle="handleGetJob",jle="handleGetJobsByStartDate",jp={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},Qle=[bs.createTable.name,bs.createAttribute.name,bs.dropTable.name,bs.dropAttribute.name],KG={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},Q=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};Y.set(PO.insert.name,new Q(!1,[Ta]));Y.set(PO.update.name,new Q(!1,[qc]));Y.set(PO.upsert.name,new Q(!1,[Ta,qc]));Y.set(Kp.searchByConditions.name,new Q(!1,[mo]));Y.set(Kp.searchByHash.name,new Q(!1,[mo]));Y.set(Kp.searchByValue.name,new Q(!1,[mo]));Y.set(Kp.search.name,new Q(!1,[mo]));Y.set(bs.createSchema.name,new Q(!0,[]));Y.set(bs.createTable.name,new Q(!0,[]));Y.set(bs.createAttribute.name,new Q(!1,[Ta]));Y.set(bs.dropSchema.name,new Q(!0,[]));Y.set(bs.dropTable.name,new Q(!0,[]));Y.set(bs.dropAttribute.name,new Q(!0,[]));Y.set(Hf.describeSchema.name,new Q(!1,[mo]));Y.set(Hf.describeTable.name,new Q(!1,[mo]));Y.set(LO.deleteRecord.name,new Q(!1,[VG]));Y.set(xf.addUser.name,new Q(!0,[]));Y.set(xf.alterUser.name,new Q(!0,[]));Y.set(xf.dropUser.name,new Q(!0,[]));Y.set(xf.listUsersExternal.name,new Q(!0,[]));Y.set(Wp.listRoles.name,new Q(!0,[]));Y.set(Wp.addRole.name,new Q(!0,[]));Y.set(Wp.alterRole.name,new Q(!0,[]));Y.set(Wp.dropRole.name,new Q(!0,[]));Y.set(vle.name,new Q(!0,[]));Y.set(Ble.name,new Q(!0,[]));Y.set(Hle.name,new Q(!0,[]));Y.set(xle.name,new Q(!0,[]));Y.set(kle.name,new Q(!0,[]));Y.set(Fle.name,new Q(!0,[]));Y.set(MO.setRoutes.name,new Q(!0,[]));Y.set(MO.getRoutes.name,new Q(!0,[]));Y.set(MO.deleteRoutes.name,new Q(!0,[]));Y.set(xG.setConfiguration.name,new Q(!0,[]));Y.set(Gle.clusterStatus.name,new Q(!0,[]));Y.set(qle.name,new Q(!0,[]));Y.set(UO.getFingerprint.name,new Q(!0,[]));Y.set(UO.setLicense.name,new Q(!0,[]));Y.set(LO.deleteFilesBefore.name,new Q(!0,[]));Y.set(LO.deleteAuditLogsBefore.name,new Q(!0,[]));Y.set(UG.restart.name,new Q(!0,[]));Y.set(UG.restartService.name,new Q(!0,[]));Y.set(Mle.name,new Q(!0,[]));Y.set(Ule.name,new Q(!0,[mo]));Y.set(Vle.systemInformation.name,new Q(!0,[]));Y.set(xG.getConfiguration.name,new Q(!0,[]));Y.set(kG.readTransactionLog.name,new Q(!0,[]));Y.set(kG.deleteTransactionLogsBefore.name,new Q(!0,[]));Y.set(FG.installModules.name,new Q(!0,[]));Y.set(FG.auditModules.name,new Q(!0,[]));Y.set(kf.createCsr.name,new Q(!0,[]));Y.set(kf.signCertificate.name,new Q(!0,[]));Y.set(kf.listCertificates.name,new Q(!0,[]));Y.set(kf.addCertificate.name,new Q(!0,[]));Y.set(kf.removeCertificate.name,new Q(!0,[]));Y.set(GG.addNodeBack.name,new Q(!0,[]));Y.set(GG.removeNodeBack.name,new Q(!0,[]));Y.set(BG.createTokens.name,new Q(!1,[]));Y.set(BG.refreshOperationToken.name,new Q(!1,[]));Y.set(HG.login.name,new Q(!1,[]));Y.set(HG.logout.name,new Q(!1,[]));Y.set(ir.customFunctionsStatus.name,new Q(!0,[]));Y.set(ir.getCustomFunctions.name,new Q(!0,[]));Y.set(ir.getComponents.name,new Q(!0,[]));Y.set(ir.getComponentFile.name,new Q(!0,[]));Y.set(ir.setComponentFile.name,new Q(!0,[]));Y.set(ir.dropComponent.name,new Q(!0,[]));Y.set(ir.getCustomFunction.name,new Q(!0,[]));Y.set(ir.setCustomFunction.name,new Q(!0,[]));Y.set(ir.dropCustomFunction.name,new Q(!0,[]));Y.set(ir.addComponent.name,new Q(!0,[]));Y.set(ir.dropCustomFunctionProject.name,new Q(!0,[]));Y.set(ir.packageComponent.name,new Q(!0,[]));Y.set(ir.deployComponent.name,new Q(!0,[]));Y.set(ir.addSSHKey.name,new Q(!0,[]));Y.set(ir.updateSSHKey.name,new Q(!0,[]));Y.set(ir.deleteSSHKey.name,new Q(!0,[]));Y.set(ir.listSSHKeys.name,new Q(!0,[]));Y.set(ir.setSSHKnownHosts.name,new Q(!0,[]));Y.set(ir.getSSHKnownHosts.name,new Q(!0,[]));Y.set(UO.getRegistrationInfo.name,new Q(!1,[]));Y.set(xf.userInfo.name,new Q(!1,[]));Y.set(Hf.describeAll.name,new Q(!1,[]));Y.set(Wle,new Q(!1,[]));Y.set(jle,new Q(!0,[]));Y.set(Kle,new Q(!0,[]));Y.set(jp.CSV_DATA_LOAD,new Q(!1,[Ta,qc]));Y.set(jp.CSV_URL_LOAD,new Q(!1,[Ta,qc]));Y.set(jp.CSV_FILE_LOAD,new Q(!1,[Ta,qc]));Y.set(jp.IMPORT_FROM_S3,new Q(!1,[Ta,qc]));Y.set(KG.EXPORT_TO_S3,new Q(!0,[]));Y.set(KG.EXPORT_LOCAL,new Q(!0,[]));Y.set(As.VALID_SQL_OPS_ENUM.DELETE,new Q(!1,[VG]));Y.set(As.VALID_SQL_OPS_ENUM.SELECT,new Q(!1,[mo]));Y.set(As.VALID_SQL_OPS_ENUM.INSERT,new Q(!1,[Ta]));Y.set(As.VALID_SQL_OPS_ENUM.UPDATE,new Q(!1,[qc]));jG.exports={verifyPerms:Jle,verifyPermsAst:zle,verifyBulkLoadAttributePerms:Zle};function zle(e,t,r){if(ho.isEmptyOrZeroLength(e))throw mr.info("verify_perms_ast has an empty user parameter"),gn(new Error);if(ho.isEmptyOrZeroLength(t))throw mr.info("verify_perms_ast has an empty user parameter"),gn(new Error);if(ho.isEmptyOrZeroLength(r))throw mr.info("verify_perms_ast has a null operation parameter"),gn(new Error);try{let n=new qG,s=new $le(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw mr.info("No schemas defined in verifyPermsAst(), will not continue."),gn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&YG[r])throw gn(new Error,Mr.DROP_SYSTEM,vf.FORBIDDEN);if(c&&!l)return null;let d=vG.getRolePermissions(t.role);t.role.permission=d,!c&&e instanceof Yle.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(d));for(let _=0;_<i.length;_++){let E=s.getTablesBySchemaName(i[_]);E&&o.set(i[_],E)}let u=WG(t,r,o,n);return u||(o.forEach((_,E)=>{for(let f=0;f<_.length;f++){let h=s.getAttributesBySchemaTableName(E,_[f]),T=BO(t.role.permission,E,_[f]);vO(h,T,r,_[f],E,n)}}),n.getPermsResponse())}catch(n){throw gn(n)}}a(zle,"verifyPermsAst");function Jle(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw mr.info("null required parameter in verifyPerms"),gn(new Error,Mr.DEFAULT_INVALID_REQUEST,vf.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 qG;if(ho.isEmptyOrZeroLength(e.hdb_user?.role)||ho.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return mr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(Mr.USER_HAS_NO_PERMS(e.hdb_user?.username));let l=!!e.hdb_user?.role?.permission?.super_user,d=e.hdb_user?.role?.permission?.structure_user,u=o.has(As.SYSTEM_SCHEMA_NAME)||s===As.SYSTEM_SCHEMA_NAME;if(u&&YG[r])throw gn(new Error,Mr.DROP_SYSTEM,vf.FORBIDDEN);if(l&&!u||d===!0&&(r===bs.createSchema.name||r===bs.dropSchema.name))return null;if(Qle.indexOf(r)>=0&&(d===!0||Array.isArray(d)))return d===!0||d.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let _=vG.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=_),r===LG||r===MG){if(s===As.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Mr.SCHEMA_PERM_ERROR(s));if(!_.super_user){if(r===LG&&(!_[s]||!_[s][Bf]))return c.handleInvalidItem(Mr.SCHEMA_NOT_FOUND(s));if(r===MG&&(!_[s]||!_[s].tables[i]||!_[s].tables[i][Bf]))return c.handleInvalidItem(Mr.TABLE_NOT_FOUND(s,i))}}let E=WG(e.hdb_user,r,o,c,n);if(E)return E;if(Y.get(r)&&Y.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&As.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let T=[],S=_[s].tables[i];S[As.PERMS_CRUD_ENUM.READ]&&(S.attribute_permissions.length>0?S.attribute_permissions.filter(p=>p[As.PERMS_CRUD_ENUM.READ]).forEach(p=>{T.push(p.attribute_name)}):T=global.hdb_schema[s][i].attributes.map(R=>R.attribute),e.get_attributes=T)}let f=Xle(e),h=BO(e.hdb_user?.role?.permission,s,i);return vO(f,h,r,i,s,c,n),c.getPermsResponse()}a(Jle,"verifyPerms");function WG(e,t,r,n,s){if(ho.arrayHasEmptyValues([e,t,r]))throw mr.info("hasPermissions has an invalid parameter"),gn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||Y.get(t).requires_su))return null;if(!Y.get(t))throw mr.info(`operation ${t} not found.`),gn(new Error,Mr.OP_NOT_FOUND(t),vf.BAD_REQUEST);if(Y.get(t)&&Y.get(t).requires_su)return mr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Mr.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Bf]===!1){n.addInvalidItem(Mr.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(Mr.SCHEMA_NOT_FOUND(l));continue}let d=r.get(l);for(let u of d){let _=o[l].tables[u];if(!_||_[Bf]===!1)n.addInvalidItem(Mr.TABLE_NOT_FOUND(l,u));else try{let E=[],f=Y.get(t).perms;!ho.isEmpty(s)&&f.includes(s)&&(f=[s]);for(let h=0;h<f.length;h++){let T=f[h],S=_[T];(S==null||S===!1)&&(mr.info(`Required ${T} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),E.push(T))}E.length>0&&n.addUnauthorizedTable(l,u,E)}catch(E){let f=Mr.UNKNOWN_OP_AUTH_ERROR(t,l,u);throw mr.error(f),mr.error(E),gn($G.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(WG,"hasPermissions");function vO(e,t,r,n,s,i,o){if(!e||!t)throw mr.info("no attributes specified in checkAttributePerms."),gn(new Error);let c=Y.get(r).perms;if(!c||c==="")throw mr.info(`no permissions found for ${r} in checkAttributePerms().`),gn(new Error);if(ho.isEmptyOrZeroLength(t))return mr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let u of e){let _=t.get(u);if(_){if(_[Bf]===!1){i.addInvalidItem(Mr.ATTR_NOT_FOUND(s,n,u),s,n);continue}if(c)for(let E of c){if(As.TIME_STAMP_NAMES.includes(_.attribute_name)&&E!==mo)throw gn(new Error,Mr.SYSTEM_TIMESTAMP_PERMS_ERR,vf.FORBIDDEN);_[E]===!1&&(l[_.attribute_name]?l[_.attribute_name].push(E):l[_.attribute_name]=[E])}}else i.addInvalidItem(Mr.ATTR_NOT_FOUND(s,n,u),s,n)}let d=Object.keys(l);d.length>0&&i.addUnauthorizedAttributes(d,s,n,l)}a(vO,"checkAttributePerms");function Xle(e){let t=new Set;try{if(e.action)return t;if(e.operation===As.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){mr.info(r)}return t}a(Xle,"getRecordAttributes");function BO(e,t,r){let n=new Map;if(ho.isEmpty(e))return mr.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{mr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(BO,"getAttributePermissions");function Zle(e,t,r,n,s,i,o){let c=new Set(i),l=BO(e,n,s);vO(c,l,t,s,n,o,r)}a(Zle,"verifyBulkLoadAttributePerms")});var Jp=b((bDe,ZG)=>{"use strict";ZG.exports={evaluateSQL:_ue,processAST:XG,convertSQLToAST:JG,checkASTPermissions:zG};var eue=Yr(),QG=require("util"),tue=QG.callbackify(eue.insert),rue=Vr().search,nue=Jv().update,sue=QG.callbackify(nue),iue=Zv().convertDelete,ga=require("alasql"),oue=Qp(),zp=V(),aue=um(),cue=J(),Ff=M(),{hdb_errors:lue,handleHDBError:HO}=fe(),{HTTP_STATUS_CODES:xO}=lue;aue(ga);var uue=403,due="There was a problem performing this insert. Please check the logs and try again.",kO=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function _ue(e,t){let r=e.parsed_sql_object;if(!r){r=JG(e.sql);let n,s=r.ast.statements[0];if(s instanceof ga.yy.Insert?n=s.into.databaseid:s instanceof ga.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof ga.yy.Update||s instanceof ga.yy.Delete?n=s.table.databaseid:zp.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof ga.yy.Select)&&cue.isEmptyOrZeroLength(n))return t("No schema specified",null)}XG(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(_ue,"evaluateSQL");function zG(e,t){let r;try{r=oue.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(zG,"checkASTPermissions");function JG(e){let t=new kO;if(!e)throw HO(new Error,"The 'sql' parameter is missing from the request body",xO.BAD_REQUEST);try{let r=e.trim(),n=ga.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
31
|
+
`);throw n[1]?HO(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,xO.BAD_REQUEST):HO(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",xO.BAD_REQUEST)}return t}a(JG,"convertSQLToAST");function XG(e,t,r){try{let n=fue;if(!e.bypass_auth&&!t.permissions_checked){let i=zG(e,t);if(i&&i.length>0)return r(uue,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case Ff.VALID_SQL_OPS_ENUM.SELECT:n=rue,s=t.ast.statements[0];break;case Ff.VALID_SQL_OPS_ENUM.INSERT:n=Eue;break;case Ff.VALID_SQL_OPS_ENUM.UPDATE:n=sue;break;case Ff.VALID_SQL_OPS_ENUM.DELETE:n=iue;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(XG,"processAST");function fue(e,t){zp.info(e),t("unknown sql statement")}a(fue,"nullFunction");function Eue({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=hue(i,e.values)}catch(o){return r(o)}tue(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){zp.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(Eue,"convertInsert");function hue(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]]=ga.compile(`SELECT ${s.toString()} AS [${Ff.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw zp.error(r),new Error(due)}}a(hue,"createDataObjects")});var FO=b((ODe,tq)=>{"use strict";var{S3:mue,GetObjectCommand:pue}=require("@aws-sdk/client-s3");tq.exports={getFileStreamFromS3:Sue,getS3AuthObj:eq};async function Sue(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await eq(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new pue(r))).Body}a(Sue,"getFileStreamFromS3");function eq(e,t,r){return new mue({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(eq,"getS3AuthObj")});var Xp=b((IDe,uq)=>{"use strict";var qO=Vr(),Tue=Jp(),gue=FO(),{AsyncParser:Rue,Transform:Aue}=require("json2csv"),qf=require("stream"),$n=J(),GO=require("fs-extra"),bue=require("path"),ys=V(),{promisify:sq}=require("util"),Gf=J(),{handleHDBError:or,hdb_errors:yue}=fe(),{HDB_ERROR_MSGS:Rn,HTTP_STATUS_CODES:ar}=yue,{streamAsJSON:Oue}=(Cg(),oe(ED)),{Upload:Nue}=require("@aws-sdk/lib-storage"),rq=["search_by_value","search_by_hash","sql","search_by_conditions"],nq=["json","csv"],iq="json",oq="csv",Iue="Successfully exported JSON locally.",wue="Successfully exported CSV locally.",Cue=1e3,Due=qO.searchByHash,Pue=qO.searchByValue,Lue=sq(Tue.evaluateSQL),Mue=sq(qf.finished);uq.exports={export_to_s3:Hue,export_local:Uue,toCsvStream:aq};async function Uue(e){ys.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=cq(e);if(!$n.isEmpty(t))throw ys.error(t),or(new Error,t,ar.BAD_REQUEST,void 0,void 0,!0);if($n.isEmpty(e.path))throw ys.error(Rn.MISSING_VALUE("path")),or(new Error,Rn.MISSING_VALUE("path"),ar.BAD_REQUEST,void 0,void 0,!0);let r=($n.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(bue.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=$n.buildFolderPath(e.path,r);await vue(e.path);let s=await lq(e);return await Bue(n,e.format,s)}a(Uue,"export_local");async function vue(e){if(ys.trace("in confirmPath"),$n.isEmptyOrZeroLength(e))throw or(new Error,`Invalid path: ${e}`,ar.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await GO.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,ys.error(n),or(new Error,n,ar.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 ys.error(r),or(new Error,r,ar.BAD_REQUEST,void 0,void 0,!0)}return!0}a(vue,"confirmPath");async function Bue(e,t,r){if(ys.trace("in saveToLocal"),Gf.isEmptyOrZeroLength(e))throw or(new Error,Rn.INVALID_VALUE("file_path"),ar.BAD_REQUEST,void 0,void 0,!0);if(Gf.isEmptyOrZeroLength(t))throw or(new Error,Rn.INVALID_VALUE("Source format"),ar.BAD_REQUEST,void 0,void 0,!0);if(Gf.isEmpty(r))throw or(new Error,Rn.NOT_FOUND("Data"),ar.BAD_REQUEST,void 0,void 0,!0);if(t===iq){let n=GO.createWriteStream(e);return Oue(r).pipe(n),await Mue(n),{message:Iue,path:e}}else if(t===oq){let n=GO.createWriteStream(e),s=qf.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(u=>({label:u,value:u})));let c={objectMode:!0};return await new Rue(i,c).fromInput(s).toOutput(n).promise(!1),{message:wue,path:e}}throw or(new Error,Rn.INVALID_VALUE("format"),ar.BAD_REQUEST)}a(Bue,"saveToLocal");async function Hue(e){if(!e.s3||Object.keys(e.s3).length===0)throw or(new Error,Rn.MISSING_VALUE("S3 object"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw or(new Error,Rn.MISSING_VALUE("aws_access_key_id"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw or(new Error,Rn.MISSING_VALUE("aws_secret_access_key"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.bucket))throw or(new Error,Rn.MISSING_VALUE("bucket"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.key))throw or(new Error,Rn.MISSING_VALUE("key"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.region))throw or(new Error,Rn.MISSING_VALUE("region"),ar.BAD_REQUEST);let t=cq(e);if(!$n.isEmpty(t))throw or(new Error,t,ar.BAD_REQUEST);ys.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await lq(e)}catch(l){throw ys.error(l),l}let n,s=await gue.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new qf.PassThrough;if(e.format===oq){i=e.s3.key+".csv";let l=aq(r,r.getColumns?.());l.on("error",d=>{throw d}),l.pipe(o)}else if(e.format===iq){i=e.s3.key+".json";let l=new qf.Readable;l.pipe(o),l.on("error",_=>{throw _}),l.push("[");let d=r.length,u="";for(let[_,E]of r.entries()){let f=_===d-1?JSON.stringify(E):JSON.stringify(E)+",";u+=f,_!==0&&_%Cue===0&&(l.push(u),u="")}u.length!==0&&l.push(u),l.push("]"),l.push(null)}else throw or(new Error,Rn.INVALID_VALUE("format"),ar.BAD_REQUEST);return new Nue({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(Hue,"export_to_s3");function aq(e,t){let r=qf.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 Aue(n,s);return r.pipe(i)}a(aq,"toCsvStream");function cq(e){if(ys.trace("in exportCoreValidation"),$n.isEmpty(e.format))return"format missing";if(nq.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${nq.join(", ")}`;let t=e.search_operation.operation;if($n.isEmpty(t))return"search_operation.operation missing";if(rq.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${rq.join(", ")}`}a(cq,"exportCoreValidation");async function lq(e){ys.trace("in getRecords");let t,r;if(Gf.isEmpty(e.search_operation)||Gf.isEmptyOrZeroLength(e.search_operation.operation))throw or(new Error,Rn.INVALID_VALUE("Search operation"),ar.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=Pue;break;case"search_by_hash":t=Due;break;case"search_by_conditions":t=qO.searchByConditions;break;case"sql":t=Lue;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,ys.error(r),or(new Error,r,ar.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(lq,"getRecords")});var gq={};et(gq,{contentTypes:()=>KO,findBestSerializer:()=>tS,getDeserializer:()=>Vc,registerContentHandlers:()=>WO,serialize:()=>Yf,serializeMessage:()=>kc});function xue(e){try{return e?.[0]===123?YO(e):e}catch{return e}}function WO(e){e.register(Fue,{serializers:[{regex:/^application\/json$/,serializer:Fd},{regex:/^application\/cbor$/,serializer:function(t){return new $c.EncoderStream(Vf).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?eS.Readable.from((0,wi.encodeIter)(t,Vf)):(0,wi.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,Zp.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,wi.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,$c.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function tS(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[d,...u]=l.split(/\s*;\s*/),_=1,E={q:1};for(let h of u){let T=h.indexOf("=");E[h.substring(0,T)]=h.substring(T+1)}_=+E.q;let f=br.get(d);if(f){let h=(f.q||1)*_;h>s&&(n=f,i=f.type||d,s=h,o=E)}}if(!n){if(r)throw new Eq.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(br.keys()).join(", "),406);n=br.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Yf(e,t,r){let n=_q&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=tS(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}),pq.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,po.createBrotliCompress)({params:{[po.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?po.constants.BROTLI_MODE_TEXT:po.constants.BROTLI_MODE_GENERIC,[po.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>_q?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,po.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function kc(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return $f(e);let r=t.serialize;if(r)return r(e);let n=tS(t);return r=t.serialize=n.serializer.serialize,r(e)}function Gue(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 Vc(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=br.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=br.get(e)?.deserialize||fq(e,n);return o=>Gue(o).then(i)}return e&&br.get(e)?.deserialize||fq(e,n)}function fq(e,t){if(e.startsWith("text/")){let r=t?.match(/charset=(.+)/)?.[1]||"utf-8";return n=>({contentType:e,data:n.toString(r)})}else return e==="application/octet-stream"?r=>r:r=>{if(!e)try{if(r?.[0]===123)return YO(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function que(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}var Zp,wi,$c,po,Eq,eS,hq,$O,VO,mq,pq,Sq,$f,YO,Vf,br,KO,dq,Tq,kue,Fue,_q,Uu=De(()=>{Cg();Zp=v(Xp()),wi=require("msgpackr"),$c=require("cbor-x"),po=require("zlib"),Eq=v(fe()),eS=require("stream");$r();hq=v(Vi()),$O=v(te()),VO=v(M()),mq=v(require("yaml")),pq=v(zl()),Sq=$O.default.get(VO.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,$f=Sq?Va:JSON.stringify,YO=Sq?wg:JSON.parse,Vf={useRecords:!1,useToJSON:!0},br=new Map,KO=br;st.contentTypes=KO;(0,hq._assignPackageExport)("contentTypes",KO);br.set("application/json",{serializeStream:Fd,serialize:$f,deserialize(e){return YO(e)},q:.8});dq=new $c.Encoder(Vf);br.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new $c.EncoderStream(Vf).end(e)},serialize:dq.encode,deserialize:dq.decode,q:1});br.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?eS.Readable.from((0,wi.encodeIter)(e,Vf)):(0,wi.pack)(e)},serialize:wi.pack,deserialize:wi.unpack,q:.9});br.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,Zp.toCsvStream)(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),(0,Zp.toCsvStream)(e,e?.getColumns?.())},q:.1});br.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});br.set("text/yaml",{serialize(e){return mq.stringify(e,{aliasDuplicateObjects:!1})},q:.7});br.set("text/event-stream",{serializeStream:function(e){return eS.Readable.from(que(e,this.serialize))},serialize:function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
|
|
32
|
+
`),e.data){let r=e.data;typeof r=="object"&&(r=$f(r)),t+="data: "+r+`
|
|
31
33
|
`}return e.id&&(t+="id: "+e.id+`
|
|
32
34
|
`),e.retry&&(t+="retry: "+e.retry+`
|
|
33
35
|
`),t+`
|
|
34
|
-
`}else return typeof e=="object"?`data: ${
|
|
36
|
+
`}else return typeof e=="object"?`data: ${$f(e)}
|
|
35
37
|
|
|
36
38
|
`:`data: ${e}
|
|
37
39
|
|
|
38
|
-
`},compressible:!1,q:.8});hr.set("application/x-www-form-urlencoded",{deserialize(e){let t={};for(let[r,n]of new URLSearchParams(e))if(t.hasOwnProperty(r)){let s=t[r];Array.isArray(s)?s.push(n):t.key=[s,n]}else t[r]=n},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});wk={type:"application/json",serializeStream:du,serialize:f_,deserialize:Toe,q:.5};hr.set("*/*",wk);hr.set("",wk);a(Toe,"tryJSONParse");a($b,"registerContentHandlers");goe=require("fastify-plugin"),Roe=goe(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=Rm(n.raw);s.type(c),s.serializer(function(l){return(o.serializeStream||o.serialize)(l,{headers:{set:(d,u)=>{s.header(d,u)}}})})}),r()},{name:"content-type-negotiation"});a(Rm,"findBestSerializer");Ak=Fb.default.get(Gb.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(h_,"serialize");a(va,"serializeMessage");a(Aoe,"streamToBuffer");a(Fa,"getDeserializer");a(bk,"deserializerUnknownType");a(boe,"transformIterable")});function Wb(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let _=d(l);for(let f=1;f<e.length;f++){let h=e[f],p=d(h);_=_.concat(p)}let E=new Set;return _.filter(f=>{let h=f.key??f;return E.has(h)?!1:(E.add(h),!0)})}else{let _=d(l),E=u(e.slice(1),!0,l.estimated_count);return E.length>0?o(_,E):_}function d(_){return _.conditions?Wb(_.conditions,_.operator,r,n,s,i,o,c):yl(_,n,_.descending||s.reverse===!0,r,s.allowFullScan,c)}a(d,"executeCondition");function u(_,E,f){return _.map((h,p)=>{if(h.conditions){let T=h.operator==="or",A=u(h.conditions,!T,f);return T?(I,V)=>A.some(x=>x(I,V)):(I,V)=>A.every(x=>x(I,V))}let S=(h.attribute||h[0])===r.primaryKey,g=zb(h,r,i,c,S,f);return E&&p<_.length-1&&f&&(f=Poe(r.primaryStore,h.estimated_count,f)),g}).filter(Boolean)}a(u,"mapConditionsToFilters")}function yl(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(Array.isArray(o)){let T=o[0],A=ri(n.attributes,T);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 I=A.definition?.tableClass||A.elements?.definition?.tableClass,V=new Map,x=yl({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,I,s,V);if(A.relationship.to){i[o[0]]=V;let X=!!ri(I.attributes,A.relationship.to)?.elements;x=woe(x,A,I.primaryStore,X,V)}if(A.relationship.from){let X=a($=>yl({attribute:A.relationship.from,value:$},t,r,n,s,V),"searchEntry");A.elements?(i[o[0]]=V,x=Coe(x,A,I.primaryStore,V,X)):x=x.flatMap(X)}return x}else if(o.length===1)o=o[0];else throw new Mn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let d,u,_,E;c instanceof Date&&(c=c.getTime());let f;switch(Qb[l]||l){case"lt":d=!0,u=c;break;case"le":d=!0,u=c,_=!0;break;case"gt":d=c,E=!0;break;case"ge":d=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],d=c,u=c.slice(0),u[u.length-1]=ti.MAXIMUM_KEY;break;case"starts_with":d=c.toString(),u=c+"\uFFFF";break;case"between":d=c[0],d instanceof Date&&(d=d.getTime()),u=c[1],u instanceof Date&&(u=u.getTime()),_=!0;break;case"equals":case void 0:d=c,u=c,_=!0;break;case"ne":if(c===null){d=c,E=!0;break}case"sort":case"contains":case"ends_with":d=!0,f=!0;break;default:throw new Mn.ClientError(`Unknown query comparator "${l}"`)}if(r){let T=d;d=u,u=T,T=!E,E=!_,_=T}let h=o===n.primaryKey||o==null,p=h?n.primaryStore:n.indices[o],S;if(!p||p.isIndexing||f||c===null&&!p.indexNulls){if(s===!1&&!p)throw new Mn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&f)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(p?.isIndexing)throw new Mn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&!p.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(S=zb(e),!S)throw new Mn.ClientError(`Unknown search operator ${e.comparator}`)}let g={start:d,end:u,inclusiveEnd:_,exclusiveStart:E,values:!0,versions:h,transaction:t,reverse:r};if(h){let T=p.getRange(g).map(S?function({key:A,value:I}){return this.isSync?I&&S(I)?A:Lo.SKIP:new Promise((V,x)=>setImmediate(()=>{try{V(I&&S(I)?A:Lo.SKIP)}catch(X){x(X)}}))}:A=>A.value==null?Lo.SKIP:A);return T.hasEntries=!0,T}else return p?p.getRange(g).map(S?function({key:T,value:A}){return this.isSync?S({[o]:T})?A:Lo.SKIP:new Promise((I,V)=>setImmediate(()=>{try{I(S({[o]:T})?A:Lo.SKIP)}catch(x){V(x)}}))}:({value:T})=>T):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:T,value:A}){return this.isSync?A&&S(A)?T:Lo.SKIP:new Promise((I,V)=>setImmediate(()=>{try{I(A&&S(A)?T:Lo.SKIP)}catch(x){V(x)}}))})}function ri(e,t){if(Array.isArray(t))if(t.length>1){let r=ri(e,t[0]),n=(r?.definition?.tableClass||r?.elements.definition?.tableClass)?.attributes;return n?ri(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 woe(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;s.hasMappings=!0;let o;return{next(){if(!i){let l=t.relationship.to,d=a((u,_)=>{let E=u;Array.isArray(u)&&(E=bs(u),o=!0);let f=s.get(E);f?f.push(_):s.set(E,f=[_]),u!==E&&(f.key=u)},"add_entry");for(let u of e){let _=u.value??r.get(u.key??u),E=_?.[l];if(E!=null&&!s.filters?.some(f=>!f(_)))if(n)for(let f=0;f<E.length;f++)d(E[f],u);else d(E,u)}return i=(o?s:s.keys())[Symbol.iterator](),this.next()}let c=i.next();return c.done?c:{value:o?c.value[1].key||c.value[0]:c.value}},return(){if(i?.return)return i.return()}}}})}function Coe(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 d=bs(l.value);if(!c.has(d))return c.add(d),l}if(!i){let d=new Map;n.fromRecord=u=>u[t.relationship.from]?.filter?.(_=>d.has(bs(_)));for(let u of e){if(n.filters){let _=r.get(u);if(n.filters.some(E=>!E(_)))continue}d.set(bs(u),u)}return i=d.values()[Symbol.iterator](),this.next()}do{let d=i.next();return d.done?d:(o=s(d.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function zb(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 u=c[0],_=ri(t.attributes,u),E=_.definition?.tableClass||_.elements.definition?.tableClass,f=n?.[u],h=zb({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},E,r,f?.[u]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(f){f.filters||(f.filters=[]),f.filters.push(h);return}let p=t.propertyResolvers?.[u],S,g=a((T,A)=>{let I,V;if(p){if(p.from&&h.idFilter){if(!S)if(h.idFilter.idSet?.size===1){for(let X of h.idFilter.idSet)e={attribute:p.from,value:X};S=d(p.from,h.idFilter,!0,!0)}else S=d(p.from,h.idFilter,!1,!0);let x=S(T);return S.idFilter&&(g.idFilter=S.idFilter),x}V=p(T,r,A),I=V?.value}else I=T[u];return I?Array.isArray(I)?I.some(h):h(I,V):!1},"recordFilter");return g}}switch(l instanceof Date&&(l=l.getTime()),Qb[o]||o){case Yb.SEARCH_TYPES.EQUALS:case void 0:return d(c,u=>u===l,!0);case"contains":return d(c,u=>u?.toString().includes(l));case"ends_with":return d(c,u=>u?.toString().endsWith(l));case"starts_with":return d(c,u=>typeof u=="string"&&u.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],d(c,u=>{if(!Array.isArray(u))return!1;for(let _=0,E=l.length;_<E;_++)if(u[_]!==l[_])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()),d(c,u=>(0,ti.compareKeys)(u,l[0])>=0&&(0,ti.compareKeys)(u,l[1])<=0,!0);case"gt":return d(c,u=>(0,ti.compareKeys)(u,l)>0);case"ge":return d(c,u=>(0,ti.compareKeys)(u,l)>=0);case"lt":return d(c,u=>(0,ti.compareKeys)(u,l)<0);case"le":return d(c,u=>(0,ti.compareKeys)(u,l)<=0);case"ne":return d(c,u=>(0,ti.compareKeys)(u,l)!==0);case"sort":return()=>!0;default:throw new Mn.ClientError(`Unknown query comparator "${o}"`)}function d(u,_,E,f){let h;E=E&&!s&&t?.indices[u]&&i>3,E&&(e.estimated_count==null&&bm(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let p=0,S=3;function g(T){let A=T[u],I;if(typeof A!="object"||!A||f?I=_(A):Array.isArray(A)?I=A.some(_):A instanceof Date&&(I=_(A.getTime())),E&&(S++,!I&&!g.idFilter&&++p/S*(i-S)>h)){let V=yl(e,r.transaction.getReadTxn(),!1,t).map(bs),x=new Set(V);g.idFilter=X=>x.has(bs(X)),g.idFilter.idSet=x}return I}return a(g,"recordFilter"),s&&(g.idFilter=_),g}a(d,"attributeComparator")}function bm(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/Fi(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=Qb[n]||n,n===Yb.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=ri(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=bm(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*Fi(e.indices[i.relationship.from])/(Fi(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=Fi(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=Noe*Fi(e.primaryStore)+1:n==="between"?r.estimated_count=Ooe*Fi(e.primaryStore)+1:n==="sort"?r.estimated_count=Fi(e.primaryStore)+1:r.estimated_count=yoe*Fi(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function ym(e){if(e)if(Po=e,Al.lastIndex=0,Doe.test(e))try{let t=m_(new bl,"");if(ln!==Po.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 ${ln} in '${Po}'`,t}else return new URLSearchParams(e)}function m_(e,t){let r=Al,n,s,i,o,c,l=decodeURIComponent,d;for(;n=r.exec(Po);){ln=r.lastIndex;let[,u,_]=n;if(o){if(u)throw new SyntaxError(`expected operator, but encountered '${u}'`);o=!1,c=!1}else c=!0;let E;switch(_){case"=":if(s){if(u.length<=2)i=u;else throw new SyntaxError(`invalid FIQL operator ${u}`);l=Dk}else{if(l=decodeURIComponent,i="equals",!u)throw new SyntaxError("attribute must be specified before equality comparator");s=p_(u)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=Ioe[_],l=Kb[i]?Dk:decodeURIComponent,!u)throw new SyntaxError(`attribute must be specified before comparator ${_}`);s=p_(u);break;case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${_[0]?"'"+_[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${_?"'"+_+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s,value:l(u)};i==="eq"&&Lk(h,u),Am(e,d),e.conditions.push(h)}_==="&"&&(d="and"),_==="|"&&(d="or"),s=void 0;break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(p_(u)),s=void 0;break;case"(":Al.lastIndex=ln;let f=m_(u?[]:new bl,")");switch(u){case"":Am(e,d),e.conditions.push(f);break;case"limit":switch(f.length){case 1:e.limit=+f[0];break;case 2:e.offset=+f[0],e.limit=f[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(f[0])&&f.length===1&&!f[0].name?(e.select=f[0],e.select.asArray=!0):f.length===1?e.select=f[0]:f.length===2&&f[1]===""?e.select=f.slice(0,1):e.select=f;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=Pk(f);break;default:throw new SyntaxError(`unknown query function call ${u}`)}Po[ln]===","?r.lastIndex=++ln:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!u)throw new SyntaxError("property sets must have a defined parent property name");Al.lastIndex=ln,E=m_([],"}"),E.name=u,e.push(E),Po[ln]===","?r.lastIndex=++ln:o=!0;break;case"[":Al.lastIndex=ln,u?(E=m_(new bl,"]"),E.name=u):E=m_(e.conditions?new bl:[],"]"),e.conditions?(Am(e,d),e.conditions.push(E),s=null):e.push(E),Po[ln]===","?r.lastIndex=++ln:o=!0;break;case")":case"]":case"}":if(t===_[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(u)};i==="eq"&&Lk(h,u),Am(e,d),e.conditions.push(h)}else if(u)throw new SyntaxError("no attribute or comparison specified")}else(u||e.length>0&&c)&&e.push(p_(u));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${_[0]}'`):new SyntaxError(`unexpected token '${_[0]}'`);default:throw new SyntaxError(`unexpected operator '${_}'`)}if(t!==")"&&(r=s?Loe:Al,r.lastIndex=ln),ln===Po.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function Am(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 p_(e){return e.indexOf(".")>-1?e.split(".").map(p_):decodeURIComponent(e)}function Dk(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 Lk(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 Pk(e){let t=Mk(e[0]);return e.length>1&&(t.next=Pk(e.slice(1))),t}function Mk(e){if(Array.isArray(e)){let t=Mk(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 bs(e){return Array.isArray(e)?e.join("\0"):e}function Fi(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function Poe(e,t,r){return t*r/Fi(e)}var Mn,Yb,ti,Lo,yoe,Ooe,Noe,Ioe,Kb,Qb,Doe,Al,Loe,ln,Po,bl,Ga,S_=Oe(()=>{Mn=v(ce()),Yb=v(Gt()),ti=require("ordered-binary"),Lo=require("lmdb"),yoe=.3,Ooe=.1,Noe=.05,Ioe={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},Kb={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(Wb,"executeConditions");a(yl,"searchByIndex");a(ri,"findAttribute");a(woe,"joinTo");a(Coe,"joinFrom");Qb={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(zb,"filterByType");a(bm,"estimateCondition");Doe=/[()[\]|!<>.]|(=\w*=)/,Al=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,Loe=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(ym,"parseQuery");a(m_,"parseBlock");a(Am,"assignOperator");a(p_,"decodeProperty");a(Dk,"typedDecoding");a(Lk,"wildcardDecoding");a(Pk,"toSortObject");a(Mk,"toSortEntry");bl=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(bs,"flattenKey");a(Fi,"estimatedEntryCount");a(Poe,"intersectionEstimate");Ga=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});function Hk(e){let t={openapi:Moe,info:{title:"HarperDB HTTP REST interface",version:(0,Bk.version)()},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let d={},u=[];if(o)for(let{type:A,name:I,elements:V,relationship:x,definition:X}of o){if(x)A==="array"?d[I]={type:"array",items:{$ref:Mo+V.type}}:d[I]={$ref:Mo+A};else{let $=X??V?.definition;if($){if(!t.components.schemas[$.type]){let F={};$.properties.forEach(se=>{F[se.name]=new Zb(jb[se.type],se.type)}),t.components.schemas[$.type]=new xk(F)}A==="array"?d[I]={type:"array",items:{$ref:Mo+$.type}}:d[I]={$ref:Mo+$.type}}else A==="array"?V.type==="Any"||V.type=="ID"?d[I]={type:"array",items:{format:V.type}}:d[I]={type:"array",items:new Zb(jb[V.type],V.type)}:A==="Any"||A=="ID"?d[I]={format:A}:d[I]=new Zb(jb[A],A)}u.push(new ey(I,"query",d[I]))}let _=Object.keys(d),E=new ey(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new ey("property","path",{enum:_});f.required=!0,t.components.schemas[i]=new xk(d);let h=l.post!==Resource.prototype.post||l.update,p=typeof l.put=="function",S=typeof l.get=="function",g=typeof l.delete=="function",T="/"+s+"/";h&&(t.paths[T]={},t.paths[T].post=new Uoe(i,r,"create a new record auto-assigning a primary key")),S&&(t.paths[T]||(t.paths[T]={}),t.paths[T].get=new Jb(u,r,{200:new Xb({$ref:Mo+i})},"search for records by the specified property name and value pairs")),g&&(t.paths[T]||(t.paths[T]={}),t.paths[T].delete=new vk(u,r,"delete all the records that match the provided query",{204:new Uk})),T="/"+s+"/{"+c+"}",S&&(t.paths[T]={},t.paths[T].get=new Jb([E],r,{200:new Xb({$ref:Mo+i})},"retrieve a record by its primary key")),p&&(t.paths[T]||(t.paths[T]={}),t.paths[T].put=new voe([E],r,i,"create or update the record with the URL path that maps to the record's primary key")),g&&(t.paths[T]||(t.paths[T]={}),t.paths[T].delete=new vk([E],r,"delete a record with the given primary key",{204:new Uk})),S&&f.schema.enum.length>0&&(T="/"+s+"/{"+c+"}.{property}",t.paths[T]={},t.paths[T].get=new Jb([E,f],r,{200:new Xb({enum:_})},"used to retrieve the specified property of the specified record"))}return t}function Uoe(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Mo+e}}}},this.security=t,this.responses={200:{description:ty,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function Jb(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function Xb(e){this.description=ty,this.content={"application/json":{schema:e}}}function Uk(){this.description="successfully processed request, no content returned to client"}function voe(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Mo+r}}}},this.responses={200:{description:ty}}}function vk(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function xk(e){this.type="object",this.properties=e}function Zb(e,t){this.type=e,this.format=t}function ey(e,t,r){this.name=e,this.in=t,this.schema=r}var Bk,Moe,jb,Mo,ty,kk=Oe(()=>{Bk=v(rh()),Moe="3.0.3",jb={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Mo="#/components/schemas/",ty="successful operation";a(Hk,"generateJsonApi");a(Uoe,"Post");a(Jb,"Get");a(Xb,"Response200");a(Uk,"Response204");a(voe,"Put");a(vk,"Delete");a(xk,"ResourceSchema");a(Zb,"Type");a(ey,"Parameter")});var Nm={};Ze(Nm,{start:()=>Hoe});async function Boe(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&ym(e);let i=new Ui;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==Fk){let S=Om.getMatch(o,n?"sse":"rest");if(!S)return t(e);e.handlerPath=S.path,c=new Ga(S.relativeURL),c.async=!0,l=S.Resource}let d=r["cache-control"];if(d){let S=Vk(d);for(let g of S)switch(g.name){case"max-age":e.expiresAt=g.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 S=Vk(u).map(g=>(g.next?.name==="confirm"&&g.next.value>=0&&(e.replicatedConfirmation=+g.next.value),g.name));e.replicateTo=S.length===1&&+S[0]>=0?+S[0]:S[0]==="*"?void 0:S}let _=await gt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=Fa(r["content-type"],!0)(e.body,e.headers)}catch(S){throw new Ol.ClientError(S,400)}if(e.authorize=!0,o===Fk&&s==="GET"){if(e?.user?.role?.permission?.super_user)return Hk(Om);throw new Ol.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 Ol.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Ol.ServerError(`Method ${s} is not recognized`,501)}}),E=200,f;if(_==null)E=s==="GET"||s==="HEAD"?404:204,ry.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else{if(_.status>0&&_.headers)return _.headers=Eb(_.headers,i),_.data!==void 0&&(_.body=h_(_.data,e,_)),_;if(f=e.lastModified){xoe[0]=f;let S=String.fromCharCode(34,(yr[0]&63)+62,(yr[0]>>6)+(yr[1]<<2&63)+62,(yr[1]>>4)+(yr[2]<<4&63)+62,(yr[2]>>2)+62,(yr[3]&63)+62,(yr[3]>>6)+(yr[4]<<2&63)+62,(yr[4]>>4)+(yr[5]<<4&63)+62,(yr[5]>>2)+62,(yr[6]&63)+62,(yr[6]>>6)+(yr[7]<<2&63)+62,34),g=r["if-none-match"];g&&S==g?(_?.onDone&&_.onDone(),E=304,_=void 0):i.setIfNone("ETag",S),ry.lastModified&&i.setIfNone("Last-Modified",new Date(f).toUTCString())}}e.createdResource&&(E=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:E,headers:i,body:void 0},p=_?.wasLoadedFromSource?.();return p!==void 0&&(h.wasCacheMiss=p,!p&&f&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||f))/1e3))),_!==void 0&&(h.body=h_(_,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?qa.warn(o):qa.info(o):qa.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=h_(o.contentType?o:o.toString(),e,c),c}}function Hoe(e){ry=e,!Gk&&(Gk=!0,Om=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Boe(t,r)},e),e.server.ws(async(t,r,n)=>{T_++;let s=new mn;qk||(qk=!0,td(l=>{T_>0&&l.push({metric:"ws-connections",connections:T_,byThread:!0})}));let i;t.on("error",l=>{i=!0,qa.warn(l)});let o;t.on("message",a(function(d){o||(o=Fa(r.headers.asObject["content-type"]));let u=o(d);s.push(u)},"message"));let c;t.on("close",()=>{T_--,wn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),d=Om.getMatch(l,"ws");if(wn(!!d,"connection","ws","connect"),d){r.handlerPath=d.path,Qr(h=>({count:h.count,total:T_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let u=new Ga(d.relativeURL),_=d.Resource;c=(await gt(r,()=>_.connect(u,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=va(f.value,r);t.send(h),Qr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){t.close(koe[l.statusCode]||1011,l.toString())}t.close()},e))}function Vk(e){return e.split(/\s*,\s*/).map(r=>{let n,s=r.split(/\s*;\s*/),i;for(;i=s.pop();)if(i.includes("=")){let[o,c]=i.split(/\s*=\s*/);n={name:o.toLowerCase(),value:c,next:n}}else n={name:i.toLowerCase(),next:n};return n})}var qa,Ol,yr,xoe,ry,Fk,Gk,Om,qk,T_,koe,$k=Oe(()=>{hl();yi();qa=v(j()),Ol=v(ce());S_();cc();ca();Zd();kk();S_();yr=new Uint8Array(8),xoe=new Float64Array(yr.buffer,0,1),ry={},Fk="openapi";a(Boe,"http");T_=0;a(Hoe,"start");koe={401:3e3,403:3003};a(Vk,"parseHeaderValue")});var ny=N((Cbe,Yk)=>{var{recordAction:Im,recordActionBinary:Foe}=(yi(),ae(rd)),Goe=require("fastify-plugin"),qoe=200;Yk.exports=Goe(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,d,u,_;l.config?.isOperation?(d=n.body?.operation,u="operation"):(d=l.url,u="fastify-route",_=l.method),Im(o,"duration",d,_,u),Foe(s.raw.statusCode<400,"success",d,_,u);let E=qoe;i?.pipe?(i.on("data",S=>{E+=S.length}),i.on("end",()=>{Im(performance.now()-c,"transfer",d,_,u),Im(E,"bytes-sent",d,_,u)})):(E+=i?.length||0,Im(E,"bytes-sent",d,_,u));let f=o.toFixed(3),h=s.getHeader("Server-Timing"),p=`db;dur=${f}`;s.header("Server-Timing",h?`${h}, ${p}`:p)}),r()},{name:"hdb-request-time"})});var ly=N((Pbe,zk)=>{var Lm=require("clone"),Pm=ct(),Voe=te(),Cm=M(),Dbe=j(),sy=require("fs"),oy=require("joi"),{string:Dm}=oy.types(),{hdb_errors:$oe,handleHDBError:wm}=ce(),{HDB_ERROR_MSGS:Lbe,HTTP_STATUS_CODES:iy}=$oe,{common_validators:Nl}=Bs(),Kk=" is required",Yoe=["insert","update","upsert"],ay={database:{presence:!1,format:Nl.schema_format,length:Nl.schema_length},schema:{presence:!1,format:Nl.schema_format,length:Nl.schema_length},table:{presence:!0,format:Nl.schema_format,length:Nl.schema_length},action:{inclusion:{within:Yoe,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},Koe={schema:Dm.required(),table:Dm.required(),action:Dm.valid("insert","update","upsert")},{AWS_ACCESS_KEY:Woe,AWS_SECRET:Qoe,AWS_BUCKET:zoe,AWS_FILE_KEY:joe,REGION:Joe}=Cm.S3_BUCKET_AUTH_KEYS,Xoe={s3:{presence:!0},[`s3.${Woe}`]:{presence:!0,type:"String"},[`s3.${Qoe}`]:{presence:!0,type:"String"},[`s3.${zoe}`]:{presence:!0,type:"String"},[`s3.${joe}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${Joe}`]:{presence:!0,type:"String"}},Wk=Lm(ay);Wk.data.presence={message:Kk};var Qk=Lm(ay);Qk.file_path.presence={message:Kk};var Zoe=Object.assign(Lm(ay),Xoe),cy=Lm(Koe);cy.csv_url=Dm.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();cy.passthrough_headers=oy.object();function eae(e){let t=Pm.validateObject(e,Wk);return Mm(e,t)}a(eae,"dataObject");function tae(e){let t=Pm.validateBySchema(e,oy.object(cy));return Mm(e,t)}a(tae,"urlObject");function rae(e){let t=Pm.validateObject(e,Qk);return Mm(e,t)}a(rae,"fileObject");function nae(e){let t=Pm.validateObject(e,Zoe);return Mm(e,t)}a(nae,"s3FileObject");function Mm(e,t){if(!t){let r=Voe.checkGlobalSchemaTable(e.schema,e.table);if(r)return wm(new Error,r,iy.BAD_REQUEST);if(e.operation===Cm.OPERATIONS_ENUM.CSV_FILE_LOAD)try{sy.accessSync(e.file_path,sy.constants.R_OK|sy.constants.F_OK)}catch(n){return n.code===Cm.NODE_ERROR_CODES.ENOENT?wm(n,`No such file or directory ${n.path}`,iy.BAD_REQUEST):n.code===Cm.NODE_ERROR_CODES.EACCES?wm(n,`Permission denied ${n.path}`,iy.BAD_REQUEST):wm(n)}}return t}a(Mm,"postValidateChecks");zk.exports={dataObject:eae,urlObject:tae,fileObject:rae,s3FileObject:nae}});var uy=N((Ube,jk)=>{"use strict";var g_=j(),Um=M();async function sae(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===Um.OPERATIONS_ENUM.INSERT||t.operation===Um.OPERATIONS_ENUM.UPDATE||t.operation===Um.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===Um.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(g_.info(i.message),i):i.http_resp_msg?(g_.error(`Error calling operation: ${e.name}`),g_.error(i.http_resp_msg),i):(g_.error(`Error calling operation: ${e.name}`),g_.error(i),i)}}a(sae,"callOperationFunctionAsAwait");jk.exports={callOperationFunctionAsAwait:sae}});var Xk=N((xbe,Jk)=>{"use strict";var dy=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}},_y=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};Jk.exports={BulkLoadFileObject:dy,BulkLoadDataObject:_y}});var eF=N((Hbe,Zk)=>{"use strict";var fy=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};Zk.exports=fy});var Ty=N(($be,pF)=>{"use strict";var vm=Rn(),Bm=ly(),iae=require("needle"),ys=M(),Fbe=lt(),Il=te(),{handleHDBError:Bt,hdb_errors:lF}=ce(),{HTTP_STATUS_CODES:Or,HDB_ERROR_MSGS:cr,CHECK_LOGS_WRAPPER:$a}=lF,wl=j(),Ey=require("papaparse");Il.promisifyPapaParse();var Os=require("fs-extra"),oae=require("path"),{chain:tF}=require("stream-chain"),rF=require("stream-json/streamers/StreamArray"),nF=require("stream-json/utils/Batch"),sF=require("stream-chain/utils/comp"),{finished:iF}=require("stream"),aae=ne(),uF=uy(),cae=Bb(),{BulkLoadFileObject:my,BulkLoadDataObject:lae}=Xk(),py=Ib(),{verifyBulkLoadAttributePerms:dF}=hm(),Gbe=eF(),qbe=Mt(),Vbe=pi(),{databases:uae}=(Ne(),ae(ot)),{coerceType:dae}=(Hm(),ae(gy)),oF="No records parsed from csv file.",Va=`${aae.get("HDB_ROOT")}/tmp`,{schema_regex:_ae}=Bs(),aF=1024*1024*2,cF=5e3,fae={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};pF.exports={csvDataLoad:Eae,csvURLLoad:hae,csvFileLoad:mae,importFromS3:pae};async function Eae(e,t){let r=Bm.dataObject(e);if(r)throw Bt(r,r.message,Or.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=EF(e.schema,e.table),i=Ey.parse(e.data,{header:!0,skipEmptyLines:!0,transform:hy.bind(null,s),dynamicTyping:!1}),o=new py;e.hdb_user&&e.hdb_user.role&&e.hdb_user.role.permission&&e.hdb_user.role.permission.super_user!==!0&&dF(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 Bt(new Error,c,Or.BAD_REQUEST,void 0,void 0,!0);let l=new lae(e.action,e.schema,e.table,i.data);return n=await uF.callOperationFunctionAsAwait(hF,l,null),n.message===oF?oF:mF(n.records,n.number_written)}catch(s){throw Ya(s)}}a(Eae,"csvDataLoad");async function hae(e){let t=Bm.urlObject(e);if(t)throw Bt(t,t.message,Or.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Va}/${r}`;try{await Sae(e,r)}catch(s){throw wl.error(cr.DOWNLOAD_FILE_ERR(r)+" - "+s),Bt(s,$a(cr.DOWNLOAD_FILE_ERR(r)))}try{let s=new my(this.job_operation_function.name,e.action,e.schema,e.table,n,ys.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission),i=await Sy(s);return await xm(n),i}catch(s){throw await xm(n),Ya(s)}}a(hae,"csvURLLoad");async function mae(e){let t=Bm.fileObject(e);if(t)throw Bt(t,t.message,Or.BAD_REQUEST,void 0,void 0,!0);let r=new my(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,ys.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission);try{return await Sy(r)}catch(n){throw Ya(n)}}a(mae,"csvFileLoad");async function pae(e){let t=Bm.s3FileObject(e);if(t)throw Bt(t,t.message,Or.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=oae.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Va}/${s}`;let i=new my(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user.role.permission);await Tae(s,e);let o=await Sy(i);return await xm(r),o}catch(n){throw await xm(r),Ya(n)}}a(pae,"importFromS3");async function Sae(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await iae("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 Bt(n,s,n.statusCode,ys.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Rae(r,e.csv_url),await gae(t,r.raw)}a(Sae,"downloadCSVFile");async function Tae(e,t){try{let r=`${Va}/${e}`;await Os.mkdirp(Va),await Os.writeFile(`${Va}/${e}`,"",{flag:"a+"});let n=await Os.createWriteStream(r),s=await cae.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(){wl.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw wl.error(cr.S3_DOWNLOAD_ERR+" - "+r),Bt(r,$a(cr.S3_DOWNLOAD_ERR))}}a(Tae,"downloadFileFromS3");async function gae(e,t){try{await Os.mkdirp(Va),await Os.writeFile(`${Va}/${e}`,t)}catch(r){throw wl.error(cr.WRITE_TEMP_FILE_ERR),Bt(r,$a(cr.DEFAULT_BULK_LOAD_ERR))}}a(gae,"writeFileToTempFolder");async function xm(e){if(e)try{await Os.access(e),await Os.unlink(e)}catch{wl.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(xm,"deleteTempFile");function Rae(e,t){if(e.statusCode!==lF.HTTP_STATUS_CODES.OK)throw Bt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Or.BAD_REQUEST);if(!fae[e.headers["content-type"]])throw Bt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Or.BAD_REQUEST);if(!e.raw)throw Bt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Or.BAD_REQUEST)}a(Rae,"validateURLResponse");async function Sy(e){try{let t;switch(e.file_type){case ys.VALID_S3_FILE_TYPES.CSV:t=await Aae(e);break;case ys.VALID_S3_FILE_TYPES.JSON:t=await bae(e);break;default:throw Bt(new Error,cr.DEFAULT_BULK_LOAD_ERR,Or.BAD_REQUEST,ys.LOG_LEVELS.ERROR,cr.INVALID_FILE_EXT_ERR(e))}return mF(t.records,t.number_written)}catch(t){throw Ya(t)}}a(Sy,"fileLoad");async function _F(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 vm.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&dF(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=Bt(c);r(l)}}a(_F,"validateChunk");async function fF(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Il.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Il.isEmpty(c)&&!Il.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(d=>c.add(d))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await uF.callOperationFunctionAsAwait(hF,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=Bt(c,$a(cr.INSERT_CSV_ERR),Or.INTERNAL_SERVER_ERROR,ys.LOG_LEVELS.ERROR,cr.INSERT_CSV_ERR+" - "+c);r(l)}}a(fF,"insertChunk");async function Aae(e){let t={records:0,number_written:0},r=EF(e.schema,e.table);try{let n=new py,s=Os.createReadStream(e.file_path,{highWaterMark:aF});s.setEncoding("utf8"),await Ey.parsePromise(s,_F.bind(null,e,n),hy.bind(null,r));let i=n.getPermsResponse();if(i)throw Bt(new Error,i,Or.BAD_REQUEST);return s=Os.createReadStream(e.file_path,{highWaterMark:aF}),s.setEncoding("utf8"),await Ey.parsePromise(s,fF.bind(null,e,t),hy.bind(null,r)),s.destroy(),t}catch(n){throw Bt(n,$a(cr.PAPA_PARSE_ERR),Or.INTERNAL_SERVER_ERROR,ys.LOG_LEVELS.ERROR,cr.PAPA_PARSE_ERR+n)}}a(Aae,"callPapaParse");function EF(e,t){let r=uae[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>dae(i,s));return n}a(EF,"createTransformMap");function hy(e,t,r){let n=e.get(r);return n?n(t):Il.autoCast(t)}a(hy,"typeFunction");async function bae(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new py,s=tF([Os.createReadStream(e.file_path,{encoding:"utf-8"}),rF.withParser(),c=>c.value,new nF({batchSize:cF}),sF(async c=>{await _F(e,n,r,c)})]);await new Promise((c,l)=>{iF(s,d=>{d?l(d):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw Bt(new Error,i,Or.BAD_REQUEST);let o=tF([Os.createReadStream(e.file_path,{encoding:"utf-8"}),rF.withParser(),c=>c.value,new nF({batchSize:cF}),sF(async c=>{await fF(e,t,r,c)})]);return await new Promise((c,l)=>{iF(o,d=>{d?l(d):c()}),o.resume()}),t}catch(n){throw Bt(n,$a(cr.INSERT_JSON_ERR),Or.INTERNAL_SERVER_ERROR,ys.LOG_LEVELS.ERROR,cr.INSERT_JSON_ERR+n)}}a(bae,"insertJson");async function hF(e){let t={};try{e.data&&e.data.length>0&&yae(e.data[0])?t=await Oae(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",wl.info(t.message))}catch(r){throw Ya(r)}return t}a(hF,"callBulkFileLoad");function yae(e){let t=Object.keys(e);for(let r of t)if(!_ae.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(yae,"validateColumnNames");async function Oae(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=vm.insert;break;case"update":i=vm.update;break;case"upsert":i=vm.upsert;break;default:throw Bt(new Error,cr.INVALID_ACTION_PARAM_ERR(n),Or.BAD_REQUEST,ys.LOG_LEVELS.ERROR,cr.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 u=global.hdb_schema[t][r].hash_attribute,_=e.length;for(;_--;)o.skipped_hashes.indexOf(e[_][u])>=0&&e.splice(_,1)}let l=Il.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw Ya(o)}}a(Oae,"bulkFileLoad");function mF(e,t){return`successfully loaded ${t} of ${e} records`}a(mF,"buildResponseMsg");function Ya(e){return Bt(e,$a(cr.DEFAULT_BULK_LOAD_ERR),Or.INTERNAL_SERVER_ERROR,ys.LOG_LEVELS.ERROR,cr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(Ya,"buildTopLevelErrMsg")});var TF=N((Kbe,SF)=>{"use strict";var Ry=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};SF.exports=Ry});var AF=N((Qbe,RF)=>{"use strict";var Nae=M(),gF=require("moment"),Iae=require("uuid").v4,Ay=class{static{a(this,"JobObject")}constructor(){this.id=Iae(),this.type=void 0,this.start_datetime=gF().valueOf(),this.created_datetime=gF().valueOf(),this.end_datetime=void 0,this.status=Nae.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};RF.exports=Ay});var by=N((jbe,DF)=>{"use strict";var wae=require("uuid").v4,IF=Rn(),wF=gn(),Cae=qs(),Dae=Ic(),Lae=TF(),Rt=M(),Pae=AF(),Mae=zE(),ns=j(),Uae=Iu(),Cl=te(),{promisify:vae}=require("util"),Ka=require("moment"),xae=pm(),km=ly(),bF=hT(),{deleteTransactionLogsBeforeValidator:Bae}=Ab(),{handleHDBError:yF,hdb_errors:Hae}=ce(),{HTTP_STATUS_CODES:OF}=Hae,NF=wF.searchByValue,kae=wF.searchByHash,Fae=IF.insert,Gae=vae(xae.evaluateSQL),qae=IF.update;DF.exports={addJob:Yae,updateJob:Wae,handleGetJob:Vae,handleGetJobsByStartDate:$ae,getJobById:CF};async function Vae(e){try{let t=await CF(e.id);return Cl.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}catch(t){let r=`There was an error getting job: ${t}`;throw ns.error("There was an error getting job",t),new Error(r)}}a(Vae,"handleGetJob");async function $ae(e){try{let t=await Kae(e);if(ns.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=Ka(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Ka(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 ns.error(r),new Error(r)}}a($ae,"handleGetJobsByStartDate");async function Yae(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Cl.isEmptyOrZeroLength(e.operation)){let u="job parameter is invalid";return ns.info(u),t.error=u,t}if(!Rt.JOB_TYPE_ENUM[e.operation])return ns.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case Rt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=km.fileObject(e);break;case Rt.OPERATIONS_ENUM.CSV_URL_LOAD:n=km.urlObject(e);break;case Rt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=km.dataObject(e);break;case Rt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=km.s3FileObject(e);break;case Rt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case Rt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=bF(e,"date");break;case Rt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=bF(e,"timestamp");break;case Rt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=Bae(e);break;case Rt.OPERATIONS_ENUM.RESTART_SERVICE:if(Rt.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw yF(new Error,"Invalid service",OF.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw yF(n,n.message,OF.BAD_REQUEST,void 0,void 0,!0);let s=new Pae;s.type=e.operation===Rt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?Rt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user.username;let i=new Cae(Rt.SYSTEM_SCHEMA_NAME,Rt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await NF(i))}catch(u){let _=`There was an error inserting a new job: ${u}`;return ns.error(_),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=wae();try{o=await NF(i)}catch(u){let _=`There was an error inserting a new job: ${u}`;return ns.error(_),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return ns.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Uae(Rt.SYSTEM_SCHEMA_NAME,Rt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),d;try{d=await Fae(l)}catch(u){return ns.error(`There was an error inserting a job for job type: ${e.operation} -- ${u}`),t.success=!1,t}if(d.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let u=`Created a job with type ${s.type} and id ${s.id}`;t.message=u,t.createdJob=s,t.success=!0,ns.trace(u)}return t}a(Yae,"addJob");async function Kae(e){let t=Ka(e.from_date,Ka.ISO_8601),r=Ka(e.to_date,Ka.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 Lae(n,e.hdb_user);try{return await Gae(s)}catch(i){throw ns.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(Kae,"getJobsInDateRange");async function CF(e){if(Cl.isEmptyOrZeroLength(e))return Cl.errorizeMessage("Invalid job ID specified.");let t=new Dae(Rt.SYSTEM_SCHEMA_NAME,Rt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await kae(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return ns.error(n),Cl.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(CF,"getJobById");async function Wae(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Cl.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===Rt.JOB_STATUS_ENUM.COMPLETE||e.status===Rt.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Ka().valueOf());let t=new Mae(Rt.SYSTEM_SCHEMA_NAME,Rt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await qae(t),r}a(Wae,"updateJob")});var HF=N((Xbe,BF)=>{"use strict";var LF=te(),lr=M(),Qae=require("moment"),Fm=Ty(),R_=j(),PF=by(),MF=Sm(),UF=so(),vF=et(),zae=dm(),jae=Jd(),{parentPort:Jae,isMainThread:xF}=require("worker_threads"),{onMessageByType:Xae}=et(),yy=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Zae(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(LF.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(LF.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case lr.JOB_TYPE_ENUM.csv_file_load:await ni(e,Fm.csvFileLoad);break;case lr.JOB_TYPE_ENUM.csv_url_load:await ni(e,Fm.csvURLLoad);break;case lr.JOB_TYPE_ENUM.csv_data_load:await ni(e,Fm.csvDataLoad);break;case lr.JOB_TYPE_ENUM.import_from_s3:await ni(e,Fm.importFromS3);break;case lr.JOB_TYPE_ENUM.empty_trash:break;case lr.JOB_TYPE_ENUM.export_local:await ni(e,MF.export_local);break;case lr.JOB_TYPE_ENUM.export_to_s3:await ni(e,MF.export_to_s3);break;case lr.JOB_TYPE_ENUM.delete_files_before:case lr.JOB_TYPE_ENUM.delete_records_before:await ni(e,UF.deleteFilesBefore);break;case lr.JOB_TYPE_ENUM.delete_audit_logs_before:await ni(e,UF.deleteAuditLogsBefore);break;case lr.JOB_TYPE_ENUM.delete_transaction_logs_before:await ni(e,zae.deleteTransactionLogsBefore);break;case lr.JOB_TYPE_ENUM.restart_service:return await ni(e,jae.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(Zae,"parseMessage");async function ni(e,t){try{e.job.status=lr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=Qae().valueOf(),await PF.updateJob(e.job),await ece(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):R_.error(`There was an error running ${t.name} job with id ${e.job.id}`),R_.error(n),e.job.message=n,e.job.status=lr.JOB_STATUS_ENUM.ERROR;try{await PF.updateJob(e.job)}catch(s){throw R_.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(ni,"runJob");async function ece(e){R_.trace("launching job thread:",e),xF?vF.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[lr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`})}):Jae.postMessage({type:lr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(ece,"launchJobThread");xF&&Xae(lr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{vF.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:Object.assign({},process.env,{[lr.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`})})}catch(r){R_.error(r)}});BF.exports={parseMessage:Zae,RunnerMessage:yy}});var FF=N((eye,kF)=>{"use strict";var Oy=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};kF.exports=Oy});var sG=N((nye,Ly)=>{"use strict";var Ym=gn(),wy=pm(),Gm=Ty(),Gi=ld(),qm=Si(),y_=so(),tce=uR(),A_=$n(),Vm=TR(),It=Rb(),$m=j(),rce=AR(),nce=Dh(),GF=CA(),sce=Ph(),ice=PA(),oce=MA(),ace=xA(),cce=HA(),Ny=GA(),qF=Sm(),lce=hm(),Cy=by(),G=M(),{hdb_errors:N_,handleHDBError:O_}=ce(),{HTTP_STATUS_CODES:VF}=N_,Iy=KA(),$F=Jd(),eG=require("util"),Dl=Rn(),uce=Ti(),dce=Vc(),YF=HF(),KF=Ed(),WF=(Xh(),ae(e_)),QF=dr(),zF=dm(),jF=sm(),{setServerUtilities:_ce}=(Hm(),ae(gy)),{CONTEXT:rye}=(us(),ae(dg)),{_assignPackageExport:fce}=require("../index"),{transformReq:Ece}=te(),{server:hce}=(Lr(),ae(qo)),kr=$m.loggerWithTag("operation"),b_=bo(),JF=(wa(),ae(Ia)),mce=uy(),XF=Ym.searchByHash,pce=Ym.searchByValue,Sce=eG.promisify(Ym.search),Tce=eG.promisify(wy.evaluateSQL),gce={[G.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[G.OPERATIONS_ENUM.CREATE_TABLE]:!0,[G.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[G.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[G.OPERATIONS_ENUM.DROP_TABLE]:!0,[G.OPERATIONS_ENUM.DROP_SCHEMA]:!0},Q=FF();async function tG(e,t){try{if(e.body.operation!=="read_log"&&($m.log_level===G.LOG_LEVELS.INFO||$m.log_level===G.LOG_LEVELS.DEBUG||$m.log_level===G.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;kr.info(o)}}catch(n){kr.error(n)}let r=await mce.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return gce[e.body.operation]&&uce.setSchemaDataToGlobal(n=>{n&&kr.error(n)}),r}a(tG,"processLocalTransaction");var ZF=Ace();Ly.exports={chooseOperation:rG,getOperationFunction:nG,operation:Dy,processLocalTransaction:tG};_ce(Ly.exports);hce.operation=Dy;function rG(e){let t;try{t=nG(e)}catch(s){throw kr.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=wy.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=wy.checkASTPermissions(e,i);if(o)throw kr.error(`${VF.FORBIDDEN} from operation ${e.operation}`),kr.warn(`User '${e.hdb_user.username}' is not permitted to ${e.operation}`),O_(new Error,o,N_.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==G.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==G.OPERATIONS_ENUM.LOGIN&&e.operation!==G.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=lce.verifyPerms(i,s);if(o)throw kr.error(`${VF.FORBIDDEN} from operation ${e.operation}`),kr.warn(`User '${i.hdb_user.username}' is not permitted to ${i.operation}`),O_(new Error,o,N_.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw O_(s,"There was an error when trying to choose an operation path")}return r}a(rG,"chooseOperation");function nG(e){if(kr.trace(`getOperationFunction with operation: ${e.operation}`),ZF.has(e.operation))return ZF.get(e.operation);throw O_(new Error,N_.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),N_.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(nG,"getOperationFunction");fce("operation",Dy);function Dy(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=rG(e);return tG({body:e},n)}a(Dy,"operation");async function Rce(e){kr.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[G.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case G.OPERATIONS_ENUM.INSERT:o=await Dl.insert(i);break;case G.OPERATIONS_ENUM.UPDATE:o=await Dl.update(i);break;case G.OPERATIONS_ENUM.UPSERT:o=await Dl.upsert(i);break;case G.OPERATIONS_ENUM.DELETE:o=await y_.deleteRecord(i);break;default:kr.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){kr.info("Invalid operation in transaction"),kr.error(o)}}a(Rce,"catchup");async function Ns(e){Ece(e);let t,r;try{r=await Cy.addJob(e),t=r.createdJob,kr.info("addJob result",r);let n=new YF.RunnerMessage(t,e);return{message:await YF.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 kr.error(s),O_(n,s)}}a(Ns,"executeJob");function Ace(){let e=new Map;return e.set(G.OPERATIONS_ENUM.INSERT,new Q(Dl.insert)),e.set(G.OPERATIONS_ENUM.UPDATE,new Q(Dl.update)),e.set(G.OPERATIONS_ENUM.UPSERT,new Q(Dl.upsert)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new Q(Ym.searchByConditions)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_HASH,new Q(XF)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_ID,new Q(XF)),e.set(G.OPERATIONS_ENUM.SEARCH_BY_VALUE,new Q(pce)),e.set(G.OPERATIONS_ENUM.SEARCH,new Q(Sce)),e.set(G.OPERATIONS_ENUM.SQL,new Q(Tce)),e.set(G.OPERATIONS_ENUM.CSV_DATA_LOAD,new Q(Ns,Gm.csvDataLoad)),e.set(G.OPERATIONS_ENUM.CSV_FILE_LOAD,new Q(Ns,Gm.csvFileLoad)),e.set(G.OPERATIONS_ENUM.CSV_URL_LOAD,new Q(Ns,Gm.csvURLLoad)),e.set(G.OPERATIONS_ENUM.IMPORT_FROM_S3,new Q(Ns,Gm.importFromS3)),e.set(G.OPERATIONS_ENUM.CREATE_SCHEMA,new Q(Gi.createSchema)),e.set(G.OPERATIONS_ENUM.CREATE_DATABASE,new Q(Gi.createSchema)),e.set(G.OPERATIONS_ENUM.CREATE_TABLE,new Q(Gi.createTable)),e.set(G.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new Q(Gi.createAttribute)),e.set(G.OPERATIONS_ENUM.DROP_SCHEMA,new Q(Gi.dropSchema)),e.set(G.OPERATIONS_ENUM.DROP_DATABASE,new Q(Gi.dropSchema)),e.set(G.OPERATIONS_ENUM.DROP_TABLE,new Q(Gi.dropTable)),e.set(G.OPERATIONS_ENUM.DROP_ATTRIBUTE,new Q(Gi.dropAttribute)),e.set(G.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new Q(qm.describeSchema)),e.set(G.OPERATIONS_ENUM.DESCRIBE_DATABASE,new Q(qm.describeSchema)),e.set(G.OPERATIONS_ENUM.DESCRIBE_TABLE,new Q(qm.describeTable)),e.set(G.OPERATIONS_ENUM.DESCRIBE_ALL,new Q(qm.describeAll)),e.set(G.OPERATIONS_ENUM.DELETE,new Q(y_.deleteRecord)),e.set(G.OPERATIONS_ENUM.ADD_USER,new Q(A_.addUser)),e.set(G.OPERATIONS_ENUM.ALTER_USER,new Q(A_.alterUser)),e.set(G.OPERATIONS_ENUM.DROP_USER,new Q(A_.dropUser)),e.set(G.OPERATIONS_ENUM.LIST_USERS,new Q(A_.listUsersExternal)),e.set(G.OPERATIONS_ENUM.LIST_ROLES,new Q(Vm.listRoles)),e.set(G.OPERATIONS_ENUM.ADD_ROLE,new Q(Vm.addRole)),e.set(G.OPERATIONS_ENUM.ALTER_ROLE,new Q(Vm.alterRole)),e.set(G.OPERATIONS_ENUM.DROP_ROLE,new Q(Vm.dropRole)),e.set(G.OPERATIONS_ENUM.USER_INFO,new Q(A_.userInfo)),e.set(G.OPERATIONS_ENUM.READ_LOG,new Q(rce)),e.set(G.OPERATIONS_ENUM.ADD_NODE,new Q(nce)),e.set(G.OPERATIONS_ENUM.UPDATE_NODE,new Q(GF)),e.set(G.OPERATIONS_ENUM.SET_NODE_REPLICATION,new Q(GF)),e.set(G.OPERATIONS_ENUM.REMOVE_NODE,new Q(sce)),e.set(G.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new Q(ice)),e.set(G.OPERATIONS_ENUM.PURGE_STREAM,new Q(oce)),e.set(G.OPERATIONS_ENUM.SET_CONFIGURATION,new Q(QF.setConfiguration)),e.set(G.OPERATIONS_ENUM.CLUSTER_STATUS,new Q(ace.clusterStatus)),e.set(G.OPERATIONS_ENUM.CLUSTER_NETWORK,new Q(cce)),e.set(G.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new Q(Ny.setRoutes)),e.set(G.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new Q(Ny.getRoutes)),e.set(G.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new Q(Ny.deleteRoutes)),e.set(G.OPERATIONS_ENUM.EXPORT_TO_S3,new Q(Ns,qF.export_to_s3)),e.set(G.OPERATIONS_ENUM.CREATE_CSR,new Q(b_.createCsr)),e.set(G.OPERATIONS_ENUM.SIGN_CERTIFICATE,new Q(b_.signCertificate)),e.set(G.OPERATIONS_ENUM.LIST_CERTIFICATES,new Q(b_.listCertificates)),e.set(G.OPERATIONS_ENUM.ADD_CERTIFICATES,new Q(b_.addCertificate)),e.set(G.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new Q(b_.removeCertificate)),e.set(G.OPERATIONS_ENUM.ADD_NODE_BACK,new Q(JF.addNodeBack)),e.set(G.OPERATIONS_ENUM.REMOVE_NODE_BACK,new Q(JF.removeNodeBack)),e.set(G.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new Q(Ns,y_.deleteFilesBefore)),e.set(G.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new Q(Ns,y_.deleteFilesBefore)),e.set(G.OPERATIONS_ENUM.EXPORT_LOCAL,new Q(Ns,qF.export_local)),e.set(G.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new Q(Cy.handleGetJobsByStartDate)),e.set(G.OPERATIONS_ENUM.GET_JOB,new Q(Cy.handleGetJob)),e.set(G.OPERATIONS_ENUM.GET_FINGERPRINT,new Q(Iy.getFingerprint)),e.set(G.OPERATIONS_ENUM.SET_LICENSE,new Q(Iy.setLicense)),e.set(G.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new Q(Iy.getRegistrationInfo)),e.set(G.OPERATIONS_ENUM.RESTART,new Q($F.restart)),e.set(G.OPERATIONS_ENUM.RESTART_SERVICE,new Q(Ns,$F.restartService)),e.set(G.OPERATIONS_ENUM.CATCHUP,new Q(Rce)),e.set(G.OPERATIONS_ENUM.SYSTEM_INFORMATION,new Q(dce.systemInformation)),e.set(G.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new Q(Ns,y_.deleteAuditLogsBefore)),e.set(G.OPERATIONS_ENUM.READ_AUDIT_LOG,new Q(tce)),e.set(G.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new Q(KF.createTokens)),e.set(G.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new Q(KF.refreshOperationToken)),e.set(G.OPERATIONS_ENUM.LOGIN,new Q(WF.login)),e.set(G.OPERATIONS_ENUM.LOGOUT,new Q(WF.logout)),e.set(G.OPERATIONS_ENUM.GET_CONFIGURATION,new Q(QF.getConfiguration)),e.set(G.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new Q(It.customFunctionsStatus)),e.set(G.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new Q(It.getCustomFunctions)),e.set(G.OPERATIONS_ENUM.GET_COMPONENT_FILE,new Q(It.getComponentFile)),e.set(G.OPERATIONS_ENUM.GET_COMPONENTS,new Q(It.getComponents)),e.set(G.OPERATIONS_ENUM.SET_COMPONENT_FILE,new Q(It.setComponentFile)),e.set(G.OPERATIONS_ENUM.DROP_COMPONENT,new Q(It.dropComponent)),e.set(G.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new Q(It.getCustomFunction)),e.set(G.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new Q(It.setCustomFunction)),e.set(G.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new Q(It.dropCustomFunction)),e.set(G.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new Q(It.addComponent)),e.set(G.OPERATIONS_ENUM.ADD_COMPONENT,new Q(It.addComponent)),e.set(G.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new Q(It.dropCustomFunctionProject)),e.set(G.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new Q(It.packageComponent)),e.set(G.OPERATIONS_ENUM.PACKAGE_COMPONENT,new Q(It.packageComponent)),e.set(G.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new Q(It.deployComponent)),e.set(G.OPERATIONS_ENUM.DEPLOY_COMPONENT,new Q(It.deployComponent)),e.set(G.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new Q(zF.readTransactionLog)),e.set(G.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new Q(Ns,zF.deleteTransactionLogsBefore)),e.set(G.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new Q(jF.installModules)),e.set(G.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new Q(jF.auditModules)),e.set(G.OPERATIONS_ENUM.GET_BACKUP,new Q(Gi.getBackup)),e.set(G.OPERATIONS_ENUM.ADD_SSH_KEY,new Q(It.addSSHKey)),e.set(G.OPERATIONS_ENUM.UPDATE_SSH_KEY,new Q(It.updateSSHKey)),e.set(G.OPERATIONS_ENUM.DELETE_SSH_KEY,new Q(It.deleteSSHKey)),e.set(G.OPERATIONS_ENUM.LIST_SSH_KEYS,new Q(It.listSSHKeys)),e.set(G.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new Q(It.setSSHKnownHosts)),e.set(G.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new Q(It.getSSHKnownHosts)),e}a(Ace,"initializeOperationFunctionMap")});var Wm=N((iye,aG)=>{"use strict";var Py=M(),bce=te(),I_=j(),{handleHDBError:My,hdb_errors:Km}=ce(),{isMainThread:yce}=require("worker_threads"),{Readable:Oce}=require("stream"),iG=require("os"),Nce=require("util"),Ice=PR(),wce=Nce.promisify(Ice.authorize),oG=sG(),{createGzip:Cce,constants:Dce}=require("zlib");function Lce(e){let t=`Found an uncaught exception with message: ${e.message}. ${iG.EOL}Stack: ${e.stack} ${iG.EOL}Terminating ${yce?"HDB":"thread"}.`;console.error(t),I_.fatal(t),process.exit(1)}a(Lce,"handleServerUncaughtException");function Pce(e,t,r){if(I_[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:Km.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(Pce,"serverErrorHandler");function Mce(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=My(new Error,"Invalid JSON.",Km.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(bce.isEmpty(e.body.operation)){let n=My(new Error,"Request body must include an 'operation' property.",Km.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Mce,"reqBodyValidationHandler");function Uce(e,t,r){let n;e.body.operation!==Py.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==Py.OPERATIONS_ENUM.LOGIN&&e.body.operation!==Py.OPERATIONS_ENUM.LOGOUT?wce(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{I_.warn(s),I_.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(My(s,i,Km.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(Uce,"authHandler");async function vce(e,t,r=!1){let n;try{r&&(e.body.operation!=="configure_cluster"||e.body.operation!=="set_configuration")&&(e.body.bypass_auth=r),n=oG.chooseOperation(e.body);let s=await oG.processLocalTransaction(e,n);if(s instanceof Oce&&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(Cce({level:Dce.Z_BEST_SPEED})))}return s}catch(s){throw I_.error(s),s}}a(vce,"handlePostRequest");aG.exports={authHandler:Uce,handlePostRequest:vce,handleServerUncaughtException:Lce,serverErrorHandler:Pce,reqBodyValidationHandler:Mce}});var dG=N((aye,uG)=>{"use strict";var xce=require("fastify-plugin"),{handlePostRequest:cG,authHandler:Bce,reqBodyValidationHandler:Hce}=Wm();async function kce(e){e.decorate("hdbCore",{preValidation:[Hce,Bce],request:t=>lG(cG(t,response)),requestWithoutAuthentication:(t,r)=>lG(cG(t,r,!0))})}a(kce,"hdbCore");async function lG(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(lG,"convertAsyncIterators");uG.exports=xce(kce)});var EG=N((uye,fG)=>{"use strict";var lye=require("fs"),Uy=ne();Uy.initSync();var{CONFIG_PARAMS:_G}=M(),Fce=1024*1024*1024;function Gce(e){let t=Uy.get(_G.HTTP_TIMEOUT),r=Uy.get(_G.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Fce,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,https:e}}a(Gce,"getServerOptions");fG.exports=Gce});var pG=N((_ye,mG)=>{"use strict";var vy=ne();vy.initSync();var{CONFIG_PARAMS:hG}=M();function qce(){let e=vy.get(hG.HTTP_CORSACCESSLIST),t=vy.get(hG.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(qce,"getCORSOptions");mG.exports=qce});var gG=N((Eye,TG)=>{"use strict";var SG=ne();SG.initSync();var Vce=M();function $ce(){return SG.get(Vce.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a($ce,"getHeaderTimeoutConfig");TG.exports=$ce});var By={};Ze(By,{customFunctionsServer:()=>Wce,ready:()=>vG,start:()=>Kce});function Kce(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){qi||(qi=UG(t),it.http((await qi).server));let o=await qi,c=(0,xy.dirname)(s),l=(0,xy.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!RG.has(c)){RG.add(c);try{o.register(zce(c,l))}catch(d){if(d.message==="Root plugin has already booted")_t.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw d}}},ready:vG}}async function Wce(){try{_t.info("In Custom Functions Fastify server"+process.cwd()),_t.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),_t.debug(`Custom Functions server process ${process.pid} starting up.`),await Qce();let e=IG.get(wG.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=qi=await UG(e)}catch(r){throw _t.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw _t.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){_t.error(`Custom Functions ${process.pid} Error: ${e}`),_t.error(e),process.exit(1)}}async function Qce(){try{_t.info("Custom Functions starting configuration."),await CG.setUsersToGlobal(),_t.info("Custom Functions completed configuration.")}catch(e){_t.error(e)}}function zce(e,t){return async function(r){try{_t.info("Custom Functions starting buildRoutes"),_t.trace("Loading fastify routes folder "+e),(0,AG.existsSync)(e)&&r.register(NG.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:_t.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?_t.error(s.message):s&&_t.error(s),o()})}catch(n){_t.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function UG(e){_t.info("Custom Functions starting buildServer.");let t=(0,DG.default)(e),r=(0,bG.default)(t);r.server.headersTimeout=(0,PG.default)(),r.setErrorHandler(MG.serverErrorHandler);let n=(0,LG.default)();return n&&r.register(yG.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(OG.default),await r.register(Yce),await r.after(),$b(r),_t.info("Custom Functions completed buildServer."),r}function vG(){if(qi)return qi.then?qi.then(e=>e.ready()):qi.ready()}var xy,AG,bG,yG,OG,NG,IG,wG,_t,Yce,CG,DG,LG,PG,MG,qi,RG,xG=Oe(()=>{xy=require("path"),AG=require("fs"),bG=v(require("fastify")),yG=v(require("@fastify/cors")),OG=v(ny()),NG=v(require("@fastify/autoload")),IG=v(ne()),wG=v(M()),_t=v(j()),Yce=v(dG()),CG=v($n()),DG=v(EG()),LG=v(pG()),PG=v(gG()),MG=v(Wm());hl();Lr();RG=new Set;a(Kce,"start");a(Wce,"customFunctionsServer");a(Qce,"setUp");a(zce,"buildRouteFolder");a(UG,"buildServer");a(vG,"ready")});var Hy={};Ze(Hy,{start:()=>jce});function jce(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,GG.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){HG||(HG=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=BG.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,kG.default)(s,(0,FG.realpathSync)(o))}}return i(s)},{runFirst:!0})),BG.set(r,n)}}}var kG,FG,GG,BG,HG,qG=Oe(()=>{kG=v(require("send")),FG=require("fs"),GG=v(require("serve-static")),BG=new Map;a(jce,"start")});function Zce(){let e=(0,KG.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),Fy=setInterval(()=>{jm.notify(e)},Xce).unref())}function ele(e,t=1,r){if(ky++,(0,si.startWorker)("server/threads/threadServer.js",{name:vl.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(d){d.type===vl.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Jce.push(s),await s,Ll.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=zm.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Ll.indexOf(n);o>-1&&Ll.splice(o,1)}if(a(i,"removeWorker"),Pl){let o=Pl;Pl=[];for(let c of o)WG[c.localPort](null,c)}}}),r){let n=setInterval(()=>{Gy?Gy=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,si.shutdownWorkers)(),ky=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function QG(e=0,t){if(typeof e=="string")try{(0,Jm.existsSync)(e)&&(0,Jm.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=tle:r=rle(t):r=qy;let n=(0,Ml.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=WG[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),Gy=!0,r(o,(c,l)=>{if(!c){if(VG){let u=o._socket||new Ml.Socket({handle:o,writable:!0,readable:!0});VG.deliverSocket(u,e,l),u.resume()}else ky>0?(Pl.length===0&&setTimeout(()=>{Pl.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,Pl.push(o)):(console.log("start up a dynamic thread to handle request"),ele(0));Qr(!1,"socket-routed");return}c.requests++;let d=o.fd;if(d>=0)c.postMessage({port:e,fd:d,data:l});else{let u=o._socket||new Ml.Socket({handle:o,writable:!0,readable:!0});ole(u,c,e)}Qr(!0,"socket-routed")})};let s=Ju();jm.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function qy(e,t){let r,n=0;for(let s of Ll){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=Qm)return Qm=i,t(r);n=i}Qm=0,t(r)}function tle(e,t){let r={};e.getpeername(r);let n=r.address,s=Ul.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);qy(e,o=>{Ul.set(n,{worker:o,lastUsed:i}),t(o)})}function rle(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new Ml.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],d=Ul.get(l),u=Date.now();if(d&&d.worker.threadId!==-1)return d.lastUsed=u,s(d.worker);qy(n,_=>{Ul.set(l,{worker:_,lastUsed:u}),s(_,o)})})}a(r,"findByHeaderAffinity")}function sle(){Qm=0;for(let e of Ll)e.expectedIdle=e.recentELU.idle+nle,e.requests=1;Ll.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function ole(e,t,r){let n=ile++;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(),zm.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")),zm.delete(n)),s.event=="destroy"&&(e.destroy(),zm.delete(n))})}var si,Ml,vl,jm,Jm,YG,KG,Ll,Pl,WG,VG,ky,Jce,Fy,Xce,Gy,Qm,$G,Ul,nle,zm,ile,zG=Oe(()=>{si=v(et()),Ml=require("net"),vl=v(M()),jm=v(j()),Jm=require("fs");yi();YG=require("worker_threads"),KG=v(ra()),Ll=[],Pl=[],WG=[],ky=0,Jce=[];YG.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,si.onMessageFromWorkers)(e=>{e.type===vl.ITC_EVENT_TYPES.RESTART&&Fy&&(clearInterval(Fy),Zce())}));Xce=6e5;a(Zce,"licenseWarning");a(ele,"startHTTPWorker");a(QG,"startSocketServer");Qm=0;a(qy,"findMostIdleWorker");$G=36e5,Ul=new Map;a(tle,"findByRemoteAddressAffinity");a(rle,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Ul)r.lastUsed+$G<e&&Ul.delete(t)},$G).unref();nle=1e3;a(sle,"updateWorkerIdleness");(0,si.setMonitorListener)(sle);zm=new Map,ile=1;a(ole,"proxySocket")});var Ky={};Ze(Ky,{Request:()=>Vy,createReuseportFd:()=>Xm});var jG,Vy,$y,Yy,Xm,Zm=Oe(()=>{jG=require("os"),Vy=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 Yy(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 $y(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},$y=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)}},Yy=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,jG.platform)()!="win32"&&(Xm=require("node-unix-socket").createReuseportFd)});var eq=N((Cye,ZG)=>{"use strict";var ale=require("cluster"),Wa=ne();Wa.initSync();var XG=M(),yye=require("util"),Vi=j(),Oye=require("fs"),cle=require("fastify"),Nye=Ju(),lle=require("@fastify/cors"),ule=require("@fastify/compress"),dle=require("@fastify/static"),_le=ny(),fle=require("path"),{PACKAGE_ROOT:Ele}=M(),hle=Ti(),mle=te(),ple=$n(),Sle=ra(),{server:Tle}=(Lr(),ae(qo)),{node_request_key:Iye}=(Zm(),ae(Ky)),{authHandler:gle,handlePostRequest:Rle,serverErrorHandler:Ale,reqBodyValidationHandler:ble}=Wm(),wye=require("net"),{registerContentHandlers:yle}=(hl(),ae(Ck)),Ole=6e4,Nle=1024*1024*1024,Ile="TRUE",{CONFIG_PARAMS:w_}=XG,xl;ZG.exports={hdbServer:JG,start:JG};async function JG(e){try{Vi.debug("In Fastify server"+process.cwd()),Vi.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Vi.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=ale.isMaster,await wle();let t=e.securePort>0;xl=Cle(t),await xl.ready(),e||(e={}),e.isOperationsServer=!0;try{Tle.http(xl.server,e),xl.server.closeIdleConnections||await xl.listen({port:0,host:"::"})}catch(r){throw xl.close(),Vi.error(r),Vi.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Vi.fatal(t),process.exit(1)}}a(JG,"operationsServer");async function wle(){Vi.trace("Configuring HarperDB process."),hle.setSchemaDataToGlobal(),await ple.setUsersToGlobal(),await Sle.getLicense()}a(wle,"setUp");function Cle(e){Vi.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=Dle(e),r=cle(t);r.server.headersTimeout=Ple(),r.setErrorHandler(Ale);let n=Lle();n&&r.register(lle,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,d){r.server.emit("unhandled",l.raw,d.raw)}),c()}),r.register(_le),r.register(ule),r.register(dle,{root:fle.join(Ele,"studio/build-local")}),yle(r);let s=Wa.get(XG.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!mle.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[ble,gle],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Rle(i,o)}),r.get("/health",()=>"HarperDB is running."),Vi.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(Cle,"buildServer");function Dle(e){let t=Wa.get(w_.OPERATIONSAPI_NETWORK_TIMEOUT),r=Wa.get(w_.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Nle,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(Dle,"getServerOptions");function Lle(){let e=Wa.get(w_.OPERATIONSAPI_NETWORK_CORS),t=Wa.get(w_.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===Ile)&&(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(Lle,"getCORSOpts");function Ple(){return Wa.get(w_.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??Ole}a(Ple,"getHeaderTimeoutConfig")});var Xy={};Ze(Xy,{disableNATS:()=>Ule,publishToStream:()=>rp,setNATSReplicator:()=>Wy,setPublishToStream:()=>vle,setSubscription:()=>Jy,start:()=>Mle});function Mle(){C_.default.get(D_.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&Ble()}function Ule(e=!0){iq=e}function vle(e,t){rp=e,Jy=t}function Ble(){if(iq||process.env._DISABLE_NATS)return;let e=ut(),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];Wy(s,r,i)}}Aa((r,n)=>{Wy(r.tableName,r.databaseName,r),n&&aq(r)}),!tq&&(tq=!0)}function Wy(e,t,r){if(t==="system"&&Hle.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 pr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[Ke],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[Ke]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[Ke],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[Ke],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[Ke]})}static defineSchema(i){aq(i)}static subscribe(){let i=new mn;return Jy(t,e,i),i}static subscribeOnThisThread(i){return i<(C_.default.get(D_.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??xle)}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 ep(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=oq;return i}a(n,"getNATSTransaction")}function aq(e){let t=C_.default.get(D_.default.CONFIG_PARAMS.CLUSTERING_NODENAME);rp(`${zy.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,jy.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 rq,zy,jy,nq,sq,C_,D_,tp,iq,rp,Jy,xle,oq,tq,Hle,ep,Qy,cq=Oe(()=>{Ne();us();rq=v(Mt()),zy=v(lt()),jy=v(pi());cc();nq=v(Xg()),sq=v(hn()),C_=v(ne()),D_=v(M()),tp=v(j());a(Mle,"start");a(Ule,"disableNATS");rp=rq.publishToStream,Jy=nq.setSubscription;a(vle,"setPublishToStream");xle=2;a(Ble,"assignReplicationSource");Hle=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(Wy,"setNATSReplicator");a(aq,"publishSchema");ep=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=C_.default.get(D_.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,d;for(let u of i){let _=u.table,E=u.operation=="put"?"upsert":u.operation;l||(tp.trace(`Sending transaction event ${E}`),d=l={operation:E,schema:s,table:_,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===_&&l.operation===E?(o.push(u.record),c.push(u.id)):d=d.next={operation:E,table:_,id:u.id,record:u.record},u.expiresAt&&(d.expiresAt=u.expiresAt)}l&&n.push(rp(`${zy.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,jy.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(u=>{throw tp.error("An error has occurred trying to replicate transaction",l,u),u.statusCode=504,u}))}return Promise.all(n)}},Qy=class extends ep{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,sq.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};oq=new Qy});var Rq=N(Uo=>{"use strict";var{isMainThread:eO,parentPort:U_,threadId:sp,workerData:kle}=require("worker_threads"),{Socket:Fle,createServer:Gle}=require("net"),{createServer:qle,IncomingMessage:Vle}=require("http"),{createServer:$le}=require("https"),{unlinkSync:dq,existsSync:Yle}=require("fs"),Fr=j(),mt=ne(),Kt=M(),{server:op}=(Lr(),ae(qo)),{WebSocketServer:Kle}=require("ws"),{createServer:Wle}=require("node:tls"),{getTicketKeys:Qle,restartNumber:zle,getWorkerIndex:v_}=et(),{Headers:tO,appendHeader:jle}=(Zd(),ae(XB)),{recordAction:L_,recordActionBinary:Jle}=(yi(),ae(rd)),{Request:_q,createReuseportFd:M_}=(Zm(),ae(Ky)),{checkMemoryLimit:Xle}=ra(),{createTLSSelector:fq}=bo(),{resolvePath:Eq}=dr(),hq=mt.get(Kt.CONFIG_PARAMS.THREADS_DEBUG);if(hq){let e;if(eO)e=mt.get(Kt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Fr.info("Could not close debugger",t)}});else{let t=mt.get(Kt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&v_()>=0&&(e=t+v_())}if(e){let t=mt.get(Kt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=mt.get(Kt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Fr.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&eO)try{require("inspector").open(9229)}catch(e){zle<=1&&Fr.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:xye,CONFIG_PARAMS:Zle}=Kt;mt.initSync();var eue=mt.get(Zle.HTTP_SESSIONAFFINITY),ii={};Uo.registerServer=iO;Uo.httpServer=oO;Uo.deliverSocket=sO;Uo.startServers=mq;Uo.listenOnPorts=pq;Uo.when_components_loaded=null;op.http=oO;op.request=sue;op.socket=iue;op.ws=oue;var Zy={},P_={},tue,np={},ip={},rue=[],rO=[];function mq(){return Uo.when_components_loaded=aO().loadRootComponents(!0).then(()=>{U_?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)sO(n,r,s);else if(t.requestId)nue(t);else if(t.type===Kt.ITC_EVENT_TYPES.SHUTDOWN){Fr.trace("received shutdown request",sp);for(let i in ii){let o=ii[i],c;if(o.closeIdleConnections){let d=Object.getOwnPropertySymbols(o).find(E=>E.description.includes("connections")),u=0,_=setInterval(()=>{u++;let E=u>=100,f=o[d][E?"all":"idle"]();if(f.length===0){E&&clearInterval(_);return}u===1?Fr.info(`Closing ${f.length} idle connections`):E&&Fr.warn(`Forcefully closing ${f.length} active connections`);for(let h=0,p=f.length;h<p;h++){let S=f[h].socket;S._httpMessage&&!S._httpMessage.finished&&!E||(E?S.destroySoon():S.end(`HTTP/1.1 408 Request Timeout\r
|
|
40
|
+
`},compressible:!1,q:.8});br.set("application/x-www-form-urlencoded",{deserialize(e){let t={};for(let[r,n]of new URLSearchParams(e))if(t.hasOwnProperty(r)){let s=t[r];Array.isArray(s)?s.push(n):t.key=[s,n]}else t[r]=n},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});Tq={type:"application/json",serializeStream:Fd,serialize:$f,deserialize:xue,q:.5};br.set("*/*",Tq);br.set("",Tq);a(xue,"tryJSONParse");a(WO,"registerContentHandlers");kue=require("fastify-plugin"),Fue=kue(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=tS(n.raw);s.type(c),s.serializer(function(l){let d;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let u=l.getColumns;l=l.mapError(_=>(_.toJSON=()=>({error:_.name,message:_.message,..._.partialObject}),_)),l.getColumns=u}d=o.serializeStream}else d=o.serialize;return d(l,{headers:{set:(u,_)=>{s.header(u,_)}}})})}),r()},{name:"content-type-negotiation"});a(tS,"findBestSerializer");_q=$O.default.get(VO.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(Yf,"serialize");a(kc,"serializeMessage");a(Gue,"streamToBuffer");a(Vc,"getDeserializer");a(fq,"deserializerUnknownType");a(que,"transformIterable")});function QO(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let _=d(l);for(let f=1;f<e.length;f++){let h=e[f],T=d(h);_=_.concat(T)}let E=new Set;return _.filter(f=>{let h=f.key??f;return E.has(h)?!1:(E.add(h),!0)})}else{let _=d(l),E=u(e.slice(1),!0,l.estimated_count);return E.length>0?o(_,E):_}function d(_){return _.conditions?QO(_.conditions,_.operator,r,n,s,i,o,c):qu(_,n,_.descending||s.reverse===!0,r,s.allowFullScan,c)}a(d,"executeCondition");function u(_,E,f){return _.map((h,T)=>{if(h.conditions){let p=h.operator==="or",y=u(h.conditions,!p,f);return p?(O,B)=>y.some(x=>x(O,B)):(O,B)=>y.every(x=>x(O,B))}let S=(h.attribute||h[0])===r.primaryKey,R=jf(h,r,i,c,S,f);return E&&T<_.length-1&&f&&(f=Jue(r.primaryStore,h.estimated_count,f)),R}).filter(Boolean)}a(u,"mapConditionsToFilters")}function qu(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(Array.isArray(o)){let p=o[0],y=Di(n.attributes,p);if(y.relationship){if(o.length<2)throw new Vn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let O=y.definition?.tableClass||y.elements?.definition?.tableClass,B=new Map,x=qu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,O,s,B);if(y.relationship.to){i[o[0]]=B;let W=!!Di(O.attributes,y.relationship.to)?.elements;x=Wue(x,y,O.primaryStore,W,B)}if(y.relationship.from){let W=a(q=>(q?.key!==void 0&&(q=q.key),qu({attribute:y.relationship.from,value:q},t,r,n,s,B)),"searchEntry");y.elements?(i[o[0]]=B,x=jue(x,y,O.primaryStore,B,W)):x=x.flatMap(W)}return x}else if(o.length===1)o=o[0];else throw new Vn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let d,u,_,E;c instanceof Date&&(c=c.getTime());let f;switch(zO[l]||l){case"lt":d=!0,u=c;break;case"le":d=!0,u=c,_=!0;break;case"gt":d=c,E=!0;break;case"ge":d=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],d=c,u=c.slice(0),u[u.length-1]=Ci.MAXIMUM_KEY;break;case"starts_with":d=c.toString(),u=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":d=c[0],d instanceof Date&&(d=d.getTime()),u=c[1],u instanceof Date&&(u=u.getTime()),_=l==="gele"||l==="gtle"||l==="between",E=l==="gtlt"||l==="gtle";break;case"equals":case void 0:d=c,u=c,_=!0;break;case"ne":if(c===null){d=c,E=!0;break}case"sort":case"contains":case"ends_with":d=!0,f=!0;break;default:throw new Vn.ClientError(`Unknown query comparator "${l}"`)}let h,T=o===n.primaryKey||o==null;if(typeof d=="string"&&d.length>Os.MAX_SEARCH_KEY_LENGTH&&(d=d.slice(0,Os.MAX_SEARCH_KEY_LENGTH)+Os.OVERFLOW_MARKER,E=!1,h=jf(e,n,null,i,T)),typeof u=="string"&&u.length>Os.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Os.MAX_SEARCH_KEY_LENGTH)+Os.OVERFLOW_MARKER,_=!0,h=h??jf(e,n,null,i,T)),r){let p=d;d=u,u=p,p=!E,E=!_,_=p}let S=T?n.primaryStore:n.indices[o];if(!S||S.isIndexing||f||c===null&&!S.indexNulls){if(s===!1&&!S)throw new Vn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&f)throw new Vn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(S?.isIndexing)throw new Vn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&!S.indexNulls)throw new Vn.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??jf(e,n,null,i,T),!h)throw new Vn.ClientError(`Unknown search operator ${e.comparator}`)}let R={start:d,end:u,inclusiveEnd:_,exclusiveStart:E,values:!0,versions:T,transaction:t,reverse:r};if(T){let p=S.getRange(R).map(h?function({key:y,value:O}){return this?.isSync?O&&h(O)?y:Ra.SKIP:new Promise((B,x)=>setImmediate(()=>{try{B(O&&h(O)?y:Ra.SKIP)}catch(W){x(W)}}))}:y=>y.value==null&&!(y.metadataFlags&(Pi|ba))?Ra.SKIP:y);return p.hasEntries=!0,p}else return S?S.getRange(R).map(h?function({key:p,value:y}){let O;return typeof p=="string"&&p.length>Os.MAX_SEARCH_KEY_LENGTH?O=n.primaryStore.get(y):O={[o]:p},this.isSync?h(O)?y:Ra.SKIP:new Promise((B,x)=>setImmediate(()=>{try{B(h(O)?y:Ra.SKIP)}catch(W){x(W)}}))}:({value:p})=>p):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:p,value:y}){return this.isSync?y&&h(y)?p:Ra.SKIP:new Promise((O,B)=>setImmediate(()=>{try{O(y&&h(y)?p:Ra.SKIP)}catch(x){B(x)}}))})}function Di(e,t){if(Array.isArray(t))if(t.length>1){let r=Di(e,t[0]),n=(r?.definition?.tableClass||r?.elements.definition?.tableClass)?.attributes;return n?Di(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 Wue(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((d,u)=>{let _=s.get(d);_?_.push(u):s.set(d,_=[u])},"add_entry");for(let d of e){let u=d.value??r.get(d.key??d),_=u?.[c];if(_!=null&&!s.filters?.some(E=>!E(u)))if(n)for(let E=0;E<_.length;E++)l(_[E],d);else l(_,d)}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 jue(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 d=l.value;if(!c.has(d))return c.add(d),l}if(!i){let d=new Set;n.fromRecord=u=>u[t.relationship.from]?.filter?.(_=>d.has(_));for(let u of e){if(n.filters){let _=r.get(u);if(n.filters.some(E=>!E(_)))continue}d.add(u)}return i=d[Symbol.iterator](),this.next()}do{let d=i.next();return d.done?d:(o=s(d.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function jf(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 u=c[0],_=Di(t.attributes,u),E=_.definition?.tableClass||_.elements.definition?.tableClass,f=n?.[u],h=jf({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},E,r,f?.[u]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(f){f.filters||(f.filters=[]),f.filters.push(h);return}let T=t.propertyResolvers?.[u],S,R=a((p,y)=>{let O,B;if(T){if(T.from&&h.idFilter){if(!S)if(h.idFilter.idSet?.size===1){for(let W of h.idFilter.idSet)e={attribute:T.from,value:W};S=d(T.from,h.idFilter,!0,!0)}else S=d(T.from,h.idFilter,!1,!0);let x=S(p);return S.idFilter&&(R.idFilter=S.idFilter),x}B=T(p,r,y),O=B?.value}else O=p[u];return O?Array.isArray(O)?O.some(h):h(O,B):!1},"recordFilter");return R}}switch(l instanceof Date&&(l=l.getTime()),zO[o]||o){case Os.SEARCH_TYPES.EQUALS:case void 0:return d(c,u=>u===l,!0);case"contains":return d(c,u=>u?.toString().includes(l));case"ends_with":return d(c,u=>u?.toString().endsWith(l));case"starts_with":return d(c,u=>typeof u=="string"&&u.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],d(c,u=>{if(!Array.isArray(u))return!1;for(let _=0,E=l.length;_<E;_++)if(u[_]!==l[_])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()),d(c,u=>(0,Ci.compareKeys)(u,l[0])>=0&&(0,Ci.compareKeys)(u,l[1])<=0,!0);case"gt":return d(c,u=>(0,Ci.compareKeys)(u,l)>0);case"ge":return d(c,u=>(0,Ci.compareKeys)(u,l)>=0);case"lt":return d(c,u=>(0,Ci.compareKeys)(u,l)<0);case"le":return d(c,u=>(0,Ci.compareKeys)(u,l)<=0);case"ne":return d(c,u=>(0,Ci.compareKeys)(u,l)!==0);case"sort":return()=>!0;default:throw new Vn.ClientError(`Unknown query comparator "${o}"`)}function d(u,_,E,f){let h;E=E&&!s&&t?.indices[u]&&i>3,E&&(e.estimated_count==null&&nS(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let T=0,S=3;function R(p){let y=p[u],O;if(typeof y!="object"||!y||f?O=_(y):Array.isArray(y)?O=y.some(_):y instanceof Date&&(O=_(y.getTime())),E&&(S++,!O&&!R.idFilter&&++T/S*(i-S)>h)){let B=qu(e,r.transaction.getReadTxn(),!1,t).map($u),x=new Set(B);R.idFilter=W=>x.has($u(W)),R.idFilter.idSet=x}return O}return a(R,"recordFilter"),s&&(R.idFilter=_),R}a(d,"attributeComparator")}function nS(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=zO[n]||n,n===Os.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=Di(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=nS(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=Yue*So(e.primaryStore)+1:n==="between"?r.estimated_count=Vue*So(e.primaryStore)+1:n==="sort"?r.estimated_count=So(e.primaryStore)+1:r.estimated_count=$ue*So(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function sS(e){if(e)if(Aa=e,Fu.lastIndex=0,Que.test(e))try{let t=Kf(new Gu,"");if(An!==Aa.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 ${An} in '${Aa}'`,t}else return new URLSearchParams(e)}function Kf(e,t){let r=Fu,n,s,i,o,c,l=decodeURIComponent,d;for(;n=r.exec(Aa);){An=r.lastIndex;let[,u,_]=n;if(o){if(u)throw new SyntaxError(`expected operator, but encountered '${u}'`);o=!1,c=!1}else c=!0;let E;switch(_){case"=":if(s!=null){if(u.length<=2)i=u;else throw new SyntaxError(`invalid FIQL operator ${u}`);l=Rq}else{if(l=decodeURIComponent,i="equals",!u)throw new SyntaxError("attribute must be specified before equality comparator");s=Wf(u)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=Kue[_],l=jO[i]?Rq:decodeURIComponent,!u)throw new SyntaxError(`attribute must be specified before comparator ${_}`);s=Wf(u);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${_[0]?"'"+_[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${_?"'"+_+"'":"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(u)};if(i==="eq"&&Aq(h,u),s===""){let T=e.conditions[e.conditions.length-1];T.chainedConditions=T.chainedConditions||[],T.chainedConditions.push(h),T.operator=d}else rS(e,d),e.conditions.push(h)}_==="&"?(d="and",s=void 0):_==="|"?(d="or",s=void 0):_==="&="?(d="and",s=""):_==="|="&&(d="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(Wf(u)),s=void 0;break;case"(":Fu.lastIndex=An;let f=Kf(u?[]:new Gu,")");switch(u){case"":rS(e,d),e.conditions.push(f);break;case"limit":switch(f.length){case 1:e.limit=+f[0];break;case 2:e.offset=+f[0],e.limit=f[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(f[0])&&f.length===1&&!f[0].name?(e.select=f[0],e.select.asArray=!0):f.length===1?e.select=f[0]:f.length===2&&f[1]===""?e.select=f.slice(0,1):e.select=f;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=bq(f);break;default:throw new SyntaxError(`unknown query function call ${u}`)}Aa[An]===","?r.lastIndex=++An:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!u)throw new SyntaxError("property sets must have a defined parent property name");Fu.lastIndex=An,E=Kf([],"}"),E.name=u,e.push(E),Aa[An]===","?r.lastIndex=++An:o=!0;break;case"[":Fu.lastIndex=An,u?(E=Kf(new Gu,"]"),E.name=u):E=Kf(e.conditions?new Gu:[],"]"),e.conditions?(rS(e,d),e.conditions.push(E),s=null):e.push(E),Aa[An]===","?r.lastIndex=++An:o=!0;break;case")":case"]":case"}":if(t===_[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(u)};i==="eq"&&Aq(h,u),rS(e,d),e.conditions.push(h)}else if(u)throw new SyntaxError("no attribute or comparison specified")}else(u||e.length>0&&c)&&e.push(Wf(u));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${_[0]}'`):new SyntaxError(`unexpected token '${_[0]}'`);default:throw new SyntaxError(`unexpected operator '${_}'`)}if(t!==")"&&(r=s?zue:Fu,r.lastIndex=An),An===Aa.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function rS(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 Wf(e){return e.indexOf(".")>-1?e.split(".").map(Wf):decodeURIComponent(e)}function Rq(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 Vn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function Aq(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Vn.ClientError("wildcard can only be used at the end of a string")}function bq(e){let t=yq(e[0]);return e.length>1&&(t.next=bq(e.slice(1))),t}function yq(e){if(Array.isArray(e)){let t=yq(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 $u(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 Jue(e,t,r){return t*r/So(e)}var Vn,Os,Ci,Ra,$ue,Vue,Yue,Kue,jO,zO,Que,Fu,zue,An,Aa,Gu,Yc,Qf=De(()=>{Vn=v(fe()),Os=v(Bt()),Ci=require("ordered-binary"),Ra=require("lmdb");zf();$ue=.3,Vue=.1,Yue=.05,Kue={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},jO={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(QO,"executeConditions");a(qu,"searchByIndex");a(Di,"findAttribute");a(Wue,"joinTo");a(jue,"joinFrom");zO={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(jf,"filterByType");a(nS,"estimateCondition");Que=/[()[\]|!<>.]|(=\w*=)/,Fu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,zue=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(sS,"parseQuery");a(Kf,"parseBlock");a(rS,"assignOperator");a(Wf,"decodeProperty");a(Rq,"typedDecoding");a(Aq,"wildcardDecoding");a(bq,"toSortObject");a(yq,"toSortEntry");Gu=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($u,"flattenKey");a(So,"estimatedEntryCount");a(Jue,"intersectionEstimate");Yc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});function Cq(e){let t={openapi:Xue,info:{title:"HarperDB HTTP REST interface",version:(0,wq.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 d={},u=[];if(o)for(let{type:y,name:O,elements:B,relationship:x,definition:W}of o){if(x)y==="array"?d[O]={type:"array",items:{$ref:ya+B.type}}:d[O]={$ref:ya+y};else{let q=W??B?.definition;if(q){if(!t.components.schemas[q.type]){let z={};q.properties.forEach(_e=>{z[_e.name]=new eN(JO[_e.type],_e.type)}),t.components.schemas[q.type]=new Iq(z)}y==="array"?d[O]={type:"array",items:{$ref:ya+q.type}}:d[O]={$ref:ya+q.type}}else y==="array"?B.type==="Any"||B.type=="ID"?d[O]={type:"array",items:{format:B.type}}:d[O]={type:"array",items:new eN(JO[B.type],B.type)}:y==="Any"||y=="ID"?d[O]={format:y}:d[O]=new eN(JO[y],y)}u.push(new tN(O,"query",d[O]))}let _=Object.keys(d),E=new tN(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new tN("property","path",{enum:_});f.required=!0,t.components.schemas[i]=new Iq(d);let h=l.post!==Resource.prototype.post||l.update,T=typeof l.put=="function",S=typeof l.get=="function",R=typeof l.delete=="function",p="/"+s+"/";h&&(t.paths[p]={},t.paths[p].post=new Zue(i,r,"create a new record auto-assigning a primary key")),S&&(t.paths[p]||(t.paths[p]={}),t.paths[p].get=new XO(u,r,{200:new ZO({$ref:ya+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[p]||(t.paths[p]={}),t.paths[p].delete=new Nq(u,r,"delete all the records that match the provided query",{204:new Oq})),p="/"+s+"/{"+c+"}",S&&(t.paths[p]={},t.paths[p].get=new XO([E],r,{200:new ZO({$ref:ya+i})},"retrieve a record by its primary key")),T&&(t.paths[p]||(t.paths[p]={}),t.paths[p].put=new ede([E],r,i,"create or update the record with the URL path that maps to the record's primary key")),R&&(t.paths[p]||(t.paths[p]={}),t.paths[p].delete=new Nq([E],r,"delete a record with the given primary key",{204:new Oq})),S&&f.schema.enum.length>0&&(p="/"+s+"/{"+c+"}.{property}",t.paths[p]={},t.paths[p].get=new XO([E,f],r,{200:new ZO({enum:_})},"used to retrieve the specified property of the specified record"))}return t}function Zue(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:ya+e}}}},this.security=t,this.responses={200:{description:rN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function XO(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function ZO(e){this.description=rN,this.content={"application/json":{schema:e}}}function Oq(){this.description="successfully processed request, no content returned to client"}function ede(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:ya+r}}}},this.responses={200:{description:rN}}}function Nq(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function Iq(e){this.type="object",this.properties=e}function eN(e,t){this.type=e,this.format=t}function tN(e,t,r){this.name=e,this.in=t,this.schema=r}var wq,Xue,JO,ya,rN,Dq=De(()=>{wq=v(Ic()),Xue="3.0.3",JO={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},ya="#/components/schemas/",rN="successful operation";a(Cq,"generateJsonApi");a(Zue,"Post");a(XO,"Get");a(ZO,"Response200");a(Oq,"Response204");a(ede,"Put");a(Nq,"Delete");a(Iq,"ResourceSchema");a(eN,"Type");a(tN,"Parameter")});var oS={};et(oS,{start:()=>nde});async function rde(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&sS(e);let i=new _o;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==Pq){let S=iS.getMatch(o,n?"sse":"rest");if(!S)return t(e);e.handlerPath=S.path,c=new Yc(S.relativeURL),c.async=!0,l=S.Resource}let d=r["cache-control"];if(d){let S=Uq(d);for(let R of S)switch(R.name){case"max-age":e.expiresAt=R.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 S=Uq(u).map(R=>(R.next?.name==="confirm"&&R.next.value>=0&&(e.replicatedConfirmation=+R.next.value),R.name));e.replicateTo=S.length===1&&+S[0]>=0?+S[0]:S[0]==="*"?void 0:S}let _=await Ct(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=Vc(r["content-type"],!0)(e.body,e.headers)}catch(S){throw new Vu.ClientError(S,400)}if(e.authorize=!0,o===Pq&&s==="GET"){if(e?.user?.role?.permission?.super_user)return Cq(iS);throw new Vu.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new Vu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Vu.ServerError(`Method ${s} is not recognized`,501)}}),E=200,f;if(_==null)E=s==="GET"||s==="HEAD"?404:204,nN.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else{if(_.status>0&&_.headers)return _.headers=pO(_.headers,i),_.data!==void 0&&(_.body=Yf(_.data,e,_)),_;if(f=e.lastModified){tde[0]=f;let S=String.fromCharCode(34,(Ur[0]&63)+62,(Ur[0]>>6)+(Ur[1]<<2&63)+62,(Ur[1]>>4)+(Ur[2]<<4&63)+62,(Ur[2]>>2)+62,(Ur[3]&63)+62,(Ur[3]>>6)+(Ur[4]<<2&63)+62,(Ur[4]>>4)+(Ur[5]<<4&63)+62,(Ur[5]>>2)+62,(Ur[6]&63)+62,(Ur[6]>>6)+(Ur[7]<<2&63)+62,34),R=r["if-none-match"];R&&S==R?(_?.onDone&&_.onDone(),E=304,_=void 0):i.setIfNone("ETag",S),nN.lastModified&&i.setIfNone("Last-Modified",new Date(f).toUTCString())}}e.createdResource&&(E=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:E,headers:i,body:void 0},T=_?.wasLoadedFromSource?.();return T!==void 0&&(h.wasCacheMiss=T,!T&&f&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||f))/1e3))),_!==void 0&&(h.body=Yf(_,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Kc.warn(o):Kc.info(o):Kc.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=Yf(o.contentType?o:o.toString(),e,c),c}}function nde(e){nN=e,!Lq&&(Lq=!0,iS=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return rde(t,r)},e),e.server.ws(async(t,r,n)=>{Jf++;let s=new In;Mq||(Mq=!0,N_(l=>{Jf>0&&l.push({metric:"ws-connections",connections:Jf,byThread:!0})}));let i;t.on("error",l=>{i=!0,Kc.warn(l)});let o;t.on("message",a(function(d){o||(o=Vc(r.requestedContentType??r.headers.asObject["content-type"],!1));let u=o(d);s.push(u)},"message"));let c;t.on("close",()=>{Jf--,kn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),d=iS.getMatch(l,"ws");if(kn(!!d,"connection","ws","connect"),d){r.handlerPath=d.path,gr(h=>({count:h.count,total:Jf}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let u=new Yc(d.relativeURL),_=d.Resource;c=(await Ct(r,()=>_.connect(u,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=kc(f.value,r);t.send(h),gr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){t.close(sde[l.statusCode]||1011,l.toString())}t.close()},e))}function Uq(e){return e.split(/\s*,\s*/).map(r=>{let n,s=r.split(/\s*;\s*/),i;for(;i=s.pop();)if(i.includes("=")){let[o,c]=i.split(/\s*=\s*/);n={name:o.toLowerCase(),value:c,next:n}}else n={name:i.toLowerCase(),next:n};return n})}var Kc,Vu,Ur,tde,nN,Pq,Lq,iS,Mq,Jf,sde,vq=De(()=>{Uu();gi();Kc=v(V()),Vu=v(fe());Qf();Al();uc();Nf();Dq();Qf();Ur=new Uint8Array(8),tde=new Float64Array(Ur.buffer,0,1),nN={},Pq="openapi";a(rde,"http");Jf=0;a(nde,"start");sde={401:3e3,403:3003};a(Uq,"parseHeaderValue")});var sN=b((KDe,Hq)=>{var{recordAction:aS,recordActionBinary:Bq}=(gi(),oe(I_)),ide=require("fastify-plugin"),ode=200;Hq.exports=ide(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,d,u,_;l.config?.isOperation?(d=n.body?.operation,u="operation"):(d=l.url,u="fastify-route",_=l.method),aS(o,"duration",d,_,u),Bq(s.raw.statusCode<400,"success",d,_,u),Bq(1,"response_"+s.raw.statusCode,d,_,u);let E=ode;i?.pipe?(i.on("data",S=>{E+=S.length}),i.on("end",()=>{aS(performance.now()-c,"transfer",d,_,u),aS(E,"bytes-sent",d,_,u)})):(E+=i?.length||0,aS(E,"bytes-sent",d,_,u));let f=o.toFixed(3),h=s.getHeader("Server-Timing"),T=`db;dur=${f}`;s.header("Server-Timing",h?`${h}, ${T}`:T)}),r()},{name:"hdb-request-time"})});var uN=b((QDe,Gq)=>{var dS=require("clone"),_S=ut(),ade=J(),lS=M(),WDe=V(),iN=require("fs"),aN=require("joi"),{string:uS}=aN.types(),{hdb_errors:cde,handleHDBError:cS}=fe(),{HDB_ERROR_MSGS:jDe,HTTP_STATUS_CODES:oN}=cde,{common_validators:Yu}=di(),xq=" is required",lde=["insert","update","upsert"],cN={database:{presence:!1,format:Yu.schema_format,length:Yu.schema_length},schema:{presence:!1,format:Yu.schema_format,length:Yu.schema_length},table:{presence:!0,format:Yu.schema_format,length:Yu.schema_length},action:{inclusion:{within:lde,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},ude={schema:uS.required(),table:uS.required(),action:uS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:dde,AWS_SECRET:_de,AWS_BUCKET:fde,AWS_FILE_KEY:Ede,REGION:hde}=lS.S3_BUCKET_AUTH_KEYS,mde={s3:{presence:!0},[`s3.${dde}`]:{presence:!0,type:"String"},[`s3.${_de}`]:{presence:!0,type:"String"},[`s3.${fde}`]:{presence:!0,type:"String"},[`s3.${Ede}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${hde}`]:{presence:!0,type:"String"}},kq=dS(cN);kq.data.presence={message:xq};var Fq=dS(cN);Fq.file_path.presence={message:xq};var pde=Object.assign(dS(cN),mde),lN=dS(ude);lN.csv_url=uS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();lN.passthrough_headers=aN.object();function Sde(e){let t=_S.validateObject(e,kq);return fS(e,t)}a(Sde,"dataObject");function Tde(e){let t=_S.validateBySchema(e,aN.object(lN));return fS(e,t)}a(Tde,"urlObject");function gde(e){let t=_S.validateObject(e,Fq);return fS(e,t)}a(gde,"fileObject");function Rde(e){let t=_S.validateObject(e,pde);return fS(e,t)}a(Rde,"s3FileObject");function fS(e,t){if(!t){let r=ade.checkGlobalSchemaTable(e.schema,e.table);if(r)return cS(new Error,r,oN.BAD_REQUEST);if(e.operation===lS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{iN.accessSync(e.file_path,iN.constants.R_OK|iN.constants.F_OK)}catch(n){return n.code===lS.NODE_ERROR_CODES.ENOENT?cS(n,`No such file or directory ${n.path}`,oN.BAD_REQUEST):n.code===lS.NODE_ERROR_CODES.EACCES?cS(n,`Permission denied ${n.path}`,oN.BAD_REQUEST):cS(n)}}return t}a(fS,"postValidateChecks");Gq.exports={dataObject:Sde,urlObject:Tde,fileObject:gde,s3FileObject:Rde}});var dN=b((JDe,qq)=>{"use strict";var Xf=V(),ES=M();async function Ade(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===ES.OPERATIONS_ENUM.INSERT||t.operation===ES.OPERATIONS_ENUM.UPDATE||t.operation===ES.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===ES.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(Xf.info(i.message),i):i.http_resp_msg?(Xf.error(`Error calling operation: ${e.name}`),Xf.error(i.http_resp_msg),i):(Xf.error(`Error calling operation: ${e.name}`),Xf.error(i),i)}}a(Ade,"callOperationFunctionAsAwait");qq.exports={callOperationFunctionAsAwait:Ade}});var Vq=b((ZDe,$q)=>{"use strict";var _N=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}},fN=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};$q.exports={BulkLoadFileObject:_N,BulkLoadDataObject:fN}});var Kq=b((tPe,Yq)=>{"use strict";var EN=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};Yq.exports=EN});var gN=b((aPe,l$)=>{"use strict";var hS=Yr(),pS=uN(),bde=require("needle"),Js=M(),nPe=dt(),Ku=J(),{handleHDBError:$t,hdb_errors:t$}=fe(),{HTTP_STATUS_CODES:vr,HDB_ERROR_MSGS:pr,CHECK_LOGS_WRAPPER:jc}=t$,Wu=V(),hN=require("papaparse");Ku.promisifyPapaParse();var Xs=require("fs-extra"),yde=require("path"),{chain:Wq}=require("stream-chain"),jq=require("stream-json/streamers/StreamArray"),Qq=require("stream-json/utils/Batch"),zq=require("stream-chain/utils/comp"),{finished:Jq}=require("stream"),Ode=te(),r$=dN(),Nde=FO(),{BulkLoadFileObject:pN,BulkLoadDataObject:Ide}=Vq(),SN=DO(),{verifyBulkLoadAttributePerms:n$}=Qp(),sPe=Kq(),iPe=kt(),oPe=zi(),{databases:wde}=(Le(),oe(lt)),{coerceType:Cde}=(zf(),oe(RN)),Xq="No records parsed from csv file.",Wc=`${Ode.get("HDB_ROOT")}/tmp`,{schema_regex:Dde}=di(),Zq=1024*1024*2,e$=5e3,Pde={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};l$.exports={csvDataLoad:Lde,csvURLLoad:Mde,csvFileLoad:Ude,importFromS3:vde};async function Lde(e,t){let r=pS.dataObject(e);if(r)throw $t(r,r.message,vr.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=o$(e.schema,e.table),i=hN.parse(e.data,{header:!0,skipEmptyLines:!0,transform:mN.bind(null,s),dynamicTyping:!1}),o=new SN;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&n$(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 $t(new Error,c,vr.BAD_REQUEST,void 0,void 0,!0);let l=new Ide(e.action,e.schema,e.table,i.data);return n=await r$.callOperationFunctionAsAwait(a$,l,null),n.message===Xq?Xq:c$(n.records,n.number_written)}catch(s){throw Qc(s)}}a(Lde,"csvDataLoad");async function Mde(e){let t=pS.urlObject(e);if(t)throw $t(t,t.message,vr.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Wc}/${r}`;try{await Bde(e,r)}catch(s){throw Wu.error(pr.DOWNLOAD_FILE_ERR(r)+" - "+s),$t(s,jc(pr.DOWNLOAD_FILE_ERR(r)))}try{let s=new pN(this.job_operation_function.name,e.action,e.schema,e.table,n,Js.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await TN(s);return await mS(n),i}catch(s){throw await mS(n),Qc(s)}}a(Mde,"csvURLLoad");async function Ude(e){let t=pS.fileObject(e);if(t)throw $t(t,t.message,vr.BAD_REQUEST,void 0,void 0,!0);let r=new pN(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,Js.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await TN(r)}catch(n){throw Qc(n)}}a(Ude,"csvFileLoad");async function vde(e){let t=pS.s3FileObject(e);if(t)throw $t(t,t.message,vr.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=yde.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Wc}/${s}`;let i=new pN(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Hde(s,e);let o=await TN(i);return await mS(r),o}catch(n){throw await mS(r),Qc(n)}}a(vde,"importFromS3");async function Bde(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await bde("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 $t(n,s,n.statusCode,Js.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}kde(r,e.csv_url),await xde(t,r.raw)}a(Bde,"downloadCSVFile");async function Hde(e,t){try{let r=`${Wc}/${e}`;await Xs.mkdirp(Wc),await Xs.writeFile(`${Wc}/${e}`,"",{flag:"a+"});let n=await Xs.createWriteStream(r),s=await Nde.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(){Wu.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Wu.error(pr.S3_DOWNLOAD_ERR+" - "+r),$t(r,jc(pr.S3_DOWNLOAD_ERR))}}a(Hde,"downloadFileFromS3");async function xde(e,t){try{await Xs.mkdirp(Wc),await Xs.writeFile(`${Wc}/${e}`,t)}catch(r){throw Wu.error(pr.WRITE_TEMP_FILE_ERR),$t(r,jc(pr.DEFAULT_BULK_LOAD_ERR))}}a(xde,"writeFileToTempFolder");async function mS(e){if(e)try{await Xs.access(e),await Xs.unlink(e)}catch{Wu.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(mS,"deleteTempFile");function kde(e,t){if(e.statusCode!==t$.HTTP_STATUS_CODES.OK)throw $t(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,vr.BAD_REQUEST);if(!Pde[e.headers["content-type"]])throw $t(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,vr.BAD_REQUEST);if(!e.raw)throw $t(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,vr.BAD_REQUEST)}a(kde,"validateURLResponse");async function TN(e){try{let t;switch(e.file_type){case Js.VALID_S3_FILE_TYPES.CSV:t=await Fde(e);break;case Js.VALID_S3_FILE_TYPES.JSON:t=await Gde(e);break;default:throw $t(new Error,pr.DEFAULT_BULK_LOAD_ERR,vr.BAD_REQUEST,Js.LOG_LEVELS.ERROR,pr.INVALID_FILE_EXT_ERR(e))}return c$(t.records,t.number_written)}catch(t){throw Qc(t)}}a(TN,"fileLoad");async function s$(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 hS.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&n$(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=$t(c);r(l)}}a(s$,"validateChunk");async function i$(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Ku.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Ku.isEmpty(c)&&!Ku.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(d=>c.add(d))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await r$.callOperationFunctionAsAwait(a$,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=$t(c,jc(pr.INSERT_CSV_ERR),vr.INTERNAL_SERVER_ERROR,Js.LOG_LEVELS.ERROR,pr.INSERT_CSV_ERR+" - "+c);r(l)}}a(i$,"insertChunk");async function Fde(e){let t={records:0,number_written:0},r=o$(e.schema,e.table);try{let n=new SN,s=Xs.createReadStream(e.file_path,{highWaterMark:Zq});s.setEncoding("utf8"),await hN.parsePromise(s,s$.bind(null,e,n),mN.bind(null,r));let i=n.getPermsResponse();if(i)throw $t(new Error,i,vr.BAD_REQUEST);return s=Xs.createReadStream(e.file_path,{highWaterMark:Zq}),s.setEncoding("utf8"),await hN.parsePromise(s,i$.bind(null,e,t),mN.bind(null,r)),s.destroy(),t}catch(n){throw $t(n,jc(pr.PAPA_PARSE_ERR),vr.INTERNAL_SERVER_ERROR,Js.LOG_LEVELS.ERROR,pr.PAPA_PARSE_ERR+n)}}a(Fde,"callPapaParse");function o$(e,t){let r=wde[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>Cde(i,s));return n}a(o$,"createTransformMap");function mN(e,t,r){let n=e.get(r);return n?n(t):Ku.autoCast(t)}a(mN,"typeFunction");async function Gde(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new SN,s=Wq([Xs.createReadStream(e.file_path,{encoding:"utf-8"}),jq.withParser(),c=>c.value,new Qq({batchSize:e$}),zq(async c=>{await s$(e,n,r,c)})]);await new Promise((c,l)=>{Jq(s,d=>{d?l(d):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw $t(new Error,i,vr.BAD_REQUEST);let o=Wq([Xs.createReadStream(e.file_path,{encoding:"utf-8"}),jq.withParser(),c=>c.value,new Qq({batchSize:e$}),zq(async c=>{await i$(e,t,r,c)})]);return await new Promise((c,l)=>{Jq(o,d=>{d?l(d):c()}),o.resume()}),t}catch(n){throw $t(n,jc(pr.INSERT_JSON_ERR),vr.INTERNAL_SERVER_ERROR,Js.LOG_LEVELS.ERROR,pr.INSERT_JSON_ERR+n)}}a(Gde,"insertJson");async function a$(e){let t={};try{e.data&&e.data.length>0&&qde(e.data[0])?t=await $de(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Wu.info(t.message))}catch(r){throw Qc(r)}return t}a(a$,"callBulkFileLoad");function qde(e){let t=Object.keys(e);for(let r of t)if(!Dde.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(qde,"validateColumnNames");async function $de(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=hS.insert;break;case"update":i=hS.update;break;case"upsert":i=hS.upsert;break;default:throw $t(new Error,pr.INVALID_ACTION_PARAM_ERR(n),vr.BAD_REQUEST,Js.LOG_LEVELS.ERROR,pr.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 u=global.hdb_schema[t][r].hash_attribute,_=e.length;for(;_--;)o.skipped_hashes.indexOf(e[_][u])>=0&&e.splice(_,1)}let l=Ku.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw Qc(o)}}a($de,"bulkFileLoad");function c$(e,t){return`successfully loaded ${t} of ${e} records`}a(c$,"buildResponseMsg");function Qc(e){return $t(e,jc(pr.DEFAULT_BULK_LOAD_ERR),vr.INTERNAL_SERVER_ERROR,Js.LOG_LEVELS.ERROR,pr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(Qc,"buildTopLevelErrMsg")});var d$=b((lPe,u$)=>{"use strict";var AN=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};u$.exports=AN});var E$=b((dPe,f$)=>{"use strict";var Vde=M(),_$=require("moment"),Yde=require("uuid").v4,bN=class{static{a(this,"JobObject")}constructor(){this.id=Yde(),this.type=void 0,this.start_datetime=_$().valueOf(),this.created_datetime=_$().valueOf(),this.end_datetime=void 0,this.status=Vde.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};f$.exports=bN});var yN=b((fPe,A$)=>{"use strict";var Kde=require("uuid").v4,T$=Yr(),g$=Vr(),Wde=qs(),jde=Fl(),Qde=d$(),Ot=M(),zde=E$(),Jde=J_(),Ns=V(),Xde=Hd(),ju=J(),{promisify:Zde}=require("util"),zc=require("moment"),e_e=Jp(),SS=uN(),h$=SR(),{deleteTransactionLogsBeforeValidator:t_e}=OO(),{handleHDBError:m$,hdb_errors:r_e}=fe(),{HTTP_STATUS_CODES:p$}=r_e,S$=g$.searchByValue,n_e=g$.searchByHash,s_e=T$.insert,i_e=Zde(e_e.evaluateSQL),o_e=T$.update;A$.exports={addJob:l_e,updateJob:d_e,handleGetJob:a_e,handleGetJobsByStartDate:c_e,getJobById:R$};async function a_e(e){try{let t=await R$(e.id);return ju.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}catch(t){let r=`There was an error getting job: ${t}`;throw Ns.error("There was an error getting job",t),new Error(r)}}a(a_e,"handleGetJob");async function c_e(e){try{let t=await u_e(e);if(Ns.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=zc(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=zc(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 Ns.error(r),new Error(r)}}a(c_e,"handleGetJobsByStartDate");async function l_e(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||ju.isEmptyOrZeroLength(e.operation)){let u="job parameter is invalid";return Ns.info(u),t.error=u,t}if(!Ot.JOB_TYPE_ENUM[e.operation])return Ns.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case Ot.OPERATIONS_ENUM.CSV_FILE_LOAD:n=SS.fileObject(e);break;case Ot.OPERATIONS_ENUM.CSV_URL_LOAD:n=SS.urlObject(e);break;case Ot.OPERATIONS_ENUM.CSV_DATA_LOAD:n=SS.dataObject(e);break;case Ot.OPERATIONS_ENUM.IMPORT_FROM_S3:n=SS.s3FileObject(e);break;case Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=h$(e,"date");break;case Ot.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=h$(e,"timestamp");break;case Ot.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=t_e(e);break;case Ot.OPERATIONS_ENUM.RESTART_SERVICE:if(Ot.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw m$(new Error,"Invalid service",p$.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw m$(n,n.message,p$.BAD_REQUEST,void 0,void 0,!0);let s=new zde;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 Wde(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await S$(i))}catch(u){let _=`There was an error inserting a new job: ${u}`;return Ns.error(_),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Kde();try{o=await S$(i)}catch(u){let _=`There was an error inserting a new job: ${u}`;return Ns.error(_),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return Ns.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Xde(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),d;try{d=await s_e(l)}catch(u){return Ns.error(`There was an error inserting a job for job type: ${e.operation} -- ${u}`),t.success=!1,t}if(d.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let u=`Created a job with type ${s.type} and id ${s.id}`;t.message=u,t.createdJob=s,t.success=!0,Ns.trace(u)}return t}a(l_e,"addJob");async function u_e(e){let t=zc(e.from_date,zc.ISO_8601),r=zc(e.to_date,zc.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 Qde(n,e.hdb_user);try{return await i_e(s)}catch(i){throw Ns.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(u_e,"getJobsInDateRange");async function R$(e){if(ju.isEmptyOrZeroLength(e))return ju.errorizeMessage("Invalid job ID specified.");let t=new jde(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await n_e(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return Ns.error(n),ju.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(R$,"getJobById");async function d_e(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(ju.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=zc().valueOf());let t=new Jde(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await o_e(t),r}a(d_e,"updateJob")});var D$=b((hPe,C$)=>{"use strict";var b$=J(),Sr=M(),__e=require("moment"),TS=gN(),Zf=V(),y$=yN(),O$=Xp(),N$=Wo(),I$=it(),f_e=Yp(),E_e=Lu(),{parentPort:h_e,isMainThread:w$}=require("worker_threads"),{onMessageByType:m_e}=it(),ON=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function p_e(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(b$.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(b$.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Sr.JOB_TYPE_ENUM.csv_file_load:await Li(e,TS.csvFileLoad);break;case Sr.JOB_TYPE_ENUM.csv_url_load:await Li(e,TS.csvURLLoad);break;case Sr.JOB_TYPE_ENUM.csv_data_load:await Li(e,TS.csvDataLoad);break;case Sr.JOB_TYPE_ENUM.import_from_s3:await Li(e,TS.importFromS3);break;case Sr.JOB_TYPE_ENUM.empty_trash:break;case Sr.JOB_TYPE_ENUM.export_local:await Li(e,O$.export_local);break;case Sr.JOB_TYPE_ENUM.export_to_s3:await Li(e,O$.export_to_s3);break;case Sr.JOB_TYPE_ENUM.delete_files_before:case Sr.JOB_TYPE_ENUM.delete_records_before:await Li(e,N$.deleteFilesBefore);break;case Sr.JOB_TYPE_ENUM.delete_audit_logs_before:await Li(e,N$.deleteAuditLogsBefore);break;case Sr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Li(e,f_e.deleteTransactionLogsBefore);break;case Sr.JOB_TYPE_ENUM.restart_service:return await Li(e,E_e.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(p_e,"parseMessage");async function Li(e,t){try{e.job.status=Sr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=__e().valueOf(),await y$.updateJob(e.job),await S_e(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):Zf.error(`There was an error running ${t.name} job with id ${e.job.id}`),Zf.error(n),e.job.message=n,e.job.status=Sr.JOB_STATUS_ENUM.ERROR;try{await y$.updateJob(e.job)}catch(s){throw Zf.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Li,"runJob");async function S_e(e){Zf.trace("launching job thread:",e),w$?I$.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Sr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):h_e.postMessage({type:Sr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(S_e,"launchJobThread");w$&&m_e(Sr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{I$.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Sr.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){Zf.error(r)}});C$.exports={parseMessage:p_e,RunnerMessage:ON}});var L$=b((pPe,P$)=>{"use strict";var NN=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};P$.exports=NN});var z$=b((gPe,LN)=>{"use strict";var yS=Vr(),CN=Jp(),gS=gN(),To=j_(),RS=fi(),rE=Wo(),T_e=Gb(),eE=vn(),AS=Jm(),Lt=yO(),bS=V(),g_e=Xb(),R_e=dp(),M$=Ly(),A_e=fp(),b_e=vy(),y_e=By(),O_e=ky(),N_e=Gy(),IN=pp(),U$=Xp(),I_e=Qp(),DN=yN(),$=M(),{hdb_errors:sE,handleHDBError:nE}=fe(),{HTTP_STATUS_CODES:v$}=sE,wN=jy(),B$=Lu(),K$=require("util"),Qu=Yr(),w_e=as(),C_e=gu(),H$=D$(),x$=ef(),k$=(vp(),oe(If)),F$=wt(),G$=Yp(),q$=Gp(),{setServerUtilities:D_e}=(zf(),oe(RN)),{CONTEXT:TPe}=(Hs(),oe(EA)),{_assignPackageExport:P_e}=Vi(),{transformReq:L_e}=J(),{server:M_e}=($r(),oe($a)),Xr=bS.loggerWithTag("operation"),tE=js(),$$=(Dc(),oe(Cc)),U_e=dN(),V$=yS.searchByHash,v_e=yS.searchByValue,B_e=K$.promisify(yS.search),H_e=K$.promisify(CN.evaluateSQL),x_e={[$.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[$.OPERATIONS_ENUM.CREATE_TABLE]:!0,[$.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[$.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[$.OPERATIONS_ENUM.DROP_TABLE]:!0,[$.OPERATIONS_ENUM.DROP_SCHEMA]:!0},K=L$();async function W$(e,t){try{if(e.body.operation!=="read_log"&&(bS.log_level===$.LOG_LEVELS.INFO||bS.log_level===$.LOG_LEVELS.DEBUG||bS.log_level===$.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;Xr.info(o)}}catch(n){Xr.error(n)}let r=await U_e.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return x_e[e.body.operation]&&w_e.setSchemaDataToGlobal(n=>{n&&Xr.error(n)}),r}a(W$,"processLocalTransaction");var Y$=F_e();LN.exports={chooseOperation:j$,getOperationFunction:Q$,operation:PN,processLocalTransaction:W$};D_e(LN.exports);M_e.operation=PN;function j$(e){let t;try{t=Q$(e)}catch(s){throw Xr.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=CN.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=CN.checkASTPermissions(e,i);if(o)throw Xr.error(`${v$.FORBIDDEN} from operation ${e.operation}`),Xr.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),nE(new Error,o,sE.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==$.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==$.OPERATIONS_ENUM.LOGIN&&e.operation!==$.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=I_e.verifyPerms(i,s);if(o)throw Xr.error(`${v$.FORBIDDEN} from operation ${e.operation}`),Xr.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),nE(new Error,o,sE.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw nE(s,"There was an error when trying to choose an operation path")}return r}a(j$,"chooseOperation");function Q$(e){if(Xr.trace(`getOperationFunction with operation: ${e.operation}`),Y$.has(e.operation))return Y$.get(e.operation);throw nE(new Error,sE.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),sE.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(Q$,"getOperationFunction");P_e("operation",PN);function PN(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=j$(e);return W$({body:e},n)}a(PN,"operation");async function k_e(e){Xr.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[$.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case $.OPERATIONS_ENUM.INSERT:o=await Qu.insert(i);break;case $.OPERATIONS_ENUM.UPDATE:o=await Qu.update(i);break;case $.OPERATIONS_ENUM.UPSERT:o=await Qu.upsert(i);break;case $.OPERATIONS_ENUM.DELETE:o=await rE.deleteRecord(i);break;default:Xr.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){Xr.info("Invalid operation in transaction"),Xr.error(o)}}a(k_e,"catchup");async function Zs(e){L_e(e);let t,r;try{r=await DN.addJob(e),t=r.createdJob,Xr.info("addJob result",r);let n=new H$.RunnerMessage(t,e);return{message:await H$.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 Xr.error(s),nE(n,s)}}a(Zs,"executeJob");function F_e(){let e=new Map;return e.set($.OPERATIONS_ENUM.INSERT,new K(Qu.insert)),e.set($.OPERATIONS_ENUM.UPDATE,new K(Qu.update)),e.set($.OPERATIONS_ENUM.UPSERT,new K(Qu.upsert)),e.set($.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new K(yS.searchByConditions)),e.set($.OPERATIONS_ENUM.SEARCH_BY_HASH,new K(V$)),e.set($.OPERATIONS_ENUM.SEARCH_BY_ID,new K(V$)),e.set($.OPERATIONS_ENUM.SEARCH_BY_VALUE,new K(v_e)),e.set($.OPERATIONS_ENUM.SEARCH,new K(B_e)),e.set($.OPERATIONS_ENUM.SQL,new K(H_e)),e.set($.OPERATIONS_ENUM.CSV_DATA_LOAD,new K(Zs,gS.csvDataLoad)),e.set($.OPERATIONS_ENUM.CSV_FILE_LOAD,new K(Zs,gS.csvFileLoad)),e.set($.OPERATIONS_ENUM.CSV_URL_LOAD,new K(Zs,gS.csvURLLoad)),e.set($.OPERATIONS_ENUM.IMPORT_FROM_S3,new K(Zs,gS.importFromS3)),e.set($.OPERATIONS_ENUM.CREATE_SCHEMA,new K(To.createSchema)),e.set($.OPERATIONS_ENUM.CREATE_DATABASE,new K(To.createSchema)),e.set($.OPERATIONS_ENUM.CREATE_TABLE,new K(To.createTable)),e.set($.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new K(To.createAttribute)),e.set($.OPERATIONS_ENUM.DROP_SCHEMA,new K(To.dropSchema)),e.set($.OPERATIONS_ENUM.DROP_DATABASE,new K(To.dropSchema)),e.set($.OPERATIONS_ENUM.DROP_TABLE,new K(To.dropTable)),e.set($.OPERATIONS_ENUM.DROP_ATTRIBUTE,new K(To.dropAttribute)),e.set($.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new K(RS.describeSchema)),e.set($.OPERATIONS_ENUM.DESCRIBE_DATABASE,new K(RS.describeSchema)),e.set($.OPERATIONS_ENUM.DESCRIBE_TABLE,new K(RS.describeTable)),e.set($.OPERATIONS_ENUM.DESCRIBE_ALL,new K(RS.describeAll)),e.set($.OPERATIONS_ENUM.DELETE,new K(rE.deleteRecord)),e.set($.OPERATIONS_ENUM.ADD_USER,new K(eE.addUser)),e.set($.OPERATIONS_ENUM.ALTER_USER,new K(eE.alterUser)),e.set($.OPERATIONS_ENUM.DROP_USER,new K(eE.dropUser)),e.set($.OPERATIONS_ENUM.LIST_USERS,new K(eE.listUsersExternal)),e.set($.OPERATIONS_ENUM.LIST_ROLES,new K(AS.listRoles)),e.set($.OPERATIONS_ENUM.ADD_ROLE,new K(AS.addRole)),e.set($.OPERATIONS_ENUM.ALTER_ROLE,new K(AS.alterRole)),e.set($.OPERATIONS_ENUM.DROP_ROLE,new K(AS.dropRole)),e.set($.OPERATIONS_ENUM.USER_INFO,new K(eE.userInfo)),e.set($.OPERATIONS_ENUM.READ_LOG,new K(g_e)),e.set($.OPERATIONS_ENUM.ADD_NODE,new K(R_e)),e.set($.OPERATIONS_ENUM.UPDATE_NODE,new K(M$)),e.set($.OPERATIONS_ENUM.SET_NODE_REPLICATION,new K(M$)),e.set($.OPERATIONS_ENUM.REMOVE_NODE,new K(A_e)),e.set($.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new K(b_e)),e.set($.OPERATIONS_ENUM.PURGE_STREAM,new K(y_e)),e.set($.OPERATIONS_ENUM.SET_CONFIGURATION,new K(F$.setConfiguration)),e.set($.OPERATIONS_ENUM.CLUSTER_STATUS,new K(O_e.clusterStatus)),e.set($.OPERATIONS_ENUM.CLUSTER_NETWORK,new K(N_e)),e.set($.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new K(IN.setRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new K(IN.getRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new K(IN.deleteRoutes)),e.set($.OPERATIONS_ENUM.EXPORT_TO_S3,new K(Zs,U$.export_to_s3)),e.set($.OPERATIONS_ENUM.CREATE_CSR,new K(tE.createCsr)),e.set($.OPERATIONS_ENUM.SIGN_CERTIFICATE,new K(tE.signCertificate)),e.set($.OPERATIONS_ENUM.LIST_CERTIFICATES,new K(tE.listCertificates)),e.set($.OPERATIONS_ENUM.ADD_CERTIFICATES,new K(tE.addCertificate)),e.set($.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new K(tE.removeCertificate)),e.set($.OPERATIONS_ENUM.ADD_NODE_BACK,new K($$.addNodeBack)),e.set($.OPERATIONS_ENUM.REMOVE_NODE_BACK,new K($$.removeNodeBack)),e.set($.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new K(Zs,rE.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new K(Zs,rE.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.EXPORT_LOCAL,new K(Zs,U$.export_local)),e.set($.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new K(DN.handleGetJobsByStartDate)),e.set($.OPERATIONS_ENUM.GET_JOB,new K(DN.handleGetJob)),e.set($.OPERATIONS_ENUM.GET_FINGERPRINT,new K(wN.getFingerprint)),e.set($.OPERATIONS_ENUM.SET_LICENSE,new K(wN.setLicense)),e.set($.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new K(wN.getRegistrationInfo)),e.set($.OPERATIONS_ENUM.RESTART,new K(B$.restart)),e.set($.OPERATIONS_ENUM.RESTART_SERVICE,new K(Zs,B$.restartService)),e.set($.OPERATIONS_ENUM.CATCHUP,new K(k_e)),e.set($.OPERATIONS_ENUM.SYSTEM_INFORMATION,new K(C_e.systemInformation)),e.set($.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new K(Zs,rE.deleteAuditLogsBefore)),e.set($.OPERATIONS_ENUM.READ_AUDIT_LOG,new K(T_e)),e.set($.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new K(x$.createTokens)),e.set($.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new K(x$.refreshOperationToken)),e.set($.OPERATIONS_ENUM.LOGIN,new K(k$.login)),e.set($.OPERATIONS_ENUM.LOGOUT,new K(k$.logout)),e.set($.OPERATIONS_ENUM.GET_CONFIGURATION,new K(F$.getConfiguration)),e.set($.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new K(Lt.customFunctionsStatus)),e.set($.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new K(Lt.getCustomFunctions)),e.set($.OPERATIONS_ENUM.GET_COMPONENT_FILE,new K(Lt.getComponentFile)),e.set($.OPERATIONS_ENUM.GET_COMPONENTS,new K(Lt.getComponents)),e.set($.OPERATIONS_ENUM.SET_COMPONENT_FILE,new K(Lt.setComponentFile)),e.set($.OPERATIONS_ENUM.DROP_COMPONENT,new K(Lt.dropComponent)),e.set($.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new K(Lt.getCustomFunction)),e.set($.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new K(Lt.setCustomFunction)),e.set($.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new K(Lt.dropCustomFunction)),e.set($.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new K(Lt.addComponent)),e.set($.OPERATIONS_ENUM.ADD_COMPONENT,new K(Lt.addComponent)),e.set($.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new K(Lt.dropCustomFunctionProject)),e.set($.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new K(Lt.packageComponent)),e.set($.OPERATIONS_ENUM.PACKAGE_COMPONENT,new K(Lt.packageComponent)),e.set($.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new K(Lt.deployComponent)),e.set($.OPERATIONS_ENUM.DEPLOY_COMPONENT,new K(Lt.deployComponent)),e.set($.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new K(G$.readTransactionLog)),e.set($.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new K(Zs,G$.deleteTransactionLogsBefore)),e.set($.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new K(q$.installModules)),e.set($.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new K(q$.auditModules)),e.set($.OPERATIONS_ENUM.GET_BACKUP,new K(To.getBackup)),e.set($.OPERATIONS_ENUM.ADD_SSH_KEY,new K(Lt.addSSHKey)),e.set($.OPERATIONS_ENUM.UPDATE_SSH_KEY,new K(Lt.updateSSHKey)),e.set($.OPERATIONS_ENUM.DELETE_SSH_KEY,new K(Lt.deleteSSHKey)),e.set($.OPERATIONS_ENUM.LIST_SSH_KEYS,new K(Lt.listSSHKeys)),e.set($.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new K(Lt.setSSHKnownHosts)),e.set($.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new K(Lt.getSSHKnownHosts)),e}a(F_e,"initializeOperationFunctionMap")});var NS=b((APe,Z$)=>{"use strict";var MN=M(),G_e=J(),iE=V(),{handleHDBError:UN,hdb_errors:OS}=fe(),{isMainThread:q_e}=require("worker_threads"),{Readable:$_e}=require("stream"),J$=require("os"),V_e=require("util"),Y_e=cy(),K_e=V_e.promisify(Y_e.authorize),X$=z$(),{createGzip:W_e,constants:j_e}=require("zlib");function Q_e(e){let t=`Found an uncaught exception with message: ${e.message}. ${J$.EOL}Stack: ${e.stack} ${J$.EOL}Terminating ${q_e?"HDB":"thread"}.`;console.error(t),iE.fatal(t),process.exit(1)}a(Q_e,"handleServerUncaughtException");function z_e(e,t,r){if(iE[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:OS.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(z_e,"serverErrorHandler");function J_e(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=UN(new Error,"Invalid JSON.",OS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(G_e.isEmpty(e.body.operation)){let n=UN(new Error,"Request body must include an 'operation' property.",OS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(J_e,"reqBodyValidationHandler");function X_e(e,t,r){let n;e.body.operation!==MN.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==MN.OPERATIONS_ENUM.LOGIN&&e.body.operation!==MN.OPERATIONS_ENUM.LOGOUT?K_e(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{iE.warn(s),iE.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(UN(s,i,OS.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(X_e,"authHandler");async function Z_e(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=X$.chooseOperation(e.body);let s=await X$.processLocalTransaction(e,n);if(s instanceof $_e&&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(W_e({level:j_e.Z_BEST_SPEED})))}return s}catch(s){throw iE.error(s),s}}a(Z_e,"handlePostRequest");Z$.exports={authHandler:X_e,handlePostRequest:Z_e,handleServerUncaughtException:Q_e,serverErrorHandler:z_e,reqBodyValidationHandler:J_e}});var nV=b((yPe,rV)=>{"use strict";var efe=require("fastify-plugin"),{handlePostRequest:eV,authHandler:tfe,reqBodyValidationHandler:rfe}=NS();async function nfe(e){e.decorate("hdbCore",{preValidation:[rfe,tfe],request:t=>tV(eV(t,response)),requestWithoutAuthentication:(t,r)=>tV(eV(t,r,!0))})}a(nfe,"hdbCore");async function tV(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(tV,"convertAsyncIterators");rV.exports=efe(nfe)});var oV=b((IPe,iV)=>{"use strict";var NPe=require("fs"),vN=te();vN.initSync();var{CONFIG_PARAMS:sV}=M(),sfe=1024*1024*1024;function ife(e){let t=vN.get(sV.HTTP_TIMEOUT),r=vN.get(sV.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:sfe,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,https:e}}a(ife,"getServerOptions");iV.exports=ife});var lV=b((CPe,cV)=>{"use strict";var BN=te();BN.initSync();var{CONFIG_PARAMS:aV}=M();function ofe(){let e=BN.get(aV.HTTP_CORSACCESSLIST),t=BN.get(aV.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(ofe,"getCORSOptions");cV.exports=ofe});var _V=b((PPe,dV)=>{"use strict";var uV=te();uV.initSync();var afe=M();function cfe(){return uV.get(afe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(cfe,"getHeaderTimeoutConfig");dV.exports=cfe});var xN={};et(xN,{customFunctionsServer:()=>dfe,ready:()=>IV,start:()=>ufe});function ufe(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){go||(go=NV(t),st.http((await go).server));let o=await go,c=(0,HN.dirname)(s),l=(0,HN.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!fV.has(c)){fV.add(c);try{o.register(ffe(c,l))}catch(d){if(d.message==="Root plugin has already booted")St.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw d}}},ready:IV}}async function dfe(){try{St.info("In Custom Functions Fastify server"+process.cwd()),St.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),St.debug(`Custom Functions server process ${process.pid} starting up.`),await _fe();let e=TV.get(gV.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=go=await NV(e)}catch(r){throw St.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw St.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){St.error(`Custom Functions ${process.pid} Error: ${e}`),St.error(e),process.exit(1)}}async function _fe(){try{St.info("Custom Functions starting configuration."),await RV.setUsersToGlobal(),St.info("Custom Functions completed configuration.")}catch(e){St.error(e)}}function ffe(e,t){return async function(r){try{St.info("Custom Functions starting buildRoutes"),St.trace("Loading fastify routes folder "+e),(0,EV.existsSync)(e)&&r.register(SV.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:St.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?St.error(s.message):s&&St.error(s),o()})}catch(n){St.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function NV(e){St.info("Custom Functions starting buildServer.");let t=(0,AV.default)(e),r=(0,hV.default)(t);r.server.headersTimeout=(0,yV.default)(),r.setErrorHandler(OV.serverErrorHandler);let n=(0,bV.default)();return n&&r.register(mV.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(pV.default),await r.register(lfe),await r.after(),WO(r),St.info("Custom Functions completed buildServer."),r}function IV(){if(go)return go.then?go.then(e=>e.ready()):go.ready()}var HN,EV,hV,mV,pV,SV,TV,gV,St,lfe,RV,AV,bV,yV,OV,go,fV,wV=De(()=>{HN=require("path"),EV=require("fs"),hV=v(require("fastify")),mV=v(require("@fastify/cors")),pV=v(sN()),SV=v(require("@fastify/autoload")),TV=v(te()),gV=v(M()),St=v(V()),lfe=v(nV()),RV=v(vn()),AV=v(oV()),bV=v(lV()),yV=v(_V()),OV=v(NS());Uu();$r();fV=new Set;a(ufe,"start");a(dfe,"customFunctionsServer");a(_fe,"setUp");a(ffe,"buildRouteFolder");a(NV,"buildServer");a(IV,"ready")});var kN={};et(kN,{start:()=>Efe});function Efe(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,MV.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){DV||(DV=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=CV.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,PV.default)(s,(0,LV.realpathSync)(o))}}return i(s)},{runFirst:!0})),CV.set(r,n)}}}var PV,LV,MV,CV,DV,UV=De(()=>{PV=v(require("send")),LV=require("fs"),MV=v(require("serve-static")),CV=new Map;a(Efe,"start")});var $N={};et($N,{Request:()=>FN,createReuseportFd:()=>IS});var vV,FN,GN,qN,IS,wS=De(()=>{vV=require("os"),FN=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 qN(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 GN(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},GN=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)}},qN=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,vV.platform)()!="win32"&&(IS=require("node-unix-socket").createReuseportFd)});var YN=b((xPe,BV)=>{"use strict";var oE=te();oE.initSync();var zu=require("fs-extra"),VN=require("path"),Ju=M(),hfe=require("crypto"),mfe=require("uuid").v4;BV.exports=pfe;function pfe(){if(oE.getHdbBasePath()!==void 0){let e=VN.join(oE.getHdbBasePath(),Ju.LICENSE_KEY_DIR_NAME,Ju.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=VN.join(oE.getHdbBasePath(),Ju.LICENSE_KEY_DIR_NAME,Ju.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=VN.join(oE.getHdbBasePath(),Ju.LICENSE_KEY_DIR_NAME,Ju.JWT_ENUM.JWT_PASSPHRASE_NAME);try{zu.accessSync(r),zu.accessSync(e),zu.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=mfe(),i=hfe.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});zu.writeFileSync(r,s),zu.writeFileSync(e,i.privateKey),zu.writeFileSync(t,i.publicKey)}else throw n}}}a(pfe,"checkJWTTokenExist")});var xV=b((FPe,HV)=>{"use strict";var KN=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};HV.exports={HdbInfoInsertObject:KN}});var GV=b((qPe,FV)=>{"use strict";var kV=M(),WN=class{static{a(this,"UpgradeObject")}constructor(t,r){this[kV.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[kV.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};FV.exports={UpgradeObject:WN}});var CS=b((VPe,$V)=>{"use strict";var Is=require("prompt"),Xu=require("chalk"),qV=V(),ei=require("os"),jN=qa(),QN=["yes","y"];async function Sfe(e){let t=`${ei.EOL}`+Xu.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}`;Is.override=jN(["CONFIRM_UPGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Xu.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 Is.get([r])}catch(s){return qV.error("There was an error when prompting user about an upgrade."),qV.error(s),!1}return QN.includes(n.CONFIRM_UPGRADE)}a(Sfe,"forceUpdatePrompt");async function Tfe(e){let t=`${ei.EOL}`+Xu.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}`);Is.override=jN(["CONFIRM_DOWNGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Xu.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 Is.get([r]);return QN.includes(n.CONFIRM_DOWNGRADE)}a(Tfe,"forceDowngradePrompt");async function gfe(){let e=`${ei.EOL}`+Xu.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");Is.override=jN(["GENERATE_CERTS"]),Is.start(),Is.message=e;let t={properties:{GENERATE_CERTS:{description:Xu.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 Is.get([t]);return QN.includes(r.GENERATE_CERTS)}a(gfe,"upgradeCertsPrompt");$V.exports={forceUpdatePrompt:Sfe,forceDowngradePrompt:Tfe,upgradeCertsPrompt:gfe}});var JN=b((KPe,VV)=>{"use strict";var zN=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};VV.exports=zN});var KV=b((XPe,YV)=>{"use strict";var Rfe=J(),Afe=wt(),jPe=V(),QPe=require("path"),zPe=require("fs"),JPe=M();YV.exports={getOldPropsValue:bfe};function bfe(e,t,r=!1){let n=t.getRaw(e);return Rfe.isNotEmptyAndHasValue(n)?n:r?Afe.getDefaultConfig(e):""}a(bfe,"getOldPropsValue")});var zV=b((eLe,QV)=>{"use strict";var Oa=require("path"),Na=require("fs-extra"),yfe=require("properties-reader"),Ofe=JN(),cr=V(),{getOldPropsValue:Tt}=KV(),{HDB_SETTINGS_NAMES:he,CONFIG_PARAMS:Jc}=M(),Xc=wt(),DS=te(),WV=J(),Mi=M(),XN=new Ofe("3.1.0"),jV=[];function Nfe(){let e=yfe(DS.get(he.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),cr.info(t);let r=` ;Settings for the HarperDB process.
|
|
41
|
+
|
|
42
|
+
;The directory selected during install where the database files reside.
|
|
43
|
+
${he.HDB_ROOT_KEY} = ${Tt(he.HDB_ROOT_KEY,e)}
|
|
44
|
+
;The port the HarperDB REST interface will listen on.
|
|
45
|
+
${he.SERVER_PORT_KEY} = ${Tt(he.SERVER_PORT_KEY,e)}
|
|
46
|
+
;Set to true to enable HTTPS on the HarperDB REST endpoint. Requires a valid certificate and key.
|
|
47
|
+
${he.HTTP_SECURE_ENABLED_KEY} = ${Tt(he.HTTP_SECURE_ENABLED_KEY,e)}
|
|
48
|
+
;The path to the SSL certificate used when running with HTTPS enabled.
|
|
49
|
+
${he.CERT_KEY} = ${Tt(he.CERT_KEY,e)}
|
|
50
|
+
;The path to the SSL private key used when running with HTTPS enabled.
|
|
51
|
+
${he.PRIVATE_KEY_KEY} = ${Tt(he.PRIVATE_KEY_KEY,e)}
|
|
52
|
+
;Set to true to enable Cross Origin Resource Sharing, which allows requests across a domain.
|
|
53
|
+
${he.CORS_ENABLED_KEY} = ${Tt(he.CORS_ENABLED_KEY,e)}
|
|
54
|
+
;Allows for setting allowable domains with CORS. Comma separated list.
|
|
55
|
+
${he.CORS_WHITELIST_KEY} = ${Tt(he.CORS_WHITELIST_KEY,e)}
|
|
56
|
+
;Length of time in milliseconds after which a request will timeout. Defaults to 120,000 ms (2 minutes).
|
|
57
|
+
${he.SERVER_TIMEOUT_KEY} = ${Tt(he.SERVER_TIMEOUT_KEY,e,!0)}
|
|
58
|
+
;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).
|
|
59
|
+
${he.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${Tt(he.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0)}
|
|
60
|
+
;Limit the amount of time the parser will wait to receive the complete HTTP headers.. Defaults to 60,000 ms (1 minute).
|
|
61
|
+
${he.SERVER_HEADERS_TIMEOUT_KEY} = ${Tt(he.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
|
|
62
|
+
;Define whether to log to file or not.
|
|
63
|
+
${he.LOG_TO_FILE} = ${Xc.getDefaultConfig(Jc.LOGGING_FILE)}
|
|
64
|
+
;Define whether to log to stdout/stderr or not. NOTE HarperDB must run in foreground in order to receive the std stream from HarperDB.
|
|
65
|
+
${he.LOG_TO_STDSTREAMS} = ${Xc.getDefaultConfig(Jc.LOGGING_STDSTREAMS)}
|
|
66
|
+
;Set to control amount of logging generated. Accepted levels are trace, debug, warn, error, fatal.
|
|
67
|
+
${he.LOG_LEVEL_KEY} = ${Tt(he.LOG_LEVEL_KEY,e)}
|
|
68
|
+
;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'
|
|
69
|
+
${he.LOG_PATH_KEY} = ${Tt(he.LOG_PATH_KEY,e)}
|
|
70
|
+
;Set to true to enable daily log file rotations - each log file name will be prepended with YYYY-MM-DD.
|
|
71
|
+
${he.LOG_DAILY_ROTATE_KEY} = ${Tt(he.LOG_DAILY_ROTATE_KEY,e)}
|
|
72
|
+
;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
|
|
73
|
+
;daily log files which may consume a large amount of storage depending on your log settings.
|
|
74
|
+
${he.LOG_MAX_DAILY_FILES_KEY} = ${Tt(he.LOG_MAX_DAILY_FILES_KEY,e)}
|
|
75
|
+
;The environment used by NodeJS. Setting to production will be the most performant, settings to development will generate more logging.
|
|
76
|
+
${he.PROPS_ENV_KEY} = ${Tt(he.PROPS_ENV_KEY,e)}
|
|
77
|
+
;This allows self signed certificates to be used in clustering. This is a security risk
|
|
78
|
+
;as clustering will not validate the cert, so should only be used internally.
|
|
79
|
+
;The HDB install creates a self signed certificate, if you use that cert this must be set to true.
|
|
80
|
+
${he.ALLOW_SELF_SIGNED_SSL_CERTS} = ${Tt(he.ALLOW_SELF_SIGNED_SSL_CERTS,e,!0)}
|
|
81
|
+
;Set the max number of processes HarperDB will start. This can also be limited by number of cores and licenses.
|
|
82
|
+
${he.MAX_HDB_PROCESSES} = ${Tt(he.MAX_HDB_PROCESSES,e)}
|
|
83
|
+
;Set to true to enable clustering. Requires a valid enterprise license.
|
|
84
|
+
${he.CLUSTERING_ENABLED_KEY} = ${Tt(he.CLUSTERING_ENABLED_KEY,e,!0)}
|
|
85
|
+
;The port that will be used for HarperDB clustering.
|
|
86
|
+
${he.CLUSTERING_PORT_KEY} = ${Tt(he.CLUSTERING_PORT_KEY,e)}
|
|
87
|
+
;The name of this node in your HarperDB cluster topology. This must be a value unique from the rest of your cluster node names.
|
|
88
|
+
${he.CLUSTERING_NODE_NAME_KEY} = ${Tt(he.CLUSTERING_NODE_NAME_KEY,e)}
|
|
89
|
+
;The user used to connect to other instances of HarperDB, this user must have a role of cluster_user.
|
|
90
|
+
${he.CLUSTERING_USER_KEY} = ${Tt(he.CLUSTERING_USER_KEY,e)}
|
|
91
|
+
;Defines if this instance does not record transactions. Note, if Clustering is enabled and Transaction Log is disabled your nodes will not catch up.
|
|
92
|
+
${he.DISABLE_TRANSACTION_LOG_KEY} = ${Tt(he.DISABLE_TRANSACTION_LOG_KEY,e,!0)}
|
|
93
|
+
;Defines the length of time an operation token will be valid until it expires. Example values: https://github.com/vercel/ms
|
|
94
|
+
${he.OPERATION_TOKEN_TIMEOUT_KEY} = ${Tt(he.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
|
|
95
|
+
;Defines the length of time a refresh token will be valid until it expires. Example values: https://github.com/vercel/ms
|
|
96
|
+
${he.REFRESH_TOKEN_TIMEOUT_KEY} = ${Tt(he.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
|
|
97
|
+
;The port the IPC server will run on.
|
|
98
|
+
${he.IPC_SERVER_PORT} = ${Xc.getDefaultConfig(Jc.IPC_NETWORK_PORT)}
|
|
99
|
+
;Run HDB in the foreground.
|
|
100
|
+
${he.RUN_IN_FOREGROUND} = ${Xc.getDefaultConfig(Jc.OPERATIONSAPI_FOREGROUND)}
|
|
101
|
+
;Set to true to enable custom API endpoints. Requires a valid enterprise license.
|
|
102
|
+
${he.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${Xc.getDefaultConfig(Jc.CUSTOMFUNCTIONS_ENABLED)}
|
|
103
|
+
;The port used to access the custom functions server.
|
|
104
|
+
${he.CUSTOM_FUNCTIONS_PORT_KEY} = ${Xc.getDefaultConfig(Jc.HTTP_PORT)}
|
|
105
|
+
;The path to the folder containing HarperDB custom function files.
|
|
106
|
+
${he.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${Oa.join(Tt(he.HDB_ROOT_KEY,e),"custom_functions")}
|
|
107
|
+
;Set the max number of processes HarperDB will start for the Custom Functions server
|
|
108
|
+
${he.MAX_CUSTOM_FUNCTION_PROCESSES} = ${Xc.getDefaultConfig(Jc.HTTP_THREADS)}
|
|
109
|
+
`,n=DS.get("settings_path"),s=Oa.dirname(n),i=Oa.join(s,"3_1_0_upgrade_settings.bak");try{cr.info(`Backing up old settings file to: ${i}`),Na.copySync(n,i)}catch(c){throw cr.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{cr.info("New settings file values for 3.1.0 upgrade:",r),cr.info(`Creating new/upgraded settings file at '${n}'`),Na.writeFileSync(n,r),cr.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."),cr.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),cr.error(c),Na.copySync(i,n),c}DS.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),cr.info(o),o}a(Nfe,"updateSettingsFile_3_1_0");function Ife(){let e=Oa.join(WV.getHomeDir(),Mi.HDB_HOME_DIR_NAME,Mi.LICENSE_KEY_DIR_NAME,Mi.LICENSE_FILE_NAME),t=Oa.join(WV.getHomeDir(),Mi.HDB_HOME_DIR_NAME,Mi.LICENSE_KEY_DIR_NAME,Mi.REG_KEY_FILE_NAME),r=Oa.join(DS.getHdbBasePath(),Mi.LICENSE_KEY_DIR_NAME,Mi.LICENSE_FILE_NAME),n=Oa.join(r,Mi.LICENSE_FILE_NAME),s=Oa.join(r,Mi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),cr.info(i);let o="Creating .license directory";console.log(o),cr.info(o),Na.mkdirpSync(r);try{Na.accessSync(e);try{let c="Moving licence file";console.log(c),cr.info(c),Na.moveSync(e,n);let l="License file successfully moved.";console.log(l),cr.info(l)}catch{let l="moving license file failed";console.error(l),cr.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),cr.warn(l)}try{Na.accessSync(t);try{let c="Moving registration file";console.log(c),cr.info(c),Na.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),cr.info(l)}catch{let l="moving registration file failed";console.error(l),cr.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),cr.warn(l)}}a(Ife,"moveLicenseFiles");XN.sync_functions.push(Nfe);XN.sync_functions.push(Ife);jV.push(XN);QV.exports=jV});var t1=b((rLe,e1)=>{"use strict";var Yn=ht(),{insertRecords:wfe}=Qa(),Cfe=nn(),Ia=Bt(),Dfe=J(),Ro=V(),Pfe=J(),Ui=require("fs-extra"),Ao=require("path"),Lfe=require("cli-progress"),aE=require("assert"),Mfe=require("pino"),Ufe=te();e1.exports=vfe;var PS,JV,LS,ZN,Zr,cE=!1;async function vfe(e=!0){return PS=Ufe.getHdbBasePath(),JV=Ao.join(PS,"schema"),LS=Ao.join(PS,"4_0_0_upgrade_tmp"),ZN=Ao.join(PS,"transactions"),console.info("Reindexing upgrade started for schemas"),Ro.notify("Reindexing upgrade started for schemas"),await XV(JV,!1,e),await Ui.pathExists(ZN)&&(console.info(`
|
|
110
|
+
|
|
111
|
+
Reindexing upgrade started for transaction logs`),Ro.notify("Reindexing upgrade started for transaction logs"),await XV(ZN,!0,e)),Ro.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(cE?", but errors occurred":"")}a(vfe,"reindexUpgrade");async function XV(e,t,r){let n=await Ui.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Ao.join(e,o.toString());if(o===".DS_Store")continue;let l=await Ui.readdir(c),d=l.length;for(let u=0;u<d;u++){let _=l[u];if(_!==".DS_Store"&&Ui.statSync(Ao.join(c,_)).isDirectory())try{await Bfe(o,_,t),Zr.info(`Reindexing started for ${o}.${_}`),Ro.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${_}`),await xfe(o,_,c,t,r),Zr.info(`Reindexing completed for ${o}.${_}`),Ro.notify(`Reindexing completed for ${o}.${_}`)}catch(E){cE=!0,E.schema_path=c,E.table_name=_,Ro.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Ro.error(E),Zr.error(E),console.error(E)}}}if(!cE)try{await Ui.rm(LS,{recursive:!0})}catch{}}a(XV,"processTables");async function Bfe(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Ao.join(LS,s);await Ui.ensureDir(LS),await Ui.writeFile(i,""),Zr=Mfe({level:"debug",formatters:{bindings(){}}},i)}a(Bfe,"initPinoLogger");var Hfe=20;async function xfe(e,t,r,n,s){let i;try{i=await Yn.openEnvironment(r,t,n)}catch(p){if(p.message==="MDB_INVALID: File is not an LMDB file"){Ro.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`),Zr.error(p);return}throw p}let o=Gfe(i.dbis),c=Yn.openDBI(i,o),l=Object.keys(i.dbis),d=Yn.statDBI(i,o);Zr.info(`Old environment stats: ${JSON.stringify(d)}`);let u=new Lfe.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});u.start(d.entryCount,0,{});let _=await Yn.createEnvironment(r,t,!1);Yn.createDBI(_,o,!1,!0);let E=[];try{for(let p of c.getRange({start:!1}))p.value={...p.value},E.push(p),n||e==="system"&&(t==="hdb_schema"&&(p.key=p.key.toString(),p.value.name=p.value.name.toString()),t==="hdb_table"&&(p.key=p.key.toString(),p.value.schema=p.value.schema.toString(),p.value.name=p.value.name.toString()),t==="hdb_attribute"&&(p.key=p.key.toString(),p.value.schema=p.value.schema.toString(),p.value.table=p.value.table.toString(),p.value.attribute=p.value.attribute.toString())),E.length>Hfe&&await f();await f()}catch(p){throw cE=!0,Zr.error(p),p}async function f(){let p,y=E.map(({value:B})=>B);n?p=await Promise.all(y.map(B=>kfe(_,B))):p=await wfe(_,o,l.filter(B=>B!=="__blob__"),y,!1);for(let B=0,x=E.length;B<x;B++){let{key:W,value:q}=E[B];Zr.info(`Record hash value: ${W} hash: ${o}`);let z;n?z=p[B]:z=p.written_hashes.indexOf(W)>-1,aE(z,!0),Ffe(_,o,q[o],n),Zr.info(`Insert success, written hashes: ${p.written_hashes}`),u.increment()}E=[],u.value/u.total*100%10===0&&Ro.notify(`${e}.${t} ${u.value}/${u.total} records inserted`),Zr.info(`${u.value}/${u.total} records inserted`)}a(f,"finishOutstanding"),u.stop();let h=Yn.statDBI(i,o),T=Yn.statDBI(_,o);if(Zr.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${T.entryCount}`),aE.deepStrictEqual(h.entryCount,T.entryCount),await Yn.closeEnvironment(i),await Yn.closeEnvironment(_),delete global.lmdb_map[`${e}.${t}`],s){let p=Ao.join(r,t),y=Ao.join(p,"data.mdb"),O=Ao.join(p,"lock.mdb");await Ui.unlink(y),await Ui.unlink(O),await Ui.rmdir(p),Zr.info(`Deleted old environment files from schema folder: ${y}, ${O}`)}let S=await Yn.openEnvironment(r,t),R=Yn.statDBI(S,o);Zr.info(`New stats: ${JSON.stringify(T)}. New stats after move: ${JSON.stringify(R)}`),aE.deepStrictEqual(R.entryCount,T.entryCount),await Yn.closeEnvironment(S),delete global.lmdb_map[`${e}.${t}`]}a(xfe,"processTable");async function kfe(e,t){Yn.initializeDBIs(e,Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Ia.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),Pfe.isEmpty(t.user_name)||e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(kfe,"insertTransaction");function Ffe(e,t,r,n){let i=e.dbis[t].get(r);aE.deepStrictEqual(typeof i,"object");let o;if(n){let c={[Ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[Ia.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&&!Dfe.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let d=0,u=l.length;d<u;d++){let _=l[d];ZV(e,c,_,r)}else ZV(e,c,l,r)}a(Ffe,"validateIndices");function ZV(e,t,r,n){try{let s=!1,i=Cfe.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||Zr.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),aE.deepStrictEqual(s,!0)}catch(s){cE=!0,Zr.error(s),console.error(s)}}a(ZV,"validateIndex");function Gfe(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(Gfe,"getHashDBI")});var o1=b((iLe,i1)=>{"use strict";var MS=require("path"),wa=require("fs-extra"),qfe=JN(),Zc=V(),r1=wt(),eI=te(),ti=M(),US=J(),$fe=require("properties-reader"),Vfe=qs(),Yfe=J_(),Kfe=Vr(),sLe=require("util"),Wfe=Kfe.searchByValue,jfe=Yr(),Qfe=pp(),zfe=dt(),Jfe=t1(),n1=js(),Xfe=CS(),dE=new qfe("4.0.0"),s1=[],lE,uE;async function Zfe(){try{if(await Xfe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),lE){let t=US.changeExtension(lE,".bak");await wa.move(lE,t)}if(uE){let t=US.changeExtension(uE,".bak");await wa.move(uE,t)}await n1.generateKeys()}else console.log("Using existing certificates."),n1.updateConfigCert(lE,uE,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(Zfe,"generateNewKeys");async function eEe(){console.log("Updating HarperDB nodes."),Zc.info("Updating HarperDB nodes.");let e=[];try{let t=new Vfe(ti.SYSTEM_SCHEMA_NAME,ti.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await Wfe(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!zfe.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let u=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(u),u}let l={host:c.host,port:c.port};e.push(l);let d=[];for(let u=0,_=c.subscriptions.length;u<_;u++){let E=c.subscriptions[u],f=E.channel.split(":");d.push({schema:f[0],table:f[1],publish:E.publish,subscribe:E.subscribe})}n.push({name:c.name,subscriptions:d,system_info:{hdb_version:ti.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(US.isEmptyOrZeroLength(n))return;let s=new Yfe(ti.SYSTEM_SCHEMA_NAME,ti.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await jfe.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{Qfe.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(eEe,"updateNodes");async function tEe(){let e=eI.get(ti.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(MS.join("config","settings.js"))){Zc.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),Zc.info(t);let r=MS.dirname(e),n=eI.get(ti.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=MS.join(n,"backup","4_0_0_upgrade_settings.bak"),i=MS.join(n,ti.HDB_CONFIG_FILE);try{Zc.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),wa.copySync(e,s)}catch(_){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),_}try{Zc.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),Zc.info("Updating env variables with new settings values");let _=r1.initOldConfig(e);lE=_[ti.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],uE=_[ti.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],r1.createConfigFile(_)}catch(_){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),_}let o=US.getPropsFilePath();wa.accessSync(o,wa.constants.F_OK|wa.constants.R_OK);let l=$fe(o).get(ti.HDB_SETTINGS_NAMES.INSTALL_USER),d=`settings_path = ${i}
|
|
112
|
+
install_user = ${l}`;try{wa.writeFileSync(o,d)}catch(_){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),_}try{eI.initSync(!0)}catch(_){throw console.error("Unable to initialize new properties. Please check the log for details."),_}let u="New settings file for 4.0.0 upgrade successfully created.";try{wa.removeSync(r),console.log(u),Zc.info(u)}catch(_){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),_}}a(tEe,"updateSettingsFile_4_0_0");dE.async_functions.push(tEe);dE.async_functions.push(Zfe);dE.async_functions.push(Jfe);dE.async_functions.push(eEe);s1.push(dE);i1.exports=s1});var tI=b((aLe,u1)=>{"use strict";var el=J(),rEe=M(),a1=V(),{DATA_VERSION:nEe,UPGRADE_VERSION:sEe}=rEe.UPGRADE_JSON_FIELD_NAMES_ENUM,c1=zV(),vS=o1(),tl=new Map;c1&&c1.forEach(e=>{tl.set(e.version,e)});vS&&vS.forEach(e=>{tl.set(e.version,e)});vS&&vS.forEach(e=>{tl.set(e.version,e)});function iEe(){return[...tl.keys()].sort(el.compareVersions)}a(iEe,"getSortedVersions");function l1(e){let t=e[nEe],r=e[sEe];return el.isEmptyOrZeroLength(t)||el.isEmptyOrZeroLength(r)?(a1.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),a1.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."),[]):[...tl.keys()].sort(el.compareVersions).filter(function(n){return el.compareVersions(n,t)>0&&el.compareVersions(n,r)<=0})}a(l1,"getVersionsForUpgrade");function oEe(e){return l1(e).length>0}a(oEe,"hasUpgradesRequired");function aEe(e){return el.isEmptyOrZeroLength(e)?null:tl.has(e)?tl.get(e):null}a(aEe,"getDirectiveByVersion");u1.exports={getSortedVersions:iEe,getDirectiveByVersion:aEe,getVersionsForUpgrade:l1,hasUpgradesRequired:oEe}});var HS=b((lLe,h1)=>{"use strict";var cEe=require("util"),rI=require("chalk"),lEe=require("os"),_1=Yr(),uEe=Vr(),Kn=M(),f1=xV(),sI=bR(),{UpgradeObject:d1}=GV(),{forceDowngradePrompt:dEe}=CS(),_Ee=Ic(),BS=V(),Zu=J(),iI=as(),fEe=(Le(),oe(lt)),EEe=tI(),hEe=cEe.promisify(iI.setSchemaDataToGlobal),mEe=uEe.searchByValue,pEe="info_id",SEe="2.9.9",TEe="3.0.0";async function gEe(e){let t=new f1.HdbInfoInsertObject(1,e,e),r=new sI.InsertObject(Kn.OPERATIONS_ENUM.INSERT,Kn.SYSTEM_SCHEMA_NAME,Kn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Kn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return iI.setSchemaDataToGlobal(),_1.insert(r)}a(gEe,"insertHdbInstallInfo");async function nI(e){let t,r=await E1(),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 f1.HdbInfoInsertObject(i,e,e);let o=new sI.InsertObject(Kn.OPERATIONS_ENUM.INSERT,Kn.SYSTEM_SCHEMA_NAME,Kn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Kn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return await hEe(),_1.insert(o)}a(nI,"insertHdbUpgradeInfo");async function E1(){let e=new sI.NoSQLSeachObject(Kn.SYSTEM_SCHEMA_NAME,Kn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,pEe,Kn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await mEe(e))}catch(r){console.error(r)}return t}a(E1,"getAllHdbInfoRecords");async function REe(){let e=await E1();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 AEe(){BS.info("Checking if HDB software has been updated");try{let e=_Ee.version(),t=await REe(),r;if(Zu.isEmpty(t))r=SEe;else if(r=t.data_version_num,Zu.compareVersions(r.toString(),e.toString())>0){if(!Zu.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(rI.yellow(`This instance's data was last run on version ${r}`)),console.error(rI.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.${lEe.EOL}${Kn.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Zu.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(rI.yellow(`This instance's data was last run on version ${r}`)),await dEe(new d1(r,e))?await nI(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(iI.setSchemaDataToGlobal(),bEe(r),e.toString()===r.toString())return;let n=new d1(r,e);if(EEe.hasUpgradesRequired(n))return n;Zu.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await nI(n.upgrade_version),BS.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw BS.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),BS.fatal(e),e}}a(AEe,"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 ${Kn.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in fEe.databases.system))throw console.log(t),new Error(t);if(!Zu.isEmpty(e)&&e<TEe)throw console.log(t),new Error(t)}a(bEe,"checkIfInstallIsSupported");h1.exports={insertHdbInstallInfo:gEe,insertHdbUpgradeInfo:nI,getVersionUpdateInfo:AEe}});var T1=b((dLe,S1)=>{"use strict";var xS=require("joi"),{boolean:yEe,string:oI,number:OEe}=xS.types(),m1=require("fs-extra"),_E=M(),p1=require("path"),NEe=ut();S1.exports=IEe;function IEe(e){let t=oI.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=xS.object({[_E.INSTALL_PROMPTS.ROOTPATH]:xS.custom(wEe),[_E.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:xS.alternatives([OEe.min(0),oI]).allow("null",null),[_E.INSTALL_PROMPTS.TC_AGREEMENT]:oI.valid("yes","YES","Yes"),[_E.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[_E.INSTALL_PROMPTS.CLUSTERING_ENABLED]:yEe});return NEe.validateBySchema(e,r)}a(IEe,"installValidator");function wEe(e,t){if(m1.existsSync(p1.join(e,"system/hdb_user/data.mdb"))||m1.existsSync(p1.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(wEe,"validateRootAvailable")});var R1=b((fLe,g1)=>{"use strict";var{mkdirpSync:CEe,copySync:DEe}=require("fs-extra"),Ca=require("path"),ed=M(),cI=V(),PEe=Pn(),aI=ji(),LEe=gt();g1.exports=MEe;async function MEe(e){cI.trace("Mounting HarperDB"),rl(e),rl(Ca.join(e,"backup")),rl(Ca.join(e,"keys")),rl(Ca.join(e,"keys",ed.LICENSE_FILE_NAME)),rl(Ca.join(e,"log")),rl(Ca.join(e,"database")),rl(Ca.join(e,"components")),DEe(Ca.resolve(ed.PACKAGE_ROOT,"./utility/install/README.md"),Ca.join(e,"README.md")),await UEe()}a(MEe,"mountHdb");async function UEe(){let e=ql(),t=Object.keys(aI);for(let r=0;r<t.length;r++){let n=t[r],s=aI[n].hash_attribute;try{LEe.initSystemSchemaPaths(ed.SYSTEM_SCHEMA_NAME,n);let i=new e(ed.SYSTEM_SCHEMA_NAME,n,s);i.attributes=aI[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,await PEe.createTable(n,i)}catch(i){throw cI.error(`issue creating environment for ${ed.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(UEe,"createLMDBTables");function rl(e){CEe(e,{mode:ed.HDB_FILE_PERMISSIONS}),cI.info(`Directory ${e} created`)}a(rl,"makeDirectory")});var B1=b((pLe,v1)=>{"use strict";var uI=require("os"),N1=require("inquirer"),Cs=require("fs-extra"),vEe=require("properties-reader"),sl=require("chalk"),Bi=require("path"),BEe=require("human-readable-ids").hri,HEe=require("ora"),xEe=require("yaml"),lr=V(),Da=te(),fE=J(),FS=qa(),I1=HS(),w1=Ic(),le=M(),{CONFIG_PARAM_MAP:hLe,CONFIG_PARAMS:Mt}=le,kEe=T1(),FEe=R1(),dI=wt(),GEe=vn(),qEe=Jm(),$Ee=YN(),VEe=as(),YEe=require("util").promisify,KEe=YEe(VEe.setSchemaDataToGlobal),A1=js(),nl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),Hr=a(e=>sl.magenta.bold(e),"HDB_PROMPT_MSG"),WEe="https://harperdb.io/legal/end-user-license-agreement",Pa=uI.EOL,bo="",jEe="yes",b1="Starting HarperDB install...",y1="HarperDB installation was successful.",O1="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",QEe="An out of date version of HarperDB is already installed.",lI="It appears that HarperDB is already installed. Exiting install...",zEe="Aborting install",mLe=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])$/),JEe=new RegExp(/^[^\s.,*>]+$/),XEe=uI.homedir(),ZEe=Bi.join(XEe,le.HDB_ROOT_DIR_NAME),ehe="HDB_ADMIN",the="CLUSTER_USER",rhe="dev",nhe="localhost",kS={[Mt.HTTP_CORS]:!0,[Mt.HTTP_CORSACCESSLIST]:["*"],[Mt.HTTP_PORT]:9926,[Mt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Mt.THREADS_COUNT]:1,[Mt.THREADS_DEBUG]:!0,[Mt.LOGGING_STDSTREAMS]:!0,[Mt.LOGGING_LEVEL]:"info",[Mt.OPERATIONSAPI_NETWORK_PORT]:9925,[Mt.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:"},La=FS([le.INSTALL_PROMPTS.HDB_CONFIG]),vi,C1=!1,D1=!1,P1=!1;v1.exports={install:L1,updateConfigEnv:Ehe,setIgnoreExisting:hhe};L1.createSuperUser=U1;async function L1(){console.log(Hr(Pa+b1+Pa)),lr.notify(b1);let e;La[le.INSTALL_PROMPTS.HDB_CONFIG]&&(e=she());let t=ohe();Object.assign(t,e),t[le.INSTALL_PROMPTS.TC_AGREEMENT]&&t[le.INSTALL_PROMPTS.ROOTPATH]&&t[le.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[le.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&(P1=!0,t[le.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=kEe(t);if(r)throw r.message;await ahe(),await che(t);let n=await ihe(t);vi=n[le.INSTALL_PROMPTS.ROOTPATH],La[le.INSTALL_PROMPTS.HDB_CONFIG]&&Bi.dirname(La[le.INSTALL_PROMPTS.HDB_CONFIG])===vi&&(C1=!0),!La[le.INSTALL_PROMPTS.HDB_CONFIG]&&await Cs.pathExists(Bi.join(vi,le.HDB_CONFIG_FILE))&&(console.error(lI),process.exit());let s=HEe({prefixText:Hr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),fE.isEmpty(vi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");Da.setHdbBasePath(vi),await FEe(vi),await lhe(),await uhe(n),lr.initLogSettings(!0),await U1(n),await _he(n),await A1.updateConfigCert(),await A1.generateCertsKeys(),await fhe(),$Ee(),s.stop(),console.log(Hr(Pa+y1+Pa)),lr.notify(y1)}a(L1,"install");function she(){let e=xEe.parseDocument(Cs.readFileSync(La[le.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=dI.flattenConfig(e.toJSON());return t[le.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[le.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(she,"getConfigFromFile");async function ihe(e){lr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:nl,when:yo(e[le.INSTALL_PROMPTS.ROOTPATH],Br.DESTINATION),name:le.INSTALL_PROMPTS.ROOTPATH,prefix:bo,default:ZEe,validate:async s=>ws(s)?ws(s):await Cs.pathExists(Bi.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,message:Hr(Br.DESTINATION)},{type:"input",transformer:nl,when:yo(e[le.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Br.HDB_USERNAME),name:le.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:bo,default:ehe,validate:s=>ws(s)?ws(s):(t=s,!0),message:Hr(Br.HDB_USERNAME)},{type:"password",when:yo(e[le.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Br.HDB_PASS),name:le.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:bo,validate:s=>ws(s)?ws(s):!0,message:Hr(Br.HDB_PASS)},{type:"input",transformer:nl,when:yo(e[le.INSTALL_PROMPTS.DEFAULTS_MODE],Br.DEFAULTS_MODE),name:le.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:bo,default:rhe,validate:s=>ws(s)?ws(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,message:Hr(Br.DEFAULTS_MODE)}];if(P1||r.push({type:"input",name:le.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:nl,when:yo(e[le.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Br.REPLICATION_HOSTNAME),prefix:bo,default:nhe,message:Hr(Br.REPLICATION_HOSTNAME)}),fE.autoCastBoolean(e[le.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:nl,when:yo(e[le.INSTALL_PROMPTS.CLUSTERING_NODENAME],Br.NODE_NAME),name:le.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:bo,default:BEe.random(),validate:i=>JEe.test(i)?!0:"Invalid node name, must not contain ., * or >",message:Hr(Br.NODE_NAME)},{type:"input",transformer:nl,when:yo(e[le.INSTALL_PROMPTS.CLUSTERING_USER],Br.CLUSTER_USERNAME),name:le.INSTALL_PROMPTS.CLUSTERING_USER,prefix:bo,default:the,validate:i=>ws(i)?ws(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,message:Hr(Br.CLUSTER_USERNAME)},{type:"password",when:yo(e[le.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Br.CLUSTER_PASS),name:le.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:bo,validate:i=>ws(i)?ws(i):!0,message:Hr(Br.CLUSTER_PASS)}];r.push(...s)}let n=await N1.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(ihe,"installPrompts");function yo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${Hr(t)} ${sl.gray("[hidden]")}`),lr.trace(`${Hr(t)} [hidden]`)):(console.log(`${Hr(t)} ${e}`),lr.trace(`${Hr(t)} ${e}`)),!1):!0}a(yo,"displayCmdEnvVar");function ws(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(ws,"checkForEmptyValue");function ohe(){let e=Object.keys(le.INSTALL_PROMPTS),t=FS(e),r=FS(Object.keys(le.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=le.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(ohe,"checkForPromptOverride");async function ahe(){lr.trace("Checking for existing install.");let e=fE.getPropsFilePath(),t=await Cs.pathExists(e),r;if(t){lr.trace(`Install found an existing boot prop file at:${e}`);let n=vEe(e),s=dI.getConfigValue(le.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(le.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Cs.pathExists(s)}if(!t&&fE.noBootFile()&&(r=!0),r&&!D1){if(lr.trace(`Install found existing HDB config at:${e}`),await I1.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${w1.version()}. Exiting install...`;console.log(Pa+sl.magenta.bold(QEe)),console.log(sl.magenta.bold(s)),lr.error(s)}else console.log(Pa+sl.magenta.bold(lI)),lr.error(lI);process.exit(0)}}a(ahe,"checkForExistingInstall");async function che(e){lr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${WEe}${Pa}and can be viewed by typing or copying and pasting the URL into your web browser.${Pa}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:bo,transformer:nl,when:yo(e[le.INSTALL_PROMPTS.TC_AGREEMENT],t),name:le.INSTALL_PROMPTS.TC_AGREEMENT,message:Hr(t),validate:s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:sl.yellow("Please enter 'yes' or 'no'")},n=await N1.prompt([r]);n[le.INSTALL_PROMPTS.TC_AGREEMENT]&&n[le.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==jEe&&(console.log(sl.yellow(O1)),lr.error(O1),process.exit(0))}a(che,"termsAgreement");async function lhe(){let e=Bi.join(vi,le.HDB_CONFIG_FILE),t;try{t=uI.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}
|
|
113
|
+
install_user = ${t}`,n=fE.getHomeDir(),s=Bi.join(n,le.HDB_HOME_DIR_NAME),i=Bi.join(s,le.LICENSE_KEY_DIR_NAME);try{Cs.mkdirpSync(s,{mode:le.HDB_FILE_PERMISSIONS}),Cs.mkdirpSync(i,{mode:le.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${le.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Bi.join(s,le.BOOT_PROPS_FILE_NAME);try{await Cs.writeFile(o,r)}catch(c){throw lr.error(`There was an error creating the boot file at path: ${o}`),c}Da.setProperty(le.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),Da.setProperty(le.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),Da.setProperty(Da.BOOT_PROPS_FILE_PATH,o)}}a(lhe,"createBootPropertiesFile");async function uhe(e){lr.trace("Creating HarperDB config file");let t=FS(Object.keys(le.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[le.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in kS){if(r===Mt.HTTP_PORT&&t[Mt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??kS[r],t[Mt.HTTP_SECUREPORT]=null;continue}else if(r===Mt.HTTP_PORT)continue;if(r===Mt.OPERATIONSAPI_NETWORK_PORT&&t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??kS[r],t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Mt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=kS[r])}}else t[Mt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Mt.HTTP_PORT.toLowerCase()]&&(t[Mt.HTTP_SECUREPORT]=null);try{La[le.INSTALL_PROMPTS.HDB_CONFIG]||dI.createConfigFile(t),Da.initSync()}catch(r){dhe(r)}}a(uhe,"createConfigFile");function dhe(e){lr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(zEe);let t=Bi.resolve(Da.get(Da.BOOT_PROPS_FILE_PATH),"../");t&&Cs.removeSync(t),vi&&(C1?Cs.readdirSync(vi,{withFileTypes:!0}).forEach(n=>{let s=Bi.join(n.path,n.name);s!==La[le.INSTALL_PROMPTS.HDB_CONFIG]&&Cs.removeSync(s)}):Cs.removeSync(vi)),process.exit(1)}a(dhe,"rollbackInstall");async function M1(e,t){lr.trace("Creating admin user"),await KEe();let r;try{r=await qEe.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 GEe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(M1,"createAdminUser");async function U1(e){lr.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[le.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[le.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await M1(t,r),delete e[le.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[le.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(U1,"createSuperUser");async function _he(e){lr.trace("Creating Cluster user.");let t;e[le.INSTALL_PROMPTS.CLUSTERING_USER]&&e[le.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[le.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[le.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await M1({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[le.INSTALL_PROMPTS.CLUSTERING_USER],delete e[le.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(_he,"createClusterUser");async function fhe(){let e=w1.version();if(e)await I1.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(fhe,"insertHdbVersionInfo");function Ehe(e){La[le.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Ehe,"updateConfigEnv");function hhe(e){D1=e}a(hhe,"setIgnoreExisting")});var k1=b((TLe,x1)=>{"use strict";var _I=J(),Wn=V(),H1=tI();x1.exports={processDirectives:mhe};async function mhe(e){console.log("Starting upgrade process...");let t=H1.getVersionsForUpgrade(e),r=The(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;Wn.notify(c),console.log(c);let l=[],d=[];try{l=phe(o.sync_functions)}catch(u){throw Wn.error(`Error while running an upgrade script for ${o.version}`),u}try{d=await She(o.async_functions)}catch(u){throw Wn.error(`Error while running an upgrade script for ${o.version}`),u}n.push(...l,...d)}return n}a(mhe,"processDirectives");function phe(e){if(_I.isEmptyOrZeroLength(e))return Wn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Wn.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(Wn.info(`Running function ${r.name}`),!(r instanceof Function)){Wn.info("Variable being processed is not a function");continue}let n=r();Wn.info(n),t.push(n)}return t}a(phe,"runSyncFunctions");async function She(e){if(_I.isEmptyOrZeroLength(e))return Wn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Wn.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(Wn.info(`Running function ${s.name}`),!(s instanceof Function)){Wn.info("Variable being processed is not a function");continue}let i=await s();Wn.info(i),t.push(i)}return t}a(She,"runAsyncFunctions");function The(e){if(_I.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=H1.getDirectiveByVersion(r);n&&t.push(n)}return t}a(The,"getUpgradeDirectivesToInstall")});var K1=b((RLe,Y1)=>{"use strict";var GS=te();GS.initSync();var $1=require("chalk"),F1=require("fs-extra"),No=V(),Oo=M(),G1=Ic(),ghe=k1(),fI=J(),V1=HS(),Rhe=CS(),q1=fg(),Ahe=as(),bhe=require("util").promisify,yhe=bhe(Ahe.setSchemaDataToGlobal),EI,{UPGRADE_VERSION:qS}=Oo.UPGRADE_JSON_FIELD_NAMES_ENUM;Y1.exports={upgrade:Ohe};async function Ohe(e){await yhe(),EI===void 0&&(EI=Tf()),F1.existsSync(GS.get(GS.BOOT_PROPS_FILE_PATH))||(EE("The hdb_boot_properties file was not found. Please install HDB.",Oo.LOG_LEVELS.ERROR),process.exit(1)),F1.existsSync(GS.get(Oo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(EE("The hdb settings file was not found. Please make sure HDB is installed.",Oo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await V1.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),EE(`This version of HarperDB is ${G1.version()}`,Oo.LOG_LEVELS.INFO);let r=t[qS]?t[qS]:G1.version();r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${Oo.HDB_SUPPORT_ADDRESS}`),No.notify("Missing new version field from upgrade info object"),process.exit(1)),await Nhe();let n,s=0;try{n=await Rhe.forceUpdatePrompt(t)}catch(i){No.error("There was an error when prompting user about upgrade."),No.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),No.info(`Starting upgrade to version ${r}`),await Ihe(t),EE(`HarperDB was successfully upgraded to version ${t[qS]}`,Oo.LOG_LEVELS.INFO)}a(Ohe,"upgrade");async function Nhe(){let e=!1,t=await q1.findPs(Oo.HDB_PROC_NAME);if(fI.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await q1.findPs("hdb_express");fI.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await EI.list();fI.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($1.red(r)),No.error(r),process.exit(1)}}a(Nhe,"checkIfRunning");async function Ihe(e){try{await ghe.processDirectives(e)}catch(t){throw EE("There was an error during the data upgrade. Please check the logs.",Oo.LOG_LEVELS.ERROR),t}try{await V1.insertHdbUpgradeInfo(e[qS])}catch(t){No.error("Error updating the 'hdb_info' system table."),No.error(t)}}a(Ihe,"runUpgrade");function EE(e,t=void 0){t||(t=No.info),No[t](e),console.log($1.magenta(e))}a(EE,"printToLogAndConsole")});var J1=b((bLe,z1)=>{"use strict";var{promises:mI,createReadStream:whe,createWriteStream:Che}=require("fs"),{createGzip:Dhe}=require("zlib"),{promisify:Phe}=require("util"),{pipeline:Lhe}=require("stream"),Mhe=Phe(Lhe),Uhe=require("path"),ol=te();ol.initSync();var il=V(),{CONFIG_PARAMS:hE,ITC_EVENT_TYPES:vhe}=M(),{onMessageFromWorkers:Bhe}=it(),Hhe=6e4,xhe="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",khe="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",hI,j1;z1.exports=Q1;Bhe(e=>{e.type===vhe.RESTART&&(ol.initSync(!0),clearInterval(j1),ol.get(hE.LOGGING_ROTATION_ENABLED)&&Q1())});async function Q1(){try{let e=il.getLogFilePath(),t=ol.get(hE.LOGGING_ROTATION_MAXSIZE),r=ol.get(hE.LOGGING_ROTATION_INTERVAL);if(!t&&!r){il.error(xhe);return}let n=ol.get(hE.LOGGING_ROTATION_PATH);if(!n){il.error(khe);return}let s;if(t){let o=t.slice(-1),c=t.slice(0,-1);o==="G"?s=c*1e9:o==="M"?s=c*1e6:s=c*1e3}let i;if(r){let o=r.slice(-1),c=r.slice(0,-1);o==="D"?i=c*1440:o==="H"?i=c*60:i=c}hI=Date.now()/6e4,il.trace("Log rotate enabled, maxSize:",t,"interval:",r),j1=setInterval(async()=>{if(s){let o;o=await mI.stat(e),o.size>=s&&await W1(e,n)}i&&Date.now()/6e4-hI>=i&&(await W1(e,n),hI=Date.now()/6e4)},Hhe).unref()}catch(e){il.error(e)}}a(Q1,"logRotator");async function W1(e,t){let r=ol.get(hE.LOGGING_ROTATION_COMPRESS),n=Uhe.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.${r?"log.gz":"log"}`);r?(await Mhe(whe(e),Dhe(),Che(n)),await mI.unlink(e)):await mI.rename(e,n),il.closeLogFile(),il.notify(`hdb.log rotated, old log moved to ${n}`)}a(W1,"moveLogFile")});var iY=b(sY=>{"use strict";var me=te();me.initSync();var OLe=Lu(),Zt=M(),jn=V(),Io=require("fs-extra"),wo=require("path"),Fhe=require("systeminformation"),Ghe=YN(),{install:qhe}=B1(),pI=require("chalk"),$he=Kl(),Co=J(),SI=wt(),Z1=qa(),X1=Ap(),Vhe=K1(),Yhe=J1(),{compactOnStart:Khe}=(aO(),oe(oO)),Whe=require("minimist"),jhe=js(),{PACKAGE_ROOT:Qhe,CONFIG_PARAMS:Ne}=M(),{startHTTPThreads:zhe,startSocketServer:NLe,mostIdleRouting:ILe,remoteAffinityRouting:wLe}=(TI(),oe(oY)),Jhe=HS(),{isMainThread:Xhe}=require("worker_threads"),CLe=ji(),DLe=fi(),PLe=TA(),LLe=ql(),$S=M(),Hi,td,eY=!1,Zhe="Upgrade complete. Starting HarperDB.",eme="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",tme="HarperDB not found, starting install process.",rme="There was an error during install, check install_log.log for more details. Exiting.",nme="HarperDB successfully started.";function sme(){if(!eY){let e=a(()=>{Io.removeSync(wo.join(me.get(Zt.CONFIG_PARAMS.ROOTPATH),Zt.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(sme,"addExitListeners");async function tY(e=!1,t=!1){if(console.log(pI.magenta("Starting HarperDB...")),jn.suppressLogging?.(()=>{console.log(pI.magenta(""+Io.readFileSync(wo.join(Qhe,"utility/install/ascii_logo.txt"))))}),await nY()===!1){console.log(tme);try{await qhe()}catch(o){console.error(rme,o),jn.error(o),process.exit(1)}}if(!e){let o=Z1(Object.keys(Zt.CONFIG_PARAM_MAP),!0);!Co.isEmpty(o)&&!Co.isEmptyOrZeroLength(Object.keys(o))&&SI.updateConfigValue(void 0,void 0,o,!0,!0)}let r,n=td?.service==="clustering";td?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));try{let o=Number.parseInt(await Io.readFile(wo.join(me.get(Zt.CONFIG_PARAMS.ROOTPATH),Zt.HDB_PID_FILE),"utf8")),c=await Fhe.processes();for(let l of c.list)if(l.pid===o){n?r=!0:console.log("HarperDB appears to be already running.");break}}catch{}Hi===void 0&&(Hi=Tf()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),me.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await X1.generateNatsConfig(),await Hi.startClusteringProcesses(!0),process.exit()),sme(),await Io.writeFile(wo.join(me.get($S.CONFIG_PARAMS.ROOTPATH),$S.HDB_PID_FILE),`${process.pid}`),jn.info("HarperDB PID",process.pid);let s;try{let o=await Jhe.getVersionUpdateInfo();o!==void 0&&(s=o[Zt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Vhe.upgrade(o),console.log(Zhe))}catch(o){s?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${s}. Exiting HarperDB.`,o),jn.error(o)):(console.error(eme,o),jn.error(o)),process.exit(1)}Ghe(),ame(),await jhe.reviewSelfSignedCert(),Co.autoCastBoolean(me.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&Xhe&&await X1.generateNatsConfig(t)}a(tY,"initialize");async function ime(e=!1){try{td=Whe(process.argv),td.ROOTPATH&&SI.updateConfigObject("settings_path",wo.join(td.ROOTPATH,Zt.HDB_CONFIG_FILE)),await tY(e,!0),me.get(Zt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Khe();let t=process.env.IS_SCRIPTED_SERVICE&&!td.service;Co.autoCastBoolean(me.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Hi.startClusteringProcesses(),await Hi.startClusteringThreads()),await zhe(process.env.DEV_MODE?1:me.get($S.CONFIG_PARAMS.THREADS_COUNT)??me.get($S.CONFIG_PARAMS.THREADS)),me.get(Zt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Yhe(),t||rY()}catch(t){console.error(t),jn.error(t),process.exit(1)}}a(ime,"main");function rY(){jn.suppressLogging(()=>{console.log(pI.magenta(`HarperDB ${$he.version} successfully started`))}),jn.notify(nme)}a(rY,"started");async function ome(e=!0){eY=!e;try{Hi===void 0&&(Hi=Tf()),Hi.enterPM2Mode(),await tY(),Co.autoCastBoolean(me.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Hi.startClusteringProcesses(),await Hi.startService(Zt.PROCESS_DESCRIPTORS.HDB),rY(),e&&process.exit(0)}catch(t){console.error(t),jn.error(t),process.exit(1)}}a(ome,"launch");function ame(){let e=wo.join(me.get(Zt.CONFIG_PARAMS.ROOTPATH),Zt.LICENSE_KEY_DIR_NAME,Zt.LICENSE_FILE_NAME),t=wo.join(e,Zt.LICENSE_FILE_NAME),r=wo.join(e,Zt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=Z1(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Co.isEmpty(n)||Co.isEmpty(s))return;Io.mkdirpSync(e),Io.writeFileSync(r,n),Io.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),jn.error(s)}}a(ame,"writeLicenseFromVars");Object.assign(sY,{launch:ome,main:ime,isHdbInstalled:nY,startupLog:cme});async function nY(){try{await Io.stat(Co.getPropsFilePath()),await Io.stat(me.get(Zt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Co.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw jn.error(`Error checking for HDB install - ${e}`),e}return!0}a(nY,"isHdbInstalled");function cme(e){let r=a(f=>f.padEnd(20),"pad"),n=`
|
|
114
|
+
`;me.get(Ne.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${me.get(Ne.REPLICATION_HOSTNAME)}
|
|
115
|
+
`),me.get(Ne.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${me.get(Ne.REPLICATION_URL)}
|
|
116
|
+
`),n+=`${r("Worker Threads:")}${me.get(Ne.THREADS_COUNT)}
|
|
117
|
+
`,n+=`${r("Root Path:")}${me.get(Ne.ROOTPATH)}
|
|
118
|
+
`,me.get(Ne.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=me.get(Ne.THREADS_DEBUG_PORT)?`, TCP: ${me.get(Ne.THREADS_DEBUG_PORT)}
|
|
119
|
+
`:`
|
|
120
|
+
`);let s=wo.join(me.get(Ne.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${me.get(Ne.LOGGING_LEVEL)}, location: ${s+(me.get(Ne.LOGGING_STDSTREAMS)?", stdout/err":"")}
|
|
121
|
+
`,n+=r("Default:"),n+=me.get(Ne.HTTP_PORT)?`HTTP (and WS): ${me.get(Ne.HTTP_PORT)}, `:"",n+=me.get(Ne.HTTP_SECUREPORT)?`HTTPS (and WS): ${me.get(Ne.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${me.get(Ne.HTTP_CORS)?`enabled for ${me.get(Ne.HTTP_CORSACCESSLIST)}`:"disabled"}
|
|
122
|
+
`,n+=r("Operations API:"),n+=me.get(Ne.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${me.get(Ne.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=me.get(Ne.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${me.get(Ne.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${me.get(Ne.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${me.get(Ne.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${me.get(Ne.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
|
|
123
|
+
`,n+=r("MQTT:"),n+=me.get(Ne.MQTT_NETWORK_PORT)?`TCP: ${me.get(Ne.MQTT_NETWORK_PORT)}, `:"",n+=me.get(Ne.MQTT_NETWORK_SECUREPORT)?`TLS: ${me.get(Ne.MQTT_NETWORK_SECUREPORT)}`:"",n+=me.get(Ne.MQTT_WEBSOCKET)&&me.get(Ne.HTTP_PORT)?`, WS: ${me.get(Ne.HTTP_PORT)}`:"",n+=me.get(Ne.MQTT_WEBSOCKET)&&me.get(Ne.HTTP_SECUREPORT)?`, WSS: ${me.get(Ne.HTTP_SECUREPORT)}
|
|
124
|
+
`:`
|
|
125
|
+
`;let i=me.get(Ne.REPLICATION_PORT)??me.get(Ne.OPERATIONSAPI_NETWORK_PORT),o=me.get(Ne.REPLICATION_SECUREPORT)??me.get(Ne.OPERATIONSAPI_NETWORK_SECUREPORT),c=r("Replication:");c+=i?`WS: ${i}, `:"",c+=o?`WSS: ${o} `:"",n+=`${c.slice(0,-2)}
|
|
126
|
+
`;let l=[],d=SI.getConfigObj();for(let f in d)d[f].package&&l.push(f);let u={},_=`${r("REST:")}`;for(let[f,h]of e)for(let T of h){let S=T.name;S==="rest"&&(_+=`${T.protocol_name}: ${f}, `),l.includes(S)&&(u[S]?u[S]+=`${T.protocol_name}: ${f}, `:u[S]=`${T.protocol_name}: ${f}, `)}_.length>21&&(_=_.slice(0,-2),n+=`${_}
|
|
127
|
+
`);let E=me.get(Ne.HTTP_PORT)?`HTTP: ${me.get(Ne.HTTP_PORT)}, `:"";E+=me.get(Ne.HTTP_SECUREPORT)?`HTTPS: ${me.get(Ne.HTTP_SECUREPORT)}, `:"",E.length>21&&(E=E.slice(0,-2));for(let f of l)u[f]?n+=`${r(f)}${u[f].slice(0,-2)}
|
|
128
|
+
`:n+=`${r(f)}${E}
|
|
129
|
+
`;console.log(n),me.get(Ne.LOGGING_STDSTREAMS)&&jn.logsAtLevel("info")&&jn.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(cme,"startupLog")});var CI=b(Ma=>{"use strict";var{isMainThread:RI,parentPort:TE,threadId:YS,workerData:lme}=require("worker_threads"),{Socket:ume,createServer:dme}=require("net"),{createServer:_me,IncomingMessage:fme}=require("http"),{createServer:Eme}=require("https"),{unlinkSync:uY,existsSync:hme}=require("fs"),en=V(),At=te(),er=M(),{server:QS}=($r(),oe($a)),{WebSocketServer:mme}=require("ws"),{createServer:pme}=require("node:tls"),{getTicketKeys:Sme,restartNumber:Tme,getWorkerIndex:rd}=it(),{Headers:AI,appendHeader:gme}=(Nf(),oe(qF)),{recordAction:mE,recordActionBinary:aY}=(gi(),oe(I_)),{Request:dY,createReuseportFd:SE}=(wS(),oe($N)),{checkMemoryLimit:Rme}=sc(),{createTLSSelector:_Y}=js(),{resolvePath:fY}=wt(),{startupLog:Ame}=iY(),EY=At.get(er.CONFIG_PARAMS.THREADS_DEBUG);if(EY){let e;if(RI)e=At.get(er.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){en.info("Could not close debugger",t)}});else{let t=At.get(er.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&rd()>=0&&(e=t+rd())}if(e){let t=At.get(er.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=At.get(er.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){en.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&RI)try{require("inspector").open(9229)}catch(e){Tme<=1&&en.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:vLe,CONFIG_PARAMS:bme}=er;At.initSync();var yme=At.get(bme.HTTP_SESSIONAFFINITY),xi={},bI=new Map;Ma.registerServer=II;Ma.httpServer=wI;Ma.deliverSocket=NI;Ma.startServers=hY;Ma.listenOnPorts=mY;Ma.when_components_loaded=null;QS.http=wI;QS.request=wme;QS.socket=Cme;QS.ws=Dme;var gI={},pE={},Ome,VS={},KS={},Nme=[],yI=[];function hY(){return Ma.when_components_loaded=zS().loadRootComponents(!0).then(()=>{TE?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)NI(n,r,s);else if(t.requestId)Ime(t);else if(t.type===er.ITC_EVENT_TYPES.SHUTDOWN){en.trace("received shutdown request",YS);for(let i in xi){let o=xi[i],c;if(o.closeIdleConnections){let d=Object.getOwnPropertySymbols(o).find(E=>E.description.includes("connections")),u=0,_=setInterval(()=>{u++;let E=u>=100,f=o[d][E?"all":"idle"]();if(f.length===0){E&&clearInterval(_);return}u===1?en.info(`Closing ${f.length} idle connections`):E&&en.warn(`Forcefully closing ${f.length} active connections`);for(let h=0,T=f.length;h<T;h++){let S=f[h].socket;S._httpMessage&&!S._httpMessage.finished&&!E||(E?S.destroySoon():S.end(`HTTP/1.1 408 Request Timeout\r
|
|
39
130
|
Connection: close\r
|
|
40
131
|
\r
|
|
41
|
-
`))}},25).unref()}o.close?.(()=>{if(
|
|
42
|
-
`)}a(uq,"defaultNotFound")});async function Oq({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await cO.get(e,{returnNonexistent:!0});i=new dO(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await cO.get(e);o&&o.delete()}i=new cp(e,t)}return n&&(n.id=e,n.user={username:t?.username},x_.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function lO(){return ap++,ap>65500&&(ap=1),ap}function uO(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=To.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 gt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var Aq,vo,bq,yq,cO,x_,ap,cp,dO,Nq=Oe(()=>{Ne();Sd();Aq=v(hn()),vo=v(j());ca();bq=v(et()),yq=v(Rq());Lr();cO=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"}]}}]}),x_=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,bq.getWorkerIndex)()===0&&(async()=>{await yq.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of x_.search({})){let t=e.data,r=Object.assign({},e);r.user?.username&&(r.user=await it.getUser(r.user.username)),gt(r,()=>{try{uO(r,t,r)}catch{(0,vo.warn)("Failed to publish will",t)}x_.delete(e.id,r)})}})();a(Oq,"getSession");ap=1;a(lO,"getNextMessageId");cp=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,d;if(c>-1?(l=s.slice(c),d=s.slice(0,c)):d=s,!d)throw new Error("No topic provided");if(d.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let u=this.subscriptions.find(g=>g.topic===s),_;u?(_=i>0,u.end(),this.subscriptions.splice(this.subscriptions.indexOf(u),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,vo.trace)("Resuming subscription from",s,"from",o);let f=To.getMatch(d,"mqtt");if(!f){let g=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw g.statusCode=404,g}if(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let g=E.url.slice(1);if(g.indexOf("#")>-1&&g.indexOf("#")!==g.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,g.indexOf("+")===g.length-1)E.onlyChildren=!0,E.url="/"+g.slice(0,g.length-1);else{let T=g.split("/"),A;for(let x=0;x<T.length;x++)if(T[x].indexOf("+")>-1)if(T[x]==="+")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 I=!0;T[T.length-1]==="#"&&(T.length--,I=!1),A&&(n=a(x=>{let X=x.id;if(!Array.isArray(X)||I&&X.length!==T.length)return!1;for(let $=0;$<T.length;$++)if(T[$]!=="+"&&T[$]!==X[$])return!1;return!0},"filter"));let V=T.indexOf("+");E.url="/"+(V>-1?T.slice(0,V):T).concat("").join("/")}}let h=f.path,p=f.Resource,S=await gt(E,async()=>{let g=this.createContext();g.topic=s,g.retainHandling=i;let T=await p.subscribe(E,g);if(!T)throw new Error(`No subscription was returned from subscribe for topic ${s}`);if(!T[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);return(async()=>{for await(let A of T)try{let I;if(A.type&&A.type!=="put"&&A.type!=="delete"&&A.type!=="message"&&A.type!=="patch"||n&&!n(A))continue;r?(A.topic=s,I=this.needsAcknowledge(A)):(A.acknowledge?.(),I=lO());let V=A.id;Array.isArray(V)&&(V=Yc(V)),V==null&&(V=""),this.listener(h+"/"+V,A.value,I,t)}catch(I){(0,vo.warn)(I)}})(),T});return S.topic=s,S.qos=t.qos,this.subscriptions.push(S),S}resume(){}needsAcknowledge(t){let r=lO();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,t.acknowledge)),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return uO(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();gt(r,async()=>{try{if(!t){let n=await x_.get(this.sessionId);n?.doesExist()&&await uO(n,n.data,r)}}finally{await x_.delete(this.sessionId)}}).catch(n=>{(0,vo.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(uO,"publish");dO=class extends cp{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.timestamp):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=lO(),n={topic:t.topic,timestamp:t.timestamp};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks.get(t);this.awaitingAcks.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,vo.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,Aq.getNextMonotonicTime)()),(0,vo.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),cO.put(this.sessionRecord)}}});var fO={};Ze(fO,{bypassAuth:()=>aue,start:()=>cue});function aue(){Lq=!0}function cue({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new Dq.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((d,u,_)=>{if(d.protocol==="mqtt"){o.events.emit("connection",d),Nr.debug?.("Received WebSocket connection for MQTT from",d._socket.remoteAddress);let{onMessage:E,onClose:f}=wq(d,(h,p)=>{if(d.send(h),p&&d._socket.writableNeedDrain)return new Promise(S=>this._socket.once("drain",S))},u,Promise.resolve(_).then(()=>u?.user),o);d.on("message",E),d.on("close",f),d.on("error",h=>{Nr.info?.("WebSocket error",h)})}},Object.assign({subProtocol:"mqtt"},n))),(t||s)&&c.push(e.socket(async d=>{let u;if(o.events.emit("connection",d),Nr.debug?.(`Received ${d.getCertificate?"SSL":"TCP"} connection for MQTT from ${d.remoteAddress}`),l){if(d.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=d.getPeerCertificate().subject.CN);try{u=await e.getUser(f,null,null),(0,Bl.get)(Ir.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&up.notify({username:u?.username,status:Ir.AUTH_AUDIT_STATUS.SUCCESS,type:Ir.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:d.remoteAddress})}catch(h){throw(0,Bl.get)(Ir.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&up.error?.({username:f,status:Ir.AUTH_AUDIT_STATUS.FAILURE,type:Ir.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:d.remoteAddress}),h}}else Nr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",d.remoteAddress)}catch(f){o.events.emit("error",f,d),Nr.error?.(f)}else if(l.required)return Nr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${d.authorizationError}`),d.end()}!u&&Lq&&d.remoteAddress.includes("127.0.0.1")&&(u=await(0,Cq.getSuperUser)(),Nr.debug?.("Auto-authorizing local connection",u?.username));let{onMessage:_,onClose:E}=wq(d,f=>d.write(f),null,u,o);d.on("data",_),d.on("close",E),d.on("error",f=>{Nr.info?.("Socket error",f)})},{port:t,securePort:s,mtls:l})),c}function wq(e,t,r,n,s){Iq||(Iq=!0,td(_=>{lp>0&&_.push({metric:"mqtt-connections",connections:lp,byThread:!0})}));let i;lp++;let o,c={protocolVersion:4},l=(0,dp.parser)({protocolVersion:5});function d(_){l.parse(_)}a(d,"onMessage");function u(){lp--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),wn(!1,"connection","mqtt","disconnect"),Nr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(u,"onClose"),l.on("packet",async _=>{n?.then&&(n=await n),o?.then&&await o;let E=_.topic,f=E?.indexOf("/",1),h=f>0?E.slice(0,f):E;Qr(_.length,"bytes-received",h,S(_),"mqtt");try{switch(o?.receivedPacket?.(),_.cmd){case"connect":if(c.protocolVersion=_.protocolVersion,_.username)try{n=await it.getUser(_.username,_.password.toString(),r),(0,Bl.get)(Ir.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&up.notify({username:n?.username,status:Ir.AUTH_AUDIT_STATUS.SUCCESS,type:Ir.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch($){return(0,Bl.get)(Ir.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&up.error?.({username:_.username,status:Ir.AUTH_AUDIT_STATUS.FAILURE,type:Ir.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",_,e,$),wn(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",_,e),wn(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(_,n),_.will){let $=e.deserialize||(e.deserialize=Fa(r?.headers.get?.("content-type")));_.will.data=_.will.payload?.length>0?$(_.will.payload):void 0,delete _.will.payload}o=Oq({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch($){return Nr.error?.($),s.events.emit("auth-failed",_,e,$),wn(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:$.code||5,returnCode:$.code||128})}s.events.emit("connected",o,e),wn(!0,"connection","mqtt","connect"),p({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener(($,F,se,ee)=>{try{let Z=$.indexOf("/",1),le=Z>0?$.slice(0,Z):$;p({cmd:"publish",topic:$,payload:g(F),messageId:se||Math.floor(Math.random()*1e8),qos:ee.qos},le)}catch(Z){Nr.error?.(Z),o?.disconnect(),s.sessions.delete(o)}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let T=[];for(let $ of _.subscriptions){let F;try{F=(await o.addSubscription($,$.qos>=1)).qos||0}catch(se){s.events.emit("error",se,e,$,o),Nr.error?.(se),F=c.protocolVersion<5?128:se.statusCode===403?135:se.statusCode===404?143:128}T.push(F)}await o.committed,p({cmd:"suback",granted:T,messageId:_.messageId});break;case"unsubscribe":{let $=[];for(let F of _.unsubscriptions)$.push(o.removeSubscription(F)?0:17);p({cmd:"unsuback",granted:$,messageId:_.messageId});break}case"pubrel":p({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let A=_.qos===2?"pubrec":"puback",I=e.deserialize||(e.deserialize=Fa(r?.headers.get?.("content-type"))),x=(_.payload?.length||0)>0?I(_.payload):void 0,X;try{X=await o.publish(_,x)}catch($){s.events.emit("error",$,e,_,o),Nr.warn?.($),_.qos>0&&p({cmd:A,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&p({cmd:A,messageId:_.messageId,reasonCode:X===!1?144:0},_.topic);break;case"pubrec":p({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":p({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),wn(!0,"connection","mqtt","disconnect"),Nr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(T){s.events.emit("error",T,e,_,o),Nr.error?.(T),p({cmd:"disconnect"})}function p(T,A){let I=(0,dp.generate)(T,c);t(I),Qr(I.length,"bytes-sent",A,S(T),"mqtt")}a(p,"sendPacket");function S(T){return T.qos>0?T.cmd+",qos="+T.qos:T.cmd}a(S,"packetMethodName");function g(T){return va(T,r)}a(g,"serialize")}),l.on("error",_=>{Nr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:d,onClose:u}}var dp,Cq,Bl,Ir,_O,Dq,up,Nr,Lq,Iq,lp,Pq=Oe(()=>{dp=require("mqtt-packet");Nq();Cq=v($n());hl();yi();Lr();Bl=v(ne()),Ir=v(M()),_O=v(md()),Dq=require("events"),up=(0,_O.loggerWithTag)("auth-event"),Nr=(0,_O.loggerWithTag)("mqtt"),Lq=(0,Bl.get)(Ir.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(aue,"bypassAuth");a(cue,"start");lp=0;a(wq,"onSocket")});var am={};Ze(am,{component_errors:()=>kl,loadComponent:()=>_p,loadComponentDirectories:()=>Fq,setErrorReporter:()=>_ue});function Fq(e,t){t&&(hO=t),e&&(mO=e);let r=[];if((0,At.existsSync)(EO)){let s=(0,At.readdirSync)(EO,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,wt.join)(EO,o);r.push(_p(c,hO,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(_p(n,hO,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{kq=!0})}function _ue(e){B_=e}async function _p(e,t,r,n,s,i){let o=(0,At.realpathSync)(e);if(!Uq.has(o)){Uq.set(o,!0),s&&(mO=s);try{let c;n&&(kl=new Map);let l=(0,wt.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,At.existsSync)(l)?c=n?(0,fp.getConfigObj)():(0,vq.parseDocument)((0,At.readFileSync)(l,"utf8")).toJSON():c=pO;let d=(0,wt.join)(e,"node_modules","harperdb");try{Qa.isMainThread&&(n||(0,At.existsSync)(d)&&(0,At.realpathSync)(Gl.PACKAGE_ROOT)!==(0,At.realpathSync)(d))&&((0,At.rmSync)(d,{recursive:!0,force:!0}),(0,At.existsSync)((0,wt.join)(e,"node_modules"))||(0,At.mkdirSync)((0,wt.join)(e,"node_modules")),(0,At.symlinkSync)(Gl.PACKAGE_ROOT,d,"dir"))}catch(_){Hl.default.error("Error symlinking harperdb module",_)}let u=n;for(let _ in c){let E=c[_];if(kl.set(n?_:(0,wt.basename)(e),!1),!E)continue;let f,h=E.package;try{if(h){let A=e,I;for(;!(0,At.existsSync)(I=(0,wt.join)(A,"node_modules",_));)if(A=(0,wt.dirname)(A),A.length<(0,Hq.getHdbBasePath)().length){I=null;break}if(I)f=await _p(I,t,r,!1),u=!0;else throw new Error(`Unable to find package ${_}:${h}`)}else f=due[_];if(!f)continue;let p=a(A=>(A.origin=r,ft(A)),"ensureTable"),S=E.network||(E.port||E.securePort)&&E,g=S?.securePort||S?.https&&S.port,T=!S?.https&&S?.port;if(Qa.isMainThread&&(f=await f.startOnMainThread?.({server:it,ensureTable:p,port:T,securePort:g,resources:t,...E})||f,n&&S))for(let A of[T,g])try{if(+A&&!Mq.includes(A)){let I=SO.get(Gl.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);I&&Hl.default.warn("Session affinity is not recommended and may cause memory leaks"),(I||!Xm)&&(Mq.push(A),QG(A,I))}}catch(I){console.error("Error listening on socket",A,I,_)}if(t.isWorker&&(f=await f.start?.({server:it,ensureTable:p,port:T,securePort:g,resources:t,...E})||f),mO.set(f,!0),(f.handleFile||f.handleDirectory||f.setupFile||f.setupDirectory)&&E.files!=null){if(E.files.includes(".."))throw(0,Bq.handleHDBError)("Can not reference parent directories");let A=(0,wt.join)(e,E.files).replace(/\\/g,"/"),I=A.indexOf("/*");if(I>-1&&E.files!==pO[_]?.files&&!(0,At.existsSync)(A.slice(0,I)))throw new Error(`The path '${A.slice(0,I)}' does not exist and cannot be used as the base of the resolved 'files' path value '${E.files}'`);let V=(0,wt.basename)(e),x=E.path||"/";x=x.startsWith("/")?x:x.startsWith("./")?"/"+V+x.slice(2):x==="."?"/"+V:"/"+V+"/"+x;let X,$,F;if(E.root){let ee=E.root;ee.startsWith("/")&&(ee=ee.slice(1)),ee.endsWith("/")&&(ee=ee.slice(0,-1)),ee+="/",$=(0,wt.join)(e,ee)}else(F=A.indexOf("/*"))>-1&&($=A.slice(0,F+1),X=(0,wt.relative)(e,$));let se=!1;if(Qa.isMainThread&&f.setupDirectory&&(se=await f.setupDirectory?.(x,$,t)),t.isWorker&&f.handleDirectory&&(se=await f.handleDirectory?.(x,$,t)),se)continue;for(let ee of await(0,xq.default)(A,{onlyFiles:!1,objectMode:!0})){let{path:Z,dirent:le}=ee;u=!0;let _e=(0,wt.relative)(e,Z).replace(/\\/g,"/");if(X)if(_e.startsWith(X))_e=_e.slice(X.length+1);else throw new Error(`The root path '${E.root}' does not reference a valid part of the file path '${_e}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let je=x+(x.endsWith("/")?"":"/")+_e;try{if(le.isFile()){let ye=await uue(Z);Qa.isMainThread&&await f.setupFile?.(ye,je,Z,t),t.isWorker&&await f.handleFile?.(ye,je,Z,t)}else Qa.isMainThread&&await f.setupDirectory?.(je,Z,t),t.isWorker&&await f.handleDirectory?.(je,Z,t)}catch(ye){ye.message=`Could not load ${le.isFile()?"file":"directory"} '${Z}'${E.module?" using '"+E.module+"'":""} for application '${e}' due to: ${ye.message}`,B_?.(ye),((0,Fl.getWorkerIndex)()===0?console:Hl.default).error(ye),t.set(E.path||"/",new H_(ye)),kl.set(n?_:(0,wt.basename)(e),ye.message)}}}}catch(p){p.message=`Could not load component '${_}' for application '${(0,wt.basename)(e)}' due to: ${p.message}`,B_?.(p),((0,Fl.getWorkerIndex)()===0?console:Hl.default).error(p),t.set(E.path||"/",new H_(p),null,!0),kl.set(n?_:(0,wt.basename)(e),p.message)}}if(Qa.isMainThread&&!kq&&i&&(0,Fl.watchDir)(e,async()=>Fq()),c.extensionModule)return await yf((0,wt.join)(e,c.extensionModule));if(!u&&t.isWorker){let _=`${e} did not load any modules, resources, or files, is this a valid component?`;B_?.(new Error(_)),((0,Fl.getWorkerIndex)()===0?console:Hl.default).error(_),kl.set((0,wt.basename)(e),_)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,B_?.(c),t.set("",new H_(c))}}}var At,wt,Qa,vq,SO,Gl,xq,Fl,Hl,Bq,Hq,lue,fp,uue,EO,mO,kq,hO,kl,due,pO,Mq,Uq,B_,H_,cm=Oe(()=>{At=require("fs"),wt=require("path"),Qa=require("worker_threads"),vq=require("yaml"),SO=v(ne()),Gl=v(M());pI();RI();AI();$k();xG();qG();xq=v(require("fast-glob")),Fl=v(et()),Hl=v(j());pS();Lr();Bq=v(ce());Ne();zG();Hq=v(ne()),lue=v(eq());Xh();cq();Oi();Pq();fp=v(dr());Zm();({readFile:uue}=At.promises),EO=(0,fp.resolvePath)(SO.get(Gl.CONFIG_PARAMS.COMPONENTSROOT)),mO=new Map,kl=new Map;a(Fq,"loadComponentDirectories");due={REST:Nm,rest:Nm,graphqlSchema:mS,jsResource:TS,fastifyRoutes:By,login:RS,static:Hy,operationsApi:lue,customFunctions:{},http:{},clustering:Xy,replication:Nd,authentication:e_,mqtt:fO},pO={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(pO,"static",{value:{files:"web/**"}});Mq=[],Uq=new Map;a(_ue,"setErrorReporter");a(_p,"loadComponent");H_=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}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 aO=N((iOe,qq)=>{var{isMainThread:Gq}=require("worker_threads"),{getTables:fue,getDatabases:nOe,table:sOe}=(Ne(),ae(ot)),{loadComponentDirectories:Eue,loadComponent:hue}=(cm(),ae(am)),{resetResources:mue}=(Sd(),ae(Gv)),pue=Sb(),Sue=dr(),{dirname:Tue}=require("path"),{getConnection:gue}=Mt(),Rue=ne(),{CONFIG_PARAMS:Aue}=M(),{loadCertificates:bue}=bo(),TO=new Map;async function yue(e=!1){!Gq&&Rue.get(Aue.CLUSTERING_ENABLED)&&gue();try{Gq&&await pue()}catch(n){console.error(n)}let t=mue();fue(),t.isWorker=e,await bue(),await hue(Tue(Sue.getConfigFilePath()),t,"hdb",!0,TO),await Eue(TO,t);let r=[];for(let[n]of TO)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(yue,"loadRootComponents");qq.exports.loadRootComponents=yue});var et=N((aOe,Is)=>{"use strict";var{Worker:Oue,MessageChannel:Nue,parentPort:oi,isMainThread:yO,threadId:Iue,workerData:ai}=require("worker_threads"),{PACKAGE_ROOT:wue}=M(),{join:Kq,isAbsolute:Cue,extname:Due}=require("path"),{server:Wq}=(Lr(),ae(qo)),{watch:Lue,readdir:Pue}=require("fs/promises"),{totalmem:Vq}=require("os"),k_=M(),Qq=ne(),ci=j(),{randomBytes:Mue}=require("crypto"),{_assignPackageExport:Uue}=require("../index"),vue=M(),$q=1024*1024,xo=[],ss=[],xue=50,OO=1e4,Bue="restart",zq="request_thread_info",jq="resource_report",Jq="thread_info",Xq="added-port",Hue="ack",gO;Uue("threads",ss);Is.exports={startWorker:RO,restartWorkers:IO,shutdownWorkers:Vue,workers:xo,setMonitorListener:Jue,onMessageFromWorkers:$ue,onMessageByType:iV,broadcast:Kue,broadcastWithAcknowledgement:Que,setChildListenerByType:que,getWorkerIndex:Zq,getWorkerCount:eV,getTicketKeys:rV,setMainIsWorker:Fue,setTerminateTimeout:kue,restartNumber:ai?.restartNumber||1};ss.onMessageByType=iV;ss.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=ss.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Is.exports.whenThreadsStarted=new Promise(e=>{Is.exports.threadsHaveStarted=e});var NO;function kue(e){OO=e}a(kue,"setTerminateTimeout");function Zq(){return ai?ai.workerIndex:NO?0:void 0}a(Zq,"getWorkerIndex");function eV(){return ai?ai.workerCount:NO?1:void 0}a(eV,"getWorkerCount");function Fue(e){NO=e,Is.exports.threadsHaveStarted()}a(Fue,"setMainIsWorker");var tV=1,Ep;function rV(){return Ep||(Ep=yO?Mue(48):ai.ticketKeys,Ep)}a(rV,"getTicketKeys");Object.defineProperty(Wq,"workerIndex",{get(){return Zq()}});Object.defineProperty(Wq,"workerCount",{get(){return eV()}});var nV={[zq](e,t){zue(t)},[jq](e,t){jue(t,e)}};function RO(e,t={}){let r=process.constrainedMemory?.()||Vq();r=Math.min(r,Vq(),2e4*$q);let n=Qq.get(k_.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/$q/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of ss){let d=new Nue;d.existingPort=l,i.push(d),o.push(d.port2)}Due(e)||(e+=".js");let c=new Oue(Cue(e)?e:Kq(wue,e),Object.assign({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:tV=t.threadCount,name:t.name,restartNumber:Is.exports.restartNumber,ticketKeys:rV()},transferList:o},t));for(let{port1:l,existingPort:d}of i)d.postMessage({type:Xq,port:l,threadId:c.threadId},[l]);return mp(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>RO(e,t),c.on("error",l=>{ci.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{xo.splice(xo.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<xue?(t.unexpectedRestarts=c.unexpectedRestarts+1,RO(e,t)):ci.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{nV[l.type]?.(l,c)}),xo.push(c),Zue(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(RO,"startWorker");var Gue=[k_.THREAD_TYPES.HTTP];async function IO(e=null,t=Math.max(tV>3,1),r=!0){if(yO){if(r){let{loadRootComponents:o}=aO();await o()}Is.exports.restartNumber++,t<1&&(t=t*xo.length);let n=[],s=[];for(let o of xo.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;ci.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Is.exports.restartNumber,type:k_.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=Gue.indexOf(o.name)>-1,l=new Promise(d=>{let u=setTimeout(()=>{ci.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},OO*2).unref();o.on("exit",()=>{clearTimeout(u),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),d()})});if(n.push(l),c&&r){let d=o.startCopy(),u=new Promise(_=>{let E=a(f=>{f.type===vue.ITC_EVENT_TYPES.CHILD_STARTED&&(ci.trace("Worker has started",d.threadId),_(),s.splice(s.indexOf(u)),d.off("message",E))},"startListener");ci.trace("Waiting for worker to start",d.threadId),d.on("message",E)});s.push(u),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}=Jd();r&&(e==="http"||!e)&&Qq.get(k_.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else oi.postMessage({type:Bue,workerType:e})}a(IO,"restartWorkers");function que(e,t){nV[e]=t}a(que,"setChildListenerByType");function Vue(e){return IO(e,1/0,!1)}a(Vue,"shutdownWorkers");var sV=[];function $ue(e){sV.push(e)}a($ue,"onMessageFromWorkers");var AO=new Map;function iV(e,t){let r=AO.get(e);r||AO.set(e,r=[]),r.push(t)}a(iV,"onMessageByType");var Yue=10;async function Kue(e,t){let r=0;for(let n of ss)try{n.postMessage(e),r++>Yue&&(r=0,await new Promise(setImmediate))}catch(s){ci.error("Unable to send message to worker",s)}t&&aV(e,null)}a(Kue,"broadcast");var hp=new Map,Wue=1;function Que(e){return new Promise(t=>{let r=0;for(let n of ss)try{let s=Wue++,i=a(()=>{hp.delete(s),--r===0&&t(),n!==oi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,hp.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of hp)o.port===n&&o()})),n.postMessage(e),r++}catch(s){ci.error("Unable to send message to worker",s)}r===0&&t()})}a(Que,"broadcastWithAcknowledgement");function zue(e){e.postMessage({type:Jq,workers:oV()})}a(zue,"sendThreadInfo");function oV(){let e=Date.now();return xo.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(oV,"getChildWorkerInfo");function jue(e,t){e.resources=t,e.resources.updated=Date.now()}a(jue,"recordResourceReport");var bO;function Jue(e){bO=e}a(Jue,"setMonitorListener");var Xue=1e3,Yq=!1;function Zue(){Yq||(Yq=!0,setInterval(()=>{for(let e of xo){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}bO&&bO()},Xue).unref())}a(Zue,"startMonitoring");var ede=1e3;if(oi&&ai.addPorts){mp(oi);for(let e=0,t=ai.addPorts.length;e<t;e++){let r=ai.addPorts[e];r.threadId=ai.addThreadIds[e],mp(r)}setInterval(()=>{let e=process.memoryUsage();oi.postMessage({type:jq,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},ede).unref(),gO=a(()=>new Promise((e,t)=>{oi.on("message",r),oi.postMessage({type:zq});function r(n){n.type===Jq&&(oi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else gO=oV;Is.exports.getThreadInfo=gO;function mp(e,t){ss.push(e),e.on("message",r=>{if(r.type===Xq)r.port.threadId=r.threadId,mp(r.port);else if(r.type===Hue){let n=hp.get(r.id);n&&n()}else aV(r,e)}).on("close",()=>{ss.splice(ss.indexOf(e),1)}).on("exit",()=>{ss.splice(ss.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(mp,"addPort");function aV(e,t){for(let n of sV)n(e,t);let r=AO.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){ci.error(s)}}a(aV,"notifyMessageListeners");if(yO){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await Pue(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(Kq(s,o.name));try{for await(let{filename:o}of Lue(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await IO(),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");Is.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else oi.on("message",async e=>{let{type:t}=e;t===k_.ITC_EVENT_TYPES.SHUTDOWN&&(Is.exports.restartNumber=e.restartNumber,oi.unref(),setTimeout(()=>{ci.warn("Thread did not voluntarily terminate",Iue),process.exit(0)},OO).unref())})});var wP={};Ze(wP,{AUDIT_STORE_OPTIONS:()=>Wd,Decoder:()=>Jc,HAS_CURRENT_RESIDENCY_ID:()=>Yo,HAS_EXPIRATION_EXTENDED_TYPE:()=>Su,HAS_ORIGINATING_OPERATION:()=>pu,HAS_PREVIOUS_RESIDENCY_ID:()=>Ko,REMOTE_SEQUENCE_UPDATE:()=>mh,createAuditEntry:()=>uc,getLastRemoved:()=>EA,openAuditStore:()=>Rp,readAuditEntry:()=>Pt,setAuditRetention:()=>rde,transactionKeyEncoder:()=>SV});function Rp(e){let t=e.auditStore=e.openDB(wO.AUDIT_STORE_NAME,Object.assign({create:!1},Wd));t||(t=e.auditStore=e.openDB(wO.AUDIT_STORE_NAME,Wd),lV(t,1)),t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=pp){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:d,value:u}of t.getRange({start:1,snapshot:!1,end:Date.now()-CO})){if((u[0]&15)===DO){let _=Pt(u),E=_.tableId;r[E]?.(_.recordId)}if(c=t.remove(d),l=d,await new Promise(setImmediate),++o>=tde){i=10;break}}await c}finally{o===0?i=Math.min(i<<1,CO/10):lV(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,G_.getWorkerIndex)()===(0,G_.getWorkerCount)()-1&&s(pp),(0,G_.getWorkerIndex)()===0&&!cV)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(cV=!0,gp.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 lV(e,t){LO[0]=t,e.put(Symbol.for("last-removed"),TV)}function EA(e){let t=e.get(Symbol.for("last-removed"));if(t)return TV.set(t),LO[0]}function rde(e,t=pp){CO=e,pp=t}function uc(e,t,r,n,s,i,o,c,l,d,u,_,E){let f=gV[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?Bo.setFloat64(0,n):is.set(HS),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}g(s),g(t),S(r),Bo.setFloat64(h,e),h+=8,l&Yo&&g(d),l&Ko&&g(u),l&Su&&(Bo.setFloat64(h,_),h+=8),l&pu&&g(RV[E]),i?S(i):is[h++]=0,l?Bo.setUint16(n?8:0,f|l|32768):is[n?8:0]=f;let p=is.subarray(0,h);if(c)return Buffer.concat([p,c]);return p;function S(T){let A=h;h+=1,h=(0,ql.writeKey)(T,is,h);let I=h-A-1;I>127?I>16383?(gp.error("Key or username was too large for audit entry",T),h=A+1,is[A]=0):(is.copyWithin(A+2,A+1,h),Bo.setUint16(A,I|32768),h++):is[A]=I}function g(T){T<128?is[h++]=T:T<16384?(Bo.setUint16(h,T|32768),h+=2):T<1056964608?(Bo.setUint32(h,T|3221225472),h+=4):(is[h]=255,Bo.setUint32(h+1,T),h+=5)}}function Pt(e){try{let t=e.dataView||(e.dataView=new Jc(e.buffer,e.byteOffset,e.byteLength)),r;e[t.position]==66&&(r=t.readFloat64());let n=t.readInt(),s=t.readInt(),i=t.readInt(),o=t.readInt(),c=t.position,l=t.position+=o,d=t.readFloat64(),u,_,E,f;if(n&Yo&&(u=t.readInt()),n&Ko&&(_=t.readInt()),n&Su&&(E=t.readFloat64()),n&pu){let S=t.readInt();f=RV[S]}o=t.readInt();let h=t.position,p=t.position+=o;return{type:gV[n&7],tableId:i,nodeId:s,get recordId(){return hV(e,c,l)},getBinaryRecordId(){return e.subarray(c,l)},version:d,previousLocalTime:r,get user(){return p>h?hV(e,h,p):void 0},encoded:e,getValue(S,g,T){if(n&Sp||n&F_&&!g)return S.decoder.decode(e.subarray(t.position));if(n&F_&&T)return PO(S.getEntry(this.recordId),T,S)},getBinaryValue(){return n&(Sp|F_)?e.subarray(t.position):void 0},extendedType:n,residencyId:u,previousResidencyId:_,expiresAt:E,originatingOperation:f}}catch(t){return gp.error("Reading audit entry error",t,e),{}}}function hV(e,t,r){let n=e.subarray(t,r);return(0,ql.readKey)(n,0,r-t)}var ql,Tp,wO,mV,G_,pV,gp,is,Bo,SV,Wd,CO,tde,LO,TV,pp,cV,Sp,F_,uV,DO,dV,_V,fV,EV,mh,Yo,Ko,pu,Su,gV,RV,Jc,Ei=Oe(()=>{ql=require("ordered-binary"),Tp=v(ne()),wO=v(Gt()),mV=v(M()),G_=v(et()),pV=v(te());dc();gp=v(j());Ap();(0,Tp.initSync)();is=Buffer.alloc(1024),Bo=new DataView(is.buffer,is.byteOffset,1024),SV={writeKey(e,t,r){return e===mu?(t.set(mu,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)}},Wd={encoding:"binary",keyEncoder:SV},CO=(0,pV.convertToMS)((0,Tp.get)(mV.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,tde=1e3,LO=new Float64Array(1),TV=new Uint8Array(LO.buffer),pp=1e4,cV=!1;a(Rp,"openAuditStore");a(lV,"updateLastRemoved");a(EA,"getLastRemoved");a(rde,"setAuditRetention");Sp=16,F_=32,uV=1,DO=2,dV=3,_V=4,fV=5,EV=6,mh=11,Yo=512,Ko=1024,pu=2048,Su=4096,gV={put:uV|Sp,[uV]:"put",delete:DO,[DO]:"delete",message:dV|Sp,[dV]:"message",invalidate:_V|F_,[_V]:"invalidate",patch:fV|F_,[fV]:"patch",relocate:EV,[EV]:"relocate"},RV={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(uc,"createAuditEntry");a(Pt,"readAuditEntry");Jc=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;try{t=this.getUint8(this.position++)}catch(r){throw r}return t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch{debugger}}};a(hV,"readKeySafely")});var MO={};Ze(MO,{add:()=>bp,applyReverse:()=>AV,getRecordAtTime:()=>PO,rebuildUpdateBefore:()=>yp});function bp(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 yp(e,t){let r=null;for(let n in e)if(n in t){let s=t[n];if(s?.__op__){let i=e[n];if(i?.__op__)if(i.__op__===s.__op__)r||(r={}),r[n]=i;else throw new Error("Can not merge updates with different operations");else r||(r={}),r[n]=i,bp(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function AV(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=nde[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=bV}}function PO(e,t,r){let n=r.rootStore.auditStore,s=Object.assign({},e.value),i=e.localTime;for(;i>t;){let l=n.get(i),d=Pt(l);switch(d.type){case"put":s=d.getValue(r);break;case"patch":AV(s,d.getValue(r));break;case"delete":s=null}i=d.previousLocalTime}let o={},c=0;for(let l in s)s[l]===bV&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),d=Pt(l),u;switch(d.type){case"put":u=d.getValue(r);break;case"patch":u=d.getValue(r);break}for(let _ in u)o[_]&&(s[_]=u[_],o[_]=!1,c--);i=d.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var nde,bV,Ap=Oe(()=>{Ei();a(bp,"add");bp.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)};nde={add:bp};a(yp,"rebuildUpdateBefore");a(AV,"applyReverse");bV={};a(PO,"getRecordAtTime")});function Un(e){return e[tr]||(e[tr]=Object.create(null))}function Cp(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,d;if(o.resolve)d={get(){return o.resolve(this,this[Me])},set(u){return o.set(this,u)},configurable:!0};else{switch(o.type){case"String":l=a(function(u){if(!(typeof u=="string"||u==null&&o.nullable!==!1))throw new os.ClientError(`${c} must be a string, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"ID":l=a(function(u){if(!(typeof u=="string"||u?.length>0&&u.every?.(_=>typeof _=="string")||u==null&&o.nullable!==!1))throw new os.ClientError(`${c} must be a string, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Float":case"Number":l=a(function(u){let _=u?.__op__?u.value:u;if(!(typeof _=="number"||u==null&&o.nullable!==!1))throw new os.ClientError(`${c} must be a number, attempt to assign ${_}`);Un(this)[c]=u},"set");break;case"Int":l=a(function(u){let _=u?.__op__?u.value:u;if(!(_>>0===_||u==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),u?.__op__?u.value=_:u=_;else throw new os.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Long":l=a(function(u){let _=u?.__op__?u.value:u;if(!(Math.round(_)===u&&Math.abs(_)<=9007199254740992||u==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),u?.__op__?u.value=_:u=_;else throw new os.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"BigInt":l=a(function(u){let _=u?.__op__?u.value:u;if(!(typeof _=="bigint"||u==null&&o.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),u?.__op__?u.value=_:u=_;else throw new os.ClientError(`${c} must be a number, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Boolean":l=a(function(u){if(!(typeof u=="boolean"||u==null&&o.nullable!==!1))throw new os.ClientError(`${c} must be a boolean, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Date":l=a(function(u){if(!(u instanceof Date||u==null&&o.nullable!==!1))if(typeof u=="string"||typeof u=="number")u=new Date(u);else throw new os.ClientError(`${c} must be a Date, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Bytes":l=a(function(u){if(!(u instanceof Uint8Array||u==null&&o.nullable!==!1))throw new os.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${u}`);Un(this)[c]=u},"set");break;case"Any":case void 0:l=a(function(u){Un(this)[c]=u},"set");break;default:l=a(function(u){if(!(typeof u=="object"||u==null&&o.nullable!==!1))throw new os.ClientError(`${c} must be an object, attempt to assign ${u}`);Un(this)[c]=u},"set")}d={get(){let u=this[tr];if(u&&c in u){let E=u[c];if(E?.__op__){let f=this[Ce]?.[c];return E.update(f)}return E}let _=this[Ce]?.[c];if(_&&typeof _=="object"){let E=OV(_,o);if(E)return u||(u=this[tr]=Object.create(null)),u[c]=E}return _},set:l,enumerable:!0,configurable:!0}}d.get.isAttribute=!0,n[c]=d,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,d)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let l=this[tr];return l?.[o]!==void 0?l[o]:this[Ce]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new os.ClientError("Can not add a property to a sealed table schema");Un(this)[o]=c}),i("deleteProperty",function(o){Un(this)[o]=void 0}),i("toJSON",function(){let o=this[tr],c;for(let d in o){c||(c=Object.assign({},this[Ce]));let u=o[d];if(u?.__op__){let _=c[d];u=u.update(_)}c[d]=u}return Object.keys(this).length>0&&(c||(c=Object.assign({},this[Ce])),Object.assign(c,this)),c||this[Ce]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function OV(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[Ce])throw new Error("Can not track an already tracked object, check for circular references");this[Ce]=s}},Cp(r,t)),new r(e)):new Op(e);case Array:let n=new Ip(e.length);n[Ce]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=OV(o,t?.elements)),n[s]=o}return n;default:return e}}function bE(e){let t=e[tr],r;for(let s in t){r||(r=Object.assign({},e[Ce]));let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=bE(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=Object.assign({},e[Ce])),Object.assign(r,e)),r||e[Ce]}function ja(e,t=e[tr]){let r;if(yV.call(e,Ce)&&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=ja(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r=Object.assign({},e[Ce]));let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=MO[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=ja(s);r[n]=s}return r?Object.freeze(r):yV.call(e,Ce)?e[Ce]:e}function Np(e){let t=e[Ce];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[za]||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?.[Ce]===s){if(Np(i))return!0}else return!0}}else{let r=e[tr];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[Ce]===i){if(Np(s))return!0}else return!0}else return!0}}return!1}var os,tr,Op,yV,za,Ip,wp,yE=Oe(()=>{us();os=v(ce());Ap();tr=Symbol("own-data");a(Un,"getChanges");a(Cp,"assignTrackedAccessors");a(OV,"trackObject");Op=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[Ce])throw new Error("Can not track an already tracked object, check for circular references");this[Ce]=t}};Cp(Op,{});a(bE,"collapseData");yV=Object.prototype.hasOwnProperty;a(ja,"deepFreeze");a(Np,"hasChanges");za=Symbol.for("has-array-changes"),Ip=class extends Array{static{a(this,"TrackedArray")}[za];constructor(t){super(t)}splice(...t){return this[za]=!0,super.splice(...t)}push(...t){return this[za]=!0,super.push(...t)}pop(){return this[za]=!0,super.pop()}unshift(...t){return this[za]=!0,super.unshift(...t)}shift(){return this[za]=!0,super.shift()}};Ip.prototype.constructor=Array;wp=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var dg={};Ze(dg,{CONTEXT:()=>Me,ID_PROPERTY:()=>Ke,IS_COLLECTION:()=>ws,RECORD_PROPERTY:()=>Ce,Resource:()=>pr,snake_case:()=>ide,transformForSelect:()=>Lp});function ide(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function NV(e,t){if(q_=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(q_=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new vO;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){q_=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function vn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,d,u;if(r?(o?(u=i,o=o[Me]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(u=s,c=u[this.primaryKey]??null,o=i[Me]||i):u=i:(u=s,s=void 0,c=u[Ke]??u[this.primaryKey]),c===null&&(d=!0)):i?o=i[Me]||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"){let f=c.indexOf("?");if(f>-1){let p=this.parseQuery(c.slice(f+1));l?l=Object.assign(p,l):l=p,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),d=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],d=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,d=!1)))}c===void 0&&(c=s.id??null,c==null&&(d=!0))}else c=s,l=new Ga(c),c===null&&(d=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||d?(_=Object.assign({},t),l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),d&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return gt(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,u,o):f.allowUpdate(o.user,u,o):t.type==="create"?f.allowCreate(o.user,u,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(p=>{if(!p)throw new Dp(o.user);return typeof u?.then=="function"?u.then(S=>e(f,l,o,S)):e(f,l,o,u)});if(!h)throw new Dp(o.user)}return typeof u?.then=="function"?u.then(h=>e(f,l,o,h)):e(f,l,o,u)}a(E,"authorizeActionOnResource")}}function xn(e,t){let r=new CV.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 UO(e,t,r){let n=e[Ce];if(n){let s=e[tr];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 Lp(e,t){let r=t?.propertyResolvers,n=t[Me],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):UO(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 d=[],u=i(UO(l,r,n));for(let _ of e)d.push(u(_));return d},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let d={},u=i(UO(l,r,n)),_;for(let E of e){let f=u(E);f===void 0&&o&&(f=null),f?.then?(_||(_=[]),_.push(f.then(h=>d[E.name||E]=h))):d[E.name||E]=f}return _?Promise.all(_).then(()=>d):d},"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 u=r[c.name]?.definition?.tableClass;l=s[c.name]=Lp(c.select||c,u)}let d=o(c.name);return l(d)}else return o(c);else return c}}a(i,"handleProperty")}var IV,wV,CV,Me,Ke,ws,Ce,sde,pr,Dp,q_,vO,us=Oe(()=>{IV=require("crypto");cc();wV=require("../index"),CV=v(ce());yE();ca();S_();Me=Symbol.for("context"),Ke=Symbol.for("primary-key"),ws=Symbol("is-collection"),Ce=Symbol("stored-record"),sde={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},pr=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[Ke]=t;let n=r?.[Me];this[Me]=n!==void 0?n:r||null}static get=vn(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 d=Lp(l,t.constructor);return typeof c?.map=="function"?c.map(d):d(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=vn(function(t,r,n,s){if(Array.isArray(s)&&t[ws]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,d=l.getResource(c[l.primaryKey],n,{async:!0});d.then?i.push(d.then(u=>u.put(c,n))):i.push(d.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):xn(t,"put")},{hasContent:!0,type:"update"});static patch=vn(function(t,r,n,s){return t.patch?t.patch(s,r):xn(t,"patch")},{hasContent:!0,type:"update"});static delete=vn(function(t,r,n,s){return t.delete?t.delete(r):xn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,IV.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={}),gt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):xn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=vn(function(t,r,n,s){return t.invalidate?t.invalidate(r):xn(t,"delete")},{hasContent:!1,type:"update"});static post=vn(function(t,r,n,s){return t[Ke]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=vn(function(t,r,n,s){return t.connect?t.connect(s,r):xn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=vn(function(t,r,n,s){return t.subscribe?t.subscribe(r):xn(t,"subscribe")},{type:"read"});static publish=vn(function(t,r,n,s){return t[Ke]!=null&&t.update?.(),t.publish?t.publish(s,r):xn(t,"publish")},{hasContent:!0,type:"create"});static search=vn(function(t,r,n,s){let i=t.search?t.search(r):xn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=Lp(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=vn(function(t,r,n,s){return t.search?t.search(s,r):xn(t,"search")},{hasContent:!0,type:"read"});static copy=vn(function(t,r,n,s){return t.copy?t.copy(s,r):xn(t,"copy")},{hasContent:!0,type:"create"});static move=vn(function(t,r,n,s){return t.move?t.move(s,r):xn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[ws])return(await this.constructor.create(this[Ke],t,this[Me]))[Ke];xn(this,"post")}static isCollection(t){return t?.[ws]}static coerceId(t){return t}static parseQuery(t){return ym(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&sde[o];if(c)r.headers.set("accept",c);else if(n)n.property=o;else return{query:{property:o},id:NV(t,this),isCollection:q_}}let i=NV(t,this);return q_?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[Me],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 d=l.asMap.get(t);if(s=d?.find(u=>u.constructor===c),s)return s;d||l.asMap.set(t,d=[]),d.push(s=new c(t,i))}else{if(s=l.find(d=>d[Ke]===t&&d.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let d=new Map;for(let u of l){let _=u[Ke],E=d.get(_);E?E.push(u):d.set(_,[u])}i.resourceCache.length=0,i.resourceCache.asMap=d}}}else s=new c(t,i);return o&&(s[ws]=!0),s}subscribe(t){return new mn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new mn}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[Ke]}getContext(){return this[Me]}};pr.prototype[Me]=null;(0,wV._assignPackageExport)("Resource",pr);a(ide,"snake_case");Dp=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(NV,"pathToId");vO=class extends Array{static{a(this,"MulitPartId")}toString(){return this.join("/")}};a(vn,"transactional");a(xn,"missingMethod");a(UO,"selectFromObject");a(Lp,"transformForSelect")});var gy={};Ze(gy,{coerceType:()=>Pp,makeTable:()=>vp,setServerUtilities:()=>Ede,updateResource:()=>Mp});function vp(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:d,dbisDB:u,sealed:_,replicate:E}=e,{expirationMS:f,evictionMS:h,audit:p,trackDeletes:S}=e,{attributes:g}=e;g||(g=[]);let T=GS(i,n,l),A,I,V={},x=Promise.resolve(),X,$,F;for(let q of g)(q.assignCreatedTime||q.name==="__createdtime__")&&(X=q),(q.assignUpdatedTime||q.name==="__updatedtime__")&&($=q),q.expiresAt&&(F=q),q.isPrimaryKey&&(V=q);let se,ee=[],Z=[],le=1,_e=2,je={},ye={},kt=864e5,Fo,sc,Gr,zl=!1,Ki,Wi,Ds=new Map,Ls=new Map,Dt,jp,dn=Vl.get(as.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(dn)){for(let q of dn)if(q.name===c&&q.replicateTo>=0){jp=q.replicateTo;break}}let cf=i.getRange({start:!1,end:!1}).constructor,lf=10,jl=6;p&&rt();class ve extends pr{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=p;static databasePath=o;static databaseName=c;static attributes=g;static replicate=E;static sealed=_;static createdTimeProperty=X;static updatedTimeProperty=$;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return f}static dbisDB=u;static schemaDefined=d;static sourcedFrom(m,R){if(R&&(this.sourceOptions=R,(R.expiration||R.eviction||R.scanInterval)&&this.setTTLExpiration(R)),R?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(C=>!C.intermediateSource))throw new Error("Can not have multiple canonical (non-intermediate) sources");this.sources.push(m)}I=I||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),A=A||m.load;let w=a(C=>{let O=this.sources;if(O=O.filter(P=>P.intermediateSource&&P[C]&&(!P[C].reliesOnPrototype||P.prototype[C])),O.length>0)if(O.length===1){let P=O[0];return(U,L,H)=>{if(U?.source!==P)return P[C](L,H,U)}}else return(P,U,L)=>{let H=[];for(let Y of O){if(P?.source===Y)break;H.push(Y[C](U,L,P))}return Promise.all(H)}},"getApplyToIntermediateSource"),b=this.sources[this.sources.length-1];b.intermediateSource&&(b={});let y=a(C=>{if(b[C]&&(!b[C].reliesOnPrototype||b.prototype[C]))return(O,P,U)=>{if(!O?.source)return b[C](P,U,O)}},"getApplyToCanonicalSource");return je={put:y("put"),patch:y("patch"),delete:y("delete"),publish:y("publish")},ye={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")},(async()=>{let C=!1,O,P=a(async(U,L)=>{let H=U.value,Y=U.table?Ve[c][U.table]:ve;if(c===as.SYSTEM_SCHEMA_NAME&&(U.table===as.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||U.table===as.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(C=!0),U.id===void 0&&(U.id=H[Y.primaryKey],U.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(U));U.source=m;let K={residencyId:Lt(U.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:U.nodeId},Te=await Y.getResource(U.id,L,K);switch(U.type){case"put":return Te._writeUpdate(H,!0,K);case"patch":return Te._writeUpdate(H,!1,K);case"delete":return Te._writeDelete(K);case"publish":return Te._writePublish(H,K);case"invalidate":return Te._writeInvalidate(K);case"relocate":return Te._writeRelocate(K);default:qe.default.error?.("Unknown operation",U.type,U.id)}},"writeUpdate");try{let U=m.subscribe;U&&S==null&&(S=!0);let L=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Za.getWorkerIndex)()):(0,Za.getWorkerIndex)()===0,H=U&&L&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(H){let Y;for await(let K of H)try{if(!(K.type==="transaction"?K.writes[0]:K)){qe.default.error?.("Bad subscription event",K);continue}if(K.source=m,K.type==="end_txn"){if(Y?.resolve(),K.localTime&&O!==K.localTime){if(K.remoteNodeIds?.length>0){let Ie=[Symbol.for("seq"),K.remoteNodeIds[0]],he=u.get(Ie),De=he?.nodes;De||(De=[]);for(let k of K.remoteNodeIds.slice(1)){let ie=De.find(ue=>ue.name===k);ie||(ie={id:k,seqId:0},De.push(ie)),ie.seqId=Math.max(he?.seqId??1,K.localTime),k===K.nodeId&&(ie.lastTxnTime=K.timestamp)}let B=Math.max(he?.seqId??1,K.localTime);u.put(Ie,{seqId:B,nodes:De})}O=K.localTime}K.onCommit&&Y?.committed.then(K.onCommit);continue}if(Y)if(K.beginTxn)Y.resolve();else{Y.write_promises.push(P(K,Y));continue}let J=gt(K,()=>{if(K.type==="transaction"){let Ie=[];for(let he of K.writes)try{Ie.push(P(he,K))}catch(De){throw De.message+=" writing "+JSON.stringify(he)+" of event "+JSON.stringify(K),De}return Promise.all(Ie)}else if(K.type==="define_schema"){let Ie=this.attributes.slice(0),he;for(let De of K.attributes)Ie.find(B=>B.name===De.name)||(Ie.push(De),he=!0);he&&(ft({table:s,database:c,attributes:Ie,origin:"cluster"}),Q_.signalSchemaChange(new z_.SchemaEventMsg(process.pid,as.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return K.beginTxn?(Y=K,Y.write_promises=[P(K,K)],new Promise(Ie=>{Y.resolve=()=>Ie(Promise.all(Y.write_promises))})):P(K,K)});Y&&(Y.committed=J),C&&J&&!J?.waitingForUserChange&&(J.then(()=>Q_.signalUserChange(new z_.UserEventMsg(process.pid))),J.waitingForUserChange=!0),K.onCommit&&(J?J.then(K.onCommit):K.onCommit())}catch(Te){qe.default.error?.("error in subscription handler",Te)}}}catch(U){qe.default.error?.(U)}})(),this}static getResource(m,R,w){let b=super.getResource(m,R,w);if(m!=null){ui(m);try{if(b.hasOwnProperty(Ce))return b;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let y=!w?.async||i.cache?.get(m),C=Dr(R),O=C.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return ic(m,R,{transaction:O,ensureLoaded:w?.ensureLoaded},y,P=>{if(P?Mp(b,P):b[Ce]=null,R.onlyIfCached&&R.noCacheStore){if(!b.doesExist())throw new Cr.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let U=oc(m,P,R,b);if(U)return C?.disregardReadTxn(),b[xO]=!0,HO(U,L=>(Mp(b,L),b))}return b})}catch(y){throw y.message.includes("Unable to serialize object")&&(y.message+=": "+JSON.stringify(m)),y}}return b}ensureLoaded(){let m=oc(this[Ke],this[wr],this[Me]);if(m)return this[xO]=!0,HO(m,R=>{this[wr]=R,this[Ce]=R.value,this[K_]=R.version})}static getNewId(){let m=V?.type;if(m==="String"||m==="ID")return super.getNewId();if(!Dt){let y=i.getEntry(Symbol.for("id_allocation")),C=y?.value,O;if(C&&C.nodeName===server.hostname&&(!mde(i)||C.pid===process.pid)){let P=C.start,U=C.end;O=P;for(let L of i.getKeys({start:U,end:P,limit:1,reverse:!0}))O=L}else C=b(y?.version??null),O=C.start;Dt=new BigInt64Array([BigInt(O)+1n]),Dt=new BigInt64Array(i.getUserSharedBuffer("id",Dt.buffer)),Dt.maxSafeId=C.end}let R=Number(Atomics.add(Dt,0,1n)),w=m==="Int"?512:1048576;if(R+w>=Dt.maxSafeId){let y=a(C=>{Dt.maxSafeId=R+(m==="Int"?1023:4194303);let O=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,P=C?void 0:i.useReadTransaction(),U=Number(Dt[0]);for(let Y of i.getKeys({start:U+1,end:O,limit:1,transaction:P}))O=Y;P?.done();let{value:L,version:H}=i.getEntry(Symbol.for("id_allocation"));if(Dt.maxSafeId<O){if(L.end>Dt.maxSafeId-100)return;qe.default.info?.("New id allocation",R,Dt.maxSafeId,H),i.put(Symbol.for("id_allocation"),{start:L.start,end:Dt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),H)}else{qe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${Dt.maxSafeId}, but id of ${O} detected`);let Y=b(H);Y.alreadyUpdated||Atomics.store(Dt,0,BigInt(Y.start+1)),Dt.maxSafeId=Y.end}},"updateEnd");R+w===Dt.maxSafeId?setImmediate(y):R+100>=Dt.maxSafeId&&(qe.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 R;function b(y){let C=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=C/4,P,U,L=!1,H,Y;do{H=Math.floor(Math.random()*C),Y={start:H,end:H+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},P=0;for(let K of i.getKeys({start:H,limit:1,reverse:!0}))P=K;U=C;for(let K of i.getKeys({start:H+1,end:C,limit:1}))U=K;O*=.875,O<1e3&&!L&&(L=!0,qe.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":""}`,H,P,U,O))}while(!(O<U-H&&(O<H-P||P===0)));return i.transactionSync(()=>{let K=i.getEntry(Symbol.for("id_allocation"));return(K?.version??null)==y?(qe.default.info?.("Allocated new id range",Y),i.put(Symbol.for("id_allocation"),Y,Date.now()),Y):(qe.default.debug?.("Looks like ids were already allocated"),Object.assign({alreadyUpdated:!0},K.value))})}}static setTTLExpiration(m){if(typeof m=="number")f=m*1e3,h||(h=0);else if(m&&typeof m=="object")f=m.expiration*1e3,h=(m.eviction||0)*1e3,kt=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(f<0)throw new Error("Expiration can not be negative");kt=kt||(f+h)/4,Fe()}static getResidencyRecord(m){return u.get([Symbol.for("residency_by_id"),m])}static setResidency(m){ve.getResidency=m}static setResidencyById(m){ve.getResidencyById=m}static getResidency(m,R,w){if(ve.getResidencyById)return ve.getResidencyById(m[t]);let b=jp;if(R.replicateTo!=null){if(Array.isArray(R.replicateTo))return R.replicateTo.includes(server.hostname)?R.replicateTo:[server.hostname,...R.replicateTo];R.replicateTo>=0&&(b=R.replicateTo)}if(b>=0&&server.nodes){let y=[server.hostname];if(w)y.push(...w.slice(0,b));else{let C=Math.floor(server.nodes.length*Math.random());y.push(...server.nodes.slice(C,C+b));let O=C+b-server.nodes.length;O>0&&y.push(...server.nodes.slice(0,O))}return y}}static enableAuditing(m=!0){p=m,m&&rt(),ve.audit=m}static coerceId(m){return m===""?null:Pp(m,V)}static async dropTable(){if(delete Ve[c][s],c===o){for(let m of g)u.remove(ve.tableName+"/"+m.name),r[m.name]?.drop();u.remove(ve.tableName+"/"),i.drop(),await u.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));Q_.signalSchemaChange(new z_.SchemaEventMsg(process.pid,as.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[ws])return this.search(m);if(this[Ke]===null){if(m?.conditions)return this.search(m);let R=ve.getRecordCount();return{recordCount:R.recordCount,estimatedRecordRange:R.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:g}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[Me]?.returnNonexistent)return this}allowRead(m,R){let w=di(m);if(w?.read){if(w.isSuperUser)return!0;let b=w.attribute_permissions,y=R?.select;if(b?.length>0||zl&&y){if(R||(R={}),y){let C=b?.length>0&&BO(b,"read");R.select=y.map(O=>{let P=O.name||O;if(!C||C[P]){let U=Gr[P]?.definition?.tableClass;if(U){if(O.name||(O={name:O}),!U.prototype.allowRead.call(null,m,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else R.select=b.filter(C=>C.read&&!Gr[C.attribute_name]).map(C=>C.attribute_name);return R}else return!0}}allowUpdate(m,R){let w=di(m);if(w?.update){let b=w.attribute_permissions;if(b?.length>0){let y=BO(b,"update");for(let C in R)if(!y[C])return!1;for(let C of b){let O=C.attribute_name;!C.update&&!(O in R)&&(R[O]=this.getProperty(O))}}return Ae(this[Me])}}allowCreate(m,R){if(this[ws]){let w=di(m);if(w?.insert){let b=w.attribute_permissions;if(b?.length>0){let y=BO(b,"insert");for(let C in R)if(!y[C])return!1;return Ae(this[Me])}else return Ae(this[Me])}}else return this.allowUpdate(m,{})}allowDelete(m){return di(m)?.delete&&Ae(this[Me])}update(m,R){if(!Dr(this[Me]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let b;return typeof m=="object"&&m&&(R?(Object.isFrozen(m)&&(m=Object.assign({},m)),this[Ce]={},this[tr]=m):(b=this[tr],b&&(m=Object.assign(b,m)),this[tr]=b=m)),this._writeUpdate(this[tr],R),this}addTo(m,R){if(typeof R=="number"||typeof R=="bigint")this[V_]===LV?this.set(m,(+this.getProperty(m)||0)+R):(this[V_]||this.update(),this.set(m,new wp(R)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,R){if(typeof R=="number")return this.addTo(m,-R);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[wr]}invalidate(){this._writeInvalidate()}_writeInvalidate(m){let R=this[Me],w=this[Ke];ui(w),Dr(this[Me]).addWrite({key:w,store:i,invalidated:!0,entry:this[wr],before:je.invalidate?.bind(this,R,w),beforeIntermediate:ye.invalidate?.bind(this,R,w),commit:(y,C)=>{if(me(y,C,m?.nodeId))return;let O=null;for(let P in r)O||(O={}),O[P]=this.getProperty(P);qe.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),T(w,O,this[wr],y,Ja,p,{user:R?.user,residencyId:m?.residencyId,nodeId:m?.nodeId},"invalidate")}})}_writeRelocate(m){let R=this[Me],w=this[Ke];ui(w),Dr(this[Me]).addWrite({key:w,store:i,invalidated:!0,entry:this[wr],before:je.relocate?.bind(this,R,w),beforeIntermediate:ye.relocate?.bind(this,R,w),commit:(y,C)=>{if(me(y,C,m?.nodeId))return;let O=ve.getResidencyRecord(m.residencyId),P=0,U=null,L=C?.value;if(O&&!O.includes(server.hostname)){for(let H in r)U||(U={}),U[H]=L(H);P=Ja}else U=L;qe.default.trace?.(`Relocating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),T(w,U,this[wr],y,P,p,{user:R.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)}})}static _recordRelocate(m,R){let w={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},b=this.getResidency(R.value,w),y;if(b){if(!Array.isArray(b))throw new Error("Residency must be an array, but was: "+b);if(!b.includes(server.hostname))return;y=Lt(b)}let O=T(m.key,R.value,m,m.version,0,!0,{residencyId:y,expiresAt:R.expiresAt},"relocate",!1,null)}static evict(m,R,w){let b=this.Source,y;if(!((I||p)&&(!R||(y=i.getEntry(m),!y||!R)||y.version!==w))){if(I){if(i.hasLock(m,y.version))return;let C;for(let O in r)C||(C={}),C[O]=R[O];if(C)return T(m,C,y,w,$_,null,null,null,!0)}return i.ifVersion(m,w,()=>{Qi(m,R,null)}),p?T(m,null,y,w,$_,null,null,null,!0):i.remove(m,w)}}lock(){throw new Error("Not yet implemented")}static operation(m,R){return m.table||=s,m.schema||=c,BV.operation(m,R)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,R,w){let b=this[Me],y=Dr(b),C=this[Ke];ui(C);let O=this[wr];this[V_]=R?LV:dde;let P={key:C,store:i,entry:O,nodeName:b?.nodeName,validate:U=>{m||(m=this[tr]),R||m&&Np(this[tr]===m?this:m)?b?.source||(y.checkOverloaded(),this.validate(m,!R),$&&(m[$.name]=$.type==="Date"?new Date(U):$.type==="String"?new Date(U).toISOString():U),R&&(t&&m[t]!==C&&(m[t]=C),X&&(O?.value?m[X.name]=O?.value[X.name]:m[X.name]=X.type==="Date"?new Date(U):X.type==="String"?new Date(U).toISOString():U),m=ja(m))):y.removeWrite(P)},before:R?je.put?()=>je.put(b,C,m):null:je.patch?()=>je.patch(b,C,m):je.put?()=>je.put(b,C,ja(this)):null,beforeIntermediate:R?ye.put?()=>ye.put(b,C,m):null:ye.patch?()=>ye.patch(b,C,m):ye.put?()=>ye.put(b,C,ja(this)):null,commit:(U,L,H)=>{if(H){if(b&&L?.version>(b.lastModified||0)&&(b.lastModified=L.version),this[wr]=L,L?.value?.[Ce])throw new Error("Can not assign a record to a record, check for circular references");R||(this[Ce]=L?.value??null)}this[tr]=void 0,this[K_]=U;let Y=L?.value,K=m;if(this[V_]=0,me(U,L,w?.nodeId))if(p){let k=L.localTime,ie=L.version;for(;K&&(k>U||ie>=U&&k>0);){let ue=l.get(k);if(!ue)break;let pe=Pt(ue);if(ie=pe.version,ie>U){if(pe.type==="patch"){let nt=pe.getValue(i);K=yp(K,nt)}else if(pe.type==="put"||pe.type==="delete")return}else if(ie===U)return;k=pe.previousLocalTime}}else{if(R)return;K=yp(K,Y)}let J;if(R?J=K:(this[Ce]=Y,J=R?K:ja(this,K)),this[Ce]=J,J?.[Ce])throw new Error("Can not assign a record to a record, check for circular references");let Ie,he;if(w?.residencyId!=null)he=w.residencyId;else{O?.residencyId&&(b.previousResidency=ve.getResidencyRecord(O.residencyId));let k=ve.getResidency(J,b);if(k){if(!Array.isArray(k))throw new Error("Residency must be an array, got: "+k);k.includes(server.hostname)||k.push(server.hostname)}he=Lt(k)}R||(Ie=m);let De=b?.expiresAt||(f?f+Date.now():0);qe.default.trace?.(`Saving record with id: ${C}, timestamp: ${new Date(U).toISOString()}${De?", expires at: "+new Date(De).toISOString():""}${L?", replaces entry from: "+new Date(L.version).toISOString():", new entry"}`),Qi(C,Y,J);let B=R?"put":"patch";T(C,J,L,U,0,p,{user:b?.user,residencyId:he,expiresAt:De,nodeId:w?.nodeId,originatingOperation:b?.originatingOperation},B,!1,Ie),b.expiresAt&&Fe()}};y.addWrite(P)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[ws]){for await(let R of this.search(m))(await ve.getResource(R[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[Ce]?this._writeDelete(m):!1}_writeDelete(m){let R=Dr(this[Me]),w=this[Ke];ui(w);let b=this[Me];return R.addWrite({key:w,store:i,resource:this,nodeName:b?.nodeName,before:je.delete?.bind(this,b,w),beforeIntermediate:ye.delete?.bind(this,b,w),commit:(y,C,O)=>{let P=C?.value;O&&(b&&C?.version>(b.lastModified||0)&&(b.lastModified=C.version),Mp(this,C)),!me(y,C,m?.nodeId)&&(Qi(this[Ke],P),qe.default.trace?.(`Deleting record with id: ${w}, txn timestamp: ${new Date(y).toISOString()}`),p||S?(T(w,null,this[wr],y,0,p,{user:b?.user,nodeId:m?.nodeId},"delete"),p||Fe()):i.remove(this[Ke]))}}),!0}search(m){let R=this[Me],w=Dr(R);if(!m)throw new Error("No query provided");let b=m.conditions;b?b.length===void 0&&(b=b[Symbol.iterator]?Array.from(b):[b]):b=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[Ke]&&(b=[{attribute:null,comparator:"prefix",value:this[Ke]}].concat(b));let y,C={};function O(k,ie){let ue;switch(ie){case"and":case void 0:if(k.length<1)throw new Error('An "and" operator requires at least one condition');ue=!0;break;case"or":if(k.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+ie)}let pe=ue&&{},nt;for(let xe of k){if(xe.conditions){xe.conditions=O(xe.conditions,xe.operator);continue}let He=xe[0]??xe.attribute,st=He==null?V:ri(g,He);if(st){if(ue){let rr=bs(He),Ft=pe[rr];Ft?(Ft.push(xe),nt=!0):pe[rr]=[xe]}(st.type||Kb[xe.comparator])&&(xe[1]===void 0?xe.value=U(xe.value,st):xe[1]=U(xe[1],st))}else if(He!=null)throw(0,Cr.handleHDBError)(new Error,`${He} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return k;if(nt)for(let xe in pe){let He=pe[xe],st=He.length;if(st>1)for(let rr=0;rr<st;rr++){let Ft=He[rr];if(Ft.comparator==="ge"||Ft.comparator==="greater_than_equal")for(let _n=0;_n<st;_n++){let _i=He[_n];(_i.comparator==="le"||_i.comparator==="less_than_equal")&&(Ft.comparator="between",Ft.value=[Ft.value,_i.value],k.splice(k.indexOf(_i),1))}if(Ft.comparator==="equals"||!Ft.comparator){for(let _n=0;_n<st;_n++)if(_n!==rr){let _i=He[_n];k.splice(k.indexOf(_i),1)}break}}}return k}a(O,"prepareConditions");function P(k,ie){if(m.enforceExecutionOrder)return k;for(let ue of k)ue.conditions&&(ue.conditions=P(ue.conditions,ue.operator));return k.length>1&&ie!=="or"?(0,xV.sortBy)(k,bm(ve)):k}a(P,"orderConditions");function U(k,ie){return Array.isArray(k)?k.map(ue=>Pp(ue,ie)):Pp(k,ie)}a(U,"coerceTypedValues");let L=m.operator;(b.length>0||L)&&(b=O(b,L));let H=typeof m.sort=="object"&&m.sort,Y;if(H&&L!=="or"){let k=H.attribute;if(y=b.find(ie=>bs(ie.attribute)===bs(k)),!y){let ie=ri(g,k);if(!ie)throw(0,Cr.handleHDBError)(new Error,`${Array.isArray(k)?k.join("."):k} is not a defined attribute`,404);if(ie.indexed)y={attribute:k,comparator:"sort"},b.push(y);else if(b.length===0&&!m.allowFullScan)throw(0,Cr.handleHDBError)(new Error,`${Array.isArray(k)?k.join("."):k} is not indexed and not combined with any other conditions`,404)}y&&(y.descending=!!H.descending)}b=P(b,L),H&&(y&&b[0]===y?H.next&&(Y={dbOrderedAttribute:H.attribute,attribute:H.next.attribute,descending:H.next.descending,next:H.next.next}):(y&&b.splice(b.indexOf(y),1),Y=H));let K=m.select;if(b.length===0&&(b=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:b,operator:L,postOrdering:Y,selectApplied:!!K};let Te=w.useReadTxn(),J=Wb(b,L,ve,Te,m,R,(k,ie)=>re(k,K,R,Te,ie),C),Ie=m.ensureLoaded!==!1;Y||(J=B(J));let he=ve.transformEntryForSelect(K,R,Te,C,Ie,!0),De=ve.transformToOrderedSelect(J,K,Y,Te,R,he);function B(k){return m.offset||m.limit!==void 0?k.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):k}return a(B,"applyOffset"),Y&&(De=B(De)),De.onDone=()=>{De.onDone=null,w.doneReadTxn()},De.selectApplied=!0,De.getColumns=()=>{if(K){let k=[];for(let ie of K)ie==="*"?k.push(...g.map(ue=>ue.name)):k.push(ie.name||ie);return k}return g.filter(k=>!k.computed&&!k.relationship).map(k=>k.name)},De}static transformToOrderedSelect(m,R,w,b,y,C){let O=new cf;if(w){m=re(m,R,b,y,null);let P;O.iterate=function(){let L,H=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),Y,K=w.dbOrderedAttribute,Te,J,Ie=!0;function he(B){let k=B.next&&he(B.next),ie=B.descending;return(ue,pe)=>{let nt=Go(ue,B.attribute,b),xe=Go(pe,B.attribute,b),He=ie?(0,ec.compareKeys)(xe,nt):(0,ec.compareKeys)(nt,xe);return He===0?k?.(ue,pe)||0:He}}a(he,"createComparator");let De=he(w);return{async next(){let B;if(L)if(B=L.next(),B.done){if(Y)return O.onDone&&O.onDone(),B}else return{value:await C.call(this,B.value)};P=[],Te&&P.push(Te);do if(B=await H.next(),B.done){if(Y=!0,P.length)break;return O.onDone&&O.onDone(),B}else{let k=B.value;if(k?.then&&(k=await k),K){let ie=Go(k,K,b);if(Ie)Ie=!1,J=ie;else if(ie!==J){J=ie,Te=k;break}}P.push(k)}while(!0);return w.isGrouped,P.sort(De),L=P[Symbol.iterator](),B=L.next(),B.done?(O.onDone&&O.onDone(),B):{value:await C.call(this,B.value)}},return(){O.onDone&&O.onDone(),H.return()},throw(){O.onDone&&O.onDone(),H.throw()}}};let U=a(L=>{if(typeof R=="object"&&Array.isArray(L.attribute))for(let H=0;H<R.length;H++){let Y=R[H],K;if(Y.name===L.attribute[0]){for(K=Y.sort||(Y.sort={});K.next;)K=K.next;K.attribute=L.attribute.slice(1),K.descending=L.descending}else Y===L.attribute[0]&&(R[H]=K={name:Y,sort:{attribute:L.attribute.slice(1),descending:L.descending}})}L.next&&U(L.next)},"applySortingOnSelect");U(w)}else O.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),O=O.map(C);return O}static transformEntryForSelect(m,R,w,b,y,C){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let L=a(H=>(R?.transaction?.stale&&(R.transaction.stale=!1),H?.key??H),"transform");return m===t?L:m.asArray?H=>[L(H)]:H=>({[t]:L(H)})}let O;y&&I&&!(typeof m=="string"?[m]:m)?.every(L=>{let H;return typeof L=="object"?H=L.name:H=L,r[H]||H===t})&&(O=!0);let P,U=a(function(L){let H;if(R?.transaction?.stale&&(R.transaction.stale=!1),L!=null){if(Ki=L,H=L.value||L.deref?.(),!H&&(L.key===void 0||L.deref)){if(L=ic(L.key??L,R,{transaction:w,lazy:m?.length<4},this?.isSync,Y=>Y),L?.then)return L.then(U.bind(this));H=L?.value}if(O&&L?.metadataFlags&(Ja|$_)||L?.expiresAt&&L?.expiresAt<Date.now()){let Y=oc(L.key??L,L,R);if(Y?.then)return Y.then(U)}}if(H==null)return C?Xa.SKIP:H;if(m&&!(m[0]==="*"&&m.length===1)){let Y,K=a((J,Ie)=>{let he;typeof J=="object"?he=J.name:he=J;let De=Gr?.[he],B;if(De){let k=b?.[he];if(k)if(k.hasMappings){let ue=De.from?H[De.from]:bs(L.key);B=k.get(ue),B||(B=[])}else B=k.fromRecord?.(H);else B=De(H,R,L);let ie=a(ue=>{if(ue&&typeof ue=="object"){let pe=De.definition?.tableClass||ve;P||(P={});let nt=P[he]||(P[he]=pe.transformEntryForSelect(he===J?null:J.select||(Array.isArray(J)?J:null),R,w,k,y));if(Array.isArray(ue)){let xe=[],He=pe.transformToOrderedSelect(ue,J.select,typeof J.sort=="object"&&J.sort,R,w,nt)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),st=a(Ft=>{for(;!Ft.done;){if(Ft?.then)return Ft.then(st);xe.push(Ft.value),Ft=He.next()}Ie(xe,he)},"nextValue"),rr=st(He.next());rr&&(Y||(Y=[]),Y.push(rr));return}else if(ue=nt.call(this,ue),ue?.then){Y||(Y=[]),Y.push(ue.then(xe=>Ie(xe,he)));return}}Ie(ue,he)},"handleResolvedValue");B?.then?(Y||(Y=[]),Y.push(B.then(ie))):ie(B);return}else B=H[he],B&&typeof B=="object"&&he!==J&&(B=ve.transformEntryForSelect(J.select||J,R,w,null)({value:B}));Ie(B,he)},"selectAttribute"),Te;if(typeof m=="string")K(m,J=>{Te=J});else if(Array.isArray(m))if(m.asArray)Te=[],m.forEach((J,Ie)=>{J==="*"?m[Ie]=H:K(J,he=>Te[Ie]=he)});else{Te={};let J=m.forceNulls;for(let Ie of m)if(Ie==="*")for(let he in H)Te[he]=H[he];else K(Ie,(he,De)=>{he===void 0&&J&&(he=null),Te[De]=he})}else throw new Cr.ClientError("Invalid select"+m);return Y?Promise.all(Y).then(()=>Te):Te}return H},"transform");return U}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");p||ft({table:s,database:c,schemaDefined:d,attributes:g,audit:!0}),m||(m={});let R=!m.rawEvents,w=sA(ve,this[Ke]??null,function(O,P,U,L){try{let H=P.getValue?.(i,R),Y=P.type;if(!H&&P.type==="patch"&&R){let K=i.getEntry(O);K?.version===P.version?H=K.value:H=P.getValue?.(i,!0,U),Y="put"}this.send({id:O,timestamp:U,value:H,version:P.version,type:Y,beginTxn:L})}catch(H){qe.default.error?.(H)}},m.startTime||0,m);this[ws]&&(w.includeDescendants=!0,m.onlyChildren&&(w.onlyChildren=!0)),m.supportsTransactions&&(w.supportsTransactions=!0);let b=this[Ke],y=m.previousCount;y>1e3&&(y=1e3);let C=m.startTime;if(this[ws]){if(C){if(y)throw new Cr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:O,value:P}of l.getRange({start:C,exclusiveStart:!0})){let U=Pt(P);if(U.tableId!==n)continue;let L=U.recordId;if(b==null||UV(b,L)){let H=U.getValue(i,R,O);w.send({id:L,timestamp:O,value:H,version:U.version,type:U.type})}w.startTime=O}}else if(y){let O=[];for(let{key:P,value:U}of l.getRange({start:"z",end:!1,reverse:!0}))try{let L=Pt(U);if(L.tableId!==n)continue;let H=L.recordId;if(b==null||UV(b,H)){let Y=L.getValue(i,R,P);if(O.push({id:H,timestamp:P,value:Y,version:L.version,type:L.type}),--y<=0)break}}catch(L){qe.default.error?.("Error getting history entry",P,L)}for(let P=O.length;P>0;)w.send(O[--P]);O[0]&&(w.startTime=O[0].timestamp)}else if(!m.omitCurrent)for(let{key:O,value:P,version:U,localTime:L}of i.getRange({start:b??!1,end:b==null?void 0:[b,ec.MAXIMUM_KEY],versions:!0}))P&&w.send({id:O,timestamp:L,value:P,version:U,type:"put"})}else{y&&!C&&(C=0);let O=this[wr]?.localTime;if(O===FS&&(i.cache?.delete(b),this[wr]=i.getEntry(b),qe.default.trace?.("re-retrieved record",O,this[wr]?.localTime),O=this[wr]?.localTime),qe.default.trace?.("Subscription from",C,"from",b,O),C<O){let P=[],U=O;do{let L=l.get(U);if(L){m.omitCurrent=!0;let H=Pt(L),Y=H.getValue(i,R,U);R&&(H.type="put"),P.push({id:b,value:Y,timestamp:U,...H}),U=H.previousLocalTime}else break;y&&y--}while(U>C&&y!==0);for(let L=P.length;L>0;)w.send(P[--L]);w.startTime=O}!m.omitCurrent&&this.doesExist()&&w.send({id:b,timestamp:O,value:this[Ce],version:this[K_],type:"put"})}return m.listener&&w.on("data",m.listener),w}doesExist(){return!!(this[Ce]||this[V_])}publish(m,R){this._writePublish(m,R)}_writePublish(m,R){let w=Dr(this[Me]),b=this[Ke]||null;b!=null&&ui(b);let y=this[Me];w.addWrite({key:b,store:i,entry:this[wr],nodeName:y?.nodeName,validate:()=>{y?.source||(w.checkOverloaded(),this.validate(m))},before:je.publish?.bind(this,y,b,m),beforeIntermediate:ye.publish?.bind(this,y,b,m),commit:(C,O,P)=>{O===void 0&&S&&!p&&Fe(),qe.default.trace?.(`Publishing message to id: ${b}, timestamp: ${new Date(C).toISOString()}`),T(b,O?.value??null,O,O?.version||C,0,!0,{user:y?.user,residencyId:R?.residencyId,expiresAt:y?.expiresAt,nodeId:R?.nodeId},"message",!1,m)}})}validate(m,R){let w,b=a((y,C,O)=>{if(C.type&&y!=null)if(R&&y.__op__&&(y=y.value),C.properties){typeof y!="object"&&(w||(w=[])).push(`Value ${Cs(y)} in property ${O} must be an object${C.type?" ("+C.type+")":""}`);let P=C.properties;for(let U=0,L=P.length;U<L;U++){let H=P[U],Y=b(y[H.name],H,O+"."+H.name);Y&&(y[H.name]=Y)}if(C.sealed&&y!=null&&typeof y=="object")for(let U in y)P.find(L=>L.name===U)||(w||(w=[])).push(`Property ${U} is not allowed within object in property ${O}`)}else switch(C.type){case"Int":(typeof y!="number"||y>>0!==y)&&(w||(w=[])).push(`Value ${Cs(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))&&(w||(w=[])).push(`Value ${Cs(y)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof y!="number"&&(w||(w=[])).push(`Value ${Cs(y)} in property ${O} must be a number`);break;case"ID":typeof y=="string"||y?.length>0&&y.every?.(P=>typeof P=="string")||(w||(w=[])).push(`Value ${Cs(y)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof y!="string"&&(w||(w=[])).push(`Value ${Cs(y)} in property ${O} must be a string`);break;case"Boolean":typeof y!="boolean"&&(w||(w=[])).push(`Value ${Cs(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);(w||(w=[])).push(`Value ${Cs(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);(w||(w=[])).push(`Value ${Cs(y)} in property ${O} must be a bigint`)}break;case"Bytes":y instanceof Uint8Array||(w||(w=[])).push(`Value ${Cs(y)} in property ${O} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(y)){if(C.elements)for(let P=0,U=y.length;P<U;P++){let L=y[P],H=b(L,C.elements,O+"[*]");H&&(y[P]=H)}}else(w||(w=[])).push(`Value ${Cs(y)} in property ${O} must be a Buffer or Uint8Array`);break}C.nullable===!1&&y==null&&(w||(w=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let y=0,C=g.length;y<C;y++){let O=g[y];if(!(O.relationship||O.computed)&&(!R||O.name in m)){let P=b(m[O.name],O,O.name);P&&(m[O.name]=P)}}if(_)for(let y in m)g.find(C=>C.name===y)||(w||(w=[])).push(`Property ${y} is not allowed`);if(w)throw new Cr.ClientError(w.join(". "))}getUpdatedTime(){return this[K_]}wasLoadedFromSource(){return I?!!this[xO]:void 0}static async addAttributes(m){let R=g.slice(0);for(let w of m){if(!w.name)throw new Cr.ClientError("Attribute name is required");if(w.name.match(/[`/]/))throw new Cr.ClientError("Attribute names cannot include backticks or forward slashes");R.push(w)}return ft({table:s,database:c,schemaDefined:d,attributes:R}),ve.indexingOperation}static async removeAttributes(m){let R=g.filter(w=>!m.includes(w.name));return ft({table:s,database:c,schemaDefined:d,attributes:R}),ve.indexingOperation}static getRecordCount(m){let R=i.getStats().entryCount,w=5e3,b=1e3,y;R>w&&!m?.exactCount&&(y=b);let C=0;for(let{value:O}of i.getRange({start:!0,lazy:!0,limit:y}))O!=null&&C++;if(y){let O=C;C=0;for(let{value:Ie}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:y}))Ie!=null&&C++;let P=y*2,U=(C+O)/P,L=Math.pow((C-O+1)/y/2,2)+U*(1-U)/P,H=Math.max(Math.sqrt(L)*R,1),Y=Math.round(U*R),K=Math.max(Y-1.96*H,0),Te=Math.min(Y+1.96*H,R),J=Math.pow(10,Math.round(Math.log10(H)));return J>Y&&(J=J/10),C=Math.round(Y/J)*J,{recordCount:C,estimatedRange:[Math.round(K),Math.round(Te)]}}return{recordCount:C}}static updatedAttributes(){Gr=this.propertyResolvers={$id:(m,R,w)=>({value:w.key}),$updatedtime:(m,R,w)=>w.version,$record:(m,R,w)=>w?{value:m}:m};for(let m of this.attributes){m.resolve=null;let R=m.relationship,w=m.computed;if(R)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),w&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),zl=!0,R.to)m.elements?.definition?(Gr[m.name]=m.resolve=(b,y,C)=>{let O=b[R.from?R.from:t],P=m.elements.definition.tableClass;return C?yl({attribute:R.to,value:O},Dr(y).getReadTxn(),!1,P,!1).asArray:P.search([{attribute:R.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,R.from&&(m.resolve.from=R.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(R.from){let b=m.definition||m.elements?.definition;b?(Gr[m.name]=m.resolve=(y,C,O)=>{let P=y[R.from];if(P!==void 0){if(m.elements){let U,L=P.map(H=>{let Y=O?b.tableClass.primaryStore.getEntry(H,{transaction:Dr(C).getReadTxn()}):b.tableClass.get(H,C);return Y?.then&&(U=!0),Y});return R.filterMissing?U?Promise.all(L).then(H=>H.filter(vV)):L.filter(vV):U?Promise.all(L):L}return O?b.tableClass.primaryStore.getEntry(P,{transaction:Dr(C).getReadTxn()}):b.tableClass.get(P,C)}},m.set=(y,C)=>{if(Array.isArray(C)){let O=C.map(P=>P[Ke]||P[b.tableClass.primaryKey]);y[R.from]=O}else{let O=C[Ke]||C[b.tableClass.primaryKey];y[R.from]=O}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=R.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else w&&(typeof w.from=="function"&&this.setComputedAttribute(m.name,w.from),Gr[m.name]=m.resolve=(b,y,C)=>{let O=typeof w.from=="string"?b[w.from]:b,P=this.userResolvers[m.name];if(P)return P(O,y,C);qe.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]=()=>{}})}Cp(this,this)}static setComputedAttribute(m,R){let w=ri(g,m);if(!w){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!w.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=R}static async deleteHistory(m=0){let R;for(let{key:w,value:b}of l.getRange({start:0,end:m}))await Y_(),Pt(b).tableId===n&&(R=l.remove(w));await R}static async*getHistory(m=0,R=1/0){for(let{key:w,value:b}of l.getRange({start:m,end:R})){await Y_();let y=Pt(b);y.tableId===n&&(yield{id:y.recordId,localTime:w,version:y.version,type:y.type,value:y.getValue(i,!0,w),user:y.user,operation:y.originatingOperation})}}static async getHistoryOfRecord(m){let R=[];if(m==null)throw new Error("An id is required");let w=i.getEntry(m);if(!w)return R;let b=w.localTime;if(!b)throw new Error("The entry does not have a local audit time");let y=0;do{await Y_();let C=l.get(b);if(C){let O=Pt(C);R.push({id:O.recordId,localTime:b,version:O.version,type:O.type,value:O.getValue(i,!0,b),user:O.user}),b=O.previousLocalTime}else break}while(y<1e3&&b);return R.reverse()}static cleanup(){se?.remove()}}ve.updatedAttributes();let Jp=ve.prototype;return Jp[ude]=!0,f&&ve.setTTLExpiration(f/1e3),F&&Ee(),ve;function Qi(q,m,R){let w;for(let b in r){let y=r[b],C=y.isIndexing,O=Gr[b],P=R&&(O?O(R):R[b]),U=m&&(O?O(m):m[b]);if(P===U&&!C)continue;w=!0;let L=y.indexNulls,H=(0,W_.getIndexedValues)(P,L),Y=(0,W_.getIndexedValues)(U,L);if(Y?.length>0){let K=new Set(Y);if(H=H?H.filter(Te=>{if(K.has(Te))K.delete(Te);else return!0}):[],Y=Array.from(K),(Y.length>0||H.length>0)&&DV){let Te=Y.concat(H).map(J=>({key:J,value:q}));y.prefetch(Te,MV)}for(let Te=0,J=Y.length;Te<J;Te++)y.remove(Y[Te],q)}else H?.length>0&&DV&&y.prefetch(H.map(K=>({key:K,value:q})),MV);if(H)for(let K=0,Te=H.length;K<Te;K++)y.put(H[K],q)}return w}a(Qi,"updateIndices");function ui(q){switch(typeof q){case"number":return!0;case"string":if(q.length<659)return!0;if(q.length>PV)throw new Error("Primary key size is too large: "+q.length);break;case"object":if(q===null)throw new Error("Invalid primary key of null");break;case"bigint":if(q<2n**64n&&q>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof q)}if((0,ec.writeKey)(q,_de,0)>PV)throw new Error("Primary key size is too large: "+q.length);return!0}a(ui,"checkValidId");function ic(q,m,R,w,b){if(ve.getResidencyById&&R.ensureLoaded){let C=ve.getResidencyById(q);if(C&&!C.includes(server.hostname))return A({key:q,residency:C}).then(b,O=>{qe.default.error?.("Unable to retrieve data",O)})}let y=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),R.transaction?.isDone)return b(null,q);let C=i.getEntry(q,R);return C?.residencyId&&C.metadataFlags&Ja&&A&&R.ensureLoaded?A(C).then(O=>b(O,q)):(C&&m&&(C?.version>(m.lastModified||0)&&(m.lastModified=C.version),C?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=C.localTime)),b(C,q))},"whenPrefetched");return w?y():le>0?(le--,y()):new Promise((C,O)=>{le===0?(le--,i.prefetch([q],()=>{P(),U()})):(ee.push(q),Z.push(U),ee.length>jl&&(le--,P()));function P(){if(ee.length>0){let L=Z;i.prefetch(ee,()=>{le===-1?P():le++;for(let H of L)H()}),ee=[],Z=[],_e>2&&_e--}else le=_e,_e<lf&&_e++}a(P,"prefetch");function U(){try{C(y())}catch(L){O(L)}}a(U,"load")})}a(ic,"loadLocalRecord");function di(q){if(!q?.role)return;let m=q.role.permission;if(m.super_user)return fde;let R=m[c],w,b=R?.tables;if(b)return b[s];if(c==="data"&&(w=m[s])&&!w.tables)return w}a(di,"getTablePermissions");function oc(q,m,R,w){if(I){let b=!1;if(R.noCache?b=!0:(m?(!m.value||m.metadataFlags&(Ja|$_)||m.expiresAt&&m.expiresAt<Date.now())&&(b=!0):b=!0,wn(!b,"cache-hit",s)),b){let y=Je(q,m,R).then(C=>(C?.value?.[Ce]&&qe.default.error?.("Can not assign a record with a record property"),R&&(C?.version>(R.lastModified||0)&&(R.lastModified=C.version),R.lastRefreshed=Date.now()),C));if(R?.onlyIfCached||m?.value&&w?.allowStaleWhileRevalidate?.(m,q)){if(y.catch(C=>qe.default.warn?.(C)),R?.onlyIfCached&&!w.doesExist())throw new Cr.ServerError("Entry is not cached",504);return}else return y}}else if(m?.value&&m.expiresAt&&m.expiresAt<Date.now())return ve.evict(m.key,m.value,m.version),m.value=null,{then(b){return b(m)}}}a(oc,"ensureLoadedFromSource");function Dr(q){let m=q?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let R=m.next;if(!R)return m=m.next=new aa,m.lmdbDb=i,m;m=R}while(!0)}else return new gE}a(Dr,"txnForContext");function Go(q,m,R){if(!q)return;Ki=q;let w=q.value||q.deref?.()||(Ki=i.getEntry(q.key))?.value;if(typeof m=="object"){let y=Gr,C=w;for(let O=0,P=m.length;O<P;O++){let U=m[O],L=y?.[U];C=L&&C?L(C,R,!0)?.value:C?.[U],y=L?.definition?.tableClass?.propertyResolvers}return C}let b=Gr[m];return b?b(w,R):w[m]}a(Go,"getAttributeValue");function re(q,m,R,w,b){let y=b?.length,C={transaction:w,lazy:y>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},O;function P(U,L){let H=U?.value;if(!H)return Xa.SKIP;for(let Y=0;Y<y;Y++)if(!O?.includes(Y)&&!b[Y](H,U))return Xa.SKIP;return L!==void 0&&(U.key=L),U}if(a(P,"processEntry"),y>0||!q.hasEntries){let U=q.map(L=>{if(O=null,typeof L=="object"&&L?.key!==void 0)return y>0?P(L):L;if(L==null)return Xa.SKIP;for(let H=0;H<y;H++){let K=b[H].idFilter;if(K){if(!K(L))return Xa.SKIP;O||(O=[]),O.push(H)}}return ic(L,R,C,!1,P)});return Array.isArray(q)&&(U=U.filter(L=>L!==Xa.SKIP)),U.hasEntries=!0,U}return q}a(re,"transformToEntries");function me(q,m,R=server.replication?.getThisNodeId(l)){if(q<=m?.version){if(m?.version===q&&R!==void 0){let w=server.replication?.exportIdMapping(l),b=m.localTime,y=l.get(b);if(y){let C,O,P=Pt(y);for(let U in w)w[U]===R&&(C=U),w[U]===P.nodeId&&(O=U);if(C>O)return!1}}return!0}return!1}a(me,"precedesExistingVersion");async function Je(q,m,R){let w=m?.metadataFlags,b=m?.version,y,C;if(!i.attemptLock(q,b,()=>{clearTimeout(C);let L=i.getEntry(q);!L||!L.value||L.metadataFlags&(Ja|$_)?y(Je(q,i.getEntry(q),R)):y(L)}))return new Promise(L=>{y=L,C=setTimeout(()=>{i.unlock(q,b)},lde)});let O=m?.value,P={requestContext:R,replacingRecord:O,replacingEntry:m,replacingVersion:b,noCacheStore:!1,source:null,resourceCache:R?.resourceCache},U=R?.responseHeaders;return new Promise((L,H)=>{let Y;HO(gt(P,async K=>{let Te=performance.now(),J,Ie,he;try{for(let ie of ve.sources)if(ie.get&&(!ie.get.reliesOnPrototype||ie.prototype.get)){if(ie.available?.(m)===!1)continue;if(P.source=ie,J=await ie.get(q,P),J)break}he=w&Ja;let B=P.lastModified||he&&b;Ie=he||B>b||!O,B||(B=(0,W_.getNextMonotonicTime)());let k=performance.now()-Te;if(Qr(k,"cache-resolution",s),U&&fb(U,"Server-Timing",`cache-resolve;dur=${k.toFixed(2)}`,!0),K.timestamp=B,f&&!P.expiresAt&&(P.expiresAt=Date.now()+f),J){if(typeof J!="object")throw new Error("Only objects can be cached and stored in tables");if(J.status>0&&J.headers)if(J.status>=300)if(J.status===304)J=O,B=b;else throw new Cr.ServerError(J.body||"Error from source",J.status);else J=J.body;typeof J.toJSON=="function"&&(J=J.toJSON()),t&&J[t]!==q&&(J[t]=q)}Y=!0,L({key:q,version:B,value:J})}catch(B){B.message+=` while resolving record ${q} for ${s}`,O&&((B.code==="ECONNRESET"||B.code==="ECONNREFUSED"||B.code==="EAI_AGAIN")&&!R?.mustRevalidate||R?.staleIfError&&(B.statusCode===500||B.statusCode===502||B.statusCode===503||B.statusCode===504))?(L({key:q,version:b,value:O}),qe.default.trace?.(B.message,"(returned stale record)")):H(B),P.transaction.abort();return}if(R?.noCacheStore||P.noCacheStore){P.transaction.abort();return}Dr(P).addWrite({key:q,store:i,entry:m,nodeName:"source",commit:(B,k)=>{if(k?.version!==b)return;let ie=Qi(q,O,J);J?(ye.put?.(P,q,J),qe.default.trace?.(`Writing resolved record from source with id: ${q}, timestamp: ${new Date(B).toISOString()}`),T(q,J,k,B,0,p&&Ie||null,{user:P?.user,expiresAt:P.expiresAt},"put",!!he)):k&&(ye.delete?.(P,q),qe.default.trace?.(`Deleting resolved record from source with id: ${q}, timestamp: ${new Date(B).toISOString()}`),p||S?T(q,null,k,B,0,p&&Ie||null,{user:P?.user},"delete",!!he):i.remove(q,b))}})}),()=>{i.unlock(q,b)},K=>{i.unlock(q,b),Y&&qe.default.error?.("Error committing cache update",K)})})}a(Je,"getFromSource");function Ae(q){if(!q||q.user?.role?.permission?.super_user)return!0;if(q.replicateTo)throw new Cr.ClientError("Can not specify replication parameters without super user permissions",403);if(q.replicatedConfirmation)throw new Cr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(Ae,"checkContextPermissions");function Fe(){if(kt!==Fo&&(Fo=kt,(0,Za.getWorkerIndex)()===(0,Za.getWorkerCount)()-1)){if(sc&&clearTimeout(sc),!kt)return;let q=new Date;q.setMonth(0),q.setDate(1),q.setHours(0),q.setMinutes(0),q.setSeconds(0);let m=Math.ceil((Date.now()-q.getTime())/kt)*kt+q.getTime(),R=a(w=>{qe.default.trace?.(`Scheduled next cleanup scan at ${new Date(w)}ms`),sc=setTimeout(()=>x=x.then(async()=>{if(R(Math.max(w+kt,Date.now())),i.rootStore.status!=="open"){clearTimeout(sc);return}let b=50,y=new Array(b),C=0;qe.default.info?.(`Starting cleanup scan for ${s}`);try{let O=0;for(let{key:P,value:U,version:L,expiresAt:H}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let Y;U===null&&!p&&L+cde<Date.now()?Y=i.remove(P,L):H&&H+h<Date.now()&&(Y=ve.evict(P,U,L),O++),Y&&(await y[C],y[C]=Y.catch(K=>{qe.default.error?.("Cleanup error",K)}),++C>=b&&(C=0)),await Y_()}qe.default.info?.(`Finished cleanup scan for ${s}, evicted ${O} entries`)}catch(O){qe.default.warn?.(`Error in cleanup scan for ${s}:`,O)}}),Math.min(w-Date.now(),2147483647)).unref()},"startNextTimer");R(m)}}a(Fe,"scheduleCleanup");function rt(){se=l?.addDeleteRemovalCallback(n,q=>{let m=i.getEntry(q);m?.value===null&&i.remove(q,m.version)})}a(rt,"addDeleteRemoval");function Ee(){(0,Za.getWorkerIndex)()===0&&setInterval(async()=>{if(!Wi){Wi=!0;try{let q=F.name,m=r[q];if(!m)throw new Error(`expiresAt attribute ${F} must be indexed`);for(let R of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let w of m.getValues(R)){let b=i.getEntry(w);b?.value?b.value[q]<Date.now()&&ve.evict(w,b.value,b.version):i.ifVersion(w,b?.version,()=>m.remove(R,w))}await Y_()}}catch(q){qe.default.error?.("Error in evicting old records",q)}finally{Wi=!1}}},ade).unref()}a(Ee,"runRecordExpirationEviction");function Lt(q){if(q){let m=q.join(","),R=u.get([Symbol.for("residency_by_set"),m]);return R||(u.put([Symbol.for("residency_by_set"),m],R=Math.floor(Math.random()*2147483647)),u.put([Symbol.for("residency_by_id"),R],q),R)}}a(Lt,"getResidencyId")}function BO(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 MV(){}function Ede(e){BV=e}function Pp(e,t){let r=t?.type;return e===null?e:e===""&&r&&r!=="String"&&r!=="Any"?null:r==="Int"||r==="Long"?e[0]==="$"?parseInt(e.slice(1),36):e==="null"?null:parseInt(e):r==="Float"?e==="null"?null:+e:r==="BigInt"?e==="null"?null:BigInt(e):r==="Boolean"?e==="true"?!0:e==="false"?!1:e:r==="Date"?isNaN(e)?e==="null"?null:(hde.test(e)||(e+="Z"),new Date(e)):new Date(+e):!r||r==="Any"?(0,Up.autoCast)(e):e}function UV(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t;if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function HO(e,t,r){return e?.then?e.then(t,r):t(e)}function Mp(e,t){e[wr]=t,e[Ce]=t?.value??null,e[K_]=t?.version}function vV(e){return e!=null}function Cs(e){try{return JSON.stringify(e)}catch{return e}}function mde(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var as,Xa,W_,xV,Vl,Cr,Q_,z_,qe,ec,Za,Up,ode,BV,ade,cde,DV,lde,K_,ude,wr,V_,LV,dde,xO,Ja,$_,_de,PV,fde,BOe,hde,Y_,Hm=Oe(()=>{as=v(M()),Xa=require("lmdb"),W_=v(hn()),xV=require("lodash");us();RE();Vl=v(ne());iA();Cr=v(ce()),Q_=v(gi()),z_=v(hs());Ne();S_();qe=v(md());yE();ca();ec=require("ordered-binary"),Za=v(et());Ei();Up=v(te());dc();yi();Ap();Zd();ode=new Uint8Array(9);ode[8]=192;ade=6e4,cde=864e5;Vl.initSync();DV=Vl.get(as.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),lde=1e4,K_=Symbol.for("version"),ude=Symbol.for("incremental-update"),wr=Symbol("entry"),V_=Symbol("is-saving"),LV=1,dde=2,xO=Symbol("loaded-from-source"),Ja=1,$_=8,_de=Buffer.allocUnsafeSlow(8192),PV=1978,fde={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},BOe=(0,Up.convertToMS)(Vl.get(as.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(vp,"makeTable");a(BO,"attributesAsObject");a(MV,"noop");a(Ede,"setServerUtilities");hde=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(Pp,"coerceType");a(UV,"isDescendantId");Y_=a(()=>new Promise(setImmediate),"rest");a(HO,"when");a(Mp,"updateResource");a(vV,"exists");a(Cs,"stringify");a(mde,"hasOtherProcesses")});var ot={};Ze(ot,{database:()=>Dc,databases:()=>Ve,dropDatabase:()=>xg,dropTableMeta:()=>Rde,getDatabases:()=>ut,getDefaultCompression:()=>Kh,getTables:()=>pde,onRemovedDB:()=>yd,onUpdatedTable:()=>Aa,readMetaDb:()=>j_,resetDatabases:()=>Yd,table:()=>ft,tables:()=>pn});function pde(){return kp||ut(),pn||{}}function ut(){if(kp)return Ve;kp=!0,Kl=new Map;let e=(0,Wt.getHdbBasePath)()&&(0,Ct.join)((0,Wt.getHdbBasePath)(),ur.DATABASES_DIR_NAME),t=(0,Wt.get)(ur.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Wt.get)(ur.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,Bn.existsSync)(e)?e:(0,Ct.join)((0,Wt.getHdbBasePath)(),ur.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,Bn.existsSync)(e))for(let n of(0,Bn.readdirSync)(e,{withFileTypes:!0})){let s=(0,Ct.basename)(n.name,".mdb");n.isFile()&&(0,Ct.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&j_((0,Ct.join)(e,n.name),null,s)}if((0,Bn.existsSync)((0,Yl.getBaseSchemaPath)())){for(let n of(0,Bn.readdirSync)((0,Yl.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Ct.join)((0,Yl.getBaseSchemaPath)(),n.name),i=(0,Ct.join)((0,Yl.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,Bn.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Ct.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Ct.join)(i,o.name);j_((0,Ct.join)(s,o.name),(0,Ct.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,Bn.existsSync)(i))for(let c of(0,Bn.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Ct.extname)(c.name).toLowerCase()===".mdb"&&j_((0,Ct.join)(i,c.name),(0,Ct.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],d=(0,Ct.join)(l.path,(0,Ct.basename)(c+".mdb"));(0,Bn.existsSync)(d)&&j_(d,c,n,null,!0)}}for(let n in Ve){let s=Kl.get(n);if(s){let i=Ve[n];n.includes("delete")&&mr.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(mr.trace(`delete table class ${o}`),delete i[o])}else if(delete Ve[n],n==="data"){for(let i in pn)delete pn[i];delete pn[Fp]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(Ve.system)for(let n of r)Ve.system[n]&&(Ve.system[n].replicate=!1);return Kl=null,Ve}function Yd(){kp=!1;for(let[,e]of Ho)e.needsDeletion=!0;ut();for(let[e,t]of Ho)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Ho.delete(e),delete Ve[t.databaseName],X_.forEach(r=>r(t.databaseName)));return Ve}function j_(e,t,r=GO,n,s){let i=new kO.default(e,!1);try{let o=Ho.get(e);o?o.needsDeletion=!1:(o=(0,Wl.open)(i),Ho.set(e,o));let c=new tc.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(xp.INTERNAL_DBIS_NAME,c)),d=o.auditStore;d||(n?(0,Bn.existsSync)(n)&&(i.path=n,d=(0,Wl.open)(i),d.isLegacy=!0):d=Rp(o));let u=GV(r),_=u[Fp],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[p,S]=f.toString().split("/");S===""?S=h.name:S||(S=p,p=t,h.name||(h.name=S,h.indexed=!h.is_hash_attribute)),_?.add(p);let g=E.get(p);g||E.set(p,g={attributes:[]}),(S==null||h.is_hash_attribute)&&(g.primary=h),S!=null&&g.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:p,primary:S}=h;if(!S){for(let Z of p)if(Z.is_hash_attribute||Z.isPrimaryKey){S=Z;break}if(!S){mr.fatal(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(p)}`);continue}}let g=u[f],T={},A=[],I,V,x=typeof S.audit=="boolean"?S.audit:(0,Wt.get)(ur.CONFIG_PARAMS.LOGGING_AUDITLOG),X=S.trackDeletes,$=S.expiration,F=S.eviction,se=S.sealed,ee=S.replicate;if(g)T=g.indices,A=g.attributes,g.schemaVersion++;else{I=S.tableId,I?I>=(l.get($l)||0)&&l.putSync($l,I+1):(S.tableId=I=l.get($l),I||(I=1),l.putSync($l,I+1),l.putSync(S.key,S));let Z=new tc.default(!S.is_hash_attribute,S.is_hash_attribute);if(Z.compression=S.compression,Z.compression){let le=(0,Wt.get)(ur.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||FV;Z.compression.threshold=le}V=Df(o.openDB(S.key,Z)),o.databaseName=r,V.rootStore=o,V.tableId=I}for(let Z of p){Z.attribute=Z.name;try{if(!Z.is_hash_attribute&&(Z.indexed||Z.attribute&&!Z.name)){if(!T[Z.name]){let _e=new tc.default(!Z.is_hash_attribute,Z.is_hash_attribute);T[Z.name]=o.openDB(Z.key,_e),T[Z.name].indexNulls=Z.indexNulls}let le=A.find(_e=>_e.name===Z.name);le?A.splice(A.indexOf(le),1,Z):A.push(Z)}}catch(le){mr.error("Error trying to update attribute",Z,A,T,le)}}if(!g){g=qV(u,f,vp({primaryStore:V,auditStore:d,audit:x,sealed:se,replicate:ee,expirationMS:$&&$*1e3,evictionMS:F&&F*1e3,trackDeletes:X,tableName:f,tableId:I,primaryKey:S.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:T,attributes:p,schemaDefined:S.schemaDefined,dbisDB:l})),g.schemaVersion=1;for(let Z of J_)Z(g)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function GV(e){let t=Ve[e];if(t||(e==="data"?t=Ve[e]=pn:e==="system"?Object.defineProperty(Ve,"system",{value:t=Object.create(null),configurable:!0}):t=Ve[e]=Object.create(null)),Kl&&!Kl.has(e)){let r=new Set;t[Fp]=r,Kl.set(e,r)}return t}function qV(e,t,r){return e[t]=r,r}function Dc({database:e,table:t}){e||(e=GO),ut();let r=GV(e),n=(0,Ct.join)((0,Wt.getHdbBasePath)(),ur.DATABASES_DIR_NAME),s=(0,Wt.get)(ur.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Wt.get)(ur.CONFIG_PARAMS.STORAGE_PATH)||((0,Bn.existsSync)(n)?n:(0,Ct.join)((0,Wt.getHdbBasePath)(),ur.LEGACY_DATABASES_DIR_NAME));let o=(0,Ct.join)(n,(i?t:e)+".mdb"),c=Ho.get(o);if(!c||c.status==="closed"){let l=new kO.default(o,!1);c=(0,Wl.open)(l),Ho.set(o,c)}return c.auditStore||(c.auditStore=Rp(c)),c}async function xg(e){if(!Ve[e])throw new Error("Schema does not exist");let t=Ve[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Ho.delete(r.path),r.status==="open"&&(await r.close(),await Z_.remove(r.path));if(r||(r=Dc({database:e,table:null}),r.status==="open"&&(await r.close(),await Z_.remove(r.path))),e==="data"){for(let n in pn)delete pn[n];delete pn[Fp]}delete Ve[e],X_.forEach(n=>n(e))}function ft({table:e,database:t,expiration:r,eviction:n,scanInterval:s,attributes:i,audit:o,sealed:c,replicate:l,trackDeletes:d,schemaDefined:u,origin:_}){t||(t=GO);let E=Dc({database:t,table:e}),f=Ve[t];mr.trace(`Defining ${e} in ${t}`);let h=f?.[e];if(E.status==="closed")throw new Error(`Can not use a closed data store for ${e}`);let p,S,g,T;u==null&&(u=!0);let A=new tc.default(!1);for(let F of i)F.attribute&&!F.name?(F.name=F.attribute,F.indexed=!0):F.attribute=F.name,F.expiresAt&&(F.indexed=!0);let I,V;if(h){if(p=h.primaryKey,h.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${e} class`);h.attributes.splice(0,h.attributes.length,...i)}else{let F=E.auditStore;S=i.find(le=>le.isPrimaryKey)||{},p=S.name,S.is_hash_attribute=!0,S.schemaDefined=u,S.compression=Kh(),d&&(S.trackDeletes=!0),o=S.audit=typeof o=="boolean"?o:(0,Wt.get)(ur.CONFIG_PARAMS.LOGGING_AUDITLOG),r&&(S.expiration=r),n&&(S.eviction=n),typeof c=="boolean"&&(S.sealed=c),typeof l=="boolean"&&(S.replicate=l),_&&(S.origins?S.origins.includes(_)||S.origins.push(_):S.origins=[_]),mr.trace(`${e} table loading, opening primary store`);let se=new tc.default(!1,!0);se.compression=S.compression;let ee=e+"/",Z=Df(E.openDB(ee,se));E.databaseName=t,Z.rootStore=E,T=E.dbisDb=E.openDB(xp.INTERNAL_DBIS_NAME,A),Z.tableId=T.get($l),Z.tableId||(Z.tableId=1),T.putSync($l,Z.tableId+1),S.tableId=Z.tableId,h=qV(f,e,vp({primaryStore:Z,auditStore:F,audit:o,sealed:c,replicate:l,trackDeletes:d,expirationMS:r&&r*1e3,evictionMS:n&&n*1e3,primaryKey:p,tableName:e,tableId:Z.tableId,databasePath:t,databaseName:t,indices:{},attributes:i,schemaDefined:u,dbisDB:T})),h.schemaVersion=1,I=!0,$(),T.put(ee,S)}g=h.indices,T=T||(E.dbisDb=E.openDB(xp.INTERNAL_DBIS_NAME,A)),h.dbisDB=T;let x=[];for(let{key:F,value:se}of T.getRange({start:!0})){let[ee,Z]=F.toString().split("/");if(Z===""&&(Z=se.name),Z){if(ee!==e)continue}else Z=ee;if(!i.find(_e=>_e.name===Z)?.indexed&&se.indexed&&!se.isPrimaryKey){$(),I=!0,T.remove(F);let _e=h.indices[ee];_e&&x.push(_e)}}let X=[];try{for(let F of i||[]){if(F.relationship)continue;let se=e+"/"+(F.name||"");Object.defineProperty(F,"key",{value:se,configurable:!0});let ee=T.get(se);if(F.isPrimaryKey){if(ee=ee||T.get(se=e+"/")||{},o!==void 0&&o!==h.audit||c!==void 0&&c!==h.sealed||l!==void 0&&l!==h.replicate||(+r||void 0)!==(+ee.expiration||void 0)||(+n||void 0)!==(+ee.eviction||void 0)){let le=Object.assign({},ee);typeof o=="boolean"&&(o&&h.enableAuditing(o),le.audit=o),r&&(le.expiration=+r),n&&(le.eviction=+n),c!==void 0&&(le.sealed=c),l!==void 0&&(le.replicate=l),I=!0,$(),T.put(se,le)}continue}ee?.attribute&&!ee.name&&(ee.indexed=!0);let Z=!ee||ee.type!==F.type||ee.indexed!==F.indexed||ee.nullable!==F.nullable||ee.version!==F.version||JSON.stringify(ee.attributes)!==JSON.stringify(F.attributes)||JSON.stringify(ee.elements)!==JSON.stringify(F.elements);if(F.indexed){let le=new tc.default(!0,!1),_e=E.openDB(se,le);(Z||ee.indexingPID&&ee.indexingPID!==process.pid||ee.restartNumber<ef.workerData?.restartNumber)&&(I=!0,$(),ee=T.get(se),(Z||ee.indexingPID&&ee.indexingPID!==process.pid||ee.restartNumber<ef.workerData?.restartNumber)&&(I=!0,F.indexNulls===void 0&&(F.indexNulls=!0),h.primaryStore.getStats().entryCount>0&&(F.lastIndexedKey=ee?.lastIndexedKey??void 0,F.indexingPID=process.pid,_e.isIndexing=!0,Object.defineProperty(F,"dbi",{value:_e}),X.push(F))),T.put(se,F)),ee?.indexNulls&&F.indexNulls===void 0&&(F.indexNulls=!0),_e.indexNulls=F.indexNulls,g[F.name]=_e}else Z&&(I=!0,$(),T.put(se,F))}}finally{V&&V()}if(I&&(E.auditStore,h.schemaVersion++,h.updatedAttributes()),mr.trace(`${e} table loading, running index`),X.length>0||x.length>0?h.indexingOperation=gde(h,X,x):I&&Bp.signalSchemaChange(new Hp.SchemaEventMsg(process.pid,"schema-change",h.databaseName,h.tableName)),h.origin=_,I)for(let F of J_)F(h,_!=="cluster");return(r||n||s)&&h.setTTLExpiration({expiration:r,eviction:n,scanInterval:s}),mr.trace(`${e} table loaded`),h;function $(){V||E.transactionSync(()=>({then(F){V=F}}))}a($,"startTxn")}async function gde(e,t,r){try{mr.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await Bp.signalSchemaChange(new Hp.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let d of r)s=d.drop();let i,o={},c=0,l=t.length;if(await new Promise(d=>setImmediate(d)),l>0){let d;for(let _ of t)(0,Wl.compareKeys)(_.lastIndexedKey,d)<0&&(d=_.lastIndexedKey),_.lastIndexedKey==null&&_.dbi.clearAsync();let u=0;for(let{key:_,value:E,version:f}of e.primaryStore.getRange({start:d,lazy:l<4,versions:!0,snapshot:!1}))if(E){if(u++,s=e.primaryStore.ifVersion(_,f,()=>{for(let h=0;h<l;h++){let p=t[h],S=p.name;try{let g=p.resolve,T=E&&(g?g(E):E[S]),A=(0,HV.getIndexedValues)(T);if(A)for(let I=0,V=A.length;I<V;I++)p.dbi.put(A[I],_)}catch(g){o[S]||(o[S]=!0,mr.error(`Error indexing attribute ${S}`,g))}}}),s.then(()=>u--,h=>{u--,mr.error(h)}),ef.workerData&&ef.workerData.restartNumber!==kV.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}u>Sde?await s:u>Tde&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await Bp.signalSchemaChange(new Hp.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),mr.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){mr.error("Error in indexing",n)}}function Rde({table:e,database:t}){let r=Dc({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 Aa(e){return J_.push(e),{remove(){let t=J_.indexOf(e);t>-1&&J_.splice(t,1)}}}function yd(e){return X_.push(e),{remove(){let t=X_.indexOf(e);t>-1&&X_.splice(t,1)}}}function Kh(){let e=(0,Wt.get)(ur.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,Wt.get)(ur.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,Wt.get)(ur.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||FV,n={startingOffset:32};return t&&(n.dictionary=Z_.readFileSync(t)),r&&(n.threshold=r),e&&n}var Wt,xp,Wl,Ct,Bn,Yl,tc,kO,ur,Z_,FO,HV,Bp,Hp,ef,mr,kV,GO,Fp,FV,pn,Ve,$l,J_,X_,kp,Ho,Kl,Sde,Tde,Ne=Oe(()=>{Wt=v(ne()),xp=v(Gt()),Wl=require("lmdb"),Ct=require("path"),Bn=require("fs"),Yl=v(pt());Hm();tc=v(Tu()),kO=v(gu()),ur=v(M()),Z_=v(require("fs-extra")),FO=require("../index"),HV=v(hn()),Bp=v(gi()),Hp=v(hs()),ef=require("worker_threads"),mr=v(j()),kV=v(et());Ei();dc();GO="data",Fp=Symbol("defined-tables"),FV=((0,Wt.get)(ur.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,Wt.initSync)();pn=Object.create(null),Ve=Object.create(null);(0,FO._assignPackageExport)("databases",Ve);(0,FO._assignPackageExport)("tables",pn);$l=Symbol.for("next-table-id"),J_=[],X_=[],Ho=new Map;a(pde,"getTables");a(ut,"getDatabases");a(Yd,"resetDatabases");a(j_,"readMetaDb");a(GV,"ensureDB");a(qV,"setTable");a(Dc,"database");a(xg,"dropDatabase");a(ft,"table");Sde=1e3,Tde=10;a(gde,"runIndexing");a(Rde,"dropTableMeta");a(Aa,"onUpdatedTable");a(yd,"onRemovedDB");a(Kh,"getDefaultCompression")});var te=N((KOe,r$)=>{"use strict";var ko=require("path"),WV=require("fs-extra"),un=j(),VV=require("fs-extra"),Gp=require("os"),Ade=require("net"),bde=require("recursive-iterator"),Ht=M(),yde=FN(),$V=require("papaparse"),qp=require("moment"),{inspect:Ode}=require("util"),YV=require("is-number"),YOe=require("lodash"),Nde=require("minimist"),Ide=require("https"),wde=require("http"),{hdb_errors:Vp}=ce(),Cde=/^((\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)))$/,QV=require("util").promisify(setTimeout),Dde=100,Lde=5,Pde="",Mde=4,KV={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};r$.exports={isEmpty:Hn,isEmptyOrZeroLength:li,arrayHasEmptyValues:xde,arrayHasEmptyOrZeroLengthValues:Bde,buildFolderPath:Hde,isBoolean:zV,errorizeMessage:Ude,stripFileExtension:Fde,autoCast:Gde,autoCastJSON:jV,autoCastJSONDeep:VO,removeDir:qde,compareVersions:Vde,isCompatibleDataVersion:$de,escapeRawValue:Yde,unescapeValue:Kde,stringifyProps:Wde,timeoutPromise:zde,isClusterOperation:Jde,getClusterUser:Zde,checkGlobalSchemaTable:Xde,getHomeDir:XV,getPropsFilePath:Qde,promisifyPapaParse:e_e,removeBOM:ZV,createEventPromise:t_e,checkProcessRunning:r_e,checkSchemaTableExist:n_e,checkSchemaExists:e$,checkTableExists:t$,getStartOfTomorrowInSeconds:s_e,getLimitKey:i_e,isObject:kde,isNotEmptyAndHasValue:vde,autoCasterIsNumberCheck:JV,backtickASTSchemaItems:o_e,isPortTaken:jde,createForkArgs:a_e,autoCastBoolean:c_e,async_set_timeout:QV,getTableHashAttribute:l_e,doesSchemaExist:u_e,doesTableExist:d_e,stringifyObj:__e,ms_to_time:f_e,changeExtension:E_e,getEnvCliRootPath:$O,noBootFile:h_e,httpRequest:m_e,transformReq:p_e,convertToMS:S_e,PACKAGE_ROOT:Ht.PACKAGE_ROOT};function Ude(e){return e instanceof Error?e:new Error(e)}a(Ude,"errorizeMessage");function Hn(e){return e==null}a(Hn,"isEmpty");function vde(e){return!Hn(e)&&(e||e===0||e===""||zV(e))}a(vde,"isNotEmptyAndHasValue");function li(e){return Hn(e)||e.length===0||e.size===0}a(li,"isEmptyOrZeroLength");function xde(e){if(Hn(e))return!0;for(let t=0;t<e.length;t++)if(Hn(e[t]))return!0;return!1}a(xde,"arrayHasEmptyValues");function Bde(e){if(li(e))return!0;for(let t=0;t<e.length;t++)if(li(e[t]))return!0;return!1}a(Bde,"arrayHasEmptyOrZeroLengthValues");function Hde(...e){try{return e.join(ko.sep)}catch{console.error(e)}}a(Hde,"buildFolderPath");function zV(e){return Hn(e)?!1:e===!0||e===!1}a(zV,"isBoolean");function kde(e){return Hn(e)?!1:typeof e=="object"}a(kde,"isObject");function Fde(e){return li(e)?Pde:e.slice(0,-Mde)}a(Fde,"stripFileExtension");function Gde(e){return Hn(e)||e===""||typeof e!="string"?e:KV[e]!==void 0?KV[e]:JV(e)===!0?Number(e):Cde.test(e)?new Date(e):e}a(Gde,"autoCast");function jV(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(jV,"autoCastJSON");function VO(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=VO(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=VO(r);n!==r&&(e[t]=n)}return e}else return jV(e)}a(VO,"autoCastJSONDeep");function JV(e){if(e.startsWith("0.")&&YV(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&YV(e))}a(JV,"autoCasterIsNumberCheck");async function qde(e){if(li(e))throw new Error(`Directory path: ${e} does not exist`);try{await VV.emptyDir(e),await VV.remove(e)}catch(t){throw un.error(`Error removing files in ${e} -- ${t}`),t}}a(qde,"removeDir");function Vde(e,t){if(li(e)){un.info("Invalid current version sent as parameter.");return}if(li(t)){un.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 d=0;d<l;d++)if(r=parseInt(o[d],10)-parseInt(c[d],10),r)return r;return o.length-c.length}a(Vde,"compareVersions");function $de(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a($de,"isCompatibleDataVersion");function Yde(e){if(Hn(e))return e;let t=String(e);return t==="."?Ht.UNICODE_PERIOD:t===".."?Ht.UNICODE_PERIOD+Ht.UNICODE_PERIOD:t.replace(Ht.FORWARD_SLASH_REGEX,Ht.UNICODE_FORWARD_SLASH)}a(Yde,"escapeRawValue");function Kde(e){if(Hn(e))return e;let t=String(e);return t===Ht.UNICODE_PERIOD?".":t===Ht.UNICODE_PERIOD+Ht.UNICODE_PERIOD?"..":String(e).replace(Ht.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(Kde,"unescapeValue");function Wde(e,t){if(Hn(e))return un.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+Gp.EOL}!li(n)&&n[0]===";"?r+=" "+n+s+Gp.EOL:li(n)||(r+=n+"="+s+Gp.EOL)}catch{un.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(Wde,"stringifyProps");function XV(){let e;try{e=Gp.homedir()}catch{e=process.env.HOME}return e}a(XV,"getHomeDir");function Qde(){let e=ko.join(XV(),Ht.HDB_HOME_DIR_NAME,Ht.BOOT_PROPS_FILE_NAME);return WV.existsSync(e)||(e=ko.join(__dirname,"../","hdb_boot_properties.file")),e}a(Qde,"getPropsFilePath");function zde(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(zde,"timeoutPromise");async function jde(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=Ade.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(jde,"isPortTaken");function Jde(e){try{return Ht.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){un.error(`Error checking operation against cluster ops ${t}`)}return!1}a(Jde,"isClusterOperation");function Xde(e,t){let r=(Ne(),ae(ot)).getDatabases();if(!r[e])return Vp.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return Vp.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Xde,"checkGlobalSchemaTable");function Zde(e,t){if(Hn(t)){un.warn("No CLUSTERING_USER defined, clustering disabled");return}if(Hn(e)||li(e)){un.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){un.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){un.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(Zde,"getClusterUser");function e_e(){$V.parsePromise=function(e,t,r){return new Promise(function(n,s){$V.parse(e,{header:!0,transformHeader:ZV,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(e_e,"promisifyPapaParse");function ZV(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(ZV,"removeBOM");function t_e(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;un.info(`Got cluster status event response: ${Ode(s)}`);try{i.cancel()}catch{un.error("Error trying to cancel timeout.")}n(s)})})}a(t_e,"createEventPromise");async function r_e(e){let t=!0,r=0;do await QV(Dde*r++),(await yde.findPs(e)).length>0&&(t=!1);while(t&&r<Lde);if(t)throw new Error(`process ${e} was not started`)}a(r_e,"checkProcessRunning");function n_e(e,t){let r=e$(e);if(r)return r;let n=t$(e,t);if(n)return n}a(n_e,"checkSchemaTableExist");function e$(e){let{getDatabases:t}=(Ne(),ae(ot));if(!t()[e])return Vp.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(e$,"checkSchemaExists");function t$(e,t){let{getDatabases:r}=(Ne(),ae(ot));if(!r()[e][t])return Vp.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(t$,"checkTableExists");function s_e(){let e=qp().utc().add(1,Ht.MOMENT_DAYS_TAG).startOf(Ht.MOMENT_DAYS_TAG).unix(),t=qp().utc().unix();return e-t}a(s_e,"getStartOfTomorrowInSeconds");function i_e(){return qp().utc().format("DD-MM-YYYY")}a(i_e,"getLimitKey");function o_e(e){try{let t=new bde(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){un.error("Got an error back ticking items."),un.error(t)}}a(o_e,"backtickASTSchemaItems");function a_e(e){return[e]}a(a_e,"createForkArgs");function c_e(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(c_e,"autoCastBoolean");function l_e(e,t){let{getDatabases:r}=(Ne(),ae(ot)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(l_e,"getTableHashAttribute");function u_e(e){let{getDatabases:t}=(Ne(),ae(ot));return t()[e]!==void 0}a(u_e,"doesSchemaExist");function d_e(e,t){let{getDatabases:r}=(Ne(),ae(ot));return r()[e]?.[t]!==void 0}a(d_e,"doesTableExist");function __e(e){try{return JSON.stringify(e)}catch{return e}}a(__e,"stringifyObj");function f_e(e){let t=qp.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(f_e,"ms_to_time");function E_e(e,t){let r=ko.basename(e,ko.extname(e));return ko.join(ko.dirname(e),r+t)}a(E_e,"changeExtension");function $O(){if(process.env[Ht.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Ht.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=Nde(process.argv);if(e[Ht.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Ht.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a($O,"getEnvCliRootPath");var qO;function h_e(){if(qO)return qO;let e=$O();if($O()&&WV.pathExistsSync(ko.join(e,Ht.HDB_CONFIG_FILE)))return qO=!0,!0}a(h_e,"noBootFile");function m_e(e,t){let r;return e.protocol==="http:"?r=wde:r=Ide,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",l=>{c.body+=l}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(m_e,"httpRequest");function p_e(e){if(!e.schema&&!e.database){e.schema=Ht.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(p_e,"transformReq");function S_e(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(S_e,"convertToMS")});var ne=N((a$,c$)=>{"use strict";var YO=require("fs-extra"),rc=require("path"),n$=require("os"),T_e=require("properties-reader"),rf=j(),tf=te(),be=M(),$p=dr(),g_e="Error initializing environment manager",Yp="BOOT_PROPS_FILE_PATH",s$=!1,R_e={[be.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[be.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},$i={};Object.assign(a$,c$.exports={BOOT_PROPS_FILE_PATH:Yp,getHdbBasePath:A_e,setHdbBasePath:b_e,get:i$,initSync:O_e,setProperty:We,initTestEnvironment:I_e,setCloneVar:N_e});function A_e(){return $i[be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(A_e,"getHdbBasePath");function b_e(e){$i[be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(b_e,"setHdbBasePath");function i$(e){let t=$p.getConfigValue(e);return t===void 0?$i[e]:t}a(i$,"get");function We(e,t){R_e[e]&&($i[e]=t),$p.updateConfigObject(e,t)}a(We,"setProperty");function y_e(){let e;try{e=tf.getPropsFilePath(),YO.accessSync(e,YO.constants.F_OK|YO.constants.R_OK),s$=!0;let t=T_e(e);return $i[be.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(be.HDB_SETTINGS_NAMES.INSTALL_USER),$i[be.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(be.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),$i[Yp]=e,!0}catch{return rf.trace(`Environment manager found no properties file at ${e}`),!1}}a(y_e,"doesPropFileExist");function O_e(e=!1){try{(s$||y_e()||tf.noBootFile())&&!o$&&($p.initConfig(e),$i[be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=$p.getConfigValue(be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){rf.error(g_e),rf.error(t),console.error(t),process.exit(1)}}a(O_e,"initSync");var o$=!1;function N_e(e){o$=e}a(N_e,"setCloneVar");function I_e(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=rc.join(__dirname,"../../","unitTests");$i[Yp]=rc.join(l,"hdb_boot_properties.file"),We(be.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,rc.join(l,"settings.test")),We(be.HDB_SETTINGS_NAMES.INSTALL_USER,n$.userInfo()?n$.userInfo().username:void 0),We(be.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),We(be.HDB_SETTINGS_NAMES.LOG_PATH_KEY,rc.join(l,"envDir","log")),We(be.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),We(be.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),We(be.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),We(be.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,rc.join(l,"envDir")),We(be.CONFIG_PARAMS.STORAGE_PATH,rc.join(l,"envDir")),s&&(We(be.CONFIG_PARAMS.HTTP_SECUREPORT,i$(be.CONFIG_PARAMS.HTTP_PORT)),We(be.CONFIG_PARAMS.HTTP_PORT,null)),We(be.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),We(be.CONFIG_PARAMS.HTTP_PORT,9926),We(be.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),We(be.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),We(be.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,tf.isEmpty(i)?!1:i),We(be.CONFIG_PARAMS.HTTP_CORS,tf.isEmpty(i)?!1:i),We(be.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),We(be.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),We(be.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),We(be.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),We(be.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,rc.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),We(be.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,tf.isEmpty(c)?!1:c),o&&(We("CORS_ACCESSLIST",o),We(be.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(We(be.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),We(be.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(We(be.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),We(be.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(We(be.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),We(be.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${Yp}. Please check your boot props and settings files`;rf.fatal(r),rf.error(t)}}a(I_e,"initTestEnvironment")});var f$=N((zOe,_$)=>{"use strict";var d$=require("joi"),{string:nf,boolean:l$,array:w_e}=d$.types(),u$=M(),C_e=ct();_$.exports=D_e;function D_e(e){let t=d$.object({operation:nf.valid(u$.OPERATIONS_ENUM.ADD_NODE,u$.OPERATIONS_ENUM.UPDATE_NODE).required(),node_name:nf.required(),subscriptions:w_e.items({schema:nf.required(),table:nf.optional(),hash_attribute:nf.optional(),subscribe:l$.required(),publish:l$.required()}).min(1).required()});return C_e.validateBySchema(e,t)}a(D_e,"updateRemoteSourceValidator")});var sf=N((JOe,E$)=>{"use strict";var KO=class{static{a(this,"UpdateRemoteResponseObject")}constructor(t,r,n=void 0){this.status=t,this.message=r,this.system_info=n}};E$.exports=KO});var S$=N((ZOe,p$)=>{"use strict";var L_e=f$(),Yi=j(),WO=lt(),P_e=M(),QO=Kn(),nc=Mt(),h$=ld(),M_e=pE(),{Node:U_e,NodeSubscription:m$}=po(),zO=sf(),jO=te(),v_e=ne(),{cloneDeep:x_e}=require("lodash"),{broadcast:B_e}=et();p$.exports=H_e;async function H_e(e){try{let t=L_e(e);if(t)return Yi.error(`Validation error in updateRemoteSource: ${t.message}`),new zO(WO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let{subscriptions:r,node_name:n,system_info:s}=e,i=[],o=x_e(await QO.getNodeRecord(n)),c=!jO.isEmptyOrZeroLength(o);o=c?o[0]:o,c&&Yi.trace(`Existing record found for ${n}, updating records subscriptions`);for(let d=0,u=r.length;d<u;d++){let _=r[d],E=_.schema,f=_.table;if(!jO.doesSchemaExist(E)){Yi.trace(`updateRemoteSource creating schema: ${E}`);try{await h$.createSchema({operation:"create_schema",schema:E})}catch(h){Yi.error(h)}}if(f&&!jO.doesTableExist(E,f)){let h=new M_e(E,f,_.hash_attribute);_.attributes&&(h.attributes=_.attributes),Yi.trace(`updateRemoteSource creating table: ${f} in schema: ${E} with attributes: ${JSON.stringify(_.attributes)}`);try{await h$.createTable(h)}catch(p){Yi.error(p)}}if(Yi.trace(`Creating local stream for ${E}.${f}`),await nc.createLocalTableStream(E,f),c?(await nc.updateConsumerIterator(E,f,n,"stop"),await nc.updateRemoteConsumer(_,n),_.subscribe===!0&&await nc.updateConsumerIterator(E,f,n,"start")):(await nc.updateRemoteConsumer(_,n),_.subscribe===!0?await nc.updateConsumerIterator(E,f,n,"start"):await nc.updateConsumerIterator(E,f,n,"stop")),c){let h=!1;for(let p=0,S=o.subscriptions.length;p<S;p++){let g=o.subscriptions[p];if(g.schema===E&&g.table===f){g.publish=_.publish,g.subscribe=_.subscribe,h=!0;break}}h||o.subscriptions.push(new m$(E,f,_.publish,_.subscribe))}else i.push(new m$(E,f,_.publish,_.subscribe))}c||(o=new U_e(n,i,void 0),Yi.trace(`No record found for ${n}, creating a new one`));let l=Object.create({});return Object.assign(l,o),l.system_info=s,await QO.upsertNodeRecord(l),B_e({type:"nats_update"}),new zO(WO.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${v_e.get(P_e.CONFIG_PARAMS.CLUSTERING_NODENAME)} successfully updated remote source`,await QO.getSystemInfo())}catch(t){Yi.error(t);let r=t.message?t.message:t;return new zO(WO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(H_e,"updateRemoteSource")});var A$=N((tNe,R$)=>{"use strict";var g$=require("joi"),{string:T$}=g$.types(),k_e=M(),F_e=ct();R$.exports=G_e;function G_e(e){let t=g$.object({operation:T$.valid(k_e.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:T$.required()});return F_e.validateBySchema(e,t)}a(G_e,"removeRemoteSourceValidator")});var O$=N((nNe,y$)=>{"use strict";var q_e=A$(),Kp=j(),Wp=lt(),JO=M(),V_e=Kn(),$_e=te(),b$=Mt(),Y_e=ne(),Qp=sf(),{NodeSubscription:K_e}=po(),W_e=wc(),Q_e=so(),{broadcast:z_e}=et(),j_e=Y_e.get(JO.CONFIG_PARAMS.CLUSTERING_NODENAME);y$.exports=J_e;async function J_e(e){try{let t=q_e(e);if(t)return Kp.error(`Validation error in removeRemoteSource: ${t.message}`),new Qp(Wp.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let r=e.node_name,n=await V_e.getNodeRecord(r);if($_e.isEmptyOrZeroLength(n)){let i=`No record found for node '${r}'`;return Kp.error(i),new Qp(Wp.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,i)}n=n[0];for(let i=0,o=n.subscriptions.length;i<o;i++){let c=n.subscriptions[i];Kp.trace(`remove remote source removing subscription: ${c.schema}.${c.table} for node: ${r}`);let l=new K_e(c.schema,c.table,!1,!1);await b$.updateConsumerIterator(c.schema,c.table,r,"stop"),await b$.updateRemoteConsumer(l,r)}let s=new W_e(JO.SYSTEM_SCHEMA_NAME,JO.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Q_e.deleteRecord(s),z_e({type:"nats_update"}),new Qp(Wp.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${j_e} successfully removed node '${r}'.`)}catch(t){Kp.error(t);let r=t.message?t.message:t;return new Qp(Wp.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(J_e,"removeRemoteSource")});var C$=N((iNe,w$)=>{"use strict";var zp=j(),of=M(),N$=lt(),XO=ne(),X_e=te(),I$=sf(),Z_e=Kn(),efe=zE(),tfe=Rn();w$.exports=rfe;async function rfe(e){try{zp.trace("getRemoteSourceConfig called");let t=process.uptime()*1e3,r=X_e.ms_to_time(t),n=new nfe(XO.get(of.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),XO.get(of.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)??XO.get(of.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT),r,await Z_e.getSystemInfo());try{let s={name:e.node_name,system_info:e.system_info},i=new efe(of.SYSTEM_SCHEMA_NAME,of.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[s]);await tfe.update(i)}catch(s){zp.error("Get remote config encountered an error updating system info for node:",e.node_name,s)}return zp.trace("getRemoteSourceConfig response:",n),new I$(N$.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,n)}catch(t){zp.error(t);let r=t.message?t.message:t;return new I$(N$.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(rfe,"getRemoteSourceConfig");function nfe(e,t,r,n){this.uptime=r,this.ports={clustering:e,operations_api:t},this.system_info=n}a(nfe,"ConfigResponseObject")});var M$=N((aNe,P$)=>{"use strict";var D$=ne();D$.initSync();var L$=Mt(),af=j(),Ql=M(),ZO=lt(),sfe=S$(),ife=O$(),ofe=C$(),afe=sf(),{encode:cfe,decode:lfe}=require("msgpackr"),ufe=Ti(),dfe=Si(),_fe=require("util"),ffe=M(),{isMainThread:Efe,parentPort:hfe}=require("worker_threads");et();var mfe=_fe.promisify(ufe.setSchemaDataToGlobal),eN=D$.get(Ql.CONFIG_PARAMS.CLUSTERING_NODENAME);P$.exports=pfe;async function pfe(){try{af.notify("Starting reply service."),await mfe();let e=await L$.getConnection(),t=`${eN}.__request__`,r=e.subscribe(t,{queue:eN});await Sfe(r)}catch(e){af.error(e)}}a(pfe,"initialize");async function Sfe(e){for await(let t of e){let r=lfe(t.data),n;switch(r.operation){case Ql.OPERATIONS_ENUM.ADD_NODE:case Ql.OPERATIONS_ENUM.UPDATE_NODE:n=await sfe(r);break;case Ql.OPERATIONS_ENUM.REMOVE_NODE:n=await ife(r);break;case Ql.OPERATIONS_ENUM.CLUSTER_STATUS:n=await ofe(r);break;case Ql.OPERATIONS_ENUM.DESCRIBE_ALL:n=await Tfe();break;default:let s=`node '${eN}' reply service received unrecognized request operation`;af.error(s),n=new afe(ZO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,s)}af.trace(n),t.respond(cfe(n))}}a(Sfe,"handleRequest");async function Tfe(){try{return{status:ZO.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,message:await dfe.describeAll()}}catch(e){return af.error(e),{status:ZO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,message:e.message}}}a(Tfe,"getRemoteDescribeAll");Efe||hfe.on("message",async e=>{let{type:t}=e;t===ffe.ITC_EVENT_TYPES.SHUTDOWN&&L$.closeConnection()})});var gfe=M$();(async()=>{try{await gfe()}catch(e){console.error("Error launching Nats reply service."),console.error(e)}})();
|
|
132
|
+
`))}},25).unref()}o.close?.(()=>{if(At.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&rd()==0)try{uY(fY(At.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,YS),o.cantCleanupProperly||en.warn("Had to forcefully exit the thread",YS),process.exit(0)},5e3).unref()})}if(EY||process.env.DEV_MODE)try{require("inspector").close()}catch(i){en.info("Could not close debugger",i)}}}).ref();let e;SE&&!yme&&(e=mY()),Promise.resolve(e).then(()=>{if(rd()===0)try{Ame(bI)}catch(t){console.error("Error displaying start-up log",t)}TE?.postMessage({type:er.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(hY,"startServers");function mY(){let e=[];for(let t in xi){let r=xi[t];if(t.includes?.("/")&&rd()==0){hme(t)&&uY(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),en.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=At.get(er.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=rd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?SE?n={fd:SE(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:SE?n={fd:SE(+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}),en.trace("Listening on port "+t,YS)}).on("error",c)}))}return Promise.all(e)}a(mY,"listenOnPorts");!RI&&!lme.noServerStart&&hY();function NI(e,t,r){let n=e?.read?e:new ume({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):(en.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(NI,"deliverSocket");var cY=new Map;function Ime(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=cY.get(s),r){case"connection":i=NI(void 0,t),cY.set(s,i),i.write=(c,l,d)=>(TE.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),d&&d(),!0),i.end=(c,l,d)=>(TE.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),d&&d(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),TE.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(Ime,"proxyRequest");var{getComponentName:WS}=(Mf(),oe(Lf));function II(e,t,r=!0){t||(t=At.get(er.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",lY),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",lY)}a(II,"registerServer");function pY(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=[],At.get(er.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:At.get(er.CONFIG_PARAMS.HTTP_PORT),secure:At.get(er.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),At.get(er.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:At.get(er.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&At.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:fY(At.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(pY,"getPorts");function wI(e,t){let r=[];for(let{port:n,secure:s}of pY(t))r.push(SY(n,s,t?.isOperationsServer)),typeof e=="function"?yI[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,II(e,n,!1)),KS[n]=OI(yI,n),Ome=OI(Nme,n);return r}a(wI,"httpServer");function jS(e,t){let r=bI.get(e)??[];bI.set(e,[...r,t])}a(jS,"setPortServerMap");function SY(e,t,r){if(jS(e,{protocol_name:t?"HTTPS":"HTTP",name:WS()}),!VS[e]){let n=r?"operationsApi_network":"http",s={noDelay:!0,keepAliveTimeout:At.get(n+"_keepAliveTimeout"),headersTimeout:At.get(n+"_headersTimeout"),requestTimeout:At.get(n+"_timeout"),highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600},i=At.get(n+"_mtls"),o=At.get(n+"_mtls_required");t&&Object.assign(s,{allowHTTP1:!0,rejectUnauthorized:!!o,requestCert:!!(i||r),ticketKeys:Sme(),maxHeaderSize:At.get(er.CONFIG_PARAMS.HTTP_MAXHEADERSIZE),SNICallback:_Y(r?"operations-api":"server",i),ALPNCallback:function(d){return d.protocols.includes("harperdb-replication")&&(this.isReplicationConnection=!0),"http/1.1"},ALPNProtocols:null});let c=Rme(),l=VS[e]=(t?Eme:_me)(s,async(d,u)=>{try{let E=performance.now(),f=new dY(d,u);r&&(f.isOperationsServer=!0);let h=await KS[e](f);if(!h){if(f._nodeResponse.statusCode)return;h=TY(f)}if(h.headers?.set||(h.headers=new AI(h.headers)),c?h.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):h.headers?.set?.("Server","HarperDB"),h.status===-1){for(let x of h.headers||[])u.setHeader(x[0],x[1]);return d.baseRequest=f,u.baseResponse=h,VS[e].emit("unhandled",d,u)}let T=h.status||200,S=performance.now(),R=S-E,p=h.body,y;if(!h.handlesHeaders){let x=h.headers||new AI;p?p.length>=0&&(typeof p=="string"?x.set("Content-Length",Buffer.byteLength(p)):x.set("Content-Length",p.length),y=!0):(x.set("Content-Length","0"),y=!0);let W=`hdb;dur=${R.toFixed(2)}`;h.wasCacheMiss&&(W+=", miss"),gme(x,"Server-Timing",W,!0),u.writeHead(T,x&&(x[Symbol.iterator]?Array.from(x):x)),y&&u.end(p)}let O=f.handlerPath,B=f.method;if(mE(R,"duration",O,B,h.wasCacheMiss==null?void 0:h.wasCacheMiss?"cache-miss":"cache-hit"),aY(T<400,"success",O,B),aY(1,"response_"+T,O,B),!y)if(p?.pipe){p.pipe(u),p.destroy&&u.on("close",()=>{p.destroy()});let x=0;p.on("data",W=>{x+=W.length}),p.on("end",()=>{mE(performance.now()-S,"transfer",O,B),mE(x,"bytes-sent",O,B)})}else p?.then?p.then(x=>{u.end(x)},_):u.end(p)}catch(E){_(E)}function _(E){let f=E.headers;u.writeHead(E.statusCode||500,f&&(f[Symbol.iterator]?Array.from(f):f)),u.end(E.toString()),E.statusCode?E.statusCode===500?en.warn(E):en.info(E):en.error(E)}a(_,"onError")});t&&(l.ports||(l.ports=[]),l.ports.push(e),s.SNICallback.initialize(l),i&&(l.mtlsConfig=i),l.on("secureConnection",d=>{d._parent.startTime&&mE(performance.now()-d._parent.startTime,"tls-handshake",e),mE(d.isSessionReused(),"tls-reused",e)}),l.isSecure=!0),II(l,e)}return VS[e]}a(SY,"getHTTPServer");function OI(e,t){let r=TY;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(OI,"makeCallbackChain");function TY(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new AI}}a(TY,"unhandled");function wme(e,t){wI(e,{requestOnly:!0,...t})}a(wme,"onRequest");function Cme(e,t){let r;if(t.securePort){jS(t.securePort,{protocol_name:"TLS",name:WS()});let n=_Y("server",t.mtls);r=pme({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&&(jS(t.port,{protocol_name:"TCP",name:WS()}),r=dme(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),xi[t.port]=r),r}a(Cme,"onSocket");Object.defineProperty(fme.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.includes("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});function Dme(e,t){let r=[];for(let{port:n,secure:s}of pY(t)){if(jS(n,{protocol_name:s?"WSS":"WS",name:WS()}),!pE[n]){let c;pE[n]=new mme({server:c=SY(n,s,t?.isOperationsServer)}),c._ws=pE[n],r.push(c),pE[n].on("connection",async(l,d)=>{try{let u=new dY(d);u.isWebSocket=!0;let _=KS[n](u),E=d.headers["sec-websocket-protocol"],f=gI[n],h;if(E){for(let T=0;T<f.length;T++){let S=f[T];S.protocol===E&&(h=!0,S.listener(l,u,_))}if(h)return}for(let T=0;T<f.length;T++){let S=f[T];S.protocol||(S.listener(l,u,_),h=!0)}h||l.close(1008,"No handler for protocol")}catch(u){en.warn("Error handling WebSocket connection",u)}}),pE[n].on("error",l=>{console.log("Error in setting up WebSocket server",l)})}let i=t?.subProtocol||"",o=gI[n];o||(o=gI[n]=[]),o.push({listener:e,protocol:i}),KS[n]=OI(yI,n)}return r}a(Dme,"onWebSocket");function lY(e,t){t.writeHead(404),t.end(`Not found
|
|
133
|
+
`)}a(lY,"defaultNotFound")});var oY={};et(oY,{startHTTPThreads:()=>Lme,startSocketServer:()=>UI,updateWorkerIdleness:()=>IY});async function Lme(e=2,t){try{if(t)LI(0,1,!0);else{let{loadRootComponents:r}=zS();if(e===0)return(0,Ds.setMainIsWorker)(!0),await CI().startServers(),Promise.resolve([]);await r()}NY();for(let r=0;r<e;r++)LI(r,e);return Promise.all(OY)}finally{(0,Ds.threadsHaveStarted)()}}function NY(){let e=(0,bY.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),PI=setInterval(()=>{ZS.notify(e)},Pme).unref())}function LI(e,t=1,r){if(DI++,(0,Ds.startWorker)("server/threads/threadServer.js",{name:ad.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(d){d.type===ad.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});OY.push(s),await s,nd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=XS.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=nd.indexOf(n);o>-1&&nd.splice(o,1)}if(a(i,"removeWorker"),sd){let o=sd;sd=[];for(let c of o)yY[c.localPort](null,c)}}}),r){let n=setInterval(()=>{MI?MI=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Ds.shutdownWorkers)(),DI=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function UI(e=0,t){if(typeof e=="string")try{(0,eT.existsSync)(e)&&(0,eT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=Mme:r=Ume(t):r=vI;let n=(0,id.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=yY[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),MI=!0,r(o,(c,l)=>{if(!c){if(gY){let u=o._socket||new id.Socket({handle:o,writable:!0,readable:!0});gY.deliverSocket(u,e,l),u.resume()}else DI>0?(sd.length===0&&setTimeout(()=>{sd.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,sd.push(o)):(console.log("start up a dynamic thread to handle request"),LI(0));gr(!1,"socket-routed");return}c.requests++;let d=o.fd;if(d>=0)c.postMessage({port:e,fd:d,data:l});else{let u=o._socket||new id.Socket({handle:o,writable:!0,readable:!0});Hme(u,c,e)}gr(!0,"socket-routed")})};let s=Kl();ZS.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function vI(e,t){let r,n=0;for(let s of nd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=JS)return JS=i,t(r);n=i}JS=0,t(r)}function Mme(e,t){let r={};e.getpeername(r);let n=r.address,s=od.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);vI(e,o=>{od.set(n,{worker:o,lastUsed:i}),t(o)})}function Ume(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new id.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],d=od.get(l),u=Date.now();if(d&&d.worker.threadId!==-1)return d.lastUsed=u,s(d.worker);vI(n,_=>{od.set(l,{worker:_,lastUsed:u}),s(_,o)})})}a(r,"findByHeaderAffinity")}function IY(){JS=0;for(let e of nd)e.expectedIdle=e.recentELU.idle+vme,e.requests=1;nd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Hme(e,t,r){let n=Bme++;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(),XS.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")),XS.delete(n)),s.event=="destroy"&&(e.destroy(),XS.delete(n))})}var Ds,id,ad,ZS,eT,AY,bY,nd,sd,yY,gY,DI,OY,PI,Pme,MI,JS,RY,od,vme,XS,Bme,TI=De(()=>{Ds=v(it()),id=require("net"),ad=v(M()),ZS=v(V()),eT=require("fs");gi();AY=require("worker_threads"),bY=v(sc()),nd=[],sd=[],yY=[],DI=0,OY=[];AY.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Ds.onMessageFromWorkers)(e=>{e.type===ad.ITC_EVENT_TYPES.RESTART&&PI&&(clearInterval(PI),NY())}));Pme=6e5;a(Lme,"startHTTPThreads");a(NY,"licenseWarning");a(LI,"startHTTPWorker");a(UI,"startSocketServer");JS=0;a(vI,"findMostIdleWorker");RY=36e5,od=new Map;a(Mme,"findByRemoteAddressAffinity");a(Ume,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of od)r.lastUsed+RY<e&&od.delete(t)},RY).unref();vme=1e3;a(IY,"updateWorkerIdleness");(0,Ds.setMonitorListener)(IY);XS=new Map,Bme=1;a(Hme,"proxySocket")});var PY=b((YLe,DY)=>{"use strict";var xme=require("cluster"),al=te();al.initSync();var CY=M(),FLe=require("util"),Do=V(),GLe=require("fs"),kme=require("fastify"),qLe=Kl(),Fme=require("@fastify/cors"),Gme=require("@fastify/compress"),qme=require("@fastify/static"),$me=sN(),Vme=require("path"),{PACKAGE_ROOT:Yme}=M(),Kme=as(),Wme=J(),jme=vn(),Qme=sc(),{server:zme}=($r(),oe($a)),{node_request_key:$Le}=(wS(),oe($N)),{authHandler:Jme,handlePostRequest:Xme,serverErrorHandler:Zme,reqBodyValidationHandler:epe}=NS(),VLe=require("net"),{registerContentHandlers:tpe}=(Uu(),oe(gq)),rpe=6e4,npe=1024*1024*1024,spe="TRUE",{CONFIG_PARAMS:gE}=CY,cd;DY.exports={hdbServer:wY,start:wY};async function wY(e){try{Do.debug("In Fastify server"+process.cwd()),Do.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Do.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=xme.isMaster,await ipe();let t=e.securePort>0;cd=ope(t),await cd.ready(),e||(e={}),e.isOperationsServer=!0;try{zme.http(cd.server,e),cd.server.closeIdleConnections||await cd.listen({port:0,host:"::"})}catch(r){throw cd.close(),Do.error(r),Do.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Do.fatal(t),process.exit(1)}}a(wY,"operationsServer");async function ipe(){Do.trace("Configuring HarperDB process."),Kme.setSchemaDataToGlobal(),await jme.setUsersToGlobal(),await Qme.getLicense()}a(ipe,"setUp");function ope(e){Do.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=ape(e),r=kme(t);r.server.headersTimeout=lpe(),r.setErrorHandler(Zme);let n=cpe();n&&r.register(Fme,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,d){r.server.emit("unhandled",l.raw,d.raw)}),c()}),r.register($me),r.register(Gme),r.register(qme,{root:Vme.join(Yme,"studio/build-local")}),tpe(r);let s=al.get(CY.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Wme.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[epe,Jme],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Xme(i,o)}),r.get("/health",()=>"HarperDB is running."),Do.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(ope,"buildServer");function ape(e){let t=al.get(gE.OPERATIONSAPI_NETWORK_TIMEOUT),r=al.get(gE.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:npe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(ape,"getServerOptions");function cpe(){let e=al.get(gE.OPERATIONSAPI_NETWORK_CORS),t=al.get(gE.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===spe)&&(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(cpe,"getCORSOpts");function lpe(){return al.get(gE.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??rpe}a(lpe,"getHeaderTimeoutConfig")});var GI={};et(GI,{disableNATS:()=>dpe,publishToStream:()=>nT,setNATSReplicator:()=>BI,setPublishToStream:()=>_pe,setSubscription:()=>FI,start:()=>upe});function upe(){RE.default.get(AE.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&Epe()}function dpe(e=!0){BY=e}function _pe(e,t){nT=e,FI=t}function Epe(){if(BY||process.env._DISABLE_NATS)return;let e=mt(),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];BI(s,r,i)}}bc((r,n)=>{BI(r.tableName,r.databaseName,r),n&&xY(r)}),!LY&&(LY=!0)}function BI(e,t,r){if(t==="system"&&hpe.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 Ir{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[je],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[je]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[je],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[je],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[je]})}static defineSchema(i){xY(i)}static subscribe(){let i=new In;return FI(t,e,i),i}static subscribeOnThisThread(i){return i<(RE.default.get(AE.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??fpe)}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 tT(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=HY;return i}a(n,"getNATSTransaction")}function xY(e){let t=RE.default.get(AE.default.CONFIG_PARAMS.CLUSTERING_NODENAME);nT(`${xI.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,kI.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 MY,xI,kI,UY,vY,RE,AE,rT,BY,nT,FI,fpe,HY,LY,hpe,tT,HI,kY=De(()=>{Le();Hs();MY=v(kt()),xI=v(dt()),kI=v(zi());Al();UY=v(rb()),vY=v(nn()),RE=v(te()),AE=v(M()),rT=v(V());a(upe,"start");a(dpe,"disableNATS");nT=MY.publishToStream,FI=UY.setSubscription;a(_pe,"setPublishToStream");fpe=2;a(Epe,"assignReplicationSource");hpe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(BI,"setNATSReplicator");a(xY,"publishSchema");tT=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=RE.default.get(AE.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,d;for(let u of i){let _=u.table,E=u.operation=="put"?"upsert":u.operation;l||(rT.trace(`Sending transaction event ${E}`),d=l={operation:E,schema:s,table:_,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===_&&l.operation===E?(o.push(u.record),c.push(u.id)):d=d.next={operation:E,table:_,id:u.id,record:u.record},u.expiresAt&&(d.expiresAt=u.expiresAt)}l&&n.push(nT(`${xI.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,kI.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(u=>{throw rT.error("An error has occurred trying to replicate transaction",l,u),u.statusCode=504,u}))}return Promise.all(n)}},HI=class extends tT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,vY.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};HY=new HI});async function VY({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await qI.get(e,{returnNonexistent:!0});i=new YI(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await qI.get(e);o&&o.delete()}i=new iT(e,t)}return n&&(n.id=e,n.user={username:t?.username},bE.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function $I(){return sT++,sT>65500&&(sT=1),sT}function VI(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=ea.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 Ct(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var GY,Ua,qY,$Y,FY,qI,bE,sT,iT,YI,YY=De(()=>{Le();B_();GY=v(nn()),Ua=v(V());uc();qY=v(it()),$Y=v(CI());$r();FY=100,qI=Et({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),bE=Et({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,qY.getWorkerIndex)()===0&&(async()=>{await $Y.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of bE.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await st.getUser(r.user.username));try{await VI(r,t,r)}catch{(0,Ua.warn)("Failed to publish will",t)}bE.delete(e.id)}})();a(VY,"getSession");sT=1;a($I,"getNextMessageId");iT=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,d;if(c>-1?(l=s.slice(c),d=s.slice(0,c)):d=s,!d)throw new Error("No topic provided");if(d.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let u=this.subscriptions.find(R=>R.topic===s),_;u?(_=i>0,u.end(),this.subscriptions.splice(this.subscriptions.indexOf(u),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,Ua.trace)("Resuming subscription from",s,"from",o);let f=ea.getMatch(d,"mqtt");if(!f){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(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let R=E.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(E.isCollection=!0,R.indexOf("+")===R.length-1)E.onlyChildren=!0,E.url="/"+R.slice(0,R.length-1);else{let p=R.split("/"),y;for(let x=0;x<p.length;x++)if(p[x].indexOf("+")>-1)if(p[x]==="+")y=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&y)throw new Error("Filters can not be combined");let O=!0;p[p.length-1]==="#"&&(p.length--,O=!1),y&&(n=a(x=>{let W=x.id;if(!Array.isArray(W)||O&&W.length!==p.length)return!1;for(let q=0;q<p.length;q++)if(p[q]!=="+"&&p[q]!==W[q])return!1;return!0},"filter"));let B=p.indexOf("+");E.url="/"+(B>-1?p.slice(0,B):p).concat("").join("/")}}let h=f.path,T=f.Resource,S=await Ct(E,async()=>{let R=this.createContext();R.topic=s,R.retainHandling=i;let p=await T.subscribe(E,R);if(!p)throw new Error(`No subscription was returned from subscribe for topic ${s}`);if(!p[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let y=(async()=>{for await(let O of p)try{let B;if(O.type&&O.type!=="put"&&O.type!=="delete"&&O.type!=="message"&&O.type!=="patch"||n&&!n(O))continue;r?(O.topic=s,B=this.needsAcknowledge(O)):(O.acknowledge?.(),B=$I());let x=O.id;if(Array.isArray(x)&&(x=Xl(x)),x==null&&(x=""),await this.listener(h+"/"+x,O.value,B,t)===!1)break;this.awaitingAcks?.size>FY?await new Promise(q=>setTimeout(q,this.awaitingAcks.size-FY)):await new Promise(setImmediate)}catch(B){(0,Ua.warn)(B)}})();return p});return S.topic=s,S.qos=t.qos,this.subscriptions.push(S),S}resume(){}needsAcknowledge(t){let r=$I();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,t.acknowledge)),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return VI(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();Ct(r,async()=>{try{if(!t){let n=await bE.get(this.sessionId);n?.doesExist()&&await VI(n,n.data,r)}}finally{await bE.delete(this.sessionId)}}).catch(n=>{(0,Ua.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(VI,"publish");YI=class extends iT{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.timestamp):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=$I(),n={topic:t.topic,timestamp:t.timestamp};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ua.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,GY.getNextMonotonicTime)()),(0,Ua.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),qI.put(this.sessionRecord)}}});var WI={};et(WI,{bypassAuth:()=>mpe,start:()=>ppe});function mpe(){zY=!0}function ppe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new QY.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((d,u,_)=>{if(d.protocol==="mqtt"){o.events.emit("connection",d),xr.debug?.("Received WebSocket connection for MQTT from",d._socket.remoteAddress);let{onMessage:E,onClose:f}=WY(d,h=>{d.send(h)},u,Promise.resolve(_).then(()=>u?.user),o);d.on("message",E),d.on("close",f),d.on("error",h=>{xr.info?.("WebSocket error",h)})}},{subProtocol:"mqtt",...n})),(t||s)&&c.push(e.socket(async d=>{let u;if(o.events.emit("connection",d),xr.debug?.(`Received ${d.getCertificate?"SSL":"TCP"} connection for MQTT from ${d.remoteAddress}`),l){if(d.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=d.getPeerCertificate().subject.CN);try{u=await e.getUser(f,null,null),(0,ld.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&aT.notify?.({username:u?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:d.remoteAddress})}catch(h){throw(0,ld.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&aT.error?.({username:f,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:d.remoteAddress}),h}}else xr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",d.remoteAddress)}catch(f){o.events.emit("error",f,d),xr.error?.(f)}else if(l.required)return xr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${d.authorizationError}`),d.end()}!u&&zY&&d.remoteAddress.includes("127.0.0.1")&&(u=await(0,jY.getSuperUser)(),xr.debug?.("Auto-authorizing local connection",u?.username));let{onMessage:_,onClose:E}=WY(d,f=>d.write(f),null,u,o);d.on("data",_),d.on("close",E),d.on("error",f=>{xr.info?.("Socket error",f)})},{port:t,securePort:s,mtls:l})),c}function WY(e,t,r,n,s){KY||(KY=!0,N_(_=>{oT>0&&_.push({metric:"mqtt-connections",connections:oT,byThread:!0})}));let i;oT++;let o,c={protocolVersion:4},l=(0,cT.parser)({protocolVersion:5});function d(_){l.parse(_)}a(d,"onMessage");function u(){oT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),kn(!1,"connection","mqtt","disconnect"),xr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(u,"onClose"),l.on("packet",async _=>{n?.then&&(n=await n),o?.then&&await o;let E=_.topic,f=E?.indexOf("/",1),h=f>0?E.slice(0,f):E;gr(_.length,"bytes-received",h,S(_),"mqtt");try{switch(o?.receivedPacket?.(),_.cmd){case"connect":if(c.protocolVersion=_.protocolVersion,_.username)try{n=await st.getUser(_.username,_.password.toString(),r),(0,ld.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&aT.notify?.({username:n?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(q){return(0,ld.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&aT.error?.({username:_.username,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",_,e,q),kn(!1,"connection","mqtt","connect"),T({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",_,e),kn(!1,"connection","mqtt","connect"),T({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(_,n),_.will){let q=e.deserialize||(e.deserialize=Vc(r?.headers.get?.("content-type")));_.will.data=_.will.payload?.length>0?q(_.will.payload):void 0,delete _.will.payload}o=VY({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(q){return xr.error?.(q),s.events.emit("auth-failed",_,e,q),kn(!1,"connection","mqtt","connect"),T({cmd:"connack",reasonCode:q.code||5,returnCode:q.code||128})}s.events.emit("connected",o,e),kn(!0,"connection","mqtt","connect"),T({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((q,z,_e,X)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",q);let ue=q.indexOf("/",1),j=ue>0?q.slice(0,ue):q;T({cmd:"publish",topic:q,payload:R(z),messageId:_e||Math.floor(Math.random()*1e8),qos:X.qos},j);let ie=e._socket??e;return ie.writableNeedDrain?new Promise(ye=>ie.once("drain",ye)):!ie.closed}catch(ue){return xr.error?.(ue),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let p=[];for(let q of _.subscriptions){let z;try{z=(await o.addSubscription(q,q.qos>=1)).qos||0}catch(_e){s.events.emit("error",_e,e,q,o),xr.error?.(_e),z=c.protocolVersion<5?128:_e.statusCode===403?135:_e.statusCode===404?143:128}p.push(z)}await o.committed,T({cmd:"suback",granted:p,messageId:_.messageId});break;case"unsubscribe":{let q=[];for(let z of _.unsubscriptions)q.push(o.removeSubscription(z)?0:17);T({cmd:"unsuback",granted:q,messageId:_.messageId});break}case"pubrel":T({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let y=_.qos===2?"pubrec":"puback",O=e.deserialize||(e.deserialize=Vc(r?.headers.get?.("content-type"))),x=(_.payload?.length||0)>0?O(_.payload):void 0,W;try{W=await o.publish(_,x)}catch(q){s.events.emit("error",q,e,_,o),xr.warn?.(q),_.qos>0&&T({cmd:y,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&T({cmd:y,messageId:_.messageId,reasonCode:W===!1?144:0},_.topic);break;case"pubrec":T({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":T({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),kn(!0,"connection","mqtt","disconnect"),xr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(p){s.events.emit("error",p,e,_,o),xr.error?.(p),T({cmd:"disconnect"})}function T(p,y){let O=(0,cT.generate)(p,c);t(O),gr(O.length,"bytes-sent",y,S(p),"mqtt")}a(T,"sendPacket");function S(p){return p.qos>0?p.cmd+",qos="+p.qos:p.cmd}a(S,"packetMethodName");function R(p){return kc(p,r)}a(R,"serialize")}),l.on("error",_=>{xr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:d,onClose:u}}var cT,jY,ld,kr,KI,QY,aT,xr,zY,KY,oT,JY=De(()=>{cT=require("mqtt-packet");YY();jY=v(vn());Uu();gi();$r();ld=v(te()),kr=v(M()),KI=v(zl()),QY=require("events"),aT=(0,KI.loggerWithTag)("auth-event"),xr=(0,KI.loggerWithTag)("mqtt"),zY=(0,ld.get)(kr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(mpe,"bypassAuth");a(ppe,"start");oT=0;a(WY,"onSocket")});var Lf={};et(Lf,{component_errors:()=>dd,getComponentName:()=>Ape,loadComponent:()=>uT,loadComponentDirectories:()=>iK,setErrorReporter:()=>Rpe});function iK(e,t){t&&(QI=t),e&&(zI=e);let r=[];if((0,Nt.existsSync)(jI)){let s=(0,Nt.readdirSync)(jI,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Ut.join)(jI,o);r.push(uT(c,QI,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(uT(n,QI,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{sK=!0})}function Rpe(e){yE=e}async function uT(e,t,r,n,s,i){let o=(0,Nt.realpathSync)(e);if(!ZY.has(o)){ZY.set(o,!0),s&&(zI=s);try{let c;n&&(dd=new Map);let l=(0,Ut.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Nt.existsSync)(l)?c=n?(0,dT.getConfigObj)():(0,eK.parseDocument)((0,Nt.readFileSync)(l,"utf8")).toJSON():c=JI;let d=(0,Ut.join)(e,"node_modules","harperdb");try{cl.isMainThread&&(n||(0,Nt.existsSync)(d)&&(0,Nt.realpathSync)(fd.PACKAGE_ROOT)!==(0,Nt.realpathSync)(d))&&((0,Nt.rmSync)(d,{recursive:!0,force:!0}),(0,Nt.existsSync)((0,Ut.join)(e,"node_modules"))||(0,Nt.mkdirSync)((0,Ut.join)(e,"node_modules")),(0,Nt.symlinkSync)(fd.PACKAGE_ROOT,d,"dir"))}catch(E){ud.default.error("Error symlinking harperdb module",E)}let u=lT,_=n;for(let E in c){lT=E;let f=c[E];if(dd.set(n?E:(0,Ut.basename)(e),!1),!f)continue;let h,T=f.package;try{if(T){let O=e,B;for(;!(0,Nt.existsSync)(B=(0,Ut.join)(O,"node_modules",E));)if(O=(0,Ut.dirname)(O),O.length<(0,nK.getHdbBasePath)().length){B=null;break}if(B)h=await uT(B,t,r,!1),_=!0;else throw new Error(`Unable to find package ${E}:${T}`)}else h=gpe[E];if(!h)continue;let S=a(O=>(O.origin=r,Et(O)),"ensureTable"),R=f.network||(f.port||f.securePort)&&f,p=R?.securePort||R?.https&&R.port,y=!R?.https&&R?.port;if(cl.isMainThread&&(h=await h.startOnMainThread?.({server:st,ensureTable:S,port:y,securePort:p,resources:t,...f})||h,n&&R))for(let O of[y,p])try{if(+O&&!XY.includes(O)){let B=XI.get(fd.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);B&&ud.default.warn("Session affinity is not recommended and may cause memory leaks"),(B||!IS)&&(XY.push(O),UI(O,B))}}catch(B){console.error("Error listening on socket",O,B,E)}if(t.isWorker&&(h=await h.start?.({server:st,ensureTable:S,port:y,securePort:p,resources:t,...f})||h),zI.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&f.files!=null){if(f.files.includes(".."))throw(0,rK.handleHDBError)("Can not reference parent directories");let O=(0,Ut.join)(e,f.files).replace(/\\/g,"/"),B=O.indexOf("/*");if(B>-1&&f.files!==JI[E]?.files&&!(0,Nt.existsSync)(O.slice(0,B)))throw new Error(`The path '${O.slice(0,B)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let x=(0,Ut.basename)(e),W=f.path||"/";W=W.startsWith("/")?W:W.startsWith("./")?"/"+x+W.slice(2):W==="."?"/"+x:"/"+x+"/"+W;let q,z,_e;if(f.root){let ue=f.root;ue.startsWith("/")&&(ue=ue.slice(1)),ue.endsWith("/")&&(ue=ue.slice(0,-1)),ue+="/",z=(0,Ut.join)(e,ue)}else(_e=O.indexOf("/*"))>-1&&(z=O.slice(0,_e+1),q=(0,Ut.relative)(e,z));let X=!1;if(cl.isMainThread&&h.setupDirectory&&(X=await h.setupDirectory?.(W,z,t)),t.isWorker&&h.handleDirectory&&(X=await h.handleDirectory?.(W,z,t)),X)continue;for(let ue of await(0,tK.default)(O,{onlyFiles:!1,objectMode:!0})){let{path:j,dirent:ie}=ue;_=!0;let ye=(0,Ut.relative)(e,j).replace(/\\/g,"/");if(q)if(ye.startsWith(q))ye=ye.slice(q.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${ye}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ie=W+(W.endsWith("/")?"":"/")+ye;try{if(ie.isFile()){let Me=await Tpe(j);cl.isMainThread&&await h.setupFile?.(Me,Ie,j,t),t.isWorker&&await h.handleFile?.(Me,Ie,j,t)}else cl.isMainThread&&await h.setupDirectory?.(Ie,j,t),t.isWorker&&await h.handleDirectory?.(Ie,j,t)}catch(Me){Me.message=`Could not load ${ie.isFile()?"file":"directory"} '${j}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${Me.message}`,yE?.(Me),((0,_d.getWorkerIndex)()===0?console:ud.default).error(Me),t.set(f.path||"/",new Zo(Me)),dd.set(n?E:(0,Ut.basename)(e),Me.message)}}}}catch(S){S.message=`Could not load component '${E}' for application '${(0,Ut.basename)(e)}' due to: ${S.message}`,yE?.(S),((0,_d.getWorkerIndex)()===0?console:ud.default).error(S),t.set(f.path||"/",new Zo(S),null,!0),dd.set(n?E:(0,Ut.basename)(e),S.message)}}if(lT=u,cl.isMainThread&&!sK&&i&&(0,_d.watchDir)(e,async()=>iK()),c.extensionModule)return await _h((0,Ut.join)(e,c.extensionModule));if(!_&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;yE?.(new Error(E)),((0,_d.getWorkerIndex)()===0?console:ud.default).error(E),dd.set((0,Ut.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,yE?.(c),t.set("",new Zo(c))}}}var Nt,Ut,cl,eK,XI,fd,tK,_d,ud,rK,nK,Spe,dT,Tpe,jI,zI,sK,QI,dd,gpe,JI,XY,ZY,yE,lT,Ape,Mf=De(()=>{Nt=require("fs"),Ut=require("path"),cl=require("worker_threads"),eK=require("yaml"),XI=v(te()),fd=v(M());rD();oD();aD();vq();wV();UV();tK=v(require("fast-glob")),_d=v(it()),ud=v(V());Ag();$r();rK=v(fe());Le();TI();nK=v(te()),Spe=v(PY());vp();kY();ls();JY();dT=v(wt());wS();hb();({readFile:Tpe}=Nt.promises),jI=(0,dT.resolvePath)(XI.get(fd.CONFIG_PARAMS.COMPONENTSROOT)),zI=new Map,dd=new Map;a(iK,"loadComponentDirectories");gpe={REST:oS,rest:oS,graphqlSchema:Rg,jsResource:yg,fastifyRoutes:xN,login:Ng,static:kN,operationsApi:Spe,customFunctions:{},http:{},clustering:GI,replication:sa,authentication:If,mqtt:WI},JI={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(JI,"static",{value:{files:"web/**"}});XY=[],ZY=new Map;a(Rpe,"setErrorReporter");Ape=a(()=>lT,"getComponentName");a(uT,"loadComponent")});var zS=b((TMe,aK)=>{var{isMainThread:oK}=require("worker_threads"),{getTables:bpe,getDatabases:pMe,table:SMe}=(Le(),oe(lt)),{loadComponentDirectories:ype,loadComponent:Ope}=(Mf(),oe(Lf)),{resetResources:Npe}=(B_(),oe(rB)),Ipe=RO(),wpe=wt(),{dirname:Cpe}=require("path"),{getConnection:Dpe}=kt(),Ppe=te(),{CONFIG_PARAMS:Lpe}=M(),{loadCertificates:Mpe}=js(),ZI=new Map;async function Upe(e=!1){!oK&&Ppe.get(Lpe.CLUSTERING_ENABLED)&&Dpe();try{oK&&await Ipe()}catch(n){console.error(n)}let t=Npe();bpe(),t.isWorker=e,await Mpe(),await Ope(Cpe(wpe.getConfigFilePath()),t,"hdb",!0,ZI),await ype(ZI,t);let r=[];for(let[n]of ZI)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(Upe,"loadRootComponents");aK.exports.loadRootComponents=Upe});var it=b((RMe,ri)=>{"use strict";var{Worker:vpe,MessageChannel:Bpe,parentPort:ki,isMainThread:sw,threadId:Hpe,workerData:Fi}=require("worker_threads"),{PACKAGE_ROOT:xpe}=M(),{join:dK,isAbsolute:kpe,extname:Fpe}=require("path"),{server:_K}=($r(),oe($a)),{watch:Gpe,readdir:qpe}=require("fs/promises"),{totalmem:cK}=require("os"),OE=M(),fK=te(),Gi=V(),{randomBytes:$pe}=require("crypto"),{_assignPackageExport:Vpe}=Vi(),Ype=M(),lK=1024*1024,va=[],Ps=[],Kpe=50,iw=1e4,Wpe="restart",EK="request_thread_info",hK="resource_report",mK="thread_info",pK="added-port",jpe="ack",ew;Vpe("threads",Ps);ri.exports={startWorker:tw,restartWorkers:aw,shutdownWorkers:Zpe,workers:va,setMonitorListener:aSe,onMessageFromWorkers:eSe,onMessageByType:yK,broadcast:rSe,broadcastWithAcknowledgement:sSe,setChildListenerByType:Xpe,getWorkerIndex:SK,getWorkerCount:TK,getTicketKeys:RK,setMainIsWorker:zpe,setTerminateTimeout:Qpe,restartNumber:Fi?.restartNumber||1};Ps.onMessageByType=yK;Ps.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Ps.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};ri.exports.whenThreadsStarted=new Promise(e=>{ri.exports.threadsHaveStarted=e});var ow;function Qpe(e){iw=e}a(Qpe,"setTerminateTimeout");function SK(){return Fi?Fi.workerIndex:ow?0:void 0}a(SK,"getWorkerIndex");function TK(){return Fi?Fi.workerCount:ow?1:void 0}a(TK,"getWorkerCount");function zpe(e){ow=e,ri.exports.threadsHaveStarted()}a(zpe,"setMainIsWorker");var gK=1,_T;function RK(){return _T||(_T=sw?$pe(48):Fi.ticketKeys,_T)}a(RK,"getTicketKeys");Object.defineProperty(_K,"workerIndex",{get(){return SK()}});Object.defineProperty(_K,"workerCount",{get(){return TK()}});var AK={[EK](e,t){iSe(t)},[hK](e,t){oSe(t,e)}};function tw(e,t={}){let r=process.constrainedMemory?.()||cK();r=Math.min(r,cK(),2e4*lK);let n=fK.get(OE.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/lK/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Ps){let d=new Bpe;d.existingPort=l,i.push(d),o.push(d.port2)}Fpe(e)||(e+=".js");let c=new vpe(kpe(e)?e:dK(xpe,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:gK=t.threadCount,name:t.name,restartNumber:ri.exports.restartNumber,ticketKeys:RK()},transferList:o,...t});for(let{port1:l,existingPort:d}of i)d.postMessage({type:pK,port:l,threadId:c.threadId},[l]);return ET(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>tw(e,t),c.on("error",l=>{Gi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{va.splice(va.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<Kpe?(t.unexpectedRestarts=c.unexpectedRestarts+1,tw(e,t)):Gi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{AK[l.type]?.(l,c)}),va.push(c),lSe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(tw,"startWorker");var Jpe=[OE.THREAD_TYPES.HTTP];async function aw(e=null,t=Math.max(gK>3,1),r=!0){if(sw){if(r){let{loadRootComponents:o}=zS();await o()}ri.exports.restartNumber++,t<1&&(t=t*va.length);let n=[],s=[];for(let o of va.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Gi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:ri.exports.restartNumber,type:OE.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=Jpe.indexOf(o.name)>-1,l=new Promise(d=>{let u=setTimeout(()=>{Gi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},iw*2).unref();o.on("exit",()=>{clearTimeout(u),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),d()})});if(n.push(l),c&&r){let d=o.startCopy(),u=new Promise(_=>{let E=a(f=>{f.type===Ype.ITC_EVENT_TYPES.CHILD_STARTED&&(Gi.trace("Worker has started",d.threadId),_(),s.splice(s.indexOf(u)),d.off("message",E))},"startListener");Gi.trace("Waiting for worker to start",d.threadId),d.on("message",E)});s.push(u),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}=Lu();r&&(e==="http"||!e)&&fK.get(OE.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else ki.postMessage({type:Wpe,workerType:e})}a(aw,"restartWorkers");function Xpe(e,t){AK[e]=t}a(Xpe,"setChildListenerByType");function Zpe(e){return aw(e,1/0,!1)}a(Zpe,"shutdownWorkers");var bK=[];function eSe(e){bK.push(e)}a(eSe,"onMessageFromWorkers");var rw=new Map;function yK(e,t){let r=rw.get(e);r||rw.set(e,r=[]),r.push(t)}a(yK,"onMessageByType");var tSe=10;async function rSe(e,t){let r=0;for(let n of Ps)try{n.postMessage(e),r++>tSe&&(r=0,await new Promise(setImmediate))}catch(s){Gi.error("Unable to send message to worker",s)}t&&NK(e,null)}a(rSe,"broadcast");var fT=new Map,nSe=1;function sSe(e){return new Promise(t=>{let r=0;for(let n of Ps)try{let s=nSe++,i=a(()=>{fT.delete(s),--r===0&&t(),n!==ki&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,fT.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of fT)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Gi.error("Unable to send message to worker",s)}r===0&&t()})}a(sSe,"broadcastWithAcknowledgement");function iSe(e){e.postMessage({type:mK,workers:OK()})}a(iSe,"sendThreadInfo");function OK(){let e=Date.now();return va.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(OK,"getChildWorkerInfo");function oSe(e,t){e.resources=t,e.resources.updated=Date.now()}a(oSe,"recordResourceReport");var nw;function aSe(e){nw=e}a(aSe,"setMonitorListener");var cSe=1e3,uK=!1;function lSe(){uK||(uK=!0,setInterval(()=>{for(let e of va){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}nw&&nw()},cSe).unref())}a(lSe,"startMonitoring");var uSe=1e3;if(ki&&Fi?.addPorts){ET(ki);for(let e=0,t=Fi.addPorts.length;e<t;e++){let r=Fi.addPorts[e];r.threadId=Fi.addThreadIds[e],ET(r)}setInterval(()=>{let e=process.memoryUsage();ki.postMessage({type:hK,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},uSe).unref(),ew=a(()=>new Promise((e,t)=>{ki.on("message",r),ki.postMessage({type:EK});function r(n){n.type===mK&&(ki.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else ew=OK;ri.exports.getThreadInfo=ew;function ET(e,t){Ps.push(e),e.on("message",r=>{if(r.type===pK)r.port.threadId=r.threadId,ET(r.port);else if(r.type===jpe){let n=fT.get(r.id);n&&n()}else NK(r,e)}).on("close",()=>{Ps.splice(Ps.indexOf(e),1)}).on("exit",()=>{Ps.splice(Ps.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(ET,"addPort");function NK(e,t){for(let n of bK)n(e,t);let r=rw.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Gi.error(s)}}a(NK,"notifyMessageListeners");if(sw){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await qpe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(dK(s,o.name));try{for await(let{filename:o}of Gpe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await aw(),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");ri.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else ki.on("message",async e=>{let{type:t}=e;t===OE.ITC_EVENT_TYPES.SHUTDOWN&&(ri.exports.restartNumber=e.restartNumber,ki.unref(),setTimeout(()=>{Gi.warn("Thread did not voluntarily terminate",Hpe),process.exit(0)},iw).unref())})});var cv={};et(cv,{AUDIT_STORE_OPTIONS:()=>Rf,Decoder:()=>uu,HAS_CURRENT_RESIDENCY_ID:()=>Ka,HAS_EXPIRATION_EXTENDED_TYPE:()=>Wd,HAS_ORIGINATING_OPERATION:()=>Kd,HAS_PREVIOUS_RESIDENCY_ID:()=>Wa,REMOTE_SEQUENCE_UPDATE:()=>km,createAuditEntry:()=>yl,getLastRemoved:()=>xb,openAuditStore:()=>TT,readAuditEntry:()=>Ht,setAuditRetention:()=>_Se,transactionKeyEncoder:()=>BK});function TT(e){let t=e.auditStore=e.openDB(cw.AUDIT_STORE_NAME,{create:!1,...Rf});t||(t=e.auditStore=e.openDB(cw.AUDIT_STORE_NAME,Rf),wK(t,1)),t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=hT){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:d,value:u}of t.getRange({start:1,snapshot:!1,end:Date.now()-lw})){if((u[0]&15)===uw){let _=Ht(u),E=_.tableId;r[E]?.(_.recordId)}if(c=t.remove(d),l=d,await new Promise(setImmediate),++o>=dSe){i=10;break}}await c}finally{o===0?i=Math.min(i<<1,lw/10):wK(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,IE.getWorkerIndex)()===(0,IE.getWorkerCount)()-1&&s(hT),(0,IE.getWorkerIndex)()===0&&!IK)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(IK=!0,ST.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 wK(e,t){dw[0]=t,e.put(Symbol.for("last-removed"),HK)}function xb(e){let t=e.get(Symbol.for("last-removed"));if(t)return HK.set(t),dw[0]}function _Se(e,t=hT){lw=e,hT=t}function yl(e,t,r,n,s,i,o,c,l,d,u,_,E){let f=xK[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?Ba.setFloat64(0,n):Ls.set($g),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}R(s),R(t),S(r),Ba.setFloat64(h,e),h+=8,l&Ka&&R(d),l&Wa&&R(u),l&Wd&&(Ba.setFloat64(h,_),h+=8),l&Kd&&R(kK[E]),i?S(i):Ls[h++]=0,l?Ba.setUint16(n?8:0,f|l|32768):Ls[n?8:0]=f;let T=Ls.subarray(0,h);if(c)return Buffer.concat([T,c]);return T;function S(p){let y=h;h+=1,h=(0,ll.writeKey)(p,Ls,h);let O=h-y-1;O>127?O>16383?(ST.error("Key or username was too large for audit entry",p),h=y+1,Ls[y]=0):(Ls.copyWithin(y+2,y+1,h),Ba.setUint16(y,O|32768),h++):Ls[y]=O}function R(p){p<128?Ls[h++]=p:p<16384?(Ba.setUint16(h,p|32768),h+=2):p<1056964608?(Ba.setUint32(h,p|3221225472),h+=4):(Ls[h]=255,Ba.setUint32(h+1,p),h+=5)}}function Ht(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new uu(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(),d=n.position,u=n.position+=l,_=n.readFloat64(),E,f,h,T;if(i&Ka&&(E=n.readInt()),i&Wa&&(f=n.readInt()),i&Wd&&(h=n.readFloat64()),i&Kd){let p=n.readInt();T=kK[p]}l=n.readInt();let S=n.position,R=n.position+=l;return{type:xK[i&7],tableId:c,nodeId:o,get recordId(){return(0,ll.readKey)(e,d,u)},getBinaryRecordId(){return e.subarray(d,u)},version:_,previousLocalTime:s,get user(){return R>S?(0,ll.readKey)(e,S,R):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(p,y,O){if(i&mT||i&NE&&!y)return p.decoder.decode(e.subarray(n.position,r));if(i&NE&&O)return _w(p.getEntry(this.recordId),O,p)},getBinaryValue(){return i&(mT|NE)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:E,previousResidencyId:f,expiresAt:h,originatingOperation:T}}catch(n){return ST.error("Reading audit entry error",n,e),{}}}var ll,pT,cw,UK,IE,vK,ST,Ls,Ba,BK,Rf,lw,dSe,dw,HK,hT,IK,mT,NE,CK,uw,DK,PK,LK,MK,km,Ka,Wa,Kd,Wd,xK,kK,uu,Ki=De(()=>{ll=require("ordered-binary"),pT=v(te()),cw=v(Bt()),UK=v(M()),IE=v(it()),vK=v(J());Ol();ST=v(V());gT();(0,pT.initSync)();Ls=Buffer.alloc(1024),Ba=new DataView(Ls.buffer,Ls.byteOffset,1024),BK={writeKey(e,t,r){return e===Yd?(t.set(Yd,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,ll.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,ll.readKey)(e,t,r)}},Rf={encoding:"binary",keyEncoder:BK},lw=(0,vK.convertToMS)((0,pT.get)(UK.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,dSe=1e3,dw=new Float64Array(1),HK=new Uint8Array(dw.buffer),hT=1e4,IK=!1;a(TT,"openAuditStore");a(wK,"updateLastRemoved");a(xb,"getLastRemoved");a(_Se,"setAuditRetention");mT=16,NE=32,CK=1,uw=2,DK=3,PK=4,LK=5,MK=6,km=11,Ka=512,Wa=1024,Kd=2048,Wd=4096,xK={put:CK|mT,[CK]:"put",delete:uw,[uw]:"delete",message:DK|mT,[DK]:"message",invalidate:PK|NE,[PK]:"invalidate",patch:LK|NE,[LK]:"patch",relocate:MK,[MK]:"relocate"},kK={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(yl,"createAuditEntry");a(Ht,"readAuditEntry");uu=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;try{t=this.getUint8(this.position++)}catch(r){throw r}return t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch{debugger}}}});var fw={};et(fw,{add:()=>RT,applyReverse:()=>FK,getRecordAtTime:()=>_w,rebuildUpdateBefore:()=>AT});function RT(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 AT(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,RT(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function FK(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=fSe[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=GK}}function _w(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),d=Ht(l);switch(d.type){case"put":s=d.getValue(r);break;case"patch":FK(s,d.getValue(r));break;case"delete":s=null}i=d.previousLocalTime}let o={},c=0;for(let l in s)s[l]===GK&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),d=Ht(l),u;switch(d.type){case"put":u=d.getValue(r);break;case"patch":u=d.getValue(r);break}for(let _ in u)o[_]&&(s[_]=u[_],o[_]=!1,c--);i=d.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var fSe,GK,gT=De(()=>{Ki();a(RT,"add");RT.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)};fSe={add:RT};a(AT,"rebuildUpdateBefore");a(FK,"applyReverse");GK={};a(_w,"getRecordAtTime")});function Qn(e){return e[ur]||(e[ur]=Object.create(null))}function IT(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,d;if(o.resolve)d={get(){return o.resolve(this,this[xe])},set(u){return o.set(this,u)},configurable:!0};else{switch(o.type){case"String":l=a(function(u){if(!(typeof u=="string"||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"ID":l=a(function(u){if(!(typeof u=="string"||u?.length>0&&u.every?.(_=>typeof _=="string")||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Float":case"Number":l=a(function(u){let _=u?.__op__?u.value:u;if(!(typeof _=="number"||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a number, attempt to assign ${_}`);Qn(this)[c]=u},"set");break;case"Int":l=a(function(u){let _=u?.__op__?u.value:u;if(!(_>>0===_||u==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),u?.__op__?u.value=_:u=_;else throw new Ms.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Long":l=a(function(u){let _=u?.__op__?u.value:u;if(!(Math.round(_)===u&&Math.abs(_)<=9007199254740992||u==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),u?.__op__?u.value=_:u=_;else throw new Ms.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"BigInt":l=a(function(u){let _=u?.__op__?u.value:u;if(!(typeof _=="bigint"||u==null&&o.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),u?.__op__?u.value=_:u=_;else throw new Ms.ClientError(`${c} must be a number, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Boolean":l=a(function(u){if(!(typeof u=="boolean"||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a boolean, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Date":l=a(function(u){if(!(u instanceof Date||u==null&&o.nullable!==!1))if(typeof u=="string"||typeof u=="number")u=new Date(u);else throw new Ms.ClientError(`${c} must be a Date, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Bytes":l=a(function(u){if(!(u instanceof Uint8Array||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Any":case void 0:l=a(function(u){Qn(this)[c]=u},"set");break;default:l=a(function(u){if(!(typeof u=="object"||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be an object, attempt to assign ${u}`);Qn(this)[c]=u},"set")}d={get(){let u=this[ur];if(u&&c in u){let E=u[c];if(E?.__op__){let f=this[ve]?.[c];return E.update(f)}return E}let _=this[ve]?.[c];if(_&&typeof _=="object"){let E=$K(_,o);if(E)return u||(u=this[ur]=Object.create(null)),u[c]=E}return _},set:l,enumerable:!0,configurable:!0}}d.get.isAttribute=!0,n[c]=d,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,d)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let l=this[ur];return l?.[o]!==void 0?l[o]:this[ve]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new Ms.ClientError("Can not add a property to a sealed table schema");Qn(this)[o]=c}),i("deleteProperty",function(o){Qn(this)[o]=void 0}),i("toJSON",function(){let o=this[ur],c;for(let d in o){c||(c={...this[ve]});let u=o[d];if(u?.__op__){let _=c[d];u=u.update(_)}c[d]=u}return Object.keys(this).length>0&&(c||(c={...this[ve]}),Object.assign(c,this)),c||this[ve]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function $K(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=s}},IT(r,t)),new r(e)):new bT(e);case Array:let n=new OT(e.length);n[ve]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=$K(o,t?.elements)),n[s]=o}return n;default:return e}}function am(e){let t=e[ur],r;for(let s in t){r||(r={...e[ve]});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=am(i);r[s]=i}return Object.keys(e).length>0&&(r||(r={...e[ve]}),Object.assign(r,e)),r||e[ve]}function dl(e,t=e[ur]){let r;if(qK.call(e,ve)&&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=dl(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[ve]});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=fw[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=dl(s);r[n]=s}return r?Object.freeze(r):qK.call(e,ve)?e[ve]:e}function yT(e){let t=e[ve];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[ul]||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?.[ve]===s){if(yT(i))return!0}else return!0}}else{let r=e[ur];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[ve]===i){if(yT(s))return!0}else return!0}else return!0}}return!1}var Ms,ur,bT,qK,ul,OT,NT,cm=De(()=>{Hs();Ms=v(fe());gT();ur=Symbol("own-data");a(Qn,"getChanges");a(IT,"assignTrackedAccessors");a($K,"trackObject");bT=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=t}};IT(bT,{});a(am,"collapseData");qK=Object.prototype.hasOwnProperty;a(dl,"updateAndFreeze");a(yT,"hasChanges");ul=Symbol.for("has-array-changes"),OT=class extends Array{static{a(this,"TrackedArray")}[ul];constructor(t){super(t)}splice(...t){return this[ul]=!0,super.splice(...t)}push(...t){return this[ul]=!0,super.push(...t)}pop(){return this[ul]=!0,super.pop()}unshift(...t){return this[ul]=!0,super.unshift(...t)}shift(){return this[ul]=!0,super.shift()}};OT.prototype.constructor=Array;NT=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var EA={};et(EA,{CONTEXT:()=>xe,ID_PROPERTY:()=>je,IS_COLLECTION:()=>ni,MultiPartId:()=>CT,RECORD_PROPERTY:()=>ve,Resource:()=>Ir,snake_case:()=>hSe,transformForSelect:()=>DT});function hSe(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function VK(e,t){if(_l=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(_l=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new CT;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){_l=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return _l=!0,null;e[e.length-1]==="/"&&(_l=!0)}return t.coerceId(decodeURIComponent(e))}function zn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,d,u;if(r?(o?(u=i,o=o[xe]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(u=s,c=u[this.primaryKey]??null,o=i[xe]||i):u=i:(u=s,s=void 0,c=u[je]??u[this.primaryKey]),c===null&&(d=!0)):i?o=i[xe]||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"){let f=c.indexOf("?");if(f>-1){let T=this.parseQuery(c.slice(f+1));l?l=Object.assign(T,l):l=T,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),d=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],d=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,d=!1)))}c===void 0&&(c=s.id??null,c==null&&(d=!0))}else c=s,l=new Yc(c),c===null&&(d=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||d?(_={...t},l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),d&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return Ct(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,u,o):f.allowUpdate(o.user,u,o):t.type==="create"?f.allowCreate(o.user,u,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(T=>{if(!T)throw new wT(o.user);return typeof u?.then=="function"?u.then(S=>e(f,l,o,S)):e(f,l,o,u)});if(!h)throw new wT(o.user)}return typeof u?.then=="function"?u.then(h=>e(f,l,o,h)):e(f,l,o,u)}a(E,"authorizeActionOnResource")}}function Jn(e,t){let r=new WK.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 Ew(e,t,r){let n=e[ve];if(n){let s=e[ur];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 DT(e,t){let r=t?.propertyResolvers,n=t[xe],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):Ew(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 d=[],u=i(Ew(l,r,n));for(let _ of e)d.push(u(_));return d},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let d={},u=i(Ew(l,r,n)),_;for(let E of e){let f=u(E);f===void 0&&o&&(f=null),f?.then?(_||(_=[]),_.push(f.then(h=>d[E.name||E]=h))):d[E.name||E]=f}return _?Promise.all(_).then(()=>d):d},"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 u=r[c.name]?.definition?.tableClass;l=s[c.name]=DT(c.select||c,u)}let d=o(c.name);return l(d)}else return o(c);else return c}}a(i,"handleProperty")}var YK,KK,WK,xe,je,ni,ve,ESe,Ir,wT,_l,CT,Hs=De(()=>{YK=require("crypto");Al();KK=v(Vi()),WK=v(fe());cm();uc();Qf();xe=Symbol.for("context"),je=Symbol.for("primary-key"),ni=Symbol("is-collection"),ve=Symbol("stored-record"),ESe={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Ir=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[je]=t;let n=r?.[xe];this[xe]=n!==void 0?n:r||null}static get=zn(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 d=DT(l,t.constructor);return typeof c?.map=="function"?c.map(d):d(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=zn(function(t,r,n,s){if(Array.isArray(s)&&t[ni]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,d=l.getResource(c[l.primaryKey],n,{async:!0});d.then?i.push(d.then(u=>u.put(c,n))):i.push(d.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):Jn(t,"put")},{hasContent:!0,type:"update"});static patch=zn(function(t,r,n,s){return t.patch?t.patch(s,r):Jn(t,"patch")},{hasContent:!0,type:"update"});static delete=zn(function(t,r,n,s){return t.delete?t.delete(r):Jn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,YK.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={}),Ct(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):Jn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=zn(function(t,r,n,s){return t.invalidate?t.invalidate(r):Jn(t,"delete")},{hasContent:!1,type:"update"});static post=zn(function(t,r,n,s){return t[je]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=zn(function(t,r,n,s){return t.connect?t.connect(s,r):Jn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=zn(function(t,r,n,s){return t.subscribe?t.subscribe(r):Jn(t,"subscribe")},{type:"read"});static publish=zn(function(t,r,n,s){return t[je]!=null&&t.update?.(),t.publish?t.publish(s,r):Jn(t,"publish")},{hasContent:!0,type:"create"});static search=zn(function(t,r,n,s){let i=t.search?t.search(r):Jn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=DT(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=zn(function(t,r,n,s){return t.search?t.search(s,r):Jn(t,"search")},{hasContent:!0,type:"read"});static copy=zn(function(t,r,n,s){return t.copy?t.copy(s,r):Jn(t,"copy")},{hasContent:!0,type:"create"});static move=zn(function(t,r,n,s){return t.move?t.move(s,r):Jn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[ni])return(await this.constructor.create(this[je],t,this[xe]))[je];Jn(this,"post")}static isCollection(t){return t?.[ni]}static coerceId(t){return t}static parseQuery(t){return sS(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&ESe[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:VK(t,this),isCollection:_l}}let i=VK(t,this);return _l?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[xe],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 d=l.asMap.get(t);if(s=d?.find(u=>u.constructor===c),s)return s;d||l.asMap.set(t,d=[]),d.push(s=new c(t,i))}else{if(s=l.find(d=>d[je]===t&&d.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let d=new Map;for(let u of l){let _=u[je],E=d.get(_);E?E.push(u):d.set(_,[u])}i.resourceCache.length=0,i.resourceCache.asMap=d}}}else s=new c(t,i);return o&&(s[ni]=!0),s}subscribe(t){return new In}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new In}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[je]}getContext(){return this[xe]}};Ir.prototype[xe]=null;(0,KK._assignPackageExport)("Resource",Ir);a(hSe,"snake_case");wT=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(VK,"pathToId");CT=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(zn,"transactional");a(Jn,"missingMethod");a(Ew,"selectFromObject");a(DT,"transformForSelect")});var RN={};et(RN,{EVICTED:()=>ba,INVALIDATED:()=>Pi,coerceType:()=>LT,makeTable:()=>vT,setServerUtilities:()=>ySe,updateResource:()=>MT});function vT(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:d,dbisDB:u,sealed:_,splitSegments:E,replicate:f}=e,{expirationMS:h,evictionMS:T,audit:S,trackDeletes:R}=e,{attributes:p}=e;p||(p=[]);let y=Kg(i,n,l),O,B,x={},W=Promise.resolve(),q,z,_e;for(let k of p)(k.assignCreatedTime||k.name==="__createdtime__")&&(q=k),(k.assignUpdatedTime||k.name==="__updatedtime__")&&(z=k),k.expiresAt&&(_e=k),k.isPrimaryKey&&(x=k);let X,ue=[],j=[],ie=1,ye=2,Ie={},Me={},tn=864e5,gd,ka,yn,YE=!1,Fa,zT=new Map,Rd=new Map,bt,es,ts=Ed.get(Us.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(ts)){for(let k of ts)if(k.name===c&&k.replicateTo>=0){es=k.replicateTo;break}}let KE=i.getRange({start:!1,end:!1}).constructor,Uw=10,rs=6;S&&rt();class Ge extends Ir{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=S;static databasePath=o;static databaseName=c;static attributes=p;static replicate=f;static sealed=_;static splitSegments=E??!0;static createdTimeProperty=q;static updatedTimeProperty=z;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=u;static schemaDefined=d;static sourcedFrom(m,g){if(g&&(this.sourceOptions=g,(g.expiration||g.eviction||g.scanInterval)&&this.setTTLExpiration(g)),g?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(w=>!w.intermediateSource))throw new Error("Can not have multiple canonical (non-intermediate) sources");this.sources.push(m)}B=B||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),O=O||m.load;let D=a(w=>{let N=this.sources;if(N=N.filter(H=>H.intermediateSource&&H[w]&&(!H[w].reliesOnPrototype||H.prototype[w])),N.length>0)if(N.length===1){let H=N[0];return(U,C,L)=>{if(U?.source!==H)return H[w](C,L,U)}}else return(H,U,C)=>{let L=[];for(let F of N){if(H?.source===F)break;L.push(F[w](U,C,H))}return Promise.all(L)}},"getApplyToIntermediateSource"),A=this.sources[this.sources.length-1];A.intermediateSource&&(A={});let I=a(w=>{if(A[w]&&(!A[w].reliesOnPrototype||A.prototype[w]))return(N,H,U)=>{if(!N?.source)return A[w](H,U,N)}},"getApplyToCanonicalSource");return Ie={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish")},Me={put:D("put"),patch:D("patch"),delete:D("delete"),publish:D("publish"),invalidate:D("invalidate")},(async()=>{let w=!1,N,H=a(async(U,C)=>{let L=U.value,F=U.table?We[c][U.table]:Ge;if(c===Us.SYSTEM_SCHEMA_NAME&&(U.table===Us.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||U.table===Us.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(w=!0),U.id===void 0&&(U.id=L[F.primaryKey],U.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(U));U.source=m;let G={residencyId:ft(U.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:U.nodeId},ce=await F.getResource(U.id,C,G);switch(U.type){case"put":return ce._writeUpdate(L,!0,G);case"patch":return ce._writeUpdate(L,!1,G);case"delete":return ce._writeDelete(G);case"publish":return ce._writePublish(L,G);case"invalidate":return ce._writeInvalidate(G);case"relocate":return ce._writeRelocate(G);default:Fe.default.error?.("Unknown operation",U.type,U.id)}},"writeUpdate");try{let U=m.subscribe;U&&R==null&&(R=!0);let C=m.subscribeOnThisThread?m.subscribeOnThisThread((0,El.getWorkerIndex)()):(0,El.getWorkerIndex)()===0,L=U&&C&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(L){let F;for await(let G of L)try{if(!(G.type==="transaction"?G.writes[0]:G)){Fe.default.error?.("Bad subscription event",G);continue}if(G.source=m,G.type==="end_txn"){if(F?.resolve(),G.localTime&&N!==G.localTime){if(G.remoteNodeIds?.length>0){let Te=[Symbol.for("seq"),G.remoteNodeIds[0]],de=u.get(Te),Oe=de?.nodes;Oe||(Oe=[]);for(let ee of G.remoteNodeIds.slice(1)){let ge=Oe.find(Ke=>Ke.name===ee);ge||(ge={id:ee,seqId:0},Oe.push(ge)),ge.seqId=Math.max(de?.seqId??1,G.localTime),ee===G.nodeId&&(ge.lastTxnTime=G.timestamp)}let Z=Math.max(de?.seqId??1,G.localTime);Fe.default.trace?.("Received txn",c,Z,G.localTime,G.remoteNodeIds),u.put(Te,{seqId:Z,nodes:Oe})}N=G.localTime}G.onCommit&&F?.committed.then(G.onCommit);continue}if(F)if(G.beginTxn)F.resolve();else{F.write_promises.push(H(G,F));continue}let re=Ct(G,()=>{if(G.type==="transaction"){let Te=[];for(let de of G.writes)try{Te.push(H(de,G))}catch(Oe){throw Oe.message+=" writing "+JSON.stringify(de)+" of event "+JSON.stringify(G),Oe}return Promise.all(Te)}else if(G.type==="define_schema"){let Te=this.attributes.slice(0),de;for(let Oe of G.attributes)Te.find(Z=>Z.name===Oe.name)||(Te.push(Oe),de=!0);de&&(Et({table:s,database:c,attributes:Te,origin:"cluster"}),LE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(F=G,F.write_promises=[H(G,G)],new Promise(Te=>{F.resolve=()=>Te(Promise.all(F.write_promises))})):H(G,G)});F&&(F.committed=re),w&&re&&!re?.waitingForUserChange&&(re.then(()=>LE.signalUserChange(new ME.UserEventMsg(process.pid))),re.waitingForUserChange=!0),G.onCommit&&(re?re.then(G.onCommit):G.onCommit())}catch(ce){Fe.default.error?.("error in subscription handler",ce)}}}catch(U){Fe.default.error?.(U)}})(),this}static getResource(m,g,D){let A=super.getResource(m,g,D);if(m!=null){$i(m);try{if(A.hasOwnProperty(ve))return A;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let I=!D?.async||i.cache?.get(m),w=Gr(g),N=w.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Ad(m,g,{transaction:N,ensureLoaded:D?.ensureLoaded},I,H=>{if(H?MT(A,H):A[ve]=null,g.onlyIfCached&&g.noCacheStore){if(!A.doesExist())throw new yr.ServerError("Entry is not cached",504)}else if(D?.ensureLoaded){let U=Tl(m,H,g,A);if(U)return w?.disregardReadTxn(),A[hw]=!0,pw(U,C=>(MT(A,C),A))}return A})}catch(I){throw I.message.includes("Unable to serialize object")&&(I.message+=": "+JSON.stringify(m)),I}}return A}ensureLoaded(){let m=Tl(this[je],this[Fr],this[xe]);if(m)return this[hw]=!0,pw(m,g=>{this[Fr]=g,this[ve]=g.value,this[DE]=g.version})}static getNewId(){let m=x?.type;if(m==="String"||m==="ID")return super.getNewId();if(!bt){let I=i.getEntry(Symbol.for("id_allocation")),w=I?.value,N;if(w&&w.nodeName===server.hostname&&(!NSe(i)||w.pid===process.pid)){let H=w.start,U=w.end;N=H;for(let C of i.getKeys({start:U,end:H,limit:1,reverse:!0}))N=C}else w=A(I?.version??null),N=w.start;bt=new BigInt64Array([BigInt(N)+1n]),bt=new BigInt64Array(i.getUserSharedBuffer("id",bt.buffer)),bt.maxSafeId=w.end}let g=Number(Atomics.add(bt,0,1n)),D=m==="Int"?512:1048576;if(g+D>=bt.maxSafeId){let I=a(w=>{bt.maxSafeId=g+(m==="Int"?1023:4194303);let N=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,H=w?void 0:i.useReadTransaction(),U=Number(bt[0]);for(let F of i.getKeys({start:U+1,end:N,limit:1,transaction:H}))N=F;H?.done();let{value:C,version:L}=i.getEntry(Symbol.for("id_allocation"));if(bt.maxSafeId<N){if(C.end>bt.maxSafeId-100)return;Fe.default.info?.("New id allocation",g,bt.maxSafeId,L),i.put(Symbol.for("id_allocation"),{start:C.start,end:bt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),L)}else{Fe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${bt.maxSafeId}, but id of ${N} detected`);let F=A(L);F.alreadyUpdated||Atomics.store(bt,0,BigInt(F.start+1)),bt.maxSafeId=F.end}},"updateEnd");g+D===bt.maxSafeId?setImmediate(I):g+100>=bt.maxSafeId&&(Fe.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(()=>I(!0)))}return g;function A(I){let w=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,N=w/4,H,U,C=!1,L,F;do{L=Math.floor(Math.random()*w),F={start:L,end:L+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},H=0;for(let G of i.getKeys({start:L,limit:1,reverse:!0}))H=G;U=w;for(let G of i.getKeys({start:L+1,end:w,limit:1}))U=G;N*=.875,N<1e3&&!C&&(C=!0,Fe.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":""}`,L,H,U,N))}while(!(N<U-L&&(N<L-H||H===0)));return i.transactionSync(()=>{let G=i.getEntry(Symbol.for("id_allocation"));return(G?.version??null)==I?(Fe.default.info?.("Allocated new id range",F),i.put(Symbol.for("id_allocation"),F,Date.now()),F):(Fe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...G.value})})}}static setTTLExpiration(m){if(typeof m=="number")h=m*1e3,T||(T=0);else if(m&&typeof m=="object")h=m.expiration*1e3,T=(m.eviction||0)*1e3,tn=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");tn=tn||(h+T)/4,Se()}static getResidencyRecord(m){return u.get([Symbol.for("residency_by_id"),m])}static setResidency(m){Ge.getResidency=m}static setResidencyById(m){Ge.getResidencyById=m}static getResidency(m,g,D){if(Ge.getResidencyById)return Ge.getResidencyById(m[t]);let A=es;if(g.replicateTo!=null){if(Array.isArray(g.replicateTo))return g.replicateTo.includes(server.hostname)?g.replicateTo:[server.hostname,...g.replicateTo];g.replicateTo>=0&&(A=g.replicateTo)}if(A>=0&&server.nodes){let I=[server.hostname];if(D)I.push(...D.slice(0,A));else{let w=server.nodes.map(U=>U.name),N=Math.floor(w.length*Math.random());I.push(...w.slice(N,N+A));let H=N+A-w.length;H>0&&I.push(...w.slice(0,H))}return I}}static enableAuditing(m=!0){S=m,m&&rt(),Ge.audit=m}static coerceId(m){return m===""?null:LT(m,x)}static async dropTable(){if(delete We[c][s],c===o){for(let m of p)u.remove(Ge.tableName+"/"+m.name),r[m.name]?.drop();u.remove(Ge.tableName+"/"),i.drop(),await u.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));LE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[ni])return this.search(m);if(this[je]===null){if(m?.conditions)return this.search(m);let g=Ge.getRecordCount();return{recordCount:g.recordCount,estimatedRecordRange:g.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:p}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[xe]?.returnNonexistent)return this}allowRead(m,g){let D=Uo(m);if(D?.read){if(D.isSuperUser)return!0;let A=D.attribute_permissions,I=g?.select;if(A?.length>0||YE&&I){if(g||(g={}),I){let w=A?.length>0&&mw(A,"read");g.select=I.map(N=>{let H=N.name||N;if(!w||w[H]){let U=yn[H]?.definition?.tableClass;if(U){if(N.name||(N={name:N}),!U.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else g.select=A.filter(w=>w.read&&!yn[w.attribute_name]).map(w=>w.attribute_name);return g}else return!0}}allowUpdate(m,g){let D=Uo(m);if(D?.update){let A=D.attribute_permissions;if(A?.length>0){let I=mw(A,"update");for(let w in g)if(!I[w])return!1;for(let w of A){let N=w.attribute_name;!w.update&&!(N in g)&&(g[N]=this.getProperty(N))}}return se(this[xe])}}allowCreate(m,g){if(this[ni]){let D=Uo(m);if(D?.insert){let A=D.attribute_permissions;if(A?.length>0){let I=mw(A,"insert");for(let w in g)if(!I[w])return!1;return se(this[xe])}else return se(this[xe])}}else return this.allowUpdate(m,{})}allowDelete(m){return Uo(m)?.delete&&se(this[xe])}update(m,g){if(!Gr(this[xe]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let A;return typeof m=="object"&&m&&(g?(Object.isFrozen(m)&&(m={...m}),this[ve]={},this[ur]=m):(A=this[ur],A&&(m=Object.assign(A,m)),this[ur]=A=m)),this._writeUpdate(this[ur],g),this}addTo(m,g){if(typeof g=="number"||typeof g=="bigint")this[wE]===QK?this.set(m,(+this.getProperty(m)||0)+g):(this[wE]||this.update(),this.set(m,new NT(g)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,g){if(typeof g=="number")return this.addTo(m,-g);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Fr]}invalidate(){this._writeInvalidate()}_writeInvalidate(m){let g=this[xe],D=this[je];$i(D),Gr(this[xe]).addWrite({key:D,store:i,invalidated:!0,entry:this[Fr],before:Ie.invalidate?.bind(this,g,D),beforeIntermediate:Me.invalidate?.bind(this,g,D),commit:(I,w)=>{if(Bo(I,w,m?.nodeId)<=0)return;let N=null;for(let H in r)N||(N={}),N[H]=this.getProperty(H);Fe.default.trace?.(`Invalidating entry id: ${D}, timestamp: ${new Date(I).toISOString()}`),y(D,N,this[Fr],I,Pi,S,{user:g?.user,residencyId:m?.residencyId,nodeId:m?.nodeId},"invalidate")}})}_writeRelocate(m){let g=this[xe],D=this[je];$i(D),Gr(this[xe]).addWrite({key:D,store:i,invalidated:!0,entry:this[Fr],before:Ie.relocate?.bind(this,g,D),beforeIntermediate:Me.relocate?.bind(this,g,D),commit:(I,w)=>{if(Bo(I,w,m?.nodeId)<=0)return;let N=Ge.getResidencyRecord(m.residencyId),H=0,U=null,C=w?.value;if(N&&!N.includes(server.hostname)){for(let L in r)U||(U={}),U[L]=C(L);H=Pi}else U=C;Fe.default.trace?.(`Relocating entry id: ${D}, timestamp: ${new Date(I).toISOString()}`),y(D,U,this[Fr],I,H,S,{user:g.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)}})}static _recordRelocate(m,g){let D={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},A=this.getResidency(g.value,D),I;if(A){if(!Array.isArray(A))throw new Error("Residency must be an array, but was: "+A);if(!A.includes(server.hostname))return;I=ft(A)}let N=y(m.key,g.value,m,m.version,0,!0,{residencyId:I,expiresAt:g.expiresAt},"relocate",!1,null)}static evict(m,g,D){let A=this.Source,I;if(!((B||S)&&(!g||(I=i.getEntry(m),!I||!g)||I.version!==D))){if(B){if(i.hasLock(m,I.version))return;let w;for(let N in r)w||(w={}),w[N]=g[N];if(w)return y(m,w,I,D,ba,null,null,null,!0)}return i.ifVersion(m,D,()=>{Mo(m,g,null)}),S?y(m,null,I,D,ba,null,null,null,!0):i.remove(m,D)}}lock(){throw new Error("Not yet implemented")}static operation(m,g){return m.table||=s,m.schema||=c,nW.operation(m,g)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,g,D){let A=this[xe],I=Gr(A),w=this[je];$i(w);let N=this[Fr];this[wE]=g?QK:RSe;let H={key:w,store:i,entry:N,nodeName:A?.nodeName,validate:U=>{m||(m=this[ur]),g||m&&yT(this[ur]===m?this:m)?A?.source||(I.checkOverloaded(),this.validate(m,!g),z&&(m[z.name]=z.type==="Date"?new Date(U):z.type==="String"?new Date(U).toISOString():U),g&&(t&&m[t]!==w&&(m[t]=w),q&&(N?.value?m[q.name]=N?.value[q.name]:m[q.name]=q.type==="Date"?new Date(U):q.type==="String"?new Date(U).toISOString():U),m=dl(m))):I.removeWrite(H)},before:g?Ie.put?()=>Ie.put(A,w,m):null:Ie.patch?()=>Ie.patch(A,w,m):Ie.put?()=>Ie.put(A,w,dl(this)):null,beforeIntermediate:g?Me.put?()=>Me.put(A,w,m):null:Me.patch?()=>Me.patch(A,w,m):Me.put?()=>Me.put(A,w,dl(this)):null,commit:(U,C,L)=>{if(L){if(A&&C?.version>(A.lastModified||0)&&(A.lastModified=C.version),this[Fr]=C,C?.value?.[ve])throw new Error("Can not assign a record to a record, check for circular references");g||(this[ve]=C?.value??null)}this[ur]=void 0,this[DE]=U;let F=C?.value,G=m;this[wE]=0;let ce=Bo(U,C,D?.nodeId),re;if(ce<=0)if(S){let ee=C.localTime,ge=C.version;Fe.default.trace?.("Applying CRDT update to record with id: ",w,"applying later update:",ge);let Ke=[];for(;ee>U||ge>=U&&ee>0;){let ne=l.get(ee);if(!ne)break;let we=Ht(ne);if(ge=we.version,ge>=U){if(ge===U){if(ce=Bo(U,{version:ge,localTime:ee},D?.nodeId),ce===0)return;if(ce>0)continue}if(we.type==="patch")Ke.push(we),re=m;else if(we.type==="put"||we.type==="delete")return}ee=we.previousLocalTime}Ke.sort((ne,we)=>ne.version-we.version);for(let ne of Ke){let we=ne.getValue(i);if(G=AT(G,we,g),Fe.default.debug?.("Rebuilding update with future patch:",G),!G)return}}else{if(g)return;G=AT(G,F,g),Fe.default.debug?.("Rebuilding update without audit:",G)}let Te;if(g?Te=G:(this[ve]=F,Te=dl(this,G)),this[ve]=Te,Te?.[ve])throw new Error("Can not assign a record to a record, check for circular references");let de;if(D?.residencyId!=null)de=D.residencyId;else{N?.residencyId&&(A.previousResidency=Ge.getResidencyRecord(N.residencyId));let ee=Ge.getResidency(Te,A);if(ee){if(!Array.isArray(ee))throw new Error("Residency must be an array, got: "+ee);ee.includes(server.hostname)||ee.push(server.hostname)}de=ft(ee)}g||(re=m);let Oe=A?.expiresAt??(h?h+Date.now():-1);Fe.default.trace?.(`Saving record with id: ${w}, timestamp: ${new Date(U).toISOString()}${Oe?", expires at: "+new Date(Oe).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,Te),Mo(w,F,Te);let Z=g?"put":"patch";y(w,Te,C,U,0,S,{user:A?.user,residencyId:de,expiresAt:Oe,nodeId:D?.nodeId,originatingOperation:A?.originatingOperation},Z,!1,re),A.expiresAt&&Se()}};I.addWrite(H)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[ni]){for await(let g of this.search(m))(await Ge.getResource(g[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[ve]?this._writeDelete(m):!1}_writeDelete(m){let g=Gr(this[xe]),D=this[je];$i(D);let A=this[xe];return g.addWrite({key:D,store:i,resource:this,nodeName:A?.nodeName,before:Ie.delete?.bind(this,A,D),beforeIntermediate:Me.delete?.bind(this,A,D),commit:(I,w,N)=>{let H=w?.value;N&&(A&&w?.version>(A.lastModified||0)&&(A.lastModified=w.version),MT(this,w)),!(Bo(I,w,m?.nodeId)<=0)&&(Mo(this[je],H),Fe.default.trace?.(`Deleting record with id: ${D}, txn timestamp: ${new Date(I).toISOString()}`),S||R?(y(D,null,this[Fr],I,0,S,{user:A?.user,nodeId:m?.nodeId},"delete"),S||Se()):i.remove(this[je]))}}),!0}search(m){let g=this[xe],D=Gr(g);if(!m)throw new Error("No query provided");let A=m.conditions;A?A.length===void 0&&(A=A[Symbol.iterator]?Array.from(A):[A]):A=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[je]&&(A=[{attribute:null,comparator:Array.isArray(this[je])?"prefix":"starts_with",value:this[je]}].concat(A));let I,w={};function N(ee,ge){let Ke;switch(ge){case"and":case void 0:if(ee.length<1)throw new Error('An "and" operator requires at least one condition');Ke=!0;break;case"or":if(ee.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+ge)}for(let ne of ee){if(ne.conditions){ne.conditions=N(ne.conditions,ne.operator);continue}let we=ne[0]??ne.attribute,nt=we==null?x:Di(p,we);if(nt)(nt.type||jO[ne.comparator])&&(ne[1]===void 0?ne.value=U(ne.value,nt):ne[1]=U(ne[1],nt));else if(we!=null)throw(0,yr.handleHDBError)(new Error,`${we} is not a defined attribute`,404);if(ne.chainedConditions)if(ne.chainedConditions.length===1&&(!ne.operator||ne.operator=="and")){let Xe=ne.chainedConditions[0],$e,Kt;if(Xe.comparator==="gt"||Xe.comparator==="greater_than"||Xe.comparator==="ge"||Xe.comparator==="greater_than_equal"?($e=ne,Kt=Xe):($e=Xe,Kt=ne),$e.comparator!=="lt"&&$e.comparator!=="less_than"&&$e.comparator!=="le"&&$e.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let Or=Kt.comparator==="ge"||Kt.comparator==="greater_than_equal",ii=$e.comparator==="le"||$e.comparator==="less_than_equal";ne.comparator=(Or?"ge":"gt")+(ii?"le":"lt"),ne.value=[Kt.value,$e.value]}else throw new Error("Multiple chained conditions are not currently supported")}return ee}a(N,"prepareConditions");function H(ee,ge){if(m.enforceExecutionOrder)return ee;for(let Ke of ee)Ke.conditions&&(Ke.conditions=H(Ke.conditions,Ke.operator));return ee.length>1&&ge!=="or"?(0,tW.sortBy)(ee,nS(Ge)):ee}a(H,"orderConditions");function U(ee,ge){return Array.isArray(ee)?ee.map(Ke=>LT(Ke,ge)):LT(ee,ge)}a(U,"coerceTypedValues");let C=m.operator;(A.length>0||C)&&(A=N(A,C));let L=typeof m.sort=="object"&&m.sort,F;if(L&&C!=="or"){let ee=L.attribute;if(ee==null)throw new yr.ClientError("Sort requires an attribute");if(I=A.find(ge=>$u(ge.attribute)===$u(ee)),!I){let ge=Di(p,ee);if(!ge)throw(0,yr.handleHDBError)(new Error,`${Array.isArray(ee)?ee.join("."):ee} is not a defined attribute`,404);if(ge.indexed)I={attribute:ee,comparator:"sort"},A.push(I);else if(A.length===0&&!m.allowFullScan)throw(0,yr.handleHDBError)(new Error,`${Array.isArray(ee)?ee.join("."):ee} is not indexed and not combined with any other conditions`,404)}I&&(I.descending=!!L.descending)}A=H(A,C),L&&(I&&A[0]===I?L.next&&(F={dbOrderedAttribute:L.attribute,attribute:L.next.attribute,descending:L.next.descending,next:L.next.next}):(I&&A.splice(A.indexOf(I),1),F=L));let G=m.select;if(A.length===0&&(A=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:A,operator:C,postOrdering:F,selectApplied:!!G};let ce=D.useReadTxn(),re=QO(A,C,Ge,ce,m,g,(ee,ge)=>bd(ee,G,g,ce,ge),w),Te=m.ensureLoaded!==!1;F||(re=Z(re));let de=Ge.transformEntryForSelect(G,g,ce,w,Te,!0),Oe=Ge.transformToOrderedSelect(re,G,F,ce,g,de);function Z(ee){return m.offset||m.limit!==void 0?ee.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):ee}return a(Z,"applyOffset"),F&&(Oe=Z(Oe)),Oe.onDone=()=>{Oe.onDone=null,D.doneReadTxn()},Oe.selectApplied=!0,Oe.getColumns=()=>{if(G){let ee=[];for(let ge of G)ge==="*"?ee.push(...p.map(Ke=>Ke.name)):ee.push(ge.name||ge);return ee}return p.filter(ee=>!ee.computed&&!ee.relationship).map(ee=>ee.name)},Oe}static transformToOrderedSelect(m,g,D,A,I,w){let N=new KE;if(D){m=bd(m,g,A,I,null);let H;N.iterate=function(){let C,L=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),F,G=D.dbOrderedAttribute,ce,re,Te=!0;function de(Z){let ee=Z.next&&de(Z.next),ge=Z.descending;return(Ke,ne)=>{let we=vo(Ke,Z.attribute,A),nt=vo(ne,Z.attribute,A),Xe=ge?(0,hl.compareKeys)(nt,we):(0,hl.compareKeys)(we,nt);return Xe===0?ee?.(Ke,ne)||0:Xe}}a(de,"createComparator");let Oe=de(D);return{async next(){let Z;if(C)if(Z=C.next(),Z.done){if(F)return N.onDone&&N.onDone(),Z}else return{value:await w.call(this,Z.value)};H=[],ce&&H.push(ce);do if(Z=await L.next(),Z.done){if(F=!0,H.length)break;return N.onDone&&N.onDone(),Z}else{let ee=Z.value;if(ee?.then&&(ee=await ee),G){let ge=vo(ee,G,A);if(Te)Te=!1,re=ge;else if(ge!==re){re=ge,ce=ee;break}}H.push(ee)}while(!0);return D.isGrouped,H.sort(Oe),C=H[Symbol.iterator](),Z=C.next(),Z.done?(N.onDone&&N.onDone(),Z):{value:await w.call(this,Z.value)}},return(){N.onDone&&N.onDone(),L.return()},throw(){N.onDone&&N.onDone(),L.throw()}}};let U=a(C=>{if(typeof g=="object"&&Array.isArray(C.attribute))for(let L=0;L<g.length;L++){let F=g[L],G;if(F.name===C.attribute[0]){for(G=F.sort||(F.sort={});G.next;)G=G.next;G.attribute=C.attribute.slice(1),G.descending=C.descending}else F===C.attribute[0]&&(g[L]=G={name:F,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&U(C.next)},"applySortingOnSelect");U(D)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(function(H){try{let U=w.call(this,H);return typeof U?.catch=="function"?U.catch(C=>{throw C.partialObject={[t]:H.key},C}):U}catch(U){throw U.partialObject={[t]:H.key},U}});return N}static transformEntryForSelect(m,g,D,A,I,w){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let C=a(L=>(g?.transaction?.stale&&(g.transaction.stale=!1),L?.key??L),"transform");return m===t?C:m.asArray?L=>[C(L)]:L=>({[t]:C(L)})}let N;I&&B&&!(typeof m=="string"?[m]:m)?.every(C=>{let L;return typeof C=="object"?L=C.name:L=C,r[L]||L===t})&&(N=!0);let H,U=a(function(C){let L;if(g?.transaction?.stale&&(g.transaction.stale=!1),C!=null){if(L=C.value||C.deref?.(),!L&&(C.key===void 0||C.deref)){if(C=Ad(C.key??C,g,{transaction:D,lazy:m?.length<4},this?.isSync,F=>F),C?.then)return C.then(U.bind(this));L=C?.value}if(N&&C?.metadataFlags&(Pi|ba)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(g.onlyIfCached&&g.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let F=Tl(C.key??C,C,g);if(F?.then)return F.then(U)}}if(L==null)return w?fl.SKIP:L;if(m&&!(m[0]==="*"&&m.length===1)){let F,G=a((re,Te)=>{let de;typeof re=="object"?de=re.name:de=re;let Oe=yn?.[de],Z;if(Oe){let ee=A?.[de];if(ee)if(ee.hasMappings){let Ke=Oe.from?L[Oe.from]:$u(C.key);Z=ee.get(Ke),Z||(Z=[])}else Z=ee.fromRecord?.(L);else Z=Oe(L,g,C);let ge=a(Ke=>{if(Ke&&typeof Ke=="object"){let ne=Oe.definition?.tableClass||Ge;H||(H={});let we=H[de]||(H[de]=ne.transformEntryForSelect(de===re?null:re.select||(Array.isArray(re)?re:null),g,D,ee,I));if(Array.isArray(Ke)){let nt=[],Xe=ne.transformToOrderedSelect(Ke,re.select,typeof re.sort=="object"&&re.sort,g,D,we)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),$e=a(Or=>{for(;!Or.done;){if(Or?.then)return Or.then($e);nt.push(Or.value),Or=Xe.next()}Te(nt,de)},"nextValue"),Kt=$e(Xe.next());Kt&&(F||(F=[]),F.push(Kt));return}else if(Ke=we.call(this,Ke),Ke?.then){F||(F=[]),F.push(Ke.then(nt=>Te(nt,de)));return}}Te(Ke,de)},"handleResolvedValue");Z?.then?(F||(F=[]),F.push(Z.then(ge))):ge(Z);return}else Z=L[de],Z&&typeof Z=="object"&&de!==re&&(Z=Ge.transformEntryForSelect(re.select||re,g,D,null)({value:Z}));Te(Z,de)},"selectAttribute"),ce;if(typeof m=="string")G(m,re=>{ce=re});else if(Array.isArray(m))if(m.asArray)ce=[],m.forEach((re,Te)=>{re==="*"?m[Te]=L:G(re,de=>ce[Te]=de)});else{ce={};let re=m.forceNulls;for(let Te of m)if(Te==="*")for(let de in L)ce[de]=L[de];else G(Te,(de,Oe)=>{de===void 0&&re&&(de=null),ce[Oe]=de})}else throw new yr.ClientError("Invalid select"+m);return F?Promise.all(F).then(()=>ce):ce}return L},"transform");return U}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");S||Et({table:s,database:c,schemaDefined:d,attributes:p,audit:!0}),m||(m={});let g=!m.rawEvents,D=[],A=Sb(Ge,this[je]??null,function(w,N,H,U){try{let C=N.getValue?.(i,g),L=N.type;if(!C&&N.type==="patch"&&g){let G=i.getEntry(w);G?.version===N.version?C=G.value:C=N.getValue?.(i,!0,H),L="put"}let F={id:w,timestamp:H,value:C,version:N.version,type:L,beginTxn:U};D?D.push(F):this.send(F)}catch(C){Fe.default.error?.(C)}},m.startTime||0,m),I=(async()=>{this[ni]&&(A.includeDescendants=!0,m.onlyChildren&&(A.onlyChildren=!0)),m.supportsTransactions&&(A.supportsTransactions=!0);let w=this[je],N=m.previousCount;N>1e3&&(N=1e3);let H=m.startTime;if(this[ni]){if(H){if(N)throw new yr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:U,value:C}of l.getRange({start:H,exclusiveStart:!0,snapshot:!1})){let L=Ht(C);if(L.tableId!==n)continue;let F=L.recordId;if(w==null||ZK(w,F)){let G=L.getValue(i,g,U);if(A.send({id:F,timestamp:U,value:G,version:L.version,type:L.type}),A.queue?.length>JK&&await A.waitForDrain()===!1)return}A.startTime=U}}else if(N){let U=[];for(let{key:C,value:L}of l.getRange({start:"z",end:!1,reverse:!0}))try{let F=Ht(L);if(F.tableId!==n)continue;let G=F.recordId;if(w==null||ZK(w,G)){let ce=F.getValue(i,g,C);if(U.push({id:G,timestamp:C,value:ce,version:F.version,type:F.type}),--N<=0)break}}catch(F){Fe.default.error("Error getting history entry",C,F)}for(let C=U.length;C>0;)A.send(U[--C]);U[0]&&(A.startTime=U[0].timestamp)}else if(!m.omitCurrent){for(let{key:U,value:C,version:L,localTime:F}of i.getRange({start:w??!1,end:w==null?void 0:[w,hl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(C&&(A.send({id:U,timestamp:F,value:C,version:L,type:"put"}),A.queue?.length>JK&&await A.waitForDrain()===!1))return}}else{N&&!H&&(H=0);let U=this[Fr]?.localTime;if(U===Yg&&(i.cache?.delete(w),this[Fr]=i.getEntry(w),Fe.default.trace?.("re-retrieved record",U,this[Fr]?.localTime),U=this[Fr]?.localTime),Fe.default.trace?.("Subscription from",H,"from",w,U),H<U){let C=[],L=U;do{let F=l.get(L);if(F){m.omitCurrent=!0;let G=Ht(F),ce=G.getValue(i,g,L);g&&(G.type="put"),C.push({id:w,value:ce,timestamp:L,...G}),L=G.previousLocalTime}else break;N&&N--}while(L>H&&N!==0);for(let F=C.length;F>0;)A.send(C[--F]);A.startTime=U}!m.omitCurrent&&this.doesExist()&&A.send({id:w,timestamp:U,value:this[ve],version:this[DE],type:"put"})}for(let U of D)A.send(U);D=null})();return m.listener&&A.on("data",m.listener),A}doesExist(){return!!(this[ve]||this[wE])}publish(m,g){this._writePublish(m,g)}_writePublish(m,g){let D=Gr(this[xe]),A=this[je]||null;A!=null&&$i(A);let I=this[xe];D.addWrite({key:A,store:i,entry:this[Fr],nodeName:I?.nodeName,validate:()=>{I?.source||(D.checkOverloaded(),this.validate(m))},before:Ie.publish?.bind(this,I,A,m),beforeIntermediate:Me.publish?.bind(this,I,A,m),commit:(w,N,H)=>{N===void 0&&R&&!S&&Se(),Fe.default.trace?.(`Publishing message to id: ${A}, timestamp: ${new Date(w).toISOString()}`),y(A,N?.value??null,N,N?.version||w,0,!0,{user:I?.user,residencyId:g?.residencyId,expiresAt:I?.expiresAt,nodeId:g?.nodeId},"message",!1,m)}})}validate(m,g){let D,A=a((I,w,N)=>{if(w.type&&I!=null)if(g&&I.__op__&&(I=I.value),w.properties){typeof I!="object"&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be an object${w.type?" ("+w.type+")":""}`);let H=w.properties;for(let U=0,C=H.length;U<C;U++){let L=H[U],F=A(I[L.name],L,N+"."+L.name);F&&(I[L.name]=F)}if(w.sealed&&I!=null&&typeof I=="object")for(let U in I)H.find(C=>C.name===U)||(D||(D=[])).push(`Property ${U} is not allowed within object in property ${N}`)}else switch(w.type){case"Int":(typeof I!="number"||I>>0!==I)&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof I!="number"||!(Math.floor(I)===I&&Math.abs(I)<=9007199254740992))&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof I!="number"&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a number`);break;case"ID":typeof I=="string"||I?.length>0&&I.every?.(H=>typeof H=="string")||(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof I!="string"&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a string`);break;case"Boolean":typeof I!="boolean"&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a boolean`);break;case"Date":if(!(I instanceof Date)){if(typeof I=="string"||typeof I=="number")return new Date(I);(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof I!="bigint"){if(typeof I=="string"||typeof I=="number")return BigInt(I);(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a bigint`)}break;case"Bytes":I instanceof Uint8Array||(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(I)){if(w.elements)for(let H=0,U=I.length;H<U;H++){let C=I[H],L=A(C,w.elements,N+"[*]");L&&(I[H]=L)}}else(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a Buffer or Uint8Array`);break}w.nullable===!1&&I==null&&(D||(D=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let I=0,w=p.length;I<w;I++){let N=p[I];if(!(N.relationship||N.computed)&&(!g||N.name in m)){let H=A(m[N.name],N,N.name);H&&(m[N.name]=H)}}if(_)for(let I in m)p.find(w=>w.name===I)||(D||(D=[])).push(`Property ${I} is not allowed`);if(D)throw new yr.ClientError(D.join(". "))}getUpdatedTime(){return this[DE]}wasLoadedFromSource(){return B?!!this[hw]:void 0}static async addAttributes(m){let g=p.slice(0);for(let D of m){if(!D.name)throw new yr.ClientError("Attribute name is required");if(D.name.match(/[`/]/))throw new yr.ClientError("Attribute names cannot include backticks or forward slashes");(0,rW.validateAttribute)(D.name),g.push(D)}return Et({table:s,database:c,schemaDefined:d,attributes:g}),Ge.indexingOperation}static async removeAttributes(m){let g=p.filter(D=>!m.includes(D.name));return Et({table:s,database:c,schemaDefined:d,attributes:g}),Ge.indexingOperation}static getRecordCount(m){let g=i.getStats().entryCount,D=1e3/2,A=performance.now(),I=Math.floor(g/2),w=m?.exactCount,N=0,H=0,U;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&N++,H++,!w&&H<I&&performance.now()-A>D){U=H;break}if(U){let C=N;N=0;for(let{value:Z}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:U}))Z!=null&&N++;let L=U*2,F=(N+C)/L,G=Math.pow((N-C+1)/U/2,2)+F*(1-F)/L,ce=Math.max(Math.sqrt(G)*g,1),re=Math.round(F*g),Te=Math.max(re-1.96*ce,N+C),de=Math.min(re+1.96*ce,g),Oe=Math.pow(10,Math.round(Math.log10(ce)));return Oe>re&&(Oe=Oe/10),N=Math.round(re/Oe)*Oe,{recordCount:N,estimatedRange:[Math.round(Te),Math.round(de)]}}return{recordCount:N}}static updatedAttributes(){yn=this.propertyResolvers={$id:(m,g,D)=>({value:D.key}),$updatedtime:(m,g,D)=>D.version,$record:(m,g,D)=>D?{value:m}:m};for(let m of this.attributes){m.resolve=null;let g=m.relationship,D=m.computed;if(g)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),D&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),YE=!0,g.to)m.elements?.definition?(yn[m.name]=m.resolve=(A,I,w)=>{let N=A[g.from?g.from:t],H=m.elements.definition.tableClass;return w?qu({attribute:g.to,value:N},Gr(I).getReadTxn(),!1,H,!1).asArray:H.search([{attribute:g.to,value:N}],I).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,g.from&&(m.resolve.from=g.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(g.from){let A=m.definition||m.elements?.definition;A?(yn[m.name]=m.resolve=(I,w,N)=>{let H=I[g.from];if(H!==void 0){if(m.elements){let U,C=H?.map(L=>{let F=N?A.tableClass.primaryStore.getEntry(L,{transaction:Gr(w).getReadTxn()}):A.tableClass.get(L,w);return F?.then&&(U=!0),F});return g.filterMissing?U?Promise.all(C).then(L=>L.filter(eW)):C.filter(eW):U?Promise.all(C):C}return N?A.tableClass.primaryStore.getEntry(H,{transaction:Gr(w).getReadTxn()}):A.tableClass.get(H,w)}},m.set=(I,w)=>{if(Array.isArray(w)){let N=w.map(H=>H[je]||H[A.tableClass.primaryKey]);I[g.from]=N}else{let N=w[je]||w[A.tableClass.primaryKey];I[g.from]=N}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=g.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 D&&(typeof D.from=="function"&&this.setComputedAttribute(m.name,D.from),yn[m.name]=m.resolve=(A,I,w)=>{let N=typeof D.from=="string"?A[D.from]:A,H=this.userResolvers[m.name];if(H)return H(N,I,w);Fe.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]=()=>{}})}IT(this,this)}static setComputedAttribute(m,g){let D=Di(p,m);if(!D){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!D.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=g}static async deleteHistory(m=0){let g;for(let{key:D,value:A}of l.getRange({start:0,end:m}))await CE(),Ht(A).tableId===n&&(g=l.remove(D));await g}static async*getHistory(m=0,g=1/0){for(let{key:D,value:A}of l.getRange({start:m,end:g})){await CE();let I=Ht(A);I.tableId===n&&(yield{id:I.recordId,localTime:D,version:I.version,type:I.type,value:I.getValue(i,!0,D),user:I.user,operation:I.originatingOperation})}}static async getHistoryOfRecord(m){let g=[];if(m==null)throw new Error("An id is required");let D=i.getEntry(m);if(!D)return g;let A=D.localTime;if(!A)throw new Error("The entry does not have a local audit time");let I=0;do{await CE();let w=l.get(A);if(w){let N=Ht(w);g.push({id:N.recordId,localTime:A,version:N.version,type:N.type,value:N.getValue(i,!0,A),user:N.user}),A=N.previousLocalTime}else break}while(I<1e3&&A);return g.reverse()}static cleanup(){X?.remove()}}Ge.updatedAttributes();let WE=Ge.prototype;return WE[gSe]=!0,h&&Ge.setTTLExpiration(h/1e3),_e&&Re(),Ge;function Mo(k,m,g){let D;for(let A in r){let I=r[A],w=I.isIndexing,N=yn[A],H=g&&(N?N(g):g[A]),U=m&&(N?N(m):m[A]);if(H===U&&!w)continue;D=!0;let C=I.indexNulls,L=(0,PE.getIndexedValues)(H,C),F=(0,PE.getIndexedValues)(U,C);if(F?.length>0){let G=new Set(F);if(L=L?L.filter(ce=>{if(G.has(ce))G.delete(ce);else return!0}):[],F=Array.from(G),(F.length>0||L.length>0)&&jK){let ce=F.concat(L).map(re=>({key:re,value:k}));I.prefetch(ce,XK)}for(let ce=0,re=F.length;ce<re;ce++)I.remove(F[ce],k)}else L?.length>0&&jK&&I.prefetch(L.map(G=>({key:G,value:k})),XK);if(L)for(let G=0,ce=L.length;G<ce;G++)I.put(L[G],k)}return D}a(Mo,"updateIndices");function $i(k){switch(typeof k){case"number":return!0;case"string":if(k.length<659)return!0;if(k.length>zK)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,hl.writeKey)(k,ASe,0)>zK)throw new Error("Primary key size is too large: "+k.length);return!0}a($i,"checkValidId");function Ad(k,m,g,D,A){if(Ge.getResidencyById&&g.ensureLoaded){let w=Ge.getResidencyById(k);if(w&&!w.includes(server.hostname))return O({key:k,residency:w}).then(A)}let I=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),g.transaction?.isDone)return A(null,k);let w=i.getEntry(k,g);return w?.residencyId&&w.metadataFlags&Pi&&O&&g.ensureLoaded?O(w).then(N=>A(N,k)):(w&&m&&(w?.version>(m.lastModified||0)&&(m.lastModified=w.version),w?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=w.localTime)),A(w,k))},"whenPrefetched");return D?I():ie>0?(ie--,I()):new Promise((w,N)=>{ie===0?(ie--,i.prefetch([k],()=>{H(),U()})):(ue.push(k),j.push(U),ue.length>rs&&(ie--,H()));function H(){if(ue.length>0){let C=j;i.prefetch(ue,()=>{ie===-1?H():ie++;for(let L of C)L()}),ue=[],j=[],ye>2&&ye--}else ie=ye,ye<Uw&&ye++}a(H,"prefetch");function U(){try{w(I())}catch(C){N(C)}}a(U,"load")})}a(Ad,"loadLocalRecord");function Uo(k){if(!k?.role)return;let m=k.role.permission;if(m.super_user)return bSe;let g=m[c],D,A=g?.tables;if(A)return A[s];if(c==="data"&&(D=m[s])&&!D.tables)return D}a(Uo,"getTablePermissions");function Tl(k,m,g,D){if(B){let A=!1;if(g.noCache?A=!0:(m?(!m.value||m.metadataFlags&(Pi|ba)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(A=!0):A=!0,kn(!A,"cache-hit",s)),A){let I=gl(k,m,g).then(w=>(w?.value?.[ve]&&Fe.default.error?.("Can not assign a record with a record property"),g&&(w?.version>(g.lastModified||0)&&(g.lastModified=w.version),g.lastRefreshed=Date.now()),w));if(g?.onlyIfCached||m?.value&&D?.allowStaleWhileRevalidate?.(m,k)){if(I.catch(w=>Fe.default.warn?.(w)),g?.onlyIfCached&&!D.doesExist())throw new yr.ServerError("Entry is not cached",504);return}else return I}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return Ge.evict(m.key,m.value,m.version),m.value=null,{then(A){return A(m)}}}a(Tl,"ensureLoadedFromSource");function Gr(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 g=m.next;if(!g)return m=m.next=new lc,m.lmdbDb=i,m;m=g}while(!0)}else return new sm}a(Gr,"txnForContext");function vo(k,m,g){if(!k)return;let D=k.value||k.deref?.()||i.getEntry(k.key)?.value;if(typeof m=="object"){let I=yn,w=D;for(let N=0,H=m.length;N<H;N++){let U=m[N],C=I?.[U];w=C&&w?C(w,g,!0)?.value:w?.[U],I=C?.definition?.tableClass?.propertyResolvers}return w}let A=yn[m];return A?A(D,g):D[m]}a(vo,"getAttributeValue");function bd(k,m,g,D,A){let I=A?.length,w={transaction:D,lazy:I>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function H(U,C){let L=U?.value;if(!L)return fl.SKIP;for(let F=0;F<I;F++)if(!N?.includes(F)&&!A[F](L,U))return fl.SKIP;return C!==void 0&&(U.key=C),U}if(a(H,"processEntry"),I>0||!k.hasEntries){let U=k.map(C=>{if(N=null,typeof C=="object"&&C?.key!==void 0)return I>0?H(C):C;if(C==null)return fl.SKIP;for(let L=0;L<I;L++){let G=A[L].idFilter;if(G){if(!G(C))return fl.SKIP;N||(N=[]),N.push(L)}}return Ad(C,g,w,!1,H)});return Array.isArray(k)&&(U=U.filter(C=>C!==fl.SKIP)),U.hasEntries=!0,U}return k}a(bd,"transformToEntries");function Bo(k,m,g=server.replication?.getThisNodeId(l)){if(k<=m?.version){if(m?.version===k&&g!==void 0){let D=server.replication?.exportIdMapping(l),A=m.localTime,I=l.get(A);if(I){let w,N,H=Ht(I);for(let U in D)D[U]===g&&(w=U),D[U]===H.nodeId&&(N=U);if(w>N)return 1;if(w===N)return 0}}return-1}return 1}a(Bo,"precedesExistingVersion");async function gl(k,m,g){let D=m?.metadataFlags,A=m?.version,I,w;if(!i.attemptLock(k,A,()=>{clearTimeout(w);let C=i.getEntry(k);!C||!C.value||C.metadataFlags&(Pi|ba)?I(gl(k,i.getEntry(k),g)):I(C)}))return new Promise(C=>{I=C,w=setTimeout(()=>{i.unlock(k,A)},TSe)});let N=m?.value,H={requestContext:g,replacingRecord:N,replacingEntry:m,replacingVersion:A,noCacheStore:!1,source:null,resourceCache:g?.resourceCache},U=g?.responseHeaders;return new Promise((C,L)=>{let F;pw(Ct(H,async G=>{let ce=performance.now(),re,Te,de;try{for(let ge of Ge.sources)if(ge.get&&(!ge.get.reliesOnPrototype||ge.prototype.get)){if(ge.available?.(m)===!1)continue;if(H.source=ge,re=await ge.get(k,H),re)break}de=DΠlet Z=H.lastModified||de&&A;Te=de||Z>A||!N,Z||(Z=(0,PE.getNextMonotonicTime)());let ee=performance.now()-ce;if(gr(ee,"cache-resolution",s),U&&mO(U,"Server-Timing",`cache-resolve;dur=${ee.toFixed(2)}`,!0),G.timestamp=Z,h&&H.expiresAt==null&&(H.expiresAt=Date.now()+h),re){if(typeof re!="object")throw new Error("Only objects can be cached and stored in tables");if(re.status>0&&re.headers)if(re.status>=300)if(re.status===304)re=N,Z=A;else throw new yr.ServerError(re.body||"Error from source",re.status);else re=re.body;typeof re.toJSON=="function"&&(re=re.toJSON()),t&&re[t]!==k&&(re[t]=k)}F=!0,C({key:k,version:Z,value:re})}catch(Z){Z.message+=` while resolving record ${k} for ${s}`,N&&((Z.code==="ECONNRESET"||Z.code==="ECONNREFUSED"||Z.code==="EAI_AGAIN")&&!g?.mustRevalidate||g?.staleIfError&&(Z.statusCode===500||Z.statusCode===502||Z.statusCode===503||Z.statusCode===504))?(C({key:k,version:A,value:N}),Fe.default.trace?.(Z.message,"(returned stale record)")):L(Z),H.transaction.abort();return}if(g?.noCacheStore||H.noCacheStore){H.transaction.abort();return}Gr(H).addWrite({key:k,store:i,entry:m,nodeName:"source",commit:(Z,ee)=>{if(ee?.version!==A)return;let ge=Mo(k,N,re);re?(Me.put?.(H,k,re),Fe.default.trace?.(`Writing resolved record from source with id: ${k}, timestamp: ${new Date(Z).toISOString()}`),y(k,re,ee,Z,0,S&&Te||null,{user:H?.user,expiresAt:H.expiresAt},"put",!!de)):ee&&(Me.delete?.(H,k),Fe.default.trace?.(`Deleting resolved record from source with id: ${k}, timestamp: ${new Date(Z).toISOString()}`),S||R?y(k,null,ee,Z,0,S&&Te||null,{user:H?.user},"delete",!!de):i.remove(k,A))}})}),()=>{i.unlock(k,A)},G=>{i.unlock(k,A),F&&Fe.default.error?.("Error committing cache update",G)})})}a(gl,"getFromSource");function se(k){if(!k||k.user?.role?.permission?.super_user)return!0;if(k.replicateTo)throw new yr.ClientError("Can not specify replication parameters without super user permissions",403);if(k.replicatedConfirmation)throw new yr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(se,"checkContextPermissions");function Se(){if(tn!==gd&&(gd=tn,(0,El.getWorkerIndex)()===(0,El.getWorkerCount)()-1)){if(ka&&clearTimeout(ka),!tn)return;let k=new Date;k.setMonth(0),k.setDate(1),k.setHours(0),k.setMinutes(0),k.setSeconds(0);let m=Math.ceil((Date.now()-k.getTime())/tn)*tn+k.getTime(),g=a(D=>{Fe.default.trace?.(`Scheduled next cleanup scan at ${new Date(D)}ms`),ka=setTimeout(()=>W=W.then(async()=>{if(g(Math.max(D+tn,Date.now())),i.rootStore.status!=="open"){clearTimeout(ka);return}let A=50,I=new Array(A),w=0;Fe.default.info?.(`Starting cleanup scan for ${s}`);try{let N=0;for(let{key:H,value:U,version:C,expiresAt:L}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let F;U===null&&!S&&C+SSe<Date.now()?F=i.remove(H,C):L!=null&&L+T<Date.now()&&(F=Ge.evict(H,U,C),N++),F&&(await I[w],I[w]=F.catch(G=>{Fe.default.error?.("Cleanup error",G)}),++w>=A&&(w=0)),await CE()}Fe.default.info?.(`Finished cleanup scan for ${s}, evicted ${N} entries`)}catch(N){Fe.default.warn?.(`Error in cleanup scan for ${s}:`,N)}}),Math.min(D-Date.now(),2147483647)).unref()},"startNextTimer");g(m)}}a(Se,"scheduleCleanup");function rt(){X=l?.addDeleteRemovalCallback(n,k=>{let m=i.getEntry(k);m?.value===null&&i.remove(k,m.version)})}a(rt,"addDeleteRemoval");function Re(){(0,El.getWorkerIndex)()===0&&setInterval(async()=>{if(!Fa){Fa=!0;try{let k=_e.name,m=r[k];if(!m)throw new Error(`expiresAt attribute ${_e} must be indexed`);for(let g of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let D of m.getValues(g)){let A=i.getEntry(D);A?.value?A.value[k]<Date.now()&&Ge.evict(D,A.value,A.version):i.ifVersion(D,A?.version,()=>m.remove(g,D))}await CE()}}catch(k){Fe.default.error?.("Error in evicting old records",k)}finally{Fa=!1}}},pSe).unref()}a(Re,"runRecordExpirationEviction");function ft(k){if(k){let m=k.join(","),g=u.get([Symbol.for("residency_by_set"),m]);return g||(u.put([Symbol.for("residency_by_set"),m],g=Math.floor(Math.random()*2147483647)),u.put([Symbol.for("residency_by_id"),g],k),g)}}a(ft,"getResidencyId")}function mw(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 XK(){}function ySe(e){nW=e}function LT(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 PT(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return PT(+e);case"Float":return e==="null"?null:PT(+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;OSe.test(e)||(e+="Z");let n=new Date(e);return PT(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,UT.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function PT(e){if(isNaN(e))throw new SyntaxError;return e}function ZK(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 pw(e,t,r){return e?.then?e.then(t,r):t(e)}function MT(e,t){e[Fr]=t,e[ve]=t?.value??null,e[DE]=t?.version}function eW(e){return e!=null}function si(e){try{return JSON.stringify(e)}catch{return e}}function NSe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Us,fl,PE,tW,rW,Ed,yr,LE,ME,Fe,hl,El,UT,mSe,nW,pSe,SSe,jK,TSe,DE,gSe,Fr,wE,QK,RSe,hw,Pi,ba,ASe,zK,JK,bSe,JMe,OSe,CE,zf=De(()=>{Us=v(M()),fl=require("lmdb"),PE=v(nn()),tW=require("lodash"),rW=v(xd());Hs();im();Ed=v(te());Tb();yr=v(fe()),LE=v(Ji()),ME=v(Gs());Le();Qf();Fe=v(zl());cm();uc();hl=require("ordered-binary"),El=v(it());Ki();UT=v(J());Ol();gi();gT();Nf();mSe=new Uint8Array(9);mSe[8]=192;pSe=6e4,SSe=864e5;Ed.initSync();jK=Ed.get(Us.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),TSe=1e4,DE=Symbol.for("version"),gSe=Symbol.for("incremental-update"),Fr=Symbol("entry"),wE=Symbol("is-saving"),QK=1,RSe=2,hw=Symbol("loaded-from-source"),Pi=1,ba=8,ASe=Buffer.allocUnsafeSlow(8192),zK=1978,JK=100,bSe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},JMe=(0,UT.convertToMS)(Ed.get(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(vT,"makeTable");a(mw,"attributesAsObject");a(XK,"noop");a(ySe,"setServerUtilities");OSe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(LT,"coerceType");a(PT,"rejectNaN");a(ZK,"isDescendantId");CE=a(()=>new Promise(setImmediate),"rest");a(pw,"when");a(MT,"updateResource");a(eW,"exists");a(si,"stringify");a(NSe,"hasOtherProcesses")});var lt={};et(lt,{database:()=>Vl,databases:()=>We,dropDatabase:()=>FA,dropTableMeta:()=>PSe,getDatabases:()=>mt,getDefaultCompression:()=>Cp,getTables:()=>ISe,onRemovedDB:()=>V_,onUpdatedTable:()=>bc,readMetaDb:()=>UE,resetDatabases:()=>Cu,table:()=>Et,tables:()=>wn});function ISe(){return kT||mt(),wn||{}}function mt(){if(kT)return We;kT=!0,pd=new Map;let e=(0,tr.getHdbBasePath)()&&(0,vt.join)((0,tr.getHdbBasePath)(),Tr.DATABASES_DIR_NAME),t=(0,tr.get)(Tr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,Xn.existsSync)(e)?e:(0,vt.join)((0,tr.getHdbBasePath)(),Tr.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,Xn.existsSync)(e))for(let n of(0,Xn.readdirSync)(e,{withFileTypes:!0})){let s=(0,vt.basename)(n.name,".mdb");n.isFile()&&(0,vt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&UE((0,vt.join)(e,n.name),null,s)}if((0,Xn.existsSync)((0,md.getBaseSchemaPath)())){for(let n of(0,Xn.readdirSync)((0,md.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,vt.join)((0,md.getBaseSchemaPath)(),n.name),i=(0,vt.join)((0,md.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,Xn.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,vt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,vt.join)(i,o.name);UE((0,vt.join)(s,o.name),(0,vt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,Xn.existsSync)(i))for(let c of(0,Xn.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,vt.extname)(c.name).toLowerCase()===".mdb"&&UE((0,vt.join)(i,c.name),(0,vt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],d=(0,vt.join)(l.path,(0,vt.basename)(c+".mdb"));(0,Xn.existsSync)(d)&&UE(d,c,n,null,!0)}}for(let n in We){let s=pd.get(n);if(s){let i=We[n];n.includes("delete")&&Vt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Vt.trace(`delete table class ${o}`),delete i[o])}else if(delete We[n],n==="data"){for(let i in wn)delete wn[i];delete wn[FT]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(We.system)for(let n of r)We.system[n]&&(We.system[n].replicate=!1);return pd=null,We}function Cu(){kT=!1;for(let[,e]of Ha)e.needsDeletion=!0;mt();for(let[e,t]of Ha)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Ha.delete(e),delete We[t.databaseName],BE.forEach(r=>r(t.databaseName)));return We}function UE(e,t,r=gw,n,s){let i=new Sw.default(e,!1);try{let o=Ha.get(e);o?o.needsDeletion=!1:(o=(0,Sd.open)(i),Ha.set(e,o));let c=new ml.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(BT.INTERNAL_DBIS_NAME,c)),d=o.auditStore;d||(n?(0,Xn.existsSync)(n)&&(i.path=n,d=(0,Sd.open)(i),d.isLegacy=!0):d=TT(o));let u=aW(r),_=u[FT],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[T,S]=f.toString().split("/");S===""?S=h.name:S||(S=T,T=t,h.name||(h.name=S,h.indexed=!h.is_hash_attribute)),_?.add(T);let R=E.get(T);R||E.set(T,R={attributes:[]}),(S==null||h.is_hash_attribute)&&(R.primary=h),S!=null&&R.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:T,primary:S}=h;if(!S){for(let j of T)if(j.is_hash_attribute||j.isPrimaryKey){S=j;break}if(!S){Vt.warn(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(T)}`);continue}}let R=u[f],p={},y=[],O,B,x=typeof S.audit=="boolean"?S.audit:(0,tr.get)(Tr.CONFIG_PARAMS.LOGGING_AUDITLOG),W=S.trackDeletes,q=S.expiration,z=S.eviction,_e=S.sealed,X=S.splitSegments,ue=S.replicate;if(R)p=R.indices,y=R.attributes,R.schemaVersion++;else{O=S.tableId,O?O>=(l.get(hd)||0)&&(l.putSync(hd,O+1),Vt.info(`Updating next table id (it was out of sync) to ${O+1} for ${f}`)):(S.tableId=O=l.get(hd),O||(O=1),Vt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(hd,O+1),l.putSync(S.key,S));let j=new ml.default(!S.is_hash_attribute,S.is_hash_attribute);if(j.compression=S.compression,j.compression){let ie=(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||oW;j.compression.threshold=ie}B=Sh(o.openDB(S.key,j)),o.databaseName=r,B.rootStore=o,B.tableId=O}for(let j of T){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!p[j.name]){let ye=new ml.default(!j.is_hash_attribute,j.is_hash_attribute);p[j.name]=o.openDB(j.key,ye),p[j.name].indexNulls=j.indexNulls}let ie=y.find(ye=>ye.name===j.name);ie?y.splice(y.indexOf(ie),1,j):y.push(j)}}catch(ie){Vt.error("Error trying to update attribute",j,y,p,ie)}}if(!R){R=cW(u,f,vT({primaryStore:B,auditStore:d,audit:x,sealed:_e,splitSegments:X,replicate:ue,expirationMS:q&&q*1e3,evictionMS:z&&z*1e3,trackDeletes:W,tableName:f,tableId:O,primaryKey:S.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:p,attributes:T,schemaDefined:S.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let j of vE)j(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function aW(e){let t=We[e];if(t||(e==="data"?t=We[e]=wn:e==="system"?Object.defineProperty(We,"system",{value:t=Object.create(null),configurable:!0}):t=We[e]=Object.create(null)),pd&&!pd.has(e)){let r=new Set;t[FT]=r,pd.set(e,r)}return t}function cW(e,t,r){return e[t]=r,r}function Vl({database:e,table:t}){e||(e=gw),mt();let r=aW(e),n=(0,vt.join)((0,tr.getHdbBasePath)(),Tr.DATABASES_DIR_NAME),s=(0,tr.get)(Tr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_PATH)||((0,Xn.existsSync)(n)?n:(0,vt.join)((0,tr.getHdbBasePath)(),Tr.LEGACY_DATABASES_DIR_NAME));let o=(0,vt.join)(n,(i?t:e)+".mdb"),c=Ha.get(o);if(!c||c.status==="closed"){let l=new Sw.default(o,!1);c=(0,Sd.open)(l),Ha.set(o,c)}return c.auditStore||(c.auditStore=TT(c)),c}async function FA(e){if(!We[e])throw new Error("Schema does not exist");let t=We[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Ha.delete(r.path),r.status==="open"&&(await r.close(),await HE.remove(r.path));if(r||(r=Vl({database:e,table:null}),r.status==="open"&&(await r.close(),await HE.remove(r.path))),e==="data"){for(let n in wn)delete wn[n];delete wn[FT]}delete We[e],BE.forEach(n=>n(e))}function Et(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:d,replicate:u,trackDeletes:_,schemaDefined:E,origin:f}=e;r||(r=gw);let h=Vl({database:r,table:t}),T=We[r];Vt.trace(`Defining ${t} in ${r}`);let S=T?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let R,p,y;E==null&&(E=!0);let O=new ml.default(!1);for(let X of o)X.attribute&&!X.name?(X.name=X.attribute,X.indexed=!0):X.attribute=X.name,X.expiresAt&&(X.indexed=!0);let B,x;if(S){if(R=S.primaryKey,S.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);d==null&&(d=S.splitSegments),S.attributes.splice(0,S.attributes.length,...o)}else{let X=h.auditStore;p=o.find(ye=>ye.isPrimaryKey)||{},R=p.name,p.is_hash_attribute=p.isPrimaryKey=!0,p.schemaDefined=E,p.compression=Cp(),_&&(p.trackDeletes=!0),c=p.audit=typeof c=="boolean"?c:(0,tr.get)(Tr.CONFIG_PARAMS.LOGGING_AUDITLOG),n&&(p.expiration=n),s&&(p.eviction=s),p.splitSegments=!1,typeof l=="boolean"&&(p.sealed=l),typeof u=="boolean"&&(p.replicate=u),f&&(p.origins?p.origins.includes(f)||p.origins.push(f):p.origins=[f]),Vt.trace(`${t} table loading, opening primary store`);let ue=new ml.default(!1,!0);ue.compression=p.compression;let j=t+"/";if(y=h.dbisDb=h.openDB(BT.INTERNAL_DBIS_NAME,O),_e(),y.get(j))return x&&x(),Cu(),Et(e);let ie=Sh(h.openDB(j,ue));h.databaseName=r,ie.rootStore=h,ie.tableId=y.get(hd),Vt.trace(`Assigning new table id ${ie.tableId} for ${t}`),ie.tableId||(ie.tableId=1),y.put(hd,ie.tableId+1),p.tableId=ie.tableId,S=cW(T,t,vT({primaryStore:ie,auditStore:X,audit:c,sealed:l,splitSegments:d,replicate:u,trackDeletes:_,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:R,tableName:t,tableId:ie.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:E,dbisDB:y})),S.schemaVersion=1,B=!0,y.put(j,p)}let W=S.indices;y=y||(h.dbisDb=h.openDB(BT.INTERNAL_DBIS_NAME,O)),S.dbisDB=y;let q=[];for(let{key:X,value:ue}of y.getRange({start:!0})){let[j,ie]=X.toString().split("/");if(ie===""&&(ie=ue.name),ie){if(j!==t)continue}else continue;let ye=o.find(Me=>Me.name===ie),Ie=!ye?.indexed&&ue.indexed&&!ue.isPrimaryKey;if((!ye||Ie)&&(_e(),B=!0,ye||y.remove(X),Ie)){let Me=S.indices[j];Me&&q.push(Me)}}let z=[];try{for(let X of o||[]){if((X.relationship||X.computed)&&(B=!0,X.relationship))continue;let ue=t+"/"+(X.name||"");Object.defineProperty(X,"key",{value:ue,configurable:!0});let j=y.get(ue);if(X.isPrimaryKey){if(j=j||y.get(ue=t+"/")||{},c!==void 0&&c!==S.audit||l!==void 0&&l!==S.sealed||u!==void 0&&u!==S.replicate||(+n||void 0)!==(+j.expiration||void 0)||(+s||void 0)!==(+j.eviction||void 0)){let ye={...j};typeof c=="boolean"&&(c&&S.enableAuditing(c),ye.audit=c),n&&(ye.expiration=+n),s&&(ye.eviction=+s),l!==void 0&&(ye.sealed=l),u!==void 0&&(ye.replicate=u),B=!0,_e(),y.put(ue,ye)}continue}j?.attribute&&!j.name&&(j.indexed=!0);let ie=!j||j.type!==X.type||j.indexed!==X.indexed||j.nullable!==X.nullable||j.version!==X.version||JSON.stringify(j.attributes)!==JSON.stringify(X.attributes)||JSON.stringify(j.elements)!==JSON.stringify(X.elements);if(X.indexed){let ye=new ml.default(!0,!1),Ie=h.openDB(ue,ye);(ie||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<xE.workerData?.restartNumber)&&(B=!0,_e(),j=y.get(ue),(ie||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<xE.workerData?.restartNumber)&&(B=!0,X.indexNulls===void 0&&(X.indexNulls=!0),S.primaryStore.getStats().entryCount>0&&(X.lastIndexedKey=j?.lastIndexedKey??void 0,X.indexingPID=process.pid,Ie.isIndexing=!0,Object.defineProperty(X,"dbi",{value:Ie}),z.push(X))),y.put(ue,X)),j?.indexNulls&&X.indexNulls===void 0&&(X.indexNulls=!0),Ie.indexNulls=X.indexNulls,W[X.name]=Ie}else ie&&(B=!0,_e(),y.put(ue,X))}}finally{x&&x()}if(B&&(S.schemaVersion++,S.updatedAttributes()),Vt.trace(`${t} table loading, running index`),z.length>0||q.length>0?S.indexingOperation=DSe(S,z,q):B&&HT.signalSchemaChange(new xT.SchemaEventMsg(process.pid,"schema-change",S.databaseName,S.tableName)),S.origin=f,B)for(let X of vE)X(S,f!=="cluster");return(n||s||i)&&S.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Vt.trace(`${t} table loaded`),S;function _e(){x||h.transactionSync(()=>({then(X){x=X}}))}a(_e,"startTxn")}async function DSe(e,t,r){try{Vt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await HT.signalSchemaChange(new xT.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let d of r)s=d.drop();let i,o={},c=0,l=t.length;if(await new Promise(d=>setImmediate(d)),l>0){let d;for(let _ of t)(0,Sd.compareKeys)(_.lastIndexedKey,d)<0&&(d=_.lastIndexedKey),_.lastIndexedKey==null&&_.dbi.clearAsync();let u=0;for(let{key:_,value:E,version:f}of e.primaryStore.getRange({start:d,lazy:l<4,versions:!0,snapshot:!1}))if(E){if(u++,s=e.primaryStore.ifVersion(_,f,()=>{for(let h=0;h<l;h++){let T=t[h],S=T.name;try{let R=T.resolve,p=E&&(R?R(E):E[S]),y=(0,sW.getIndexedValues)(p);if(y)for(let O=0,B=y.length;O<B;O++)T.dbi.put(y[O],_)}catch(R){o[S]||(o[S]=!0,Vt.error(`Error indexing attribute ${S}`,R))}}}),s.then(()=>u--,h=>{u--,Vt.error(h)}),xE.workerData&&xE.workerData.restartNumber!==iW.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}u>wSe?await s:u>CSe&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await HT.signalSchemaChange(new xT.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Vt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Vt.error("Error in indexing",n)}}function PSe({table:e,database:t}){let r=Vl({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 bc(e){return vE.push(e),{remove(){let t=vE.indexOf(e);t>-1&&vE.splice(t,1)}}}function V_(e){return BE.push(e),{remove(){let t=BE.indexOf(e);t>-1&&BE.splice(t,1)}}}function Cp(){let e=(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||oW,n={startingOffset:32};return t&&(n.dictionary=HE.readFileSync(t)),r&&(n.threshold=r),e&&n}var tr,BT,Sd,vt,Xn,md,ml,Sw,Tr,HE,Tw,sW,HT,xT,xE,Vt,iW,gw,FT,oW,wn,We,hd,vE,BE,kT,Ha,pd,wSe,CSe,Le=De(()=>{tr=v(te()),BT=v(Bt()),Sd=require("lmdb"),vt=require("path"),Xn=require("fs"),md=v(gt());zf();ml=v(jd()),Sw=v(Qd()),Tr=v(M()),HE=v(require("fs-extra")),Tw=v(Vi()),sW=v(nn()),HT=v(Ji()),xT=v(Gs()),xE=require("worker_threads"),Vt=v(V()),iW=v(it());Ki();Ol();gw="data",FT=Symbol("defined-tables"),oW=((0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,tr.initSync)();wn=Object.create(null),We=Object.create(null);(0,Tw._assignPackageExport)("databases",We);(0,Tw._assignPackageExport)("tables",wn);hd=Symbol.for("next-table-id"),vE=[],BE=[],Ha=new Map;a(ISe,"getTables");a(mt,"getDatabases");a(Cu,"resetDatabases");a(UE,"readMetaDb");a(aW,"ensureDB");a(cW,"setTable");a(Vl,"database");a(FA,"dropDatabase");a(Et,"table");wSe=1e3,CSe=10;a(DSe,"runIndexing");a(PSe,"dropTableMeta");a(bc,"onUpdatedTable");a(V_,"onRemovedDB");a(Cp,"getDefaultCompression")});var J=b((oUe,AW)=>{"use strict";var xa=require("path"),fW=require("fs-extra"),bn=V(),lW=require("fs-extra"),GT=require("os"),LSe=require("net"),MSe=require("recursive-iterator"),Yt=M(),USe=fg(),uW=require("papaparse"),qT=require("moment"),{inspect:vSe}=require("util"),dW=require("is-number"),iUe=require("lodash"),BSe=require("minimist"),HSe=require("https"),xSe=require("http"),{hdb_errors:$T}=fe(),kSe=/^((\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)))$/,EW=require("util").promisify(setTimeout),FSe=100,GSe=5,qSe="",$Se=4,_W={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};AW.exports={isEmpty:Zn,isEmptyOrZeroLength:qi,arrayHasEmptyValues:KSe,arrayHasEmptyOrZeroLengthValues:WSe,buildFolderPath:jSe,isBoolean:hW,errorizeMessage:VSe,stripFileExtension:zSe,autoCast:JSe,autoCastJSON:mW,autoCastJSONDeep:Aw,removeDir:XSe,compareVersions:ZSe,isCompatibleDataVersion:eTe,escapeRawValue:tTe,unescapeValue:rTe,stringifyProps:nTe,timeoutPromise:iTe,isClusterOperation:aTe,getClusterUser:lTe,checkGlobalSchemaTable:cTe,getHomeDir:SW,getPropsFilePath:sTe,promisifyPapaParse:uTe,removeBOM:TW,createEventPromise:dTe,checkProcessRunning:_Te,checkSchemaTableExist:fTe,checkSchemaExists:gW,checkTableExists:RW,getStartOfTomorrowInSeconds:ETe,getLimitKey:hTe,isObject:QSe,isNotEmptyAndHasValue:YSe,autoCasterIsNumberCheck:pW,backtickASTSchemaItems:mTe,isPortTaken:oTe,createForkArgs:pTe,autoCastBoolean:STe,async_set_timeout:EW,getTableHashAttribute:TTe,doesSchemaExist:gTe,doesTableExist:RTe,stringifyObj:ATe,ms_to_time:bTe,changeExtension:yTe,getEnvCliRootPath:bw,noBootFile:OTe,httpRequest:NTe,transformReq:ITe,convertToMS:wTe,PACKAGE_ROOT:Yt.PACKAGE_ROOT};function VSe(e){return e instanceof Error?e:new Error(e)}a(VSe,"errorizeMessage");function Zn(e){return e==null}a(Zn,"isEmpty");function YSe(e){return!Zn(e)&&(e||e===0||e===""||hW(e))}a(YSe,"isNotEmptyAndHasValue");function qi(e){return Zn(e)||e.length===0||e.size===0}a(qi,"isEmptyOrZeroLength");function KSe(e){if(Zn(e))return!0;for(let t=0;t<e.length;t++)if(Zn(e[t]))return!0;return!1}a(KSe,"arrayHasEmptyValues");function WSe(e){if(qi(e))return!0;for(let t=0;t<e.length;t++)if(qi(e[t]))return!0;return!1}a(WSe,"arrayHasEmptyOrZeroLengthValues");function jSe(...e){try{return e.join(xa.sep)}catch{console.error(e)}}a(jSe,"buildFolderPath");function hW(e){return Zn(e)?!1:e===!0||e===!1}a(hW,"isBoolean");function QSe(e){return Zn(e)?!1:typeof e=="object"}a(QSe,"isObject");function zSe(e){return qi(e)?qSe:e.slice(0,-$Se)}a(zSe,"stripFileExtension");function JSe(e){return Zn(e)||e===""||typeof e!="string"?e:_W[e]!==void 0?_W[e]:pW(e)===!0?Number(e):kSe.test(e)?new Date(e):e}a(JSe,"autoCast");function mW(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(mW,"autoCastJSON");function Aw(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=Aw(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=Aw(r);n!==r&&(e[t]=n)}return e}else return mW(e)}a(Aw,"autoCastJSONDeep");function pW(e){if(e.startsWith("0.")&&dW(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&dW(e))}a(pW,"autoCasterIsNumberCheck");async function XSe(e){if(qi(e))throw new Error(`Directory path: ${e} does not exist`);try{await lW.emptyDir(e),await lW.remove(e)}catch(t){throw bn.error(`Error removing files in ${e} -- ${t}`),t}}a(XSe,"removeDir");function ZSe(e,t){if(qi(e)){bn.info("Invalid current version sent as parameter.");return}if(qi(t)){bn.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 d=0;d<l;d++)if(r=parseInt(o[d],10)-parseInt(c[d],10),r)return r;return o.length-c.length}a(ZSe,"compareVersions");function eTe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(eTe,"isCompatibleDataVersion");function tTe(e){if(Zn(e))return e;let t=String(e);return t==="."?Yt.UNICODE_PERIOD:t===".."?Yt.UNICODE_PERIOD+Yt.UNICODE_PERIOD:t.replace(Yt.FORWARD_SLASH_REGEX,Yt.UNICODE_FORWARD_SLASH)}a(tTe,"escapeRawValue");function rTe(e){if(Zn(e))return e;let t=String(e);return t===Yt.UNICODE_PERIOD?".":t===Yt.UNICODE_PERIOD+Yt.UNICODE_PERIOD?"..":String(e).replace(Yt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(rTe,"unescapeValue");function nTe(e,t){if(Zn(e))return bn.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+GT.EOL}!qi(n)&&n[0]===";"?r+=" "+n+s+GT.EOL:qi(n)||(r+=n+"="+s+GT.EOL)}catch{bn.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(nTe,"stringifyProps");function SW(){let e;try{e=GT.homedir()}catch{e=process.env.HOME}return e}a(SW,"getHomeDir");function sTe(){let e=xa.join(SW(),Yt.HDB_HOME_DIR_NAME,Yt.BOOT_PROPS_FILE_NAME);return fW.existsSync(e)||(e=xa.join(__dirname,"../","hdb_boot_properties.file")),e}a(sTe,"getPropsFilePath");function iTe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(iTe,"timeoutPromise");async function oTe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=LSe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(oTe,"isPortTaken");function aTe(e){try{return Yt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){bn.error(`Error checking operation against cluster ops ${t}`)}return!1}a(aTe,"isClusterOperation");function cTe(e,t){let r=(Le(),oe(lt)).getDatabases();if(!r[e])return $T.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return $T.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(cTe,"checkGlobalSchemaTable");function lTe(e,t){if(Zn(t)){bn.warn("No CLUSTERING_USER defined, clustering disabled");return}if(Zn(e)||qi(e)){bn.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){bn.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){bn.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(lTe,"getClusterUser");function uTe(){uW.parsePromise=function(e,t,r){return new Promise(function(n,s){uW.parse(e,{header:!0,transformHeader:TW,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(uTe,"promisifyPapaParse");function TW(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(TW,"removeBOM");function dTe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;bn.info(`Got cluster status event response: ${vSe(s)}`);try{i.cancel()}catch{bn.error("Error trying to cancel timeout.")}n(s)})})}a(dTe,"createEventPromise");async function _Te(e){let t=!0,r=0;do await EW(FSe*r++),(await USe.findPs(e)).length>0&&(t=!1);while(t&&r<GSe);if(t)throw new Error(`process ${e} was not started`)}a(_Te,"checkProcessRunning");function fTe(e,t){let r=gW(e);if(r)return r;let n=RW(e,t);if(n)return n}a(fTe,"checkSchemaTableExist");function gW(e){let{getDatabases:t}=(Le(),oe(lt));if(!t()[e])return $T.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(gW,"checkSchemaExists");function RW(e,t){let{getDatabases:r}=(Le(),oe(lt));if(!r()[e][t])return $T.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(RW,"checkTableExists");function ETe(){let e=qT().utc().add(1,Yt.MOMENT_DAYS_TAG).startOf(Yt.MOMENT_DAYS_TAG).unix(),t=qT().utc().unix();return e-t}a(ETe,"getStartOfTomorrowInSeconds");function hTe(){return qT().utc().format("DD-MM-YYYY")}a(hTe,"getLimitKey");function mTe(e){try{let t=new MSe(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){bn.error("Got an error back ticking items."),bn.error(t)}}a(mTe,"backtickASTSchemaItems");function pTe(e){return[e]}a(pTe,"createForkArgs");function STe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(STe,"autoCastBoolean");function TTe(e,t){let{getDatabases:r}=(Le(),oe(lt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(TTe,"getTableHashAttribute");function gTe(e){let{getDatabases:t}=(Le(),oe(lt));return t()[e]!==void 0}a(gTe,"doesSchemaExist");function RTe(e,t){let{getDatabases:r}=(Le(),oe(lt));return r()[e]?.[t]!==void 0}a(RTe,"doesTableExist");function ATe(e){try{return JSON.stringify(e)}catch{return e}}a(ATe,"stringifyObj");function bTe(e){let t=qT.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(bTe,"ms_to_time");function yTe(e,t){let r=xa.basename(e,xa.extname(e));return xa.join(xa.dirname(e),r+t)}a(yTe,"changeExtension");function bw(){if(process.env[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=BSe(process.argv);if(e[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(bw,"getEnvCliRootPath");var Rw;function OTe(){if(Rw)return Rw;let e=bw();if(bw()&&fW.pathExistsSync(xa.join(e,Yt.HDB_CONFIG_FILE)))return Rw=!0,!0}a(OTe,"noBootFile");function NTe(e,t){let r;return e.protocol==="http:"?r=xSe:r=HSe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",l=>{c.body+=l}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(NTe,"httpRequest");function ITe(e){if(!e.schema&&!e.database){e.schema=Yt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(ITe,"transformReq");function wTe(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(wTe,"convertToMS")});var te=b((IW,wW)=>{"use strict";var yw=require("fs-extra"),pl=require("path"),bW=require("os"),CTe=require("properties-reader"),FE=V(),kE=J(),Pe=M(),VT=wt(),DTe="Error initializing environment manager",YT="BOOT_PROPS_FILE_PATH",yW=!1,PTe={[Pe.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Po={};Object.assign(IW,wW.exports={BOOT_PROPS_FILE_PATH:YT,getHdbBasePath:LTe,setHdbBasePath:MTe,get:OW,initSync:vTe,setProperty:Je,initTestEnvironment:HTe,setCloneVar:BTe});function LTe(){return Po[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(LTe,"getHdbBasePath");function MTe(e){Po[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(MTe,"setHdbBasePath");function OW(e){let t=VT.getConfigValue(e);return t===void 0?Po[e]:t}a(OW,"get");function Je(e,t){PTe[e]&&(Po[e]=t),VT.updateConfigObject(e,t)}a(Je,"setProperty");function UTe(){let e;try{e=kE.getPropsFilePath(),yw.accessSync(e,yw.constants.F_OK|yw.constants.R_OK),yW=!0;let t=CTe(e);return Po[Pe.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Pe.HDB_SETTINGS_NAMES.INSTALL_USER),Po[Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Po[YT]=e,!0}catch{return FE.trace(`Environment manager found no properties file at ${e}`),!1}}a(UTe,"doesPropFileExist");function vTe(e=!1){try{(yW||UTe()||kE.noBootFile())&&!NW&&(VT.initConfig(e),Po[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=VT.getConfigValue(Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){FE.error(DTe),FE.error(t),console.error(t),process.exit(1)}}a(vTe,"initSync");var NW=!1;function BTe(e){NW=e}a(BTe,"setCloneVar");function HTe(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=pl.join(__dirname,"../../","unitTests");Po[YT]=pl.join(l,"hdb_boot_properties.file"),Je(Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,pl.join(l,"settings.test")),Je(Pe.HDB_SETTINGS_NAMES.INSTALL_USER,bW.userInfo()?bW.userInfo().username:void 0),Je(Pe.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Je(Pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY,pl.join(l,"envDir","log")),Je(Pe.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Je(Pe.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Je(Pe.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Je(Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,pl.join(l,"envDir")),Je(Pe.CONFIG_PARAMS.STORAGE_PATH,pl.join(l,"envDir")),s&&(Je(Pe.CONFIG_PARAMS.HTTP_SECUREPORT,OW(Pe.CONFIG_PARAMS.HTTP_PORT)),Je(Pe.CONFIG_PARAMS.HTTP_PORT,null)),Je(Pe.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Je(Pe.CONFIG_PARAMS.HTTP_PORT,9926),Je(Pe.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Je(Pe.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Je(Pe.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,kE.isEmpty(i)?!1:i),Je(Pe.CONFIG_PARAMS.HTTP_CORS,kE.isEmpty(i)?!1:i),Je(Pe.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Je(Pe.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Je(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Je(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Je(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,pl.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Je(Pe.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,kE.isEmpty(c)?!1:c),o&&(Je("CORS_ACCESSLIST",o),Je(Pe.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Je(Pe.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Je(Pe.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Je(Pe.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Je(Pe.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Je(Pe.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Je(Pe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${YT}. Please check your boot props and settings files`;FE.fatal(r),FE.error(t)}}a(HTe,"initTestEnvironment")});var MW=b((lUe,LW)=>{"use strict";var PW=require("joi"),{string:GE,boolean:CW,array:xTe}=PW.types(),DW=M(),kTe=ut();LW.exports=FTe;function FTe(e){let t=PW.object({operation:GE.valid(DW.OPERATIONS_ENUM.ADD_NODE,DW.OPERATIONS_ENUM.UPDATE_NODE).required(),node_name:GE.required(),subscriptions:xTe.items({schema:GE.required(),table:GE.optional(),hash_attribute:GE.optional(),subscribe:CW.required(),publish:CW.required()}).min(1).required()});return kTe.validateBySchema(e,t)}a(FTe,"updateRemoteSourceValidator")});var qE=b((dUe,UW)=>{"use strict";var Ow=class{static{a(this,"UpdateRemoteResponseObject")}constructor(t,r,n=void 0){this.status=t,this.message=r,this.system_info=n}};UW.exports=Ow});var xW=b((fUe,HW)=>{"use strict";var GTe=MW(),Lo=V(),Nw=dt(),qTe=M(),Iw=hs(),Sl=kt(),vW=j_(),$Te=ql(),{Node:VTe,NodeSubscription:BW}=_a(),ww=qE(),Cw=J(),YTe=te(),{cloneDeep:KTe}=require("lodash"),{broadcast:WTe}=it();HW.exports=jTe;async function jTe(e){try{let t=GTe(e);if(t)return Lo.error(`Validation error in updateRemoteSource: ${t.message}`),new ww(Nw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let{subscriptions:r,node_name:n,system_info:s}=e,i=[],o=KTe(await Iw.getNodeRecord(n)),c=!Cw.isEmptyOrZeroLength(o);o=c?o[0]:o,c&&Lo.trace(`Existing record found for ${n}, updating records subscriptions`);for(let d=0,u=r.length;d<u;d++){let _=r[d],E=_.schema,f=_.table;if(!Cw.doesSchemaExist(E)){Lo.trace(`updateRemoteSource creating schema: ${E}`);try{await vW.createSchema({operation:"create_schema",schema:E})}catch(h){Lo.error(h)}}if(f&&!Cw.doesTableExist(E,f)){let h=new $Te(E,f,_.hash_attribute);_.attributes&&(h.attributes=_.attributes),Lo.trace(`updateRemoteSource creating table: ${f} in schema: ${E} with attributes: ${JSON.stringify(_.attributes)}`);try{await vW.createTable(h)}catch(T){Lo.error(T)}}if(Lo.trace(`Creating local stream for ${E}.${f}`),await Sl.createLocalTableStream(E,f),c?(await Sl.updateConsumerIterator(E,f,n,"stop"),await Sl.updateRemoteConsumer(_,n),_.subscribe===!0&&await Sl.updateConsumerIterator(E,f,n,"start")):(await Sl.updateRemoteConsumer(_,n),_.subscribe===!0?await Sl.updateConsumerIterator(E,f,n,"start"):await Sl.updateConsumerIterator(E,f,n,"stop")),c){let h=!1;for(let T=0,S=o.subscriptions.length;T<S;T++){let R=o.subscriptions[T];if(R.schema===E&&R.table===f){R.publish=_.publish,R.subscribe=_.subscribe,h=!0;break}}h||o.subscriptions.push(new BW(E,f,_.publish,_.subscribe))}else i.push(new BW(E,f,_.publish,_.subscribe))}c||(o=new VTe(n,i,void 0),Lo.trace(`No record found for ${n}, creating a new one`));let l=Object.create({});return Object.assign(l,o),l.system_info=s,await Iw.upsertNodeRecord(l),WTe({type:"nats_update"}),new ww(Nw.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${YTe.get(qTe.CONFIG_PARAMS.CLUSTERING_NODENAME)} successfully updated remote source`,await Iw.getSystemInfo())}catch(t){Lo.error(t);let r=t.message?t.message:t;return new ww(Nw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(jTe,"updateRemoteSource")});var qW=b((hUe,GW)=>{"use strict";var FW=require("joi"),{string:kW}=FW.types(),QTe=M(),zTe=ut();GW.exports=JTe;function JTe(e){let t=FW.object({operation:kW.valid(QTe.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:kW.required()});return zTe.validateBySchema(e,t)}a(JTe,"removeRemoteSourceValidator")});var YW=b((pUe,VW)=>{"use strict";var XTe=qW(),KT=V(),WT=dt(),Dw=M(),ZTe=hs(),ege=J(),$W=kt(),tge=te(),jT=qE(),{NodeSubscription:rge}=_a(),nge=Gl(),sge=Wo(),{broadcast:ige}=it(),oge=tge.get(Dw.CONFIG_PARAMS.CLUSTERING_NODENAME);VW.exports=age;async function age(e){try{let t=XTe(e);if(t)return KT.error(`Validation error in removeRemoteSource: ${t.message}`),new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let r=e.node_name,n=await ZTe.getNodeRecord(r);if(ege.isEmptyOrZeroLength(n)){let i=`No record found for node '${r}'`;return KT.error(i),new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,i)}n=n[0];for(let i=0,o=n.subscriptions.length;i<o;i++){let c=n.subscriptions[i];KT.trace(`remove remote source removing subscription: ${c.schema}.${c.table} for node: ${r}`);let l=new rge(c.schema,c.table,!1,!1);await $W.updateConsumerIterator(c.schema,c.table,r,"stop"),await $W.updateRemoteConsumer(l,r)}let s=new nge(Dw.SYSTEM_SCHEMA_NAME,Dw.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await sge.deleteRecord(s),ige({type:"nats_update"}),new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${oge} successfully removed node '${r}'.`)}catch(t){KT.error(t);let r=t.message?t.message:t;return new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(age,"removeRemoteSource")});var QW=b((TUe,jW)=>{"use strict";var QT=V(),$E=M(),KW=dt(),Pw=te(),cge=J(),WW=qE(),lge=hs(),uge=J_(),dge=Yr();jW.exports=_ge;async function _ge(e){try{QT.trace("getRemoteSourceConfig called");let t=process.uptime()*1e3,r=cge.ms_to_time(t),n=new fge(Pw.get($E.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),Pw.get($E.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)??Pw.get($E.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT),r,await lge.getSystemInfo());try{let s={name:e.node_name,system_info:e.system_info},i=new uge($E.SYSTEM_SCHEMA_NAME,$E.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[s]);await dge.update(i)}catch(s){QT.error("Get remote config encountered an error updating system info for node:",e.node_name,s)}return QT.trace("getRemoteSourceConfig response:",n),new WW(KW.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,n)}catch(t){QT.error(t);let r=t.message?t.message:t;return new WW(KW.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(_ge,"getRemoteSourceConfig");function fge(e,t,r,n){this.uptime=r,this.ports={clustering:e,operations_api:t},this.system_info=n}a(fge,"ConfigResponseObject")});var ZW=b((RUe,XW)=>{"use strict";var zW=te();zW.initSync();var JW=kt(),VE=V(),Td=M(),Lw=dt(),Ege=xW(),hge=YW(),mge=QW(),pge=qE(),{encode:Sge,decode:Tge}=require("msgpackr"),gge=as(),Rge=fi(),Age=require("util"),bge=M(),{isMainThread:yge,parentPort:Oge}=require("worker_threads");it();var Nge=Age.promisify(gge.setSchemaDataToGlobal),Mw=zW.get(Td.CONFIG_PARAMS.CLUSTERING_NODENAME);XW.exports=Ige;async function Ige(){try{VE.notify("Starting reply service."),await Nge();let e=await JW.getConnection(),t=`${Mw}.__request__`,r=e.subscribe(t,{queue:Mw});await wge(r)}catch(e){VE.error(e)}}a(Ige,"initialize");async function wge(e){for await(let t of e){let r=Tge(t.data),n;switch(r.operation){case Td.OPERATIONS_ENUM.ADD_NODE:case Td.OPERATIONS_ENUM.UPDATE_NODE:n=await Ege(r);break;case Td.OPERATIONS_ENUM.REMOVE_NODE:n=await hge(r);break;case Td.OPERATIONS_ENUM.CLUSTER_STATUS:n=await mge(r);break;case Td.OPERATIONS_ENUM.DESCRIBE_ALL:n=await Cge();break;default:let s=`node '${Mw}' reply service received unrecognized request operation`;VE.error(s),n=new pge(Lw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,s)}VE.trace(n),t.respond(Sge(n))}}a(wge,"handleRequest");async function Cge(){try{return{status:Lw.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,message:await Rge.describeAll({bypass_auth:!0})}}catch(e){return VE.error(e),{status:Lw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,message:e.message}}}a(Cge,"getRemoteDescribeAll");yge||Oge.on("message",async e=>{let{type:t}=e;t===bge.ITC_EVENT_TYPES.SHUTDOWN&&JW.closeConnection()})});var Dge=ZW();(async()=>{try{await Dge()}catch(e){console.error("Error launching Nats reply service."),console.error(e)}})();
|