harperdb 4.5.0-beta.1 → 4.5.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 +1 -1
- package/bin/harperdb.js +79 -79
- package/bin/lite.js +75 -75
- package/config/yaml/defaultConfig.yaml +2 -2
- package/json/systemSchema.json +3 -0
- package/launchServiceScripts/launchNatsIngestService.js +75 -75
- package/launchServiceScripts/launchNatsReplyService.js +76 -76
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +75 -75
- package/npm-shrinkwrap.json +198 -28
- package/package.json +3 -1
- package/resources/RecordEncoder.d.ts +5 -1
- package/resources/Resource.d.ts +1 -0
- package/resources/Resources.d.ts +11 -3
- package/resources/Table.d.ts +4 -3
- package/resources/blob.d.ts +1 -0
- package/resources/databases.d.ts +4 -3
- package/server/Server.d.ts +1 -0
- package/server/jobs/jobProcess.js +75 -75
- package/server/storageReclamation.d.ts +18 -0
- package/server/threads/threadServer.js +75 -75
- package/studio/build-local/asset-manifest.json +37 -37
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/running.html +86 -88
- package/studio/build-local/static/css/{main.60857e29.css → main.34b26890.css} +1 -1
- package/studio/build-local/static/js/{164.3490f18f.chunk.js → 164.6e0cda73.chunk.js} +1 -1
- package/studio/build-local/static/js/833.22ea9ecd.chunk.js +1 -0
- package/studio/build-local/static/js/{122.830d4399.chunk.js → 873.55a21fe5.chunk.js} +2 -2
- package/studio/build-local/static/js/{browse-csvupload.cdc5e843.chunk.js → browse-csvupload.1345356f.chunk.js} +1 -1
- package/studio/build-local/static/js/{browse-datatable.3f426683.chunk.js → browse-datatable.8d180288.chunk.js} +1 -1
- package/studio/build-local/static/js/{browse-entitymanager.e9b890eb.chunk.js → browse-entitymanager.3f0871ba.chunk.js} +1 -1
- package/studio/build-local/static/js/{browse-jsonviewer.d19731db.chunk.js → browse-jsonviewer.7ef3cb49.chunk.js} +1 -1
- package/studio/build-local/static/js/custom-functions.d7869749.chunk.js +1 -0
- package/studio/build-local/static/js/instance-cluster.ded77459.chunk.js +1 -0
- package/studio/build-local/static/js/instance-config.f3087710.chunk.js +1 -0
- package/studio/build-local/static/js/{instance-logs.1aaf5d15.chunk.js → instance-logs.fb150c6f.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-roles.7ac001d5.chunk.js → instance-roles.32b7be24.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-status.99235f8a.chunk.js → instance-status.d7ddf38a.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-users-datatable.30e06140.chunk.js → instance-users-datatable.68cb8e34.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-users-edit.d860ecc3.chunk.js → instance-users-edit.8de84af8.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-users.dc880abe.chunk.js → instance-users.ff289f79.chunk.js} +1 -1
- package/studio/build-local/static/js/instance.127e14b8.chunk.js +1 -0
- package/studio/build-local/static/js/instances.1dd2b960.chunk.js +1 -0
- package/studio/build-local/static/js/{main.9140b0ac.js → main.95db34b0.js} +2 -2
- package/studio/build-local/static/js/{offline-app.5bab91f6.chunk.js → offline-app.029491be.chunk.js} +1 -1
- package/studio/build-local/static/js/online-app.80d24598.chunk.js +1 -0
- package/studio/build-local/static/js/{organization-billing.75660563.chunk.js → organization-billing.586a6019.chunk.js} +1 -1
- package/studio/build-local/static/js/{organization-users.d913dc35.chunk.js → organization-users.0facdb34.chunk.js} +1 -1
- package/studio/build-local/static/js/{organization.2cbb1871.chunk.js → organization.4e2c7ae6.chunk.js} +1 -1
- package/studio/build-local/static/js/{organizations.b7abb2b5.chunk.js → organizations.c8c00251.chunk.js} +1 -1
- package/studio/build-local/static/js/{profile.cd02eab8.chunk.js → profile.a5fbf515.chunk.js} +1 -1
- package/studio/build-local/static/js/{resetPassword.f56c6a03.chunk.js → resetPassword.9ad8cde1.chunk.js} +1 -1
- package/studio/build-local/static/js/{roles-jsonviewer.891faeff.chunk.js → roles-jsonviewer.ad6e2622.chunk.js} +1 -1
- package/studio/build-local/static/js/signIn.3d65d81a.chunk.js +1 -0
- package/studio/build-local/static/js/signUp.eaa5b3f0.chunk.js +1 -0
- package/studio/build-local/static/js/{structure-reloader.4a977969.chunk.js → structure-reloader.8c8f5e18.chunk.js} +1 -1
- package/studio/build-local/static/js/topnav.73def1f2.chunk.js +1 -0
- package/studio/build-local/static/js/{updatePassword.f282bf0b.chunk.js → updatePassword.e0a672ee.chunk.js} +1 -1
- package/studio/build-local/static/media/logo_harper_db_studio.81490e70fa4af6879c2e.png +0 -0
- package/utility/hdbTerms.d.ts +5 -0
- package/utility/scripts/restartHdb.js +75 -75
- package/studio/build-local/static/js/833.3aff61e3.chunk.js +0 -1
- package/studio/build-local/static/js/custom-functions.d0e98d37.chunk.js +0 -1
- package/studio/build-local/static/js/instance-cluster.d5a2a397.chunk.js +0 -1
- package/studio/build-local/static/js/instance-config.347093bf.chunk.js +0 -1
- package/studio/build-local/static/js/instance.92e42f60.chunk.js +0 -1
- package/studio/build-local/static/js/instances.5ca66253.chunk.js +0 -1
- package/studio/build-local/static/js/online-app.38675097.chunk.js +0 -1
- package/studio/build-local/static/js/signIn.426c63a1.chunk.js +0 -1
- package/studio/build-local/static/js/signUp.2caeeae2.chunk.js +0 -1
- package/studio/build-local/static/js/topnav.d2fd9b1a.chunk.js +0 -1
- package/studio/build-local/static/media/logo_harper_db_studio.856391ec8a20ac3a6bee.png +0 -0
- /package/studio/build-local/static/js/{122.830d4399.chunk.js.LICENSE.txt → 873.55a21fe5.chunk.js.LICENSE.txt} +0 -0
- /package/studio/build-local/static/js/{main.9140b0ac.js.LICENSE.txt → main.95db34b0.js.LICENSE.txt} +0 -0
package/bin/harperdb.js
CHANGED
|
@@ -1,138 +1,138 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var BQ=Object.create;var Tf=Object.defineProperty;var HQ=Object.getOwnPropertyDescriptor;var kQ=Object.getOwnPropertyNames;var FQ=Object.getPrototypeOf,qQ=Object.prototype.hasOwnProperty;var a=(e,t)=>Tf(e,"name",{value:t,configurable:!0});var be=(e,t)=>()=>(e&&(t=e(e=0)),t);var C=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Be=(e,t)=>{for(var r in t)Tf(e,r,{get:t[r],enumerable:!0})},kP=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of kQ(t))!qQ.call(e,s)&&s!==r&&Tf(e,s,{get:()=>t[s],enumerable:!(n=HQ(t,s))||n.enumerable});return e};var x=(e,t,r)=>(r=e!=null?BQ(FQ(e)):{},kP(t||!e||!e.__esModule?Tf(r,"default",{value:e,enumerable:!0}):r,e)),D=e=>kP(Tf({},"__esModule",{value:!0}),e);var rt=C((Iye,GP)=>{var{join:GQ,dirname:FP}=require("node:path"),{existsSync:$Q,readFileSync:VQ}=require("node:fs");function KQ(){let t=__dirname,r,n=0;for(;!$Q(r=GQ(t,"package.json"));)if(t===(t=FP(t))||n++>10)throw new Error("Could not find package root");return r}a(KQ,"findPackageJson");var qP=KQ(),YQ=JSON.parse(VQ(qP,"utf8")),WQ=FP(qP);GP.exports={packageJson:YQ,PACKAGE_ROOT:WQ}});var Kp=C((Pye,$P)=>{if(__filename.endsWith("dev.js")){let e=require("fast-glob"),{tmpdir:t}=require("node:os"),{relative:r,join:n}=require("node:path"),{existsSync:s,statSync:i,readFileSync:o,writeFileSync:c}=require("node:fs"),{isMainThread:l}=require("node:worker_threads"),{spawnSync:u,spawn:f}=require("node:child_process"),{PACKAGE_ROOT:d}=rt(),h=["bin","components","dataLayer","resources","server","sqlTranslator","upgrade","utility","validation"],_="ts-build";if(l){let g=!1,T=!1;if((T=s(n(d,_)))?g=e.sync(h.map(m=>`${m}/**/*.ts`),{cwd:d}).some(m=>{let A=0,w=0;try{A=i(n(d,m)).mtimeMs-5e3,w=i(n(d,_,m.replace(/.ts$/,".js"))).mtimeMs}catch{}return A>w}):g=!0,g){console.log("Compiling TypeScript...");let m=u("npx",["tsc"],{cwd:d});if(m.stdout?.length&&console.log(m.stdout.toString()),m.stderr?.length&&console.log(m.stderr.toString()),T){let A=n(t(),"harperdb-tsc.pid"),w=!1;if(s(A))try{process.kill(+o(A,"utf8"),0),w=!0}catch{}if(!w){console.log("Starting background TypeScript compilation...");let M=f("npx",["tsc","--watch"],{detached:!0,cwd:d,stdio:"ignore"});c(A,M.pid.toString()),M.unref()}}}}let p=$P.constructor,S=p._findPath;p._findPath=function(g,T,m){if(g.startsWith(".")&&!m&&T.length===1&&T[0].startsWith(d)&&!T[0].includes("node_modules")){let A=r(d,T[0]),w;A.startsWith(_)?w=n(d,r(_,A)):w=n(d,_,A);let M=n(w,g),F=M+".js";if(s(F))return F;if(M.includes(".")&&s(M))return M}return S(g,T,m)}}});var q={};Be(q,{AUTH_AUDIT_STATUS:()=>Qs,AUTH_AUDIT_TYPES:()=>ha,BOOT_PROPS_FILE_NAME:()=>S2,BOOT_PROP_PARAMS:()=>YP,CLUSTERING_FLAG:()=>Y2,CLUSTERING_PROCESSES:()=>n2,CLUSTER_MESSAGE_TYPE_ENUM:()=>LA,CLUSTER_OPERATIONS:()=>U2,CONFIG_PARAMS:()=>H,CONFIG_PARAM_MAP:()=>WP,DATABASES_DIR_NAME:()=>yc,DATABASES_PARAM_CONFIG:()=>F2,DEFAULT_DATABASE_NAME:()=>i2,ESCAPED_FORWARD_SLASH_REGEX:()=>p2,FORWARD_SLASH_REGEX:()=>_2,FUNC_VAL:()=>X2,GEO_CONVERSION_ENUM:()=>B2,HDB_COMPONENT_CONFIG_FILE:()=>QQ,HDB_CONFIG_FILE:()=>zQ,HDB_DEFAULT_CONFIG_FILE:()=>jQ,HDB_FILE_PERMISSIONS:()=>A2,HDB_HOME_DIR_NAME:()=>m2,HDB_PID_FILE:()=>s2,HDB_PROCESS_SERVICES:()=>r2,HDB_PROC_NAME:()=>JQ,HDB_RESTART_SCRIPT:()=>XQ,HDB_ROOT_DIR_NAME:()=>IA,HDB_SETTINGS_NAMES:()=>H2,HDB_SUPPORT_ADDRESS:()=>KP,INFO_TABLE_HASH_ATTRIBUTE:()=>w2,INSERT_MAX_CHARACTER_SIZE:()=>O2,INSTALL_PROMPTS:()=>b2,ITC_EVENT_TYPES:()=>vA,JOB_STATUS_ENUM:()=>D2,JOB_TYPE_ENUM:()=>q2,JWT_ENUM:()=>Z2,LAUNCH_SERVICE_SCRIPTS:()=>c2,LEGACY_CONFIG_PARAMS:()=>k2,LEGACY_DATABASES_DIR_NAME:()=>zp,LICENSE_FILE_NAME:()=>P2,LICENSE_KEY_DIR_NAME:()=>g2,LICENSE_VALUES:()=>G2,LOG_LEVELS:()=>a2,LOG_NAMES:()=>o2,MEM_SETTING_KEY:()=>E2,METADATA_PROPERTY:()=>K2,NODE_ERROR_CODES:()=>V2,OPERATIONS_ENUM:()=>Vt,PERMS_CRUD_ENUM:()=>Q2,PERMS_UPDATE_RELEASE_TIMESTAMP:()=>j2,PRE_4_0_0_VERSION:()=>eJ,PROCESS_DESCRIPTORS:()=>t2,PROCESS_NAME_ENV_PROP:()=>y2,RAM_ALLOCATION_ENUM:()=>$2,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:()=>Jp,REG_KEY_FILE_NAME:()=>C2,RESTART_TIMEOUT_MS:()=>T2,ROLE_TYPES_ENUM:()=>l2,S3_BUCKET_AUTH_KEYS:()=>M2,SEARCH_NOT_FOUND_MESSAGE:()=>d2,SEARCH_WILDCARDS:()=>J2,SERVICE_ACTIONS_ENUM:()=>x2,SUPPORT_HELP_MSG:()=>u2,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:()=>I2,SYSTEM_SCHEMA_NAME:()=>DA,SYSTEM_TABLE_NAMES:()=>jp,THREAD_TYPES:()=>UA,TIME_STAMP_NAMES:()=>z2,TIME_STAMP_NAMES_ENUM:()=>W2,TRANSACTIONS_DIR_NAME:()=>R2,UNICODE_FORWARD_SLASH:()=>h2,UNICODE_PERIOD:()=>f2,UPGRADE_JSON_FIELD_NAMES_ENUM:()=>N2,VALID_S3_FILE_TYPES:()=>L2,VALID_SQL_OPS_ENUM:()=>v2,VALUE_SEARCH_COMPARATORS:()=>Qp,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>MA});var Yp,Wp,zQ,jQ,IA,QQ,JQ,XQ,VP,wA,CA,PA,ZQ,e2,t2,r2,n2,s2,i2,o2,a2,c2,l2,KP,u2,d2,f2,_2,h2,p2,E2,DA,m2,g2,S2,T2,A2,yc,zp,R2,y2,YP,b2,O2,N2,jp,w2,I2,C2,P2,D2,Vt,L2,M2,v2,U2,x2,B2,H2,k2,H,WP,F2,q2,LA,G2,$2,V2,K2,Y2,zP,jP,W2,z2,j2,Qp,MA,Q2,J2,X2,Jp,Z2,vA,UA,eJ,Qs,ha,v=be(()=>{Yp=require("node:path"),Wp=x(rt()),zQ="harperdb-config.yaml",jQ="defaultConfig.yaml",IA="hdb",QQ="config.yaml",JQ="harperdb.js",XQ="restartHdb.js",VP="HarperDB",wA="Custom Functions",CA="Clustering Hub",PA="Clustering Leaf",ZQ="Clustering Ingest Service",e2="Clustering Reply Service",t2={HDB:VP,CLUSTERING_HUB:CA,CLUSTERING_LEAF:PA,CLUSTERING_INGEST_SERVICE:ZQ,CLUSTERING_REPLY_SERVICE:e2,CUSTOM_FUNCTIONS:wA,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"},r2={harperdb:VP,"clustering hub":CA,"clustering leaf":PA,"custom functions":wA,custom_functions:wA,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},n2={CLUSTERING_HUB_PROC_DESCRIPTOR:CA,CLUSTERING_LEAF_PROC_DESCRIPTOR:PA},s2="hdb.pid",i2="data",o2={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},a2={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},c2={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:(0,Yp.join)(Wp.PACKAGE_ROOT,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:(0,Yp.join)(Wp.PACKAGE_ROOT,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:(0,Yp.join)(Wp.PACKAGE_ROOT,"launchServiceScripts/launchUpdateNodes4-0-0.js")},l2={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},KP="support@harperdb.io",u2=`For support, please submit a request at https://harperdbhelp.zendesk.com/hc/en-us/requests/new or contact ${KP}`,d2="None of the specified records were found.",f2="U+002E",_2=/\//g,h2="U+002F",p2=/U\+002F/g,E2="--max-old-space-size=",DA="system",m2=".harperdb",g2="keys",S2="hdb_boot_properties.file",T2=6e4,A2=448,yc="database",zp="schema",R2="transactions",y2="PROCESS_NAME",YP={SETTINGS_PATH_KEY:"settings_path"},b2={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"},O2=250,N2={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},jp={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"},w2="info_id",I2={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"},C2="060493.ks",P2=".license",D2={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},Vt={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts",GET_KEY:"get_key"},L2={CSV:".csv",JSON:".json"},M2={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},v2={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},U2={[Vt.INSERT]:Vt.INSERT,[Vt.UPDATE]:Vt.UPDATE,[Vt.UPSERT]:Vt.UPSERT,[Vt.DELETE]:Vt.DELETE},x2={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"},B2={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},H2={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"},k2={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"},H={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",AUTHENTICATION_HASHFUNCTION:"authentication_hashFunction",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",HTTP_HTTP2:"http_http2",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_NETWORK_HTTP2:"operationsApi_network_http2",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",REPLICATION_COPYTABLESTOCATCHUP:"replication_copyTablesToCatchUp",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_BLOBPATHS:"storage_blobPaths",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",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"},WP={settings_path:YP.SETTINGS_PATH_KEY,hdb_root_key:H.ROOTPATH,hdb_root:H.ROOTPATH,rootpath:H.ROOTPATH,server_port_key:H.OPERATIONSAPI_NETWORK_PORT,server_port:H.OPERATIONSAPI_NETWORK_PORT,cert_key:H.TLS_CERTIFICATE,certificate:H.TLS_CERTIFICATE,private_key_key:H.TLS_PRIVATEKEY,private_key:H.TLS_PRIVATEKEY,http_secure_enabled_key:H.OPERATIONSAPI_NETWORK_HTTPS,https_on:H.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:H.OPERATIONSAPI_NETWORK_CORS,cors_on:H.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:H.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:H.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:H.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:H.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:H.LOGGING_LEVEL,log_level:H.LOGGING_LEVEL,log_path_key:H.LOGGING_ROOT,log_path:H.LOGGING_ROOT,clustering_node_name_key:H.CLUSTERING_NODENAME,node_name:H.CLUSTERING_NODENAME,clustering_enabled_key:H.CLUSTERING_ENABLED,clustering:H.CLUSTERING_ENABLED,max_http_threads:H.THREADS_COUNT,max_hdb_processes:H.THREADS_COUNT,server_timeout_key:H.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:H.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:H.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:H.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:H.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:H.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:H.LOGGING_AUDITLOG,disable_transaction_log:H.LOGGING_AUDITLOG,operation_token_timeout_key:H.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:H.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:H.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:H.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:H.HTTP_PORT,custom_functions_port:H.HTTP_PORT,custom_functions_directory_key:H.COMPONENTSROOT,custom_functions_directory:H.COMPONENTSROOT,max_custom_function_processes:H.THREADS_COUNT,logging_console:H.LOGGING_CONSOLE,log_to_file:H.LOGGING_FILE,log_to_stdstreams:H.LOGGING_STDSTREAMS,local_studio_on:H.LOCALSTUDIO_ENABLED,clustering_port:H.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:H.CLUSTERING_USER,customfunctions_network_port:H.HTTP_PORT,customfunctions_tls_certificate:H.TLS_CERTIFICATE,customfunctions_network_cors:H.HTTP_CORS,customfunctions_network_corsaccesslist:H.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:H.HTTP_HEADERSTIMEOUT,customfunctions_network_https:H.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:H.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:H.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:H.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:H.HTTP_TIMEOUT,customfunctions_tls:H.TLS,http_threads:H.THREADS_COUNT,threads:H.THREADS_COUNT,threads_count:H.THREADS_COUNT,customfunctions_processes:H.THREADS_COUNT,customfunctions_root:H.COMPONENTSROOT,operationsapi_root:H.ROOTPATH};for(let e in H){let t=H[e];WP[t.toLowerCase()]=t}F2={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},q2={csv_file_load:"csv_file_load",csv_data_load:Vt.CSV_DATA_LOAD,csv_url_load:Vt.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},LA={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"},G2={VERSION_DEFAULT:"2.2.0"},$2={DEVELOPMENT:8192,DEFAULT:512},V2={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},K2=Symbol("metadata"),Y2="__clustering__",zP="__createdtime__",jP="__updatedtime__",W2={CREATED_TIME:zP,UPDATED_TIME:jP},z2=[zP,jP],j2=15984864e5,Qp={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},MA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},Q2={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},J2=["*","%"],X2="func_val",Jp={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},Z2={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},vA={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"},UA={HTTP:"http"},eJ="3.x.x",Qs={SUCCESS:"success",FAILURE:"failure"},ha={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var pa=C((Dye,XP)=>{"use strict";var QP=require("minimist");XP.exports=tJ;function tJ(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=JP(process.env),n=JP(QP(process.argv))):(r=process.env,n=QP(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(tJ,"assignCMDENVVariables");function JP(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(JP,"objKeysToLowerCase")});var bi=C(yi=>{"use strict";global.Resource=yi.Resource=void 0;global.tables=yi.tables={};global.databases=yi.databases={};global.getUser=yi.getUser=void 0;global.server=yi.server={};global.contentTypes=yi.contentTypes=null;global.threads=yi.threads=[];global.logger={};yi._assignPackageExport=(e,t)=>{global[e]=yi[e]=t}});var W=C((_D,hD)=>{"use strict";var co=require("fs-extra"),{workerData:rJ,threadId:nJ,isMainThread:sJ}=require("worker_threads"),Ni=require("path"),rD=require("yaml"),nD=require("properties-reader"),Kt=(v(),D(q)),ZP=pa(),iJ=require("os"),{PACKAGE_ROOT:kA}=rt(),{_assignPackageExport:oJ}=bi(),eD=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),mr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},sD={STDOUT:"stdOut",STDERR:"stdErr"},aJ=Ni.join(kA,"logs"),cJ=Ni.join(kA,"config/yaml/",Kt.HDB_DEFAULT_CONFIG_FILE),lJ=1e4,xA,Oi,ms,Lr,Xp,Af,Zp,Ea,Rf;Rf===void 0&&iD();Object.assign(_D,{notify:uD,fatal:dD,error:eE,warn:fD,info:aD,debug:lD,trace:cD,setLogLevel:mJ,log_level:Lr,loggerWithTag:fJ,suppressLogging:_J,initLogSettings:iD,logCustomLevel:pJ,closeLogFile:FA,logsAtLevel:uJ,getLogFilePath:a(()=>Zp,"getLogFilePath"),OUTPUTS:sD,AuthAuditLog:TJ});oJ("logger",hD.exports);var BA;function uJ(e){return mr[Lr]<=mr[e]}a(uJ,"logsAtLevel");function iD(e=!1){try{if(Rf===void 0||e){FA();let t=EJ(),r=ZP(["ROOTPATH"]);try{Rf=nD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!co.pathExistsSync(Ni.join(r.ROOTPATH,Kt.HDB_CONFIG_FILE)))throw n}if({level:Lr,config_log_path:Af,to_file:Oi,to_stream:ms}=gJ(r.ROOTPATH?Ni.join(r.ROOTPATH,Kt.HDB_CONFIG_FILE):Rf.get("settings_path")),Xp=Kt.LOG_NAMES.HDB,Zp=Ni.join(Af,Xp),sJ)try{require("segfault-handler").registerHandler(Ni.join(Af,"crash.log"))}catch{}}}catch(t){if(Rf=void 0,t.code===Kt.NODE_ERROR_CODES.ENOENT||t.code===Kt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=ZP(Object.keys(Kt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Kt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Kt.CONFIG_PARAMS.LOGGING_LEVEL){Lr=l;continue}if(c===Kt.CONFIG_PARAMS.LOGGING_STDSTREAMS){ms=l;continue}c===Kt.CONFIG_PARAMS.LOGGING_FILE&&(Oi=c),c===Kt.CONFIG_PARAMS.LOGGING_CONSOLE&&(xA=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=SJ();Oi=Oi===void 0?s:Oi,Oi=tD(Oi),ms=ms===void 0?i:ms,ms=tD(ms),Lr=Lr===void 0?n:Lr,Af=aJ,Xp=Kt.LOG_NAMES.INSTALL,Zp=Ni.join(Af,Xp);return}throw eE("Error initializing log settings"),eE(t),t}process.env.DEV_MODE&&(ms=!0),dJ()}a(iD,"initLogSettings");var ma=!0;function dJ(){Oi&&(process.stdout.write=function(e){return typeof e=="string"&&ma&&xA!==!1&&(HA(),e=e.toString(),e[e.length-1]===`
|
|
3
|
-
`&&(e=e.slice(0,-1)),
|
|
4
|
-
`&&(e=e.slice(0,-1)),
|
|
2
|
+
"use strict";var TJ=Object.create;var Rf=Object.defineProperty;var AJ=Object.getOwnPropertyDescriptor;var RJ=Object.getOwnPropertyNames;var yJ=Object.getPrototypeOf,bJ=Object.prototype.hasOwnProperty;var a=(e,t)=>Rf(e,"name",{value:t,configurable:!0});var be=(e,t)=>()=>(e&&(t=e(e=0)),t);var I=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),ve=(e,t)=>{for(var r in t)Rf(e,r,{get:t[r],enumerable:!0})},rD=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of RJ(t))!bJ.call(e,s)&&s!==r&&Rf(e,s,{get:()=>t[s],enumerable:!(n=AJ(t,s))||n.enumerable});return e};var M=(e,t,r)=>(r=e!=null?TJ(yJ(e)):{},rD(t||!e||!e.__esModule?Rf(r,"default",{value:e,enumerable:!0}):r,e)),C=e=>rD(Rf({},"__esModule",{value:!0}),e);var nt=I((Bye,iD)=>{var{join:OJ,dirname:nD}=require("node:path"),{existsSync:NJ,readFileSync:wJ}=require("node:fs");function IJ(){let t=__dirname,r,n=0;for(;!NJ(r=OJ(t,"package.json"));)if(t===(t=nD(t))||n++>10)throw new Error("Could not find package root");return r}a(IJ,"findPackageJson");var sD=IJ(),CJ=JSON.parse(wJ(sD,"utf8")),PJ=nD(sD);iD.exports={packageJson:CJ,PACKAGE_ROOT:PJ}});var rm=I((kye,oD)=>{if(__filename.endsWith("dev.js")){let e=require("fast-glob"),{tmpdir:t}=require("node:os"),{relative:r,join:n}=require("node:path"),{existsSync:s,statSync:i,readFileSync:o,writeFileSync:c}=require("node:fs"),{isMainThread:l}=require("node:worker_threads"),{spawnSync:u,spawn:f}=require("node:child_process"),{PACKAGE_ROOT:d}=nt(),p=["bin","components","dataLayer","resources","server","sqlTranslator","upgrade","utility","validation"],_="ts-build";if(l){let g=!1,A=!1;if((A=s(n(d,_)))?g=e.sync(p.map(E=>`${E}/**/*.ts`),{cwd:d}).some(E=>{let R=0,N=0;try{R=i(n(d,E)).mtimeMs-5e3,N=i(n(d,_,E.replace(/.ts$/,".js"))).mtimeMs}catch{}return R>N}):g=!0,g){console.log("Compiling TypeScript...");let E=u("npx",["tsc"],{cwd:d});if(E.stdout?.length&&console.log(E.stdout.toString()),E.stderr?.length&&console.log(E.stderr.toString()),A){let R=n(t(),"harperdb-tsc.pid"),N=!1;if(s(R))try{process.kill(+o(R,"utf8"),0),N=!0}catch{}if(!N){console.log("Starting background TypeScript compilation...");let v=f("npx",["tsc","--watch"],{detached:!0,cwd:d,stdio:"ignore"});c(R,v.pid.toString()),v.unref()}}}}let h=oD.constructor,S=h._findPath;h._findPath=function(g,A,E){if(g.startsWith(".")&&!E&&A.length===1&&A[0].startsWith(d)&&!A[0].includes("node_modules")){let R=r(d,A[0]),N;R.startsWith(_)?N=n(d,r(_,R)):N=n(d,_,R);let v=n(N,g),k=v+".js";if(s(k))return k;if(v.includes(".")&&s(v))return v}return S(g,A,E)}}});var G={};ve(G,{AUTH_AUDIT_STATUS:()=>zs,AUTH_AUDIT_TYPES:()=>ua,BOOT_PROPS_FILE_NAME:()=>t2,BOOT_PROP_PARAMS:()=>lD,CLUSTERING_FLAG:()=>w2,CLUSTERING_PROCESSES:()=>FJ,CLUSTER_MESSAGE_TYPE_ENUM:()=>zA,CLUSTER_OPERATIONS:()=>E2,CONFIG_PARAMS:()=>x,CONFIG_PARAM_MAP:()=>uD,DATABASES_DIR_NAME:()=>yc,DATABASES_PARAM_CONFIG:()=>A2,DEFAULT_DATABASE_NAME:()=>qJ,ESCAPED_FORWARD_SLASH_REGEX:()=>XJ,FORWARD_SLASH_REGEX:()=>QJ,FUNC_VAL:()=>M2,GEO_CONVERSION_ENUM:()=>S2,HDB_COMPONENT_CONFIG_FILE:()=>MJ,HDB_CONFIG_FILE:()=>DJ,HDB_DEFAULT_CONFIG_FILE:()=>LJ,HDB_FILE_PERMISSIONS:()=>n2,HDB_HOME_DIR_NAME:()=>e2,HDB_PID_FILE:()=>GJ,HDB_PROCESS_SERVICES:()=>kJ,HDB_PROC_NAME:()=>vJ,HDB_RESTART_SCRIPT:()=>UJ,HDB_ROOT_DIR_NAME:()=>$A,HDB_SETTINGS_NAMES:()=>WA,HDB_SUPPORT_ADDRESS:()=>cD,INFO_TABLE_HASH_ATTRIBUTE:()=>l2,INSERT_MAX_CHARACTER_SIZE:()=>a2,INSTALL_PROMPTS:()=>o2,ITC_EVENT_TYPES:()=>QA,JOB_STATUS_ENUM:()=>_2,JOB_TYPE_ENUM:()=>R2,JWT_ENUM:()=>bf,LAUNCH_SERVICE_SCRIPTS:()=>KJ,LEGACY_CONFIG_PARAMS:()=>T2,LEGACY_DATABASES_DIR_NAME:()=>im,LICENSE_FILE_NAME:()=>f2,LICENSE_KEY_DIR_NAME:()=>YA,LICENSE_VALUES:()=>y2,LOG_LEVELS:()=>VJ,LOG_NAMES:()=>$J,MEM_SETTING_KEY:()=>ZJ,METADATA_PROPERTY:()=>N2,NODE_ERROR_CODES:()=>O2,OPERATIONS_ENUM:()=>$t,PERMS_CRUD_ENUM:()=>D2,PERMS_UPDATE_RELEASE_TIMESTAMP:()=>P2,PRE_4_0_0_VERSION:()=>v2,PROCESS_DESCRIPTORS:()=>HJ,PROCESS_NAME_ENV_PROP:()=>i2,RAM_ALLOCATION_ENUM:()=>b2,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:()=>am,REG_KEY_FILE_NAME:()=>d2,RESTART_TIMEOUT_MS:()=>r2,ROLE_TYPES_ENUM:()=>YJ,S3_BUCKET_AUTH_KEYS:()=>h2,SEARCH_NOT_FOUND_MESSAGE:()=>zJ,SEARCH_WILDCARDS:()=>L2,SERVICE_ACTIONS_ENUM:()=>g2,SUPPORT_HELP_MSG:()=>WJ,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:()=>u2,SYSTEM_SCHEMA_NAME:()=>yf,SYSTEM_TABLE_NAMES:()=>du,THREAD_TYPES:()=>JA,TIME_STAMP_NAMES:()=>C2,TIME_STAMP_NAMES_ENUM:()=>I2,TRANSACTIONS_DIR_NAME:()=>s2,UNICODE_FORWARD_SLASH:()=>JJ,UNICODE_PERIOD:()=>jJ,UPGRADE_JSON_FIELD_NAMES_ENUM:()=>c2,VALID_S3_FILE_TYPES:()=>p2,VALID_SQL_OPS_ENUM:()=>m2,VALUE_SEARCH_COMPARATORS:()=>om,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>jA});var nm,sm,DJ,LJ,$A,MJ,vJ,UJ,aD,qA,VA,KA,xJ,BJ,HJ,kJ,FJ,GJ,qJ,$J,VJ,KJ,YJ,cD,WJ,zJ,jJ,QJ,JJ,XJ,ZJ,yf,e2,YA,t2,r2,n2,yc,im,s2,i2,lD,o2,a2,c2,du,l2,u2,d2,f2,_2,$t,p2,h2,m2,E2,g2,S2,WA,T2,x,uD,A2,R2,zA,y2,b2,O2,N2,w2,dD,fD,I2,C2,P2,om,jA,D2,L2,M2,am,bf,QA,JA,v2,zs,ua,B=be(()=>{nm=require("node:path"),sm=M(nt()),DJ="harperdb-config.yaml",LJ="defaultConfig.yaml",$A="hdb",MJ="config.yaml",vJ="harperdb.js",UJ="restartHdb.js",aD="HarperDB",qA="Custom Functions",VA="Clustering Hub",KA="Clustering Leaf",xJ="Clustering Ingest Service",BJ="Clustering Reply Service",HJ={HDB:aD,CLUSTERING_HUB:VA,CLUSTERING_LEAF:KA,CLUSTERING_INGEST_SERVICE:xJ,CLUSTERING_REPLY_SERVICE:BJ,CUSTOM_FUNCTIONS:qA,RESTART_HDB:"Restart HDB",INSTALL:"Install",RUN:"Run",STOP:"Stop",UPGRADE:"Upgrade",REGISTER:"Register",JOB:"Job",CLUSTERING_UPGRADE_4_0_0:"Upgrade-4-0-0"},kJ={harperdb:aD,"clustering hub":VA,"clustering leaf":KA,"custom functions":qA,custom_functions:qA,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},FJ={CLUSTERING_HUB_PROC_DESCRIPTOR:VA,CLUSTERING_LEAF_PROC_DESCRIPTOR:KA},GJ="hdb.pid",qJ="data",$J={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},VJ={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},KJ={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:(0,nm.join)(sm.PACKAGE_ROOT,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:(0,nm.join)(sm.PACKAGE_ROOT,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:(0,nm.join)(sm.PACKAGE_ROOT,"launchServiceScripts/launchUpdateNodes4-0-0.js")},YJ={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},cD="support@harperdb.io",WJ=`For support, please submit a request at https://harperdbhelp.zendesk.com/hc/en-us/requests/new or contact ${cD}`,zJ="None of the specified records were found.",jJ="U+002E",QJ=/\//g,JJ="U+002F",XJ=/U\+002F/g,ZJ="--max-old-space-size=",yf="system",e2=".harperdb",YA="keys",t2="hdb_boot_properties.file",r2=6e4,n2=448,yc="database",im="schema",s2="transactions",i2="PROCESS_NAME",lD={SETTINGS_PATH_KEY:"settings_path"},o2={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"},a2=250,c2={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},du={JOB_TABLE_NAME:"hdb_job",NODE_TABLE_NAME:"hdb_nodes",ATTRIBUTE_TABLE_NAME:"hdb_attribute",LICENSE_TABLE_NAME:"hdb_license",ROLE_TABLE_NAME:"hdb_role",SCHEMA_TABLE_NAME:"hdb_schema",TABLE_TABLE_NAME:"hdb_table",USER_TABLE_NAME:"hdb_user",INFO_TABLE_NAME:"hdb_info"},l2="info_id",u2={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"},d2="060493.ks",f2=".license",_2={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},$t={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts",GET_KEY:"get_key"},p2={CSV:".csv",JSON:".json"},h2={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},m2={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},E2={[$t.INSERT]:$t.INSERT,[$t.UPDATE]:$t.UPDATE,[$t.UPSERT]:$t.UPSERT,[$t.DELETE]:$t.DELETE},g2={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"},S2={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},WA={HDB_ROOT_KEY:"HDB_ROOT",SERVER_PORT_KEY:"SERVER_PORT",CERT_KEY:"CERTIFICATE",PRIVATE_KEY_KEY:"PRIVATE_KEY",HTTP_SECURE_ENABLED_KEY:"HTTPS_ON",CORS_ENABLED_KEY:"CORS_ON",CORS_WHITELIST_KEY:"CORS_WHITELIST",LOG_LEVEL_KEY:"LOG_LEVEL",LOGGER_KEY:"LOGGER",LOG_PATH_KEY:"LOG_PATH",LOG_ROTATE:"LOG_ROTATE",LOG_ROTATE_MAX_SIZE:"LOG_ROTATE_MAX_SIZE",LOG_ROTATE_RETAIN:"LOG_ROTATE_RETAIN",LOG_ROTATE_COMPRESS:"LOG_ROTATE_COMPRESS",LOG_ROTATE_DATE_FORMAT:"LOG_ROTATE_DATE_FORMAT",LOG_ROTATE_ROTATE_MODULE:"LOG_ROTATE_ROTATE_MODULE",LOG_ROTATE_WORKER_INTERVAL:"LOG_ROTATE_WORKER_INTERVAL",LOG_ROTATE_ROTATE_INTERVAL:"LOG_ROTATE_ROTATE_INTERVAL",LOG_ROTATE_TIMEZONE:"LOG_ROTATE_TIMEZONE",LOG_DAILY_ROTATE_KEY:"LOG_DAILY_ROTATE",LOG_MAX_DAILY_FILES_KEY:"LOG_MAX_DAILY_FILES",PROPS_ENV_KEY:"NODE_ENV",SETTINGS_PATH_KEY:"settings_path",CLUSTERING_PORT_KEY:"CLUSTERING_PORT",CLUSTERING_NODE_NAME_KEY:"NODE_NAME",CLUSTERING_ENABLED_KEY:"CLUSTERING",ALLOW_SELF_SIGNED_SSL_CERTS:"ALLOW_SELF_SIGNED_SSL_CERTS",MAX_HDB_PROCESSES:"MAX_HDB_PROCESSES",INSTALL_USER:"install_user",CLUSTERING_USER_KEY:"CLUSTERING_USER",MAX_CLUSTERING_PROCESSES:"MAX_CLUSTERING_PROCESSES",SERVER_TIMEOUT_KEY:"SERVER_TIMEOUT_MS",SERVER_KEEP_ALIVE_TIMEOUT_KEY:"SERVER_KEEP_ALIVE_TIMEOUT",SERVER_HEADERS_TIMEOUT_KEY:"SERVER_HEADERS_TIMEOUT",DISABLE_TRANSACTION_LOG_KEY:"DISABLE_TRANSACTION_LOG",OPERATION_TOKEN_TIMEOUT_KEY:"OPERATION_TOKEN_TIMEOUT",REFRESH_TOKEN_TIMEOUT_KEY:"REFRESH_TOKEN_TIMEOUT",CUSTOM_FUNCTIONS_ENABLED_KEY:"CUSTOM_FUNCTIONS",CUSTOM_FUNCTIONS_PORT_KEY:"CUSTOM_FUNCTIONS_PORT",CUSTOM_FUNCTIONS_DIRECTORY_KEY:"CUSTOM_FUNCTIONS_DIRECTORY",MAX_CUSTOM_FUNCTION_PROCESSES:"MAX_CUSTOM_FUNCTION_PROCESSES",LOG_TO_FILE:"LOG_TO_FILE",LOG_TO_STDSTREAMS:"LOG_TO_STDSTREAMS",RUN_IN_FOREGROUND:"RUN_IN_FOREGROUND",LOCAL_STUDIO_ON:"LOCAL_STUDIO_ON",STORAGE_WRITE_ASYNC:"STORAGE_WRITE_ASYNC"},T2={CUSTOMFUNCTIONS_ENABLED:"customFunctions_enabled",CUSTOMFUNCTIONS_NETWORK_PORT:"customFunctions_network_port",CUSTOMFUNCTIONS_TLS_CERTIFICATE:"customFunctions_tls_certificate",CUSTOMFUNCTIONS_NETWORK_CORS:"customFunctions_network_cors",CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST:"customFunctions_network_corsAccessList",CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT:"customFunctions_network_headersTimeout",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT:"customFunctions_network_keepAliveTimeout",CUSTOMFUNCTIONS_TLS_PRIVATEKEY:"customFunctions_tls_privateKey",CUSTOMFUNCTIONS_TLS_CERT_AUTH:"customFunctions_tls_certificateAuthority",CUSTOMFUNCTIONS_NETWORK_TIMEOUT:"customFunctions_network_timeout",CUSTOMFUNCTIONS_NODEENV:"customFunctions_nodeEnv",CUSTOMFUNCTIONS_ROOT:"customFunctions_root"},x={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",AUTHENTICATION_HASHFUNCTION:"authentication_hashFunction",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_CORSACCESSCONTROLALLOWHEADERS:"http_corsAccessControlAllowHeaders",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",HTTP_HTTP2:"http_http2",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_ROTATION_RETENTION:"logging_rotation_retention",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_NETWORK_HTTP2:"operationsApi_network_http2",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",REPLICATION_COPYTABLESTOCATCHUP:"replication_copyTablesToCatchUp",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_BLOBPATHS:"storage_blobPaths",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",STORAGE_RECLAMATION_THRESHOLD:"storage_reclamation_threshold",STORAGE_RECLAMATION_INTERVAL:"storage_reclamation_interval",STORAGE_RECLAMATION_EVICTIONFACTOR:"storage_reclamation_evictionFactor",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},uD={settings_path:lD.SETTINGS_PATH_KEY,hdb_root_key:x.ROOTPATH,hdb_root:x.ROOTPATH,rootpath:x.ROOTPATH,server_port_key:x.OPERATIONSAPI_NETWORK_PORT,server_port:x.OPERATIONSAPI_NETWORK_PORT,cert_key:x.TLS_CERTIFICATE,certificate:x.TLS_CERTIFICATE,private_key_key:x.TLS_PRIVATEKEY,private_key:x.TLS_PRIVATEKEY,http_secure_enabled_key:x.OPERATIONSAPI_NETWORK_HTTPS,https_on:x.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:x.OPERATIONSAPI_NETWORK_CORS,cors_on:x.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:x.LOGGING_LEVEL,log_level:x.LOGGING_LEVEL,log_path_key:x.LOGGING_ROOT,log_path:x.LOGGING_ROOT,clustering_node_name_key:x.CLUSTERING_NODENAME,node_name:x.CLUSTERING_NODENAME,clustering_enabled_key:x.CLUSTERING_ENABLED,clustering:x.CLUSTERING_ENABLED,max_http_threads:x.THREADS_COUNT,max_hdb_processes:x.THREADS_COUNT,server_timeout_key:x.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:x.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:x.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:x.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:x.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:x.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:x.LOGGING_AUDITLOG,disable_transaction_log:x.LOGGING_AUDITLOG,operation_token_timeout_key:x.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:x.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:x.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:x.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:x.HTTP_PORT,custom_functions_port:x.HTTP_PORT,custom_functions_directory_key:x.COMPONENTSROOT,custom_functions_directory:x.COMPONENTSROOT,max_custom_function_processes:x.THREADS_COUNT,logging_console:x.LOGGING_CONSOLE,log_to_file:x.LOGGING_FILE,log_to_stdstreams:x.LOGGING_STDSTREAMS,local_studio_on:x.LOCALSTUDIO_ENABLED,clustering_port:x.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:x.CLUSTERING_USER,customfunctions_network_port:x.HTTP_PORT,customfunctions_tls_certificate:x.TLS_CERTIFICATE,customfunctions_network_cors:x.HTTP_CORS,customfunctions_network_corsaccesslist:x.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:x.HTTP_HEADERSTIMEOUT,customfunctions_network_https:x.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:x.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:x.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:x.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:x.HTTP_TIMEOUT,customfunctions_tls:x.TLS,http_threads:x.THREADS_COUNT,threads:x.THREADS_COUNT,threads_count:x.THREADS_COUNT,customfunctions_processes:x.THREADS_COUNT,customfunctions_root:x.COMPONENTSROOT,operationsapi_root:x.ROOTPATH};for(let e in x){let t=x[e];uD[t.toLowerCase()]=t}A2={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},R2={csv_file_load:"csv_file_load",csv_data_load:$t.CSV_DATA_LOAD,csv_url_load:$t.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},zA={CLUSTERING_PAYLOAD:"clustering_payload",DELEGATE_THREAD_RESPONSE:"delegate_thread_response",CLUSTERING:"clustering",SCHEMA:"schema",CLUSTER_STATUS:"cluster_status",JOB:"job",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",USER:"user",RESTART:"restart"},y2={VERSION_DEFAULT:"2.2.0"},b2={DEVELOPMENT:8192,DEFAULT:512},O2={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},N2=Symbol("metadata"),w2="__clustering__",dD="__createdtime__",fD="__updatedtime__",I2={CREATED_TIME:dD,UPDATED_TIME:fD},C2=[dD,fD],P2=15984864e5,om={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},jA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},D2={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},L2=["*","%"],M2="func_val",am={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},bf={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},QA={SHUTDOWN:"shutdown",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",SCHEMA:"schema",USER:"user",CLUSTER_STATUS_RESPONSE:"cluster_status_response",CLUSTER_STATUS_REQUEST:"cluster_status_request",METRICS:"metrics",GET_METRICS:"get_metrics",RESTART:"restart",START_JOB:"start_job",NATS_CONSUMER_UPDATE:"nats_consumer_update"},JA={HTTP:"http"},v2="3.x.x",zs={SUCCESS:"success",FAILURE:"failure"},ua={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var da=I((Fye,hD)=>{"use strict";var _D=require("minimist");hD.exports=U2;function U2(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=pD(process.env),n=pD(_D(process.argv))):(r=process.env,n=_D(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(U2,"assignCMDENVVariables");function pD(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(pD,"objKeysToLowerCase")});var yi=I(js=>{"use strict";global.Resource=js.Resource=void 0;global.tables=js.tables={};global.databases=js.databases={};global.getUser=js.getUser=void 0;global.authenticateUser=js.authenticateUser=void 0;global.server=js.server={};global.contentTypes=js.contentTypes=null;global.threads=js.threads=[];global.logger={};js._assignPackageExport=(e,t)=>{global[e]=js[e]=t}});var Y=I((PD,DD)=>{"use strict";var ao=require("fs-extra"),{workerData:x2,threadId:B2,isMainThread:H2}=require("worker_threads"),Oi=require("path"),SD=require("yaml"),TD=require("properties-reader"),Vt=(B(),C(G)),mD=da(),k2=require("os"),{PACKAGE_ROOT:tR}=nt(),{_assignPackageExport:F2}=yi(),ED=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),hr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},AD={STDOUT:"stdOut",STDERR:"stdErr"},G2=Oi.join(tR,"logs"),q2=Oi.join(tR,"config/yaml/",Vt.HDB_DEFAULT_CONFIG_FILE),$2=1e4,XA,bi,Ss,Pr,cm,Of,lm,fa,Nf;Nf===void 0&&RD();Object.assign(PD,{notify:wD,fatal:ID,error:um,warn:CD,info:bD,debug:ND,trace:OD,setLogLevel:J2,log_level:Pr,loggerWithTag:Y2,suppressLogging:W2,initLogSettings:RD,logCustomLevel:j2,closeLogFile:rR,logsAtLevel:V2,getLogFilePath:a(()=>lm,"getLogFilePath"),OUTPUTS:AD,AuthAuditLog:e4});F2("logger",DD.exports);var ZA;function V2(e){return hr[Pr]<=hr[e]}a(V2,"logsAtLevel");function RD(e=!1){try{if(Nf===void 0||e){rR();let t=Q2(),r=mD(["ROOTPATH"]);try{Nf=TD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!ao.pathExistsSync(Oi.join(r.ROOTPATH,Vt.HDB_CONFIG_FILE)))throw n}if({level:Pr,config_log_path:Of,to_file:bi,to_stream:Ss}=X2(r.ROOTPATH?Oi.join(r.ROOTPATH,Vt.HDB_CONFIG_FILE):Nf.get("settings_path")),cm=Vt.LOG_NAMES.HDB,lm=Oi.join(Of,cm),H2)try{require("segfault-handler").registerHandler(Oi.join(Of,"crash.log"))}catch{}}}catch(t){if(Nf=void 0,t.code===Vt.NODE_ERROR_CODES.ENOENT||t.code===Vt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=mD(Object.keys(Vt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Vt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Vt.CONFIG_PARAMS.LOGGING_LEVEL){Pr=l;continue}if(c===Vt.CONFIG_PARAMS.LOGGING_STDSTREAMS){Ss=l;continue}c===Vt.CONFIG_PARAMS.LOGGING_FILE&&(bi=c),c===Vt.CONFIG_PARAMS.LOGGING_CONSOLE&&(XA=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=Z2();bi=bi===void 0?s:bi,bi=gD(bi),Ss=Ss===void 0?i:Ss,Ss=gD(Ss),Pr=Pr===void 0?n:Pr,Of=G2,cm=Vt.LOG_NAMES.INSTALL,lm=Oi.join(Of,cm);return}throw um("Error initializing log settings"),um(t),t}process.env.DEV_MODE&&(Ss=!0),K2()}a(RD,"initLogSettings");var _a=!0;function K2(){bi&&(process.stdout.write=function(e){return typeof e=="string"&&_a&&XA!==!1&&(eR(),e=e.toString(),e[e.length-1]===`
|
|
3
|
+
`&&(e=e.slice(0,-1)),ao.appendFileSync(fa,Qs("stdout",[e]))),ED.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&_a&&XA!==!1&&(eR(),e[e.length-1]===`
|
|
4
|
+
`&&(e=e.slice(0,-1)),ao.appendFileSync(fa,Qs("stderr",[e]))),ED.apply(process.stderr,arguments)})}a(K2,"stdioLogging");function Y2(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(wD,"notify"),fatal:n(ID,"fatal"),error:n(um,"error"),warn:n(CD,"warn"),info:n(bD,"info"),debug:n(ND,"debug"),trace:n(OD,"trace")};function n(s,i){return!t||hr[Pr]<=hr[i]?function(...o){return s(r,...o)}:null}}a(Y2,"loggerWithTag");function W2(e){try{_a=!1,e()}finally{_a=!0}}a(W2,"suppressLogging");var z2=x2?.name?.replace(/ /g,"-")||"main";function Qs(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||z2+"/"+B2);c<s;c++){let u=t[c];if(u instanceof Error&&u.stack)n+=u.stack,Object.keys(u).length>0&&(n+=`
|
|
5
5
|
`+JSON.stringify(u)),u.cause&&(t[c--]=u.cause,u&&(n+=`
|
|
6
6
|
Caused by:`));else if(typeof u=="object")try{n+=JSON.stringify(u)}catch{n+="Object ["+Object.keys(u)+"]"}else n+=u;c<i&&(n+=" ")}return`${r} [${o.join("] [")}]: ${n}
|
|
7
|
-
`}a(
|
|
8
|
-
`).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:RJ.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(NJ,"findPs")});var Mt=C((Bye,mD)=>{"use strict";var wJ="__dbis__",IJ="__txns__",CJ="__environment_name__",PJ="__dbi_defintion__",DJ={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"},LJ=["__createdtime__","__updatedtime__"],MJ="\uFFFF",ED={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},vJ=Object.values(ED);mD.exports={AUDIT_STORE_NAME:IJ,INTERNAL_DBIS_NAME:wJ,DBI_DEFINITION_NAME:PJ,SEARCH_TYPES:DJ,TIMESTAMP_NAMES:LJ,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:CJ,TRANSACTIONS_DBI_NAMES_ENUM:ED,TRANSACTIONS_DBIS:vJ,OVERFLOW_MARKER:MJ}});var Fn=C((Hye,ND)=>{"use strict";var gD=(v(),D(q)),SD=Mt(),TD={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},AD=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),RD={500:AD("There was an error processing your request."),400:"Invalid request"},UJ=RD[TD.INTERNAL_SERVER_ERROR],xJ={OP_NOT_SUPPORTED_FOR_FS:a(e=>`${e} is not available for this instance because it uses the File System data store.`,"OP_NOT_SUPPORTED_FOR_FS"),MISSING_VALUE:a(e=>`${e} is missing.`,"MISSING_VALUE"),INVALID_VALUE:a(e=>`${e} is invalid.`,"INVALID_VALUE"),NOT_FOUND:a(e=>`${e} not found.`,"NOT_FOUND")},BJ={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},HJ={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},kJ={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 ${SD.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${SD.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"},FJ={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${gD.INSERT_MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${gD.INSERT_MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},yD={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"},qJ={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:a(e=>`Operation '${e}' is restricted to 'super_user' roles`,"OP_IS_SU_ONLY"),OP_NOT_FOUND:a(e=>`Operation '${e}' not found`,"OP_NOT_FOUND"),SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:a((e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,"UNKNOWN_OP_AUTH_ERROR"),USER_HAS_NO_PERMS:a(e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,"USER_HAS_NO_PERMS"),DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},GJ={ATTR_PERM_MISSING:a((e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,"ATTR_PERM_MISSING"),ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:a((e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,"ATTR_PERM_NOT_BOOLEAN"),ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:a(e=>`Invalid attribute '${e}' in 'attribute_permissions'`,"INVALID_ATTRIBUTE_IN_PERMS"),INVALID_PERM_KEY:a(e=>`Invalid table permission key value '${e}'`,"INVALID_PERM_KEY"),INVALID_ATTR_PERM_KEY:a(e=>`Invalid attribute permission key value '${e}'`,"INVALID_ATTR_PERM_KEY"),INVALID_ROLE_JSON_KEYS:a(e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,"INVALID_ROLE_JSON_KEYS"),MISMATCHED_TABLE_ATTR_PERMS:a(e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,"MISMATCHED_TABLE_ATTR_PERMS"),OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:a(e=>`A role with name '${e}' already exists`,"ROLE_ALREADY_EXISTS"),ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:a(e=>`Your role does not have permission to view database metadata for '${e}'`,"SCHEMA_PERM_ERROR"),SCHEMA_TABLE_PERM_ERROR:a((e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,"SCHEMA_TABLE_PERM_ERROR"),SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:a(e=>`Value for '${e}' permission must be a boolean`,"SU_CU_ROLE_BOOLEAN_ERROR"),STRUCTURE_USER_ROLE_TYPE_ERROR:a(e=>`Value for '${e}' permission must be a boolean or Array`,"STRUCTURE_USER_ROLE_TYPE_ERROR"),SU_CU_ROLE_NO_PERMS_ALLOWED:a(e=>`Roles with '${e}' set to true cannot have other permissions set.`,"SU_CU_ROLE_NO_PERMS_ALLOWED"),SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:a(e=>`Missing table ${e.toUpperCase()} permission`,"TABLE_PERM_MISSING"),TABLE_PERM_NOT_BOOLEAN:a(e=>`Table ${e.toUpperCase()} permission must be a boolean`,"TABLE_PERM_NOT_BOOLEAN")},$J={ATTR_NOT_FOUND:a((e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,"ATTR_NOT_FOUND"),ATTR_EXISTS_ERR:a((e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,"ATTR_EXISTS_ERR"),DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:a(e=>`Invalid table ${JSON.stringify(e)}`,"INVALID_TABLE_ERR"),SCHEMA_NOT_FOUND:a(e=>`database '${e}' does not exist`,"SCHEMA_NOT_FOUND"),SCHEMA_EXISTS_ERR:a(e=>`database '${e}' already exists`,"SCHEMA_EXISTS_ERR"),TABLE_EXISTS_ERR:a((e,t)=>`Table '${t}' already exists in '${e}'`,"TABLE_EXISTS_ERR"),SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:a((e,t)=>`Table '${e}.${t}' does not exist`,"TABLE_NOT_FOUND"),TABLE_REQUIRED_ERR:"table is required"},VJ={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},KJ={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},bD={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},OD={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},YJ={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"},WJ={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},zJ={...yD,...HJ,...xJ,...qJ,...GJ,...$J,...VJ,...KJ,...FJ,...bD,...OD,...YJ,...WJ,...BJ};ND.exports={CHECK_LOGS_WRAPPER:AD,HDB_ERROR_MSGS:zJ,DEFAULT_ERROR_MSGS:RD,DEFAULT_ERROR_RESP:UJ,HTTP_STATUS_CODES:TD,LMDB_ERRORS_ENUM:kJ,AUTHENTICATION_ERROR_MSGS:yD,VALIDATION_ERROR_MSGS:bD,ITC_ERRORS:OD}});var _e=C((Fye,CD)=>{"use strict";var au=Fn(),jJ=W(),QJ=(v(),D(q)),rE=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,wD),this.statusCode=n||au.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(au.DEFAULT_ERROR_MSGS[n]?au.DEFAULT_ERROR_MSGS[n]:au.DEFAULT_ERROR_MSGS[au.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&&jJ[s](i)}},GA=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}},$A=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function wD(e,t,r,n=QJ.LOG_LEVELS.ERROR,s=null,i=!1){if(ID(e))return e;let o=new rE(e,t,r,n,s);return i&&delete o.stack,o}a(wD,"handleHDBError");function ID(e){return e.__proto__.constructor.name===rE.name}a(ID,"isHDBError");CD.exports={isHDBError:ID,handleHDBError:wD,ClientError:GA,ServerError:$A,hdb_errors:au}});var ht=C((Gye,xD)=>{"use strict";var If=(v(),D(q)),JJ=ae(),fn=ce(),Cf=require("path"),XJ=require("minimist"),PD=require("fs-extra"),DD=require("lodash");fn.initSync();var{CONFIG_PARAMS:ga,DATABASES_PARAM_CONFIG:bf,SYSTEM_SCHEMA_NAME:nE}=If,Of,Nf,wf;function LD(){if(Of!==void 0)return Of;if(fn.getHdbBasePath()!==void 0)return Of=fn.get(ga.STORAGE_PATH)||Cf.join(fn.getHdbBasePath(),If.DATABASES_DIR_NAME),Of}a(LD,"getBaseSchemaPath");function MD(){if(Nf!==void 0)return Nf;if(fn.getHdbBasePath()!==void 0)return Nf=UD(nE),Nf}a(MD,"getSystemSchemaPath");function vD(){if(wf!==void 0)return wf;if(fn.getHdbBasePath()!==void 0)return wf=fn.get(If.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Cf.join(fn.getHdbBasePath(),If.TRANSACTIONS_DIR_NAME),wf}a(vD,"getTransactionAuditStoreBasePath");function ZJ(e,t){let r=fn.get(ga.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Cf.join(vD(),e.toString())}a(ZJ,"getTransactionAuditStorePath");function UD(e,t){e=e.toString(),t=t&&t.toString();let r=fn.get(If.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Cf.join(LD(),e)}a(UD,"getSchemaPath");function e4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,XJ(process.argv));let n=r[ga.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!JJ.isObject(n))throw o;i=n}for(let o of i){let c=o[nE];if(!c)continue;let l=fn.get(ga.DATABASES);l=l??{};let u=c?.tables?.[t]?.[bf.PATH];if(u)return DD.set(l,[nE,bf.TABLES,t,bf.PATH],u),fn.setProperty(ga.DATABASES,l),u;let f=c?.[bf.PATH];if(f)return DD.set(l,[nE,bf.PATH],f),fn.setProperty(ga.DATABASES,l),f}}let s=r[ga.STORAGE_PATH.toUpperCase()];if(s){if(!PD.pathExistsSync(s))throw new Error(s+" does not exist");let i=Cf.join(s,e);return PD.mkdirsSync(i),fn.setProperty(ga.STORAGE_PATH,s),i}return MD()}a(e4,"initSystemSchemaPaths");function t4(){Of=void 0,Nf=void 0,wf=void 0}a(t4,"resetPaths");xD.exports={getBaseSchemaPath:LD,getSystemSchemaPath:MD,getTransactionAuditStorePath:ZJ,getTransactionAuditStoreBasePath:vD,getSchemaPath:UD,initSystemSchemaPaths:e4,resetPaths:t4}});var _n=C((Yye,qD)=>{"use strict";var r4=Fn().LMDB_ERRORS_ENUM,Vye=require("lmdb"),n4=Mt(),Kye=require("buffer").Buffer,{OVERFLOW_MARKER:BD,MAX_SEARCH_KEY_LENGTH:sE}=n4,HD=["number","string","symbol","boolean","bigint"];function s4(e){if(e=e?.primaryStore||e,!e)throw new Error(r4.ENV_REQUIRED)}a(s4,"validateEnv");function i4(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(i4,"stringifyData");function o4(e){return e instanceof Date?e.valueOf():e}a(o4,"convertKeyValueToWrite");function a4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(HD.includes(typeof e))return e.length>sE?[e.slice(0,sE)+BD]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(HD.includes(typeof i))i.length>sE?r.push(i.slice(0,sE)+BD):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(a4,"getIndexedValues");var iE=0,kD=0;function FD(){kD=Date.now()-performance.now()}a(FD,"adjustStartTime");FD();var c4=6e4;setInterval(FD,c4).unref();function l4(){let e=performance.now()+kD;return e>iE?(iE=e,e):(iE+=488e-6,iE)}a(l4,"getNextMonotonicTime");qD.exports={validateEnv:s4,stringifyData:i4,convertKeyValueToWrite:o4,getNextMonotonicTime:l4,getIndexedValues:a4}});var Pf=C((zye,GD)=>{"use strict";var u4=(v(),D(q)).OPERATIONS_ENUM,VA=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=u4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};GD.exports=VA});var Df=C((Jye,YD)=>{"use strict";var Qye=Pf(),oE=(v(),D(q)),KA=ae(),$D=W(),d4=require("uuid"),{handleHDBError:aE,hdb_errors:f4}=_e(),{HDB_ERROR_MSGS:cE,HTTP_STATUS_CODES:lE}=f4;YD.exports=VD;function VD(e,t,r){for(let s=0;s<t.length;s++)KD(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];_4(i,r,e.operation)}}a(VD,"processRows");VD.validateAttribute=KD;function KD(e){if(Buffer.byteLength(String(e))>oE.INSERT_MAX_CHARACTER_SIZE)throw aE(new Error,cE.ATTR_NAME_LENGTH_ERR(e),lE.BAD_REQUEST,void 0,void 0,!0);if(KA.isEmptyOrZeroLength(e)||KA.isEmpty(e.trim()))throw aE(new Error,cE.ATTR_NAME_NULLISH_ERR,lE.BAD_REQUEST,void 0,void 0,!0)}a(KD,"validateAttribute");function _4(e,t,r){if(!e.hasOwnProperty(t)||KA.isEmptyOrZeroLength(e[t])){if(r===oE.OPERATIONS_ENUM.INSERT||r===oE.OPERATIONS_ENUM.UPSERT){e[t]=d4.v4();return}throw $D.error("Update transaction aborted due to record with no hash value:",e),aE(new Error,cE.RECORD_MISSING_HASH_ERR,lE.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>oE.INSERT_MAX_CHARACTER_SIZE)throw $D.error(e),aE(new Error,cE.HASH_VAL_LENGTH_ERR,lE.BAD_REQUEST,void 0,void 0,!0)}a(_4,"validateHash")});var WD,qn,YA,cu=be(()=>{WD=require("events"),qn=class extends WD.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new YA;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)}},YA=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});function eL(e){zA=e}function m4(){E4=setInterval(function(){for(let e of WA)if(e.stale){let t=e.getContext()?.url;JD.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},p4).unref()}var jA,QD,JD,XD,ZD,zD,WA,h4,Lf,jD,zA,bc,uE,p4,E4,dE=be(()=>{jA=x(_n()),QD=x(_e()),JD=x(W()),XD=x(ce());v();ZD=x(ae()),zD=100,WA=new Set,h4=(0,ZD.convertToMS)(XD.get(H.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(eL,"replicationConfirmation");bc=class e{static{a(this,"DatabaseTransaction")}#e;writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),WA.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(WA.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(Lf&&!this.overloadChecked&&performance.now()-jD>h4)throw new QD.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,jA.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let _=d;_<this.validated;_++)this.writes[_]?.validate?.(this.timestamp);let h;for(let _=d;_<this.validated;_++){let p=this.writes[_];p&&(p.before||p.beforeIntermediate)&&(h=!0)}if(h)return(async()=>{try{for(let _=0;_<2;_++){let p;for(let S=d;S<this.validated;S++){let g=this.writes[S];if(!g)continue;let T=g[_===0?"before":"beforeIntermediate"];if(T){let m=T();p?p.push?p.push(m):p=[p,m]:p=m}}p&&await(p.push?Promise.all(p):p)}}catch(_){throw this.abort(),_}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let h=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||h}else l();else for(let h of this.writes)c(h)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<zD>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return Lf||(Lf=s,jD=performance.now(),Lf.then(()=>{Lf=null})),s.then(d=>{if(d){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let h=this.writes[0].store.rootStore.databaseName,_=this.writes[this.writes.length-1];zA&&_&&i.push(zA(h,_.store.getEntry(_.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+zD/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let f={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(h=>({txnTime:r,next:h}));f.next=d}return f}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}getContext(){return this.#e}setContext(t){this.#e=t}},uE=class extends bc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,jA.getNextMonotonicTime)())}getReadTxn(){}},p4=3e4;a(m4,"startMonitoringTxns");m4()});function Ot(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new bc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n.setContext(e),e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var tL,Oc=be(()=>{tL=x(bi());dE();a(Ot,"transaction");(0,tL._assignPackageExport)("transaction",Ot);Ot.commit=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ot.abort=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});function JA(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let d=u(l);for(let _=1;_<e.length;_++){let p=e[_],S=u(p);d=d.concat(S)}let h=new Set;return d.filter(_=>{let p=_.key??_;return h.has(p)?!1:(h.add(p),!0)})}else{let d=u(l),h=f(e.slice(1),!0,l.estimated_count);return h.length>0?o(d,h):d}function u(d){return d.conditions?JA(d.conditions,d.operator,r,n,s,i,o,c):du(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function f(d,h,_){return d.map((p,S)=>{if(p.conditions){let m=p.operator==="or",A=f(p.conditions,!m,_);return m?(w,M)=>A.some(F=>F(w,M)):(w,M)=>A.every(F=>F(w,M))}let g=(p.attribute||p[0])===r.primaryKey,T=Uf(p,r,i,c,g,_);return h&&S<d.length-1&&_&&(_=N4(r.primaryStore,p.estimated_count,_)),T}).filter(Boolean)}a(f,"mapConditionsToFilters")}function du(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(c===void 0&&l!=="sort")throw new pn.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let m=o[0],A=Ii(n.attributes,m);if(A.relationship){if(o.length<2)throw new pn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let w=A.definition?.tableClass||A.elements?.definition?.tableClass,M=new Map,F=du({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,w,s,M);if(A.relationship.to){i[o[0]]=M;let G=!!Ii(w.attributes,A.relationship.to)?.elements;F=R4(F,A,w.primaryStore,G,M)}if(A.relationship.from){let G=a(K=>(K?.key!==void 0&&(K=K.key),du({attribute:A.relationship.from,value:K},t,r,n,s,M)),"searchEntry");A.elements?(i[o[0]]=M,F=y4(F,A,w.primaryStore,M,G)):F=F.flatMap(G)}return F}else if(o.length===1)o=o[0];else throw new pn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,f,d,h;c instanceof Date&&(c=c.getTime());let _;switch(XA[l]||l){case"lt":u=!0,f=c;break;case"le":u=!0,f=c,d=!0;break;case"gt":u=c,h=!0;break;case"ge":u=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],u=c,f=c.slice(0),f[f.length-1]=wi.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),f=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),f=c[1],f instanceof Date&&(f=f.getTime()),d=l==="gele"||l==="gtle"||l==="between",h=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,f=c,d=!0;break;case"ne":if(c===null){u=c,h=!0;break}case"sort":case"contains":case"ends_with":u=!0,_=!0;break;default:throw new pn.ClientError(`Unknown query comparator "${l}"`)}let p,S=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>gs.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,gs.MAX_SEARCH_KEY_LENGTH)+gs.OVERFLOW_MARKER,h=!1,p=Uf(e,n,null,i,S)),typeof f=="string"&&f.length>gs.MAX_SEARCH_KEY_LENGTH&&(f=f.slice(0,gs.MAX_SEARCH_KEY_LENGTH)+gs.OVERFLOW_MARKER,d=!0,p=p??Uf(e,n,null,i,S)),r){let m=u;u=f,f=m,m=!h,h=!d,d=m}let g=S?n.primaryStore:n.indices[o];if(!g||g.isIndexing||_||c===null&&!g.indexNulls){if(s===!1&&!g)throw new pn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&_)throw new pn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(g?.isIndexing)throw new pn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&g&&!g.indexNulls)throw new pn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(p=p??Uf(e,n,null,i,S),!p)throw new pn.ClientError(`Unknown search operator ${e.comparator}`)}let T={start:u,end:f,inclusiveEnd:d,exclusiveStart:h,values:!0,versions:S,transaction:t,reverse:r};if(S){let m=g.getRange(T).map(p?function({key:A,value:w}){return this?.isSync?w&&p(w)?A:Sa.SKIP:new Promise((M,F)=>setImmediate(()=>{try{M(w&&p(w)?A:Sa.SKIP)}catch(G){F(G)}}))}:A=>A.value==null&&!(A.metadataFlags&(Ss|Aa))?Sa.SKIP:A);return m.hasEntries=!0,m}else return g?g.getRange(T).map(p?function({key:m,value:A}){let w;return typeof m=="string"&&m.length>gs.MAX_SEARCH_KEY_LENGTH?w=n.primaryStore.get(A):w={[o]:m},this.isSync?p(w)?A:Sa.SKIP:new Promise((M,F)=>setImmediate(()=>{try{M(p(w)?A:Sa.SKIP)}catch(G){F(G)}}))}:({value:m})=>m):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:m,value:A}){return this.isSync?A&&p(A)?m:Sa.SKIP:new Promise((w,M)=>setImmediate(()=>{try{w(A&&p(A)?m:Sa.SKIP)}catch(F){M(F)}}))})}function Ii(e,t){if(Array.isArray(t))if(t.length>1){let r=Ii(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Ii(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 R4(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=a((u,f)=>{let d=s.get(u);d?d.push(f):s.set(u,d=[f])},"add_entry");for(let u of e){let f=u.value??r.get(u.key??u),d=f?.[c];if(d!=null&&!s.filters?.some(h=>!h(f)))if(n)for(let h=0;h<d.length;h++)l(d[h],u);else l(d,u)}return i=s.keys()[Symbol.iterator](),this.next()}let o=i.next();return o.done?o:{value:o.value}},return(){if(i?.return)return i.return()}}}})}function y4(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=f=>f[t.relationship.from]?.filter?.(d=>u.has(d));for(let f of e){if(n.filters){let d=r.get(f);if(n.filters.some(h=>!h(d)))continue}u.add(f)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(o=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function Uf(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let f=c[0],d=Ii(t.attributes,f),h=d.definition?.tableClass||d.elements.definition?.tableClass,_=n?.[f],p=Uf({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},h,r,_?.[f]?.joined,c[1]===h.primaryKey,i);if(!p)return;if(_){_.filters||(_.filters=[]),_.filters.push(p);return}let S=t.propertyResolvers?.[f],g,T=a((m,A)=>{let w,M;if(S){if(S.from&&p.idFilter){if(!g)if(p.idFilter.idSet?.size===1){for(let G of p.idFilter.idSet)e={attribute:S.from,value:G};g=u(S.from,p.idFilter,!0,!0)}else g=u(S.from,p.idFilter,!1,!0);let F=g(m);return g.idFilter&&(T.idFilter=g.idFilter),F}M=S(m,r,A),w=M?.value}else w=m[f];return w?Array.isArray(w)?w.some(p):p(w,M):!1},"recordFilter");return T}}switch(l instanceof Date&&(l=l.getTime()),XA[o]||o){case gs.SEARCH_TYPES.EQUALS:case void 0:return u(c,f=>f===l,!0);case"contains":return u(c,f=>f?.toString().includes(l));case"ends_with":return u(c,f=>f?.toString().endsWith(l));case"starts_with":return u(c,f=>typeof f=="string"&&f.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,f=>{if(!Array.isArray(f))return!1;for(let d=0,h=l.length;d<h;d++)if(f[d]!==l[d])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,f=>(0,wi.compareKeys)(f,l[0])>=0&&(0,wi.compareKeys)(f,l[1])<=0,!0);case"gt":return u(c,f=>(0,wi.compareKeys)(f,l)>0);case"ge":return u(c,f=>(0,wi.compareKeys)(f,l)>=0);case"lt":return u(c,f=>(0,wi.compareKeys)(f,l)<0);case"le":return u(c,f=>(0,wi.compareKeys)(f,l)<=0);case"ne":return u(c,f=>(0,wi.compareKeys)(f,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new pn.ClientError(`Unknown query comparator "${o}"`)}function u(f,d,h,_){let p;h=h&&!s&&t?.indices[f]&&i>3,h&&(e.estimated_count==null&&_E(t)(e),p=e.estimated_count>>4,(isNaN(p)||p>=i)&&(h=!1));let S=0,g=3;function T(m){let A=m[f],w;if(typeof A!="object"||!A||_?w=d(A):Array.isArray(A)?w=A.some(d):A instanceof Date&&(w=d(A.getTime())),h&&(g++,!w&&!T.idFilter&&++S/g*(i-g)>p)){let M=du(e,r.transaction.getReadTxn(),!1,t).map(fu),F=new Set(M);T.idFilter=G=>F.has(fu(G)),T.idFilter.idSet=F}return w}return a(T,"recordFilter"),s&&(T.idFilter=d),T}a(u,"attributeComparator")}function _E(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/lo(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=XA[n]||n,n===gs.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=Ii(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=_E(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*lo(e.indices[i.relationship.from])/(lo(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=lo(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=T4*lo(e.primaryStore)+1:n==="between"?r.estimated_count=S4*lo(e.primaryStore)+1:n==="sort"?r.estimated_count=lo(e.primaryStore)+1:r.estimated_count=g4*lo(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function hE(e){if(e)if(Ta=e,lu.lastIndex=0,b4.test(e))try{let t=Mf(new uu,"");if(hn!==Ta.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${hn} in '${Ta}'`,t}else return new URLSearchParams(e)}function Mf(e,t){let r=lu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(Ta);){hn=r.lastIndex;let[,f,d]=n;if(o){if(f)throw new SyntaxError(`expected operator, but encountered '${f}'`);o=!1,c=!1}else c=!0;let h;switch(d){case"=":if(s!=null){if(f.length<=2)i=f;else throw new SyntaxError(`invalid FIQL operator ${f}`);l=rL}else{if(l=decodeURIComponent,i="equals",!f)throw new SyntaxError("attribute must be specified before equality comparator");s=vf(f)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=A4[d],l=QA[i]?rL:decodeURIComponent,!f)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=vf(f);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${d[0]?"'"+d[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${d?"'"+d+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let p={comparator:i,attribute:s||null,value:l(f)};if(i==="eq"&&nL(p,f),s===""){let S=e.conditions[e.conditions.length-1];S.chainedConditions=S.chainedConditions||[],S.chainedConditions.push(p),S.operator=u}else fE(e,u),e.conditions.push(p)}d==="&"?(u="and",s=void 0):d==="|"?(u="or",s=void 0):d==="&="?(u="and",s=""):d==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(vf(f)),s=void 0;break;case"(":lu.lastIndex=hn;let _=Mf(f?[]:new uu,")");switch(f){case"":fE(e,u),e.conditions.push(_);break;case"limit":switch(_.length){case 1:e.limit=+_[0];break;case 2:e.offset=+_[0],e.limit=_[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(_[0])&&_.length===1&&!_[0].name?(e.select=_[0],e.select.asArray=!0):_.length===1?e.select=_[0]:_.length===2&&_[1]===""?e.select=_.slice(0,1):e.select=_;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=sL(_);break;default:throw new SyntaxError(`unknown query function call ${f}`)}Ta[hn]===","?r.lastIndex=++hn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!f)throw new SyntaxError("property sets must have a defined parent property name");lu.lastIndex=hn,h=Mf([],"}"),h.name=f,e.push(h),Ta[hn]===","?r.lastIndex=++hn:o=!0;break;case"[":lu.lastIndex=hn,f?(h=Mf(new uu,"]"),h.name=f):h=Mf(e.conditions?new uu:[],"]"),e.conditions?(fE(e,u),e.conditions.push(h),s=null):e.push(h),Ta[hn]===","?r.lastIndex=++hn:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let p={comparator:i||"equals",attribute:s,value:l(f)};i==="eq"&&nL(p,f),fE(e,u),e.conditions.push(p)}else if(f)throw new SyntaxError("no attribute or comparison specified")}else(f||e.length>0&&c)&&e.push(vf(f));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${d[0]}'`):new SyntaxError(`unexpected token '${d[0]}'`);default:throw new SyntaxError(`unexpected operator '${d}'`)}if(t!==")"&&(r=s?O4:lu,r.lastIndex=hn),hn===Ta.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function fE(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 vf(e){return e.indexOf(".")>-1?e.split(".").map(vf):decodeURIComponent(e)}function rL(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 pn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function nL(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new pn.ClientError("wildcard can only be used at the end of a string")}function sL(e){let t=iL(e[0]);return e.length>1&&(t.next=sL(e.slice(1))),t}function iL(e){if(Array.isArray(e)){let t=iL(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 fu(e){return Array.isArray(e)?e.join("\0"):e}function lo(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function N4(e,t,r){return t*r/lo(e)}var pn,gs,wi,Sa,g4,S4,T4,A4,QA,XA,b4,lu,O4,hn,Ta,uu,Nc,xf=be(()=>{pn=x(_e()),gs=x(Mt()),wi=require("ordered-binary"),Sa=require("lmdb");Bf();g4=.3,S4=.1,T4=.05,A4={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},QA={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(JA,"executeConditions");a(du,"searchByIndex");a(Ii,"findAttribute");a(R4,"joinTo");a(y4,"joinFrom");XA={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(Uf,"filterByType");a(_E,"estimateCondition");b4=/[()[\]|!<>.]|(=\w*=)/,lu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,O4=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(hE,"parseQuery");a(Mf,"parseBlock");a(fE,"assignOperator");a(vf,"decodeProperty");a(rL,"typedDecoding");a(nL,"wildcardDecoding");a(sL,"toSortObject");a(iL,"toSortEntry");uu=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(fu,"flattenKey");a(lo,"estimatedEntryCount");a(N4,"intersectionEstimate");Nc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var eR={};Be(eR,{MultiPartId:()=>EE,Resource:()=>Kr,snake_case:()=>I4,transformForSelect:()=>mE});function I4(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function oL(e,t){if(wc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(wc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new EE;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){wc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return wc=!0,null;e[e.length-1]==="/"&&(wc=!0)}return t.coerceId(decodeURIComponent(e))}function Gn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,f;if(r?(o?(f=i,o=o.getContext?.()||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(f=s,c=f[this.primaryKey]??null,o=i.getContext?.()||i):f=i:(f=s,s=void 0,c=f.getId?.()??f[this.primaryKey]),c===null&&(u=!0)):i?o=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let _=c.indexOf("?");if(_>-1){let S=this.parseQuery(c.slice(_+1));l?S&&(l=Object.assign(S,l)):l=S,c=c.slice(0,_)}let p=this.parsePath(c,o,l);p?.id!==void 0?(p.query&&(l?l=Object.assign(p.query,l):l=p.query),u=p.isCollection,c=p.id):c=p}else if(s[Symbol.iterator]){c=[],u=!0;for(let _ of s){if(typeof _=="object"&&_)break;c.push(_)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Nc(c),c==null&&(u=!0);o||(o={});let d;if(l?.ensureLoaded!=null||l?.async||u?(d={...t},l?.ensureLoaded!=null&&(d.ensureLoaded=l.ensureLoaded),l?.async&&(d.async=l.async),u&&(d.isCollection=!0)):d=t,o.transaction){let _=this.getResource(c,o,d);return _.then?_.then(h):h(_)}else return Ot(o,()=>{let _=this.getResource(c,o,d);return _.then?_.then(h):h(_)},d);function h(_){if(o.authorize){o.authorize=!1;let p=t.type==="read"?_.allowRead(o.user,l,o):t.type==="update"?_.doesExist?.()===!1?_.allowCreate(o.user,f,o):_.allowUpdate(o.user,f,o):t.type==="create"?_.allowCreate(o.user,f,o):_.allowDelete(o.user,l,o);if(p?.then)return p.then(S=>{if(!S)throw new pE(o.user);return typeof f?.then=="function"?f.then(g=>e(_,l,o,g)):e(_,l,o,f)});if(!p)throw new pE(o.user)}return typeof f?.then=="function"?f.then(p=>e(_,l,o,p)):e(_,l,o,f)}a(h,"authorizeActionOnResource")}}function $n(e,t){let r=new lL.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 ZA(e,t,r){let n=e.getRecord?.();if(n){let s=e.getChanges?.();return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function mE(e,t){let r=t.propertyResolvers,n=t.getContext?.(),s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):ZA(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],f=i(ZA(l,r,n));for(let d of e)u.push(f(d));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(h=>h&&typeof h=="object"?c(h):h);let u={},f=i(ZA(l,r,n)),d;for(let h of e){let _=f(h);_===void 0&&o&&(_=null),_?.then?(d||(d=[]),d.push(_.then(p=>u[h.name||h]=p))):u[h.name||h]=_}return d?Promise.all(d).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let f=r[c.name]?.definition?.tableClass;l=s[c.name]=mE(c.select||c,f)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var aL,cL,lL,w4,Kr,pE,wc,EE,Ra=be(()=>{aL=require("crypto");cu();cL=x(bi()),lL=x(_e());Oc();xf();w4={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Kr=class{static{a(this,"Resource")}#e;#t;#n;static transactions;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=Gn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=mE(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=Gn(function(t,r,n,s){if(Array.isArray(s)&&t.#n){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(f=>f.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):$n(t,"put")},{hasContent:!0,type:"update"});static patch=Gn(function(t,r,n,s){return t.patch?t.patch(s,r):$n(t,"patch")},{hasContent:!0,type:"update"});static delete=Gn(function(t,r,n,s){return t.delete?t.delete(r):$n(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,aL.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={}),Ot(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):$n(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=Gn(function(t,r,n,s){return t.invalidate?t.invalidate(r):$n(t,"delete")},{hasContent:!1,type:"update"});static post=Gn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Gn(function(t,r,n,s){return t.connect?t.connect(s,r):$n(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Gn(function(t,r,n,s){return t.subscribe?t.subscribe(r):$n(t,"subscribe")},{type:"read"});static publish=Gn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.publish(s,r):$n(t,"publish")},{hasContent:!0,type:"create"});static search=Gn(function(t,r,n,s){let i=t.search?t.search(r):$n(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=mE(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Gn(function(t,r,n,s){return t.search?t.search(s,r):$n(t,"search")},{hasContent:!0,type:"read"});static copy=Gn(function(t,r,n,s){return t.copy?t.copy(s,r):$n(t,"copy")},{hasContent:!0,type:"create"});static move=Gn(function(t,r,n,s){return t.move?t.move(s,r):$n(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#n)return(await this.constructor.create(this.#e,t,this.#t)).#e;$n(this,"post")}static isCollection(t){return t&&t.#n}get isCollection(){return this.#n}static coerceId(t){return t}static parseQuery(t){return hE(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1),c=r?.headers&&w4[o];if(c)r.requestedContentType=c,t=t.slice(0,s);else if(this.attributes?.find(l=>l.name===o))if(t=t.slice(0,s),n)n.property=o;else return{query:{property:o},id:oL(t,this),isCollection:wc}}let i=oL(t,this);return wc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(f=>f.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let f of l){let d=f.#e,h=u.get(d);h?h.push(f):u.set(d,[f])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s.#n=!0),s}subscribe(t){return new qn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new qn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,cL._assignPackageExport)("Resource",Kr);a(I4,"snake_case");pE=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(oL,"pathToId");EE=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(Gn,"transactional");a($n,"missingMethod");a(ZA,"selectFromObject");a(mE,"transformForSelect")});var ya,tR=be(()=>{ya=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 fL={};Be(fL,{Resources:()=>gE,keyArrayToString:()=>_u,resetResources:()=>C4,resources:()=>Ci});function C4(){return Ci=new gE}function _u(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var uL,dL,gE,Ci,hu=be(()=>{Oc();tR();uL=x(W()),dL=x(_e()),gE=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 dL.ServerError(`Conflicting paths for ${t}`);uL.default.error(c),i.Resource=new ya(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let f=this.get(c.slice(0,u));f&&(f.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(!l&&c.indexOf(".")>-1){let u=c.split(".");l=this.get(u[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 Ot(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(C4,"resetResources");a(_u,"keyArrayToString")});var Ic={};Be(Ic,{server:()=>Qe});var _L,Qe,Yr=be(()=>{_L=x(bi()),Qe={};(0,_L._assignPackageExport)("server",Qe)});var sR={};Be(sR,{loadGQLSchema:()=>L4,start:()=>nR,startOnMainThread:()=>D4});function nR({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:f}=await import("graphql"),d=o(new c(r.toString(),s)),h=new Map,_=[],p;for(let T of d.definitions)switch(T.kind){case l.OBJECT_TYPE_DEFINITION:let F=function(K){if(K.kind==="NonNullType"){let X=F(K.type);return X.nullable=!1,X}if(K.kind==="ListType")return{type:"array",elements:F(K.type)};let ie={type:K.name?.value};return Object.defineProperty(ie,"location",{value:K.loc.startToken}),ie};a(F,"getProperty");let m=T.name.value,A=[],w={table:null,database:null,properties:A};h.set(m,w);for(let K of T.directives){if(K.name.value==="table"){for(let ie of K.arguments)w[ie.name.value]=ie.value.value;w.schema&&(w.database=w.schema),w.table||(w.table=m),w.audit&&(w.audit=w.audit!=="false"),w.attributes=w.properties,_.push(w)}if(K.name.value==="sealed"&&(w.sealed=!0),K.name.value==="splitSegments"&&(w.splitSegments=!0),K.name.value==="replicate"&&(w.replicate=!0),K.name.value==="export"){w.export=!0;for(let ie of K.arguments)typeof w.export!="object"&&(w.export={}),w.export[ie.name.value]=ie.value.value}}let M=!1,G={};for(let K of T.fields){let ee=F(K.type);ee.name=K.name.value,A.push(ee),G[ee.name]=void 0;for(let ie of K.directives){let X=ie.name.value;if(X==="primaryKey")M?console.warn("Can not define two attributes as a primary key at",ie.loc):(ee.isPrimaryKey=!0,M=!0);else if(X==="indexed")ee.indexed=!0;else if(X==="computed"){for(let re of ie.arguments||[])if(re.name.value==="from"){let j=re.value.value;ee.computed={from:g(j,re,G)},ee.version==null&&(ee.version=j)}else re.name.value==="version"&&(ee.version=re.value.value);ee.computed=ee.computed||!0}else if(X==="relationship"){let re={};for(let j of ie.arguments)re[j.name.value]=j.value.value;ee.relationship=re}else if(X==="createdTime")ee.assignCreatedTime=!0;else if(X==="updatedTime")ee.assignUpdatedTime=!0;else if(X==="expiresAt")ee.expiresAt=!0;else if(X==="allow"){let re=ee.authorizedRoles=[];for(let j of ie.arguments)j.name.value==="role"&&re.push(j.value.value)}else server.knownGraphQLDirectives.includes(X)&&console.warn(`@${X} is an unknown directive, at`,ie.loc)}}w.type=m,m==="Query"&&(p=w)}function S(T){let m=h.get(T.type);m?(Object.defineProperty(T,"properties",{value:m.properties}),Object.defineProperty(T,"definition",{value:m})):T.type==="array"?S(T.elements):P4.includes(T.type)||(0,pL.getWorkerIndex)()===0&&console.error(`The type ${T.type} is unknown at line ${T.location.line}, column ${T.location.column}, in ${s}`)}a(S,"connectPropertyType");for(let T of h.values())for(let m of T.properties)S(m);for(let T of _)T.tableClass=e(T),T.export&&(T.export.name===""?i.set((0,rR.dirname)(n),T.tableClass):i.set((0,rR.dirname)(n)+"/"+(T.export.name||T.type),T.tableClass,T.export));function g(T,m,A){return new hL.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${T}; } } } } computed;`,{filename:s,lineOffset:m.loc.startToken.line-1,columnOffset:m.loc.startToken.column}).runInThisContext()(A)}a(g,"createComputedFrom")}}var rR,hL,pL,P4,D4,L4,EL=be(()=>{rR=require("path"),hL=require("node:vm");Ce();pL=x(nt()),P4=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt","Blob"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(nR,"start");D4=nR,L4=nR({ensureTable:at}).handleFile});var yL={};Be(yL,{parse:()=>oR,streamAsJSON:()=>Hf,stringify:()=>Cc});function Hf(e){return new iR({value:e})}function mL(e){return console.error(e),JSON.stringify(e.toString())}function gL(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Cc(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===AL)return RL(e);if(t.resolution)return t.resolution.then(()=>Cc(e));throw t}}function RL(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+=RL(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Cc(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function oR(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),U4.test(e)?M4.parse(e):JSON.parse(e)):null}var SL,TL,M4,v4,AL,iR,U4,aR=be(()=>{SL=require("stream"),TL=x(require("json-bigint-fixes")),M4=(0,TL.default)({useNativeBigInt:!0}),v4=1e4,AL={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw AL};a(Hf,"streamAsJSON");iR=class extends SL.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),mL)}catch(s){yield mL(s)}else yield Cc(t)}else yield Cc(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);gL(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>v4?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 gL(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(mL,"handleError");a(gL,"when");a(Cc,"stringify");a(RL,"jsStringify");U4=/[[,:]\s*-?\d{16,}/;a(oR,"parse")});var uo=C(TE=>{var SE=W();for(let e of["trace","debug","info","warn","error","fatal","notify"])SE.logsAtLevel(e)&&(TE[e]=SE[e]);TE.loggerWithTag=e=>SE.loggerWithTag(e,!0);TE.setLogLevel=SE.setLogLevel});var PE={};Be(PE,{Blob:()=>Pi,blobsWereEncoded:()=>Eu,databasePaths:()=>yE,decodeBlobsWithWrites:()=>dR,decodeFromDatabase:()=>Dc,decodeWithBlobCallback:()=>fR,deleteBlob:()=>LL,deleteBlobsInObject:()=>po,deleteRootBlobPathsForDB:()=>uR,encodeBlobsAsBuffers:()=>K4,encodeBlobsWithFilePath:()=>CE,getFileId:()=>wE,getFilePathForBlob:()=>vL,getRootBlobPathsForDB:()=>IE,setDeletionDelay:()=>k4});function PL(){}function LL(e){let t=vL(e);if(!t){fo.default.debug?.("No file path for blob, can not delete");return}setTimeout(()=>{(0,je.unlink)(t,r=>{r&&fo.default.debug?.("Error trying to remove blob file",r)})},DL)}function k4(e){DL=e}function ML(e){let t=En.get(e);if(!t)t={storageIndex:0,fileId:null,store:Xs},En.set(e,t);else{if(t.saving)return t;t.store=Xs}return q4(t),t.source?cR(e,t.source,t):t.contentBuffer?F4(e,t):cR(e,Ff.Readable.from(e.stream()),t),t}function cR(e,t,r){let{filePath:n,fileId:s,store:i,compress:o,flush:c}=r;return r.saving=new Promise((l,u)=>{let f=s+":blob";if(!i.attemptLock(f,0))throw new Error(`Unable to get lock for blob file ${s}`);let d=(0,je.createWriteStream)(n,{autoClose:!1,flags:"w"});if(t.errored){let g=Buffer.from(t.errored.toString());d.end(Buffer.concat([p(BigInt(g.length)+0xff000000000000n),g]));return}let h=!1;e.size!==void 0&&(d.write(p(e.size)),h=!0);let _;o?(h||d.write(B4),_=(0,OE.createDeflate)(),t.pipe(_).pipe(d)):(h||d.write(x4),t.pipe(d)),t.on("error",S);function p(g){let T=BigInt(g),m=new Uint8Array(gr),A=new DataView(m.buffer);return T|=BigInt(o?lR:CL)<<48n,A.setBigInt64(0,T),m}a(p,"createHeader");function S(g){i.unlock(f,0);let T=d.fd;g?(T&&(0,je.close)(T),u(g)):c?(0,je.fdatasync)(T,m=>{m&&u(m),l(),(0,je.close)(T)}):(l(),(0,je.close)(T))}a(S,"finished"),d.on("error",S).on("finish",()=>{if(h)S();else{let g=_?_.bytesWritten:d.bytesWritten-gr;e.size=g,(0,je.write)(d.fd,p(g),0,gr,0,S)}})}),e}function wE(e){return En.get(e)?.fileId}function vL(e){let t=En.get(e);return t?.fileId&&qf(t)}function IE(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=yE.get(e);if(!t){if(!e.databaseName)throw new Error("No database name specified, can not determine blob storage path");let r=(0,NE.get)(H.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,ho.join)(n,e.databaseName)):t=[(0,ho.join)((0,NE.getHdbBasePath)(),"blobs",e.databaseName)],yE.set(e,t)}return t}async function uR(e){let t=yE.get(e);t&&await Promise.all(t.map(r=>UL(r)))}async function UL(e){for(let t of await(0,Zs.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await UL((0,ho.join)(e,t.name));else try{await(0,Zs.unlink)((0,ho.join)(e,t.name))}catch(r){fo.default.warn?.("Error deleting file",r)}try{await(0,Zs.rmdir)(e)}catch(t){fo.default.warn?.("Error deleting directory",t)}}function qf({storageIndex:e,fileId:t,store:r}){let n=IE(r);return(0,ho.join)(n[e],t.slice(-9,-6)||"0",t.slice(-6,-3)||"0",t.length<=9?t.slice(-3):t.slice(0,-9)+t.slice(-3))}function F4(e,t){let r=t.contentBuffer,n=r.length;if(!(n<IL))return e.size=n,cR(e,Ff.Readable.from([r]),t)}function q4(e){let t=IE(e.store),r=G4(),n=t?.length>1?$4(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=qf(e),o=(0,ho.dirname)(i);(0,je.existsSync)(o)||(0,wL.ensureDirSync)(o),e.filePath=i}function G4(){let e=NL.get(Xs);if(!e){let t=0,r=IE(Xs);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let o=0;if((0,je.existsSync)(n))for(let c of(0,je.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>o&&(o=l)}s+=o,n=(0,ho.join)(n,o.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(Xs.getUserSharedBuffer("blob-file-id",e.buffer)),NL.set(Xs,e)}return Number(Atomics.add(e,0,1n))}function $4(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(bE);for(let i=0;i<s.length;i++)s[i]=i%e.length;e.frequencyTable=s}return(e.lastUpdated??0)+6e4<r&&(e.lastUpdated=r,V4(e)),e.frequencyTable[t%bE]}async function V4(e){if(!Zs.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let o=await(0,Zs.statfs)(s),c=o.bavail*o.bsize;return Math.pow(c,.8)})),r=new Array(bE),n=t.map(s=>1/s);for(let s=0;s<bE;s++){let i=1/0,o=0;for(let c=0;c<n.length;c++)n[c]<i&&(o=c,i=n[c]);n[o]+=1/t[o],r[s]=o}e.frequencyTable=r}function CE(e,t,r){pu=t,Xs=r,Eu=!1;try{return e()}finally{pu=void 0,Xs=void 0}}function K4(e){Mr=[];let t;try{t=e()}catch(n){throw Mr=void 0,n}let r=Mr.length<2?Mr[0]:Promise.all(Mr);return Mr=void 0,r?r.then(()=>e()):t}function dR(e,t){try{Mr=[],Pc=t,e()}catch(n){throw Pc=void 0,Mr=void 0,n}Pc=void 0;let r=Mr.length<2?Mr[0]:Promise.all(Mr);return Mr=void 0,r}function fR(e,t){try{return Pc=t,e()}finally{Pc=void 0}}function Dc(e,t){return Xs=t,e()}function po(e){if(e instanceof Pi)LL(e);else if(e.constructor===Object||Array.isArray(e))for(let t in e)typeof e[t]=="object"&&po(e[t])}function Y4(){return class{static{a(this,"Blob")}content;constructor(t){this.content=t[0]}stream(){return new ReadableStream({start(t){t.enqueue(this.content),t.close()}})}text(){return Promise.resolve(this.content.toString())}arrayBuffer(){return Promise.resolve(this.content.buffer)}get size(){return this.content.length}slice(){throw new Error("Not implemented")}bytes(){return Promise.resolve(this.content)}get type(){return""}}}var _o,Zs,je,OE,Ff,wL,NE,ho,fo,IL,gr,CL,lR,bL,x4,B4,OL,En,Pc,Pi,pu,Mr,Xs,Eu,kf,AE,H4,RE,DL,yE,NL,bE,Ts=be(()=>{_o=require("msgpackr"),Zs=require("node:fs/promises"),je=require("node:fs"),OE=require("node:zlib"),Ff=require("node:stream"),wL=require("fs-extra"),NE=x(ce());v();ho=require("path"),fo=x(uo());Eo();IL=8192,gr=8,CL=0,lR=1,bL=255,x4=new Uint8Array([0,CL,255,255,255,255,255,255]),B4=new Uint8Array([0,lR,255,255,255,255,255,255]),OL=0xffffffffffff,En=new WeakMap,Pi=global.Blob||Y4(),Eu=!1,kf=new Uint8Array(8),AE=new DataView(kf.buffer),H4=6e4;a(PL,"InstanceOfBlobWithNoConstructor");PL.prototype=Pi.prototype;RE=class e extends PL{static{a(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=En.get(this),{start:r,end:n,contentBuffer:s}=t;return s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?s.toString():(_R(this.bytes().then(i=>t.contentBuffer=i)),"")}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=En.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=qf(t),o,c=a(async()=>{let l,u=gr;try{if(l=await(0,Zs.readFile)(i),l.length>=gr){l.copy(kf,0,0,gr);let d=AE.getBigUint64(0);if(Number(d>>48n)===bL)throw new Error("Error in blob: "+buffer.subarray(gr));if(u=Number(d&0xffffffffffffn),u<n&&(u=n),u<OL&&(this.size=u,this.#t))for(let h of this.#t)h(u)}}catch(d){if(d.code!=="ENOENT")throw d;l=Buffer.alloc(0)}function f(d){if(u>d.length){let h=t.store,_=t.fileId+":blob";if(o)throw new Error("Incomplete blob");return new Promise((p,S)=>{if(h.attemptLock(_,0,()=>(o=!0,h.unlock(_,0),p(c()))))return o=!0,h.unlock(_,0),p(c())})}return(n!=null||r!=null)&&(d=d.subarray(r??0,n??d.length)),d}return a(f,"checkCompletion"),l[1]===lR?new Promise((d,h)=>{(0,OE.deflate)(l.subarray(gr),(_,p)=>{_?h(_):d(f(p))})}):f(l.subarray(gr))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=En.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(p){p.enqueue(r),p.close()}});let i=qf(t),o,c=0,l=0,u,f,d,h=this;return new ReadableStream({start(){let p=1e3,S=a((g,T)=>{(0,je.open)(i,"r",(m,A)=>{if(m){if(m.code==="ENOENT"&&d!==!1&&(fo.default.debug?.("File does not exist yet, waiting for it to be created",i,p),p-- >0))return setTimeout(()=>{_(),S(g,T)},20).unref();T(m),h.#e?.forEach(w=>w(m))}else o=A,g(A)})},"openFile");return new Promise(S)},pull:a(p=>{let S=0,g=100;return new Promise(a(function T(m,A){function w(F){(0,je.close)(o),u&&u.close(),A(F),h.#e?.forEach(G=>G(F))}a(w,"onError");let M=Buffer.allocUnsafe(262144);(0,je.read)(o,M,0,M.length,c,(F,G,K)=>{if(l+=G,F)return w(F);if(c===0){if(G<gr){g-- >0&&d!==!1?(_(),fo.default.debug?.("File was empty, waiting for data to be written",i,g),setTimeout(()=>T(m,A),20).unref()):(fo.default.debug?.("File was empty, throwing error",i,g),A(new Error(`Blob ${t.fileId} was empty`)));return}K.copy(kf,0,0,gr);let ee=AE.getBigUint64(0);if(Number(ee>>48n)===bL)return w(new Error("Error in blob: "+K.subarray(gr)));if(S=Number(ee&0xffffffffffffn),S<OL&&h.size!==S&&(h.size=S,h.#t))for(let ie of h.#t)ie(S);K=K.subarray(gr,G),l-=gr}else if(G===0){let ee=Buffer.allocUnsafe(8);return(0,je.read)(o,ee,0,gr,0,ie=>{if(ie)return w(ie);if(kf.set(ee),S=Number(AE.getBigUint64(0)&0xffffffffffffn),S>l){d!==!1?(f=setTimeout(()=>{w(new Error("File read timed out"))},H4).unref(),u=(0,je.watch)(i,{persistent:!1},()=>{clearTimeout(f),u.close(),_(),T(m,A)})):w(new Error("Blob is incomplete"));return}(0,je.close)(o),p.close(),m()})}else K=K.subarray(0,G);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=G,T(m,A);s&&l>=s&&(l>s&&(K=K.subarray(0,s-c)),l=S=s),n&&n>c&&(K=K.subarray(n-c))}c+=G;try{p.enqueue(K)}catch(ee){return fo.default.debug?.("Error enqueuing chunk",ee),m()}l===S&&((0,je.close)(o),p.close()),m()})},"readMore"))},"pull"),cancel(){(0,je.close)(o),clearTimeout(f),u&&u.close()}});function _(){if(d===void 0){let p=t.store,S=t.fileId+":blob";d=!p.attemptLock(S,0,()=>{d=!1,p.unlock(S,0)}),d||p.unlock(S,0)}return d}}slice(t,r,n){let s=En.get(this),i=new e(n&&{type:n});if(s?.fileId){let o={...s,start:t,end:r};En.set(i,o),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let o={...s,contentBuffer:s.contentBuffer.subarray(t,r)};En.set(i,o),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(!t?.primaryStore?.rootStore)throw new Error("No target table specified");return ML(this).saving??Promise.resolve()}},DL=500;a(LL,"deleteBlob");a(k4,"setDeletionDelay");global.createBlob=function(e,t){let r=new RE(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(En.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Ff.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Ff.Readable.from(e);else throw new Error("Invalid source type");return r};a(ML,"saveBlob");a(cR,"writeBlobWithStream");a(wE,"getFileId");a(vL,"getFilePathForBlob");yE=new Map;a(IE,"getRootBlobPathsForDB");a(uR,"deleteRootBlobPathsForDB");a(UL,"rimrafSteadily");a(qf,"getFilePath");a(F4,"writeBlobWithBuffer");a(q4,"generateFilePath");NL=new Map;a(G4,"getNextFileId");bE=128;a($4,"getNextStorageIndex");a(V4,"createFrequencyTableForStoragePaths");a(CE,"encodeBlobsWithFilePath");a(K4,"encodeBlobsAsBuffers");a(dR,"decodeBlobsWithWrites");a(fR,"decodeWithBlobCallback");a(Dc,"decodeFromDatabase");a(po,"deleteBlobsInObject");(0,_o.addExtension)({Class:Pi,type:11,unpack:a(function(e){let t=(0,_o.unpack)(e),r=new RE;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(!Xs)throw new Error("No store specified, can not load blob from storage");if(En.set(r,{storageIndex:t[1],fileId:t[2],store:Xs}),Pc)return Pc(r)??r}else En.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:a(function(e){let t=En.get(e);if(pu!==void 0&&(Eu=!0,t?.recordId!==void 0&&t.recordId!==pu))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<IL)return r.size=t.contentBuffer.length,(0,_o.pack)([r,t.contentBuffer])}if(pu!==void 0){if(t=ML(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=pu,(0,_o.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,je.readFileSync)(qf(t));if(n.length>=gr&&(n.copy(kf,0,0,gr),Number(AE.getBigUint64(0)&0xffffffffffffn)===n.length-gr))return Buffer.concat([(0,_o.pack)([r]),n]);if(Mr)Mr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&Mr)return Mr.push(e.bytes()),Buffer.alloc(0);throw n}else throw new Error("Blob has no storage info or buffer attached to it")},"pack")});(0,_o.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(Y4,"polyfillBlob")});var SR={};Be(SR,{asyncSerialization:()=>_R,contentTypes:()=>mR,findBestSerializer:()=>LE,getDeserializer:()=>go,registerContentHandlers:()=>gR,serialize:()=>Vf,serializeMessage:()=>Oa,toCsvStream:()=>DE});function z4(e){try{return e?.[0]===123?ER(e):e}catch{return e}}function gR(e){e.register(Q4,{serializers:[{regex:/^application\/json$/,serializer:Hf},{regex:/^application\/cbor$/,serializer:a(function(t){return new Lc.EncoderStream($f).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Mc.Readable.from((0,Di.encodeIter)(t,$f)):(0,Di.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),DE(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Di.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Lc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function LE(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[u,...f]=l.split(/\s*;\s*/),d=1,h={q:1};for(let p of f){let S=p.indexOf("=");h[p.substring(0,S)]=p.substring(S+1)}d=+h.q;let _=Wr.get(u);if(_){let p=(_.q||1)*d;p>s&&(n=_,i=_.type||u,s=p,o=h)}}if(!n){if(r)throw new HL.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(Wr.keys()).join(", "),406);n=Wr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Vf(e,t,r){let n=BL&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array||e instanceof Pi)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=LE(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}),pR.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,mo.createBrotliCompress)({params:{[mo.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?mo.constants.BROTLI_MODE_TEXT:mo.constants.BROTLI_MODE_GENERIC,[mo.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>BL?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,mo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Oa(e,t,r){if(e?.contentType!=null&&e.data!=null)return e.data;ba=r?void 0:[];try{let n;if(t){let s=t.serialize;if(s)n=s(e);else{let i=LE(t);s=t.serialize=i.serializer.serialize,n=s(e)}}else n=Gf(e);return ba?.length>0?(ba.length===1?ba[0]:Promise.all(ba)).then(()=>Oa(e,t,!0)):n}finally{ba=void 0}}function _R(e){if(ba)ba.push(e);else throw new Error("Unable to serialize asynchronously")}function J4(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 Z4(e){return X4.includes(e)}function e3(e){let t=e.indexOf(";"),r;if(t>-1){r={};let n=e.slice(t+1).split(";");for(let s of n){let[i,o]=s.split("=");r[i.trim()]=o.trim()}e=e.slice(0,t)}return{type:e,parameters:r}}function go(e="",t=!1){let r=e3(e),n=r.type&&Wr.get(r.type)?.deserialize||t3(r);return t?s=>J4(s).then(n):n}function t3(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!Z4(e.parameters.charset)&&pR.default.info(`Unknown Buffer encoding ${e.parameters.charset} in content-type. Proceeding anyways.`),t=>({contentType:e.type,data:t.toString(e.parameters?.charset||"utf-8")})):e.type==="application/octet-stream"?t=>t:t=>{if(e.type==="")try{if(t?.[0]===123)return ER(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function r3(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}function DE(e,t){let r=Mc.default.Readable.from(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator]?e:[e]),n={};t&&(n.fields=t.map(o=>({label:o,value:o})));let s={objectMode:!0},i=new W4(n,s);return r.pipe(i)}var Di,Lc,mo,HL,Mc,kL,hR,FL,pR,W4,qL,Gf,ER,$f,Wr,mR,xL,GL,j4,Q4,BL,ba,X4,Eo=be(()=>{aR();Di=require("msgpackr"),Lc=require("cbor-x"),mo=require("zlib"),HL=x(_e()),Mc=x(require("stream"));Yr();kL=x(bi()),hR=x(ce());v();FL=x(require("yaml")),pR=x(uo());Ts();({Transform:W4}=require("json2csv")),qL=hR.default.get(H.SERIALIZATION_BIGINT)!==!1,Gf=qL?Cc:JSON.stringify,ER=qL?oR:JSON.parse,$f={useRecords:!1,useToJSON:!0},Wr=new Map,mR=Wr;Qe.contentTypes=mR;(0,kL._assignPackageExport)("contentTypes",mR);Wr.set("application/json",{serializeStream:Hf,serialize:Gf,deserialize(e){return ER(e)},q:.8});xL=new Lc.Encoder($f);Wr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Lc.EncoderStream($f).end(e)},serialize:xL.encode,deserialize:xL.decode,q:1});Wr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Mc.Readable.from((0,Di.encodeIter)(e,$f)):(0,Di.pack)(e)},serialize:Di.pack,deserialize:Di.unpack,q:.9});Wr.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),DE(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]),DE(e,e?.getColumns?.())},q:.1});Wr.set("text/plain",{serialize(e){return e.toString()},serializeStream(e){return Mc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Wr.set("text/yaml",{serialize(e){return FL.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Wr.set("text/event-stream",{serializeStream:a(function(e){return Mc.Readable.from(r3(e,this.serialize))},"serializeStream"),serialize:a(function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
|
|
9
|
-
`),e.data){let r=e.data;typeof r=="object"&&(r=
|
|
7
|
+
`}a(Qs,"createLogRecord");function wf(e){if(bi){if(yD(e),Ss){_a=!1;try{process.stdout.write(e)}finally{_a=!0}}}else Ss&&process.stdout.write(e)}a(wf,"logStdOut");function dm(e){if(bi){if(yD(e),Ss){_a=!1;try{process.stderr.write(e)}finally{_a=!0}}}else Ss&&process.stderr.write(e)}a(dm,"logStdErr");function yD(e){eR(),fa?ao.appendFileSync(fa,e):ZA||console.log(e)}a(yD,"logToFile");function rR(){try{ao.closeSync(fa)}catch{}fa=null}a(rR,"closeLogFile");function eR(){if(!fa){try{fa=ao.openSync(lm,"a")}catch(e){ZA||(ZA=!0,console.error(e))}setTimeout(()=>{rR()},$2).unref()}}a(eR,"openLogFile");function bD(...e){hr[Pr]<=hr.info&&wf(Qs("info",e))}a(bD,"info");function OD(...e){hr[Pr]<=hr.trace&&wf(Qs("trace",e))}a(OD,"trace");function um(...e){hr[Pr]<=hr.error&&dm(Qs("error",e))}a(um,"error");function ND(...e){hr[Pr]<=hr.debug&&wf(Qs("debug",e))}a(ND,"debug");function wD(...e){hr[Pr]<=hr.notify&&wf(Qs("notify",e))}a(wD,"notify");function ID(...e){hr[Pr]<=hr.fatal&&dm(Qs("fatal",e))}a(ID,"fatal");function CD(...e){hr[Pr]<=hr.warn&&dm(Qs("warn",e))}a(CD,"warn");function j2(e,t,...r){t===AD.STDERR?dm(Qs(e,r)):wf(Qs(e,r))}a(j2,"logCustomLevel");function Q2(){let e;try{e=k2.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=Oi.join(e,Vt.HDB_HOME_DIR_NAME,Vt.BOOT_PROPS_FILE_NAME);return ao.existsSync(t)||(t=Oi.join(tR,"utility/hdb_boot_properties.file")),t}a(Q2,"getPropsFilePath");function J2(e){Pr=e}a(J2,"setLogLevel");function gD(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(gD,"autoCastBoolean");function X2(e){try{if(e.includes("config/settings.js")){let o=TD(e);return{level:o.get(Vt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:Oi.dirname(o.get(Vt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Vt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Vt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=SD.parseDocument(ao.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===Vt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(X2,"getLogConfig");function Z2(){try{let e=SD.parseDocument(ao.readFileSync(q2,"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(Z2,"getDefaultConfig");function e4(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(e4,"AuthAuditLog")});var nR=I((Vye,LD)=>{"use strict";var t4=require("util"),r4=require("path"),n4=require("child_process"),s4=t4.promisify(n4.execFile),i4=1e3*1e3*10;LD.exports={findPs:o4};async function o4(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await s4("ps",["wwxo",`pid,${r}`],{maxBuffer:i4});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:r4.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(o4,"findPs")});var vt=I((Yye,vD)=>{"use strict";var a4="__dbis__",c4="__txns__",l4="__environment_name__",u4="__dbi_defintion__",d4={EQUALS:"equals",STARTS_WITH:"startsWith",_STARTS_WITH:"starts_with",ENDS_WITH:"endsWith",_ENDS_WITH:"ends_with",CONTAINS:"contains",SEARCH_ALL:"searchAll",SEARCH_ALL_TO_MAP:"searchAllToMap",BATCH_SEARCH_BY_HASH:"batchSearchByHash",BATCH_SEARCH_BY_HASH_TO_MAP:"batchSearchByHashToMap",GREATER_THAN:"greaterThan",_GREATER_THAN:"greater_than",GREATER_THAN_EQUAL:"greaterThanEqual",_GREATER_THAN_EQUAL:"greater_than_equal",LESS_THAN:"lessThan",_LESS_THAN:"less_than",LESS_THAN_EQUAL:"lessThanEqual",_LESS_THAN_EQUAL:"less_than_equal",BETWEEN:"between"},f4=["__createdtime__","__updatedtime__"],_4="\uFFFF",MD={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},p4=Object.values(MD);vD.exports={AUDIT_STORE_NAME:c4,INTERNAL_DBIS_NAME:a4,DBI_DEFINITION_NAME:u4,SEARCH_TYPES:d4,TIMESTAMP_NAMES:f4,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:l4,TRANSACTIONS_DBI_NAMES_ENUM:MD,TRANSACTIONS_DBIS:p4,OVERFLOW_MARKER:_4}});var Hn=I((Wye,$D)=>{"use strict";var UD=(B(),C(G)),xD=vt(),BD={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},HD=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),kD={500:HD("There was an error processing your request."),400:"Invalid request"},h4=kD[BD.INTERNAL_SERVER_ERROR],m4={OP_NOT_SUPPORTED_FOR_FS:a(e=>`${e} is not available for this instance because it uses the File System data store.`,"OP_NOT_SUPPORTED_FOR_FS"),MISSING_VALUE:a(e=>`${e} is missing.`,"MISSING_VALUE"),INVALID_VALUE:a(e=>`${e} is invalid.`,"INVALID_VALUE"),NOT_FOUND:a(e=>`${e} not found.`,"NOT_FOUND")},E4={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},g4={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},S4={BASE_PATH_REQUIRED:"base_path is required",DESTINATION_PATH_REQUIRED:"destination_path is required",ENV_NAME_REQUIRED:"env_name is required",INVALID_BASE_PATH:"invalid base_path",INVALID_DESTINATION_PATH:"invalid destination_path",INVALID_ENVIRONMENT:"invalid environment",ENV_REQUIRED:"env is required",DBI_NAME_REQUIRED:"dbi_name is required",DBI_DOES_NOT_EXIST:"dbi does not exist",HASH_ATTRIBUTE_REQUIRED:"hash_attribute is required",ID_REQUIRED:"id is required",IDS_REQUIRED:"ids is required",IDS_MUST_BE_ITERABLE:"ids must be iterable",FETCH_ATTRIBUTES_REQUIRED:"fetch_attributes is required",FETCH_ATTRIBUTES_MUST_BE_ARRAY:"fetch_attributes must be an array",ATTRIBUTE_REQUIRED:"attribute is required",SEARCH_VALUE_REQUIRED:"search_value is required",SEARCH_VALUE_TOO_LARGE:"search_value is too long",WRITE_ATTRIBUTES_REQUIRED:"write_attributes is required",WRITE_ATTRIBUTES_MUST_BE_ARRAY:"write_attributes must be an array",RECORDS_REQUIRED:"records is required",RECORDS_MUST_BE_ARRAY:"records must be an array",CANNOT_CREATE_INTERNAL_DBIS_NAME:`cannot create a dbi named ${xD.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${xD.INTERNAL_DBIS_NAME}`,START_VALUE_REQUIRED:"start_value is required",END_VALUE_REQUIRED:"end_value is required",CANNOT_COMPARE_STRING_TO_NUMERIC_KEYS:"cannot compare a string to numeric keys",END_VALUE_MUST_BE_GREATER_THAN_START_VALUE:"end_value must be greater than or equal to start_value",UNKNOWN_SEARCH_TYPE:"unknown search type",CANNOT_DROP_TABLE_HASH_ATTRIBUTE:"cannot drop a table's hash attribute"},T4={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${UD.INSERT_MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${UD.INSERT_MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},FD={GENERIC_AUTH_FAIL:"Login failed",USER_INACTIVE:"Cannot complete request: User is inactive",INVALID_TOKEN:"invalid token",NO_ENCRYPTION_KEYS:"unable to generate JWT as there are no encryption keys. please contact your administrator",INVALID_CREDENTIALS:"invalid credentials",PASSWORD_REQUIRED:"password is required",USERNAME_REQUIRED:"username is required",REFRESH_TOKEN_REQUIRED:"refresh_token is required",INVALID_AUTH_OBJECT:"invalid auth_object",INVALID_BODY:"invalid body",TOKEN_EXPIRED:"token expired",REFRESH_TOKEN_SAVE_FAILED:"unable to store refresh_token"},A4={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:a(e=>`Operation '${e}' is restricted to 'super_user' roles`,"OP_IS_SU_ONLY"),OP_NOT_FOUND:a(e=>`Operation '${e}' not found`,"OP_NOT_FOUND"),SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:a((e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,"UNKNOWN_OP_AUTH_ERROR"),USER_HAS_NO_PERMS:a(e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,"USER_HAS_NO_PERMS"),DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},R4={ATTR_PERM_MISSING:a((e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,"ATTR_PERM_MISSING"),ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:a((e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,"ATTR_PERM_NOT_BOOLEAN"),ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:a(e=>`Invalid attribute '${e}' in 'attribute_permissions'`,"INVALID_ATTRIBUTE_IN_PERMS"),INVALID_PERM_KEY:a(e=>`Invalid table permission key value '${e}'`,"INVALID_PERM_KEY"),INVALID_ATTR_PERM_KEY:a(e=>`Invalid attribute permission key value '${e}'`,"INVALID_ATTR_PERM_KEY"),INVALID_ROLE_JSON_KEYS:a(e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,"INVALID_ROLE_JSON_KEYS"),MISMATCHED_TABLE_ATTR_PERMS:a(e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,"MISMATCHED_TABLE_ATTR_PERMS"),OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:a(e=>`A role with name '${e}' already exists`,"ROLE_ALREADY_EXISTS"),ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:a(e=>`Your role does not have permission to view database metadata for '${e}'`,"SCHEMA_PERM_ERROR"),SCHEMA_TABLE_PERM_ERROR:a((e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,"SCHEMA_TABLE_PERM_ERROR"),SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:a(e=>`Value for '${e}' permission must be a boolean`,"SU_CU_ROLE_BOOLEAN_ERROR"),STRUCTURE_USER_ROLE_TYPE_ERROR:a(e=>`Value for '${e}' permission must be a boolean or Array`,"STRUCTURE_USER_ROLE_TYPE_ERROR"),SU_CU_ROLE_NO_PERMS_ALLOWED:a(e=>`Roles with '${e}' set to true cannot have other permissions set.`,"SU_CU_ROLE_NO_PERMS_ALLOWED"),SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:a(e=>`Missing table ${e.toUpperCase()} permission`,"TABLE_PERM_MISSING"),TABLE_PERM_NOT_BOOLEAN:a(e=>`Table ${e.toUpperCase()} permission must be a boolean`,"TABLE_PERM_NOT_BOOLEAN")},y4={ATTR_NOT_FOUND:a((e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,"ATTR_NOT_FOUND"),ATTR_EXISTS_ERR:a((e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,"ATTR_EXISTS_ERR"),DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:a(e=>`Invalid table ${JSON.stringify(e)}`,"INVALID_TABLE_ERR"),SCHEMA_NOT_FOUND:a(e=>`database '${e}' does not exist`,"SCHEMA_NOT_FOUND"),SCHEMA_EXISTS_ERR:a(e=>`database '${e}' already exists`,"SCHEMA_EXISTS_ERR"),TABLE_EXISTS_ERR:a((e,t)=>`Table '${t}' already exists in '${e}'`,"TABLE_EXISTS_ERR"),SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:a((e,t)=>`Table '${e}.${t}' does not exist`,"TABLE_NOT_FOUND"),TABLE_REQUIRED_ERR:"table is required"},b4={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},O4={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},GD={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},qD={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},N4={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},w4={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},I4={...FD,...g4,...m4,...A4,...R4,...y4,...b4,...O4,...T4,...GD,...qD,...N4,...w4,...E4};$D.exports={CHECK_LOGS_WRAPPER:HD,HDB_ERROR_MSGS:I4,DEFAULT_ERROR_MSGS:kD,DEFAULT_ERROR_RESP:h4,HTTP_STATUS_CODES:BD,LMDB_ERRORS_ENUM:S4,AUTHENTICATION_ERROR_MSGS:FD,VALIDATION_ERROR_MSGS:GD,ITC_ERRORS:qD}});var pe=I((jye,YD)=>{"use strict";var fu=Hn(),C4=Y(),P4=(B(),C(G)),fm=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,VD),this.statusCode=n||fu.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(fu.DEFAULT_ERROR_MSGS[n]?fu.DEFAULT_ERROR_MSGS[n]:fu.DEFAULT_ERROR_MSGS[fu.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&C4[s](i)}},sR=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},iR=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function VD(e,t,r,n=P4.LOG_LEVELS.ERROR,s=null,i=!1){if(KD(e))return e;let o=new fm(e,t,r,n,s);return i&&delete o.stack,o}a(VD,"handleHDBError");function KD(e){return e.__proto__.constructor.name===fm.name}a(KD,"isHDBError");YD.exports={isHDBError:KD,handleHDBError:VD,ClientError:sR,ServerError:iR,hdb_errors:fu}});var Et=I((Jye,ZD)=>{"use strict";var Lf=(B(),C(G)),D4=oe(),_n=ce(),Mf=require("path"),L4=require("minimist"),WD=require("fs-extra"),zD=require("lodash");_n.initSync();var{CONFIG_PARAMS:pa,DATABASES_PARAM_CONFIG:If,SYSTEM_SCHEMA_NAME:_m}=Lf,Cf,Pf,Df;function jD(){if(Cf!==void 0)return Cf;if(_n.getHdbBasePath()!==void 0)return Cf=_n.get(pa.STORAGE_PATH)||Mf.join(_n.getHdbBasePath(),Lf.DATABASES_DIR_NAME),Cf}a(jD,"getBaseSchemaPath");function QD(){if(Pf!==void 0)return Pf;if(_n.getHdbBasePath()!==void 0)return Pf=XD(_m),Pf}a(QD,"getSystemSchemaPath");function JD(){if(Df!==void 0)return Df;if(_n.getHdbBasePath()!==void 0)return Df=_n.get(Lf.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Mf.join(_n.getHdbBasePath(),Lf.TRANSACTIONS_DIR_NAME),Df}a(JD,"getTransactionAuditStoreBasePath");function M4(e,t){let r=_n.get(pa.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Mf.join(JD(),e.toString())}a(M4,"getTransactionAuditStorePath");function XD(e,t){e=e.toString(),t=t&&t.toString();let r=_n.get(Lf.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Mf.join(jD(),e)}a(XD,"getSchemaPath");function v4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,L4(process.argv));let n=r[pa.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!D4.isObject(n))throw o;i=n}for(let o of i){let c=o[_m];if(!c)continue;let l=_n.get(pa.DATABASES);l=l??{};let u=c?.tables?.[t]?.[If.PATH];if(u)return zD.set(l,[_m,If.TABLES,t,If.PATH],u),_n.setProperty(pa.DATABASES,l),u;let f=c?.[If.PATH];if(f)return zD.set(l,[_m,If.PATH],f),_n.setProperty(pa.DATABASES,l),f}}let s=r[pa.STORAGE_PATH.toUpperCase()];if(s){if(!WD.pathExistsSync(s))throw new Error(s+" does not exist");let i=Mf.join(s,e);return WD.mkdirsSync(i),_n.setProperty(pa.STORAGE_PATH,s),i}return QD()}a(v4,"initSystemSchemaPaths");function U4(){Cf=void 0,Pf=void 0,Df=void 0}a(U4,"resetPaths");ZD.exports={getBaseSchemaPath:jD,getSystemSchemaPath:QD,getTransactionAuditStorePath:M4,getTransactionAuditStoreBasePath:JD,getSchemaPath:XD,initSystemSchemaPaths:v4,resetPaths:U4}});var pn=I((tbe,sL)=>{"use strict";var x4=Hn().LMDB_ERRORS_ENUM,Zye=require("lmdb"),B4=vt(),ebe=require("buffer").Buffer,{OVERFLOW_MARKER:eL,MAX_SEARCH_KEY_LENGTH:pm}=B4,tL=["number","string","symbol","boolean","bigint"];function H4(e){if(e=e?.primaryStore||e,!e)throw new Error(x4.ENV_REQUIRED)}a(H4,"validateEnv");function k4(e){if(e==null)return null;let t;try{t=typeof e=="object"?JSON.stringify(e):e.toString()}catch{t=e.toString()}return t}a(k4,"stringifyData");function F4(e){return e instanceof Date?e.valueOf():e}a(F4,"convertKeyValueToWrite");function G4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(tL.includes(typeof e))return e.length>pm?[e.slice(0,pm)+eL]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(tL.includes(typeof i))i.length>pm?r.push(i.slice(0,pm)+eL):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(G4,"getIndexedValues");var hm=0,rL=0;function nL(){rL=Date.now()-performance.now()}a(nL,"adjustStartTime");nL();var q4=6e4;setInterval(nL,q4).unref();function $4(){let e=performance.now()+rL;return e>hm?(hm=e,e):(hm+=488e-6,hm)}a($4,"getNextMonotonicTime");sL.exports={validateEnv:H4,stringifyData:k4,convertKeyValueToWrite:F4,getNextMonotonicTime:$4,getIndexedValues:G4}});var vf=I((nbe,iL)=>{"use strict";var V4=(B(),C(G)).OPERATIONS_ENUM,oR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=V4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};iL.exports=oR});var Uf=I((obe,lL)=>{"use strict";var ibe=vf(),mm=(B(),C(G)),aR=oe(),oL=Y(),K4=require("uuid"),{handleHDBError:Em,hdb_errors:Y4}=pe(),{HDB_ERROR_MSGS:gm,HTTP_STATUS_CODES:Sm}=Y4;lL.exports=aL;function aL(e,t,r){for(let s=0;s<t.length;s++)cL(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];W4(i,r,e.operation)}}a(aL,"processRows");aL.validateAttribute=cL;function cL(e){if(Buffer.byteLength(String(e))>mm.INSERT_MAX_CHARACTER_SIZE)throw Em(new Error,gm.ATTR_NAME_LENGTH_ERR(e),Sm.BAD_REQUEST,void 0,void 0,!0);if(aR.isEmptyOrZeroLength(e)||aR.isEmpty(e.trim()))throw Em(new Error,gm.ATTR_NAME_NULLISH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(cL,"validateAttribute");function W4(e,t,r){if(!e.hasOwnProperty(t)||aR.isEmptyOrZeroLength(e[t])){if(r===mm.OPERATIONS_ENUM.INSERT||r===mm.OPERATIONS_ENUM.UPSERT){e[t]=K4.v4();return}throw oL.error("Update transaction aborted due to record with no hash value:",e),Em(new Error,gm.RECORD_MISSING_HASH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>mm.INSERT_MAX_CHARACTER_SIZE)throw oL.error(e),Em(new Error,gm.HASH_VAL_LENGTH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(W4,"validateHash")});var uL,kn,cR,_u=be(()=>{uL=require("events"),kn=class extends uL.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new cR;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},cR=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});function EL(e){uR=e}function J4(){Q4=setInterval(function(){for(let e of lR)if(e.stale){let t=e.getContext()?.url;pL.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},j4).unref()}var dR,_L,pL,hL,mL,dL,lR,z4,xf,fL,uR,bc,Tm,j4,Q4,Am=be(()=>{dR=M(pn()),_L=M(pe()),pL=M(Y()),hL=M(ce());B();mL=M(oe()),dL=100,lR=new Set,z4=(0,mL.convertToMS)(hL.get(x.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(EL,"replicationConfirmation");bc=class e{static{a(this,"DatabaseTransaction")}#e;writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),lR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(lR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(xf&&!this.overloadChecked&&performance.now()-fL>z4)throw new _L.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,dR.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let _=d;_<this.validated;_++)this.writes[_]?.validate?.(this.timestamp);let p;for(let _=d;_<this.validated;_++){let h=this.writes[_];h&&(h.before||h.beforeIntermediate)&&(p=!0)}if(p)return(async()=>{try{for(let _=0;_<2;_++){let h;for(let S=d;S<this.validated;S++){let g=this.writes[S];if(!g)continue;let A=g[_===0?"before":"beforeIntermediate"];if(A){let E=A();h?h.push?h.push(E):h=[h,E]:h=E}}h&&await(h.push?Promise.all(h):h)}}catch(_){throw this.abort(),_}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let p=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||p}else l();else for(let p of this.writes)c(p)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<dL>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return xf||(xf=s,fL=performance.now(),xf.then(()=>{xf=null})),s.then(d=>{if(d){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let p=this.writes[0].store.rootStore.databaseName,_=this.writes[this.writes.length-1];uR&&_&&i.push(uR(p,_.store.getEntry(_.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+dL/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let f={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(p=>({txnTime:r,next:p}));f.next=d}return f}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}getContext(){return this.#e}setContext(t){this.#e=t}},Tm=class extends bc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,dR.getNextMonotonicTime)())}getReadTxn(){}},j4=3e4;a(J4,"startMonitoringTxns");J4()});function Ot(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new bc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n.setContext(e),e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var gL,Oc=be(()=>{gL=M(yi());Am();a(Ot,"transaction");(0,gL._assignPackageExport)("transaction",Ot);Ot.commit=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ot.abort=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});function _R(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let d=u(l);for(let _=1;_<e.length;_++){let h=e[_],S=u(h);d=d.concat(S)}let p=new Set;return d.filter(_=>{let h=_.key??_;return p.has(h)?!1:(p.add(h),!0)})}else{let d=u(l),p=f(e.slice(1),!0,l.estimated_count);return p.length>0?o(d,p):d}function u(d){return d.conditions?_R(d.conditions,d.operator,r,n,s,i,o,c):mu(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function f(d,p,_){return d.map((h,S)=>{if(h.conditions){let E=h.operator==="or",R=f(h.conditions,!E,_);return E?(N,v)=>R.some(k=>k(N,v)):(N,v)=>R.every(k=>k(N,v))}let g=(h.attribute||h[0])===r.primaryKey,A=kf(h,r,i,c,g,_);return p&&S<d.length-1&&_&&(_=o3(r.primaryStore,h.estimated_count,_)),A}).filter(Boolean)}a(f,"mapConditionsToFilters")}function mu(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(c===void 0&&l!=="sort")throw new mn.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let E=o[0],R=wi(n.attributes,E);if(R.relationship){if(o.length<2)throw new mn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let N=R.definition?.tableClass||R.elements?.definition?.tableClass,v=new Map,k=mu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,N,s,v);if(R.relationship.to){i[o[0]]=v;let F=!!wi(N.attributes,R.relationship.to)?.elements;k=r3(k,R,N.primaryStore,F,v)}if(R.relationship.from){let F=a(K=>(K?.key!==void 0&&(K=K.key),mu({attribute:R.relationship.from,value:K},t,r,n,s,v)),"searchEntry");R.elements?(i[o[0]]=v,k=n3(k,R,N.primaryStore,v,F)):k=k.flatMap(F)}return k}else if(o.length===1)o=o[0];else throw new mn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,f,d,p;c instanceof Date&&(c=c.getTime());let _;switch(pR[l]||l){case"lt":u=!0,f=c;break;case"le":u=!0,f=c,d=!0;break;case"gt":u=c,p=!0;break;case"ge":u=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],u=c,f=c.slice(0),f[f.length-1]=Ni.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),f=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),f=c[1],f instanceof Date&&(f=f.getTime()),d=l==="gele"||l==="gtle"||l==="between",p=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,f=c,d=!0;break;case"ne":if(c===null){u=c,p=!0;break}case"sort":case"contains":case"ends_with":u=!0,_=!0;break;default:throw new mn.ClientError(`Unknown query comparator "${l}"`)}let h,S=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>Ts.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Ts.MAX_SEARCH_KEY_LENGTH)+Ts.OVERFLOW_MARKER,p=!1,h=kf(e,n,null,i,S)),typeof f=="string"&&f.length>Ts.MAX_SEARCH_KEY_LENGTH&&(f=f.slice(0,Ts.MAX_SEARCH_KEY_LENGTH)+Ts.OVERFLOW_MARKER,d=!0,h=h??kf(e,n,null,i,S)),r){let E=u;u=f,f=E,E=!p,p=!d,d=E}let g=S?n.primaryStore:n.indices[o];if(!g||g.isIndexing||_||c===null&&!g.indexNulls){if(s===!1&&!g)throw new mn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&_)throw new mn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(g?.isIndexing)throw new mn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&g&&!g.indexNulls)throw new mn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??kf(e,n,null,i,S),!h)throw new mn.ClientError(`Unknown search operator ${e.comparator}`)}let A={start:u,end:f,inclusiveEnd:d,exclusiveStart:p,values:!0,versions:S,transaction:t,reverse:r};if(S){let E=g.getRange(A).map(h?function({key:R,value:N}){return this?.isSync?N&&h(N)?R:ha.SKIP:new Promise((v,k)=>setImmediate(()=>{try{v(N&&h(N)?R:ha.SKIP)}catch(F){k(F)}}))}:R=>R.value==null&&!(R.metadataFlags&(Fn|Ea))?ha.SKIP:R);return E.hasEntries=!0,E}else return g?g.getRange(A).map(h?function({key:E,value:R}){let N;return typeof E=="string"&&E.length>Ts.MAX_SEARCH_KEY_LENGTH?N=n.primaryStore.get(R):N={[o]:E},this.isSync?h(N)?R:ha.SKIP:new Promise((v,k)=>setImmediate(()=>{try{v(h(N)?R:ha.SKIP)}catch(F){k(F)}}))}:({value:E})=>E):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:E,value:R}){return this.isSync?R&&h(R)?E:ha.SKIP:new Promise((N,v)=>setImmediate(()=>{try{N(R&&h(R)?E:ha.SKIP)}catch(k){v(k)}}))})}function wi(e,t){if(Array.isArray(t))if(t.length>1){let r=wi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?wi(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function r3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=a((u,f)=>{let d=s.get(u);d?d.push(f):s.set(u,d=[f])},"add_entry");for(let u of e){let f=u.value??r.get(u.key??u),d=f?.[c];if(d!=null&&!s.filters?.some(p=>!p(f)))if(n)for(let p=0;p<d.length;p++)l(d[p],u);else l(d,u)}return i=s.keys()[Symbol.iterator](),this.next()}let o=i.next();return o.done?o:{value:o.value}},return(){if(i?.return)return i.return()}}}})}function n3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=f=>f[t.relationship.from]?.filter?.(d=>u.has(d));for(let f of e){if(n.filters){let d=r.get(f);if(n.filters.some(p=>!p(d)))continue}u.add(f)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(o=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function kf(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let f=c[0],d=wi(t.attributes,f),p=d.definition?.tableClass||d.elements.definition?.tableClass,_=n?.[f],h=kf({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},p,r,_?.[f]?.joined,c[1]===p.primaryKey,i);if(!h)return;if(_){_.filters||(_.filters=[]),_.filters.push(h);return}let S=t.propertyResolvers?.[f],g,A=a((E,R)=>{let N,v;if(S){if(S.from&&h.idFilter){if(!g)if(h.idFilter.idSet?.size===1){for(let F of h.idFilter.idSet)e={attribute:S.from,value:F};g=u(S.from,h.idFilter,!0,!0)}else g=u(S.from,h.idFilter,!1,!0);let k=g(E);return g.idFilter&&(A.idFilter=g.idFilter),k}v=S(E,r,R),N=v?.value}else N=E[f];return N?Array.isArray(N)?N.some(h):h(N,v):!1},"recordFilter");return A}}switch(l instanceof Date&&(l=l.getTime()),pR[o]||o){case Ts.SEARCH_TYPES.EQUALS:case void 0:return u(c,f=>f===l,!0);case"contains":return u(c,f=>f?.toString().includes(l));case"ends_with":return u(c,f=>f?.toString().endsWith(l));case"starts_with":return u(c,f=>typeof f=="string"&&f.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,f=>{if(!Array.isArray(f))return!1;for(let d=0,p=l.length;d<p;d++)if(f[d]!==l[d])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,f=>(0,Ni.compareKeys)(f,l[0])>=0&&(0,Ni.compareKeys)(f,l[1])<=0,!0);case"gt":return u(c,f=>(0,Ni.compareKeys)(f,l)>0);case"ge":return u(c,f=>(0,Ni.compareKeys)(f,l)>=0);case"lt":return u(c,f=>(0,Ni.compareKeys)(f,l)<0);case"le":return u(c,f=>(0,Ni.compareKeys)(f,l)<=0);case"ne":return u(c,f=>(0,Ni.compareKeys)(f,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new mn.ClientError(`Unknown query comparator "${o}"`)}function u(f,d,p,_){let h;p=p&&!s&&t?.indices[f]&&i>3,p&&(e.estimated_count==null&&ym(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(p=!1));let S=0,g=3;function A(E){let R=E[f],N;if(typeof R!="object"||!R||_?N=d(R):Array.isArray(R)?N=R.some(d):R instanceof Date&&(N=d(R.getTime())),p&&(g++,!N&&!A.idFilter&&++S/g*(i-g)>h)){let v=mu(e,r.transaction.getReadTxn(),!1,t).map(Eu),k=new Set(v);A.idFilter=F=>k.has(Eu(F)),A.idFilter.idSet=k}return N}return a(A,"recordFilter"),s&&(A.idFilter=d),A}a(u,"attributeComparator")}function ym(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/co(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=pR[n]||n,n===Ts.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=wi(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=ym(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*co(e.indices[i.relationship.from])/(co(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=co(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=e3*co(e.primaryStore)+1:n==="between"?r.estimated_count=Z4*co(e.primaryStore)+1:n==="sort"?r.estimated_count=co(e.primaryStore)+1:r.estimated_count=X4*co(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function bm(e){if(e)if(ma=e,pu.lastIndex=0,s3.test(e))try{let t=Bf(new hu,"");if(hn!==ma.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${hn} in '${ma}'`,t}else return new URLSearchParams(e)}function Bf(e,t){let r=pu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ma);){hn=r.lastIndex;let[,f,d]=n;if(o){if(f)throw new SyntaxError(`expected operator, but encountered '${f}'`);o=!1,c=!1}else c=!0;let p;switch(d){case"=":if(s!=null){if(f.length<=2)i=f;else throw new SyntaxError(`invalid FIQL operator ${f}`);l=SL}else{if(l=decodeURIComponent,i="equals",!f)throw new SyntaxError("attribute must be specified before equality comparator");s=Hf(f)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=t3[d],l=fR[i]?SL:decodeURIComponent,!f)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=Hf(f);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${d[0]?"'"+d[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${d?"'"+d+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s||null,value:l(f)};if(i==="eq"&&TL(h,f),s===""){let S=e.conditions[e.conditions.length-1];S.chainedConditions=S.chainedConditions||[],S.chainedConditions.push(h),S.operator=u}else Rm(e,u),e.conditions.push(h)}d==="&"?(u="and",s=void 0):d==="|"?(u="or",s=void 0):d==="&="?(u="and",s=""):d==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(Hf(f)),s=void 0;break;case"(":pu.lastIndex=hn;let _=Bf(f?[]:new hu,")");switch(f){case"":Rm(e,u),e.conditions.push(_);break;case"limit":switch(_.length){case 1:e.limit=+_[0];break;case 2:e.offset=+_[0],e.limit=_[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(_[0])&&_.length===1&&!_[0].name?(e.select=_[0],e.select.asArray=!0):_.length===1?e.select=_[0]:_.length===2&&_[1]===""?e.select=_.slice(0,1):e.select=_;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=AL(_);break;default:throw new SyntaxError(`unknown query function call ${f}`)}ma[hn]===","?r.lastIndex=++hn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!f)throw new SyntaxError("property sets must have a defined parent property name");pu.lastIndex=hn,p=Bf([],"}"),p.name=f,e.push(p),ma[hn]===","?r.lastIndex=++hn:o=!0;break;case"[":pu.lastIndex=hn,f?(p=Bf(new hu,"]"),p.name=f):p=Bf(e.conditions?new hu:[],"]"),e.conditions?(Rm(e,u),e.conditions.push(p),s=null):e.push(p),ma[hn]===","?r.lastIndex=++hn:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(f)};i==="eq"&&TL(h,f),Rm(e,u),e.conditions.push(h)}else if(f)throw new SyntaxError("no attribute or comparison specified")}else(f||e.length>0&&c)&&e.push(Hf(f));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${d[0]}'`):new SyntaxError(`unexpected token '${d[0]}'`);default:throw new SyntaxError(`unexpected operator '${d}'`)}if(t!==")"&&(r=s?i3:pu,r.lastIndex=hn),hn===ma.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function Rm(e,t){if(e.conditions.length>0)if(e.operator){if(e.operator!==t)throw new SyntaxError("Can not mix operators within a condition grouping")}else e.operator=t}function Hf(e){return e.indexOf(".")>-1?e.split(".").map(Hf):decodeURIComponent(e)}function SL(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 TL(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 AL(e){let t=RL(e[0]);return e.length>1&&(t.next=AL(e.slice(1))),t}function RL(e){if(Array.isArray(e)){let t=RL(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}throw new SyntaxError(`Unknown sort type ${e}`)}function Eu(e){return Array.isArray(e)?e.join("\0"):e}function co(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function o3(e,t,r){return t*r/co(e)}var mn,Ts,Ni,ha,X4,Z4,e3,t3,fR,pR,s3,pu,i3,hn,ma,hu,Nc,Ff=be(()=>{mn=M(pe()),Ts=M(vt()),Ni=require("ordered-binary"),ha=require("lmdb");Gf();X4=.3,Z4=.1,e3=.05,t3={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},fR={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(_R,"executeConditions");a(mu,"searchByIndex");a(wi,"findAttribute");a(r3,"joinTo");a(n3,"joinFrom");pR={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};a(kf,"filterByType");a(ym,"estimateCondition");s3=/[()[\]|!<>.]|(=\w*=)/,pu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,i3=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(bm,"parseQuery");a(Bf,"parseBlock");a(Rm,"assignOperator");a(Hf,"decodeProperty");a(SL,"typedDecoding");a(TL,"wildcardDecoding");a(AL,"toSortObject");a(RL,"toSortEntry");hu=class{static{a(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}};a(Eu,"flattenKey");a(co,"estimatedEntryCount");a(o3,"intersectionEstimate");Nc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var mR={};ve(mR,{MultiPartId:()=>Nm,Resource:()=>Vr,snake_case:()=>c3,transformForSelect:()=>wm});function c3(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function yL(e,t){if(wc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(wc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new Nm;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){wc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return wc=!0,null;e[e.length-1]==="/"&&(wc=!0)}return t.coerceId(decodeURIComponent(e))}function Gn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,f;if(r?(o?(f=i,o=o.getContext?.()||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(f=s,c=f[this.primaryKey]??null,o=i.getContext?.()||i):f=i:(f=s,s=void 0,c=f.getId?.()??f[this.primaryKey]),c===null&&(u=!0)):i?o=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string")if(this.directURLMapping)c=c.slice(1);else{let _=c.indexOf("?");if(_>-1){let S=this.parseQuery(c.slice(_+1));l?S&&(l=Object.assign(S,l)):l=S,c=c.slice(0,_)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let _ of s){if(typeof _=="object"&&_)break;c.push(_)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Nc(c),c==null&&(u=!0);o||(o={});let d;if(l?.ensureLoaded!=null||l?.async||u?(d={...t},l?.ensureLoaded!=null&&(d.ensureLoaded=l.ensureLoaded),l?.async&&(d.async=l.async),u&&(d.isCollection=!0)):d=t,o.transaction){let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)}else return Ot(o,()=>{let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)},d);function p(_){if(o.authorize){o.authorize=!1;let h=t.type==="read"?_.allowRead(o.user,l,o):t.type==="update"?_.doesExist?.()===!1?_.allowCreate(o.user,f,o):_.allowUpdate(o.user,f,o):t.type==="create"?_.allowCreate(o.user,f,o):_.allowDelete(o.user,l,o);if(h?.then)return h.then(S=>{if(!S)throw new Om(o.user);return typeof f?.then=="function"?f.then(g=>e(_,l,o,g)):e(_,l,o,f)});if(!h)throw new Om(o.user)}return typeof f?.then=="function"?f.then(h=>e(_,l,o,h)):e(_,l,o,f)}a(p,"authorizeActionOnResource")}}function qn(e,t){let r=new NL.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function hR(e,t,r){let n=e.getRecord?.();if(n){let s=e.getChanges?.();return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function wm(e,t){let r=t.propertyResolvers,n=t.getContext?.(),s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):hR(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],f=i(hR(l,r,n));for(let d of e)u.push(f(d));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(p=>p&&typeof p=="object"?c(p):p);let u={},f=i(hR(l,r,n)),d;for(let p of e){let _=f(p);_===void 0&&o&&(_=null),_?.then?(d||(d=[]),d.push(_.then(h=>u[p.name||p]=h))):u[p.name||p]=_}return d?Promise.all(d).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let f=r[c.name]?.definition?.tableClass;l=s[c.name]=wm(c.select||c,f)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var bL,OL,NL,a3,Vr,Om,wc,Nm,ga=be(()=>{bL=require("crypto");_u();OL=M(yi()),NL=M(pe());Oc();Ff();a3={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Vr=class{static{a(this,"Resource")}#e;#t;#n;static transactions;static directURLMapping=!1;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=Gn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=wm(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=Gn(function(t,r,n,s){if(Array.isArray(s)&&t.#n){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(f=>f.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):qn(t,"put")},{hasContent:!0,type:"update"});static patch=Gn(function(t,r,n,s){return t.patch?t.patch(s,r):qn(t,"patch")},{hasContent:!0,type:"update"});static delete=Gn(function(t,r,n,s){return t.delete?t.delete(r):qn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,bL.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={}),Ot(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):qn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=Gn(function(t,r,n,s){return t.invalidate?t.invalidate(r):qn(t,"delete")},{hasContent:!1,type:"update"});static post=Gn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Gn(function(t,r,n,s){return t.connect?t.connect(s,r):qn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Gn(function(t,r,n,s){return t.subscribe?t.subscribe(r):qn(t,"subscribe")},{type:"read"});static publish=Gn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.publish(s,r):qn(t,"publish")},{hasContent:!0,type:"create"});static search=Gn(function(t,r,n,s){let i=t.search?t.search(r):qn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=wm(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Gn(function(t,r,n,s){return t.search?t.search(s,r):qn(t,"search")},{hasContent:!0,type:"read"});static copy=Gn(function(t,r,n,s){return t.copy?t.copy(s,r):qn(t,"copy")},{hasContent:!0,type:"create"});static move=Gn(function(t,r,n,s){return t.move?t.move(s,r):qn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#n)return(await this.constructor.create(this.#e,t,this.#t)).#e;qn(this,"post")}static isCollection(t){return t&&t.#n}get isCollection(){return this.#n}static coerceId(t){return t}static parseQuery(t){return bm(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1),c=r?.headers&&a3[o];if(c)r.requestedContentType=c,t=t.slice(0,s);else if(this.attributes?.find(l=>l.name===o))if(t=t.slice(0,s),n)n.property=o;else return{query:{property:o},id:yL(t,this),isCollection:wc}}let i=yL(t,this);return wc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(f=>f.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let f of l){let d=f.#e,p=u.get(d);p?p.push(f):u.set(d,[f])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s.#n=!0),s}subscribe(t){return new kn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new kn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,OL._assignPackageExport)("Resource",Vr);a(c3,"snake_case");Om=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(yL,"pathToId");Nm=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(Gn,"transactional");a(qn,"missingMethod");a(hR,"selectFromObject");a(wm,"transformForSelect")});var Sa,ER=be(()=>{Sa=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var CL={};ve(CL,{Resources:()=>Im,keyArrayToString:()=>gu,resetResources:()=>l3,resources:()=>Ii});function l3(){return Ii=new Im}function gu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var wL,IL,Im,Ii,Su=be(()=>{Oc();ER();wL=M(Y()),IL=M(pe()),Im=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new IL.ServerError(`Conflicting paths for ${t}`);wL.default.error(c),i.Resource=new Sa(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let f=this.get(c.slice(0,u));f&&(f.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,o=t.length;for(;n<o;){s=n,n=t.indexOf("/",n),n===-1&&(n=o);let u=n===o?t:t.slice(0,n),f=this.get(u),d=-1;if(!f&&n===o&&(d=u.indexOf("?",s),d!==-1)){let p=u.slice(0,d);f=this.get(p)}if(f&&(!r||f.exportTypes?.[r]!==!1)){if(f.relativeURL=t.slice(d!==-1?d:n),!f.hasSubPaths)return f;i=f}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Ot(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(l3,"resetResources");a(gu,"keyArrayToString")});var Tu={};ve(Tu,{server:()=>We});var PL,We,Kr=be(()=>{PL=M(yi()),We={};(0,PL._assignPackageExport)("server",We)});var TR={};ve(TR,{loadGQLSchema:()=>f3,start:()=>SR,startOnMainThread:()=>d3});function SR({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:f}=await import("graphql"),d=o(new c(r.toString(),s)),p=new Map,_=[],h;for(let A of d.definitions)switch(A.kind){case l.OBJECT_TYPE_DEFINITION:let k=function(K){if(K.kind==="NonNullType"){let Z=k(K.type);return Z.nullable=!1,Z}if(K.kind==="ListType")return{type:"array",elements:k(K.type)};let ae={type:K.name?.value};return Object.defineProperty(ae,"location",{value:K.loc.startToken}),ae};a(k,"getProperty");let E=A.name.value,R=[],N={table:null,database:null,properties:R};p.set(E,N);for(let K of A.directives){if(K.name.value==="table"){for(let ae of K.arguments)N[ae.name.value]=ae.value.value;N.schema&&(N.database=N.schema),N.table||(N.table=E),N.audit&&(N.audit=N.audit!=="false"),N.attributes=N.properties,_.push(N)}if(K.name.value==="sealed"&&(N.sealed=!0),K.name.value==="splitSegments"&&(N.splitSegments=!0),K.name.value==="replicate"&&(N.replicate=!0),K.name.value==="export"){N.export=!0;for(let ae of K.arguments)typeof N.export!="object"&&(N.export={}),N.export[ae.name.value]=ae.value.value}}let v=!1,F={};for(let K of A.fields){let re=k(K.type);re.name=K.name.value,R.push(re),F[re.name]=void 0;for(let ae of K.directives){let Z=ae.name.value;if(Z==="primaryKey")v?console.warn("Can not define two attributes as a primary key at",ae.loc):(re.isPrimaryKey=!0,v=!0);else if(Z==="indexed")re.indexed=!0;else if(Z==="computed"){for(let se of ae.arguments||[])if(se.name.value==="from"){let W=se.value.value;re.computed={from:g(W,se,F)},re.version==null&&(re.version=W)}else se.name.value==="version"&&(re.version=se.value.value);re.computed=re.computed||!0}else if(Z==="relationship"){let se={};for(let W of ae.arguments)se[W.name.value]=W.value.value;re.relationship=se}else if(Z==="createdTime")re.assignCreatedTime=!0;else if(Z==="updatedTime")re.assignUpdatedTime=!0;else if(Z==="expiresAt")re.expiresAt=!0;else if(Z==="allow"){let se=re.authorizedRoles=[];for(let W of ae.arguments)W.name.value==="role"&&se.push(W.value.value)}else server.knownGraphQLDirectives.includes(Z)&&console.warn(`@${Z} is an unknown directive, at`,ae.loc)}}N.type=E,E==="Query"&&(h=N)}function S(A){let E=p.get(A.type);E?(Object.defineProperty(A,"properties",{value:E.properties}),Object.defineProperty(A,"definition",{value:E})):A.type==="array"?S(A.elements):u3.includes(A.type)||(0,LL.getWorkerIndex)()===0&&console.error(`The type ${A.type} is unknown at line ${A.location.line}, column ${A.location.column}, in ${s}`)}a(S,"connectPropertyType");for(let A of p.values())for(let E of A.properties)S(E);for(let A of _)A.tableClass=e(A),A.export&&(A.export.name===""?i.set((0,gR.dirname)(n),A.tableClass):i.set((0,gR.dirname)(n)+"/"+(A.export.name||A.type),A.tableClass,A.export));function g(A,E,R){return new DL.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${A}; } } } } computed;`,{filename:s,lineOffset:E.loc.startToken.line-1,columnOffset:E.loc.startToken.column}).runInThisContext()(R)}a(g,"createComputedFrom")}}var gR,DL,LL,u3,d3,f3,ML=be(()=>{gR=require("path"),DL=require("node:vm");Pe();LL=M(tt()),u3=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt","Blob"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(SR,"start");d3=SR,f3=SR({ensureTable:lt}).handleFile});var FL={};ve(FL,{parse:()=>RR,streamAsJSON:()=>qf,stringify:()=>Ic});function qf(e){return new AR({value:e})}function vL(e){return console.error(e),JSON.stringify(e.toString())}function UL(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Ic(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===HL)return kL(e);if(t.resolution)return t.resolution.then(()=>Ic(e));throw t}}function kL(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+=kL(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Ic(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function RR(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),h3.test(e)?_3.parse(e):JSON.parse(e)):null}var xL,BL,_3,p3,HL,AR,h3,yR=be(()=>{xL=require("stream"),BL=M(require("json-bigint-fixes")),_3=(0,BL.default)({useNativeBigInt:!0}),p3=1e4,HL={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw HL};a(qf,"streamAsJSON");AR=class extends xL.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),vL)}catch(s){yield vL(s)}else yield Ic(t)}else yield Ic(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);UL(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>p3?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return UL(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(vL,"handleError");a(UL,"when");a(Ic,"stringify");a(kL,"jsStringify");h3=/[[,:]\s*-?\d{16,}/;a(RR,"parse")});var Ci=I(Pm=>{var Cm=Y();for(let e of["trace","debug","info","warn","error","fatal","notify"])Cm.logsAtLevel(e)&&(Pm[e]=Cm[e]);Pm.loggerWithTag=e=>Cm.loggerWithTag(e,!0);Pm.setLogLevel=Cm.setLogLevel});var Fm={};ve(Fm,{Blob:()=>Pi,blobsWereEncoded:()=>Pc,databasePaths:()=>Mm,decodeBlobsWithWrites:()=>wR,decodeFromDatabase:()=>Dc,decodeWithBlobCallback:()=>IR,deleteBlob:()=>jL,deleteBlobsInObject:()=>Aa,deleteRootBlobPathsForDB:()=>NR,encodeBlobsAsBuffers:()=>O3,encodeBlobsWithFilePath:()=>km,findBlobsInObject:()=>Yf,getFileId:()=>Bm,getFilePathForBlob:()=>JL,getRootBlobPathsForDB:()=>Hm,setDeletionDelay:()=>S3});function WL(){}function jL(e){let t=JL(e);t&&setTimeout(()=>{(0,Qe.unlink)(t,r=>{r&&Ta.default.debug?.("Error trying to remove blob file",r)})},zL)}function S3(e){zL=e}function QL(e){let t=En.get(e);if(!t)t={storageIndex:0,fileId:null,store:Js},En.set(e,t);else{if(t.saving)return t;t.store=Js}return A3(t),t.source?bR(e,t.source,t):t.contentBuffer?T3(e,t):bR(e,Vf.Readable.from(e.stream()),t),t}function bR(e,t,r){let{filePath:n,fileId:s,store:i,compress:o,flush:c}=r;return r.saving=new Promise((l,u)=>{let f=s+":blob";if(!i.attemptLock(f,0))throw new Error(`Unable to get lock for blob file ${s}`);let d=(0,Qe.createWriteStream)(n,{autoClose:!1,flags:"w"});if(t.errored){let g=Buffer.from(t.errored.toString());d.end(Buffer.concat([h(BigInt(g.length)+0xff000000000000n),g]));return}let p=!1;e.size!==void 0&&(d.write(h(e.size)),p=!0);let _;o?(p||d.write(E3),_=(0,Um.createDeflate)(),t.pipe(_).pipe(d)):(p||d.write(m3),t.pipe(d)),t.on("error",S);function h(g){let A=BigInt(g),E=new Uint8Array(mr),R=new DataView(E.buffer);return A|=BigInt(o?OR:YL)<<48n,R.setBigInt64(0,A),E}a(h,"createHeader");function S(g){i.unlock(f,0);let A=d.fd;g?(A&&(0,Qe.close)(A),u(g)):c?(0,Qe.fdatasync)(A,E=>{E&&u(E),l(),(0,Qe.close)(A)}):(l(),(0,Qe.close)(A))}a(S,"finished"),d.on("error",S).on("finish",()=>{if(p)S();else{let g=_?_.bytesWritten:d.bytesWritten-mr;e.size=g,(0,Qe.write)(d.fd,h(g),0,mr,0,S)}})}),e}function Bm(e){return En.get(e)?.fileId}function JL(e){let t=En.get(e);return t?.fileId&&Kf(t)}function Hm(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=Mm.get(e);if(!t){if(!e.databaseName)throw new Error("No database name specified, can not determine blob storage path");let r=(0,xm.get)(x.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,uo.join)(n,e.databaseName)):t=[(0,uo.join)((0,xm.getHdbBasePath)(),"blobs",e.databaseName)],Mm.set(e,t)}return t}async function NR(e){let t=Mm.get(e);t&&await Promise.all(t.map(r=>XL(r)))}async function XL(e){for(let t of await(0,Xs.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await XL((0,uo.join)(e,t.name));else try{await(0,Xs.unlink)((0,uo.join)(e,t.name))}catch(r){Ta.default.warn?.("Error deleting file",r)}try{await(0,Xs.rmdir)(e)}catch(t){Ta.default.warn?.("Error deleting directory",t)}}function Kf({storageIndex:e,fileId:t,store:r}){let n=Hm(r);return(0,uo.join)(n[e],t.slice(-9,-6)||"0",t.slice(-6,-3)||"0",t.length<=9?t.slice(-3):t.slice(0,-9)+t.slice(-3))}function T3(e,t){let r=t.contentBuffer,n=r.length;if(!(n<KL))return e.size=n,bR(e,Vf.Readable.from([r]),t)}function A3(e){let t=Hm(e.store),r=R3(),n=t?.length>1?y3(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=Kf(e),o=(0,uo.dirname)(i);(0,Qe.existsSync)(o)||(0,VL.ensureDirSync)(o),e.filePath=i}function R3(){let e=$L.get(Js);if(!e){let t=0,r=Hm(Js);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let o=0;if((0,Qe.existsSync)(n))for(let c of(0,Qe.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>o&&(o=l)}s+=o,n=(0,uo.join)(n,o.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(Js.getUserSharedBuffer("blob-file-id",e.buffer)),$L.set(Js,e)}return Number(Atomics.add(e,0,1n))}function y3(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(vm);for(let i=0;i<s.length;i++)s[i]=i%e.length;e.frequencyTable=s}return(e.lastUpdated??0)+6e4<r&&(e.lastUpdated=r,b3(e)),e.frequencyTable[t%vm]}async function b3(e){if(!Xs.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let o=await(0,Xs.statfs)(s),c=o.bavail*o.bsize;return Math.pow(c,.8)})),r=new Array(vm),n=t.map(s=>1/s);for(let s=0;s<vm;s++){let i=1/0,o=0;for(let c=0;c<n.length;c++)n[c]<i&&(o=c,i=n[c]);n[o]+=1/t[o],r[s]=o}e.frequencyTable=r}function km(e,t,r){Au=t,Js=r,Pc=!1;try{return e()}finally{Au=void 0,Js=void 0}}function O3(e){Dr=[];let t;try{t=e()}catch(n){throw Dr=void 0,n}let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r?r.then(()=>e()):t}function wR(e,t){try{Dr=[],Cc=t,e()}catch(n){throw Cc=void 0,Dr=void 0,n}Cc=void 0;let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r}function IR(e,t){try{return Cc=t,e()}finally{Cc=void 0}}function Dc(e,t){return Js=t,e()}function Aa(e){Yf(e,t=>{jL(t)})}function Yf(e,t){if(e instanceof Pi)t(e);else if(e.constructor===Object||Array.isArray(e))for(let r in e)typeof e[r]=="object"&&Yf(e[r],t)}function N3(){return class{static{a(this,"Blob")}content;constructor(t){this.content=t[0]}stream(){return new ReadableStream({start(t){t.enqueue(this.content),t.close()}})}text(){return Promise.resolve(this.content.toString())}arrayBuffer(){return Promise.resolve(this.content.buffer)}get size(){return this.content.length}slice(){throw new Error("Not implemented")}bytes(){return Promise.resolve(this.content)}get type(){return""}}}var lo,Xs,Qe,Um,Vf,VL,xm,uo,Ta,KL,mr,YL,OR,GL,m3,E3,qL,En,Cc,Pi,Au,Dr,Js,Pc,$f,Dm,g3,Lm,zL,Mm,$L,vm,As=be(()=>{lo=require("msgpackr"),Xs=require("node:fs/promises"),Qe=require("node:fs"),Um=require("node:zlib"),Vf=require("node:stream"),VL=require("fs-extra"),xm=M(ce());B();uo=require("path"),Ta=M(Ci());fo();KL=8192,mr=8,YL=0,OR=1,GL=255,m3=new Uint8Array([0,YL,255,255,255,255,255,255]),E3=new Uint8Array([0,OR,255,255,255,255,255,255]),qL=0xffffffffffff,En=new WeakMap,Pi=global.Blob||N3(),Pc=!1,$f=new Uint8Array(8),Dm=new DataView($f.buffer),g3=6e4;a(WL,"InstanceOfBlobWithNoConstructor");WL.prototype=Pi.prototype;Lm=class e extends WL{static{a(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=En.get(this),{start:r,end:n,contentBuffer:s}=t;return s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?s.toString():(CR(this.bytes().then(i=>t.contentBuffer=i)),"")}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=En.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=Kf(t),o,c=a(async()=>{let l,u=mr;try{if(l=await(0,Xs.readFile)(i),l.length>=mr){l.copy($f,0,0,mr);let d=Dm.getBigUint64(0);if(Number(d>>48n)===GL)throw new Error("Error in blob: "+buffer.subarray(mr));if(u=Number(d&0xffffffffffffn),u<n&&(u=n),u<qL&&(this.size=u,this.#t))for(let p of this.#t)p(u)}}catch(d){if(d.code!=="ENOENT")throw d;l=Buffer.alloc(0)}function f(d){if(u>d.length){let p=t.store,_=t.fileId+":blob";if(o)throw new Error("Incomplete blob");return new Promise((h,S)=>{if(p.attemptLock(_,0,()=>(o=!0,p.unlock(_,0),h(c()))))return o=!0,p.unlock(_,0),h(c())})}return(n!=null||r!=null)&&(d=d.subarray(r??0,n??d.length)),d}return a(f,"checkCompletion"),l[1]===OR?new Promise((d,p)=>{(0,Um.deflate)(l.subarray(mr),(_,h)=>{_?p(_):d(f(h))})}):f(l.subarray(mr))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=En.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(h){h.enqueue(r),h.close()}});let i=Kf(t),o,c=0,l=0,u,f,d,p=this;return new ReadableStream({start(){let h=1e3,S=a((g,A)=>{(0,Qe.open)(i,"r",(E,R)=>{if(E){if(E.code==="ENOENT"&&d!==!1&&(Ta.default.debug?.("File does not exist yet, waiting for it to be created",i,h),h-- >0))return setTimeout(()=>{_(),S(g,A)},20).unref();A(E),p.#e?.forEach(N=>N(E))}else o=R,g(R)})},"openFile");return new Promise(S)},pull:a(h=>{let S=0,g=100;return new Promise(a(function A(E,R){function N(k){(0,Qe.close)(o),u&&u.close(),R(k),p.#e?.forEach(F=>F(k))}a(N,"onError");let v=Buffer.allocUnsafe(262144);(0,Qe.read)(o,v,0,v.length,c,(k,F,K)=>{if(l+=F,k)return N(k);if(c===0){if(F<mr){g-- >0&&d!==!1?(_(),Ta.default.debug?.("File was empty, waiting for data to be written",i,g),setTimeout(()=>A(E,R),20).unref()):(Ta.default.debug?.("File was empty, throwing error",i,g),R(new Error(`Blob ${t.fileId} was empty`)));return}K.copy($f,0,0,mr);let re=Dm.getBigUint64(0);if(Number(re>>48n)===GL)return N(new Error("Error in blob: "+K.subarray(mr)));if(S=Number(re&0xffffffffffffn),S<qL&&p.size!==S&&(p.size=S,p.#t))for(let ae of p.#t)ae(S);K=K.subarray(mr,F),l-=mr}else if(F===0){let re=Buffer.allocUnsafe(8);return(0,Qe.read)(o,re,0,mr,0,ae=>{if(ae)return N(ae);if($f.set(re),S=Number(Dm.getBigUint64(0)&0xffffffffffffn),S>l){d!==!1?(f=setTimeout(()=>{N(new Error("File read timed out"))},g3).unref(),u=(0,Qe.watch)(i,{persistent:!1},()=>{clearTimeout(f),u.close(),_(),A(E,R)})):N(new Error("Blob is incomplete"));return}(0,Qe.close)(o),h.close(),E()})}else K=K.subarray(0,F);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=F,A(E,R);s&&l>=s&&(l>s&&(K=K.subarray(0,s-c)),l=S=s),n&&n>c&&(K=K.subarray(n-c))}c+=F;try{h.enqueue(K)}catch(re){return Ta.default.debug?.("Error enqueuing chunk",re),E()}l===S&&((0,Qe.close)(o),h.close()),E()})},"readMore"))},"pull"),cancel(){(0,Qe.close)(o),clearTimeout(f),u&&u.close()}});function _(){if(d===void 0){let h=t.store,S=t.fileId+":blob";d=!h.attemptLock(S,0,()=>{d=!1,h.unlock(S,0)}),d||h.unlock(S,0)}return d}}slice(t,r,n){let s=En.get(this),i=new e(n&&{type:n});if(s?.fileId){let o={...s,start:t,end:r};En.set(i,o),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let o={...s,contentBuffer:s.contentBuffer.subarray(t,r)};En.set(i,o),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(!t?.primaryStore?.rootStore)throw new Error("No target table specified");return QL(this).saving??Promise.resolve()}},zL=500;a(jL,"deleteBlob");a(S3,"setDeletionDelay");global.createBlob=function(e,t){let r=new Lm(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(En.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Vf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Vf.Readable.from(e);else throw new Error("Invalid source type");return r};a(QL,"saveBlob");a(bR,"writeBlobWithStream");a(Bm,"getFileId");a(JL,"getFilePathForBlob");Mm=new Map;a(Hm,"getRootBlobPathsForDB");a(NR,"deleteRootBlobPathsForDB");a(XL,"rimrafSteadily");a(Kf,"getFilePath");a(T3,"writeBlobWithBuffer");a(A3,"generateFilePath");$L=new Map;a(R3,"getNextFileId");vm=128;a(y3,"getNextStorageIndex");a(b3,"createFrequencyTableForStoragePaths");a(km,"encodeBlobsWithFilePath");a(O3,"encodeBlobsAsBuffers");a(wR,"decodeBlobsWithWrites");a(IR,"decodeWithBlobCallback");a(Dc,"decodeFromDatabase");a(Aa,"deleteBlobsInObject");a(Yf,"findBlobsInObject");(0,lo.addExtension)({Class:Pi,type:11,unpack:a(function(e){let t=(0,lo.unpack)(e),r=new Lm;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(!Js)throw new Error("No store specified, can not load blob from storage");if(En.set(r,{storageIndex:t[1],fileId:t[2],store:Js}),Cc)return Cc(r)??r}else En.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:a(function(e){let t=En.get(e);if(Au!==void 0&&(Pc=!0,t?.recordId!==void 0&&t.recordId!==Au))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<KL)return r.size=t.contentBuffer.length,(0,lo.pack)([r,t.contentBuffer])}if(Au!==void 0){if(t=QL(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Au,(0,lo.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Qe.readFileSync)(Kf(t));if(n.length>=mr&&(n.copy($f,0,0,mr),Number(Dm.getBigUint64(0)&0xffffffffffffn)===n.length-mr))return Buffer.concat([(0,lo.pack)([r]),n]);if(Dr)Dr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&Dr)return Dr.push(e.bytes()),Buffer.alloc(0);throw n}else throw new Error("Blob has no storage info or buffer attached to it")},"pack")});(0,lo.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(N3,"polyfillBlob")});var oM={};ve(oM,{asyncSerialization:()=>CR,contentTypes:()=>MR,findBestSerializer:()=>qm,getDeserializer:()=>po,registerContentHandlers:()=>jf,serialize:()=>Qf,serializeMessage:()=>ya,toCsvStream:()=>Gm});function I3(e){try{return e?.[0]===123?LR(e):e}catch{return e}}function jf(e){e.register(P3,{serializers:[{regex:/^application\/json$/,serializer:qf},{regex:/^application\/cbor$/,serializer:a(function(t){return new Lc.EncoderStream(zf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Mc.Readable.from((0,Di.encodeIter)(t,zf)):(0,Di.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),Gm(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Di.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Lc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function qm(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[u,...f]=l.split(/\s*;\s*/),d=1,p={q:1};for(let h of f){let S=h.indexOf("=");p[h.substring(0,S)]=h.substring(S+1)}d=+p.q;let _=Yr.get(u);if(_){let h=(_.q||1)*d;h>s&&(n=_,i=_.type||u,s=h,o=p)}}if(!n){if(r)throw new tM.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(Yr.keys()).join(", "),406);n=Yr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Qf(e,t,r){let n=eM&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array||e instanceof Pi)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=qm(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&e&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){if(e.mapError){let c=e.getColumns;e=e.mapError(l=>(l.toJSON=()=>({error:l.name,message:l.message,...l.partialObject}),DR.default.warn?.(`Error serializing error ${t?.url||t}: ${l}`),l)),e.getColumns=c}let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,_o.createBrotliCompress)({params:{[_o.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?_o.constants.BROTLI_MODE_TEXT:_o.constants.BROTLI_MODE_GENERIC,[_o.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>eM?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,_o.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function ya(e,t,r){if(e?.contentType!=null&&e.data!=null)return e.data;Ra=r?void 0:[];try{let n;if(t){let s=t.serialize;if(s)n=s(e);else{let i=qm(t);s=t.serialize=i.serializer.serialize,n=s(e)}}else n=Wf(e);return Ra?.length>0?(Ra.length===1?Ra[0]:Promise.all(Ra)).then(()=>ya(e,t,!0)):n}finally{Ra=void 0}}function CR(e){if(Ra)Ra.push(e);else throw new Error("Unable to serialize asynchronously")}function D3(e){return new Promise((t,r)=>{let n=[];e.on("data",s=>n.push(s)),e.on("end",()=>t(Buffer.concat(n))),e.on("error",r)})}function M3(e){return L3.includes(e)}function v3(e){let t=e.indexOf(";"),r;if(t>-1){r={};let n=e.slice(t+1).split(";");for(let s of n){let[i,o]=s.split("=");r[i.trim()]=o.trim()}e=e.slice(0,t)}return{type:e,parameters:r}}function po(e="",t=!1){let r=v3(e),n=r.type&&Yr.get(r.type)?.deserialize||U3(r);return t?s=>D3(s).then(n):n}function U3(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!M3(e.parameters.charset)&&DR.default.info(`Unknown Buffer encoding ${e.parameters.charset} in content-type. Proceeding anyways.`),t=>({contentType:e.type,data:t.toString(e.parameters?.charset||"utf-8")})):e.type==="application/octet-stream"?t=>t:t=>{if(e.type==="")try{if(t?.[0]===123)return LR(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function x3(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}function Gm(e,t){let r=Mc.default.Readable.from(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator]?e:[e]),n={};t&&(n.fields=t.map(o=>({label:o,value:o})));let s={objectMode:!0},i=new w3(n,s);return r.pipe(i)}var Di,Lc,_o,tM,Mc,rM,PR,nM,DR,w3,sM,Wf,LR,zf,Yr,MR,ZL,iM,C3,P3,eM,Ra,L3,fo=be(()=>{yR();Di=require("msgpackr"),Lc=require("cbor-x"),_o=require("zlib"),tM=M(pe()),Mc=M(require("stream"));Kr();rM=M(yi()),PR=M(ce());B();nM=M(require("yaml")),DR=M(Ci());As();({Transform:w3}=require("json2csv")),sM=PR.default.get(x.SERIALIZATION_BIGINT)!==!1,Wf=sM?Ic:JSON.stringify,LR=sM?RR:JSON.parse,zf={useRecords:!1,useToJSON:!0},Yr=new Map,MR=Yr;We.contentTypes=MR;(0,rM._assignPackageExport)("contentTypes",MR);Yr.set("application/json",{serializeStream:qf,serialize:Wf,deserialize(e){return LR(e)},q:.8});ZL=new Lc.Encoder(zf);Yr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Lc.EncoderStream(zf).end(e)},serialize:ZL.encode,deserialize:ZL.decode,q:1});Yr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Mc.Readable.from((0,Di.encodeIter)(e,zf)):(0,Di.pack)(e)},serialize:Di.pack,deserialize:Di.unpack,q:.9});Yr.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),Gm(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),Gm(e,e?.getColumns?.())},q:.1});Yr.set("text/plain",{serialize(e){return e.toString()},serializeStream(e){return Mc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Yr.set("text/yaml",{serialize(e){return nM.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Yr.set("text/event-stream",{serializeStream:a(function(e){return Mc.Readable.from(x3(e,this.serialize))},"serializeStream"),serialize:a(function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
|
|
9
|
+
`),e.data){let r=e.data;typeof r=="object"&&(r=Wf(r)),t+="data: "+r+`
|
|
10
10
|
`}return e.id&&(t+="id: "+e.id+`
|
|
11
11
|
`),e.retry&&(t+="retry: "+e.retry+`
|
|
12
12
|
`),t+`
|
|
13
|
-
`}else return typeof e=="object"?`data: ${
|
|
13
|
+
`}else return typeof e=="object"?`data: ${Wf(e)}
|
|
14
14
|
|
|
15
15
|
`:`data: ${e}
|
|
16
16
|
|
|
17
|
-
`},"serialize"),compressible:!1,q:.8});Wr.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()}});GL={type:"application/json",serializeStream:Hf,serialize:Gf,deserialize:z4,q:.5};Wr.set("*/*",GL);Wr.set("",GL);a(z4,"tryJSONParse");a(gR,"registerContentHandlers");j4=require("fastify-plugin"),Q4=j4(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=LE(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let f=l.getColumns;l=l.mapError(d=>(d.toJSON=()=>({error:d.name,message:d.message,...d.partialObject}),d)),l.getColumns=f}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((f,d)=>{s.header(f,d)},"set")}})})}),r()},{name:"content-type-negotiation"});a(LE,"findBestSerializer");BL=hR.default.get(H.HTTP_COMPRESSIONTHRESHOLD);a(Vf,"serialize");a(Oa,"serializeMessage");a(_R,"asyncSerialization");a(J4,"streamToBuffer");X4=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(Z4,"isBufferEncoding");a(e3,"parseContentType");a(go,"getDeserializer");a(t3,"deserializerUnknownType");a(r3,"transformIterable");a(DE,"toCsvStream")});var AR={};Be(AR,{start:()=>d3});function n3(e){if(e.kind!==Pe.Kind.OPERATION_DEFINITION&&e.kind!==Pe.Kind.FRAGMENT_DEFINITION)throw new Nr(`Unexpected non-executable definition type ${e.kind}.`)}function $L(e){if(typeof e!="object"||e===null)throw new Li("Request body must be an object.");if(!("query"in e))throw new Li("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Li("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Li("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Li("Request body `operationName` field must be a string.")}function TR(e){return parseInt(e.value,10)}function KL(e){return parseFloat(e.value)}function YL(e,t,r){let n=r.get(e.name.value);return WL(n)?zL(n,t):{attribute:t,value:n}}function WL(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function zL(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],WL(n)?zL(n,t):{attribute:t,value:n}))}function s3(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Pe.Kind.NULL:return{attribute:t,value:null};case Pe.Kind.INT:return{attribute:t,value:TR(e.value)};case Pe.Kind.FLOAT:return{attribute:t,value:KL(e.value)};case Pe.Kind.BOOLEAN:case Pe.Kind.STRING:return{attribute:t,value:e.value.value};case Pe.Kind.VARIABLE:return YL(e.value,t,r);case Pe.Kind.OBJECT:return jL(e.value,t,r);case Pe.Kind.LIST:case Pe.Kind.ENUM:default:throw new Nr(`Value type, ${e.value.kind}, is not supported.`)}}function jL(e,t,r){return e.fields.flatMap(n=>s3(n,t,r))}function i3(e,t){switch(e.value.kind){case Pe.Kind.NULL:return{attribute:e.name.value,value:null};case Pe.Kind.INT:return{attribute:e.name.value,value:TR(e.value)};case Pe.Kind.FLOAT:return{attribute:e.name.value,value:KL(e.value)};case Pe.Kind.BOOLEAN:case Pe.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Pe.Kind.VARIABLE:return YL(e.value,e.name.value,t);case Pe.Kind.OBJECT:return jL(e.value,[e.name.value],t);case Pe.Kind.LIST:case Pe.Kind.ENUM:default:throw new Nr(`Argument type, ${e.value.kind}, is not supported.`)}}function o3(e,t){return e.flatMap(r=>i3(r,t))}function ME(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Pe.Kind.FIELD:return r;case Pe.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Nr(`Fragment \`${n}\` not found.`);return ME(s.selectionSet,t)}case Pe.Kind.INLINE_FRAGMENT:return ME(r.selectionSet,t)}})}function QL(e,t){return ME(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:QL(r.selectionSet,t)}:r.name.value)}async function a3(e,t,r,n){let s=Ci.getMatch(e.name.value,"graphql");if(s===void 0)throw new Nr(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:QL(e.selectionSet,r),conditions:o3(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(o,n))c.push(l);return[e.name.value,c]}function JL(e){switch(e.kind){case Pe.Kind.NULL:return null;case Pe.Kind.INT:return TR(e);case Pe.Kind.FLOAT:return parseFloat(e.value);case Pe.Kind.STRING:case Pe.Kind.BOOLEAN:return e.value;case Pe.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:JL(r.value),...t}),{});case Pe.Kind.LIST:case Pe.Kind.ENUM:default:throw new Nr(`Value type, ${e.kind}, is not supported.`)}}function c3(e,t){let r=new Map;for(let n of e){let s=n.variable.name.value,i=t?.[s];if(i===void 0&&n.defaultValue!==void 0&&(i=JL(n.defaultValue)),n.type.kind===Pe.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Nr(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function l3(e,t,r,n){if(e.operation===Pe.OperationTypeNode.SUBSCRIPTION)throw new Nr("Subscriptions are not supported.");if(e.operation===Pe.OperationTypeNode.MUTATION)throw new Nr("Mutations are not supported yet.");let s=c3(e.variableDefinitions,t),i=await Promise.all(ME(e.selectionSet,r).map(c=>a3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function VL({query:e,variables:t={},operationName:r},n){let s=Pe.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(n3(u),u.kind===Pe.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Nr("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new Nr(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Nr("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Nr(`Operation \`${r}\` not found.`);let l=await l3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function u3(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return $L(r),VL(r,e)}case"POST":{let r=await go(e.headers.get("content-type"),!0)(e._nodeRequest);return $L(r),VL(r,e)}default:throw new Li("Method Not Allowed",405,{Allow:"GET, POST"})}}function d3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await u3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Li)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Pe.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Nr)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof Li)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Pe.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Nr)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}})}var Pe,Nr,Li,XL=be(()=>{Pe=x(require("graphql"));Eo();hu();a(n3,"assertExecutableDefinitionNode");a($L,"assertRequestParams");a(TR,"processIntValueNode");a(KL,"processFloatValueNode");a(YL,"processVariableNode");a(WL,"isObject");a(zL,"transformObjectIntoQueryCondition");a(s3,"processObjectFieldNode");a(jL,"processObjectValueNode");a(i3,"processArgumentNode");a(o3,"buildConditionsQuery");a(ME,"fillInFragments");a(QL,"buildSelectQuery");a(a3,"processFieldNode");a(JL,"processConstValueNode");a(c3,"resolveVariables");a(l3,"executeOperation");a(VL,"resolver");Nr=class extends Error{static{a(this,"GraphQLQueryingError")}},Li=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(u3,"graphqlQueryingHandler");a(d3,"start")});var vi=C((Bbe,tM)=>{"use strict";var eM=ae(),ZL=(v(),D(q)),mu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Mi=require("joi"),Na={schema_format:{pattern:mu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},f3=Mi.alternatives(Mi.string().min(1).max(Na.schema_length.maximum).pattern(mu).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Mi.number(),Mi.array()).required(),_3=Mi.alternatives(Mi.string().min(1).max(Na.schema_length.maximum).pattern(mu).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Mi.number()),h3=Mi.alternatives(Mi.string().min(1).max(Na.schema_length.maximum).pattern(mu).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Mi.number()).required();function p3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Na.schema_length.maximum?`'${e}' maximum of 250 characters`:mu.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(p3,"checkValidTable");function E3(e,t){return eM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(E3,"validateSchemaExists");function m3(e,t){let r=t.state.ancestors[0].schema;return eM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(m3,"validateTableExists");function g3(e,t){return e.toLowerCase()===ZL.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${ZL.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(g3,"validateSchemaName");tM.exports={common_validators:Na,schema_regex:mu,hdb_schema_table:f3,validateSchemaExists:E3,validateTableExists:m3,validateSchemaName:g3,checkValidTable:p3,hdb_database:_3,hdb_table:h3}});var pt=C((kbe,rM)=>{"use strict";var mn=require("validate.js");mn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||mn.validators.type.checks[t](e)?null:` must be a '${t}' value`};mn.validators.type.checks={Object:a(function(e){return mn.isObject(e)&&!mn.isArray(e)},"Object"),Array:mn.isArray,Integer:mn.isInteger,Number:mn.isNumber,String:mn.isString,Date:mn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};mn.validators.hasValidFileExt=function(e,t){return mn.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};rM.exports={validateObject:S3,validateObjectAsync:T3,validateBySchema:A3};function S3(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=mn(e,t,{format:"flat"});return r?new Error(r):null}a(S3,"validateObject");async function T3(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await mn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(T3,"validateObjectAsync");function A3(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(A3,"validateBySchema")});var yR=C((qbe,sM)=>{var{hdb_table:R3,hdb_database:nM}=vi(),y3=pt(),RR=require("joi"),b3={undefined:"undefined",null:"null"},O3=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||b3[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"),N3=RR.object({database:nM,schema:nM,table:R3,records:RR.array().items(RR.object().custom(O3)).required()});sM.exports=function(e){return y3.validateBySchema(e,N3)}});var oM=C(($be,iM)=>{"use strict";var bR=class{static{a(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};iM.exports=bR});var cM=C((Kbe,aM)=>{"use strict";var OR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};aM.exports=OR});var fM={};Be(fM,{HAS_EXPIRATION:()=>BE,HAS_RESIDENCY_ID:()=>LR,HAS_STRUCTURE_UPDATE:()=>kE,LAST_TIMESTAMP_PLACEHOLDER:()=>zf,LOCAL_TIMESTAMP:()=>w3,METADATA:()=>Kf,NO_TIMESTAMP:()=>NR,PENDING_LOCAL_TIME:()=>MR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>DR,RecordEncoder:()=>PR,TIMESTAMP_ASSIGN_LAST:()=>C3,TIMESTAMP_ASSIGN_NEW:()=>uM,TIMESTAMP_ASSIGN_PREVIOUS:()=>dM,TIMESTAMP_PLACEHOLDER:()=>vE,TIMESTAMP_RECORD_PREVIOUS:()=>wR,handleLocalTimeForGets:()=>FE,recordUpdater:()=>vR,removeEntry:()=>Uc});function D3(){return Wf[0]=Wf[0]^64,I3.getFloat64(0)}function FE(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(o,c){e.readCount++;let l=r.call(this,o,c),u=l?.value,f=u?.[Kf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l&&(l.key=o),l};let n=e.get;e.get=function(o,c){let l=n.call(this,o,c);return l?.[Kf]>=0?l.value:l};let s=e.getRange;e.getRange=function(o){let c=s.call(this,o);return o.valuesForKey?c.map(l=>l?.value):o.values===!1||o.onlyCount?c:c.map(l=>{let u=l.value,f=u[Kf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l})};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let o=i.constructor,c=i.use,l=i.done;o.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,vc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<vc.length;u++){let f=vc[u].deref();(!f||f.isDone||f.isCommitted)&&vc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function vR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,h){d||l==null?gu=i?.localTime?wR|dM:NR:gu=l?i?.localTime?wR|16384:uM|16384:NR;let _=u?.expiresAt;if(_>=0&&(c|=BE),Yf=c,IR=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let p={version:o,instructedWrite:gu>0},S,g=0;try{let T=i?.residencyId,m=u?.residencyId;m&&(CR=m,Yf|=LR,g|=xc),T!==m&&(g|=Bc,T||(T=0)),c&BE&&(g|=Qf),u?.originatingOperation&&(g|=jf),d&&(p.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&ei&&(r.getBinaryFast(i.localTime)||po(i.value));let A=CE(()=>e.put(n,s,p),n,e.rootStore);if(Eu&&(g|=ei),l){let w=u?.user?.username;if(h&&(UE=CE(()=>e.encoder.encode(h),n,e.rootStore)),e.encoder.hasStructureUpdate&&(g|=kE,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let M=i?.localTime,F=r.get(M);if(F){let G=Nt(F).previousLocalTime;return r.put(M,Su(o,t,n,G,u?.nodeId??server.replication.getThisNodeId(r)??0,w,f,UE,g,m,T,_),{ifVersion:S}),A}}r.put(zf,Su(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,w,f,UE,g,m,T,_,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return A}catch(T){throw T.message+=" id: "+n+" options: "+p,T}}}function Uc(e,t,r){if(t)return t.value&&t.metadataFlags&ei&&!e.auditStore.getBinaryFast(t.localTime)&&po(t.value),e.remove(t.key,r)}var lM,xE,vE,zf,DR,w3,Kf,Wf,I3,NR,uM,C3,dM,wR,BE,LR,MR,kE,P3,UE,gu,Yf,IR,CR,PR,vc,Tu=be(()=>{lM=require("msgpackr");So();xE=x(W());Ts();Ts();vE=new Uint8Array([1,1,1,1,4,64,0,0]),zf=new Uint8Array([1,1,1,1,1,0,0,0]),DR=new Uint8Array([1,1,1,1,3,64,0,0]),w3=Symbol("local-timestamp"),Kf=Symbol("metadata"),Wf=new Uint8Array(8),I3=new DataView(Wf.buffer,0,8),NR=0,uM=0,C3=1,dM=3,wR=4,BE=16,LR=32,MR=1,kE=256,gu=0,Yf=-1,IR=-1,CR=0,PR=class extends lM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(gu||Yf>=0){let o=0,c=gu;c&&(o+=8,gu=0);let l=Yf,u=IR,f=CR;l>=0&&(o+=4,Yf=-1,u>=0&&(o+=8,IR=-1),f&&(o+=4,CR=0));let d=P3=r.call(this,s,i|2048|o);UE=d.subarray((d.start||0)+o,d.end);let h=d.start||0;return c&&(vE[4]=c,vE[5]=c>>8,d.set(vE,h),h+=8),Eu&&(l|=ei),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(h,l|HE<<24),h+=4,u>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setFloat64(h,u),h+=8),f&&(d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(h,f)),d}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(Wf,0,c),c+=8;else for(let h=0;h<8;h++)Wf[h]=t[c++];l=D3(),i=t[c]}let u,f;i<32&&(i===HE?(o=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(o=i|t[c+1]<<5,c+=2),o&BE&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&LR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=Dc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Kf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:Dc(()=>super.decode(t,r),this.rootStore)}catch(c){return xE.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(D3,"getTimestamp");a(FE,"handleLocalTimeForGets");vc=[];setInterval(()=>{for(let e=0;e<vc.length;e++){let t=vc[e].deref();!t||t.isDone||t.isCommitted?vc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(xE.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):xE.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(vR,"recordUpdater");a(Uc,"removeEntry")});var Jf=C((Jbe,hM)=>{"use strict";var _M=ce(),L3=(v(),D(q)),{RecordEncoder:M3}=(Tu(),D(fM));_M.initSync();var v3=_M.get(L3.CONFIG_PARAMS.STORAGE_CACHING)!==!1,UR=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=v3&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:M3})}};hM.exports=UR});var Xf=C((Zbe,pM)=>{"use strict";var Vn=ce(),As=(v(),D(q));Vn.initSync();var qE=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=Vn.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Vn.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Vn.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Vn.get(As.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Vn.get(As.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Vn.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Vn.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Vn.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Vn.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Vn.get(As.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Vn.get(As.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Vn.get(As.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};pM.exports=qE;qE.MAX_DBS=1e4});var ct=C((tOe,OM)=>{"use strict";var BR=require("lmdb"),ti=require("fs-extra"),Kn=require("path"),GE=_n(),gM=W(),gn=Fn().LMDB_ERRORS_ENUM,$E=cM(),HR=Jf(),SM=Xf(),wa=Mt(),EM=(v(),D(q)),{table:U3,resetDatabases:x3}=(Ce(),D(tt)),mM=ce(),ri=wa.INTERNAL_DBIS_NAME,TM=wa.DBI_DEFINITION_NAME,B3="data.mdb",H3="lock.mdb",Zf=".mdb",k3="-lock",xR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Rs(t,r),this.key_type=this.dbi[wa.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[wa.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new BR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function VE(e,t){if(e===void 0)throw new Error(gn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(gn.ENV_NAME_REQUIRED)}a(VE,"pathEnvNameValidation");async function kR(e,t,r=!0){try{await ti.access(e)}catch(n){throw n.code==="ENOENT"?new Error(gn.INVALID_BASE_PATH):n}try{let n=Kn.join(e,t+Zf);return await ti.access(n,ti.constants.R_OK|ti.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await ti.access(Kn.join(e,t,B3),ti.constants.R_OK|ti.constants.F_OK),Kn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(gn.INVALID_ENVIRONMENT)}else throw new Error(gn.INVALID_ENVIRONMENT);throw n}}a(kR,"validateEnvironmentPath");function KE(e,t){if(GE.validateEnv(e),t===void 0)throw new Error(gn.DBI_NAME_REQUIRED)}a(KE,"validateEnvDBIName");async function F3(e,t,r=!1,n=!1){VE(e,t);let s=Kn.basename(e);t=t.toString();let i=mM.get(EM.CONFIG_PARAMS.DATABASES);i||mM.setProperty(EM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await kR(e,t,n),AM(e,t,r)}catch(o){if(o.message===gn.INVALID_ENVIRONMENT){let c=Kn.join(e,t);await ti.mkdirp(n?c:e);let l=new SM(n?c:c+Zf,!1),u=BR.open(l);u.dbis=Object.create(null);let f=new HR(!1);u.openDB(ri,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=FR(e,t,r);return u[wa.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(F3,"createEnvironment");async function q3(e,t,r,n=!0){VE(e,t),t=t.toString();let s=Kn.join(e,t);return U3({table:t,database:Kn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(q3,"copyEnvironment");async function AM(e,t,r=!1){VE(e,t),t=t.toString();let n=FR(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 kR(e,t),i=Kn.join(e,t+Zf),o=s!=i,c=new SM(s,o),l=BR.open(c);l.dbis=Object.create(null);let u=yM(l);for(let f=0;f<u.length;f++)Rs(l,u[f]);return l[wa.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(AM,"openEnvironment");async function G3(e,t,r=!1){VE(e,t),t=t.toString();let n=Kn.join(e,t+Zf),s=await kR(e,t);if(global.lmdb_map!==void 0){let i=FR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await RM(o),delete global.lmdb_map[i]}}await ti.remove(s),await ti.remove(s===n?s+k3:Kn.join(Kn.dirname(s),H3))}a(G3,"deleteEnvironment");async function RM(e){GE.validateEnv(e);let t=e[wa.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(RM,"closeEnvironment");function FR(e,t,r=!1){let s=`${Kn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(FR,"getCachedEnvironmentName");function $3(e){GE.validateEnv(e);let t=Object.create(null),r=Rs(e,ri);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==ri)try{t[n]=Object.assign(new $E,s)}catch{gM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a($3,"listDBIDefinitions");function yM(e){GE.validateEnv(e);let t=[],r=Rs(e,ri);for(let{key:n}of r.getRange({start:!1}))n!==ri&&t.push(n);return t}a(yM,"listDBIs");function V3(e,t){let n=Rs(e,ri).getEntry(t),s=new $E;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{gM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(V3,"getDBIDefinition");function bM(e,t,r,n=!r){if(KE(e,t),t=t.toString(),t===ri)throw new Error(gn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Rs(e,t)}catch(s){if(s.message===gn.DBI_DOES_NOT_EXIST){let i=new HR(r,n===!0),o=e.openDB(t,i),c=new $E(r===!0,n);return o[TM]=c,Rs(e,ri).putSync(t,c),e.dbis[t]=o,o}throw s}}a(bM,"createDBI");function Rs(e,t){if(KE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==ri?r=V3(e,t):r=new $E,r===void 0)throw new Error(gn.DBI_DOES_NOT_EXIST);let n;try{let s=new HR(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(gn.DBI_DOES_NOT_EXIST):s}return n[TM]=r,e.dbis[t]=n,n}a(Rs,"openDBI");function K3(e,t){KE(e,t),t=t.toString();let r=Rs(e,t),n=r.getStats();return r[wa.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(K3,"statDBI");async function Y3(e,t){try{let r=Kn.join(e,t+Zf);return(await ti.stat(r)).size}catch{throw new Error(gn.INVALID_ENVIRONMENT)}}a(Y3,"environmentDataSize");function W3(e,t){if(KE(e,t),t=t.toString(),t===ri)throw new Error(gn.CANNOT_DROP_INTERNAL_DBIS_NAME);Rs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Rs(e,ri).removeSync(t)}a(W3,"dropDBI");function z3(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Rs(e,i)}catch(o){if(o.message===gn.DBI_DOES_NOT_EXIST)bM(e,i,i!==t,i===t),n=!0;else throw o}}n&&x3()}a(z3,"initializeDBIs");OM.exports={openDBI:Rs,openEnvironment:AM,createEnvironment:F3,listDBIs:yM,listDBIDefinitions:$3,createDBI:bM,dropDBI:W3,statDBI:K3,deleteEnvironment:G3,initializeDBIs:z3,TransactionCursor:xR,environmentDataSize:Y3,copyEnvironment:q3,closeEnvironment:RM}});var wM=C((nOe,NM)=>{"use strict";var qR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};NM.exports=qR});var CM=C((iOe,IM)=>{"use strict";var GR=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}};IM.exports=GR});var DM=C((aOe,PM)=>{"use strict";var $R=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};PM.exports=$R});var kc=C((fOe,vM)=>{"use strict";var j3=ct(),Q3=wM(),J3=CM(),X3=DM(),Ui=_n(),e_=Fn().LMDB_ERRORS_ENUM,Z3=Mt(),To=(v(),D(q)),eX=ae(),tX=require("uuid"),lOe=require("lmdb"),{handleHDBError:rX,hdb_errors:nX}=_e(),{OVERFLOW_MARKER:uOe,MAX_SEARCH_KEY_LENGTH:dOe}=Z3,LM=ce();LM.initSync();var YE=LM.get(To.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),VR=To.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Hc=To.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function sX(e,t,r,n,s=Ui.getNextMonotonicTime()){zR(e,t,r,n),KR(e,t,r);let i=new Q3,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];MM(u,!0,s);let f=iX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return YR(o,c,n,i,s)}a(sX,"insertRecords");function iX(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let f=c([[{}]]);Array.isArray(f)&&(c=f[0][To.FUNC_VAL],n[o]=c)}let l=Ui.getIndexedValues(c),u=e.dbis[o];if(l){YE&&u.prefetch(l.map(f=>({key:f,value:s})),WE);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}YE&&e.dbis[t].prefetch([s],WE),e.dbis[t].put(s,n,n[Hc])})}a(iX,"insertRecord");function oX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(oX,"removeSkippedRecords");function MM(e,t,r){let n=r>0;(n||!Number.isInteger(e[Hc]))&&(e[Hc]=r||(r=Ui.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[VR]))&&(e[VR]=r||Ui.getNextMonotonicTime()):delete e[VR]}a(MM,"setTimestamps");function KR(e,t,r){r.indexOf(To.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(To.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(To.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(To.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),j3.initializeDBIs(e,t,r)}a(KR,"initializeTransaction");async function aX(e,t,r,n,s=Ui.getNextMonotonicTime()){zR(e,t,r,n),KR(e,t,r);let i=new J3,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],h;try{h=WR(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(h),l.push(d)}return YR(c,l,n,i,s,o)}a(aX,"updateRecords");async function cX(e,t,r,n,s=Ui.getNextMonotonicTime()){try{zR(e,t,r,n)}catch(l){throw rX(l,l.message,nX.HTTP_STATUS_CODES.BAD_REQUEST)}KR(e,t,r);let i=new X3,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;eX.isEmpty(u[t])?(f=tX.v4(),u[t]=f):f=u[t];let d=WR(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return YR(o,c,n,i,s)}a(cX,"upsertRecords");async function YR(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||Ui.getNextMonotonicTime(),oX(r,i),n}a(YR,"finalizeWrite");function WR(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,f=u;if(!u){if(i)return!1;u={}}if(MM(r,!f,o),Number.isInteger(r[Hc])&&u[Hc]>r[Hc])return!1;f&&s.original_records.push(u);let d,h=a(()=>{for(let p in r){if(!r.hasOwnProperty(p)||p===t)continue;let S=r[p],g=e.dbis[p];if(g===void 0)continue;let T=u[p];if(typeof S=="function"){let A=S([[u]]);Array.isArray(A)&&(S=A[0][To.FUNC_VAL],r[p]=S)}if(S===T)continue;let m=Ui.getIndexedValues(T);if(m){YE&&g.prefetch(m.map(A=>({key:A,value:n})),WE);for(let A=0,w=m.length;A<w;A++)g.remove(m[A],n)}if(m=Ui.getIndexedValues(S),m){YE&&g.prefetch(m.map(A=>({key:A,value:n})),WE);for(let A=0,w=m.length;A<w;A++)g.put(m[A],n)}}let _={...u,...r};c.put(n,_,_[Hc])},"do_put");return l?d=c.ifVersion(n,l.version,h):d=c.ifNoExists(n,h),d.then(_=>_?!0:WR(e,t,r,n,s,i,o))}a(WR,"updateUpsertRecord");function lX(e,t,r){if(Ui.validateEnv(e),t===void 0)throw new Error(e_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(e_.WRITE_ATTRIBUTES_REQUIRED):new Error(e_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(lX,"validateBasic");function zR(e,t,r,n){if(lX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(e_.RECORDS_REQUIRED):new Error(e_.RECORDS_MUST_BE_ARRAY)}a(zR,"validateWrite");function WE(){}a(WE,"noop");vM.exports={insertRecords:sX,updateRecords:aX,upsertRecords:cX}});var Ao=C((hOe,uX)=>{uX.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},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 zE=C((pOe,UM)=>{var{common_validators:xi}=vi(),r_=pt(),t_="is required",tr={database:{presence:!1,format:xi.schema_format,length:xi.schema_length},schema:{presence:!1,format:xi.schema_format,length:xi.schema_length},table:{presence:!0,format:xi.schema_format,length:xi.schema_length},attribute:{presence:!0,format:xi.schema_format,length:xi.schema_length},hash_attribute:{presence:!0,format:xi.schema_format,length:xi.schema_length}};function n_(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(n_,"makeAttributesStrings");function dX(e){return e=n_(e),tr.table.presence=!1,tr.attribute.presence=!1,tr.hash_attribute.presence=!1,r_.validateObject(e,tr)}a(dX,"schema_object");function fX(e){return e=n_(e),tr.table.presence={message:t_},tr.attribute.presence=!1,tr.hash_attribute.presence=!1,r_.validateObject(e,tr)}a(fX,"table_object");function _X(e){return e=n_(e),tr.table.presence={message:t_},tr.attribute.presence=!1,r_.validateObject(e,tr)}a(_X,"create_table_object");function hX(e){return e=n_(e),tr.table.presence={message:t_},tr.attribute.presence={message:t_},tr.hash_attribute.presence=!1,r_.validateObject(e,tr)}a(hX,"attribute_object");function pX(e){return e=n_(e),tr.table.presence={message:t_},tr.attribute.presence=!1,tr.hash_attribute.presence=!1,r_.validateObject(e,tr)}a(pX,"describe_table");function EX(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(EX,"validateTableResidence");UM.exports={schema_object:dX,create_table_object:_X,table_object:fX,attribute_object:hX,describe_table:pX,validateTableResidence:EX}});var BM=C((mOe,xM)=>{"use strict";var mX=require("uuid"),jR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||mX.v4(),this.schema_table=`${this.schema}.${this.table}`}};xM.exports=jR});var jE=C((SOe,HM)=>{"use strict";var gX=BM(),QR=class extends gX{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}};HM.exports=QR});var FM=C((AOe,kM)=>{"use strict";kM.exports=TX;var SX="inserted";function TX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===SX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(TX,"returnObject")});var QE=C((bOe,VM)=>{"use strict";var AX=(v(),D(q)),JR=ct(),RX=kc(),{getSystemSchemaPath:yX,getSchemaPath:bX}=ht(),yOe=Ao(),OX=zE(),NX=jE(),wX=FM(),{handleHDBError:qM,hdb_errors:$M}=_e(),GM=ae(),{HTTP_STATUS_CODES:IX}=$M,CX="inserted";VM.exports=PX;async function PX(e){let t=OX.attribute_object(e);if(t)throw qM(new Error,t.message,$M.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&GM.checkGlobalSchemaTable(e.schema,e.table);if(r)throw qM(new Error,r,IX.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=GM.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 NX(e.schema,e.table,e.attribute,e.id);try{let i=await JR.openEnvironment(bX(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}`);JR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await JR.openEnvironment(yX(),AX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await RX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return wX(CX,c,{records:[s]},l)}catch(i){throw i}}a(PX,"lmdbCreateAttribute")});var s_=C((wOe,YM)=>{"use strict";var Ro=ae(),KM=W(),NOe=yR(),{getDatabases:DX}=(Ce(),D(tt)),{ClientError:Fc}=_e();YM.exports=LX;function LX(e){if(Ro.isEmpty(e))throw new Fc("invalid update parameters defined.");if(Ro.isEmptyOrZeroLength(e.schema))throw new Fc("invalid schema specified.");if(Ro.isEmptyOrZeroLength(e.table))throw new Fc("invalid table specified.");if(!Array.isArray(e.records))throw new Fc("records must be an array");let t=DX()[e.schema]?.[e.table];if(Ro.isEmpty(t))throw new Fc(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&Ro.isEmptyOrZeroLength(o[r]))throw KM.error("a valid hash attribute must be provided with update record:",o),new Fc("a valid hash attribute must be provided with update record, check log for more info");if(!Ro.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw KM.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Fc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!Ro.isEmpty(o[r])&&o[r]!==""&&n.has(Ro.autoCast(o[r]))&&(o.skip=!0),n.add(Ro.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(LX,"insertUpdateValidate")});var zM=C((COe,WM)=>{"use strict";var XR=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};WM.exports=XR});var JM=C((DOe,QM)=>{"use strict";var ZR=ct(),MX=W(),jM=Fn().LMDB_ERRORS_ENUM;QM.exports=vX;async function vX(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 ZR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==jM.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await ZR.closeEnvironment(global.lmdb_map[n]),await ZR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==jM.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){MX.error(t)}}a(vX,"cleanLMDBMap")});var uv=C((vOe,lv)=>{"use strict";var ey=require("recursive-iterator"),UX=require("alasql"),ty=require("clone"),XM=ae(),{handleHDBError:ZM,hdb_errors:xX}=_e(),{HDB_ERROR_MSGS:ev,HTTP_STATUS_CODES:tv}=xX,{getDatabases:BX}=(Ce(),D(tt)),HX=["DISTINCT_ARRAY"],rv=Symbol("validateTables"),ry=Symbol("validateTable"),MOe=Symbol("getAllColumns"),nv=Symbol("validateAllColumns"),JE=Symbol("findColumn"),sv=Symbol("validateOrderBy"),i_=Symbol("validateSegment"),ny=Symbol("validateColumn"),iv=Symbol("setColumnsForTable"),ov=Symbol("checkColumnsForAsterisk"),av=Symbol("validateGroupBy"),cv=Symbol("hasColumns"),sy=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[rv](),this[ov](),this[nv]()}[rv](){if(this[cv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[ry](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[ry](t.table)})}}[cv](){let t=!1,r=new ey(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[ry](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=BX();if(!r[t.databaseid])throw ZM(new Error,ev.SCHEMA_NOT_FOUND(t.databaseid),tv.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw ZM(new Error,ev.TABLE_NOT_FOUND(t.databaseid,t.tableid),tv.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=ty(s);i.table=ty(t),this.attributes.push(i)})}[JE](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)}[ov](){let t=new ey(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[iv](r.tableid)}[iv](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new UX.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[nv](){this[i_](this.statement.columns,!1),this[i_](this.statement.joins,!1),this[i_](this.statement.where,!1),this[av](this.statement.group,!1),this[i_](this.statement.order,!0)}[i_](t,r){if(!t)return;let n=new ey(t),s=[];for(let{node:i,path:o}of n)!XM.isEmpty(i)&&!XM.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[sv](i):s.push(this[ny](i)));return s}[av](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&HX.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=ty(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[JE](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[JE](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`}[sv](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[ny](t)}[ny](t){let r=this[JE](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]}};lv.exports=sy});var hv=C((xOe,_v)=>{"use strict";var dv=require("lodash"),o_=require("mathjs"),kX=require("jsonata"),fv=ae();_v.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?dv.uniqWith(e,dv.isEqual):e,"distinct_array"),searchJSON:FX,mad:a_.bind(null,o_.mad),mean:a_.bind(null,o_.mean),mode:a_.bind(null,o_.mode),prod:a_.bind(null,o_.prod),median:a_.bind(null,o_.median)};function a_(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(a_,"aggregateFunction");function FX(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(fv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),fv.isEmpty(this.__ala__.res[r])){let n=kX(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(FX,"searchJSON")});var Ev=C((HOe,pv)=>{"use strict";var rr=require("moment"),iy="YYYY-MM-DDTHH:mm:ss.SSSZZ";rr.suppressDeprecationWarnings=!0;pv.exports={current_date:a(()=>rr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>rr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return rr(e).utc().format("YYYY");case"month":return rr(e).utc().format("MM");case"day":return rr(e).utc().format("DD");case"hour":return rr(e).utc().format("HH");case"minute":return rr(e).utc().format("mm");case"second":return rr(e).utc().format("ss");case"millisecond":return rr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>rr(e).utc().format(iy),"date"),date_format:a((e,t)=>rr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>rr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>rr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=rr(e).utc(),s=rr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>rr().utc().valueOf(),"now"),get_server_time:a(()=>rr().format(iy),"get_server_time"),offset_utc:a((e,t)=>rr(e).utc().utcOffset(t).format(iy),"offset_utc")}});var Tv=C((FOe,Sv)=>{"use strict";var qX=require("@turf/area"),GX=require("@turf/length"),$X=require("@turf/circle"),VX=require("@turf/difference"),KX=require("@turf/distance"),YX=require("@turf/boolean-contains"),WX=require("@turf/boolean-equal"),zX=require("@turf/boolean-disjoint"),jX=require("@turf/helpers"),mv=(v(),D(q)),Ge=ae(),yo=W();Sv.exports={geoArea:QX,geoLength:JX,geoCircle:XX,geoDifference:ZX,geoDistance:gv,geoNear:eZ,geoContains:tZ,geoEqual:rZ,geoCrosses:nZ,geoConvert:sZ};function QX(e){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return qX.default(e)}catch(t){return yo.trace(t,e),NaN}}a(QX,"geoArea");function JX(e,t){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return GX.default(e,{units:t||"kilometers"})}catch(r){return yo.trace(r,e),NaN}}a(JX,"geoLength");function XX(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return $X.default(e,t,{units:r||"kilometers"})}catch(n){return yo.trace(n,e,t),NaN}}a(XX,"geoCircle");function ZX(e,t){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return VX(e,t)}catch(r){return yo.trace(r,e,t),NaN}}a(ZX,"geoDifference");function gv(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return KX.default(e,t,{units:r||"kilometers"})}catch(n){return yo.trace(n,e,t),NaN}}a(gv,"geoDistance");function eZ(e,t,r,n){if(Ge.isEmpty(e)||Ge.isEmpty(t))return!1;if(Ge.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return gv(e,t,n)<=r}catch(s){return yo.trace(s,e,t),!1}}a(eZ,"geoNear");function tZ(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return YX.default(e,t)}catch(r){return yo.trace(r,e,t),!1}}a(tZ,"geoContains");function rZ(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return WX.default(e,t)}catch(r){return yo.trace(r,e,t),!1}}a(rZ,"geoEqual");function nZ(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return!zX.default(e,t)}catch(r){return yo.trace(r,e,t),!1}}a(nZ,"geoCrosses");function sZ(e,t,r){if(Ge.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Ge.isEmpty(t))throw new Error("geo_type is required");if(Ge.isEmpty(mv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(mv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ge.autoCastJSON(e)),jX[t](e,r)}a(sZ,"geoConvert")});var XE=C((GOe,Av)=>{var qc=hv(),Yn=Ev(),Bi=Tv();Av.exports=e=>{e.aggr.mad=e.aggr.MAD=qc.mad,e.aggr.mean=e.aggr.MEAN=qc.mean,e.aggr.mode=e.aggr.MODE=qc.mode,e.aggr.prod=e.aggr.PROD=qc.prod,e.aggr.median=e.aggr.MEDIAN=qc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=qc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=qc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Yn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Yn.current_time,e.fn.extract=e.fn.EXTRACT=Yn.extract,e.fn.date=e.fn.DATE=Yn.date,e.fn.date_format=e.fn.DATE_FORMAT=Yn.date_format,e.fn.date_add=e.fn.DATE_ADD=Yn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Yn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Yn.date_diff,e.fn.now=e.fn.NOW=Yn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Yn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Yn.get_server_time,e.fn.getdate=e.fn.GETDATE=Yn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Yn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Bi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Bi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Bi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Bi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Bi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Bi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Bi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Bi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Bi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Bi.geoNear}});var Ov=C(($Oe,bv)=>{"use strict";var c_=require("lodash"),Sn=require("alasql");Sn.options.cache=!1;var iZ=XE(),Rv=require("clone"),ZE=require("recursive-iterator"),Ue=W(),We=ae(),Au=Wn(),oZ=(v(),D(q)),{hdb_errors:aZ}=_e(),{getDatabases:yv}=(Ce(),D(tt)),cZ="IS NULL",ni="There was a problem performing this search. Please check the logs and try again.";iZ(Sn);var oy=class{static{a(this,"SQLSearch")}constructor(t,r){if(We.isEmpty(t))throw Ue.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),We.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!We.isEmptyOrZeroLength(n))return Ue.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Ue.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Ue.error(n),new Error(ni)}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(ni)}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(ni)}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(ni)}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(ni)}}_getColumns(){let t=new ZE(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(Rv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=c_.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=yv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(We.isEmpty(this.statement.where)){Ue.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new ZE(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!We.isEmpty(r)&&r.right)if(We.isNotEmptyAndHasValue(r.right.value)){let n=We.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Sn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=We.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Sn.yy.LogicValue({value:i}):n instanceof Sn.yy.StringValue&&We.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Sn.yy.NumValue({value:i}))});if(t){Ue.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new ZE(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!We.isEmpty(oZ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(We.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(We.isEmptyOrZeroLength(r.left.columnid)||We.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(We.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!We.isEmpty(r.right.value)||!We.isEmpty(r.left.value)?n.add(We.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(We.isEmptyOrZeroLength(this.all_table_attributes)&&We.isEmptyOrZeroLength(this.statement.from)&&We.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&c_.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(We.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);We.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(We.isEmptyOrZeroLength(this.all_table_attributes)&&!We.isEmptyOrZeroLength(this.columns.columns))return t;if(We.isEmptyOrZeroLength(this.all_table_attributes)&&We.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Sn.promise(r)}catch(r){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Ue.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(Rv(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(We.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(cZ)>-1&&this.tables.forEach(s=>{let i={columnid:yv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=c_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!We.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!We.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let f=await Au.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(f),new Error(ni)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let h=await Au.getDataByValue(d);for(let[_,p]of h)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,p[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,_))}))}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(f),new Error(ni)}else if(!We.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!We.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,h=f.length;d<h;d++){let _=f[d];c.search_attribute=_.attribute,c.search_value=_.search_value;let p=await Au.getDataByValue(c,_.operation);if(l)for(let[S]of p)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of p)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(f),new Error(ni)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await Au.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,h]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,h[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(f),new Error(ni)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof Sn.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new Sn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Sn.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new Sn.yy.FuncValue:new Sn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(_=>{_.joinmode&&_.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(_.table);let p=_.joinmode+" JOIN ? AS "+(_.as?_.as:_.table.tableid);_.on&&(p+=" ON "+_.on.toString()),i.push(p),t.push(Object.values(this.data[`${_.table.databaseid_orig}_${_.table.as?_.table.as_orig:_.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(_=>{let p=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__hash_name,S=_.as?_.as_orig:_.tableid_orig;o.push({key:`'${S}.${p}'`,schema:_.databaseid_orig,table:_.as?_.as_orig:_.tableid_orig,keys:new Set}),r.push(`${_.as?_.as:_.tableid}.\`${p}\` AS "${S}.${p}"`),c[_.as?_.as_orig:_.tableid_orig]=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(_=>{_.is_func?r.push(_.initial_select_column.toString()):_.initial_select_column.tableid?r.push(`${_.initial_select_column.tableid}.${_.initial_select_column.columnid} AS ${_.expression.columnid}`):r.push(`${_.initial_select_column.columnid} AS ${_.expression.columnid}`)}));let f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let h=[];try{let _=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,p=this._convertColumnsToIndexes(_,s);h=await Sn.promise(p,t),t=null}catch(_){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(_),new Error("There was a problem processing the data.")}if(h&&h.length>0){for(let _=0,p=h.length;_<p;_++){let S=h[_];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(_=>{let p=Object.keys(this.data[`${_.schema}_${_.table}`].__merged_data),S=c_.difference(p,[..._.keys].map(g=>g.toString()));for(let g=0,T=S.length;g<T;g++){let m=S[g];delete this.data[`${_.schema}_${_.table}`].__merged_data[m]}})}return{existing_attributes:c,joined_length:h?h.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new ZE(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=c_.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(ni)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let f in i)o.push(i[f][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await Au.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let h=o[f],_=l.get(h);for(let p=0;p<u;p++){let S=s.columns[p],g=_[S]===void 0?null:_[S];this.data[n].__merged_data[h].push(g)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();Ue.trace(`Final SQL: ${s}`),n=await Sn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ue.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ue.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return Ue.error(aZ.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),f=`${l}.[${c}]`;n=n.replace(u,f)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Au.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(ni)}}return Object.values(Object.values(this.data)[0].__merged_data)}};bv.exports=oy});var zr=C((KOe,Nv)=>{"use strict";var lZ=uv();Nv.exports={searchByConditions:dZ,searchByHash:fZ,searchByValue:_Z,search:hZ};var ay=Wn(),{transformReq:cy}=ae(),uZ=Ov();async function dZ(e){return cy(e),ay.searchByConditions(e)}a(dZ,"searchByConditions");async function fZ(e){cy(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of ay.searchByHash(e))r&&t.push(r);return t}a(fZ,"searchByHash");async function _Z(e){cy(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of ay.searchByValue(e))t.push(r);return t}a(_Z,"searchByValue");function hZ(e,t){try{let r=new lZ(e);r.validate(),new uZ(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(hZ,"search")});var bo=C((WOe,Pv)=>{"use strict";var l_=require("crypto"),pZ=ce(),{CONFIG_PARAMS:EZ}=(v(),D(q)),Iv="aes-256-cbc",mZ=32,gZ=16,ly=64,Cv=32,SZ=ly+Cv,wv=new Map;Pv.exports={encrypt:TZ,decrypt:AZ,createNatsTableStreamName:RZ};function TZ(e){let t=l_.randomBytes(mZ),r=l_.randomBytes(gZ),n=l_.createCipheriv(Iv,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(TZ,"encrypt");function AZ(e){let t=e.substr(0,ly),r=e.substr(ly,Cv),n=e.substr(SZ,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=l_.createDecipheriv(Iv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(AZ,"decrypt");function RZ(e,t){let r=pZ.get(EZ.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=wv.get(r);return n||(n=l_.createHash("md5").update(r).digest("hex"),wv.set(r,n)),n}a(RZ,"createNatsTableStreamName")});var Oo=C((QOe,Mv)=>{"use strict";var jOe=zr(),u_=W(),Dv=zE(),yZ=bo(),em=ae(),{handleHDBError:tm,hdb_errors:bZ}=_e(),{HDB_ERROR_MSGS:rm,HTTP_STATUS_CODES:uy}=bZ,Lv=ce();Lv.initSync();var{getDatabases:dy}=(Ce(),D(tt)),OZ=require("fs-extra"),NZ=(v(),D(q));Mv.exports={describeAll:wZ,describeTable:nm,describeSchema:IZ};async function wZ(e={}){try{let t=em.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=dy(),o={},c={},l=[],u=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let h=i[d];for(let _ in h)try{let p;if(t||s||r)p=await nm({schema:d,table:_,exact_count:u});else if(n&&n[d].describe&&n[d].tables[_].describe){let S=n[d].tables[_].attribute_permissions;p=await nm({schema:d,table:_,exact_count:u},S)}p&&l.push(p)}catch(p){u_.error(p)}}let f={};for(let d in l)t||s||r?(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?f[d]={}:c[d]&&(f[d]={});return f}catch(t){return u_.error("Got an error in describeAll"),u_.error(t),tm(new Error,rm.DESCRIBE_ALL_ERR)}}a(wZ,"describeAll");async function nm(e,t){em.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=Dv.describe_table(e);if(i)throw i;let c=dy()[r];if(!c)throw tm(new Error,rm.SCHEMA_NOT_FOUND(e.schema),uy.NOT_FOUND);let l=c[n];if(!l)throw tm(new Error,rm.TABLE_NOT_FOUND(e.schema,e.table),uy.NOT_FOUND);function u(_){f.push({attribute:_.attribute,type:_.type,elements:_.elements?.type,indexed:_.indexed,is_primary_key:_.isPrimaryKey,assigned_created_time:_.assignCreatedTime,assigned_updated_time:_.assignUpdatedTime,nullable:_.nullable,properties:_.properties?_.properties.map(p=>({type:p.type,name:p.name})):void 0})}a(u,"pushAtt");let f=[];if(s){let _={};s.forEach(p=>{p.describe&&(_[p.attribute_name]=!0)}),l.attributes.forEach(p=>{_[p.name]&&u(p)})}else l.attributes?.forEach(_=>u(_));let d;try{d=(await OZ.stat(l.primaryStore.env.path)).size}catch(_){u_.warn("unable to get database size",_)}let h={schema:r,name:l.tableName,hash_attribute:l.attributes.find(_=>_.isPrimaryKey||_.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:f,db_size:d};l.replicate!==void 0&&(h.replicate=l.replicate),l.expirationMS!==void 0&&(h.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(h.sealed=l.sealed),l.sources?.length>0&&(h.sources=l.sources.map(_=>_.name).filter(_=>_&&_!=="NATSReplicator"&&_!=="Replicator")),Lv.get(NZ.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(h.clustering_stream_name=yZ.createNatsTableStreamName(h.schema,h.name));try{let _=l.getRecordCount({exactCount:e.exact_count==="true"});h.record_count=_.recordCount,h.table_size=l.getSize(),h.db_audit_size=l.getAuditSize(),h.estimated_record_range=_.estimatedRange;let p=l.auditStore;if(p)for(let S of p.getKeys({reverse:!0,limit:1}))h.last_updated_record=S[0];if(!h.last_updated_record&&l.indices.__updatedtime__)for(let S of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))h.last_updated_record=S}catch(_){u_.warn(`unable to stat table dbi due to ${_}`)}return h}a(nm,"descTable");async function IZ(e){em.transformReq(e);let t=Dv.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=dy()[n];if(!i)throw tm(new Error,rm.SCHEMA_NOT_FOUND(e.schema),uy.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),em.isEmpty(l)||l.describe){let u=await nm({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(IZ,"describeSchema")});var ys=C((eNe,Hv)=>{var CZ=Ao(),{callbackify:Uv,promisify:PZ}=require("util"),{getDatabases:xv}=(Ce(),D(tt));Hv.exports={setSchemaDataToGlobal:vv,getTableSchema:DZ,getSystemSchema:LZ,setSchemaDataToGlobalAsync:PZ(vv)};var Bv=Oo(),XOe=Uv(Bv.describeAll),ZOe=Uv(Bv.describeTable);function vv(e){global.hdb_schema=xv(),e&&e()}a(vv,"setSchemaDataToGlobal");function DZ(e,t,r){let n=xv()[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 LZ(){return CZ}a(LZ,"getSystemSchema")});var _y=C((rNe,qv)=>{var MZ=pt(),fy=require("joi"),{hdb_table:vZ,hdb_database:kv}=vi(),Fv={schema:kv,database:kv,table:vZ},UZ={date:fy.date().iso().required()},xZ={timestamp:fy.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};qv.exports=function(e,t){let r=t==="timestamp"?{...Fv,...xZ}:{...Fv,...UZ},n=fy.object(r);return MZ.validateBySchema(e,n)}});var Vv=C((nNe,$v)=>{var BZ=pt(),hy=require("joi"),{hdb_table:HZ,hdb_database:Gv}=vi(),kZ=hy.object({schema:Gv,database:Gv,table:HZ,hash_values:hy.array().required(),ids:hy.array()});$v.exports=function(e){return BZ.validateBySchema(e,kZ)}});var gy=C((sNe,Kv)=>{"use strict";var py=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},Ey=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},my=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};Kv.exports={InsertObject:py,NoSQLSeachObject:Ey,DeleteResponseObject:my}});var Vc=C((oNe,Qv)=>{"use strict";var Wv=_y(),FZ=Vv(),Gc=ae(),Yv=require("moment"),zv=W(),{promisify:qZ,callbackify:GZ}=require("util"),$c=(v(),D(q)),$Z=ys(),Sy=qZ($Z.getTableSchema),Ty=Wn(),{DeleteResponseObject:VZ}=gy(),{handleHDBError:Ia,hdb_errors:KZ}=_e(),{HDB_ERROR_MSGS:sm,HTTP_STATUS_CODES:Ca}=KZ,YZ="records successfully deleted",WZ=GZ(jv);Qv.exports={delete:WZ,deleteRecord:jv,deleteFilesBefore:zZ,deleteAuditLogsBefore:jZ};async function zZ(e){let t=Wv(e,"date");if(t)throw Ia(t,t.message,Ca.BAD_REQUEST,void 0,void 0,!0);if(Gc.transformReq(e),!Yv(e.date,Yv.ISO_8601).isValid())throw Ia(new Error,sm.INVALID_DATE,Ca.BAD_REQUEST,$c.LOG_LEVELS.ERROR,sm.INVALID_DATE,!0);let n=Gc.checkSchemaTableExist(e.schema,e.table);if(n)throw Ia(new Error,n,Ca.NOT_FOUND,$c.LOG_LEVELS.ERROR,n,!0);let s=await Ty.deleteRecordsBefore(e);if(await Sy(e.schema,e.table),zv.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(zZ,"deleteFilesBefore");async function jZ(e){let t=Wv(e,"timestamp");if(t)throw Ia(t,t.message,Ca.BAD_REQUEST,void 0,void 0,!0);if(Gc.transformReq(e),isNaN(e.timestamp))throw Ia(new Error,sm.INVALID_VALUE("Timestamp"),Ca.BAD_REQUEST,$c.LOG_LEVELS.ERROR,sm.INVALID_VALUE("Timestamp"),!0);let r=Gc.checkSchemaTableExist(e.schema,e.table);if(r)throw Ia(new Error,r,Ca.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);let n=await Ty.deleteAuditLogsBefore(e);return await Sy(e.schema,e.table),zv.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(jZ,"deleteAuditLogsBefore");async function jv(e){e.ids&&(e.hash_values=e.ids);let t=FZ(e);if(t)throw Ia(t,t.message,Ca.BAD_REQUEST,void 0,void 0,!0);Gc.transformReq(e);let r=Gc.checkSchemaTableExist(e.schema,e.table);if(r)throw Ia(new Error,r,Ca.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);try{await Sy(e.schema,e.table);let n=await Ty.deleteRecords(e);return Gc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${YZ}`),n}catch(n){if(n.message===$c.SEARCH_NOT_FOUND_MESSAGE){let s=new VZ;return s.message=$c.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(jv,"deleteRecord")});var om={};Be(om,{HASH_FUNCTION:()=>im,hash:()=>JZ,validate:()=>XZ});function Ay(e=f_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(d_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function JZ(e,t=im[Xv?.toUpperCase()]??"sha256"){return Ry[t](e)}function XZ(e,t,r=im[Xv?.toUpperCase()]??"sha256"){return e?QZ[r](e,t):!1}var d_,Ru,Jv,Xv,f_,Zv,im,Ry,QZ,am=be(()=>{d_=x(require("node:crypto")),Ru=x(require("argon2")),Jv=x(ce());v();Xv=(0,Jv.get)(H.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),f_=16,Zv=9,im=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(im||{});a(Ay,"generateSalt");Ry={md5:a((e,t=void 0)=>{t=t??Ay(Zv);let r=d_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??Ay(f_);let r=d_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=Ay(f_),r=await Ru.hash(e,{type:Ru.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},QZ={md5:a((e,t)=>{let r=e.slice(0,Zv);return e===Ry.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,f_);return e===Ry.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await Ru.verify(e.slice(f_),t),"argon2id")};a(JZ,"hash");a(XZ,"validate")});var tU=C((uNe,eU)=>{var yy=pt(),jr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function ZZ(e){return jr.password.presence=!0,jr.username.presence=!0,jr.role.presence=!0,jr.active.presence=!0,yy.validateObject(e,jr)}a(ZZ,"addUserValidation");function e6(e){return jr.password.presence=!1,jr.username.presence=!0,jr.role.presence=!1,jr.active.presence=!1,yy.validateObject(e,jr)}a(e6,"alterUserValidation");function t6(e){return jr.password.presence=!1,jr.username.presence=!0,jr.role.presence=!1,jr.active.presence=!1,yy.validateObject(e,jr)}a(t6,"dropUserValidation");eU.exports={addUserValidation:ZZ,alterUserValidation:e6,dropUserValidation:t6}});var gt=C((_Ne,nU)=>{"use strict";var{platform:fNe}=require("os"),r6="nats-server.zip",by="nats-server",n6=process.platform==="win32"?`${by}.exe`:by,s6=/^[^\s.,*>]+$/,rU="__request__",i6=a(e=>`${e}.${rU}`,"REQUEST_SUBJECT"),o6={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},a6={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},c6={HUB:"hub.pid",LEAF:"leaf.pid"},l6={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},u6={SUCCESS:"success",ERROR:"error"},d6={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},f6={TXN:"txn",MSGID:"msgid"},yu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},_6={[yu.ERR]:1,[yu.WRN]:2,[yu.INF]:3,[yu.DBG]:4,[yu.TRC]:5},h6={debug:"-D",trace:"-DVV"};nU.exports={NATS_SERVER_ZIP:r6,NATS_SERVER_NAME:by,NATS_BINARY_NAME:n6,PID_FILES:c6,NATS_CONFIG_FILES:a6,SERVER_SUFFIX:l6,NATS_TERM_CONSTRAINTS_RX:s6,REQUEST_SUFFIX:rU,UPDATE_REMOTE_RESPONSE_STATUSES:u6,CLUSTER_STATUS_STATUSES:d6,REQUEST_SUBJECT:i6,SUBJECT_PREFIXES:f6,MSG_HEADERS:o6,LOG_LEVELS:yu,LOG_LEVEL_FLAGS:h6,LOG_LEVEL_HIERARCHY:_6}});var Oy=C(sU=>{"use strict";var p6={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
|
|
17
|
+
`},"serialize"),compressible:!1,q:.8});Yr.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});iM={type:"application/json",serializeStream:qf,serialize:Wf,deserialize:I3,q:.5};Yr.set("*/*",iM);Yr.set("",iM);a(I3,"tryJSONParse");a(jf,"registerContentHandlers");C3=require("fastify-plugin"),P3=C3(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=qm(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let f=l.getColumns;l=l.mapError(d=>(d.toJSON=()=>({error:d.name,message:d.message,...d.partialObject}),d)),l.getColumns=f}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((f,d)=>{s.header(f,d)},"set")}})})}),r()},{name:"content-type-negotiation"});a(qm,"findBestSerializer");eM=PR.default.get(x.HTTP_COMPRESSIONTHRESHOLD);a(Qf,"serialize");a(ya,"serializeMessage");a(CR,"asyncSerialization");a(D3,"streamToBuffer");L3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(M3,"isBufferEncoding");a(v3,"parseContentType");a(po,"getDeserializer");a(U3,"deserializerUnknownType");a(x3,"transformIterable");a(Gm,"toCsvStream")});var UR={};ve(UR,{start:()=>K3});function B3(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new br(`Unexpected non-executable definition type ${e.kind}.`)}function aM(e){if(typeof e!="object"||e===null)throw new Li("Request body must be an object.");if(!("query"in e))throw new Li("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Li("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Li("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Li("Request body `operationName` field must be a string.")}function vR(e){return parseInt(e.value,10)}function lM(e){return parseFloat(e.value)}function uM(e,t,r){let n=r.get(e.name.value);return dM(n)?fM(n,t):{attribute:t,value:n}}function dM(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function fM(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],dM(n)?fM(n,t):{attribute:t,value:n}))}function H3(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Le.Kind.NULL:return{attribute:t,value:null};case Le.Kind.INT:return{attribute:t,value:vR(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:lM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return uM(e.value,t,r);case Le.Kind.OBJECT:return _M(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new br(`Value type, ${e.value.kind}, is not supported.`)}}function _M(e,t,r){return e.fields.flatMap(n=>H3(n,t,r))}function k3(e,t){switch(e.value.kind){case Le.Kind.NULL:return{attribute:e.name.value,value:null};case Le.Kind.INT:return{attribute:e.name.value,value:vR(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:lM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return uM(e.value,e.name.value,t);case Le.Kind.OBJECT:return _M(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new br(`Argument type, ${e.value.kind}, is not supported.`)}}function F3(e,t){return e.flatMap(r=>k3(r,t))}function $m(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Le.Kind.FIELD:return r;case Le.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new br(`Fragment \`${n}\` not found.`);return $m(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return $m(r.selectionSet,t)}})}function pM(e,t){return $m(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:pM(r.selectionSet,t)}:r.name.value)}async function G3(e,t,r,n){let s=Ii.getMatch(e.name.value,"graphql");if(s===void 0)throw new br(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:pM(e.selectionSet,r),conditions:F3(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(o,n))c.push(l);return[e.name.value,c]}function hM(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return vR(e);case Le.Kind.FLOAT:return parseFloat(e.value);case Le.Kind.STRING:case Le.Kind.BOOLEAN:return e.value;case Le.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:hM(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new br(`Value type, ${e.kind}, is not supported.`)}}function q3(e,t){let r=new Map;for(let n of e){let s=n.variable.name.value,i=t?.[s];if(i===void 0&&n.defaultValue!==void 0&&(i=hM(n.defaultValue)),n.type.kind===Le.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new br(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function $3(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new br("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new br("Mutations are not supported yet.");let s=q3(e.variableDefinitions,t),i=await Promise.all($m(e.selectionSet,r).map(c=>G3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function cM({query:e,variables:t={},operationName:r},n){let s=Le.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(B3(u),u.kind===Le.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new br("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new br(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new br("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new br(`Operation \`${r}\` not found.`);let l=await $3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function V3(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return aM(r),cM(r,e)}case"POST":{let r=await po(e.headers.get("content-type"),!0)(e._nodeRequest);return aM(r),cM(r,e)}default:throw new Li("Method Not Allowed",405,{Allow:"GET, POST"})}}function K3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await V3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Li)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof br)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof Li)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof br)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Le,br,Li,mM=be(()=>{Le=M(require("graphql"));fo();Su();a(B3,"assertExecutableDefinitionNode");a(aM,"assertRequestParams");a(vR,"processIntValueNode");a(lM,"processFloatValueNode");a(uM,"processVariableNode");a(dM,"isObject");a(fM,"transformObjectIntoQueryCondition");a(H3,"processObjectFieldNode");a(_M,"processObjectValueNode");a(k3,"processArgumentNode");a(F3,"buildConditionsQuery");a($m,"fillInFragments");a(pM,"buildSelectQuery");a(G3,"processFieldNode");a(hM,"processConstValueNode");a(q3,"resolveVariables");a($3,"executeOperation");a(cM,"resolver");br=class extends Error{static{a(this,"GraphQLQueryingError")}},Li=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(V3,"graphqlQueryingHandler");a(K3,"start")});var vi=I((Ybe,SM)=>{"use strict";var gM=oe(),EM=(B(),C(G)),Ru=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Mi=require("joi"),ba={schema_format:{pattern:Ru,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},Y3=Mi.alternatives(Mi.string().min(1).max(ba.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Mi.number(),Mi.array()).required(),W3=Mi.alternatives(Mi.string().min(1).max(ba.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Mi.number()),z3=Mi.alternatives(Mi.string().min(1).max(ba.schema_length.maximum).pattern(Ru).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Mi.number()).required();function j3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ba.schema_length.maximum?`'${e}' maximum of 250 characters`:Ru.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(j3,"checkValidTable");function Q3(e,t){return gM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(Q3,"validateSchemaExists");function J3(e,t){let r=t.state.ancestors[0].schema;return gM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(J3,"validateTableExists");function X3(e,t){return e.toLowerCase()===EM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${EM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(X3,"validateSchemaName");SM.exports={common_validators:ba,schema_regex:Ru,hdb_schema_table:Y3,validateSchemaExists:Q3,validateTableExists:J3,validateSchemaName:X3,checkValidTable:j3,hdb_database:W3,hdb_table:z3}});var ut=I((zbe,TM)=>{"use strict";var gn=require("validate.js");gn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||gn.validators.type.checks[t](e)?null:` must be a '${t}' value`};gn.validators.type.checks={Object:a(function(e){return gn.isObject(e)&&!gn.isArray(e)},"Object"),Array:gn.isArray,Integer:gn.isInteger,Number:gn.isNumber,String:gn.isString,Date:gn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};gn.validators.hasValidFileExt=function(e,t){return gn.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};TM.exports={validateObject:Z3,validateObjectAsync:eX,validateBySchema:tX};function Z3(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=gn(e,t,{format:"flat"});return r?new Error(r):null}a(Z3,"validateObject");async function eX(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await gn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(eX,"validateObjectAsync");function tX(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(tX,"validateBySchema")});var BR=I((Qbe,RM)=>{var{hdb_table:rX,hdb_database:AM}=vi(),nX=ut(),xR=require("joi"),sX={undefined:"undefined",null:"null"},iX=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||sX[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),oX=xR.object({database:AM,schema:AM,table:rX,records:xR.array().items(xR.object().custom(iX)).required()});RM.exports=function(e){return nX.validateBySchema(e,oX)}});var bM=I((Xbe,yM)=>{"use strict";var HR=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")}};yM.exports=HR});var NM=I((eOe,OM)=>{"use strict";var kR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};OM.exports=kR});var DM={};ve(DM,{HAS_EXPIRATION:()=>Ym,HAS_RESIDENCY_ID:()=>YR,HAS_STRUCTURE_UPDATE:()=>zm,LAST_TIMESTAMP_PLACEHOLDER:()=>t_,LOCAL_TIMESTAMP:()=>aX,METADATA:()=>Jf,NEW_TIMESTAMP_PLACEHOLDER:()=>IM,NO_TIMESTAMP:()=>FR,PENDING_LOCAL_TIME:()=>WR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>KR,RecordEncoder:()=>VR,TIMESTAMP_ASSIGN_LAST:()=>lX,TIMESTAMP_ASSIGN_NEW:()=>CM,TIMESTAMP_ASSIGN_PREVIOUS:()=>PM,TIMESTAMP_PLACEHOLDER:()=>Vm,TIMESTAMP_RECORD_PREVIOUS:()=>GR,handleLocalTimeForGets:()=>jm,recordUpdater:()=>zR,removeEntry:()=>Uc});function dX(){return e_[0]=e_[0]^64,cX.getFloat64(0)}function jm(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(o,c){e.readCount++;let l=r.call(this,o,c),u=l?.value,f=u?.[Jf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l&&(l.key=o),l};let n=e.get;e.get=function(o,c){let l=n.call(this,o,c);return l?.[Jf]>=0?l.value:l};let s=e.getRange;e.getRange=function(o){let c=s.call(this,o);return o.valuesForKey?c.map(l=>l?.value):o.values===!1||o.onlyCount?c:c.map(l=>{let u=l.value,f=u[Jf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l})};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let o=i.constructor,c=i.use,l=i.done;o.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,vc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<vc.length;u++){let f=vc[u].deref();(!f||f.isDone||f.isCommitted)&&vc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function zR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,p){d||l==null?yu=i?.localTime?GR|PM:FR:yu=l?i?.localTime?GR|16384:CM|16384:FR;let _=u?.expiresAt;if(_>=0&&(c|=Ym),Zf=c,qR=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:yu>0},S,g=0;try{let A=i?.residencyId,E=u?.residencyId;E&&($R=E,Zf|=YR,g|=xc),A!==E&&(g|=Bc,A||(A=0)),c&Ym&&(g|=n_),u?.originatingOperation&&(g|=r_),d&&(h.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&$n&&(r.getBinaryFast(i.localTime)||Aa(i.value));let R;if(u?.omitLocalRecord||(R=km(()=>e.put(n,s,h),n,e.rootStore),Pc&&(g|=$n)),l){let N=u?.user?.username;if(p&&(km(()=>e.encoder.encode(p),n,e.rootStore),Pc&&(g|=$n)),e.encoder.hasStructureUpdate&&(g|=zm,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,k=r.get(v);if(k){let F=Nt(k).previousLocalTime;return R=r.put(v,bu(o,t,n,F,u?.nodeId??server.replication.getThisNodeId(r)??0,N,f,Xf,g,E,A,_),{ifVersion:S}),R}}R=r.put(s===void 0?IM:t_,bu(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,Xf,g,E,A,_,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return R}catch(A){throw A.message+=" id: "+n+" options: "+h,A}}}function Uc(e,t,r){if(t)return t.value&&t.metadataFlags&$n&&!e.auditStore.getBinaryFast(t.localTime)&&Aa(t.value),e.remove(t.key,r)}var wM,Km,Vm,t_,KR,IM,aX,Jf,e_,cX,FR,CM,lX,PM,GR,Ym,YR,WR,zm,uX,Xf,yu,Zf,qR,$R,VR,vc,Ou=be(()=>{wM=require("msgpackr");ho();Km=M(Y());As();As();Vm=new Uint8Array([1,1,1,1,4,64,0,0]),t_=new Uint8Array([1,1,1,1,1,0,0,0]),KR=new Uint8Array([1,1,1,1,3,64,0,0]),IM=new Uint8Array([1,1,1,1,0,64,0,0]),aX=Symbol("local-timestamp"),Jf=Symbol("metadata"),e_=new Uint8Array(8),cX=new DataView(e_.buffer,0,8),FR=0,CM=0,lX=1,PM=3,GR=4,Ym=16,YR=32,WR=1,zm=256,yu=0,Zf=-1,qR=-1,$R=0,VR=class extends wM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(yu||Zf>=0){let o=0,c=yu;c&&(o+=8,yu=0);let l=Zf,u=qR,f=$R;l>=0&&(o+=4,Zf=-1,u>=0&&(o+=8,qR=-1),f&&(o+=4,$R=0));let d=uX=r.call(this,s,i|2048|o);Xf=d.subarray((d.start||0)+o,d.end);let p=d.start||0;return c&&(Vm[4]=c,Vm[5]=c>>8,d.set(Vm,p),p+=8),Pc&&(l|=$n),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,l|Wm<<24),p+=4,u>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setFloat64(p,u),p+=8),f&&(d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,f)),d}else return Xf=r.call(this,s,i),Xf};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(e_,0,c),c+=8;else for(let p=0;p<8;p++)e_[p]=t[c++];l=dX(),i=t[c]}let u,f;i<32&&(i===Wm?(o=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(o=i|t[c+1]<<5,c+=2),o&Ym&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&YR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=Dc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Jf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:Dc(()=>super.decode(t,r),this.rootStore)}catch(c){return Km.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(dX,"getTimestamp");a(jm,"handleLocalTimeForGets");vc=[];setInterval(()=>{for(let e=0;e<vc.length;e++){let t=vc[e].deref();!t||t.isDone||t.isCommitted?vc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Km.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Km.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(zR,"recordUpdater");a(Uc,"removeEntry")});var s_=I((oOe,MM)=>{"use strict";var LM=ce(),fX=(B(),C(G)),{RecordEncoder:_X}=(Ou(),C(DM));LM.initSync();var pX=LM.get(fX.CONFIG_PARAMS.STORAGE_CACHING)!==!1,jR=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=pX&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:_X})}};MM.exports=jR});var i_=I((cOe,vM)=>{"use strict";var Vn=ce(),Rs=(B(),C(G));Vn.initSync();var Qm=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Vn.get(Rs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Vn.get(Rs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Vn.get(Rs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Vn.get(Rs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Vn.get(Rs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Vn.get(Rs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Vn.get(Rs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Vn.get(Rs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Vn.get(Rs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Vn.get(Rs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Vn.get(Rs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Vn.get(Rs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};vM.exports=Qm;Qm.MAX_DBS=1e4});var dt=I((uOe,VM)=>{"use strict";var JR=require("lmdb"),Zs=require("fs-extra"),Kn=require("path"),Jm=pn(),BM=Y(),Sn=Hn().LMDB_ERRORS_ENUM,Xm=NM(),XR=s_(),HM=i_(),Oa=vt(),UM=(B(),C(G)),{table:hX,resetDatabases:mX}=(Pe(),C(rt)),xM=ce(),ei=Oa.INTERNAL_DBIS_NAME,kM=Oa.DBI_DEFINITION_NAME,EX="data.mdb",gX="lock.mdb",o_=".mdb",SX="-lock",QR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ys(t,r),this.key_type=this.dbi[Oa.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Oa.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new JR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Zm(e,t){if(e===void 0)throw new Error(Sn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Sn.ENV_NAME_REQUIRED)}a(Zm,"pathEnvNameValidation");async function ZR(e,t,r=!0){try{await Zs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Sn.INVALID_BASE_PATH):n}try{let n=Kn.join(e,t+o_);return await Zs.access(n,Zs.constants.R_OK|Zs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Zs.access(Kn.join(e,t,EX),Zs.constants.R_OK|Zs.constants.F_OK),Kn.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(ZR,"validateEnvironmentPath");function eE(e,t){if(Jm.validateEnv(e),t===void 0)throw new Error(Sn.DBI_NAME_REQUIRED)}a(eE,"validateEnvDBIName");async function TX(e,t,r=!1,n=!1){Zm(e,t);let s=Kn.basename(e);t=t.toString();let i=xM.get(UM.CONFIG_PARAMS.DATABASES);i||xM.setProperty(UM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ZR(e,t,n),FM(e,t,r)}catch(o){if(o.message===Sn.INVALID_ENVIRONMENT){let c=Kn.join(e,t);await Zs.mkdirp(n?c:e);let l=new HM(n?c:c+o_,!1),u=JR.open(l);u.dbis=Object.create(null);let f=new XR(!1);u.openDB(ei,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=ey(e,t,r);return u[Oa.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(TX,"createEnvironment");async function AX(e,t,r,n=!0){Zm(e,t),t=t.toString();let s=Kn.join(e,t);return hX({table:t,database:Kn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(AX,"copyEnvironment");async function FM(e,t,r=!1){Zm(e,t),t=t.toString();let n=ey(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 ZR(e,t),i=Kn.join(e,t+o_),o=s!=i,c=new HM(s,o),l=JR.open(c);l.dbis=Object.create(null);let u=qM(l);for(let f=0;f<u.length;f++)ys(l,u[f]);return l[Oa.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(FM,"openEnvironment");async function RX(e,t,r=!1){Zm(e,t),t=t.toString();let n=Kn.join(e,t+o_),s=await ZR(e,t);if(global.lmdb_map!==void 0){let i=ey(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await GM(o),delete global.lmdb_map[i]}}await Zs.remove(s),await Zs.remove(s===n?s+SX:Kn.join(Kn.dirname(s),gX))}a(RX,"deleteEnvironment");async function GM(e){Jm.validateEnv(e);let t=e[Oa.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(GM,"closeEnvironment");function ey(e,t,r=!1){let s=`${Kn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(ey,"getCachedEnvironmentName");function yX(e){Jm.validateEnv(e);let t=Object.create(null),r=ys(e,ei);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==ei)try{t[n]=Object.assign(new Xm,s)}catch{BM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(yX,"listDBIDefinitions");function qM(e){Jm.validateEnv(e);let t=[],r=ys(e,ei);for(let{key:n}of r.getRange({start:!1}))n!==ei&&t.push(n);return t}a(qM,"listDBIs");function bX(e,t){let n=ys(e,ei).getEntry(t),s=new Xm;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{BM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(bX,"getDBIDefinition");function $M(e,t,r,n=!r){if(eE(e,t),t=t.toString(),t===ei)throw new Error(Sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ys(e,t)}catch(s){if(s.message===Sn.DBI_DOES_NOT_EXIST){let i=new XR(r,n===!0),o=e.openDB(t,i),c=new Xm(r===!0,n);return o[kM]=c,ys(e,ei).putSync(t,c),e.dbis[t]=o,o}throw s}}a($M,"createDBI");function ys(e,t){if(eE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==ei?r=bX(e,t):r=new Xm,r===void 0)throw new Error(Sn.DBI_DOES_NOT_EXIST);let n;try{let s=new XR(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[kM]=r,e.dbis[t]=n,n}a(ys,"openDBI");function OX(e,t){eE(e,t),t=t.toString();let r=ys(e,t),n=r.getStats();return r[Oa.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(OX,"statDBI");async function NX(e,t){try{let r=Kn.join(e,t+o_);return(await Zs.stat(r)).size}catch{throw new Error(Sn.INVALID_ENVIRONMENT)}}a(NX,"environmentDataSize");function wX(e,t){if(eE(e,t),t=t.toString(),t===ei)throw new Error(Sn.CANNOT_DROP_INTERNAL_DBIS_NAME);ys(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ys(e,ei).removeSync(t)}a(wX,"dropDBI");function IX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ys(e,i)}catch(o){if(o.message===Sn.DBI_DOES_NOT_EXIST)$M(e,i,i!==t,i===t),n=!0;else throw o}}n&&mX()}a(IX,"initializeDBIs");VM.exports={openDBI:ys,openEnvironment:FM,createEnvironment:TX,listDBIs:qM,listDBIDefinitions:yX,createDBI:$M,dropDBI:wX,statDBI:OX,deleteEnvironment:RX,initializeDBIs:IX,TransactionCursor:QR,environmentDataSize:NX,copyEnvironment:AX,closeEnvironment:GM}});var YM=I((fOe,KM)=>{"use strict";var ty=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};KM.exports=ty});var zM=I((pOe,WM)=>{"use strict";var ry=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}};WM.exports=ry});var QM=I((mOe,jM)=>{"use strict";var ny=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};jM.exports=ny});var kc=I((AOe,ZM)=>{"use strict";var CX=dt(),PX=YM(),DX=zM(),LX=QM(),Ui=pn(),a_=Hn().LMDB_ERRORS_ENUM,MX=vt(),mo=(B(),C(G)),vX=oe(),UX=require("uuid"),gOe=require("lmdb"),{handleHDBError:xX,hdb_errors:BX}=pe(),{OVERFLOW_MARKER:SOe,MAX_SEARCH_KEY_LENGTH:TOe}=MX,JM=ce();JM.initSync();var tE=JM.get(mo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),sy=mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Hc=mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function HX(e,t,r,n,s=Ui.getNextMonotonicTime()){cy(e,t,r,n),iy(e,t,r);let i=new PX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];XM(u,!0,s);let f=kX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return oy(o,c,n,i,s)}a(HX,"insertRecords");function kX(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let f=c([[{}]]);Array.isArray(f)&&(c=f[0][mo.FUNC_VAL],n[o]=c)}let l=Ui.getIndexedValues(c),u=e.dbis[o];if(l){tE&&u.prefetch(l.map(f=>({key:f,value:s})),rE);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}tE&&e.dbis[t].prefetch([s],rE),e.dbis[t].put(s,n,n[Hc])})}a(kX,"insertRecord");function FX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(FX,"removeSkippedRecords");function XM(e,t,r){let n=r>0;(n||!Number.isInteger(e[Hc]))&&(e[Hc]=r||(r=Ui.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[sy]))&&(e[sy]=r||Ui.getNextMonotonicTime()):delete e[sy]}a(XM,"setTimestamps");function iy(e,t,r){r.indexOf(mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(mo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(mo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),CX.initializeDBIs(e,t,r)}a(iy,"initializeTransaction");async function GX(e,t,r,n,s=Ui.getNextMonotonicTime()){cy(e,t,r,n),iy(e,t,r);let i=new DX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],p;try{p=ay(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(p),l.push(d)}return oy(c,l,n,i,s,o)}a(GX,"updateRecords");async function qX(e,t,r,n,s=Ui.getNextMonotonicTime()){try{cy(e,t,r,n)}catch(l){throw xX(l,l.message,BX.HTTP_STATUS_CODES.BAD_REQUEST)}iy(e,t,r);let i=new LX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;vX.isEmpty(u[t])?(f=UX.v4(),u[t]=f):f=u[t];let d=ay(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return oy(o,c,n,i,s)}a(qX,"upsertRecords");async function oy(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||Ui.getNextMonotonicTime(),FX(r,i),n}a(oy,"finalizeWrite");function ay(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,f=u;if(!u){if(i)return!1;u={}}if(XM(r,!f,o),Number.isInteger(r[Hc])&&u[Hc]>r[Hc])return!1;f&&s.original_records.push(u);let d,p=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let S=r[h],g=e.dbis[h];if(g===void 0)continue;let A=u[h];if(typeof S=="function"){let R=S([[u]]);Array.isArray(R)&&(S=R[0][mo.FUNC_VAL],r[h]=S)}if(S===A)continue;let E=Ui.getIndexedValues(A);if(E){tE&&g.prefetch(E.map(R=>({key:R,value:n})),rE);for(let R=0,N=E.length;R<N;R++)g.remove(E[R],n)}if(E=Ui.getIndexedValues(S),E){tE&&g.prefetch(E.map(R=>({key:R,value:n})),rE);for(let R=0,N=E.length;R<N;R++)g.put(E[R],n)}}let _={...u,...r};c.put(n,_,_[Hc])},"do_put");return l?d=c.ifVersion(n,l.version,p):d=c.ifNoExists(n,p),d.then(_=>_?!0:ay(e,t,r,n,s,i,o))}a(ay,"updateUpsertRecord");function $X(e,t,r){if(Ui.validateEnv(e),t===void 0)throw new Error(a_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(a_.WRITE_ATTRIBUTES_REQUIRED):new Error(a_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a($X,"validateBasic");function cy(e,t,r,n){if($X(e,t,r),!Array.isArray(n))throw n===void 0?new Error(a_.RECORDS_REQUIRED):new Error(a_.RECORDS_MUST_BE_ARRAY)}a(cy,"validateWrite");function rE(){}a(rE,"noop");ZM.exports={insertRecords:HX,updateRecords:GX,upsertRecords:qX}});var Eo=I((yOe,VX)=>{VX.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"revoked_certificates"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var nE=I((bOe,ev)=>{var{common_validators:xi}=vi(),l_=ut(),c_="is required",Zt={database:{presence:!1,format:xi.schema_format,length:xi.schema_length},schema:{presence:!1,format:xi.schema_format,length:xi.schema_length},table:{presence:!0,format:xi.schema_format,length:xi.schema_length},attribute:{presence:!0,format:xi.schema_format,length:xi.schema_length},hash_attribute:{presence:!0,format:xi.schema_format,length:xi.schema_length}};function u_(e){for(let t in e)e[t]=e[t]===null||e[t]===void 0||typeof e[t]=="object"?e[t]:e[t].toString();return e}a(u_,"makeAttributesStrings");function KX(e){return e=u_(e),Zt.table.presence=!1,Zt.attribute.presence=!1,Zt.hash_attribute.presence=!1,l_.validateObject(e,Zt)}a(KX,"schema_object");function YX(e){return e=u_(e),Zt.table.presence={message:c_},Zt.attribute.presence=!1,Zt.hash_attribute.presence=!1,l_.validateObject(e,Zt)}a(YX,"table_object");function WX(e){return e=u_(e),Zt.table.presence={message:c_},Zt.attribute.presence=!1,l_.validateObject(e,Zt)}a(WX,"create_table_object");function zX(e){return e=u_(e),Zt.table.presence={message:c_},Zt.attribute.presence={message:c_},Zt.hash_attribute.presence=!1,l_.validateObject(e,Zt)}a(zX,"attribute_object");function jX(e){return e=u_(e),Zt.table.presence={message:c_},Zt.attribute.presence=!1,Zt.hash_attribute.presence=!1,l_.validateObject(e,Zt)}a(jX,"describe_table");function QX(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(QX,"validateTableResidence");ev.exports={schema_object:KX,create_table_object:WX,table_object:YX,attribute_object:zX,describe_table:jX,validateTableResidence:QX}});var rv=I((NOe,tv)=>{"use strict";var JX=require("uuid"),ly=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||JX.v4(),this.schema_table=`${this.schema}.${this.table}`}};tv.exports=ly});var sE=I((IOe,nv)=>{"use strict";var XX=rv(),uy=class extends XX{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}};nv.exports=uy});var iv=I((POe,sv)=>{"use strict";sv.exports=eZ;var ZX="inserted";function eZ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===ZX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(eZ,"returnObject")});var iE=I((MOe,lv)=>{"use strict";var tZ=(B(),C(G)),dy=dt(),rZ=kc(),{getSystemSchemaPath:nZ,getSchemaPath:sZ}=Et(),LOe=Eo(),iZ=nE(),oZ=sE(),aZ=iv(),{handleHDBError:ov,hdb_errors:cv}=pe(),av=oe(),{HTTP_STATUS_CODES:cZ}=cv,lZ="inserted";lv.exports=uZ;async function uZ(e){let t=iZ.attribute_object(e);if(t)throw ov(new Error,t.message,cv.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&av.checkGlobalSchemaTable(e.schema,e.table);if(r)throw ov(new Error,r,cZ.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=av.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 oZ(e.schema,e.table,e.attribute,e.id);try{let i=await dy.openEnvironment(sZ(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}`);dy.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await dy.openEnvironment(nZ(),tZ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await rZ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return aZ(lZ,c,{records:[s]},l)}catch(i){throw i}}a(uZ,"lmdbCreateAttribute")});var d_=I((xOe,dv)=>{"use strict";var go=oe(),uv=Y(),UOe=BR(),{getDatabases:dZ}=(Pe(),C(rt)),{ClientError:Fc}=pe();dv.exports=fZ;function fZ(e){if(go.isEmpty(e))throw new Fc("invalid update parameters defined.");if(go.isEmptyOrZeroLength(e.schema))throw new Fc("invalid schema specified.");if(go.isEmptyOrZeroLength(e.table))throw new Fc("invalid table specified.");if(!Array.isArray(e.records))throw new Fc("records must be an array");let t=dZ()[e.schema]?.[e.table];if(go.isEmpty(t))throw new Fc(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&go.isEmptyOrZeroLength(o[r]))throw uv.error("a valid hash attribute must be provided with update record:",o),new Fc("a valid hash attribute must be provided with update record, check log for more info");if(!go.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw uv.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Fc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!go.isEmpty(o[r])&&o[r]!==""&&n.has(go.autoCast(o[r]))&&(o.skip=!0),n.add(go.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(fZ,"insertUpdateValidate")});var _v=I((HOe,fv)=>{"use strict";var fy=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};fv.exports=fy});var mv=I((FOe,hv)=>{"use strict";var _y=dt(),_Z=Y(),pv=Hn().LMDB_ERRORS_ENUM;hv.exports=pZ;async function pZ(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 _y.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==pv.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await _y.closeEnvironment(global.lmdb_map[n]),await _y.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==pv.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){_Z.error(t)}}a(pZ,"cleanLMDBMap")});var Cv=I(($Oe,Iv)=>{"use strict";var py=require("recursive-iterator"),hZ=require("alasql"),hy=require("clone"),Ev=oe(),{handleHDBError:gv,hdb_errors:mZ}=pe(),{HDB_ERROR_MSGS:Sv,HTTP_STATUS_CODES:Tv}=mZ,{getDatabases:EZ}=(Pe(),C(rt)),gZ=["DISTINCT_ARRAY"],Av=Symbol("validateTables"),my=Symbol("validateTable"),qOe=Symbol("getAllColumns"),Rv=Symbol("validateAllColumns"),oE=Symbol("findColumn"),yv=Symbol("validateOrderBy"),f_=Symbol("validateSegment"),Ey=Symbol("validateColumn"),bv=Symbol("setColumnsForTable"),Ov=Symbol("checkColumnsForAsterisk"),Nv=Symbol("validateGroupBy"),wv=Symbol("hasColumns"),gy=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[Av](),this[Ov](),this[Rv]()}[Av](){if(this[wv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[my](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[my](t.table)})}}[wv](){let t=!1,r=new py(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[my](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=EZ();if(!r[t.databaseid])throw gv(new Error,Sv.SCHEMA_NOT_FOUND(t.databaseid),Tv.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw gv(new Error,Sv.TABLE_NOT_FOUND(t.databaseid,t.tableid),Tv.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=hy(s);i.table=hy(t),this.attributes.push(i)})}[oE](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[Ov](){let t=new py(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[bv](r.tableid)}[bv](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new hZ.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Rv](){this[f_](this.statement.columns,!1),this[f_](this.statement.joins,!1),this[f_](this.statement.where,!1),this[Nv](this.statement.group,!1),this[f_](this.statement.order,!0)}[f_](t,r){if(!t)return;let n=new py(t),s=[];for(let{node:i,path:o}of n)!Ev.isEmpty(i)&&!Ev.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[yv](i):s.push(this[Ey](i)));return s}[Nv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&gZ.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=hy(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[oE](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[oE](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[yv](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[Ey](t)}[Ey](t){let r=this[oE](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};Iv.exports=gy});var Mv=I((KOe,Lv)=>{"use strict";var Pv=require("lodash"),__=require("mathjs"),SZ=require("jsonata"),Dv=oe();Lv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Pv.uniqWith(e,Pv.isEqual):e,"distinct_array"),searchJSON:TZ,mad:p_.bind(null,__.mad),mean:p_.bind(null,__.mean),mode:p_.bind(null,__.mode),prod:p_.bind(null,__.prod),median:p_.bind(null,__.median)};function p_(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(p_,"aggregateFunction");function TZ(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(Dv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Dv.isEmpty(this.__ala__.res[r])){let n=SZ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(TZ,"searchJSON")});var Uv=I((WOe,vv)=>{"use strict";var er=require("moment"),Sy="YYYY-MM-DDTHH:mm:ss.SSSZZ";er.suppressDeprecationWarnings=!0;vv.exports={current_date:a(()=>er().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>er().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return er(e).utc().format("YYYY");case"month":return er(e).utc().format("MM");case"day":return er(e).utc().format("DD");case"hour":return er(e).utc().format("HH");case"minute":return er(e).utc().format("mm");case"second":return er(e).utc().format("ss");case"millisecond":return er(e).utc().format("SSS");default:break}},"extract"),date:a(e=>er(e).utc().format(Sy),"date"),date_format:a((e,t)=>er(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>er(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>er(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=er(e).utc(),s=er(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>er().utc().valueOf(),"now"),get_server_time:a(()=>er().format(Sy),"get_server_time"),offset_utc:a((e,t)=>er(e).utc().utcOffset(t).format(Sy),"offset_utc")}});var kv=I((jOe,Hv)=>{"use strict";var AZ=require("@turf/area"),RZ=require("@turf/length"),yZ=require("@turf/circle"),bZ=require("@turf/difference"),OZ=require("@turf/distance"),NZ=require("@turf/boolean-contains"),wZ=require("@turf/boolean-equal"),IZ=require("@turf/boolean-disjoint"),CZ=require("@turf/helpers"),xv=(B(),C(G)),qe=oe(),So=Y();Hv.exports={geoArea:PZ,geoLength:DZ,geoCircle:LZ,geoDifference:MZ,geoDistance:Bv,geoNear:vZ,geoContains:UZ,geoEqual:xZ,geoCrosses:BZ,geoConvert:HZ};function PZ(e){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return AZ.default(e)}catch(t){return So.trace(t,e),NaN}}a(PZ,"geoArea");function DZ(e,t){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return RZ.default(e,{units:t||"kilometers"})}catch(r){return So.trace(r,e),NaN}}a(DZ,"geoLength");function LZ(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return yZ.default(e,t,{units:r||"kilometers"})}catch(n){return So.trace(n,e,t),NaN}}a(LZ,"geoCircle");function MZ(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 bZ(e,t)}catch(r){return So.trace(r,e,t),NaN}}a(MZ,"geoDifference");function Bv(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 OZ.default(e,t,{units:r||"kilometers"})}catch(n){return So.trace(n,e,t),NaN}}a(Bv,"geoDistance");function vZ(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 Bv(e,t,n)<=r}catch(s){return So.trace(s,e,t),!1}}a(vZ,"geoNear");function UZ(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 NZ.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(UZ,"geoContains");function xZ(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 wZ.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(xZ,"geoEqual");function BZ(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!IZ.default(e,t)}catch(r){return So.trace(r,e,t),!1}}a(BZ,"geoCrosses");function HZ(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(xv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(xv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=qe.autoCastJSON(e)),CZ[t](e,r)}a(HZ,"geoConvert")});var aE=I((JOe,Fv)=>{var Gc=Mv(),Yn=Uv(),Bi=kv();Fv.exports=e=>{e.aggr.mad=e.aggr.MAD=Gc.mad,e.aggr.mean=e.aggr.MEAN=Gc.mean,e.aggr.mode=e.aggr.MODE=Gc.mode,e.aggr.prod=e.aggr.PROD=Gc.prod,e.aggr.median=e.aggr.MEDIAN=Gc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Gc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Gc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Yn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Yn.current_time,e.fn.extract=e.fn.EXTRACT=Yn.extract,e.fn.date=e.fn.DATE=Yn.date,e.fn.date_format=e.fn.DATE_FORMAT=Yn.date_format,e.fn.date_add=e.fn.DATE_ADD=Yn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Yn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Yn.date_diff,e.fn.now=e.fn.NOW=Yn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Yn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Yn.get_server_time,e.fn.getdate=e.fn.GETDATE=Yn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Yn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Bi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Bi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Bi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Bi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Bi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Bi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Bi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Bi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Bi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Bi.geoNear}});var Vv=I((XOe,$v)=>{"use strict";var h_=require("lodash"),Tn=require("alasql");Tn.options.cache=!1;var kZ=aE(),Gv=require("clone"),cE=require("recursive-iterator"),Ue=Y(),ze=oe(),Nu=Wn(),FZ=(B(),C(G)),{hdb_errors:GZ}=pe(),{getDatabases:qv}=(Pe(),C(rt)),qZ="IS NULL",ti="There was a problem performing this search. Please check the logs and try again.";kZ(Tn);var Ty=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(ti)}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(ti)}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(ti)}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(ti)}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(ti)}}_getColumns(){let t=new cE(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(Gv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=h_.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=qv()[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 cE(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!ze.isEmpty(r)&&r.right)if(ze.isNotEmptyAndHasValue(r.right.value)){let n=ze.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Tn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=ze.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Tn.yy.LogicValue({value:i}):n instanceof Tn.yy.StringValue&&ze.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Tn.yy.NumValue({value:i}))});if(t){Ue.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new cE(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!ze.isEmpty(FZ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(ze.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(ze.isEmptyOrZeroLength(r.left.columnid)||ze.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(ze.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!ze.isEmpty(r.right.value)||!ze.isEmpty(r.left.value)?n.add(ze.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from)&&ze.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&h_.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(ze.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);ze.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&!ze.isEmptyOrZeroLength(this.columns.columns))return t;if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Tn.promise(r)}catch(r){throw 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(Gv(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(qZ)>-1&&this.tables.forEach(s=>{let i={columnid:qv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=h_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!ze.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let f=await Nu.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(f),new Error(ti)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let p=await Nu.getDataByValue(d);for(let[_,h]of p)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,_))}))}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(f),new Error(ti)}else if(!ze.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,p=f.length;d<p;d++){let _=f[d];c.search_attribute=_.attribute,c.search_value=_.search_value;let h=await Nu.getDataByValue(c,_.operation);if(l)for(let[S]of h)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of h)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(f),new Error(ti)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await Nu.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,p]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(f),new Error(ti)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof Tn.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new Tn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Tn.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new Tn.yy.FuncValue:new Tn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(_=>{_.joinmode&&_.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(_.table);let h=_.joinmode+" JOIN ? AS "+(_.as?_.as:_.table.tableid);_.on&&(h+=" ON "+_.on.toString()),i.push(h),t.push(Object.values(this.data[`${_.table.databaseid_orig}_${_.table.as?_.table.as_orig:_.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(_=>{let h=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__hash_name,S=_.as?_.as_orig:_.tableid_orig;o.push({key:`'${S}.${h}'`,schema:_.databaseid_orig,table:_.as?_.as_orig:_.tableid_orig,keys:new Set}),r.push(`${_.as?_.as:_.tableid}.\`${h}\` AS "${S}.${h}"`),c[_.as?_.as_orig:_.tableid_orig]=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(_=>{_.is_func?r.push(_.initial_select_column.toString()):_.initial_select_column.tableid?r.push(`${_.initial_select_column.tableid}.${_.initial_select_column.columnid} AS ${_.expression.columnid}`):r.push(`${_.initial_select_column.columnid} AS ${_.expression.columnid}`)}));let f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let p=[];try{let _=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,h=this._convertColumnsToIndexes(_,s);p=await Tn.promise(h,t),t=null}catch(_){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(_),new Error("There was a problem processing the data.")}if(p&&p.length>0){for(let _=0,h=p.length;_<h;_++){let S=p[_];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(_=>{let h=Object.keys(this.data[`${_.schema}_${_.table}`].__merged_data),S=h_.difference(h,[..._.keys].map(g=>g.toString()));for(let g=0,A=S.length;g<A;g++){let E=S[g];delete this.data[`${_.schema}_${_.table}`].__merged_data[E]}})}return{existing_attributes:c,joined_length:p?p.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new cE(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=h_.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw Ue.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Ue.error(i),new Error(ti)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let f in i)o.push(i[f][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await Nu.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let p=o[f],_=l.get(p);for(let h=0;h<u;h++){let S=s.columns[h],g=_[S]===void 0?null:_[S];this.data[n].__merged_data[p].push(g)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();Ue.trace(`Final SQL: ${s}`),n=await Tn.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(GZ.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),f=`${l}.[${c}]`;n=n.replace(u,f)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Nu.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Ue.error("There was an error when processing this SQL operation. Check your logs"),Ue.error(o),new Error(ti)}}return Object.values(Object.values(this.data)[0].__merged_data)}};$v.exports=Ty});var Wr=I((eNe,Kv)=>{"use strict";var $Z=Cv();Kv.exports={searchByConditions:KZ,searchByHash:YZ,searchByValue:WZ,search:zZ};var Ay=Wn(),{transformReq:Ry}=oe(),VZ=Vv();async function KZ(e){return Ry(e),Ay.searchByConditions(e)}a(KZ,"searchByConditions");async function YZ(e){Ry(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of Ay.searchByHash(e))r&&t.push(r);return t}a(YZ,"searchByHash");async function WZ(e){Ry(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of Ay.searchByValue(e))t.push(r);return t}a(WZ,"searchByValue");function zZ(e,t){try{let r=new $Z(e);r.validate(),new VZ(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(zZ,"search")});var To=I((rNe,jv)=>{"use strict";var m_=require("crypto"),jZ=ce(),{CONFIG_PARAMS:QZ}=(B(),C(G)),Wv="aes-256-cbc",JZ=32,XZ=16,yy=64,zv=32,ZZ=yy+zv,Yv=new Map;jv.exports={encrypt:e6,decrypt:t6,createNatsTableStreamName:r6};function e6(e){let t=m_.randomBytes(JZ),r=m_.randomBytes(XZ),n=m_.createCipheriv(Wv,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(e6,"encrypt");function t6(e){let t=e.substr(0,yy),r=e.substr(yy,zv),n=e.substr(ZZ,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=m_.createDecipheriv(Wv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(t6,"decrypt");function r6(e,t){let r=jZ.get(QZ.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Yv.get(r);return n||(n=m_.createHash("md5").update(r).digest("hex"),Yv.set(r,n)),n}a(r6,"createNatsTableStreamName")});var Ao=I((iNe,Xv)=>{"use strict";var sNe=Wr(),E_=Y(),Qv=nE(),n6=To(),lE=oe(),{handleHDBError:uE,hdb_errors:s6}=pe(),{HDB_ERROR_MSGS:dE,HTTP_STATUS_CODES:by}=s6,Jv=ce();Jv.initSync();var{getDatabases:Oy}=(Pe(),C(rt)),i6=require("fs-extra"),o6=(B(),C(G));Xv.exports={describeAll:a6,describeTable:fE,describeSchema:c6};async function a6(e={}){try{let t=lE.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=Oy(),o={},c={},l=[],u=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let p=i[d];for(let _ in p)try{let h;if(t||s||r)h=await fE({schema:d,table:_,exact_count:u});else if(n&&n[d].describe&&n[d].tables[_].describe){let S=n[d].tables[_].attribute_permissions;h=await fE({schema:d,table:_,exact_count:u},S)}h&&l.push(h)}catch(h){E_.error(h)}}let f={};for(let d in l)t||s||r?(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?f[d]={}:c[d]&&(f[d]={});return f}catch(t){return E_.error("Got an error in describeAll"),E_.error(t),uE(new Error,dE.DESCRIBE_ALL_ERR)}}a(a6,"describeAll");async function fE(e,t){lE.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=Qv.describe_table(e);if(i)throw i;let c=Oy()[r];if(!c)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),by.NOT_FOUND);let l=c[n];if(!l)throw uE(new Error,dE.TABLE_NOT_FOUND(e.schema,e.table),by.NOT_FOUND);function u(_){f.push({attribute:_.attribute,type:_.type,elements:_.elements?.type,indexed:_.indexed,is_primary_key:_.isPrimaryKey,assigned_created_time:_.assignCreatedTime,assigned_updated_time:_.assignUpdatedTime,nullable:_.nullable,properties:_.properties?_.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let f=[];if(s){let _={};s.forEach(h=>{h.describe&&(_[h.attribute_name]=!0)}),l.attributes.forEach(h=>{_[h.name]&&u(h)})}else l.attributes?.forEach(_=>u(_));let d;try{d=(await i6.stat(l.primaryStore.env.path)).size}catch(_){E_.warn("unable to get database size",_)}let p={schema:r,name:l.tableName,hash_attribute:l.attributes.find(_=>_.isPrimaryKey||_.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:f,db_size:d};l.replicate!==void 0&&(p.replicate=l.replicate),l.expirationMS!==void 0&&(p.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(p.sealed=l.sealed),l.sources?.length>0&&(p.sources=l.sources.map(_=>_.name).filter(_=>_&&_!=="NATSReplicator"&&_!=="Replicator")),Jv.get(o6.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(p.clustering_stream_name=n6.createNatsTableStreamName(p.schema,p.name));try{let _=await l.getRecordCount({exactCount:e.exact_count==="true"});p.record_count=_.recordCount,p.table_size=l.getSize(),p.db_audit_size=l.getAuditSize(),p.estimated_record_range=_.estimatedRange;let h=l.auditStore;if(h)for(let S of h.getKeys({reverse:!0,limit:1}))p.last_updated_record=S[0];if(!p.last_updated_record&&l.indices.__updatedtime__)for(let S of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))p.last_updated_record=S}catch(_){E_.warn(`unable to stat table dbi due to ${_}`)}return p}a(fE,"descTable");async function c6(e){lE.transformReq(e);let t=Qv.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=Oy()[n];if(!i)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),by.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),lE.isEmpty(l)||l.describe){let u=await fE({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(c6,"describeSchema")});var bs=I((lNe,nU)=>{var l6=Eo(),{callbackify:eU,promisify:u6}=require("util"),{getDatabases:tU}=(Pe(),C(rt));nU.exports={setSchemaDataToGlobal:Zv,getTableSchema:d6,getSystemSchema:f6,setSchemaDataToGlobalAsync:u6(Zv)};var rU=Ao(),aNe=eU(rU.describeAll),cNe=eU(rU.describeTable);function Zv(e){global.hdb_schema=tU(),e&&e()}a(Zv,"setSchemaDataToGlobal");function d6(e,t,r){let n=tU()[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(d6,"getTableSchema");function f6(){return l6}a(f6,"getSystemSchema")});var wy=I((dNe,oU)=>{var _6=ut(),Ny=require("joi"),{hdb_table:p6,hdb_database:sU}=vi(),iU={schema:sU,database:sU,table:p6},h6={date:Ny.date().iso().required()},m6={timestamp:Ny.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};oU.exports=function(e,t){let r=t==="timestamp"?{...iU,...m6}:{...iU,...h6},n=Ny.object(r);return _6.validateBySchema(e,n)}});var lU=I((fNe,cU)=>{var E6=ut(),Iy=require("joi"),{hdb_table:g6,hdb_database:aU}=vi(),S6=Iy.object({schema:aU,database:aU,table:g6,hash_values:Iy.array().required(),ids:Iy.array()});cU.exports=function(e){return E6.validateBySchema(e,S6)}});var Ly=I((_Ne,uU)=>{"use strict";var Cy=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}},Py=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}},Dy=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};uU.exports={InsertObject:Cy,NoSQLSeachObject:Py,DeleteResponseObject:Dy}});var Vc=I((hNe,hU)=>{"use strict";var fU=wy(),T6=lU(),qc=oe(),dU=require("moment"),_U=Y(),{promisify:A6,callbackify:R6}=require("util"),$c=(B(),C(G)),y6=bs(),My=A6(y6.getTableSchema),vy=Wn(),{DeleteResponseObject:b6}=Ly(),{handleHDBError:Na,hdb_errors:O6}=pe(),{HDB_ERROR_MSGS:_E,HTTP_STATUS_CODES:wa}=O6,N6="records successfully deleted",w6=R6(pU);hU.exports={delete:w6,deleteRecord:pU,deleteFilesBefore:I6,deleteAuditLogsBefore:C6};async function I6(e){let t=fU(e,"date");if(t)throw Na(t,t.message,wa.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),!dU(e.date,dU.ISO_8601).isValid())throw Na(new Error,_E.INVALID_DATE,wa.BAD_REQUEST,$c.LOG_LEVELS.ERROR,_E.INVALID_DATE,!0);let n=qc.checkSchemaTableExist(e.schema,e.table);if(n)throw Na(new Error,n,wa.NOT_FOUND,$c.LOG_LEVELS.ERROR,n,!0);let s=await vy.deleteRecordsBefore(e);if(await My(e.schema,e.table),_U.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(I6,"deleteFilesBefore");async function C6(e){let t=fU(e,"timestamp");if(t)throw Na(t,t.message,wa.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),isNaN(e.timestamp))throw Na(new Error,_E.INVALID_VALUE("Timestamp"),wa.BAD_REQUEST,$c.LOG_LEVELS.ERROR,_E.INVALID_VALUE("Timestamp"),!0);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw Na(new Error,r,wa.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);let n=await vy.deleteAuditLogsBefore(e);return await My(e.schema,e.table),_U.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(C6,"deleteAuditLogsBefore");async function pU(e){e.ids&&(e.hash_values=e.ids);let t=T6(e);if(t)throw Na(t,t.message,wa.BAD_REQUEST,void 0,void 0,!0);qc.transformReq(e);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw Na(new Error,r,wa.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);try{await My(e.schema,e.table);let n=await vy.deleteRecords(e);return qc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${N6}`),n}catch(n){if(n.message===$c.SEARCH_NOT_FOUND_MESSAGE){let s=new b6;return s.message=$c.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(pU,"deleteRecord")});var pE={};ve(pE,{HASH_FUNCTION:()=>T_,hash:()=>By,validate:()=>Hy});function Uy(e=S_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(g_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function By(e,t=T_[EU?.toUpperCase()]??"sha256"){return xy[t](e)}function Hy(e,t,r=T_[EU?.toUpperCase()]??"sha256"){return e?P6[r](e,t):!1}var g_,wu,mU,EU,S_,gU,T_,xy,P6,hE=be(()=>{g_=M(require("node:crypto")),wu=M(require("argon2")),mU=M(ce());B();EU=(0,mU.get)(x.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),S_=16,gU=9,T_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(T_||{});a(Uy,"generateSalt");xy={md5:a((e,t=void 0)=>{t=t??Uy(gU);let r=g_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??Uy(S_);let r=g_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=Uy(S_),r=await wu.hash(e,{type:wu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},P6={md5:a((e,t)=>{let r=e.slice(0,gU);return e===xy.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,S_);return e===xy.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await wu.verify(e.slice(S_),t),"argon2id")};a(By,"hash");a(Hy,"validate")});var TU=I((SNe,SU)=>{var ky=ut(),zr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function D6(e){return zr.password.presence=!0,zr.username.presence=!0,zr.role.presence=!0,zr.active.presence=!0,ky.validateObject(e,zr)}a(D6,"addUserValidation");function L6(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,ky.validateObject(e,zr)}a(L6,"alterUserValidation");function M6(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,ky.validateObject(e,zr)}a(M6,"dropUserValidation");SU.exports={addUserValidation:D6,alterUserValidation:L6,dropUserValidation:M6}});var St=I((RNe,RU)=>{"use strict";var{platform:ANe}=require("os"),v6="nats-server.zip",Fy="nats-server",U6=process.platform==="win32"?`${Fy}.exe`:Fy,x6=/^[^\s.,*>]+$/,AU="__request__",B6=a(e=>`${e}.${AU}`,"REQUEST_SUBJECT"),H6={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},k6={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},F6={HUB:"hub.pid",LEAF:"leaf.pid"},G6={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},q6={SUCCESS:"success",ERROR:"error"},$6={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},V6={TXN:"txn",MSGID:"msgid"},Iu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},K6={[Iu.ERR]:1,[Iu.WRN]:2,[Iu.INF]:3,[Iu.DBG]:4,[Iu.TRC]:5},Y6={debug:"-D",trace:"-DVV"};RU.exports={NATS_SERVER_ZIP:v6,NATS_SERVER_NAME:Fy,NATS_BINARY_NAME:U6,PID_FILES:F6,NATS_CONFIG_FILES:k6,SERVER_SUFFIX:G6,NATS_TERM_CONSTRAINTS_RX:x6,REQUEST_SUFFIX:AU,UPDATE_REMOTE_RESPONSE_STATUSES:q6,CLUSTER_STATUS_STATUSES:$6,REQUEST_SUBJECT:B6,SUBJECT_PREFIXES:V6,MSG_HEADERS:H6,LOG_LEVELS:Iu,LOG_LEVEL_FLAGS:Y6,LOG_LEVEL_HIERARCHY:K6}});var Gy=I(yU=>{"use strict";var W6={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
|
|
18
18
|
`),key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
|
|
19
|
-
`)},E6="certificate.pem",m6="privateKey.pem",g6="caCertificate.pem",S6="natsCertificate.pem",T6="natsCaCertificate.pem",St={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},A6={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"]},R6={[St.SERVER]:2,[St.DEFAULT]:1},y6={[St["OPERATIONS-API"]]:3,[St.SERVER]:2,[St.DEFAULT]:1},b6={[St["OPERATIONS-API"]]:3,[St.SERVER]:2,[St.DEFAULT]:1},O6={[St["OPERATIONS-CA"]]:3,[St.CA]:2,[St["DEFAULT-CA"]]:1},N6={[St["OPERATIONS-CA"]]:3,[St.CA]:2,[St["DEFAULT-CA"]]:1},w6={[St.CA]:2,[St["DEFAULT-CA"]]:1};Object.assign(sU,{CERTIFICATE_PEM_NAME:E6,PRIVATEKEY_PEM_NAME:m6,CA_PEM_NAME:g6,CERT_NAME:St,CERT_CONFIG_NAME_MAP:A6,CERT_PREFERENCE_APP:R6,CERT_PREFERENCE_OPS:y6,CERT_PREFERENCE_REP:b6,CA_CERT_PREFERENCE_REP:O6,CA_CERT_PREFERENCE_OPS:N6,CA_CERT_PREFERENCE_APP:w6,CERTIFICATE_VALUES:p6,NATS_CERTIFICATE_PEM_NAME:S6,NATS_CA_PEM_NAME:T6})});var wy=C((mNe,uU)=>{"use strict";var cU=require("fs-extra"),Se=require("joi"),I6=require("os"),{boolean:He,string:Tt,number:nr,array:Yc}=Se.types(),{totalmem:iU}=require("os"),Kc=require("path"),C6=W(),Ny=ae(),ENe=Oy(),oU=(v(),D(q)),P6=pt(),aU="log",D6="components",L6="Invalid logging.rotation.maxSize unit. Available units are G, M or K",M6="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",v6="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",U6="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",x6="rootPath config parameter is undefined",Tn=Se.alternatives([nr.min(0),Tt]).optional().empty(null),cm=Se.alternatives([Yc.items(Tt,{host:Tt.required(),port:Tn},{hostname:Tt.required(),port:Tn}).empty(null),Yc.items(Tt)]),Hi,lU=!1;uU.exports={configValidator:B6,routesValidator:$6,route_constraints:cm};function B6(e,t=!1){if(lU=t,Hi=e.rootPath,Ny.isEmpty(Hi))throw x6;let r=He.optional(),n=nr.min(0).max(1e3).empty(null).default(G6),s=Tt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(__),i=Tt.optional().empty(null),o=Tt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Se.string().empty(null).default(__),l=Se.custom(k6).empty(null).default(__),u=e.clustering?.enabled,f=Se.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Se.object({enabled:r,hubServer:Se.object({cluster:Se.object({name:Se.required().empty(null),network:Se.object({port:Tn,routes:cm}).required()}).required(),leafNodes:Se.object({network:Se.object({port:Tn}).required()}).required(),network:Se.object({port:Tn}).required()}).required(),leafServer:Se.object({network:Se.object({port:Tn,routes:cm}).required(),streams:Se.object({maxAge:nr.min(120).allow(null).optional(),maxBytes:nr.min(1).allow(null).optional(),maxMsgs:nr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:Se.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:He.optional(),databaseLevel:He.optional(),tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.required(),verify:He.optional()}),user:Tt.optional().empty(null)}).optional():d=Se.object({enabled:r,tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.optional()})}).optional(),Se.object({authentication:Se.alternatives(Se.object({authorizeLocal:He,cacheTTL:nr.required(),enableSessions:He,hashFunction:Tt.valid("md5","sha256","argon2id").optional().empty(null)}),He).optional(),analytics:Se.object({aggregatePeriod:nr}),replication:Se.object({hostname:Se.alternatives(Tt,nr).optional().empty(null),url:Tt.optional().empty(null),port:Tn,securePort:Tn,routes:Yc.optional().empty(null),databases:Se.alternatives(Tt,Yc),enableRootCAs:He.optional(),copyTablesToCatchUp:He.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Se.object({enabled:r}).required(),logging:Se.object({auditAuthEvents:Se.object({logFailed:He,logSuccessful:He}),file:He.required(),level:Se.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Se.object({enabled:He.optional(),compress:He.optional(),interval:Tt.custom(q6).optional().empty(null),maxSize:Tt.custom(F6).optional().empty(null),path:Tt.optional().empty(null).default(__)}).required(),root:s,stdStreams:He.required(),auditLog:He.required()}).required(),operationsApi:Se.object({network:Se.object({cors:He.optional(),corsAccessList:Yc.optional(),headersTimeout:nr.min(1).optional(),keepAliveTimeout:nr.min(1).optional(),port:Tn,domainSocket:Se.optional().empty("hdb/operations-server").default(__),securePort:Tn,timeout:nr.min(1).optional()}).optional(),tls:Se.alternatives([Se.array().items(f),f])}).required(),rootPath:Tt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Se.object({network:Se.object({port:Tn,securePort:Tn,mtls:Se.alternatives([He.optional(),Se.object({user:Tt.optional(),certificateAuthority:i,required:He.optional()})])}).required(),webSocket:He.optional(),requireAuthentication:He.optional()}),http:Se.object({compressionThreshold:nr.optional(),cors:He.optional(),corsAccessList:Yc.optional(),headersTimeout:nr.min(1).optional(),port:Tn,securePort:Tn,maxHeaderSize:nr.optional(),mtls:Se.alternatives([He.optional(),Se.object({user:Tt.optional(),certificateAuthority:i,required:He.optional()})]),threadRange:Se.alternatives([Yc.optional(),Tt.optional()])}).required(),threads:Se.alternatives(n.optional(),Se.object({count:n.optional(),debug:Se.alternatives(He.optional(),Se.object({startingPort:nr.min(1).optional(),host:Tt.optional(),waitForDebugger:He.optional()})),maxHeapMemory:nr.min(0).optional()})),storage:Se.object({writeAsync:He.required(),overlappingSync:He.optional(),caching:He.optional(),compression:Se.alternatives([He.optional(),Se.object({dictionary:Tt.optional(),threshold:nr.optional()})]),compactOnStart:He.optional(),compactOnStartKeepBackup:He.optional(),noReadAhead:He.optional(),path:l,prefetchWrites:He.optional(),maxFreeSpaceToLoad:nr.optional(),maxFreeSpaceToRetain:nr.optional()}).required(),ignoreScripts:He.optional(),tls:Se.alternatives([Se.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(B6,"configValidator");function H6(e){return lU||cU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(H6,"doesPathExist");function k6(e,t){Se.assert(e,Tt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=H6(e);if(r)return t.message(r)}a(k6,"validatePath");function F6(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(L6);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(v6):e}a(F6,"validateRotationMaxSize");function q6(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(M6);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(U6):e}a(q6,"validateRotationInterval");function G6(e,t){let r=t.state.path.join("."),n=I6.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||iU();return i=Math.round(Math.min(i,iU())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),C6.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(G6,"setDefaultThreads");function __(e,t){let r=t.state.path.join(".");if(!Ny.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Ny.isEmpty(Hi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Kc.join(Hi,D6);case"logging.root":return Kc.join(Hi,aU);case"clustering.leafServer.streams.path":return Kc.join(Hi,"clustering","leaf");case"storage.path":let n=Kc.join(Hi,oU.LEGACY_DATABASES_DIR_NAME);return cU.existsSync(n)?n:Kc.join(Hi,oU.DATABASES_DIR_NAME);case"logging.rotation.path":return Kc.join(Hi,aU);case"operationsApi.network.domainSocket":return r==null?null:Kc.join(Hi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(__,"setDefaultRoot");function $6(e){let t=Se.object({routes:cm});return P6.validateBySchema({routes:e},t)}a($6,"routesValidator")});var At=C(AU=>{"use strict";var bs=(v(),D(q)),Sr=ae(),sr=W(),{configValidator:V6,routesValidator:dU}=wy(),Qr=require("fs-extra"),_U=require("yaml"),jn=require("path"),K6=require("is-number"),hU=require("properties-reader"),Y6=require("lodash"),{handleHDBError:W6}=_e(),{HTTP_STATUS_CODES:z6,HDB_ERROR_MSGS:bu}=Fn(),{server:j6}=(Yr(),D(Ic)),{PACKAGE_ROOT:pU}=rt(),{DATABASES_PARAM_CONFIG:h_,CONFIG_PARAMS:zn,CONFIG_PARAM_MAP:si}=bs,Q6="Unable to get config value because config is uninitialized",J6="Config successfully initialized",X6="Error backing up config file",Z6="Empty parameter sent to getConfigValue",EU=jn.join(pU,"config","yaml",bs.HDB_DEFAULT_CONFIG_FILE),e8=jn.join(pU,"config","yaml","defaultNatsConfig.yaml"),t8="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",fU={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"},lm,wt,um;Object.assign(AU,{createConfigFile:r8,getDefaultConfig:n8,getConfigValue:gU,initConfig:dm,flattenConfig:Ou,updateConfigValue:SU,updateConfigObject:i8,getConfiguration:c8,setConfiguration:l8,readConfigFile:Dy,getClusteringRoutes:u8,initOldConfig:TU,getConfigFromFile:d8,getConfigFilePath:Wc,addConfig:f8,deleteConfigFromFile:_8,getConfigObj:h8,resolvePath:Iy,getFlatConfigObj:p8});function Iy(e){if(e?.startsWith("~/"))return jn.join(Sr.getHomeDir(),e.slice(1));let t=ce();return jn.resolve(t.getHdbBasePath(),e)}a(Iy,"resolvePath");function r8(e,t=!1){let r=Pa(EU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=_U.parseDocument(Qr.readFileSync(e8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}lm=Ou(r.toJSON());let n;for(let c in e){let l=si[c.toLowerCase()];if(l===zn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),f=Cy(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){sr.error(d)}}}n&&mU(r,n),Py(r,t);let s=r.toJSON();wt=Ou(s);let i=r.getIn(["rootPath"]),o=jn.join(i,bs.HDB_CONFIG_FILE);if(Qr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);Qr.writeFileSync(o,String(r)),sr.trace(`Config file written to ${o}`)}a(r8,"createConfigFile");function mU(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(h_.TABLES))for(let i in n[s][h_.TABLES])for(let o in n[s][h_.TABLES][i]){let c=n[s][h_.TABLES][i][o],l=[zn.DATABASES,s,h_.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=[zn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){sr.error("Error parsing schemas CLI/env config arguments",n)}}a(mU,"setSchemasConfig");function n8(e){if(lm===void 0){let r=Pa(EU);lm=Ou(r.toJSON())}let t=si[e.toLowerCase()];if(t!==void 0)return lm[t.toLowerCase()]}a(n8,"getDefaultConfig");function gU(e){if(e==null){sr.info(Z6);return}if(wt===void 0){sr.trace(Q6);return}let t=si[e.toLowerCase()];if(t!==void 0)return wt[t.toLowerCase()]}a(gU,"getConfigValue");function Wc(e=Sr.getPropsFilePath()){let t=Sr.getEnvCliRootPath();if(t)return Iy(jn.join(t,bs.HDB_CONFIG_FILE));let r=hU(e);return Iy(r.get(bs.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Wc,"getConfigFilePath");function dm(e=!1){if(wt===void 0||e){let t;if(!Sr.noBootFile()){t=Sr.getPropsFilePath();try{Qr.accessSync(t,Qr.constants.F_OK|Qr.constants.R_OK)}catch(i){throw sr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Wc(t),n;if(r.includes("config/settings.js"))try{TU(r);return}catch(i){if(i.code!==bs.NODE_ERROR_CODES.ENOENT)throw i}try{n=Pa(r)}catch(i){if(i.code===bs.NODE_ERROR_CODES.ENOENT){sr.trace(`HarperDB config file not found at ${r}.
|
|
20
|
-
This can occur during early stages of install where the config file has not yet been created`);return}else throw sr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}s8(n,r),Py(n);let s=n.toJSON();if(j6.config=s,wt=Ou(s),wt.logging_rotation_rotate)for(let i in fU)wt[i]&&sr.error(`Config ${fU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);sr.trace(J6)}}a(dm,"initConfig");function s8(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],jn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],jn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(sr.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);Qr.writeFileSync(t,String(e))}}a(s8,"checkForUpdatedConfig");function Py(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 bu.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 bu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=V6(r,t);if(n.error)throw bu.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(Py,"validateConfig");function i8(e,t){wt===void 0&&(wt={});let r=si[e.toLowerCase()];if(r===void 0){sr.trace(`Unable to update config object because config param '${e}' does not exist`);return}wt[r.toLowerCase()]=t}a(i8,"updateConfigObject");function SU(e,t,r=void 0,n=!1,s=!1,i=!1){wt===void 0&&dm();let o=gU(si.hdb_root),c=jn.join(o,bs.HDB_CONFIG_FILE),l=Pa(c),u;if(r&&wt){let h=!1;for(let _ in r)if(r[_]!=wt[_.toLowerCase()]){h=!0;break}if(!h){sr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===zn.DATABASES)u=t;else if(r===void 0){let h;if(i)h=e;else if(h=si[e.toLowerCase()],h===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=h.split("_"),p=Cy(h,t);l.setIn([..._],p)}else for(let h in r){let _=si[h.toLowerCase()];if(_===zn.HTTP_SECUREPORT&&r[h]===wt[zn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===zn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[h]===wt[zn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===zn.DATABASES){u=r[h];continue}if(_?.startsWith("threads_")){let p=l.getIn(["threads"]);p>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],p))}if(!_&&(h.endsWith("_package")||h.endsWith("_port"))&&(_=h),_!==void 0){let p=_.split("_"),S=bs.LEGACY_CONFIG_PARAMS[h.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,p=S.split("_"));let g=Cy(_,r[h]);_==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{p.length>1&&typeof l.getIn(p.slice(0,-1))=="boolean"&&l.deleteIn(p.slice(0,-1)),l.setIn([...p],g)}catch(T){sr.error(T)}}}u&&mU(l,u),Py(l);let f=l.getIn(["rootPath"]),d=jn.join(f,bs.HDB_CONFIG_FILE);if(n===!0&&o8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);Qr.writeFileSync(d,String(l)),s&&(wt=Ou(l.toJSON())),sr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(SU,"updateConfigValue");function o8(e,t){try{let r=jn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${bs.HDB_CONFIG_FILE}.bak`);Qr.copySync(e,r),sr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){sr.error(X6),sr.error(r)}}a(o8,"backupConfigFile");var a8=["databases"];function Ou(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}),um=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])&&!a8.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;!zn[l.toUpperCase()]&&si[l]&&(s[si[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Ou,"flattenConfig");function Cy(e,t){if(e===zn.CLUSTERING_NODENAME||e===zn.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(K6(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(Cy,"castConfigValue");function c8(){let e=Sr.getPropsFilePath(),t=Wc(e);return Pa(t).toJSON()}a(c8,"getConfiguration");async function l8(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return SU(void 0,void 0,s,!0),t8}catch(i){throw typeof i=="string"||i instanceof String?W6(i,i,z6.BAD_REQUEST,void 0,void 0,!0):i}}a(l8,"setConfiguration");function Dy(){let e=Sr.getPropsFilePath();try{Qr.accessSync(e,Qr.constants.F_OK|Qr.constants.R_OK)}catch(n){if(!Sr.noBootFile())throw sr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Wc(e);return Pa(t).toJSON()}a(Dy,"readConfigFile");function Pa(e){return _U.parseDocument(Qr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Pa,"parseYamlDoc");function u8(){let e=Dy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Sr.isEmptyOrZeroLength(t)?[]:t;let r=dU(t);if(r)throw bu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Sr.isEmptyOrZeroLength(n)?[]:n;let s=dU(n);if(s)throw bu.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 bu.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(u8,"getClusteringRoutes");function TU(e){let t=hU(e);wt={};for(let r in si){let n=t.get(r.toUpperCase());if(Sr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=si[r].toLowerCase();s===zn.LOGGING_ROOT?wt[s]=jn.dirname(n):wt[s]=n}return wt}a(TU,"initOldConfig");function d8(e){let t=Dy();return Y6.get(t,e.replaceAll("_","."))}a(d8,"getConfigFromFile");async function f8(e,t){let r=Pa(Wc());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await Qr.writeFile(Wc(),String(r))}a(f8,"addConfig");function _8(e){let t=Wc(Sr.getPropsFilePath()),r=Pa(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=jn.join(n,bs.HDB_CONFIG_FILE);Qr.writeFileSync(s,String(r))}a(_8,"deleteConfigFromFile");function h8(){return um||(dm(),um)}a(h8,"getConfigObj");function p8(){return wt||dm(),wt}a(p8,"getFlatConfigObj")});var An=C((ANe,wr)=>{"use strict";var bU="username is required",OU="nothing to update, must supply active, role or password to update",NU="password cannot be an empty string",wU="If role is specified, it cannot be empty.",IU="active must be true or false";wr.exports.addUser=b8;wr.exports.alterUser=O8;wr.exports.dropUser=w8;wr.exports.getSuperUser=L8;wr.exports.userInfo=I8;wr.exports.listUsers=fm;wr.exports.listUsersExternal=C8;wr.exports.setUsersWithRolesCache=zc;wr.exports.findAndValidateUser=MU;wr.exports.getClusterUser=M8;wr.exports.getUsersWithRolesCache=D8;wr.exports.USERNAME_REQUIRED=bU;wr.exports.ALTERUSER_NOTHING_TO_UPDATE=OU;wr.exports.EMPTY_PASSWORD=NU;wr.exports.EMPTY_ROLE=wU;wr.exports.ACTIVE_BOOLEAN=IU;var CU=Rn(),E8=Vc(),p_=(am(),D(om)),PU=tU(),E_=zr(),xy=wo(),ki=ae(),DU=require("validate.js"),By=W(),{promisify:m8}=require("util"),Hy=bo(),My=(v(),D(q)),RU=gt(),g8=At(),S8=ce(),T8=Ao(),{hdb_errors:A8,ClientError:ii}=_e(),{HTTP_STATUS_CODES:No,AUTHENTICATION_ERROR_MSGS:Ly,HDB_ERROR_MSGS:Nu}=A8,{UserEventMsg:ky}=oi(),vy=require("lodash"),{server:Fy}=(Yr(),D(Ic)),R8=W();Fy.getUser=(e,t)=>MU(e,t,t!=null);var LU={username:!0,active:!0,role:!0,password:!0},yU=new Map,y8=m8(E8.delete),Uy=S8.get(My.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??p_.HASH_FUNCTION.SHA256,Fi;async function b8(e){let t=DU.cleanAttributes(e,LU),r=PU.addUserValidation(t);if(r)throw new ii(r.message);let n=await E_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new ii(Nu.ROLE_NAME_NOT_FOUND(t.role),No.NOT_FOUND);if(n.length>1)throw new ii(Nu.DUP_ROLES_FOUND(t.role),No.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=Hy.encrypt(t.password)),t.password=await p_.hash(t.password,Uy),t.hash_function=Uy,t.role=n[0].id;let s=await CU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(By.debug(s),await zc(),s.skipped_hashes.length===1)throw new ii(Nu.USER_ALREADY_EXISTS(t.username),No.CONFLICT);return xy.signalUserChange(new ky(process.pid)),`${t.username} successfully added`}a(b8,"addUser");async function O8(e){let t=DU.cleanAttributes(e,LU);if(ki.isEmptyOrZeroLength(t.username))throw new Error(bU);if(ki.isEmptyOrZeroLength(t.password)&&ki.isEmptyOrZeroLength(t.role)&&ki.isEmptyOrZeroLength(t.active))throw new Error(OU);if(!ki.isEmpty(t.password)&&ki.isEmptyOrZeroLength(t.password.trim()))throw new Error(NU);if(!ki.isEmpty(t.active)&&!ki.isBoolean(t.active))throw new Error(IU);if(!ki.isEmpty(t.password)&&!ki.isEmptyOrZeroLength(t.password.trim())&&(N8(t.username)&&(t.hash=Hy.encrypt(t.password)),t.password=await p_.hash(t.password,Uy)),t.role==="")throw new Error(wU);if(t.role){let n=await E_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ii(Nu.ALTER_USER_ROLE_NOT_FOUND(t.role),No.NOT_FOUND);if(n.length>1)throw new ii(Nu.DUP_ROLES_FOUND(t.role),No.CONFLICT);t.role=n[0].id}let r=await CU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await zc(),xy.signalUserChange(new ky(process.pid)),r}a(O8,"alterUser");function N8(e){let t=!1,r=Fi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(N8,"isClusterUser");async function w8(e){let t=PU.dropUserValidation(e);if(t)throw new ii(t.message);if(Fi.get(e.username)===void 0)throw new ii(Nu.USER_NOT_EXIST(e.username),No.NOT_FOUND);let r=await y8({table:"hdb_user",schema:"system",hash_values:[e.username]});return By.debug(r),await zc(),xy.signalUserChange(new ky(process.pid)),`${e.username} successfully deleted`}a(w8,"dropUser");async function I8(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=vy.cloneDeep(e.hdb_user);let r=await E_.searchByHash({schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]});return t.role=r[0],delete t.password,delete t.refresh_token,delete t.hash,delete t.hash_function,t}a(I8,"userInfo");async function C8(){let e=await fm();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(C8,"listUsersExternal");async function fm(){let e=await E_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=vy.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await E_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=vy.cloneDeep(s),s.role=t[s.role],P8(s.role),n.set(s.username,s);return n}a(fm,"listUsers");function P8(e){if(!e){By.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(T8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(P8,"appendSystemTablesToRole");async function zc(e=void 0){e?Fi=e:Fi=await fm()}a(zc,"setUsersWithRolesCache");async function D8(){return Fi||await zc(),Fi}a(D8,"getUsersWithRolesCache");async function MU(e,t,r=!0){Fi||await zc();let n=Fi.get(e);if(!n){if(!r)return{username:e};throw new ii(Ly.GENERIC_AUTH_FAIL,No.UNAUTHORIZED)}if(n&&!n.active)throw new ii(Ly.USER_INACTIVE,No.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(yU.get(t)===n.password)return s;{let i=p_.validate(n.password,t,n.hash_function||p_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)yU.set(t,n.password);else throw new ii(Ly.GENERIC_AUTH_FAIL,No.UNAUTHORIZED)}}return s}a(MU,"findAndValidateUser");async function L8(){Fi||await zc();for(let[,e]of Fi)if(e.role.role==="super_user")return e}a(L8,"getSuperUser");async function M8(){let e=await fm(),t=g8.getConfigFromFile(My.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==My.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=Hy.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+RU.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+RU.SERVER_SUFFIX.ADMIN,r}a(M8,"getClusterUser");var vU=[];Fy.invalidateUser=function(e){for(let t of vU)try{t(e)}catch(r){R8.error("Error invalidating user",r)}};Fy.onInvalidatedUser=function(e){vU.push(e)}});var g_=C((ONe,HU)=>{"use strict";var jc=W(),Qn=(v(),D(q)),v8=JM(),yNe=ys(),bNe=Oo(),U8=An(),{validateEvent:UU}=oi(),m_=Wn(),x8=require("process"),{resetDatabases:B8}=(Ce(),D(tt)),H8={[Qn.ITC_EVENT_TYPES.SCHEMA]:k8,[Qn.ITC_EVENT_TYPES.USER]:BU};async function k8(e){let t=UU(e);if(t){jc.error(t);return}jc.trace("ITC schemaHandler received schema event:",e),await v8(e.message),await F8(e.message)}a(k8,"schemaHandler");async function F8(e){try{m_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),m_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),m_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=B8();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){jc.error(t)}}a(F8,"syncSchemaMetadata");var xU=[];async function BU(e){try{try{m_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),m_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){jc.warn(r)}let t=UU(e);if(t){jc.error(t);return}jc.trace(`ITC userHandler ${Qn.HDB_ITC_CLIENT_PREFIX}${x8.pid} received user event:`,e),await U8.setUsersWithRolesCache();for(let r of xU)r()}catch(t){jc.error(t)}}a(BU,"userHandler");BU.addListener=function(e){xU.push(e)};HU.exports=H8});var oi=C((DNe,FU)=>{"use strict";var wNe=W(),qy=ae(),q8=(v(),D(q)),{ITC_ERRORS:S_}=Fn(),{parentPort:INe,threadId:G8,isMainThread:$8,workerData:CNe}=require("worker_threads"),{onMessageFromWorkers:V8,broadcast:PNe,broadcastWithAcknowledgement:K8}=nt();FU.exports={sendItcEvent:Y8,validateEvent:kU,SchemaEventMsg:W8,UserEventMsg:z8};var _m;V8(async(e,t)=>{_m=_m||g_(),kU(e),_m[e.type]&&await _m[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function Y8(e){return!$8&&e.message&&(e.message.originator=G8),K8(e)}a(Y8,"sendItcEvent");function kU(e){if(typeof e!="object")return S_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||qy.isEmpty(e.type))return S_.MISSING_TYPE;if(!e.hasOwnProperty("message")||qy.isEmpty(e.message))return S_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||qy.isEmpty(e.message.originator))return S_.MISSING_ORIGIN;if(q8.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return S_.INVALID_EVENT(e.type)}a(kU,"validateEvent");function W8(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(W8,"SchemaEventMsg");function z8(e){this.originator=e}a(z8,"UserEventMsg")});var wo=C((vNe,VU)=>{"use strict";var qU=(v(),D(q)),MNe=ae(),hm=W(),GU=zM(),wu,{sendItcEvent:$U}=oi();function j8(e){try{hm.info("signalSchemaChange called with message:",e),wu=wu||g_();let t=new GU(qU.ITC_EVENT_TYPES.SCHEMA,e);return wu.schema(t),$U(t)}catch(t){hm.error(t)}}a(j8,"signalSchemaChange");function Q8(e){try{hm.trace("signalUserChange called with message:",e),wu=wu||g_();let t=new GU(qU.ITC_EVENT_TYPES.USER,e);return wu.user(t),$U(t)}catch(t){hm.error(t)}}a(Q8,"signalUserChange");VU.exports={signalSchemaChange:j8,signalUserChange:Q8}});var pm=C((xNe,YU)=>{"use strict";var KU=ae(),J8=(v(),D(q)),X8=W(),Z8=QE(),e5=jE(),t5=wo(),{SchemaEventMsg:r5}=oi(),n5="already exists in";YU.exports=s5;async function s5(e,t,r){if(KU.isEmptyOrZeroLength(r))return r;let n=[];KU.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 i5(e,t.schema,t.name,i)})),s}a(s5,"lmdbCheckForNewAttributes");async function i5(e,t,r,n){let s=new e5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await o5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(n5))X8.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(i5,"createNewAttribute");async function o5(e){let t;return t=await Z8(e),t5.signalSchemaChange(new r5(process.pid,J8.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(o5,"createAttribute")});var Iu=C((HNe,WU)=>{"use strict";var Gy=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}};WU.exports=Gy});var jU=C((FNe,zU)=>{"use strict";var a5=Iu(),c5=(v(),D(q)).OPERATIONS_ENUM,$y=class extends a5{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(c5.INSERT,r,n,s,i),this.records=t}};zU.exports=$y});var JU=C((GNe,QU)=>{"use strict";var l5=Iu(),u5=(v(),D(q)).OPERATIONS_ENUM,Vy=class extends l5{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(u5.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};QU.exports=Vy});var ZU=C((VNe,XU)=>{"use strict";var d5=Iu(),f5=(v(),D(q)).OPERATIONS_ENUM,Ky=class extends d5{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(f5.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};XU.exports=Ky});var t0=C((YNe,e0)=>{"use strict";var _5=Iu(),h5=(v(),D(q)).OPERATIONS_ENUM,Yy=class extends _5{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(h5.DELETE,n,s,t,i),this.original_records=r}};e0.exports=Yy});var T_=C((jNe,i0)=>{"use strict";var zNe=require("path"),r0=ct(),p5=jU(),E5=JU(),m5=ZU(),g5=t0(),Cu=Mt(),n0=ae(),{CONFIG_PARAMS:S5}=(v(),D(q)),s0=ce();s0.initSync();var Em=(v(),D(q)).OPERATIONS_ENUM,{getTransactionAuditStorePath:T5}=ht();i0.exports=A5;async function A5(e,t){if(s0.get(S5.LOGGING_AUDITLOG)===!1)return;let r=T5(e.schema,e.table),n=await r0.openEnvironment(r,e.table,!0),s=R5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){r0.initializeDBIs(n,Cu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Cu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Cu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Cu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),n0.isEmpty(s.user_name)||n.dbis[Cu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Cu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(A5,"writeTransaction");function R5(e,t){let r=n0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Em.INSERT)return new p5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Em.UPDATE)return new E5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Em.UPSERT)return new m5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Em.DELETE)return new g5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(R5,"createTransactionObject")});var Wy=C((XNe,o0)=>{"use strict";var y5=s_(),JNe=Pf(),A_=(v(),D(q)),b5=Df(),O5=kc().insertRecords,N5=ct(),w5=W(),I5=pm(),{getSchemaPath:C5}=ht(),P5=T_();o0.exports=D5;async function D5(e){try{let{schema_table:t,attributes:r}=y5(e);b5(e,r,t.hash_attribute),e.schema!==A_.SYSTEM_SCHEMA_NAME&&(r.includes(A_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(A_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(A_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(A_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await I5(e.hdb_auth_header,t,r),s=C5(e.schema,e.table),i=await N5.openEnvironment(s,e.table),o=await O5(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await P5(e,o)}catch(c){w5.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(D5,"lmdbCreateRecords")});var l0=C((ewe,c0)=>{"use strict";var a0=(v(),D(q)),L5=Wy(),M5=Pf(),v5=require("fs-extra"),{getSchemaPath:U5}=ht();c0.exports=x5;async function x5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new M5(a0.SYSTEM_SCHEMA_NAME,a0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await L5(r),await v5.mkdirp(U5(e.schema))}a(x5,"lmdbCreateSchema")});var d0=C((rwe,u0)=>{"use strict";var zy=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}};u0.exports=zy});var p0=C((awe,h0)=>{"use strict";var f0=ct(),jy=_n(),Qy=Fn().LMDB_ERRORS_ENUM,B5=Mt(),_0=W(),swe=ae(),H5=require("lmdb"),k5=d0(),F5=(v(),D(q)),{OVERFLOW_MARKER:iwe,MAX_SEARCH_KEY_LENGTH:owe}=B5,q5=F5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function G5(e,t,r,n){if(jy.validateEnv(e),t===void 0)throw new Error(Qy.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Qy.IDS_REQUIRED):new Error(Qy.IDS_MUST_BE_ITERABLE);try{let s=f0.listDBIs(e);f0.initializeDBIs(e,t,s);let i=new k5,o,c=[],l=[];for(let h=0,_=r.length;h<_;h++)try{o=r[h];let p=e.dbis[t].get(o);if(!p||n&&p[q5]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,H5.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let T=s[g];if(!p.hasOwnProperty(T)||T===t)continue;let m=e.dbis[T],A=p[T];if(A!=null)try{let w=jy.getIndexedValues(A);if(w)for(let M=0,F=w.length;M<F;M++)m.remove(w[M],o)}catch{_0.warn(`cannot delete from attribute: ${T}, ${A}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(p)}catch(p){_0.warn(p),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let h=0,_=f.length;h<_;h++)f[h]===!0?i.deleted.push(l[h]):(i.skipped.push(l[h]),u.push(h));let d=0;for(let h=0;h<u.length;h++){let _=u[h];i.original_records.splice(_-d,1),d++}return i.txn_time=jy.getNextMonotonicTime(),i}catch(s){throw s}}a(G5,"deleteRecords");h0.exports={deleteRecords:G5}});var R_=C((lwe,m0)=>{"use strict";var Pu=ae(),$5=p0(),V5=ct(),{getSchemaPath:K5}=ht(),Y5=T_(),W5=W();m0.exports=z5;async function z5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Pu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Pu.isEmptyOrZeroLength(e.hash_values)&&!Pu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Pu.isEmpty(l)||e.hash_values.push(l)}}if(Pu.isEmptyOrZeroLength(e.hash_values))return E0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Pu.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=K5(e.schema,e.table),i=await V5.openEnvironment(s,e.table),o=await $5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await Y5(e,o)}catch(c){W5.error(`unable to write transaction due to ${c.message}`)}return E0(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(z5,"lmdbDeleteRecords");function E0(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(E0,"createDeleteResponse")});var Xy=C((fwe,g0)=>{"use strict";var j5=(v(),D(q)),dwe=_n();function Jy(e,t){let r=Object.create(null);if(t.length===1&&j5.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(Jy,"parseRow");function Q5(e,t,r,n){let s=Jy(r,e);n.push(s)}a(Q5,"searchAll");function J5(e,t,r,n){let s=Jy(r,e);n[t]=s}a(J5,"searchAllToMap");function X5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(X5,"iterateDBI");function Qc(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(Qc,"pushResults");function Z5(e,t,r,n,s,i){t.toString().endsWith(e)&&Qc(t,r,n,s,i)}a(Z5,"endsWith");function e9(e,t,r,n,s,i){t.toString().includes(e)&&Qc(t,r,n,s,i)}a(e9,"contains");function t9(e,t,r,n,s,i){t>e&&Qc(t,r,n,s,i)}a(t9,"greaterThanCompare");function r9(e,t,r,n,s,i){t>=e&&Qc(t,r,n,s,i)}a(r9,"greaterThanEqualCompare");function n9(e,t,r,n,s,i){t<e&&Qc(t,r,n,s,i)}a(n9,"lessThanCompare");function s9(e,t,r,n,s,i){t<=e&&Qc(t,r,n,s,i)}a(s9,"lessThanEqualCompare");g0.exports={parseRow:Jy,searchAll:Q5,searchAllToMap:J5,iterateDBI:X5,endsWith:Z5,contains:e9,greaterThanCompare:t9,greaterThanEqualCompare:r9,lessThanCompare:n9,lessThanEqualCompare:s9,pushResults:Qc}});var Du=C((mwe,O0)=>{"use strict";var Da=ct(),hwe=W(),Jn=_n(),mm=Mt(),Yt=Fn().LMDB_ERRORS_ENUM,pwe=ae(),i9=(v(),D(q)),gm=Xy(),{parseRow:o9}=gm,Ewe=require("lmdb"),{OVERFLOW_MARKER:S0,MAX_SEARCH_KEY_LENGTH:a9}=mm;function T0(e,t,r,n=!1,s=void 0,i=void 0){return Jc(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(T0,"iterateFullIndex");function y_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Jc(e,t,r,(f,d,h,_)=>{let m={transaction:f,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return _===r?(m.values=!1,d.getRange(m).map(A=>({value:A}))):d.getRange(m)})}a(y_,"iterateRangeBetween");function Jc(e,t,r,n){let s=e.database||e,i=Da.openDBI(s,r);i[mm.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Da.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Jc,"setupTransaction");function A0(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(S0)){if(!s)if(r)s=Da.openDBI(e,r);else{let l=Da.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=Da.openDBI(e,l[u]),!s[mm.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(A0,"getOverflowCheck");function c9(e,t,r,n=!1,s=void 0,i=void 0){if(Jn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);return Jc(e,t,t,(o,c,l)=>(Sm(r),r=b_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>o9(u.value,r))))}a(c9,"searchAll");function l9(e,t,r,n=!1,s=void 0,i=void 0){if(Jn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);Sm(r),r=b_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of T0(e,t,t,n,s,i))o.set(c,gm.parseRow(l,r));return o}a(l9,"searchAllToMap");function u9(e,t,r=!1,n=void 0,s=void 0){if(Jn.validateEnv(e),t===void 0)throw new Error(Yt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=T0(e,void 0,t,r,n,s),c=o.transaction,l=A0(c.database,c,void 0,t);for(let{key:u,value:f}of o){let d=l(u,f);i[d]===void 0&&(i[d]=[]),i[d].push(f)}return i}a(u9,"iterateDBI");function d9(e,t){if(Jn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);return Da.statDBI(e,t).entryCount}a(d9,"countAll");function f9(e,t,r,n,s=!1,i=void 0,o=void 0){return La(e,r,n),Jc(e,t,r,(c,l,u,f)=>(n=Jn.convertKeyValueToWrite(n),f===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(f9,"equals");function _9(e,t,r){return La(e,t,r),Da.openDBI(e,t).getValuesCount(r)}a(_9,"count");function h9(e,t,r,n,s=!1,i=void 0,o=void 0){return La(e,r,n),Jc(e,null,r,(c,l)=>{n=Jn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let h of l.getKeys({transaction:c,start:n}))if(!h.startsWith(n)){d=h;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),f=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(h=>{let{key:_}=h;if(_!==d){if(_.toString().startsWith(n))return h;if(u===!0)return f.DONE}}),f.filter(h=>h)}else return f=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(u===!0)return f.DONE}),u?f:f.filter(d=>d)})}a(h9,"startsWith");function p9(e,t,r,n,s=!1,i=void 0,o=void 0){return R0(e,t,r,n,s,i,o,!0)}a(p9,"endsWith");function R0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return La(e,r,n),Jc(e,null,r,(l,u,f,d)=>{let h=A0(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(_=>{let p=_.toString();return p.endsWith(S0)?u.getValues(_,{transaction:l}).map(S=>{let g=h(_,S);if(c?g.endsWith(n):g.includes(n))return{key:g,value:S}}).filter(S=>S):(c?p.endsWith(n):p.includes(n))?u[mm.DBI_DEFINITION_NAME].is_hash_attribute?{key:_,value:_}:u.getValues(_,{transaction:l}).map(S=>({key:_,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(R0,"contains");function E9(e,t,r,n,s=!1,i=void 0,o=void 0){La(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),y_(e,t,r,n,l,s,i,o,!0,!1)}a(E9,"greaterThan");function m9(e,t,r,n,s=!1,i=void 0,o=void 0){La(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),y_(e,t,r,n,l,s,i,o,!1,!1)}a(m9,"greaterThanEqual");function g9(e,t,r,n,s=!1,i=void 0,o=void 0){La(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),y_(e,t,r,l,n,s,i,o,!1,!0)}a(g9,"lessThan");function S9(e,t,r,n,s=!1,i=void 0,o=void 0){La(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),y_(e,t,r,l,n,s,i,o,!1,!1)}a(S9,"lessThanEqual");function T9(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Jn.validateEnv(e),r===void 0)throw new Error(Yt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Yt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Yt.END_VALUE_REQUIRED);if(n=Jn.convertKeyValueToWrite(n),s=Jn.convertKeyValueToWrite(s),n>s)throw new Error(Yt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return y_(e,t,r,n,s,i,o,c)}a(T9,"between");function A9(e,t,r,n){Jn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);if(Sm(r),r=b_(s,r),n===void 0)throw new Error(Yt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=gm.parseRow(c,r)),o}a(A9,"searchByHash");function R9(e,t,r){Jn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Yt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(R9,"checkHashExists");function y9(e,t,r,n,s=[]){return b0(e,t,r,n,s),y0(e,t,r,n,s).map(i=>i[1])}a(y9,"batchSearchByHash");function b9(e,t,r,n,s=[]){b0(e,t,r,n,s);let i=new Map;for(let[o,c]of y0(e,t,r,n,s))i.set(o,c);return i}a(b9,"batchSearchByHashToMap");function y0(e,t,r,n,s=[]){return Jc(e,t,t,(i,o,c)=>{r=b_(c,r);let l=r.length<3;return n.map(u=>{let f=c.dbis[t].get(u,{transaction:i,lazy:l});if(f)return[u,gm.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(y0,"batchHashSearch");function b0(e,t,r,n,s){if(Jn.validateEnv(e),t===void 0)throw new Error(Yt.HASH_ATTRIBUTE_REQUIRED);if(Sm(r),n==null)throw new Error(Yt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Yt.IDS_MUST_BE_ITERABLE)}a(b0,"initializeBatchSearchByHash");function Sm(e){if(!Array.isArray(e))throw e===void 0?new Error(Yt.FETCH_ATTRIBUTES_REQUIRED):new Error(Yt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(Sm,"validateFetchAttributes");function La(e,t,r){if(Jn.validateEnv(e),t===void 0)throw new Error(Yt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Yt.SEARCH_VALUE_REQUIRED);if(r?.length>a9)throw new Error(Yt.SEARCH_VALUE_TOO_LARGE)}a(La,"validateComparisonFunctions");function b_(e,t){return t.length===1&&i9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Da.listDBIs(e)),t}a(b_,"setGetWholeRowAttributes");O0.exports={searchAll:c9,searchAllToMap:l9,count:_9,countAll:d9,equals:f9,startsWith:h9,endsWith:p9,contains:R0,searchByHash:A9,setGetWholeRowAttributes:b_,batchSearchByHash:y9,batchSearchByHashToMap:b9,checkHashExists:R9,iterateDBI:u9,greaterThan:E9,greaterThanEqual:m9,lessThan:g9,lessThanEqual:S9,between:T9}});var Lu=C((Swe,P0)=>{var N0=require("lodash"),w0=pt(),ke=require("joi"),O9=ae(),{hdb_schema_table:O_,checkValidTable:I0,hdb_table:C0,hdb_database:Tm}=vi(),{handleHDBError:N9,hdb_errors:w9}=_e(),{getDatabases:I9}=(Ce(),D(tt)),{HTTP_STATUS_CODES:C9}=w9,P9=ke.object({database:Tm,schema:Tm,table:C0,search_attribute:O_,search_value:ke.any().required(),get_attributes:ke.array().min(1).items(ke.alternatives(O_,ke.object())).optional(),desc:ke.bool(),limit:ke.number().integer().min(1),offset:ke.number().integer().min(0)}),D9=ke.object({database:Tm,schema:Tm,table:C0,operator:ke.string().valid("and","or").default("and").lowercase(),offset:ke.number().integer().min(0),limit:ke.number().integer().min(1),get_attributes:ke.array().min(1).items(ke.alternatives(O_,ke.object())).optional(),sort:ke.object({attribute:ke.alternatives(O_,ke.array().min(1)),descending:ke.bool().optional()}).optional(),conditions:ke.array().min(1).items(ke.alternatives(ke.object({operator:ke.string().valid("and","or").default("and").lowercase(),conditions:ke.array()}),ke.object({search_attribute:ke.alternatives(O_,ke.array().min(1)),search_type:ke.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:ke.when("search_type",{switch:[{is:"equals",then:ke.any()},{is:"between",then:ke.array().items(ke.alternatives([ke.string(),ke.number()])).length(2)}],otherwise:ke.alternatives(ke.string(),ke.number())}).required()}))).required()});P0.exports=function(e,t){let r=null;switch(t){case"value":r=w0.validateBySchema(e,P9);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(I0("database",e.schema)),i(I0("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(o=>typeof o=="string"||typeof o=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=w0.validateBySchema(e,D9);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=O9.checkGlobalSchemaTable(e.schema,e.table);if(s)return N9(new Error,s,C9.NOT_FOUND);let o=I9()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(f=>{for(let d=0,h=f.conditions.length;d<h;d++){let _=f.conditions[d];_.conditions?l(_):c.push(_.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=N0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!N0.some(o,d=>d===f||d.attribute===f||d.attribute===f.attribute));if(u&&u.length>0){let f=u.join(", ");return f=f.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${f}'`)}}return r}});var Zy=C((Awe,D0)=>{"use strict";var L9=ct(),M9=Lu(),{getSchemaPath:v9}=ht();D0.exports=U9;function U9(e){let t=M9(e,"hashes");if(t)throw t;let r=v9(e.schema,e.table);return L9.openEnvironment(r,e.table)}a(U9,"initialize")});var eb=C((ywe,L0)=>{"use strict";var x9=Du(),B9=Zy();L0.exports=H9;async function H9(e){let t=await B9(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return x9.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(H9,"lmdbGetDataByHash")});var Mu=C((Owe,M0)=>{"use strict";var tb=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};M0.exports=tb});var U0=C((Iwe,v0)=>{"use strict";var wwe=Mu(),k9=Du(),F9=Zy();v0.exports=q9;async function q9(e){let t=await F9(e),r=global.hdb_schema[e.schema][e.table];return k9.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(q9,"lmdbSearchByHash")});var ai=C((Pwe,x0)=>{"use strict";var rb=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,f=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=f}};x0.exports=rb});var Am=C((Lwe,G0)=>{"use strict";var Jr=Du(),G9=ct(),$9=ae(),Fe=Mt(),Xc=(v(),D(q)),V9=Ao(),B0=Fn().LMDB_ERRORS_ENUM,{getSchemaPath:K9}=ht(),Io=Xc.SEARCH_WILDCARDS;async function Y9(e,t,r){let n;e.schema===Xc.SYSTEM_SCHEMA_NAME?n=V9[e.table]:n=global.hdb_schema[e.schema][e.table];let s=q0(e,n.hash_attribute,r,t);return k0(e,s,n.hash_attribute,r)}a(Y9,"prepSearch");async function k0(e,t,r,n){let s=K9(e.schema,e.table),i=await G9.openEnvironment(s,e.table),o=F0(i,e,t,r),c=o.transaction||i;if([Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Fe.SEARCH_TYPES.SEARCH_ALL,Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(W9(e,r)===!1){let f=e.search_attribute;if(f===r)return n?H0(o,()=>!0):o.map(h=>({[r]:h.key}));let d=a(h=>({[r]:h.value,[f]:h.key}),"toObject");return n?H0(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?Jr.batchSearchByHashToMap(c,r,e.get_attributes,u):Jr.batchSearchByHash(c,r,e.get_attributes,u)}a(k0,"executeSearch");function F0(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case Fe.SEARCH_TYPES.EQUALS:s=Jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.CONTAINS:s=Jr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.ENDS_WITH:case Fe.SEARCH_TYPES._ENDS_WITH:s=Jr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.STARTS_WITH:case Fe.SEARCH_TYPES._STARTS_WITH:s=Jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.SEARCH_ALL:return Jr.searchAll(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.BETWEEN:s=Jr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN:case Fe.SEARCH_TYPES._GREATER_THAN:s=Jr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN_EQUAL:case Fe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Jr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN:case Fe.SEARCH_TYPES._LESS_THAN:s=Jr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN_EQUAL:case Fe.SEARCH_TYPES._LESS_THAN_EQUAL:s=Jr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(F0,"searchByType");function H0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(H0,"createMapFromIterable");function W9(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(W9,"checkToFetchMore");function q0(e,t,r,n){if($9.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),Io.indexOf(s)>-1)return r===!0?Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Fe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Io[0])<0&&s.indexOf(Io[1])<0)return c===!0?r===!0?Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Fe.SEARCH_TYPES.EQUALS;if(Io.indexOf(i)>=0&&Io.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Fe.SEARCH_TYPES.CONTAINS;if(Io.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Fe.SEARCH_TYPES.ENDS_WITH;if(Io.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Fe.SEARCH_TYPES.STARTS_WITH;if(s.includes(Io[0])||s.includes(Io[1]))return Fe.SEARCH_TYPES.EQUALS;throw new Error(B0.UNKNOWN_SEARCH_TYPE)}else switch(n){case Xc.VALUE_SEARCH_COMPARATORS.BETWEEN:return Fe.SEARCH_TYPES.BETWEEN;case Xc.VALUE_SEARCH_COMPARATORS.GREATER:return Fe.SEARCH_TYPES.GREATER_THAN;case Xc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Fe.SEARCH_TYPES.GREATER_THAN_EQUAL;case Xc.VALUE_SEARCH_COMPARATORS.LESS:return Fe.SEARCH_TYPES.LESS_THAN;case Xc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Fe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(B0.UNKNOWN_SEARCH_TYPE)}}a(q0,"createSearchTypeFromSearchObject");G0.exports={executeSearch:k0,createSearchTypeFromSearchObject:q0,prepSearch:Y9,searchByType:F0}});var V0=C((Uwe,$0)=>{"use strict";var vwe=ai(),z9=Lu(),j9=ae(),Q9=(v(),D(q)),J9=Am();$0.exports=X9;function X9(e,t){if(!j9.isEmpty(t)&&Q9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=z9(e,"value");if(n)throw n;return J9.prepSearch(e,t,!0)}a(X9,"lmdbGetDataByValue")});var N_=C((Hwe,K0)=>{"use strict";var Bwe=ai(),Z9=Lu(),e7=ae(),t7=(v(),D(q)),r7=Am();K0.exports=n7;async function n7(e,t){if(!e7.isEmpty(t)&&t7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=Z9(e,"value");if(n)throw n;return r7.prepSearch(e,t,!1)}a(n7,"lmdbSearchByValue")});var W0=C((qwe,Y0)=>{"use strict";var Fwe=Mt(),nb=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}},sb=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},ib=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};Y0.exports={SearchByConditionsObject:nb,SearchCondition:sb,SortAttribute:ib}});var X0=C((Kwe,J0)=>{"use strict";var $we=W0().SearchByConditionsObject,s7=ai(),i7=Lu(),ob=Du(),Rm=Mt(),{Resource:Vwe}=(Ra(),D(eR)),Q0=Am(),o7=Xy(),a7=require("lodash"),{getSchemaPath:c7}=ht(),z0=ct(),{handleHDBError:l7,hdb_errors:u7}=_e(),{HTTP_STATUS_CODES:d7}=u7,f7=1e8;J0.exports=_7;async function _7(e){let t=i7(e,"conditions");if(t)throw l7(t,t.message,d7.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=c7(e.schema,e.table),n=await z0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)z0.openDBI(n,u.search_attribute);let i=a7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===Rm.SEARCH_TYPES.EQUALS?u.estimated_count=ob.count(n,u.search_attribute,u.search_value):f===Rm.SEARCH_TYPES.CONTAINS||f===Rm.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=f7}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await j0(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],f=i.slice(1).map(Q0.filterByType),d=f.length,h=ob.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(_=>u.get(_,{transaction:o,lazy:!0})),d>0&&(l=l.filter(_=>{for(let p=0;p<d;p++)if(!f[p](_))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(_=>o7.parseRow(_,h))}else{for(let d=1;d<i.length;d++){let h=i[d],_=await j0(o,e,h,s.hash_attribute);c=c.concat(_)}let u=new Set,f=e.offset||0;c=c.filter(d=>u.has(d)?!1:(u.add(d),!0)).slice(f,e.limit&&e.limit+f),l=ob.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(_7,"lmdbSearchByConditions");async function j0(e,t,r,n){let s=new s7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===Rm.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Q0.searchByType(e,s,i,n).map(o=>o.value)}a(j0,"executeConditionSearch")});var w_=C((Wwe,Z0)=>{"use strict";var h7=(v(),D(q)).OPERATIONS_ENUM,ab=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=h7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Z0.exports=ab});var cb=C((jwe,ax)=>{"use strict";var nx=ai(),sx=w_(),ix=N_(),ox=R_(),yn=(v(),D(q)),ex=ae(),tx=ct(),{getTransactionAuditStorePath:p7,getSchemaPath:E7}=ht(),rx=W();ax.exports=m7;async function m7(e){try{if(ex.isEmpty(global.hdb_schema[e.schema])||ex.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await g7(e),await S7(e);let t=E7(e.schema,e.table);try{await tx.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")rx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=p7(e.schema,e.table);await tx.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")rx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(m7,"lmdbDropTable");async function g7(e){let t=new nx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await ix(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 sx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await ox(s)}a(g7,"deleteAttributesFromSystem");async function S7(e){let t=new nx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await ix(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 sx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await ox(s)}catch(i){throw i}}a(S7,"dropTableFromSystem")});var lx=C((Jwe,cx)=>{"use strict";var T7=require("fs-extra"),A7=ai(),R7=Mu(),y7=w_(),b7=cb(),O7=R_(),N7=eb(),w7=N_(),Co=(v(),D(q)),{getSchemaPath:I7}=ht(),{handleHDBError:C7,hdb_errors:P7}=_e(),{HDB_ERROR_MSGS:D7,HTTP_STATUS_CODES:L7}=P7;cx.exports=M7;async function M7(e){let t;try{t=await v7(e.schema);let r=new A7(Co.SYSTEM_SCHEMA_NAME,Co.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Co.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Co.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await w7(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await b7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new y7(Co.SYSTEM_SCHEMA_NAME,Co.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await O7(s);let i=I7(t);await T7.remove(i)}catch(r){throw r}}a(M7,"lmdbDropSchema");async function v7(e){let t=new R7(Co.SYSTEM_SCHEMA_NAME,Co.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Co.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await N7(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw C7(new Error,D7.SCHEMA_NOT_FOUND(e),L7.NOT_FOUND,void 0,void 0,!0);return n}a(v7,"validateDropSchema")});var I_=C((Zwe,ux)=>{"use strict";var lb=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};ux.exports=lb});var db=C((rIe,dx)=>{"use strict";var U7=require("fs-extra"),ym=ct(),{getTransactionAuditStorePath:x7}=ht(),ub=Mt(),tIe=I_();dx.exports=B7;async function B7(e){let t;try{let r=x7(e.schema,e.table);await U7.mkdirp(r),t=await ym.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{ym.createDBI(t,ub.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),ym.createDBI(t,ub.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),ym.createDBI(t,ub.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(B7,"createTransactionsAuditEnvironment")});var hx=C((iIe,_x)=>{"use strict";var fb=(v(),D(q)),fx=ct(),H7=kc(),{getSystemSchemaPath:k7,getSchemaPath:F7}=ht(),sIe=Ao(),q7=QE(),_b=jE(),G7=W(),$7=db();_x.exports=V7;async function V7(e,t){let r=F7(t.schema,t.table),n=new _b(t.schema,t.table,fb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new _b(t.schema,t.table,fb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new _b(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await fx.createEnvironment(r,t.table),e!==void 0){let o=await fx.openEnvironment(k7(),fb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await H7.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 hb(n),await hb(s),await hb(i)}await $7(t)}catch(o){throw o}}a(V7,"lmdbCreateTable");async function hb(e){try{await q7(e)}catch(t){G7.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(hb,"createAttribute")});var Ex=C((aIe,px)=>{"use strict";var K7=s_(),Y7=Df(),W7=pm(),C_=(v(),D(q)),z7=kc().updateRecords,j7=ct(),{getSchemaPath:Q7}=ht(),J7=T_(),X7=W();px.exports=Z7;async function Z7(e){try{let{schema_table:t,attributes:r}=K7(e);Y7(e,r,t.hash_attribute),e.schema!==C_.SYSTEM_SCHEMA_NAME&&(r.includes(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await W7(e.hdb_auth_header,t,r),s=Q7(e.schema,e.table),i=await j7.openEnvironment(s,e.table),o=await z7(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await J7(e,o)}catch(c){X7.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(Z7,"lmdbUpdateRecords")});var gx=C((lIe,mx)=>{"use strict";var eee=(v(),D(q)).OPERATIONS_ENUM,pb=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=eee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};mx.exports=pb});var Tx=C((fIe,Sx)=>{"use strict";var dIe=gx(),tee=s_(),ree=Df(),nee=pm(),P_=(v(),D(q)),see=kc().upsertRecords,iee=ct(),{getSchemaPath:oee}=ht(),aee=T_(),cee=W(),{handleHDBError:lee,hdb_errors:uee}=_e();Sx.exports=dee;async function dee(e){let t;try{t=tee(e)}catch(l){throw lee(l,l.message,uee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;ree(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 nee(e.hdb_auth_header,r,n),i=oee(e.schema,e.table),o=await iee.openEnvironment(i,e.table),c=await see(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await aee(e,c)}catch(l){cee.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(dee,"lmdbUpsertRecords")});var Rx=C((hIe,Ax)=>{"use strict";var Eb=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};Ax.exports=Eb});var bx=C((EIe,yx)=>{"use strict";var mb=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}};yx.exports=mb});var wx=C((SIe,Nx)=>{"use strict";var gb=ct(),{getTransactionAuditStorePath:fee}=ht(),gIe=Rx(),D_=Mt(),_ee=ae(),Ox=bx(),hee=require("util").promisify,pee=hee(setTimeout),Eee=1e4,mee=100;Nx.exports=gee;async function gee(e){let t=fee(e.schema,e.table),r=await gb.openEnvironment(t,e.table,!0),n=gb.listDBIs(r);gb.initializeDBIs(r,D_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Ox;do s=await See(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 pee(mee);while(s.transactions_deleted>0);return i}a(gee,"deleteAuditLogsBefore");async function See(e,t){let r=new Ox;try{let n=e.dbis[D_.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[D_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];_ee.isEmpty(c)||(s=e.dbis[D_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[D_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Eee)break}return await s,r}catch(n){throw n}}a(See,"deleteTransactions")});var Cx=C((AIe,Ix)=>{"use strict";var Sb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};Ix.exports=Sb});var Dx=C((bIe,Px)=>{"use strict";var Tee=ai(),Aee=w_(),yIe=Cx(),qi=(v(),D(q)),Ree=ae(),Tb=ct(),yee=Ao(),bee=N_(),Oee=R_(),{getSchemaPath:Nee}=ht();Px.exports=wee;async function wee(e,t=!0){let r;e.schema===qi.SYSTEM_SCHEMA_NAME?r=yee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await Cee(e),s=Nee(e.schema,e.table),i=await Tb.openEnvironment(s,e.table);return t===!0&&await Iee(e,i,r.hash_attribute),Tb.dropDBI(i,e.attribute),n}a(wee,"lmdbDropAttribute");async function Iee(e,t,r){let n=Tb.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let f in c)f!==i&&(u[f]=c[f]);s=t.dbis[r].put(o,u,l)}await s}a(Iee,"removeAttributeFromAllObjects");async function Cee(e){let t=new Tee(qi.SYSTEM_SCHEMA_NAME,qi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,qi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[qi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,qi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await bee(t)).filter(o=>o[qi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Ree.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[qi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Aee(qi.SYSTEM_SCHEMA_NAME,qi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Oee(i)}a(Cee,"dropAttributeFromSystem")});var Bx=C((wIe,xx)=>{"use strict";var Ab=ct(),vu=Mt(),NIe=_n(),Rb=(v(),D(q)),Lx=ae(),{getTransactionAuditStorePath:Pee}=ht(),Dee=Du(),bm=Iu(),Lee=W();xx.exports=Mee;async function Mee(e){let t=Pee(e.schema,e.table),r=await Ab.openEnvironment(t,e.table,!0),n=Ab.listDBIs(r);Ab.initializeDBIs(r,vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Rb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Mx(r,e.search_values);case Rb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,Uee(r,e.search_values,s);case Rb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return vee(r,e.search_values);default:return Mx(r)}}a(Mee,"readAuditLog");function Mx(e,t=[0,Date.now()]){Lx.isEmpty(t[0])&&(t[0]=0),Lx.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[vu.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 bm,s))}a(Mx,"searchTransactionsByTimestamp");function vee(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[vu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,Ux(e,i))}return Object.fromEntries(r)}a(vee,"searchTransactionsByUsername");function Uee(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=Dee.equals(e,vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,vu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let h=Number(d);n.has(h)?n.get(h).push(u.toString()):n.set(h,[u.toString()])}}let s=Array.from(n.keys()),i=Ux(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);vx(l,"records",r,f,o),vx(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(Uee,"searchTransactionsByHashValues");function vx(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),f=u[u.length-1];if(f.timestamp===i)f[t]=[c];else{let d=new bm(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new bm(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(vx,"loopRecords");function Ux(e,t){let r=[];try{let n=e.dbis[vu.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 bm,i);r.push(o)}}catch(i){Lee.warn(i)}return r}catch(n){throw n}}a(Ux,"batchSearchTransactions")});var kx=C((DIe,Hx)=>{"use strict";var{getSchemaPath:CIe}=ht(),PIe=ct(),{database:xee}=(Ce(),D(tt));Hx.exports={writeTransaction:Bee};async function Bee(e,t,r){return xee({database:e,table:t}).transaction(r)}a(Bee,"writeTransaction")});var $x=C((MIe,Gx)=>{"use strict";var{getSchemaPath:Fx}=ht(),qx=ct();Gx.exports={flush:Hee,resetReadTxn:kee};async function Hee(e,t){return(await qx.openEnvironment(Fx(e,t),t.toString())).flushed}a(Hee,"flush");async function kee(e,t){try{(await qx.openEnvironment(Fx(e,t),t.toString())).resetReadTxn()}catch{}}a(kee,"resetReadTxn")});var Wx=C((UIe,Yx)=>{"use strict";var{Readable:Fee}=require("stream"),{getDatabases:qee}=(Ce(),D(tt)),{readSync:Gee,openSync:$ee,createReadStream:Vx}=require("fs"),{open:Vee}=require("lmdb"),Kx=Jf(),Kee=Xf(),{AUDIT_STORE_OPTIONS:Yee}=(So(),D(zx)),{INTERNAL_DBIS_NAME:Wee,AUDIT_STORE_NAME:zee}=Mt();Yx.exports=Qee;var yb=32768,jee=100;async function Qee(e){let t=e.database||e.schema||"data",r=qee()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let f=u.dbisDB,d=Vee({noSync:!0,maxDbs:Kee.MAX_DBS}),h,_=d.openDB(Wee,new Kx(!1)),p=f.useReadTransaction(),S=0,g=a(async function(m,A){A.encoding="binary",A.encoder=void 0;let w=d.openDB(m,A),M=f.openDB(m,A);for(let{key:F,version:G,value:K}of M.getRange({start:null,transaction:p,versions:M.useVersions}))h=w.put(F,K,G),S++%jee===0&&(await new Promise(ee=>setTimeout(ee,20)),p.openTimer&&(p.openTimer=0))},"copyDatabase");for(let{key:m,value:A}of f.getRange({transaction:p,start:!1}))if(s.some(w=>m.startsWith?.(w+"/"))){_.put(m,A);let[,w]=m.split("/"),M=!w,F=new Kx(!M,M);await g(m,F)}e.include_audit&&await g(zee,{...Yee}),await h;let T=Vx(d.path);return T.headers=l(),T.on("close",()=>{p.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=$ee(o.path);return o.transaction(()=>{let u=Buffer.alloc(yb);Gee(c,u,0,yb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=Vx(null,{fd:c,start:yb}),h=new Fee.from(async function*(){yield u;for await(let _ of d)f.openTimer&&(f.openTimer=0),yield _;f.done()}());return h.headers=l(),h});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(Qee,"getBackup")});var Jx=C((BIe,Qx)=>{"use strict";var Jee=W(),{handleHDBError:Xee}=_e(),Zee=oM(),ete=QE(),tte=Wy(),rte=l0(),nte=R_(),ste=eb(),ite=U0(),ote=V0(),ate=N_(),cte=X0(),lte=lx(),ute=hx(),dte=Ex(),fte=Tx(),_te=wx(),hte=cb(),pte=Dx(),Ete=Bx(),mte=kx(),jx=$x(),gte=Wx(),bb=class extends Zee{static{a(this,"LMDBBridge")}async searchByConditions(t){return cte(t)}async getDataByHash(t){return await ste(t)}async searchByHash(t){return await ite(t)}async getDataByValue(t,r){return await ote(t,r)}async searchByValue(t){return await ate(t)}async createSchema(t){return await rte(t)}async dropSchema(t){return await lte(t)}async createTable(t,r){return await ute(t,r)}async dropTable(t){return await hte(t)}async createAttribute(t){return await ete(t)}async createRecords(t){return await tte(t)}async updateRecords(t){return await dte(t)}async upsertRecords(t){try{return await fte(t)}catch(r){throw Xee(r,null,null,Jee.ERR,r)}}async deleteRecords(t){return await nte(t)}async dropAttribute(t){return await pte(t)}async deleteAuditLogsBefore(t){return await _te(t)}async readAuditLog(t){return await Ete(t)}writeTransaction(t,r,n){return mte.writeTransaction(t,r,n)}flush(t,r){return jx.flush(t,r)}resetReadTxn(t,r){return jx.resetReadTxn(t,r)}getBackup(t){return gte(t)}};Qx.exports=bb});var Nb={};Be(Nb,{add:()=>Om,applyReverse:()=>Xx,getRecordAtTime:()=>Ob,rebuildUpdateBefore:()=>Nm});function Om(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 Nm(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,Om(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function Xx(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Ste[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=Zx}}function Ob(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=Nt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":Xx(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===Zx&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=Nt(l),f;switch(u.type){case"put":f=u.getValue(r);break;case"patch":f=u.getValue(r);break}for(let d in f)o[d]&&(s[d]=f[d],o[d]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var Ste,Zx,wm=be(()=>{So();a(Om,"add");Om.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)};Ste={add:Om};a(Nm,"rebuildUpdateBefore");a(Xx,"applyReverse");Zx={};a(Ob,"getRecordAtTime")});function bn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function Dm(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a string, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(h=>typeof h=="string")||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a string, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let h=d?.__op__?d.value:d;if(!(typeof h=="number"||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a number, attempt to assign ${h}`);bn(this)[l]=d},"set");break;case"Int":u=a(function(d){let h=d?.__op__?d.value:d;if(!(h>>0===h||d==null&&c.nullable!==!1))if(typeof h=="number"&&Math.abs((h>>0)-h)<=1)h=Math.round(h),d?.__op__?d.value=h:d=h;else throw new Xn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Long":u=a(function(d){let h=d?.__op__?d.value:d;if(!(Math.round(h)===d&&Math.abs(h)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof h=="number"&&Math.abs(h)<=9007199254740992)h=Math.round(h),d?.__op__?d.value=h:d=h;else throw new Xn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let h=d?.__op__?d.value:d;if(!(typeof h=="bigint"||d==null&&c.nullable!==!1))if(typeof h=="string"||typeof h=="number")h=BigInt(h),d?.__op__?d.value=h:d=h;else throw new Xn.ClientError(`${l} must be a number, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new Xn.ClientError(`${l} must be a Date, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Pi||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){bn(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be an object, attempt to assign ${d}`);bn(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let _=d[l];if(_?.__op__){let p=this.getRecord()?.[l];return _.update(p)}return _}let h=this.getRecord()?.[l];if(h&&typeof h=="object"){let _=wb(h,c);if(_)return d||this._setChanges(d=Object.create(null)),d[l]=_}return h},set:u,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,n[l]=f,(!(l in r)||Object.getOwnPropertyDescriptor(r,l)?.get?.isAttribute)&&Object.defineProperty(r,l,f)}i("getProperty",function(c){let l=n[c];if(l)return l.get.call(this);let u=this.getChanges();return u?.[c]!==void 0?u[c]:this.getRecord()?.[c]}),i("set",function(c,l){let u=n[c];if(u)return u.set.call(this,l);if(t.sealed)throw new Xn.ClientError("Can not add a property to a sealed table schema");bn(this)[c]=l}),i("deleteProperty",function(c){bn(this)[c]=void 0}),i("toJSON",function(){let c=this.getChanges?.(),l;for(let f in c){l||(l={...this.getRecord()});let d=c[f];if(d?.__op__){let h=l[f];d=d.update(h)}l[f]=d}return Object.keys(this).length>0&&(l||(l={...this.getRecord()}),Object.assign(l,this)),l||this.getRecord()}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty),r.then||i("then",null);function i(c,l){Object.defineProperty(r,c,{value:l,configurable:!0})}a(i,"setMethod");let o=r;do{let c=Object.getPrototypeOf(o);if(c===Object.prototype){Object.setPrototypeOf(o,tB);break}o=c}while(o&&o!==tB)}function wb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends L_{static{a(this,"TrackedObject")}},Dm(r,t)),new r(e)):new L_(e);case Array:let n=new Cm(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=wb(o,t?.elements)),n[s]=o}return n;default:return e}}function Lm(e){let t=e.getChanges?.(),r;for(let s in t){r||(r=e.getRecord?{...e.getRecord()}:{});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=Lm(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=e.getRecord?{...e.getRecord()}:{}),Object.assign(r,e)),r||e.getRecord?.()||e}function el(e,t=e.getChanges?.()){let r;if(e.getRecord&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=el(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?.()});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=Nb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=el(s);r[n]=s}if(!Array.isArray(e))for(let n in e)Tte.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function Im(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Zc]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(Im(i))return!0}else return!0}}else{let r=e.getChanges?.();if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s.getRecord?.()===i){if(Im(s))return!0}else return!0}else return!0}}return!1}var Xn,eB,tB,L_,Tte,Zc,Cm,Pm,Ib=be(()=>{Xn=x(_e());wm();Ts();a(bn,"getChanges");a(Dm,"assignTrackedAccessors");eB=Object.prototype,tB=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(eB[t])return eB[t];let n=r.getChanges?.();if(n&&t in n)return n[t];let s=r.getRecord?.()[t];if(s&&typeof s=="object"){let i=wb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(wb,"trackObject");L_=class{static{a(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};Dm(L_,{});a(Lm,"collapseData");Tte=Object.prototype.hasOwnProperty;a(el,"updateAndFreeze");a(Im,"hasChanges");Zc=Symbol.for("has-array-changes"),Cm=class extends Array{static{a(this,"TrackedArray")}#e;[Zc];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[Zc]=!0,super.splice(...t)}push(...t){return this[Zc]=!0,super.push(...t)}pop(){return this[Zc]=!0,super.pop()}unshift(...t){return this[Zc]=!0,super.unshift(...t)}shift(){return this[Zc]=!0,super.shift()}};Cm.prototype.constructor=Array;Pm=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var lB={};Be(lB,{ResourceBridge:()=>Db});function Lb({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 nB(e,t){let r=Gi(e),n=Lb(e,r);if(!r)throw new ci.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Ot(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],f;try{f=await r.get({id:u,lazy:s,select:n},i),f=f&&Lm(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function Gi(e){let t=e.database||e.schema||Rte,r=Je()[t];if(!r)throw(0,ci.handleHDBError)(new Error,Ate.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function sB(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*iB(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var oB,Mm,ci,aB,Cb,Pb,cB,Ate,Rte,yte,bte,rB,Db,uB=be(()=>{"use strict";oB=x(Jx()),Mm=x(Lu()),ci=x(_e());Ce();aB=x(s_());v();Cb=x(wo()),Pb=x(oi()),cB=x(ae());Oc();Ib();({HDB_ERROR_MSGS:Ate}=ci.hdb_errors),Rte="data",yte=1e4,bte=10,Db=class extends oB.default{static{a(this,"ResourceBridge")}constructor(t){super(t),rB=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,Mm.default)(t,"conditions");if(r)throw(0,ci.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Gi(t);if(!n)throw new ci.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:Lb(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new ci.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}]}at({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Gi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Gi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Gi(t).dropTable()}createSchema(t){return Uu({database:t.schema,table:null}),Cb.signalSchemaChange(new Pb.SchemaEventMsg(process.pid,Vt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Mb(t.schema),Cb.signalSchemaChange(new Pb.SchemaEventMsg(process.pid,Vt.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,rB.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,aB.default)(t),s,i=Je()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Ot(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(h=>h.name==f)||s.push(f);s.length>0&&await i.addAttributes(s.map(f=>({name:f,indexed:!0})))}let l=[],u=[];for(let f of t.records){let d=f[i.primaryKey],h=d!=null&&await i.get(d,o);if(t.requires_existing&&!h||t.requires_no_existing&&h){u.push(f[i.primaryKey]);continue}h&&(h=Lm(h));for(let _ in f)if(Object.prototype.hasOwnProperty.call(f,_)){let p=f[_];if(typeof p=="function")try{let S=p([[h]]);Array.isArray(S)&&(p=S[0].func_val,f[_]=p)}catch(S){throw S.message+="Trying to set key "+_+" on object"+JSON.stringify(f),S}}if(h)for(let _ in h)Object.prototype.hasOwnProperty.call(f,_)||(f[_]=h[_]);await(d==null?i.create(f,o):i.put(f,o)),l.push(f[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=Je()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Ot(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 sB(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Je()[t.schema][t.table];if(!r.createdTimeProperty)throw new ci.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:Qp.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let f=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...f.deleted_hashes),o.push(...f.skipped_hashes),await(0,cB.async_set_timeout)(bte),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%yte===0&&await u();return l.length>0&&await u(),s?sB(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,Mm.default)(t,"hashes");if(r)throw r;return nB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of nB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&MA[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,Mm.default)(t,"value");if(n)throw n;let s=Gi(t);if(!s)throw new ci.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===Qp.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:Lb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Gi(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){Gi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Gi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Gi(t),n={};switch(t.search_type){case Jp.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 Jp.USERNAME:let s=t.search_values;for await(let i of iB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return iB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(Lb,"getSelect");a(nB,"getRecords");a(Gi,"getTable");a(sB,"createDeleteResponse");a(iB,"groupRecordsInHistory")});var Wn=C((QIe,dB)=>{"use strict";var{ResourceBridge:Ote}=(uB(),D(lB)),Nte=ce();Nte.initSync();var vm;function wte(){return vm||(vm=new Ote,vm)}a(wte,"getBridge");dB.exports=wte()});var Rn=C((XIe,pB)=>{"use strict";var xm=yR(),vr=ae(),Ite=require("util"),Bm=Wn(),Cte=ys(),fB=W(),{handleHDBError:tl,hdb_errors:Pte}=_e(),{HTTP_STATUS_CODES:rl}=Pte,Dte=Ite.promisify(Cte.getTableSchema),Lte="updated",_B="inserted",hB="upserted";pB.exports={insert:vte,update:Ute,upsert:xte,validation:Mte,flush:Bte};async function Mte(e){if(vr.isEmpty(e))throw new Error("invalid update parameters defined.");if(vr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(vr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await Dte(e.schema,e.table),r=xm(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&&vr.isEmptyOrZeroLength(c[n]))throw fB.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(!vr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw fB.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!vr.isEmpty(c[n])&&c[n]!==""&&s.has(vr.autoCast(c[n]))&&(c.skip=!0),s.add(vr.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(Mte,"validation");async function vte(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=xm(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);vr.transformReq(e);let r=vr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await Bm.createRecords(e);return Um(_B,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(vte,"insertData");async function Ute(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=xm(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);vr.transformReq(e);let r=vr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await Bm.updateRecords(e);return vr.isEmpty(n.existing_rows)?Um(Lte,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Um(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(Ute,"updateData");async function xte(e){if(e.operation!=="upsert")throw tl(new Error,"invalid operation, must be upsert",rl.INTERNAL_SERVER_ERROR);let t=xm(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);vr.transformReq(e);let r=vr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await Bm.upsertRecords(e);return Um(hB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(xte,"upsertData");function Um(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===_B?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===hB?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Um,"returnObject");function Bte(e){return vr.transformReq(e),Bm.flush(e.schema,e.table)}a(Bte,"flush")});var AB=C((eCe,TB)=>{var xu=require("validate.js"),mB=pt(),Bu=(v(),D(q)),{handleHDBError:Hte,hdb_errors:kte}=_e(),{HDB_ERROR_MSGS:Wt,HTTP_STATUS_CODES:Fte}=kte,vb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),qte={STRUCTURE_USER:"structure_user"},EB=Object.values(Bu.ROLE_TYPES_ENUM),Gte="attribute_permissions",$te="attribute_name",{PERMS_CRUD_ENUM:Hu}=Bu,Vte=[Gte,...Object.values(Hu)],gB=[Hu.READ,Hu.INSERT,Hu.UPDATE],Kte=[$te,...gB];function Yte(e){let t=vb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,SB(e,t)}a(Yte,"addRoleValidation");function Wte(e){let t=vb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,SB(e,t)}a(Wte,"alterRoleValidation");function zte(e){let t=vb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,mB.validateObject(e,t)}a(zte,"dropRoleValidation");var jte=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function SB(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)jte.includes(n[o])||s.push(n[o]);s.length>0&&ir(Wt.INVALID_ROLE_JSON_KEYS(s),r);let i=mB.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{ir(o,r)}),e.permission){let o=Qte(e);o&&ir(o,r),EB.forEach(c=>{e.permission[c]&&!xu.isBoolean(e.permission[c])&&ir(Wt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(EB.indexOf(o)<0){if(o===qte.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,f=l.length;u<f;u++){let d=l[u];global.hdb_schema[d]||ir(Wt.SCHEMA_NOT_FOUND(d),r)}continue}ir(Wt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){ir(Wt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){ir(Wt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{Vte.includes(f)||ir(Wt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Hu).forEach(f=>{xu.isDefined(u[f])?xu.isBoolean(u[f])||ir(Wt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):ir(Wt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){ir(Wt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){ir(Wt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:h})=>h),d={read:!1,insert:!1,update:!1};for(let h in u.attribute_permissions){let _=u.attribute_permissions[h];if(Object.keys(_).forEach(S=>{!Kte.includes(S)&&S!==Hu.DELETE&&ir(Wt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!xu.isDefined(_.attribute_name)){ir(Wt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let p=_.attribute_name;if(!f.includes(p)){ir(Wt.INVALID_ATTRIBUTE_IN_PERMS(p),r,o,l);continue}gB.forEach(S=>{xu.isDefined(_[S])?xu.isBoolean(_[S])||ir(Wt.ATTR_PERM_NOT_BOOLEAN(S,p),r,o,l):ir(Wt.ATTR_PERM_MISSING(S,p),r,o,l)}),!d.read&&_.read===!0&&(d.read=!0),!d.insert&&_.insert===!0&&(d.insert=!0),!d.update&&_.update===!0&&(d.update=!0)}if(u.read===!1&&d.read===!0||u.insert===!1&&d.insert===!0||u.update===!1&&d.update===!0){let h=`${o}.${l}`;ir(Wt.MISMATCHED_TABLE_ATTR_PERMS(h),r,o,l)}}}}return Jte(r)}a(SB,"customValidate");TB.exports={addRoleValidation:Yte,alterRoleValidation:Wte,dropRoleValidation:zte};function Qte(e){let{operation:t,permission:r}=e;if(t===Bu.OPERATIONS_ENUM.ADD_ROLE||t===Bu.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Wt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Bu.ROLE_TYPES_ENUM.SUPER_USER:Bu.ROLE_TYPES_ENUM.CLUSTER_USER;return Wt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Qte,"validateNoSUPerms");function Jte(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Wt.ROLE_PERMS_ERROR,...e};return Hte(new Error,n,Fte.BAD_REQUEST)}else return null}a(Jte,"generateRolePermResponse");function ir(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(ir,"addPermError")});var v_=C((nCe,OB)=>{"use strict";var RB=Rn(),yB=zr(),Xte=Vc(),xb=AB(),Bb=wo(),rCe=require("uuid").v4,Zte=require("util"),Hm=(v(),D(q)),ere=ae(),Hb=yB.searchByValue,tre=yB.searchByHash,rre=Zte.promisify(Xte.delete),nre=ai(),sre=Mu(),{hdb_errors:ire,handleHDBError:nl}=_e(),{HDB_ERROR_MSGS:bB,HTTP_STATUS_CODES:M_}=ire,{UserEventMsg:kb}=oi();OB.exports={addRole:ore,alterRole:are,dropRole:cre,listRoles:lre};function Ub(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(Ub,"scrubRoleDetails");async function ore(e){let t=xb.addRoleValidation(e);if(t)throw t;e=Ub(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 Hb(r)||[])}catch(i){throw nl(i)}if(n&&n.length>0)throw nl(new Error,bB.ROLE_ALREADY_EXISTS(e.role),M_.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 RB.insert(s),Bb.signalUserChange(new kb(process.pid)),e=Ub(e),e}a(ore,"addRole");async function are(e){let t=xb.alterRoleValidation(e);if(t)throw t;e=Ub(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await RB.update(r)}catch(s){throw nl(s)}if(n&&n?.message==="updated 0 of 1 records")throw nl(new Error,"Invalid role id",M_.BAD_REQUEST,void 0,void 0,!0);return await Bb.signalUserChange(new kb(process.pid)),e}a(are,"alterRole");async function cre(e){let t=xb.dropRoleValidation(e);if(t)throw nl(new Error,t,M_.BAD_REQUEST,void 0,void 0,!0);let r=new sre(Hm.SYSTEM_SCHEMA_NAME,Hm.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await tre(r));if(n.length===0)throw nl(new Error,bB.ROLE_NOT_FOUND,M_.NOT_FOUND,void 0,void 0,!0);let s=new nre(Hm.SYSTEM_SCHEMA_NAME,Hm.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await Hb(s)),o=!1;if(ere.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw nl(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,M_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await rre(c),Bb.signalUserChange(new kb(process.pid)),`${n[0].role} successfully deleted`}a(cre,"dropRole");async function lre(){return Hb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(lre,"listRoles")});var Fb={};Be(Fb,{start:()=>IB,startOnMainThread:()=>fre});function IB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,NB.parseDocument)(r.toString(),{simpleKeys:!0}).toJSON();for(let s in n){let i=n[s];i.permission||(i={permission:i},i.permission.access&&(i.access=i.permission.access,delete i.permission.access));for(let o in i.permission){if(ure.includes(o))continue;let c=i.permission[o];c.tables||(i.permission[o]=c={tables:c});for(let l in c.tables){let u=c.tables[l];if(u.read=!!u.read,u.insert=!!u.insert,u.update=!!u.update,u.delete=!!u.delete,u.attributes){let f=[];for(let d in u.attributes){let h=u.attributes[d];h.attribute_name=d,f.push(h)}u.attribute_permissions=f,delete u.attributes}if(u.attribute_permissions){if(!Array.isArray(u.attribute_permissions))throw new Error("attribute_permissions must be an array if defined");for(let f of u.attribute_permissions)f.read=!!f.read,f.insert=!!f.insert,f.update=!!f.update}else u.attribute_permissions=null}}i.role=i.id=s,await dre(i)}}}async function dre(e){let t=Je().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,wB.isEqual)(i,e)?void 0:(e.id=r.id,(0,km.alterRole)(e))}return(0,km.addRole)(e)}var km,NB,wB,ure,fre,CB=be(()=>{Ce();km=x(v_()),NB=require("yaml"),wB=require("lodash"),ure=["super_user","cluster_user","structure_user"];a(IB,"start");a(dre,"ensureRole");fre=IB});async function Fm(e){let t=(0,LB.pathToFileURL)(e).toString();return _re?(U_||(U_=hre(Ere)),(await(await U_).import(t)).namespace):import(t)}async function hre(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),U_=new Compartment({console,Math,Date,fetch:pre,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,DB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Kr,tables:Zn,databases:$e})}};let n=await(0,PB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),U_}function pre(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 Ere(){return{Resource:Kr,tables:Zn}}var PB,DB,LB,_re,U_,qb=be(()=>{Ra();Ce();PB=require("fs/promises"),DB=require("path"),LB=require("url"),_re=!1;a(Fm,"secureImport");a(hre,"getCompartment");a(pre,"secureOnlyFetch");a(Ere,"getGlobalVars")});var $b={};Be($b,{handleFile:()=>mre});async function mre(e,t,r,n){let s=new Map,i=await Fm(r);c(i.default)&&n.set((0,Gb.dirname)(t),i.default),o(i,(0,Gb.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var Gb,MB=be(()=>{qb();Gb=require("path");a(mre,"handleFile")});var Kb={};Be(Kb,{start:()=>gre});function gre({resources:e}){e.set("login",Vb),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Vb,vB=be(()=>{Ra();a(gre,"start");Vb=class extends Kr{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 q_={};Be(q_,{addAnalyticsListener:()=>F_,calculateCPUUtilization:()=>ZB,diffResourceUsage:()=>eH,recordAction:()=>or,recordActionBinary:()=>es,setAnalyticsEnabled:()=>Sre});function Sre(e){zB=e}function Tre(e,t){if(typeof e=="number"){let r=t.values,n=r.index++;if(n>=r.length){let s=r;t.values=r=new Float32Array(n*2),r.set(s),r.index=n+1}r[n]=e,t.total+=e}else if(typeof e=="boolean")e&&t.total++,t.count++;else if(typeof e=="function")t.count++;else throw new TypeError("Invalid metric value type "+typeof e)}function Are(e,t,r,n,s,i){let o={};if(typeof t=="number")o.total=t,o.values=new Float32Array(4),o.values.index=1,o.values[0]=t,o.total=t;else if(typeof t=="boolean")o.total=t?1:0,o.count=1;else if(typeof t=="function")o.count=1,o.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);o.description={metric:r,path:n,method:s,type:i},Gm.set(e,o)}function or(e,t,r,n,s){if(!zB)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Gm.get(i);o?Tre(e,o):Are(i,e,t,r,n,s),qm||Rre()}function es(e,t,r,n,s){or(!!e,t,r,n,s)}function F_(e){JB.push(e)}function Rre(){qm=performance.now(),setTimeout(async()=>{let e=performance.now()-qm;qm=0;let t=[],r={time:Date.now(),period:e,threadId:sl.threadId,metrics:t};for(let[s,i]of Gm){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],f;for(let d of XB){let h=Math.floor(c*d),_=o[h-1];if(h>l){let p=h-l;if(_===f){let S=u[u.length-1];typeof S=="number"?u[u.length-1]={value:S,count:1+p}:S.count+=p}else u.push(p>1?{value:_,count:p}:_),f=_;l=h}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await tH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:sl.threadId,byThread:!0,...n});for(let s of JB)s(t);Gm=new Map,sl.parentPort?sl.parentPort.postMessage({type:QB,report:r}):sH({report:r})},jB).unref()}function $m(e,t,r){let n={id:(0,H_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function ZB(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function eH(e,t){return{userCPUTime:t.userCPUTime/1e3-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime/1e3-(e?.systemCPUTime??0),minorPageFault:t.minorPageFault-(e?.minorPageFault??0),majorPageFault:t.majorPageFault-(e?.majorPageFault??0),fsRead:t.fsRead-(e?.fsRead??0),fsWrite:t.fsWrite-(e?.fsWrite??0),voluntaryContextSwitches:t.voluntaryContextSwitches-(e?.voluntaryContextSwitches??0),involuntaryContextSwitches:t.involuntaryContextSwitches-(e?.involuntaryContextSwitches??0)}}function yre(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let o=`${t}.${s}`,c=i.getSize(),l={database:t,table:s,size:c};$m(e,"table-size",l),il.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function UB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getAuditSize(),o=WB.default.statSync(s.primaryStore.env.path).size,c=yre(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};$m(e,"database-size",u),il.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){il.warn?.("Error getting DB size metrics",s)}}function xB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getStorageStats(),o={database:r,...i};$m(e,"storage-volume",o),il.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){il.warn?.("Error getting DB volumne metrics",s)}}async function bre(e,t=6e4){let r=Wb(),n=rH(),s=new Promise(m=>{let A=performance.now();setImmediate(()=>{let w=performance.now();w-A>5e3&&il.warn?.("Unusually high event queue latency on the main thread of "+Math.round(w-A)+"ms"),A=performance.now()}),n.primaryStore.prefetch([1],()=>{let w=performance.now();w-A>5e3&&il.warn?.("Unusually high task queue latency on the main thread of "+Math.round(w-A)+"ms"),m(w-A)})}),i;for(let m of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(m.value?.time){i=m.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:m,value:A}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!A)continue;if(o){if(m>o+t)break}else o=m;f=m;let{metrics:w,threadId:M}=A;for(let F of w||[]){let{path:G,method:K,type:ee,metric:ie,count:X,total:re,distribution:j,threads:he,...Te}=F;X||(X=1);let Ie=ie+(G?"-"+G:"");K!==void 0&&(Ie+="-"+K),ee!==void 0&&(Ie+="-"+ee);let pe=c.get(Ie);if(pe){if(pe.threads){let Gt=pe.threads[M];if(Gt)pe=Gt;else{pe.threads[M]={...Te};continue}}pe.count||(pe.count=1);let qt=pe.count;for(let Gt in Te){let Zt=Te[Gt];typeof Zt=="number"&&(pe[Gt]=(pe[Gt]*qt+Zt*X)/(qt+X))}pe.count+=X,re>=0&&(pe.total+=re,pe.ratio=pe.total/pe.count)}else pe={period:t,...F},delete pe.distribution,c.set(Ie,pe),pe.byThread&&(pe.threads=[],pe.threads[M]={...Te},u.push(pe));if(j){j=j.map(Gt=>typeof Gt=="number"?{value:Gt,count:1}:Gt);let qt=l.get(Ie);qt?qt.push(...j):l.set(Ie,j)}}await tH()}for(let m of u){let{path:A,method:w,type:M,metric:F,count:G,total:K,distribution:ee,threads:ie,...X}=m;ie=ie.filter(re=>re);for(let re in X){if(typeof m[re]!="number")continue;let j=0;for(let he of ie){let Te=he[re];typeof Te=="number"&&(j+=Te)}m[re]=j}m.count=ie.length,delete m.threads,delete m.byThread}for(let[m,A]of l){let w=c.get(m);A.sort((Gt,Zt)=>Gt.value>Zt.value?1:-1);let M=w.count-1,F=[],G=0,K=0,ee;for(let Gt of XB){let Zt=M*Gt;for(;G<Zt;)ee=A[K++],G+=ee.count,K===1&&G--;let pr=A[K>1?K-2:0];ee||(ee=A[0]),F.push(ee.value-(ee.value-pr.value)*(G-Zt)/ee.count)}let[ie,X,re,j,he,Te,Ie,pe,qt]=F;Object.assign(w,{p1:ie,p10:X,p25:re,median:j,p75:he,p90:Te,p95:Ie,p99:pe,p999:qt})}let d;for(let[m,A]of c)A.id=(0,H_.getNextMonotonicTime)(),A.time=f,n.primaryStore.put(A.id,A,{append:!0}).then(w=>{w||n.primaryStore.put(A.id,A)}),d=!0;let h=Date.now(),{idle:_,active:p}=performance.eventLoopUtilization();if(d||p*10>_){let m=(0,H_.getNextMonotonicTime)(),A={id:m,metric:"main-thread-utilization",idle:_-BB,active:p-HB,taskQueueLatency:await s,time:h,...process.memoryUsage()};n.primaryStore.put(m,A,{append:!0}).then(w=>{w||n.primaryStore.put(m,A)})}BB=_,HB=p;let S=process.resourceUsage(),g=eH(x_,S);g.time=h,g.period=x_.time?h-x_.time:t,g.cpuUtilization=ZB(x_,g.period),$m(n,"resource-usage",g),x_=g;let T=Je();UB(n,T),UB(n,{system:T.system}),xB(n,T),xB(n,{system:T.system})}async function kB(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Wb(){return FB||(FB=at({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function rH(){return qB||(qB=at({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function wre(){nH=!0;let e=(0,k_.get)(H.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await bre(jB,e),await kB(Wb(),Ore),await kB(rH(),Nre)},Math.min(e/2,2147483647)).unref()}function sH(e,t){let r=e.report;r.threadId=t?.threadId||sl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(GB+=n.mean*n.count);r.totalBytesProcessed=GB,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization($B.get(t))}),$B.set(t,t.performance.eventLoopUtilization())),r.id=(0,H_.getNextMonotonicTime)(),Wb().primaryStore.put(r.id,r),nH||wre(),Ire&&(iH=Pre(r))}async function Pre(e){if(await iH,!Ma){let r=(0,B_.dirname)((0,KB.getLogFilePath)());try{Ma=await(0,Yb.open)((0,B_.join)(r,"analytics.log"),"r+")}catch{Ma=await(0,Yb.open)((0,B_.join)(r,"analytics.log"),"w+")}}let t=(await Ma.stat()).size;if(t>Cre){let r=Buffer.alloc(t);await Ma.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Ma.write(r,{position:0}),await Ma.truncate(r.length),t=r.length}await Ma.write(JSON.stringify(e)+`
|
|
21
|
-
`,t)}var sl,VB,KB,YB,B_,Yb,H_,k_,WB,il,Gm,zB,qm,jB,QB,JB,XB,BB,HB,x_,tH,Ore,Nre,FB,qB,nH,GB,$B,Ire,iH,Ma,Cre,$i=be(()=>{sl=require("worker_threads"),VB=x(nt());Ce();KB=x(W()),YB=x(uo()),B_=require("path"),Yb=require("fs/promises"),H_=x(_n()),k_=x(ce());v();Yr();WB=x(require("node:fs")),il=(0,YB.loggerWithTag)("analytics");(0,k_.initSync)();Gm=new Map,zB=(0,k_.get)(H.ANALYTICS_AGGREGATEPERIOD)>-1;a(Sre,"setAnalyticsEnabled");a(Tre,"recordExistingAction");a(Are,"recordNewAction");a(or,"recordAction");Qe.recordAnalytics=or;a(es,"recordActionBinary");qm=0,jB=1e3,QB="analytics-report",JB=[];a(F_,"addAnalyticsListener");XB=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Rre,"sendAnalytics");a($m,"storeMetric");a(ZB,"calculateCPUUtilization");a(eH,"diffResourceUsage");a(yre,"storeTableSizeMetrics");a(UB,"storeDBSizeMetrics");a(xB,"storeVolumeMetrics");a(bre,"aggregation");BB=0,HB=0,x_={},tH=a(()=>new Promise(setImmediate),"rest");a(kB,"cleanup");Ore=36e5,Nre=31536e6;a(Wb,"getRawAnalyticsTable");a(rH,"getAnalyticsTable");(0,VB.setChildListenerByType)(QB,sH);a(wre,"startScheduledTasks");GB=0,$B=new Map,Ire=!1;a(sH,"recordAnalytics");Cre=1e6;a(Pre,"logAnalytics")});var oH={};Be(oH,{Headers:()=>Po,appendHeader:()=>Vm,mergeHeaders:()=>zb});function Vm(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 zb(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new Po(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 Po,G_=be(()=>{Po=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(Vm,"appendHeader");a(zb,"mergeHeaders")});function dH(e){let t={openapi:Dre,info:{title:"HarperDB HTTP REST interface",version:uH.packageJson.version},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},f=[];if(o)for(let{type:A,name:w,elements:M,relationship:F,definition:G}of o){if(F)A==="array"?u[w]={type:"array",items:{$ref:va+M.type}}:u[w]={$ref:va+A};else{let K=G??M?.definition;if(K){if(!t.components.schemas[K.type]){let ee={};K.properties.forEach(ie=>{ee[ie.name]=new Xb(jb[ie.type],ie.type)}),t.components.schemas[K.type]=new lH(ee)}A==="array"?u[w]={type:"array",items:{$ref:va+K.type}}:u[w]={$ref:va+K.type}}else A==="array"?M.type==="Any"||M.type=="ID"?u[w]={type:"array",items:{format:M.type}}:u[w]={type:"array",items:new Xb(jb[M.type],M.type)}:A==="Any"||A=="ID"?u[w]={format:A}:u[w]=new Xb(jb[A],A)}f.push(new Zb(w,"query",u[w]))}let d=Object.keys(u),h=new Zb(c,"path",{format:"ID"});h.required=!0,h.description="primary key of record";let _=new Zb("property","path",{enum:d});_.required=!0,t.components.schemas[i]=new lH(u);let p=l.post!==Resource.prototype.post||l.update,S=typeof l.put=="function",g=typeof l.get=="function",T=typeof l.delete=="function",m="/"+s+"/";p&&(t.paths[m]={},t.paths[m].post=new Lre(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[m]||(t.paths[m]={}),t.paths[m].get=new Qb(f,r,{200:new Jb({$ref:va+i})},"search for records by the specified property name and value pairs")),T&&(t.paths[m]||(t.paths[m]={}),t.paths[m].delete=new cH(f,r,"delete all the records that match the provided query",{204:new aH})),m="/"+s+"/{"+c+"}",g&&(t.paths[m]={},t.paths[m].get=new Qb([h],r,{200:new Jb({$ref:va+i})},"retrieve a record by its primary key")),S&&(t.paths[m]||(t.paths[m]={}),t.paths[m].put=new Mre([h],r,i,"create or update the record with the URL path that maps to the record's primary key")),T&&(t.paths[m]||(t.paths[m]={}),t.paths[m].delete=new cH([h],r,"delete a record with the given primary key",{204:new aH})),g&&_.schema.enum.length>0&&(m="/"+s+"/{"+c+"}.{property}",t.paths[m]={},t.paths[m].get=new Qb([h,_],r,{200:new Jb({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function Lre(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:va+e}}}},this.security=t,this.responses={200:{description:eO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function Qb(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function Jb(e){this.description=eO,this.content={"application/json":{schema:e}}}function aH(){this.description="successfully processed request, no content returned to client"}function Mre(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:va+r}}}},this.responses={200:{description:eO}}}function cH(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function lH(e){this.type="object",this.properties=e}function Xb(e,t){this.type=e,this.format=t}function Zb(e,t,r){this.name=e,this.in=t,this.schema=r}var uH,Dre,jb,va,eO,fH=be(()=>{uH=x(rt()),Dre="3.0.3",jb={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},va="#/components/schemas/",eO="successful operation";a(dH,"generateJsonApi");a(Lre,"Post");a(Qb,"Get");a(Jb,"Response200");a(aH,"Response204");a(Mre,"Put");a(cH,"Delete");a(lH,"ResourceSchema");a(Xb,"Type");a(Zb,"Parameter")});var Ym={};Be(Ym,{parseHeaderValue:()=>rO,start:()=>xre});async function Ure(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&hE(e);let i=new Po;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==_H){let g=Km.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Nc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let T=rO(g);for(let m of T)switch(m.name){case"max-age":e.expiresAt=m.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let g=rO(u).map(T=>(T.next?.name==="confirm"&&T.next.value>=0&&(e.replicatedConfirmation=+T.next.value),T.name));e.replicateTo=g.length===1&&+g[0]>=0?+g[0]:g[0]==="*"?void 0:g}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let d=await Ot(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=go(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new ku.ClientError(g,400)}if(e.authorize=!0,o===_H&&s==="GET"){if(e?.user?.role?.permission?.super_user)return dH(Km);throw new ku.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new ku.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new ku.ServerError(`Method ${s} is not recognized`,501)}}),h=200,_;if(d==null)h=s==="GET"||s==="HEAD"?404:204,tO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=zb(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Vf(d.data,e,d)),d}else if(_=e.lastModified){vre[0]=_;let g=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),T=r["if-none-match"];T&&g==T?(d?.onDone&&d.onDone(),h=304,d=void 0):i.setIfNone("ETag",g),tO.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}e.createdResource&&(h=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let p={status:h,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(p.wasCacheMiss=S,!S&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),d!==void 0&&(p.body=Vf(d,e,p),s==="HEAD"&&(p.body=void 0)),p}catch(o){o.statusCode?o.statusCode===500?Vi.warn(o):Vi.info(o):Vi.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=Vf(o.contentType?o:o.toString(),e,c),c}}function xre(e){tO=e,!hH&&(hH=!0,Km=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Ure(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{$_++;let s=new qn;pH||(pH=!0,F_(l=>{$_>0&&l.push({metric:"ws-connections",connections:$_,byThread:!0})}));let i;t.on("error",l=>{i=!0,Vi.warn(l)});let o;t.on("message",a(function(u){o||(o=go(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);or(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{$_--,es(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=Km.getMatch(l,"ws");if(es(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,or(p=>({count:p.count,total:$_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new Nc(u.relativeURL),d=u.Resource;c=(await Ot(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let p=await Oa(_.value,r);t.send(p),or(p.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Vi.warn(l):Vi.info(l):Vi.error(l),t.close(Bre[l.statusCode]||1011,l.toString())}t.close()},e))}function rO(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var Vi,ku,Ur,vre,tO,_H,hH,Km,pH,$_,Bre,EH=be(()=>{Eo();$i();Vi=x(W()),ku=x(_e());xf();cu();Oc();G_();fH();xf();Ur=new Uint8Array(8),vre=new Float64Array(Ur.buffer,0,1),tO={},_H="openapi";a(Ure,"http");$_=0;a(xre,"start");Bre={401:3e3,403:3003};a(rO,"parseHeaderValue")});var nO=C((LCe,gH)=>{var{recordAction:Wm,recordActionBinary:mH}=($i(),D(q_)),Hre=require("fastify-plugin"),kre=200;gH.exports=Hre(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,f,d;l.config?.isOperation?(u=n.body?.operation,f="operation"):(u=l.url,f="fastify-route",d=l.method),Wm(o,"duration",u,d,f),mH(s.raw.statusCode<400,"success",u,d,f),mH(1,"response_"+s.raw.statusCode,u,d,f);let h=kre;i?.pipe?(i.on("data",g=>{h+=g.length}),i.on("end",()=>{Wm(performance.now()-c,"transfer",u,d,f),Wm(h,"bytes-sent",u,d,f)})):(h+=i?.length||0,Wm(h,"bytes-sent",u,d,f));let _=o.toFixed(3),p=s.getHeader("Server-Timing"),S=`db;dur=${_}`;s.header("Server-Timing",p?`${p}, ${S}`:S)}),r()},{name:"hdb-request-time"})});var TH=C((MCe,SH)=>{var Fre=pt(),qre={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};SH.exports=function(e){return Fre.validateObject(e,qre)}});var zm=C((vCe,AH)=>{"use strict";var Gre=(v(),D(q)).OPERATIONS_ENUM,sO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Gre.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};AH.exports=sO});var yH=C((xCe,RH)=>{"use strict";var $re={OPERATION:"operation",REFRESH:"refresh"},iO=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},oO=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};RH.exports={JWTTokens:iO,TOKEN_TYPE_ENUM:$re,JWTRSAKeys:oO}});var Fu=C((HCe,NH)=>{"use strict";var K_=require("jsonwebtoken"),aO=require("fs-extra"),cO=ae(),Os=(v(),D(q)),{handleHDBError:On,hdb_errors:Vre}=_e(),{HTTP_STATUS_CODES:Nn,AUTHENTICATION_ERROR_MSGS:wn}=Vre,V_=W(),jm=(am(),D(om)),dO=An(),Kre=Rn().update,Yre=zm(),Wre=wo(),{UserEventMsg:zre}=oi(),Ua=ce();Ua.initSync();var lO=require("path"),{JWTTokens:jre,JWTRSAKeys:Qre,TOKEN_TYPE_ENUM:Qm}=yH(),Jre=Ua.get(Os.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?Ua.get(Os.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",Xre=Ua.get(Os.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?Ua.get(Os.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",Jm="RS256",uO;NH.exports={createTokens:Zre,validateOperationToken:tne,refreshOperationToken:ene,validateRefreshToken:OH,getJWTRSAKeys:Y_};async function Zre(e){if(cO.isEmpty(e)||typeof e!="object")throw On(new Error,wn.INVALID_AUTH_OBJECT,Nn.BAD_REQUEST,void 0,void 0,!0);if(cO.isEmpty(e.username))throw On(new Error,wn.USERNAME_REQUIRED,Nn.BAD_REQUEST,void 0,void 0,!0);if(cO.isEmpty(e.password))throw On(new Error,wn.PASSWORD_REQUIRED,Nn.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await dO.findAndValidateUser(e.username,e.password),!t)throw On(new Error,wn.INVALID_CREDENTIALS,Nn.UNAUTHORIZED,void 0,void 0,!0)}catch(h){throw V_.error(h),On(new Error,wn.INVALID_CREDENTIALS,Nn.UNAUTHORIZED,void 0,void 0,!0)}let r=await Y_(),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 bH(i,r.private_key,r.passphrase),c=await K_.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:Xre,algorithm:Jm,subject:Qm.REFRESH}),l=jm.hash(c,jm.HASH_FUNCTION.SHA256),u=new Yre(Os.SYSTEM_SCHEMA_NAME,Os.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),f,d;try{f=await Kre(u)}catch(h){V_.error(h),d=h}if(d!==void 0||f.skipped_hashes.length>0)throw On(new Error,wn.REFRESH_TOKEN_SAVE_FAILED,Nn.INTERNAL_SERVER_ERROR);return Wre.signalUserChange(new zre(process.pid)),new jre(o,c)}a(Zre,"createTokens");async function bH(e,t,r){return await K_.sign(e,{key:t,passphrase:r},{expiresIn:Jre,algorithm:Jm,subject:Qm.OPERATION})}a(bH,"signOperationToken");async function Y_(){if(uO===void 0)try{let e=lO.join(Ua.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME,Os.JWT_ENUM.JWT_PASSPHRASE_NAME),t=lO.join(Ua.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME,Os.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=lO.join(Ua.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME,Os.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await aO.readFile(e)).toString(),s=(await aO.readFile(t)).toString(),i=(await aO.readFile(r)).toString();uO=new Qre(i,s,n)}catch(e){throw V_.error(e),On(new Error,wn.NO_ENCRYPTION_KEYS,Nn.INTERNAL_SERVER_ERROR)}return uO}a(Y_,"getJWTRSAKeys");async function ene(e){if(!e)throw On(new Error,wn.INVALID_BODY,Nn.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw On(new Error,wn.REFRESH_TOKEN_REQUIRED,Nn.BAD_REQUEST,void 0,void 0,!0);await OH(e.refresh_token);let t=await Y_(),r=await K_.decode(e.refresh_token);return{operation_token:await bH({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(ene,"refreshOperationToken");async function tne(e){try{let t=await Y_(),r=await K_.verify(e,t.public_key,{algorithms:Jm,subject:Qm.OPERATION});return await dO.findAndValidateUser(r.username,void 0,!1)}catch(t){throw V_.warn(t),t.name&&t.name==="TokenExpiredError"?On(new Error,wn.TOKEN_EXPIRED,Nn.FORBIDDEN):On(new Error,wn.INVALID_TOKEN,Nn.UNAUTHORIZED)}}a(tne,"validateOperationToken");async function OH(e){let t;try{let r=await Y_(),n=await K_.verify(e,r.public_key,{algorithms:Jm,subject:Qm.REFRESH});t=await dO.findAndValidateUser(n.username,void 0,!1)}catch(r){throw V_.warn(r),r.name&&r.name==="TokenExpiredError"?On(new Error,wn.TOKEN_EXPIRED,Nn.FORBIDDEN):On(new Error,wn.INVALID_TOKEN,Nn.UNAUTHORIZED)}if(!jm.validate(t.refresh_token,e,jm.HASH_FUNCTION.SHA256))throw On(new Error,wn.INVALID_TOKEN,Nn.UNAUTHORIZED);return t}a(OH,"validateRefreshToken")});var fO=C((qCe,CH)=>{"use strict";var rne=TH(),qu=require("passport"),nne=require("passport-local").Strategy,sne=require("passport-http").BasicStrategy,ine=require("util"),one=An(),IH=ine.callbackify(one.findAndValidateUser),FCe=Fn(),ane=(v(),D(q)),wH=Fu();qu.use(new nne(function(e,t,r){IH(e,t,r)}));qu.use(new sne(function(e,t,r){IH(e,t,r)}));qu.serializeUser(function(e,t){t(null,e)});qu.deserializeUser(function(e,t){t(null,e)});function cne(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":qu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===ane.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?wH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):wH.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:qu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(cne,"authorize");function lne(e,t){let r=rne(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(lne,"checkPermissions");CH.exports={authorize:cne,checkPermissions:lne}});var Xm=C(($Ce,PH)=>{"use strict";var une=Wn();PH.exports={writeTransaction:dne};function dne(e,t,r){return une.writeTransaction(e,t,r)}a(dne,"writeTransaction")});var vH=C((YCe,MH)=>{"use strict";var fne=zr(),_ne=ys(),DH=W(),hne=Rn(),KCe=Xm(),pne=require("clone"),hO=require("alasql"),Ene=XE(),LH=require("util"),mne=LH.promisify(_ne.getTableSchema),gne=LH.promisify(fne.search),Sne=(v(),D(q)),_O=ae();Ene(hO);MH.exports={update:Ane};var Tne="There was a problem performing this update. Please check the logs and try again.";async function Ane({statement:e,hdb_user:t}){let r=await mne(e.table.databaseid,e.table.tableid),n=Rne(e.columns);_O.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=pne(s),c=_O.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=hO.parse(l).statements[0],f=await gne(u),d=yne(n,f);return bne(o,d,t)}a(Ane,"update");function Rne(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=hO.compile(`SELECT ${r.expression.toString()} AS [${Sne.FUNC_VAL}] FROM ?`)}),t}catch(t){throw DH.error(t),new Error(Tne)}}a(Rne,"createUpdateRecord");function yne(e,t){return _O.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(yne,"buildUpdateRecords");async function bne(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await hne.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){DH.error(`Error delete new_attributes from update response: ${i}`)}return s}a(bne,"updateRecords")});var xH=C((QCe,UH)=>{var One=require("alasql"),Nne=zr(),wne=W(),Ine=Wn(),EO=require("util"),pO=ae(),Cne=(v(),D(q)),Pne=ys(),zCe=Xm(),jCe=Rn(),Dne="record",Lne="successfully deleted",Mne=EO.callbackify(Bne),vne=EO.promisify(Nne.search),Une=EO.promisify(Pne.getTableSchema);UH.exports={convertDelete:Mne};function xne(e){return`${e.deleted_hashes.length} ${Dne}${e.deleted_hashes.length===1?"":"s"} ${Lne}`}a(xne,"generateReturnMessage");async function Bne({statement:e,hdb_user:t}){let r=await Une(e.table.databaseid,e.table.tableid);pO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=pO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=One.parse(o).statements[0],l={operation:Cne.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await vne(c);let u=await Ine.deleteRecords(l);return pO.isEmptyOrZeroLength(u.message)&&(u.message=xne(u)),delete u.txn_time,u}catch(u){throw wne.error(u),u.hdb_code?u.message:u}}a(Bne,"convertDelete")});var qH=C((XCe,FH)=>{"use strict";var Hne=Oo(),{hdb_errors:BH}=_e(),{getDatabases:HH}=(Ce(),D(tt));FH.exports={checkSchemaExists:kH,checkSchemaTableExists:kne,schema_describe:Hne};async function kH(e){if(!HH()[e])return BH.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(kH,"checkSchemaExists");async function kne(e,t){let r=await kH(e);if(r)return r;if(!HH()[e][t])return BH.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(kne,"checkSchemaTableExists")});var AO=C((nPe,ZH)=>{"use strict";var{decode:Fne}=require("msgpackr"),{isMainThread:ePe,parentPort:tPe,threadId:rPe}=require("worker_threads"),tg=ar(),Gu=gt(),SO=(v(),D(q)),Xr=W(),gO=ce(),qne=(v(),D(q)),{onMessageByType:Gne}=nt(),KH=bo(),{recordAction:GH,recordActionBinary:$ne}=($i(),D(q_)),{publishToStream:Vne}=tg,{ConsumerEvents:$H}=require("nats"),Kne=zr(),{promisify:Yne}=require("util"),{decodeBlobsWithWrites:Wne}=(Ts(),D(PE)),YH=Yne(setTimeout),rg=1e4,ng,eg,zne,jne,WH,W_=new Map,$u=new Map;ZH.exports={initialize:zH,ingestConsumer:TO,setSubscription:Qne,setIgnoreOrigin:Zne,getDatabaseSubscriptions:Xne,updateConsumer:jH};async function zH(){Gne(SO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await jH(n)}),WH=!0,Xr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await tg.getNATSReferences();ng=e,eg=e.info.server_name,zne=t,jne=r}a(zH,"initialize");async function jH(e){if(e.status==="start"){let{js:t,jsm:r}=await QH(e.node_domain_name);TO(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&&(Xr.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")),$u.get(e.node_domain_name)==="failed"&&$u.set(e.node_domain_name,"close")}}a(jH,"updateConsumer");var sg=new Map;function Qne(e,t,r){let n=sg.get(e);n||sg.set(e,n=new Map),n.set(t,r),WH||zH().then(Jne)}a(Qne,"setSubscription");async function Jne(){let e=await Kne.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Gu.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await QH(r),!n))break;let{schema:o,table:c}=i,l=KH.createNatsTableStreamName(o,c);TO(l,n,s,r)}}}a(Jne,"accessConsumers");async function QH(e){let t,r,n=1;for(;!r;)try{t=await ng.jetstream({domain:e}),r=await ng.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if($u.get(e)==="close")break;$u.set(e,"failed"),n%10===1&&Xr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<rg?n++*100:rg;await YH(i)}return{js:t,jsm:r}}a(QH,"connectToRemoteJS");function Xne(){return sg}a(Xne,"getDatabaseSubscriptions");var JH;function Zne(e){JH=e}a(Zne,"setIgnoreOrigin");var XH=100,VH=new Array(XH),Zm=0;async function TO(e,t,r,n){let{connection:s}=await tg.getNATSReferences();ng=s,eg=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,eg),Xr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if($u.get(n)==="close")break;o%10===1&&Xr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(Xr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await tg.createConsumer(r,e,eg,new Date(Date.now()).toISOString()));let f=o++*100<rg?o++*100:rg;await YH(f)}let c=!1,l;for(;!c;){if(W_.get(e+n)==="close"||$u.get(n)==="close"){W_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:gO.get(SO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),W_.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===$H.ConsumerDeleted&&(await l.close(),c=!0),f.type===$H.HeartbeatsMissed){let d=f.data;Xr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(Xr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let f of l)await VH[Zm],VH[Zm]=ese(f).catch(d=>{Xr.error(d)}),++Zm>=XH&&(Zm=0)}catch(f){f.message==="consumer deleted"?(Xr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):Xr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(TO,"ingestConsumer");async function ese(e){let t;await Wne(()=>{t=Fne(e.data)}),GH(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),Xr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=gO.get(SO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Gu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Gu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Gu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!JH),$ne(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Gu.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:f,hash_values:d,__origin:h,expiresAt:_}=t;Xr.trace("processing message:",o,c,u,(f?"records: "+f.map(M=>M?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Xr.trace(`messageProcessor nats msg id: ${e.headers.get(Gu.MSG_HEADERS.NATS_MSG_ID)}`);let p;f||(f=d);let S=new Promise(M=>p=M),{timestamp:g,user:T,node_name:m}=h||{},A=sg.get(c)?.get(u);if(!A)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=p,A.send(t);else if(f.length===1&&!l)A.send({type:mO(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:p,user:T,nodeName:m});else{let M=f.map((F,G)=>({type:mO(o),value:F,expiresAt:_,id:d?.[G],table:u}));for(;l;)M.push({type:mO(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;A.send({type:"transaction",writes:M,table:u,timestamp:g,onCommit:p,user:T,nodeName:m})}gO.get(qne.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&Vne(e.subject.split(".").slice(0,-1).join("."),KH.createNatsTableStreamName(c,u),e.headers,e.data),await S;let w=Date.now()-g;g&&GH(w,"replication-latency",e.subject,o,"ingest")}catch(o){Xr.error(o)}e.ack()}a(ese,"messageProcessor");function mO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(mO,"convertOperation")});var ar=C((uPe,Ek)=>{"use strict";var Ir=ce();Ir.initSync();var tse=require("fs-extra"),rse=require("semver"),Q_=require("path"),{monotonicFactory:nse}=require("ulidx"),tk=nse(),sse=require("util"),rk=require("child_process"),ise=sse.promisify(rk.exec),ose=rk.spawn,xr=gt(),Ve=(v(),D(q)),{packageJson:ase,PACKAGE_ROOT:cse}=rt(),ig=ae(),li=W(),og=bo(),lse=Xm(),z_=At(),{broadcast:use,onMessageByType:dse,getWorkerIndex:fse}=nt(),{isMainThread:nk}=require("worker_threads"),{Encoder:_se,decode:OO}=require("msgpackr"),sk=new _se,{isEmpty:ll}=ig,ik=An(),iPe=48*36e11;nk&&dse(Ve.ITC_EVENT_TYPES.RESTART,()=>{Zr=void 0,cl=void 0});var{connect:hse,StorageType:pse,RetentionPolicy:Ese,AckPolicy:NO,DeliverPolicy:wO,DiscardPolicy:mse,NatsConnection:oPe,JetStreamManager:aPe,JetStreamClient:cPe,StringCodec:lPe,JSONCodec:gse,createInbox:IO,headers:Sse,ErrorCode:ek}=require("nats"),{recordAction:Tse}=($i(),D(q_)),{encodeBlobsAsBuffers:Ase}=(Ts(),D(PE)),ok=gse(),Rse="clustering",yse=ase.engines[xr.NATS_SERVER_NAME],bse=Q_.join(cse,"dependencies"),bO=Q_.join(bse,`${process.platform}-${process.arch}`,xr.NATS_BINARY_NAME),RO,yO,j_,ol,al;Ek.exports={runCommand:ak,checkNATSServerInstalled:Ose,createConnection:CO,getConnection:J_,getJetStreamManager:X_,getJetStream:lk,getNATSReferences:Ki,getServerList:wse,createLocalStream:PO,listStreams:uk,deleteLocalStream:Ise,getServerConfig:Vu,listRemoteStreams:Cse,viewStream:Pse,viewStreamIterator:Dse,publishToStream:Lse,request:Use,reloadNATS:DO,reloadNATSHub:xse,reloadNATSLeaf:Bse,extractServerName:vse,requestErrorHandler:Hse,createLocalTableStream:hk,createTableStreams:qse,purgeTableStream:pk,purgeSchemaTableStreams:Gse,getStreamInfo:$se,updateLocalStreams:Kse,closeConnection:Nse,getJsmServerName:ag,addNatsMsgHeader:dk,clearClientCache:ck,updateRemoteConsumer:kse,createConsumer:fk,updateConsumerIterator:Fse};async function ak(e,t=void 0){let{stdout:r,stderr:n}=await ise(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
19
|
+
`)},z6="certificate.pem",j6="privateKey.pem",Q6="caCertificate.pem",J6="natsCertificate.pem",X6="natsCaCertificate.pem",Tt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},Z6={tls_certificate:Tt.SERVER,tls_certificateAuthority:Tt.CA,customFunctions_tls_certificate:Tt.SERVER,customFunctions_tls_certificateAuthority:Tt.CA,operationsApi_tls_certificate:Tt["OPERATIONS-API"],operationsApi_tls_certificateAuthority:Tt["OPERATIONS-CA"]},e8={[Tt.SERVER]:2,[Tt.DEFAULT]:1},t8={[Tt["OPERATIONS-API"]]:3,[Tt.SERVER]:2,[Tt.DEFAULT]:1},r8={[Tt["OPERATIONS-API"]]:3,[Tt.SERVER]:2,[Tt.DEFAULT]:1},n8={[Tt["OPERATIONS-CA"]]:3,[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1},s8={[Tt["OPERATIONS-CA"]]:3,[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1},i8={[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1};Object.assign(yU,{CERTIFICATE_PEM_NAME:z6,PRIVATEKEY_PEM_NAME:j6,CA_PEM_NAME:Q6,CERT_NAME:Tt,CERT_CONFIG_NAME_MAP:Z6,CERT_PREFERENCE_APP:e8,CERT_PREFERENCE_OPS:t8,CERT_PREFERENCE_REP:r8,CA_CERT_PREFERENCE_REP:n8,CA_CERT_PREFERENCE_OPS:s8,CA_CERT_PREFERENCE_APP:i8,CERTIFICATE_VALUES:W6,NATS_CERTIFICATE_PEM_NAME:J6,NATS_CA_PEM_NAME:X6})});var $y=I((NNe,CU)=>{"use strict";var wU=require("fs-extra"),Se=require("joi"),o8=require("os"),{boolean:He,string:At,number:tr,array:Yc}=Se.types(),{totalmem:bU}=require("os"),Kc=require("path"),a8=Y(),qy=oe(),ONe=Gy(),OU=(B(),C(G)),c8=ut(),NU="log",l8="components",u8="Invalid logging.rotation.maxSize unit. Available units are G, M or K",d8="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",f8="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",_8="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",p8="rootPath config parameter is undefined",An=Se.alternatives([tr.min(0),At]).optional().empty(null),mE=Se.alternatives([Yc.items(At,{host:At.required(),port:An},{hostname:At.required(),port:An}).empty(null),Yc.items(At)]),Hi,IU=!1;CU.exports={configValidator:h8,routesValidator:A8,route_constraints:mE};function h8(e,t=!1){if(IU=t,Hi=e.rootPath,qy.isEmpty(Hi))throw p8;let r=He.optional(),n=tr.min(0).max(1e3).empty(null).default(T8),s=At.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(A_),i=At.optional().empty(null),o=At.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Se.string().empty(null).default(A_),l=Se.custom(E8).empty(null).default(A_),u=e.clustering?.enabled,f=Se.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Se.object({enabled:r,hubServer:Se.object({cluster:Se.object({name:Se.required().empty(null),network:Se.object({port:An,routes:mE}).required()}).required(),leafNodes:Se.object({network:Se.object({port:An}).required()}).required(),network:Se.object({port:An}).required()}).required(),leafServer:Se.object({network:Se.object({port:An,routes:mE}).required(),streams:Se.object({maxAge:tr.min(120).allow(null).optional(),maxBytes:tr.min(1).allow(null).optional(),maxMsgs:tr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:Se.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:He.optional(),databaseLevel:He.optional(),tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.required(),verify:He.optional()}),user:At.optional().empty(null)}).optional():d=Se.object({enabled:r,tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.optional()})}).optional(),Se.object({authentication:Se.alternatives(Se.object({authorizeLocal:He,cacheTTL:tr.required(),enableSessions:He,hashFunction:At.valid("md5","sha256","argon2id").optional().empty(null)}),He).optional(),analytics:Se.object({aggregatePeriod:tr}),replication:Se.object({hostname:Se.alternatives(At,tr).optional().empty(null),url:At.optional().empty(null),port:An,securePort:An,routes:Yc.optional().empty(null),databases:Se.alternatives(At,Yc),enableRootCAs:He.optional(),copyTablesToCatchUp:He.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Se.object({enabled:r}).required(),logging:Se.object({auditAuthEvents:Se.object({logFailed:He,logSuccessful:He}),file:He.required(),level:Se.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Se.object({enabled:He.optional(),compress:He.optional(),interval:At.custom(S8).optional().empty(null),maxSize:At.custom(g8).optional().empty(null),path:At.optional().empty(null).default(A_)}).required(),root:s,stdStreams:He.required(),auditLog:He.required()}).required(),operationsApi:Se.object({network:Se.object({cors:He.optional(),corsAccessList:Yc.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:An,domainSocket:Se.optional().empty("hdb/operations-server").default(A_),securePort:An,timeout:tr.min(1).optional()}).optional(),tls:Se.alternatives([Se.array().items(f),f])}).required(),rootPath:At.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Se.object({network:Se.object({port:An,securePort:An,mtls:Se.alternatives([He.optional(),Se.object({user:At.optional(),certificateAuthority:i,required:He.optional()})])}).required(),webSocket:He.optional(),requireAuthentication:He.optional()}),http:Se.object({compressionThreshold:tr.optional(),cors:He.optional(),corsAccessList:Yc.optional(),headersTimeout:tr.min(1).optional(),port:An,securePort:An,maxHeaderSize:tr.optional(),mtls:Se.alternatives([He.optional(),Se.object({user:At.optional(),certificateAuthority:i,required:He.optional()})]),threadRange:Se.alternatives([Yc.optional(),At.optional()])}).required(),threads:Se.alternatives(n.optional(),Se.object({count:n.optional(),debug:Se.alternatives(He.optional(),Se.object({startingPort:tr.min(1).optional(),host:At.optional(),waitForDebugger:He.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:Se.object({writeAsync:He.required(),overlappingSync:He.optional(),caching:He.optional(),compression:Se.alternatives([He.optional(),Se.object({dictionary:At.optional(),threshold:tr.optional()})]),compactOnStart:He.optional(),compactOnStartKeepBackup:He.optional(),noReadAhead:He.optional(),path:l,prefetchWrites:He.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:He.optional(),tls:Se.alternatives([Se.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(h8,"configValidator");function m8(e){return IU||wU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(m8,"doesPathExist");function E8(e,t){Se.assert(e,At.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=m8(e);if(r)return t.message(r)}a(E8,"validatePath");function g8(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(u8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(f8):e}a(g8,"validateRotationMaxSize");function S8(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(d8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(_8):e}a(S8,"validateRotationInterval");function T8(e,t){let r=t.state.path.join("."),n=o8.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||bU();return i=Math.round(Math.min(i,bU())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),a8.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(T8,"setDefaultThreads");function A_(e,t){let r=t.state.path.join(".");if(!qy.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(qy.isEmpty(Hi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Kc.join(Hi,l8);case"logging.root":return Kc.join(Hi,NU);case"clustering.leafServer.streams.path":return Kc.join(Hi,"clustering","leaf");case"storage.path":let n=Kc.join(Hi,OU.LEGACY_DATABASES_DIR_NAME);return wU.existsSync(n)?n:Kc.join(Hi,OU.DATABASES_DIR_NAME);case"logging.rotation.path":return Kc.join(Hi,NU);case"operationsApi.network.domainSocket":return r==null?null:Kc.join(Hi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(A_,"setDefaultRoot");function A8(e){let t=Se.object({routes:mE});return c8.validateBySchema({routes:e},t)}a(A8,"routesValidator")});var Rt=I(FU=>{"use strict";var Os=(B(),C(G)),Er=oe(),rr=Y(),{configValidator:R8,routesValidator:PU}=$y(),jr=require("fs-extra"),LU=require("yaml"),jn=require("path"),y8=require("is-number"),MU=require("properties-reader"),b8=require("lodash"),{handleHDBError:O8}=pe(),{HTTP_STATUS_CODES:N8,HDB_ERROR_MSGS:Cu}=Hn(),{server:w8}=(Kr(),C(Tu)),{PACKAGE_ROOT:vU}=nt(),{DATABASES_PARAM_CONFIG:R_,CONFIG_PARAMS:zn,CONFIG_PARAM_MAP:ri}=Os,I8="Unable to get config value because config is uninitialized",C8="Config successfully initialized",P8="Error backing up config file",D8="Empty parameter sent to getConfigValue",UU=jn.join(vU,"config","yaml",Os.HDB_DEFAULT_CONFIG_FILE),L8=jn.join(vU,"config","yaml","defaultNatsConfig.yaml"),M8="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",DU={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},EE,wt,gE;Object.assign(FU,{createConfigFile:v8,getDefaultConfig:U8,getConfigValue:BU,initConfig:SE,flattenConfig:Pu,updateConfigValue:HU,updateConfigObject:B8,getConfiguration:F8,setConfiguration:G8,readConfigFile:Wy,getClusteringRoutes:q8,initOldConfig:kU,getConfigFromFile:$8,getConfigFilePath:Wc,addConfig:V8,deleteConfigFromFile:K8,getConfigObj:Y8,resolvePath:Vy,getFlatConfigObj:W8});function Vy(e){if(e?.startsWith("~/"))return jn.join(Er.getHomeDir(),e.slice(1));let t=ce();return jn.resolve(t.getHdbBasePath(),e)}a(Vy,"resolvePath");function v8(e,t=!1){let r=Ia(UU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=LU.parseDocument(jr.readFileSync(L8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}EE=Pu(r.toJSON());let n;for(let c in e){let l=ri[c.toLowerCase()];if(l===zn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),f=Ky(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){rr.error(d)}}}n&&xU(r,n),Yy(r,t);let s=r.toJSON();wt=Pu(s);let i=r.getIn(["rootPath"]),o=jn.join(i,Os.HDB_CONFIG_FILE);if(jr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);jr.writeFileSync(o,String(r)),rr.trace(`Config file written to ${o}`)}a(v8,"createConfigFile");function xU(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Er.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(R_.TABLES))for(let i in n[s][R_.TABLES])for(let o in n[s][R_.TABLES][i]){let c=n[s][R_.TABLES][i][o],l=[zn.DATABASES,s,R_.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[zn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){rr.error("Error parsing schemas CLI/env config arguments",n)}}a(xU,"setSchemasConfig");function U8(e){if(EE===void 0){let r=Ia(UU);EE=Pu(r.toJSON())}let t=ri[e.toLowerCase()];if(t!==void 0)return EE[t.toLowerCase()]}a(U8,"getDefaultConfig");function BU(e){if(e==null){rr.info(D8);return}if(wt===void 0){rr.trace(I8);return}let t=ri[e.toLowerCase()];if(t!==void 0)return wt[t.toLowerCase()]}a(BU,"getConfigValue");function Wc(e=Er.getPropsFilePath()){let t=Er.getEnvCliRootPath();if(t)return Vy(jn.join(t,Os.HDB_CONFIG_FILE));let r=MU(e);return Vy(r.get(Os.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Wc,"getConfigFilePath");function SE(e=!1){if(wt===void 0||e){let t;if(!Er.noBootFile()){t=Er.getPropsFilePath();try{jr.accessSync(t,jr.constants.F_OK|jr.constants.R_OK)}catch(i){throw rr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Wc(t),n;if(r.includes("config/settings.js"))try{kU(r);return}catch(i){if(i.code!==Os.NODE_ERROR_CODES.ENOENT)throw i}try{n=Ia(r)}catch(i){if(i.code===Os.NODE_ERROR_CODES.ENOENT){rr.trace(`HarperDB config file not found at ${r}.
|
|
20
|
+
This can occur during early stages of install where the config file has not yet been created`);return}else throw rr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}x8(n,r),Yy(n);let s=n.toJSON();if(w8.config=s,wt=Pu(s),wt.logging_rotation_rotate)for(let i in DU)wt[i]&&rr.error(`Config ${DU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);rr.trace(C8)}}a(SE,"initConfig");function x8(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],jn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],jn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(rr.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);jr.writeFileSync(t,String(e))}}a(x8,"checkForUpdatedConfig");function Yy(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Cu.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Cu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=R8(r,t);if(n.error)throw Cu.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(Yy,"validateConfig");function B8(e,t){wt===void 0&&(wt={});let r=ri[e.toLowerCase()];if(r===void 0){rr.trace(`Unable to update config object because config param '${e}' does not exist`);return}wt[r.toLowerCase()]=t}a(B8,"updateConfigObject");function HU(e,t,r=void 0,n=!1,s=!1,i=!1){wt===void 0&&SE();let o=BU(ri.hdb_root),c=jn.join(o,Os.HDB_CONFIG_FILE),l=Ia(c),u;if(r&&wt){let p=!1;for(let _ in r)if(r[_]!=wt[_.toLowerCase()]){p=!0;break}if(!p){rr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===zn.DATABASES)u=t;else if(r===void 0){let p;if(i)p=e;else if(p=ri[e.toLowerCase()],p===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=p.split("_"),h=Ky(p,t);l.setIn([..._],h)}else for(let p in r){let _=ri[p.toLowerCase()];if(_===zn.HTTP_SECUREPORT&&r[p]===wt[zn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===zn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[p]===wt[zn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===zn.DATABASES){u=r[p];continue}if(_?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!_&&(p.endsWith("_package")||p.endsWith("_port"))&&(_=p),_!==void 0){let h=_.split("_"),S=Os.LEGACY_CONFIG_PARAMS[p.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,h=S.split("_"));let g=Ky(_,r[p]);_==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],g)}catch(A){rr.error(A)}}}u&&xU(l,u),Yy(l);let f=l.getIn(["rootPath"]),d=jn.join(f,Os.HDB_CONFIG_FILE);if(n===!0&&H8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);jr.writeFileSync(d,String(l)),s&&(wt=Pu(l.toJSON())),rr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(HU,"updateConfigValue");function H8(e,t){try{let r=jn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${Os.HDB_CONFIG_FILE}.bak`);jr.copySync(e,r),rr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){rr.error(P8),rr.error(r)}}a(H8,"backupConfigFile");var k8=["databases"];function Pu(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),gE=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!k8.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;!zn[l.toUpperCase()]&&ri[l]&&(s[ri[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Pu,"flattenConfig");function Ky(e,t){if(e===zn.CLUSTERING_NODENAME||e===zn.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(y8(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Er.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 Er.autoCast(t)}a(Ky,"castConfigValue");function F8(){let e=Er.getPropsFilePath(),t=Wc(e);return Ia(t).toJSON()}a(F8,"getConfiguration");async function G8(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return HU(void 0,void 0,s,!0),M8}catch(i){throw typeof i=="string"||i instanceof String?O8(i,i,N8.BAD_REQUEST,void 0,void 0,!0):i}}a(G8,"setConfiguration");function Wy(){let e=Er.getPropsFilePath();try{jr.accessSync(e,jr.constants.F_OK|jr.constants.R_OK)}catch(n){if(!Er.noBootFile())throw rr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Wc(e);return Ia(t).toJSON()}a(Wy,"readConfigFile");function Ia(e){return LU.parseDocument(jr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Ia,"parseYamlDoc");function q8(){let e=Wy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Er.isEmptyOrZeroLength(t)?[]:t;let r=PU(t);if(r)throw Cu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=PU(n);if(s)throw Cu.CONFIG_VALIDATION(s.message);if(!Er.isEmptyOrZeroLength(n)&&!Er.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Er.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Cu.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(q8,"getClusteringRoutes");function kU(e){let t=MU(e);wt={};for(let r in ri){let n=t.get(r.toUpperCase());if(Er.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ri[r].toLowerCase();s===zn.LOGGING_ROOT?wt[s]=jn.dirname(n):wt[s]=n}return wt}a(kU,"initOldConfig");function $8(e){let t=Wy();return b8.get(t,e.replaceAll("_","."))}a($8,"getConfigFromFile");async function V8(e,t){let r=Ia(Wc());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await jr.writeFile(Wc(),String(r))}a(V8,"addConfig");function K8(e){let t=Wc(Er.getPropsFilePath()),r=Ia(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=jn.join(n,Os.HDB_CONFIG_FILE);jr.writeFileSync(s,String(r))}a(K8,"deleteConfigFromFile");function Y8(){return gE||(SE(),gE)}a(Y8,"getConfigObj");function W8(){return wt||SE(),wt}a(W8,"getFlatConfigObj")});var Rn=I((PNe,Or)=>{"use strict";var $U="username is required",VU="nothing to update, must supply active, role or password to update",KU="password cannot be an empty string",YU="If role is specified, it cannot be empty.",WU="active must be true or false";Or.exports.addUser=r5;Or.exports.alterUser=n5;Or.exports.dropUser=i5;Or.exports.getSuperUser=u5;Or.exports.userInfo=o5;Or.exports.listUsers=AE;Or.exports.listUsersExternal=a5;Or.exports.setUsersWithRolesCache=zc;Or.exports.findAndValidateUser=rb;Or.exports.getClusterUser=d5;Or.exports.getUsersWithRolesCache=l5;Or.exports.USERNAME_REQUIRED=$U;Or.exports.ALTERUSER_NOTHING_TO_UPDATE=VU;Or.exports.EMPTY_PASSWORD=KU;Or.exports.EMPTY_ROLE=YU;Or.exports.ACTIVE_BOOLEAN=WU;var zU=yn(),z8=Vc(),y_=(hE(),C(pE)),jU=TU(),b_=Wr(),Xy=yo(),ki=oe(),QU=require("validate.js"),Zy=Y(),{promisify:j8}=require("util"),eb=To(),jy=(B(),C(G)),GU=St(),Q8=Rt(),J8=ce(),X8=Eo(),{hdb_errors:Z8,ClientError:ni}=pe(),{HTTP_STATUS_CODES:Ro,AUTHENTICATION_ERROR_MSGS:zy,HDB_ERROR_MSGS:Du}=Z8,{UserEventMsg:tb}=si(),Qy=require("lodash"),{server:TE}=(Kr(),C(Tu)),e5=Y();TE.getUser=(e,t)=>rb(e,t,t!=null);TE.authenticateUser=(e,t)=>rb(e,t);var JU={username:!0,active:!0,role:!0,password:!0},qU=new Map,t5=j8(z8.delete),Jy=J8.get(jy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??y_.HASH_FUNCTION.SHA256,Fi;async function r5(e){let t=QU.cleanAttributes(e,JU),r=jU.addUserValidation(t);if(r)throw new ni(r.message);let n=await b_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new ni(Du.ROLE_NAME_NOT_FOUND(t.role),Ro.NOT_FOUND);if(n.length>1)throw new ni(Du.DUP_ROLES_FOUND(t.role),Ro.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=eb.encrypt(t.password)),t.password=await y_.hash(t.password,Jy),t.hash_function=Jy,t.role=n[0].id;let s=await zU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(Zy.debug(s),await zc(),s.skipped_hashes.length===1)throw new ni(Du.USER_ALREADY_EXISTS(t.username),Ro.CONFLICT);return Xy.signalUserChange(new tb(process.pid)),`${t.username} successfully added`}a(r5,"addUser");async function n5(e){let t=QU.cleanAttributes(e,JU);if(ki.isEmptyOrZeroLength(t.username))throw new Error($U);if(ki.isEmptyOrZeroLength(t.password)&&ki.isEmptyOrZeroLength(t.role)&&ki.isEmptyOrZeroLength(t.active))throw new Error(VU);if(!ki.isEmpty(t.password)&&ki.isEmptyOrZeroLength(t.password.trim()))throw new Error(KU);if(!ki.isEmpty(t.active)&&!ki.isBoolean(t.active))throw new Error(WU);if(!ki.isEmpty(t.password)&&!ki.isEmptyOrZeroLength(t.password.trim())&&(s5(t.username)&&(t.hash=eb.encrypt(t.password)),t.password=await y_.hash(t.password,Jy)),t.role==="")throw new Error(YU);if(t.role){let n=await b_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ni(Du.ALTER_USER_ROLE_NOT_FOUND(t.role),Ro.NOT_FOUND);if(n.length>1)throw new ni(Du.DUP_ROLES_FOUND(t.role),Ro.CONFLICT);t.role=n[0].id}let r=await zU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await zc(),Xy.signalUserChange(new tb(process.pid)),r}a(n5,"alterUser");function s5(e){let t=!1,r=Fi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(s5,"isClusterUser");async function i5(e){let t=jU.dropUserValidation(e);if(t)throw new ni(t.message);if(Fi.get(e.username)===void 0)throw new ni(Du.USER_NOT_EXIST(e.username),Ro.NOT_FOUND);let r=await t5({table:"hdb_user",schema:"system",hash_values:[e.username]});return Zy.debug(r),await zc(),Xy.signalUserChange(new tb(process.pid)),`${e.username} successfully deleted`}a(i5,"dropUser");async function o5(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Qy.cloneDeep(e.hdb_user);let r=await b_.searchByHash({schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]});return t.role=r[0],delete t.password,delete t.refresh_token,delete t.hash,delete t.hash_function,t}a(o5,"userInfo");async function a5(){let e=await AE();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(a5,"listUsersExternal");async function AE(){let e=await b_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Qy.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await b_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Qy.cloneDeep(s),s.role=t[s.role],c5(s.role),n.set(s.username,s);return n}a(AE,"listUsers");function c5(e){if(!e){Zy.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(X8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(c5,"appendSystemTablesToRole");async function zc(e=void 0){e?Fi=e:Fi=await AE()}a(zc,"setUsersWithRolesCache");async function l5(){return Fi||await zc(),Fi}a(l5,"getUsersWithRolesCache");async function rb(e,t,r=!0){Fi||await zc();let n=Fi.get(e);if(!n){if(!r)return{username:e};throw new ni(zy.GENERIC_AUTH_FAIL,Ro.UNAUTHORIZED)}if(n&&!n.active)throw new ni(zy.USER_INACTIVE,Ro.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(qU.get(t)===n.password)return s;{let i=y_.validate(n.password,t,n.hash_function||y_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)qU.set(t,n.password);else throw new ni(zy.GENERIC_AUTH_FAIL,Ro.UNAUTHORIZED)}}return s}a(rb,"findAndValidateUser");async function u5(){Fi||await zc();for(let[,e]of Fi)if(e.role.role==="super_user")return e}a(u5,"getSuperUser");async function d5(){let e=await AE(),t=Q8.getConfigFromFile(jy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==jy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=eb.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+GU.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+GU.SERVER_SUFFIX.ADMIN,r}a(d5,"getClusterUser");var XU=[];TE.invalidateUser=function(e){for(let t of XU)try{t(e)}catch(r){e5.error("Error invalidating user",r)}};TE.onInvalidatedUser=function(e){XU.push(e)}});var N_=I((vNe,r0)=>{"use strict";var jc=Y(),Qn=(B(),C(G)),f5=mv(),LNe=bs(),MNe=Ao(),_5=Rn(),{validateEvent:ZU}=si(),O_=Wn(),p5=require("process"),{resetDatabases:h5}=(Pe(),C(rt)),m5={[Qn.ITC_EVENT_TYPES.SCHEMA]:E5,[Qn.ITC_EVENT_TYPES.USER]:t0};async function E5(e){let t=ZU(e);if(t){jc.error(t);return}jc.trace("ITC schemaHandler received schema event:",e),await f5(e.message),await g5(e.message)}a(E5,"schemaHandler");async function g5(e){try{O_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),O_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),O_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=h5();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){jc.error(t)}}a(g5,"syncSchemaMetadata");var e0=[];async function t0(e){try{try{O_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),O_.resetReadTxn(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){jc.warn(r)}let t=ZU(e);if(t){jc.error(t);return}jc.trace(`ITC userHandler ${Qn.HDB_ITC_CLIENT_PREFIX}${p5.pid} received user event:`,e),await _5.setUsersWithRolesCache();for(let r of e0)r()}catch(t){jc.error(t)}}a(t0,"userHandler");t0.addListener=function(e){e0.push(e)};r0.exports=m5});var si=I((FNe,s0)=>{"use strict";var xNe=Y(),nb=oe(),S5=(B(),C(G)),{ITC_ERRORS:w_}=Hn(),{parentPort:BNe,threadId:T5,isMainThread:A5,workerData:HNe}=require("worker_threads"),{onMessageFromWorkers:R5,broadcast:kNe,broadcastWithAcknowledgement:y5}=tt();s0.exports={sendItcEvent:b5,validateEvent:n0,SchemaEventMsg:O5,UserEventMsg:N5};var RE;R5(async(e,t)=>{RE=RE||N_(),n0(e),RE[e.type]&&await RE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function b5(e){return!A5&&e.message&&(e.message.originator=T5),y5(e)}a(b5,"sendItcEvent");function n0(e){if(typeof e!="object")return w_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||nb.isEmpty(e.type))return w_.MISSING_TYPE;if(!e.hasOwnProperty("message")||nb.isEmpty(e.message))return w_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||nb.isEmpty(e.message.originator))return w_.MISSING_ORIGIN;if(S5.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return w_.INVALID_EVENT(e.type)}a(n0,"validateEvent");function O5(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(O5,"SchemaEventMsg");function N5(e){this.originator=e}a(N5,"UserEventMsg")});var yo=I(($Ne,c0)=>{"use strict";var i0=(B(),C(G)),qNe=oe(),yE=Y(),o0=_v(),Lu,{sendItcEvent:a0}=si();function w5(e){try{yE.info("signalSchemaChange called with message:",e),Lu=Lu||N_();let t=new o0(i0.ITC_EVENT_TYPES.SCHEMA,e);return Lu.schema(t),a0(t)}catch(t){yE.error(t)}}a(w5,"signalSchemaChange");function I5(e){try{yE.trace("signalUserChange called with message:",e),Lu=Lu||N_();let t=new o0(i0.ITC_EVENT_TYPES.USER,e);return Lu.user(t),a0(t)}catch(t){yE.error(t)}}a(I5,"signalUserChange");c0.exports={signalSchemaChange:w5,signalUserChange:I5}});var bE=I((KNe,u0)=>{"use strict";var l0=oe(),C5=(B(),C(G)),P5=Y(),D5=iE(),L5=sE(),M5=yo(),{SchemaEventMsg:v5}=si(),U5="already exists in";u0.exports=x5;async function x5(e,t,r){if(l0.isEmptyOrZeroLength(r))return r;let n=[];l0.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 B5(e,t.schema,t.name,i)})),s}a(x5,"lmdbCheckForNewAttributes");async function B5(e,t,r,n){let s=new L5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await H5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(U5))P5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(B5,"createNewAttribute");async function H5(e){let t;return t=await D5(e),M5.signalSchemaChange(new v5(process.pid,C5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(H5,"createAttribute")});var Mu=I((WNe,d0)=>{"use strict";var sb=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}};d0.exports=sb});var _0=I((jNe,f0)=>{"use strict";var k5=Mu(),F5=(B(),C(G)).OPERATIONS_ENUM,ib=class extends k5{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(F5.INSERT,r,n,s,i),this.records=t}};f0.exports=ib});var h0=I((JNe,p0)=>{"use strict";var G5=Mu(),q5=(B(),C(G)).OPERATIONS_ENUM,ob=class extends G5{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(q5.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};p0.exports=ob});var E0=I((ZNe,m0)=>{"use strict";var $5=Mu(),V5=(B(),C(G)).OPERATIONS_ENUM,ab=class extends $5{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(V5.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};m0.exports=ab});var S0=I((twe,g0)=>{"use strict";var K5=Mu(),Y5=(B(),C(G)).OPERATIONS_ENUM,cb=class extends K5{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(Y5.DELETE,n,s,t,i),this.original_records=r}};g0.exports=cb});var I_=I((swe,y0)=>{"use strict";var nwe=require("path"),T0=dt(),W5=_0(),z5=h0(),j5=E0(),Q5=S0(),vu=vt(),A0=oe(),{CONFIG_PARAMS:J5}=(B(),C(G)),R0=ce();R0.initSync();var OE=(B(),C(G)).OPERATIONS_ENUM,{getTransactionAuditStorePath:X5}=Et();y0.exports=Z5;async function Z5(e,t){if(R0.get(J5.LOGGING_AUDITLOG)===!1)return;let r=X5(e.schema,e.table),n=await T0.openEnvironment(r,e.table,!0),s=e9(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){T0.initializeDBIs(n,vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,vu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),A0.isEmpty(s.user_name)||n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(Z5,"writeTransaction");function e9(e,t){let r=A0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===OE.INSERT)return new W5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPDATE)return new z5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPSERT)return new j5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.DELETE)return new Q5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(e9,"createTransactionObject")});var lb=I((awe,b0)=>{"use strict";var t9=d_(),owe=vf(),C_=(B(),C(G)),r9=Uf(),n9=kc().insertRecords,s9=dt(),i9=Y(),o9=bE(),{getSchemaPath:a9}=Et(),c9=I_();b0.exports=l9;async function l9(e){try{let{schema_table:t,attributes:r}=t9(e);r9(e,r,t.hash_attribute),e.schema!==C_.SYSTEM_SCHEMA_NAME&&(r.includes(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await o9(e.hdb_auth_header,t,r),s=a9(e.schema,e.table),i=await s9.openEnvironment(s,e.table),o=await n9(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await c9(e,o)}catch(c){i9.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(l9,"lmdbCreateRecords")});var w0=I((lwe,N0)=>{"use strict";var O0=(B(),C(G)),u9=lb(),d9=vf(),f9=require("fs-extra"),{getSchemaPath:_9}=Et();N0.exports=p9;async function p9(e){let t=[{name:e.schema,createddate:Date.now()}],r=new d9(O0.SYSTEM_SCHEMA_NAME,O0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await u9(r),await f9.mkdirp(_9(e.schema))}a(p9,"lmdbCreateSchema")});var C0=I((dwe,I0)=>{"use strict";var ub=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}};I0.exports=ub});var M0=I((mwe,L0)=>{"use strict";var P0=dt(),db=pn(),fb=Hn().LMDB_ERRORS_ENUM,h9=vt(),D0=Y(),_we=oe(),m9=require("lmdb"),E9=C0(),g9=(B(),C(G)),{OVERFLOW_MARKER:pwe,MAX_SEARCH_KEY_LENGTH:hwe}=h9,S9=g9.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function T9(e,t,r,n){if(db.validateEnv(e),t===void 0)throw new Error(fb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(fb.IDS_REQUIRED):new Error(fb.IDS_MUST_BE_ITERABLE);try{let s=P0.listDBIs(e);P0.initializeDBIs(e,t,s);let i=new E9,o,c=[],l=[];for(let p=0,_=r.length;p<_;p++)try{o=r[p];let h=e.dbis[t].get(o);if(!h||n&&h[S9]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,m9.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let A=s[g];if(!h.hasOwnProperty(A)||A===t)continue;let E=e.dbis[A],R=h[A];if(R!=null)try{let N=db.getIndexedValues(R);if(N)for(let v=0,k=N.length;v<k;v++)E.remove(N[v],o)}catch{D0.warn(`cannot delete from attribute: ${A}, ${R}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(h)}catch(h){D0.warn(h),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let p=0,_=f.length;p<_;p++)f[p]===!0?i.deleted.push(l[p]):(i.skipped.push(l[p]),u.push(p));let d=0;for(let p=0;p<u.length;p++){let _=u[p];i.original_records.splice(_-d,1),d++}return i.txn_time=db.getNextMonotonicTime(),i}catch(s){throw s}}a(T9,"deleteRecords");L0.exports={deleteRecords:T9}});var P_=I((gwe,U0)=>{"use strict";var Uu=oe(),A9=M0(),R9=dt(),{getSchemaPath:y9}=Et(),b9=I_(),O9=Y();U0.exports=N9;async function N9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Uu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Uu.isEmptyOrZeroLength(e.hash_values)&&!Uu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Uu.isEmpty(l)||e.hash_values.push(l)}}if(Uu.isEmptyOrZeroLength(e.hash_values))return v0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Uu.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=y9(e.schema,e.table),i=await R9.openEnvironment(s,e.table),o=await A9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await b9(e,o)}catch(c){O9.error(`unable to write transaction due to ${c.message}`)}return v0(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(N9,"lmdbDeleteRecords");function v0(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(v0,"createDeleteResponse")});var pb=I((Awe,x0)=>{"use strict";var w9=(B(),C(G)),Twe=pn();function _b(e,t){let r=Object.create(null);if(t.length===1&&w9.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(_b,"parseRow");function I9(e,t,r,n){let s=_b(r,e);n.push(s)}a(I9,"searchAll");function C9(e,t,r,n){let s=_b(r,e);n[t]=s}a(C9,"searchAllToMap");function P9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(P9,"iterateDBI");function Qc(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(Qc,"pushResults");function D9(e,t,r,n,s,i){t.toString().endsWith(e)&&Qc(t,r,n,s,i)}a(D9,"endsWith");function L9(e,t,r,n,s,i){t.toString().includes(e)&&Qc(t,r,n,s,i)}a(L9,"contains");function M9(e,t,r,n,s,i){t>e&&Qc(t,r,n,s,i)}a(M9,"greaterThanCompare");function v9(e,t,r,n,s,i){t>=e&&Qc(t,r,n,s,i)}a(v9,"greaterThanEqualCompare");function U9(e,t,r,n,s,i){t<e&&Qc(t,r,n,s,i)}a(U9,"lessThanCompare");function x9(e,t,r,n,s,i){t<=e&&Qc(t,r,n,s,i)}a(x9,"lessThanEqualCompare");x0.exports={parseRow:_b,searchAll:I9,searchAllToMap:C9,iterateDBI:P9,endsWith:D9,contains:L9,greaterThanCompare:M9,greaterThanEqualCompare:v9,lessThanCompare:U9,lessThanEqualCompare:x9,pushResults:Qc}});var xu=I((Nwe,$0)=>{"use strict";var Ca=dt(),ywe=Y(),Jn=pn(),NE=vt(),Kt=Hn().LMDB_ERRORS_ENUM,bwe=oe(),B9=(B(),C(G)),wE=pb(),{parseRow:H9}=wE,Owe=require("lmdb"),{OVERFLOW_MARKER:B0,MAX_SEARCH_KEY_LENGTH:k9}=NE;function H0(e,t,r,n=!1,s=void 0,i=void 0){return Jc(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(H0,"iterateFullIndex");function D_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Jc(e,t,r,(f,d,p,_)=>{let E={transaction:f,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return _===r?(E.values=!1,d.getRange(E).map(R=>({value:R}))):d.getRange(E)})}a(D_,"iterateRangeBetween");function Jc(e,t,r,n){let s=e.database||e,i=Ca.openDBI(s,r);i[NE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Ca.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Jc,"setupTransaction");function k0(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(B0)){if(!s)if(r)s=Ca.openDBI(e,r);else{let l=Ca.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=Ca.openDBI(e,l[u]),!s[NE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(k0,"getOverflowCheck");function F9(e,t,r,n=!1,s=void 0,i=void 0){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);return Jc(e,t,t,(o,c,l)=>(IE(r),r=L_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>H9(u.value,r))))}a(F9,"searchAll");function G9(e,t,r,n=!1,s=void 0,i=void 0){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);IE(r),r=L_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of H0(e,t,t,n,s,i))o.set(c,wE.parseRow(l,r));return o}a(G9,"searchAllToMap");function q9(e,t,r=!1,n=void 0,s=void 0){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=H0(e,void 0,t,r,n,s),c=o.transaction,l=k0(c.database,c,void 0,t);for(let{key:u,value:f}of o){let d=l(u,f);i[d]===void 0&&(i[d]=[]),i[d].push(f)}return i}a(q9,"iterateDBI");function $9(e,t){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);return Ca.statDBI(e,t).entryCount}a($9,"countAll");function V9(e,t,r,n,s=!1,i=void 0,o=void 0){return Pa(e,r,n),Jc(e,t,r,(c,l,u,f)=>(n=Jn.convertKeyValueToWrite(n),f===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(V9,"equals");function K9(e,t,r){return Pa(e,t,r),Ca.openDBI(e,t).getValuesCount(r)}a(K9,"count");function Y9(e,t,r,n,s=!1,i=void 0,o=void 0){return Pa(e,r,n),Jc(e,null,r,(c,l)=>{n=Jn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let p of l.getKeys({transaction:c,start:n}))if(!p.startsWith(n)){d=p;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),f=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(p=>{let{key:_}=p;if(_!==d){if(_.toString().startsWith(n))return p;if(u===!0)return f.DONE}}),f.filter(p=>p)}else return f=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(u===!0)return f.DONE}),u?f:f.filter(d=>d)})}a(Y9,"startsWith");function W9(e,t,r,n,s=!1,i=void 0,o=void 0){return F0(e,t,r,n,s,i,o,!0)}a(W9,"endsWith");function F0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Pa(e,r,n),Jc(e,null,r,(l,u,f,d)=>{let p=k0(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(_=>{let h=_.toString();return h.endsWith(B0)?u.getValues(_,{transaction:l}).map(S=>{let g=p(_,S);if(c?g.endsWith(n):g.includes(n))return{key:g,value:S}}).filter(S=>S):(c?h.endsWith(n):h.includes(n))?u[NE.DBI_DEFINITION_NAME].is_hash_attribute?{key:_,value:_}:u.getValues(_,{transaction:l}).map(S=>({key:_,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(F0,"contains");function z9(e,t,r,n,s=!1,i=void 0,o=void 0){Pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),D_(e,t,r,n,l,s,i,o,!0,!1)}a(z9,"greaterThan");function j9(e,t,r,n,s=!1,i=void 0,o=void 0){Pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),D_(e,t,r,n,l,s,i,o,!1,!1)}a(j9,"greaterThanEqual");function Q9(e,t,r,n,s=!1,i=void 0,o=void 0){Pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),D_(e,t,r,l,n,s,i,o,!1,!0)}a(Q9,"lessThan");function J9(e,t,r,n,s=!1,i=void 0,o=void 0){Pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),D_(e,t,r,l,n,s,i,o,!1,!1)}a(J9,"lessThanEqual");function X9(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Jn.validateEnv(e),r===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Kt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Kt.END_VALUE_REQUIRED);if(n=Jn.convertKeyValueToWrite(n),s=Jn.convertKeyValueToWrite(s),n>s)throw new Error(Kt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return D_(e,t,r,n,s,i,o,c)}a(X9,"between");function Z9(e,t,r,n){Jn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),r=L_(s,r),n===void 0)throw new Error(Kt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=wE.parseRow(c,r)),o}a(Z9,"searchByHash");function e7(e,t,r){Jn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Kt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(e7,"checkHashExists");function t7(e,t,r,n,s=[]){return q0(e,t,r,n,s),G0(e,t,r,n,s).map(i=>i[1])}a(t7,"batchSearchByHash");function r7(e,t,r,n,s=[]){q0(e,t,r,n,s);let i=new Map;for(let[o,c]of G0(e,t,r,n,s))i.set(o,c);return i}a(r7,"batchSearchByHashToMap");function G0(e,t,r,n,s=[]){return Jc(e,t,t,(i,o,c)=>{r=L_(c,r);let l=r.length<3;return n.map(u=>{let f=c.dbis[t].get(u,{transaction:i,lazy:l});if(f)return[u,wE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(G0,"batchHashSearch");function q0(e,t,r,n,s){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),n==null)throw new Error(Kt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Kt.IDS_MUST_BE_ITERABLE)}a(q0,"initializeBatchSearchByHash");function IE(e){if(!Array.isArray(e))throw e===void 0?new Error(Kt.FETCH_ATTRIBUTES_REQUIRED):new Error(Kt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(IE,"validateFetchAttributes");function Pa(e,t,r){if(Jn.validateEnv(e),t===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Kt.SEARCH_VALUE_REQUIRED);if(r?.length>k9)throw new Error(Kt.SEARCH_VALUE_TOO_LARGE)}a(Pa,"validateComparisonFunctions");function L_(e,t){return t.length===1&&B9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Ca.listDBIs(e)),t}a(L_,"setGetWholeRowAttributes");$0.exports={searchAll:F9,searchAllToMap:G9,count:K9,countAll:$9,equals:V9,startsWith:Y9,endsWith:W9,contains:F0,searchByHash:Z9,setGetWholeRowAttributes:L_,batchSearchByHash:t7,batchSearchByHashToMap:r7,checkHashExists:e7,iterateDBI:q9,greaterThan:z9,greaterThanEqual:j9,lessThan:Q9,lessThanEqual:J9,between:X9}});var Bu=I((Iwe,z0)=>{var V0=require("lodash"),K0=ut(),ke=require("joi"),n7=oe(),{hdb_schema_table:M_,checkValidTable:Y0,hdb_table:W0,hdb_database:CE}=vi(),{handleHDBError:s7,hdb_errors:i7}=pe(),{getDatabases:o7}=(Pe(),C(rt)),{HTTP_STATUS_CODES:a7}=i7,c7=ke.object({database:CE,schema:CE,table:W0,search_attribute:M_,search_value:ke.any().required(),get_attributes:ke.array().min(1).items(ke.alternatives(M_,ke.object())).optional(),desc:ke.bool(),limit:ke.number().integer().min(1),offset:ke.number().integer().min(0)}),l7=ke.object({database:CE,schema:CE,table:W0,operator:ke.string().valid("and","or").default("and").lowercase(),offset:ke.number().integer().min(0),limit:ke.number().integer().min(1),get_attributes:ke.array().min(1).items(ke.alternatives(M_,ke.object())).optional(),sort:ke.object({attribute:ke.alternatives(M_,ke.array().min(1)),descending:ke.bool().optional()}).optional(),conditions:ke.array().min(1).items(ke.alternatives(ke.object({operator:ke.string().valid("and","or").default("and").lowercase(),conditions:ke.array()}),ke.object({search_attribute:ke.alternatives(M_,ke.array().min(1)),search_type:ke.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:ke.when("search_type",{switch:[{is:"equals",then:ke.any()},{is:"between",then:ke.array().items(ke.alternatives([ke.string(),ke.number()])).length(2)}],otherwise:ke.alternatives(ke.string(),ke.number())}).required()}))).required()});z0.exports=function(e,t){let r=null;switch(t){case"value":r=K0.validateBySchema(e,c7);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(Y0("database",e.schema)),i(Y0("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=K0.validateBySchema(e,l7);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=n7.checkGlobalSchemaTable(e.schema,e.table);if(s)return s7(new Error,s,a7.NOT_FOUND);let o=o7()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(f=>{for(let d=0,p=f.conditions.length;d<p;d++){let _=f.conditions[d];_.conditions?l(_):c.push(_.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=V0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!V0.some(o,d=>d===f||d.attribute===f||d.attribute===f.attribute));if(u&&u.length>0){let f=u.join(", ");return f=f.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${f}'`)}}return r}});var hb=I((Pwe,j0)=>{"use strict";var u7=dt(),d7=Bu(),{getSchemaPath:f7}=Et();j0.exports=_7;function _7(e){let t=d7(e,"hashes");if(t)throw t;let r=f7(e.schema,e.table);return u7.openEnvironment(r,e.table)}a(_7,"initialize")});var mb=I((Lwe,Q0)=>{"use strict";var p7=xu(),h7=hb();Q0.exports=m7;async function m7(e){let t=await h7(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return p7.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(m7,"lmdbGetDataByHash")});var Hu=I((vwe,J0)=>{"use strict";var Eb=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};J0.exports=Eb});var Z0=I((Bwe,X0)=>{"use strict";var xwe=Hu(),E7=xu(),g7=hb();X0.exports=S7;async function S7(e){let t=await g7(e),r=global.hdb_schema[e.schema][e.table];return E7.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(S7,"lmdbSearchByHash")});var ii=I((kwe,ex)=>{"use strict";var gb=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,f=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=f}};ex.exports=gb});var PE=I((Gwe,ox)=>{"use strict";var Qr=xu(),T7=dt(),A7=oe(),Fe=vt(),Xc=(B(),C(G)),R7=Eo(),tx=Hn().LMDB_ERRORS_ENUM,{getSchemaPath:y7}=Et(),bo=Xc.SEARCH_WILDCARDS;async function b7(e,t,r){let n;e.schema===Xc.SYSTEM_SCHEMA_NAME?n=R7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=ix(e,n.hash_attribute,r,t);return nx(e,s,n.hash_attribute,r)}a(b7,"prepSearch");async function nx(e,t,r,n){let s=y7(e.schema,e.table),i=await T7.openEnvironment(s,e.table),o=sx(i,e,t,r),c=o.transaction||i;if([Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Fe.SEARCH_TYPES.SEARCH_ALL,Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(O7(e,r)===!1){let f=e.search_attribute;if(f===r)return n?rx(o,()=>!0):o.map(p=>({[r]:p.key}));let d=a(p=>({[r]:p.value,[f]:p.key}),"toObject");return n?rx(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?Qr.batchSearchByHashToMap(c,r,e.get_attributes,u):Qr.batchSearchByHash(c,r,e.get_attributes,u)}a(nx,"executeSearch");function sx(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case Fe.SEARCH_TYPES.EQUALS:s=Qr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.CONTAINS:s=Qr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.ENDS_WITH:case Fe.SEARCH_TYPES._ENDS_WITH:s=Qr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.STARTS_WITH:case Fe.SEARCH_TYPES._STARTS_WITH:s=Qr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Qr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Qr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.SEARCH_ALL:return Qr.searchAll(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Qr.searchAllToMap(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.BETWEEN:s=Qr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN:case Fe.SEARCH_TYPES._GREATER_THAN:s=Qr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN_EQUAL:case Fe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Qr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN:case Fe.SEARCH_TYPES._LESS_THAN:s=Qr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN_EQUAL:case Fe.SEARCH_TYPES._LESS_THAN_EQUAL:s=Qr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(sx,"searchByType");function rx(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(rx,"createMapFromIterable");function O7(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(O7,"checkToFetchMore");function ix(e,t,r,n){if(A7.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),bo.indexOf(s)>-1)return r===!0?Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Fe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(bo[0])<0&&s.indexOf(bo[1])<0)return c===!0?r===!0?Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Fe.SEARCH_TYPES.EQUALS;if(bo.indexOf(i)>=0&&bo.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Fe.SEARCH_TYPES.CONTAINS;if(bo.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Fe.SEARCH_TYPES.ENDS_WITH;if(bo.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Fe.SEARCH_TYPES.STARTS_WITH;if(s.includes(bo[0])||s.includes(bo[1]))return Fe.SEARCH_TYPES.EQUALS;throw new Error(tx.UNKNOWN_SEARCH_TYPE)}else switch(n){case Xc.VALUE_SEARCH_COMPARATORS.BETWEEN:return Fe.SEARCH_TYPES.BETWEEN;case Xc.VALUE_SEARCH_COMPARATORS.GREATER:return Fe.SEARCH_TYPES.GREATER_THAN;case Xc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Fe.SEARCH_TYPES.GREATER_THAN_EQUAL;case Xc.VALUE_SEARCH_COMPARATORS.LESS:return Fe.SEARCH_TYPES.LESS_THAN;case Xc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Fe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(tx.UNKNOWN_SEARCH_TYPE)}}a(ix,"createSearchTypeFromSearchObject");ox.exports={executeSearch:nx,createSearchTypeFromSearchObject:ix,prepSearch:b7,searchByType:sx}});var cx=I((Vwe,ax)=>{"use strict";var $we=ii(),N7=Bu(),w7=oe(),I7=(B(),C(G)),C7=PE();ax.exports=P7;function P7(e,t){if(!w7.isEmpty(t)&&I7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=N7(e,"value");if(n)throw n;return C7.prepSearch(e,t,!0)}a(P7,"lmdbGetDataByValue")});var v_=I((Wwe,lx)=>{"use strict";var Ywe=ii(),D7=Bu(),L7=oe(),M7=(B(),C(G)),v7=PE();lx.exports=U7;async function U7(e,t){if(!L7.isEmpty(t)&&M7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=D7(e,"value");if(n)throw n;return v7.prepSearch(e,t,!1)}a(U7,"lmdbSearchByValue")});var dx=I((Qwe,ux)=>{"use strict";var jwe=vt(),Sb=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}},Tb=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Ab=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};ux.exports={SearchByConditionsObject:Sb,SearchCondition:Tb,SortAttribute:Ab}});var mx=I((eIe,hx)=>{"use strict";var Xwe=dx().SearchByConditionsObject,x7=ii(),B7=Bu(),Rb=xu(),DE=vt(),{Resource:Zwe}=(ga(),C(mR)),px=PE(),H7=pb(),k7=require("lodash"),{getSchemaPath:F7}=Et(),fx=dt(),{handleHDBError:G7,hdb_errors:q7}=pe(),{HTTP_STATUS_CODES:$7}=q7,V7=1e8;hx.exports=K7;async function K7(e){let t=B7(e,"conditions");if(t)throw G7(t,t.message,$7.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=F7(e.schema,e.table),n=await fx.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)fx.openDBI(n,u.search_attribute);let i=k7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===DE.SEARCH_TYPES.EQUALS?u.estimated_count=Rb.count(n,u.search_attribute,u.search_value):f===DE.SEARCH_TYPES.CONTAINS||f===DE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=V7}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await _x(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],f=i.slice(1).map(px.filterByType),d=f.length,p=Rb.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(_=>u.get(_,{transaction:o,lazy:!0})),d>0&&(l=l.filter(_=>{for(let h=0;h<d;h++)if(!f[h](_))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(_=>H7.parseRow(_,p))}else{for(let d=1;d<i.length;d++){let p=i[d],_=await _x(o,e,p,s.hash_attribute);c=c.concat(_)}let u=new Set,f=e.offset||0;c=c.filter(d=>u.has(d)?!1:(u.add(d),!0)).slice(f,e.limit&&e.limit+f),l=Rb.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(K7,"lmdbSearchByConditions");async function _x(e,t,r,n){let s=new x7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===DE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,px.searchByType(e,s,i,n).map(o=>o.value)}a(_x,"executeConditionSearch")});var U_=I((rIe,Ex)=>{"use strict";var Y7=(B(),C(G)).OPERATIONS_ENUM,yb=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=Y7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Ex.exports=yb});var bb=I((sIe,Ox)=>{"use strict";var Ax=ii(),Rx=U_(),yx=v_(),bx=P_(),bn=(B(),C(G)),gx=oe(),Sx=dt(),{getTransactionAuditStorePath:W7,getSchemaPath:z7}=Et(),Tx=Y();Ox.exports=j7;async function j7(e){try{if(gx.isEmpty(global.hdb_schema[e.schema])||gx.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await Q7(e),await J7(e);let t=z7(e.schema,e.table);try{await Sx.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Tx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=W7(e.schema,e.table);await Sx.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Tx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(j7,"lmdbDropTable");async function Q7(e){let t=new Ax(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await yx(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 Rx(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await bx(s)}a(Q7,"deleteAttributesFromSystem");async function J7(e){let t=new Ax(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await yx(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 Rx(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await bx(s)}catch(i){throw i}}a(J7,"dropTableFromSystem")});var wx=I((oIe,Nx)=>{"use strict";var X7=require("fs-extra"),Z7=ii(),eee=Hu(),tee=U_(),ree=bb(),nee=P_(),see=mb(),iee=v_(),Oo=(B(),C(G)),{getSchemaPath:oee}=Et(),{handleHDBError:aee,hdb_errors:cee}=pe(),{HDB_ERROR_MSGS:lee,HTTP_STATUS_CODES:uee}=cee;Nx.exports=dee;async function dee(e){let t;try{t=await fee(e.schema);let r=new Z7(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await iee(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await ree(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new tee(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await nee(s);let i=oee(t);await X7.remove(i)}catch(r){throw r}}a(dee,"lmdbDropSchema");async function fee(e){let t=new eee(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await see(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw aee(new Error,lee.SCHEMA_NOT_FOUND(e),uee.NOT_FOUND,void 0,void 0,!0);return n}a(fee,"validateDropSchema")});var x_=I((cIe,Ix)=>{"use strict";var Ob=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Ix.exports=Ob});var wb=I((dIe,Cx)=>{"use strict";var _ee=require("fs-extra"),LE=dt(),{getTransactionAuditStorePath:pee}=Et(),Nb=vt(),uIe=x_();Cx.exports=hee;async function hee(e){let t;try{let r=pee(e.schema,e.table);await _ee.mkdirp(r),t=await LE.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{LE.createDBI(t,Nb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),LE.createDBI(t,Nb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),LE.createDBI(t,Nb.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(hee,"createTransactionsAuditEnvironment")});var Lx=I((pIe,Dx)=>{"use strict";var Ib=(B(),C(G)),Px=dt(),mee=kc(),{getSystemSchemaPath:Eee,getSchemaPath:gee}=Et(),_Ie=Eo(),See=iE(),Cb=sE(),Tee=Y(),Aee=wb();Dx.exports=Ree;async function Ree(e,t){let r=gee(t.schema,t.table),n=new Cb(t.schema,t.table,Ib.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Cb(t.schema,t.table,Ib.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Cb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Px.createEnvironment(r,t.table),e!==void 0){let o=await Px.openEnvironment(Eee(),Ib.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await mee.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 Pb(n),await Pb(s),await Pb(i)}await Aee(t)}catch(o){throw o}}a(Ree,"lmdbCreateTable");async function Pb(e){try{await See(e)}catch(t){Tee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Pb,"createAttribute")});var vx=I((mIe,Mx)=>{"use strict";var yee=d_(),bee=Uf(),Oee=bE(),B_=(B(),C(G)),Nee=kc().updateRecords,wee=dt(),{getSchemaPath:Iee}=Et(),Cee=I_(),Pee=Y();Mx.exports=Dee;async function Dee(e){try{let{schema_table:t,attributes:r}=yee(e);bee(e,r,t.hash_attribute),e.schema!==B_.SYSTEM_SCHEMA_NAME&&(r.includes(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(B_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(B_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Oee(e.hdb_auth_header,t,r),s=Iee(e.schema,e.table),i=await wee.openEnvironment(s,e.table),o=await Nee(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Cee(e,o)}catch(c){Pee.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(Dee,"lmdbUpdateRecords")});var xx=I((gIe,Ux)=>{"use strict";var Lee=(B(),C(G)).OPERATIONS_ENUM,Db=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Lee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Ux.exports=Db});var Hx=I((AIe,Bx)=>{"use strict";var TIe=xx(),Mee=d_(),vee=Uf(),Uee=bE(),H_=(B(),C(G)),xee=kc().upsertRecords,Bee=dt(),{getSchemaPath:Hee}=Et(),kee=I_(),Fee=Y(),{handleHDBError:Gee,hdb_errors:qee}=pe();Bx.exports=$ee;async function $ee(e){let t;try{t=Mee(e)}catch(l){throw Gee(l,l.message,qee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;vee(e,n,r.hash_attribute),e.schema!==H_.SYSTEM_SCHEMA_NAME&&(n.includes(H_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(H_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(H_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(H_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Uee(e.hdb_auth_header,r,n),i=Hee(e.schema,e.table),o=await Bee.openEnvironment(i,e.table),c=await xee(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await kee(e,c)}catch(l){Fee.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($ee,"lmdbUpsertRecords")});var Fx=I((yIe,kx)=>{"use strict";var Lb=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};kx.exports=Lb});var qx=I((OIe,Gx)=>{"use strict";var Mb=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}};Gx.exports=Mb});var Kx=I((IIe,Vx)=>{"use strict";var vb=dt(),{getTransactionAuditStorePath:Vee}=Et(),wIe=Fx(),k_=vt(),Kee=oe(),$x=qx(),Yee=require("util").promisify,Wee=Yee(setTimeout),zee=1e4,jee=100;Vx.exports=Qee;async function Qee(e){let t=Vee(e.schema,e.table),r=await vb.openEnvironment(t,e.table,!0),n=vb.listDBIs(r);vb.initializeDBIs(r,k_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new $x;do s=await Jee(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 Wee(jee);while(s.transactions_deleted>0);return i}a(Qee,"deleteAuditLogsBefore");async function Jee(e,t){let r=new $x;try{let n=e.dbis[k_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[k_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Kee.isEmpty(c)||(s=e.dbis[k_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[k_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>zee)break}return await s,r}catch(n){throw n}}a(Jee,"deleteTransactions")});var Wx=I((PIe,Yx)=>{"use strict";var Ub=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};Yx.exports=Ub});var jx=I((MIe,zx)=>{"use strict";var Xee=ii(),Zee=U_(),LIe=Wx(),Gi=(B(),C(G)),ete=oe(),xb=dt(),tte=Eo(),rte=v_(),nte=P_(),{getSchemaPath:ste}=Et();zx.exports=ite;async function ite(e,t=!0){let r;e.schema===Gi.SYSTEM_SCHEMA_NAME?r=tte[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await ate(e),s=ste(e.schema,e.table),i=await xb.openEnvironment(s,e.table);return t===!0&&await ote(e,i,r.hash_attribute),xb.dropDBI(i,e.attribute),n}a(ite,"lmdbDropAttribute");async function ote(e,t,r){let n=xb.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let f in c)f!==i&&(u[f]=c[f]);s=t.dbis[r].put(o,u,l)}await s}a(ote,"removeAttributeFromAllObjects");async function ate(e){let t=new Xee(Gi.SYSTEM_SCHEMA_NAME,Gi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Gi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Gi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Gi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await rte(t)).filter(o=>o[Gi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(ete.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Gi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Zee(Gi.SYSTEM_SCHEMA_NAME,Gi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return nte(i)}a(ate,"dropAttributeFromSystem")});var tB=I((xIe,eB)=>{"use strict";var Bb=dt(),ku=vt(),UIe=pn(),Hb=(B(),C(G)),Qx=oe(),{getTransactionAuditStorePath:cte}=Et(),lte=xu(),ME=Mu(),ute=Y();eB.exports=dte;async function dte(e){let t=cte(e.schema,e.table),r=await Bb.openEnvironment(t,e.table,!0),n=Bb.listDBIs(r);Bb.initializeDBIs(r,ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Hb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Jx(r,e.search_values);case Hb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,_te(r,e.search_values,s);case Hb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return fte(r,e.search_values);default:return Jx(r)}}a(dte,"readAuditLog");function Jx(e,t=[0,Date.now()]){Qx.isEmpty(t[0])&&(t[0]=0),Qx.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new ME,s))}a(Jx,"searchTransactionsByTimestamp");function fte(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[ku.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,Zx(e,i))}return Object.fromEntries(r)}a(fte,"searchTransactionsByUsername");function _te(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=lte.equals(e,ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ku.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let p=Number(d);n.has(p)?n.get(p).push(u.toString()):n.set(p,[u.toString()])}}let s=Array.from(n.keys()),i=Zx(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);Xx(l,"records",r,f,o),Xx(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(_te,"searchTransactionsByHashValues");function Xx(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),f=u[u.length-1];if(f.timestamp===i)f[t]=[c];else{let d=new ME(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new ME(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(Xx,"loopRecords");function Zx(e,t){let r=[];try{let n=e.dbis[ku.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new ME,i);r.push(o)}}catch(i){ute.warn(i)}return r}catch(n){throw n}}a(Zx,"batchSearchTransactions")});var nB=I((FIe,rB)=>{"use strict";var{getSchemaPath:HIe}=Et(),kIe=dt(),{database:pte}=(Pe(),C(rt));rB.exports={writeTransaction:hte};async function hte(e,t,r){return pte({database:e,table:t}).transaction(r)}a(hte,"writeTransaction")});var aB=I((qIe,oB)=>{"use strict";var{getSchemaPath:sB}=Et(),iB=dt();oB.exports={flush:mte,resetReadTxn:Ete};async function mte(e,t){return(await iB.openEnvironment(sB(e,t),t.toString())).flushed}a(mte,"flush");async function Ete(e,t){try{(await iB.openEnvironment(sB(e,t),t.toString())).resetReadTxn()}catch{}}a(Ete,"resetReadTxn")});var dB=I((VIe,uB)=>{"use strict";var{Readable:gte}=require("stream"),{getDatabases:Ste}=(Pe(),C(rt)),{readSync:Tte,openSync:Ate,createReadStream:cB}=require("fs"),{open:Rte}=require("lmdb"),lB=s_(),yte=i_(),{AUDIT_STORE_OPTIONS:bte}=(ho(),C(fB)),{INTERNAL_DBIS_NAME:Ote,AUDIT_STORE_NAME:Nte}=vt();uB.exports=Ite;var kb=32768,wte=100;async function Ite(e){let t=e.database||e.schema||"data",r=Ste()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let f=u.dbisDB,d=Rte({noSync:!0,maxDbs:yte.MAX_DBS}),p,_=d.openDB(Ote,new lB(!1)),h=f.useReadTransaction(),S=0,g=a(async function(E,R){R.encoding="binary",R.encoder=void 0;let N=d.openDB(E,R),v=f.openDB(E,R);for(let{key:k,version:F,value:K}of v.getRange({start:null,transaction:h,versions:v.useVersions}))p=N.put(k,K,F),S++%wte===0&&(await new Promise(re=>setTimeout(re,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:E,value:R}of f.getRange({transaction:h,start:!1}))if(s.some(N=>E.startsWith?.(N+"/"))){_.put(E,R);let[,N]=E.split("/"),v=!N,k=new lB(!v,v);await g(E,k)}e.include_audit&&await g(Nte,{...bte}),await p;let A=cB(d.path);return A.headers=l(),A.on("close",()=>{h.done(),d.close()}),A}let o=r[Object.keys(r)[0]].primaryStore,c=Ate(o.path);return o.transaction(()=>{let u=Buffer.alloc(kb);Tte(c,u,0,kb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=cB(null,{fd:c,start:kb}),p=new gte.from(async function*(){yield u;for await(let _ of d)f.openTimer&&(f.openTimer=0),yield _;f.done()}());return p.headers=l(),p});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(Ite,"getBackup")});var hB=I((YIe,pB)=>{"use strict";var Cte=Y(),{handleHDBError:Pte}=pe(),Dte=bM(),Lte=iE(),Mte=lb(),vte=w0(),Ute=P_(),xte=mb(),Bte=Z0(),Hte=cx(),kte=v_(),Fte=mx(),Gte=wx(),qte=Lx(),$te=vx(),Vte=Hx(),Kte=Kx(),Yte=bb(),Wte=jx(),zte=tB(),jte=nB(),_B=aB(),Qte=dB(),Fb=class extends Dte{static{a(this,"LMDBBridge")}async searchByConditions(t){return Fte(t)}async getDataByHash(t){return await xte(t)}async searchByHash(t){return await Bte(t)}async getDataByValue(t,r){return await Hte(t,r)}async searchByValue(t){return await kte(t)}async createSchema(t){return await vte(t)}async dropSchema(t){return await Gte(t)}async createTable(t,r){return await qte(t,r)}async dropTable(t){return await Yte(t)}async createAttribute(t){return await Lte(t)}async createRecords(t){return await Mte(t)}async updateRecords(t){return await $te(t)}async upsertRecords(t){try{return await Vte(t)}catch(r){throw Pte(r,null,null,Cte.ERR,r)}}async deleteRecords(t){return await Ute(t)}async dropAttribute(t){return await Wte(t)}async deleteAuditLogsBefore(t){return await Kte(t)}async readAuditLog(t){return await zte(t)}writeTransaction(t,r,n){return jte.writeTransaction(t,r,n)}flush(t,r){return _B.flush(t,r)}resetReadTxn(t,r){return _B.resetReadTxn(t,r)}getBackup(t){return Qte(t)}};pB.exports=Fb});var qb={};ve(qb,{add:()=>vE,applyReverse:()=>mB,getRecordAtTime:()=>Gb,rebuildUpdateBefore:()=>UE});function vE(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function UE(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,vE(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function mB(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Jte[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=EB}}function Gb(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=Nt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":mB(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===EB&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=Nt(l),f;switch(u.type){case"put":f=u.getValue(r);break;case"patch":f=u.getValue(r);break}for(let d in f)o[d]&&(s[d]=f[d],o[d]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var Jte,EB,xE=be(()=>{ho();a(vE,"add");vE.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};Jte={add:vE};a(UE,"rebuildUpdateBefore");a(mB,"applyReverse");EB={};a(Gb,"getRecordAtTime")});function On(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function FE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a string, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(p=>typeof p=="string")||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a string, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="number"||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a number, attempt to assign ${p}`);On(this)[l]=d},"set");break;case"Int":u=a(function(d){let p=d?.__op__?d.value:d;if(!(p>>0===p||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs((p>>0)-p)<=1)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new Xn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Long":u=a(function(d){let p=d?.__op__?d.value:d;if(!(Math.round(p)===d&&Math.abs(p)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs(p)<=9007199254740992)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new Xn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="bigint"||d==null&&c.nullable!==!1))if(typeof p=="string"||typeof p=="number")p=BigInt(p),d?.__op__?d.value=p:d=p;else throw new Xn.ClientError(`${l} must be a number, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new Xn.ClientError(`${l} must be a Date, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Pi||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){On(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new Xn.ClientError(`${l} must be an object, attempt to assign ${d}`);On(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let _=d[l];if(_?.__op__){let h=this.getRecord()?.[l];return _.update(h)}return _}let p=this.getRecord()?.[l];if(p&&typeof p=="object"){let _=$b(p,c);if(_)return d||this._setChanges(d=Object.create(null)),d[l]=_}return p},set:u,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,n[l]=f,(!(l in r)||Object.getOwnPropertyDescriptor(r,l)?.get?.isAttribute)&&Object.defineProperty(r,l,f)}i("getProperty",function(c){let l=n[c];if(l)return l.get.call(this);let u=this.getChanges();return u?.[c]!==void 0?u[c]:this.getRecord()?.[c]}),i("set",function(c,l){let u=n[c];if(u)return u.set.call(this,l);if(t.sealed)throw new Xn.ClientError("Can not add a property to a sealed table schema");On(this)[c]=l}),i("deleteProperty",function(c){On(this)[c]=void 0}),i("toJSON",function(){let c=this.getChanges?.(),l;for(let f in c){l||(l={...this.getRecord()});let d=c[f];if(d?.__op__){let p=l[f];d=d.update(p)}l[f]=d}return Object.keys(this).length>0&&(l||(l={...this.getRecord()}),Object.assign(l,this)),l||this.getRecord()}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty),r.then||i("then",null);function i(c,l){Object.defineProperty(r,c,{value:l,configurable:!0})}a(i,"setMethod");let o=r;do{let c=Object.getPrototypeOf(o);if(c===Object.prototype){Object.setPrototypeOf(o,SB);break}o=c}while(o&&o!==SB)}function $b(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends F_{static{a(this,"TrackedObject")}},FE(r,t)),new r(e)):new F_(e);case Array:let n=new HE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=$b(o,t?.elements)),n[s]=o}return n;default:return e}}function GE(e){let t=e.getChanges?.(),r;for(let s in t){r||(r=e.getRecord?{...e.getRecord()}:{});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=GE(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=e.getRecord?{...e.getRecord()}:{}),Object.assign(r,e)),r||e.getRecord?.()||e}function el(e,t=e.getChanges?.()){let r;if(e.getRecord&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=el(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?.()});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=qb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=el(s);r[n]=s}if(!Array.isArray(e))for(let n in e)Xte.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function BE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Zc]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(BE(i))return!0}else return!0}}else{let r=e.getChanges?.();if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s.getRecord?.()===i){if(BE(s))return!0}else return!0}else return!0}}return!1}var Xn,gB,SB,F_,Xte,Zc,HE,kE,Vb=be(()=>{Xn=M(pe());xE();As();a(On,"getChanges");a(FE,"assignTrackedAccessors");gB=Object.prototype,SB=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(gB[t])return gB[t];let n=r.getChanges?.();if(n&&t in n)return n[t];let s=r.getRecord?.()[t];if(s&&typeof s=="object"){let i=$b(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a($b,"trackObject");F_=class{static{a(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};FE(F_,{});a(GE,"collapseData");Xte=Object.prototype.hasOwnProperty;a(el,"updateAndFreeze");a(BE,"hasChanges");Zc=Symbol.for("has-array-changes"),HE=class extends Array{static{a(this,"TrackedArray")}#e;[Zc];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[Zc]=!0,super.splice(...t)}push(...t){return this[Zc]=!0,super.push(...t)}pop(){return this[Zc]=!0,super.pop()}unshift(...t){return this[Zc]=!0,super.unshift(...t)}shift(){return this[Zc]=!0,super.shift()}};HE.prototype.constructor=Array;kE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var wB={};ve(wB,{ResourceBridge:()=>Wb});function zb({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 AB(e,t){let r=qi(e),n=zb(e,r);if(!r)throw new oi.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Ot(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],f;try{f=await r.get({id:u,lazy:s,select:n},i),f=f&&GE(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function qi(e){let t=e.database||e.schema||ere,r=Je()[t];if(!r)throw(0,oi.handleHDBError)(new Error,Zte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function RB(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*yB(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var bB,qE,oi,OB,Kb,Yb,NB,Zte,ere,tre,rre,TB,Wb,IB=be(()=>{"use strict";bB=M(hB()),qE=M(Bu()),oi=M(pe());Pe();OB=M(d_());B();Kb=M(yo()),Yb=M(si()),NB=M(oe());Oc();Vb();({HDB_ERROR_MSGS:Zte}=oi.hdb_errors),ere="data",tre=1e4,rre=10,Wb=class extends bB.default{static{a(this,"ResourceBridge")}constructor(t){super(t),TB=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,qE.default)(t,"conditions");if(r)throw(0,oi.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=qi(t);if(!n)throw new oi.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:zb(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new oi.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}]}lt({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await qi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=qi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){qi(t).dropTable()}createSchema(t){return Fu({database:t.schema,table:null}),Kb.signalSchemaChange(new Yb.SchemaEventMsg(process.pid,$t.CREATE_SCHEMA,t.schema))}async dropSchema(t){await jb(t.schema),Kb.signalSchemaChange(new Yb.SchemaEventMsg(process.pid,$t.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,TB.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,OB.default)(t),s,i=Je()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Ot(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(p=>p.name==f)||s.push(f);s.length>0&&await i.addAttributes(s.map(f=>({name:f,indexed:!0})))}let l=[],u=[];for(let f of t.records){let d=f[i.primaryKey],p=d!=null&&await i.get(d,o);if(t.requires_existing&&!p||t.requires_no_existing&&p){u.push(f[i.primaryKey]);continue}p&&(p=GE(p));for(let _ in f)if(Object.prototype.hasOwnProperty.call(f,_)){let h=f[_];if(typeof h=="function")try{let S=h([[p]]);Array.isArray(S)&&(h=S[0].func_val,f[_]=h)}catch(S){throw S.message+="Trying to set key "+_+" on object"+JSON.stringify(f),S}}if(p)for(let _ in p)Object.prototype.hasOwnProperty.call(f,_)||(f[_]=p[_]);await(d==null?i.create(f,o):i.put(f,o)),l.push(f[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=Je()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Ot(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 RB(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Je()[t.schema][t.table];if(!r.createdTimeProperty)throw new oi.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:om.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let f=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...f.deleted_hashes),o.push(...f.skipped_hashes),await(0,NB.async_set_timeout)(rre),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%tre===0&&await u();return l.length>0&&await u(),s?RB(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,qE.default)(t,"hashes");if(r)throw r;return AB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of AB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&jA[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,qE.default)(t,"value");if(n)throw n;let s=qi(t);if(!s)throw new oi.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===om.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:zb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=qi(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){qi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return qi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=qi(t),n={};switch(t.search_type){case am.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case am.USERNAME:let s=t.search_values;for await(let i of yB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return yB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(zb,"getSelect");a(AB,"getRecords");a(qi,"getTable");a(RB,"createDeleteResponse");a(yB,"groupRecordsInHistory")});var Wn=I((iCe,CB)=>{"use strict";var{ResourceBridge:nre}=(IB(),C(wB)),sre=ce();sre.initSync();var $E;function ire(){return $E||($E=new nre,$E)}a(ire,"getBridge");CB.exports=ire()});var yn=I((aCe,MB)=>{"use strict";var KE=BR(),Lr=oe(),ore=require("util"),YE=Wn(),are=bs(),PB=Y(),{handleHDBError:tl,hdb_errors:cre}=pe(),{HTTP_STATUS_CODES:rl}=cre,lre=ore.promisify(are.getTableSchema),ure="updated",DB="inserted",LB="upserted";MB.exports={insert:fre,update:_re,upsert:pre,validation:dre,flush:hre};async function dre(e){if(Lr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Lr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Lr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await lre(e.schema,e.table),r=KE(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Lr.isEmptyOrZeroLength(c[n]))throw PB.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!Lr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw PB.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Lr.isEmpty(c[n])&&c[n]!==""&&s.has(Lr.autoCast(c[n]))&&(c.skip=!0),s.add(Lr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(dre,"validation");async function fre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=KE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await YE.createRecords(e);return VE(DB,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(fre,"insertData");async function _re(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=KE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await YE.updateRecords(e);return Lr.isEmpty(n.existing_rows)?VE(ure,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):VE(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(_re,"updateData");async function pre(e){if(e.operation!=="upsert")throw tl(new Error,"invalid operation, must be upsert",rl.INTERNAL_SERVER_ERROR);let t=KE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await YE.upsertRecords(e);return VE(LB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(pre,"upsertData");function VE(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===DB?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===LB?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(VE,"returnObject");function hre(e){return Lr.transformReq(e),YE.flush(e.schema,e.table)}a(hre,"flush")});var kB=I((lCe,HB)=>{var Gu=require("validate.js"),UB=ut(),qu=(B(),C(G)),{handleHDBError:mre,hdb_errors:Ere}=pe(),{HDB_ERROR_MSGS:Yt,HTTP_STATUS_CODES:gre}=Ere,Qb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Sre={STRUCTURE_USER:"structure_user"},vB=Object.values(qu.ROLE_TYPES_ENUM),Tre="attribute_permissions",Are="attribute_name",{PERMS_CRUD_ENUM:$u}=qu,Rre=[Tre,...Object.values($u)],xB=[$u.READ,$u.INSERT,$u.UPDATE],yre=[Are,...xB];function bre(e){let t=Qb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,BB(e,t)}a(bre,"addRoleValidation");function Ore(e){let t=Qb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,BB(e,t)}a(Ore,"alterRoleValidation");function Nre(e){let t=Qb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,UB.validateObject(e,t)}a(Nre,"dropRoleValidation");var wre=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function BB(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)wre.includes(n[o])||s.push(n[o]);s.length>0&&nr(Yt.INVALID_ROLE_JSON_KEYS(s),r);let i=UB.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=Ire(e);o&&nr(o,r),vB.forEach(c=>{e.permission[c]&&!Gu.isBoolean(e.permission[c])&&nr(Yt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(vB.indexOf(o)<0){if(o===Sre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,f=l.length;u<f;u++){let d=l[u];global.hdb_schema[d]||nr(Yt.SCHEMA_NOT_FOUND(d),r)}continue}nr(Yt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(Yt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){nr(Yt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{Rre.includes(f)||nr(Yt.INVALID_PERM_KEY(f),r,o,l)}),Object.values($u).forEach(f=>{Gu.isDefined(u[f])?Gu.isBoolean(u[f])||nr(Yt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(Yt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(Yt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(Yt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:p})=>p),d={read:!1,insert:!1,update:!1};for(let p in u.attribute_permissions){let _=u.attribute_permissions[p];if(Object.keys(_).forEach(S=>{!yre.includes(S)&&S!==$u.DELETE&&nr(Yt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!Gu.isDefined(_.attribute_name)){nr(Yt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!f.includes(h)){nr(Yt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}xB.forEach(S=>{Gu.isDefined(_[S])?Gu.isBoolean(_[S])||nr(Yt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,l):nr(Yt.ATTR_PERM_MISSING(S,h),r,o,l)}),!d.read&&_.read===!0&&(d.read=!0),!d.insert&&_.insert===!0&&(d.insert=!0),!d.update&&_.update===!0&&(d.update=!0)}if(u.read===!1&&d.read===!0||u.insert===!1&&d.insert===!0||u.update===!1&&d.update===!0){let p=`${o}.${l}`;nr(Yt.MISMATCHED_TABLE_ATTR_PERMS(p),r,o,l)}}}}return Cre(r)}a(BB,"customValidate");HB.exports={addRoleValidation:bre,alterRoleValidation:Ore,dropRoleValidation:Nre};function Ire(e){let{operation:t,permission:r}=e;if(t===qu.OPERATIONS_ENUM.ADD_ROLE||t===qu.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Yt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?qu.ROLE_TYPES_ENUM.SUPER_USER:qu.ROLE_TYPES_ENUM.CLUSTER_USER;return Yt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Ire,"validateNoSUPerms");function Cre(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Yt.ROLE_PERMS_ERROR,...e};return mre(new Error,n,gre.BAD_REQUEST)}else return null}a(Cre,"generateRolePermResponse");function nr(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(nr,"addPermError")});var q_=I((fCe,$B)=>{"use strict";var FB=yn(),GB=Wr(),Pre=Vc(),Xb=kB(),Zb=yo(),dCe=require("uuid").v4,Dre=require("util"),WE=(B(),C(G)),Lre=oe(),eO=GB.searchByValue,Mre=GB.searchByHash,vre=Dre.promisify(Pre.delete),Ure=ii(),xre=Hu(),{hdb_errors:Bre,handleHDBError:nl}=pe(),{HDB_ERROR_MSGS:qB,HTTP_STATUS_CODES:G_}=Bre,{UserEventMsg:tO}=si();$B.exports={addRole:Hre,alterRole:kre,dropRole:Fre,listRoles:Gre};function Jb(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(Jb,"scrubRoleDetails");async function Hre(e){let t=Xb.addRoleValidation(e);if(t)throw t;e=Jb(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 eO(r)||[])}catch(i){throw nl(i)}if(n&&n.length>0)throw nl(new Error,qB.ROLE_ALREADY_EXISTS(e.role),G_.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await FB.insert(s),Zb.signalUserChange(new tO(process.pid)),e=Jb(e),e}a(Hre,"addRole");async function kre(e){let t=Xb.alterRoleValidation(e);if(t)throw t;e=Jb(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await FB.update(r)}catch(s){throw nl(s)}if(n&&n?.message==="updated 0 of 1 records")throw nl(new Error,"Invalid role id",G_.BAD_REQUEST,void 0,void 0,!0);return await Zb.signalUserChange(new tO(process.pid)),e}a(kre,"alterRole");async function Fre(e){let t=Xb.dropRoleValidation(e);if(t)throw nl(new Error,t,G_.BAD_REQUEST,void 0,void 0,!0);let r=new xre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Mre(r));if(n.length===0)throw nl(new Error,qB.ROLE_NOT_FOUND,G_.NOT_FOUND,void 0,void 0,!0);let s=new Ure(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await eO(s)),o=!1;if(Lre.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw nl(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,G_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await vre(c),Zb.signalUserChange(new tO(process.pid)),`${n[0].role} successfully deleted`}a(Fre,"dropRole");async function Gre(){return eO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Gre,"listRoles")});var rO={};ve(rO,{start:()=>YB,startOnMainThread:()=>Vre});function YB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,VB.parseDocument)(r.toString(),{simpleKeys:!0}).toJSON();for(let s in n){let i=n[s];i.permission||(i={permission:i},i.permission.access&&(i.access=i.permission.access,delete i.permission.access));for(let o in i.permission){if(qre.includes(o))continue;let c=i.permission[o];c.tables||(i.permission[o]=c={tables:c});for(let l in c.tables){let u=c.tables[l];if(u.read=!!u.read,u.insert=!!u.insert,u.update=!!u.update,u.delete=!!u.delete,u.attributes){let f=[];for(let d in u.attributes){let p=u.attributes[d];p.attribute_name=d,f.push(p)}u.attribute_permissions=f,delete u.attributes}if(u.attribute_permissions){if(!Array.isArray(u.attribute_permissions))throw new Error("attribute_permissions must be an array if defined");for(let f of u.attribute_permissions)f.read=!!f.read,f.insert=!!f.insert,f.update=!!f.update}else u.attribute_permissions=null}}i.role=i.id=s,await $re(i)}}}async function $re(e){let t=Je().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,KB.isEqual)(i,e)?void 0:(e.id=r.id,(0,zE.alterRole)(e))}return(0,zE.addRole)(e)}var zE,VB,KB,qre,Vre,WB=be(()=>{Pe();zE=M(q_()),VB=require("yaml"),KB=require("lodash"),qre=["super_user","cluster_user","structure_user"];a(YB,"start");a($re,"ensureRole");Vre=YB});async function jE(e){let t=(0,QB.pathToFileURL)(e).toString();return Kre?($_||($_=Yre(zre)),(await(await $_).import(t)).namespace):import(t)}async function Yre(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),$_=new Compartment({console,Math,Date,fetch:Wre,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,jB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Vr,tables:Zn,databases:$e})}};let n=await(0,zB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),$_}function Wre(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 zre(){return{Resource:Vr,tables:Zn}}var zB,jB,QB,Kre,$_,nO=be(()=>{ga();Pe();zB=require("fs/promises"),jB=require("path"),QB=require("url"),Kre=!1;a(jE,"secureImport");a(Yre,"getCompartment");a(Wre,"secureOnlyFetch");a(zre,"getGlobalVars")});var iO={};ve(iO,{handleFile:()=>jre});async function jre(e,t,r,n){let s=new Map,i=await jE(r);c(i.default)&&n.set((0,sO.dirname)(t),i.default),o(i,(0,sO.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var sO,JB=be(()=>{nO();sO=require("path");a(jre,"handleFile")});var aO={};ve(aO,{start:()=>Qre});function Qre({resources:e}){e.set("login",oO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var oO,XB=be(()=>{ga();a(Qre,"start");oO=class extends Vr{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var j_={};ve(j_,{addAnalyticsListener:()=>z_,calculateCPUUtilization:()=>EH,diffResourceUsage:()=>gH,recordAction:()=>sr,recordActionBinary:()=>es,setAnalyticsEnabled:()=>Jre});function Jre(e){fH=e}function Xre(e,t){if(typeof e=="number"){let r=t.values,n=r.index++;if(n>=r.length){let s=r;t.values=r=new Float32Array(n*2),r.set(s),r.index=n+1}r[n]=e,t.total+=e}else if(typeof e=="boolean")e&&t.total++,t.count++;else if(typeof e=="function")t.count++;else throw new TypeError("Invalid metric value type "+typeof e)}function Zre(e,t,r,n,s,i){let o={};if(typeof t=="number")o.total=t,o.values=new Float32Array(4),o.values.index=1,o.values[0]=t,o.total=t;else if(typeof t=="boolean")o.total=t?1:0,o.count=1;else if(typeof t=="function")o.count=1,o.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);o.description={metric:r,path:n,method:s,type:i},JE.set(e,o)}function sr(e,t,r,n,s){if(!fH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=JE.get(i);o?Xre(e,o):Zre(i,e,t,r,n,s),QE||ene()}function es(e,t,r,n,s){sr(!!e,t,r,n,s)}function z_(e){hH.push(e)}function ene(){QE=performance.now(),setTimeout(async()=>{let e=performance.now()-QE;QE=0;let t=[],r={time:Date.now(),period:e,threadId:sl.threadId,metrics:t};for(let[s,i]of JE){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],f;for(let d of mH){let p=Math.floor(c*d),_=o[p-1];if(p>l){let h=p-l;if(_===f){let S=u[u.length-1];typeof S=="number"?u[u.length-1]={value:S,count:1+h}:S.count+=h}else u.push(h>1?{value:_,count:h}:_),f=_;l=p}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await SH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:sl.threadId,byThread:!0,...n});for(let s of hH)s(t);JE=new Map,sl.parentPort?sl.parentPort.postMessage({type:pH,report:r}):RH({report:r})},_H).unref()}function XE(e,t,r){let n={id:(0,Y_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function EH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function gH(e,t){return{userCPUTime:t.userCPUTime/1e3-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime/1e3-(e?.systemCPUTime??0),minorPageFault:t.minorPageFault-(e?.minorPageFault??0),majorPageFault:t.majorPageFault-(e?.majorPageFault??0),fsRead:t.fsRead-(e?.fsRead??0),fsWrite:t.fsWrite-(e?.fsWrite??0),voluntaryContextSwitches:t.voluntaryContextSwitches-(e?.voluntaryContextSwitches??0),involuntaryContextSwitches:t.involuntaryContextSwitches-(e?.involuntaryContextSwitches??0)}}function tne(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let o=`${t}.${s}`,c=i.getSize(),l={database:t,table:s,size:c};XE(e,"table-size",l),il.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function ZB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getAuditSize(),o=dH.default.statSync(s.primaryStore.env.path).size,c=tne(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};XE(e,"database-size",u),il.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){il.warn?.("Error getting DB size metrics",s)}}function eH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getStorageStats(),o={database:r,...i};XE(e,"storage-volume",o),il.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){il.warn?.("Error getting DB volumne metrics",s)}}async function rne(e,t=6e4){let r=lO(),n=TH(),s=new Promise(E=>{let R=performance.now();setImmediate(()=>{let N=performance.now();N-R>5e3&&il.warn?.("Unusually high event queue latency on the main thread of "+Math.round(N-R)+"ms"),R=performance.now()}),n.primaryStore.prefetch([1],()=>{let N=performance.now();N-R>5e3&&il.warn?.("Unusually high task queue latency on the main thread of "+Math.round(N-R)+"ms"),E(N-R)})}),i;for(let E of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(E.value?.time){i=E.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:E,value:R}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!R)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:N,threadId:v}=R;for(let k of N||[]){let{path:F,method:K,type:re,metric:ae,count:Z,total:se,distribution:W,threads:he,...Te}=k;Z||(Z=1);let Ce=ae+(F?"-"+F:"");K!==void 0&&(Ce+="-"+K),re!==void 0&&(Ce+="-"+re);let me=c.get(Ce);if(me){if(me.threads){let ct=me.threads[v];if(ct)me=ct;else{me.threads[v]={...Te};continue}}me.count||(me.count=1);let Xt=me.count;for(let ct in Te){let yr=Te[ct];typeof yr=="number"&&(me[ct]=(me[ct]*Xt+yr*Z)/(Xt+Z))}me.count+=Z,se>=0&&(me.total+=se,me.ratio=me.total/me.count)}else me={period:t,...k},delete me.distribution,c.set(Ce,me),me.byThread&&(me.threads=[],me.threads[v]={...Te},u.push(me));if(W){W=W.map(ct=>typeof ct=="number"?{value:ct,count:1}:ct);let Xt=l.get(Ce);Xt?Xt.push(...W):l.set(Ce,W)}}await SH()}for(let E of u){let{path:R,method:N,type:v,metric:k,count:F,total:K,distribution:re,threads:ae,...Z}=E;ae=ae.filter(se=>se);for(let se in Z){if(typeof E[se]!="number")continue;let W=0;for(let he of ae){let Te=he[se];typeof Te=="number"&&(W+=Te)}E[se]=W}E.count=ae.length,delete E.threads,delete E.byThread}for(let[E,R]of l){let N=c.get(E);R.sort((ct,yr)=>ct.value>yr.value?1:-1);let v=N.count-1,k=[],F=0,K=0,re;for(let ct of mH){let yr=v*ct;for(;F<yr;)re=R[K++],F+=re.count,K===1&&F--;let gs=R[K>1?K-2:0];re||(re=R[0]),k.push(re.value-(re.value-gs.value)*(F-yr)/re.count)}let[ae,Z,se,W,he,Te,Ce,me,Xt]=k;Object.assign(N,{p1:ae,p10:Z,p25:se,median:W,p75:he,p90:Te,p95:Ce,p99:me,p999:Xt})}let d;for(let[E,R]of c)R.id=(0,Y_.getNextMonotonicTime)(),R.time=f,n.primaryStore.put(R.id,R,{append:!0}).then(N=>{N||n.primaryStore.put(R.id,R)}),d=!0;let p=Date.now(),{idle:_,active:h}=performance.eventLoopUtilization();if(d||h*10>_){let E=(0,Y_.getNextMonotonicTime)(),R={id:E,metric:"main-thread-utilization",idle:_-tH,active:h-rH,taskQueueLatency:await s,time:p,...process.memoryUsage()};n.primaryStore.put(E,R,{append:!0}).then(N=>{N||n.primaryStore.put(E,R)})}tH=_,rH=h;let S=process.resourceUsage(),g=gH(V_,S);g.time=p,g.period=V_.time?p-V_.time:t,g.cpuUtilization=EH(V_,g.period),XE(n,"resource-usage",g),V_=g;let A=Je();ZB(n,A),ZB(n,{system:A.system}),eH(n,A),eH(n,{system:A.system})}async function nH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function lO(){return sH||(sH=lt({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function TH(){return iH||(iH=lt({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function ine(){AH=!0;let e=(0,W_.get)(x.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await rne(_H,e),await nH(lO(),nne),await nH(TH(),sne)},Math.min(e/2,2147483647)).unref()}function RH(e,t){let r=e.report;r.threadId=t?.threadId||sl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(oH+=n.mean*n.count);r.totalBytesProcessed=oH,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(aH.get(t))}),aH.set(t,t.performance.eventLoopUtilization())),r.id=(0,Y_.getNextMonotonicTime)(),lO().primaryStore.put(r.id,r),AH||ine(),one&&(yH=cne(r))}async function cne(e){if(await yH,!Da){let r=(0,K_.dirname)((0,lH.getLogFilePath)());try{Da=await(0,cO.open)((0,K_.join)(r,"analytics.log"),"r+")}catch{Da=await(0,cO.open)((0,K_.join)(r,"analytics.log"),"w+")}}let t=(await Da.stat()).size;if(t>ane){let r=Buffer.alloc(t);await Da.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Da.write(r,{position:0}),await Da.truncate(r.length),t=r.length}await Da.write(JSON.stringify(e)+`
|
|
21
|
+
`,t)}var sl,cH,lH,uH,K_,cO,Y_,W_,dH,il,JE,fH,QE,_H,pH,hH,mH,tH,rH,V_,SH,nne,sne,sH,iH,AH,oH,aH,one,yH,Da,ane,$i=be(()=>{sl=require("worker_threads"),cH=M(tt());Pe();lH=M(Y()),uH=M(Ci()),K_=require("path"),cO=require("fs/promises"),Y_=M(pn()),W_=M(ce());B();Kr();dH=M(require("node:fs")),il=(0,uH.loggerWithTag)("analytics");(0,W_.initSync)();JE=new Map,fH=(0,W_.get)(x.ANALYTICS_AGGREGATEPERIOD)>-1;a(Jre,"setAnalyticsEnabled");a(Xre,"recordExistingAction");a(Zre,"recordNewAction");a(sr,"recordAction");We.recordAnalytics=sr;a(es,"recordActionBinary");QE=0,_H=1e3,pH="analytics-report",hH=[];a(z_,"addAnalyticsListener");mH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(ene,"sendAnalytics");a(XE,"storeMetric");a(EH,"calculateCPUUtilization");a(gH,"diffResourceUsage");a(tne,"storeTableSizeMetrics");a(ZB,"storeDBSizeMetrics");a(eH,"storeVolumeMetrics");a(rne,"aggregation");tH=0,rH=0,V_={},SH=a(()=>new Promise(setImmediate),"rest");a(nH,"cleanup");nne=36e5,sne=31536e6;a(lO,"getRawAnalyticsTable");a(TH,"getAnalyticsTable");(0,cH.setChildListenerByType)(pH,RH);a(ine,"startScheduledTasks");oH=0,aH=new Map,one=!1;a(RH,"recordAnalytics");ane=1e6;a(cne,"logAnalytics")});var bH={};ve(bH,{Headers:()=>No,appendHeader:()=>ZE,mergeHeaders:()=>uO});function ZE(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function uO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new No(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var No,Q_=be(()=>{No=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(ZE,"appendHeader");a(uO,"mergeHeaders")});function CH(e){let t={openapi:lne,info:{title:"HarperDB HTTP REST interface",version:IH.packageJson.version},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},f=[];if(o)for(let{type:R,name:N,elements:v,relationship:k,definition:F}of o){if(k)R==="array"?u[N]={type:"array",items:{$ref:La+v.type}}:u[N]={$ref:La+R};else{let K=F??v?.definition;if(K){if(!t.components.schemas[K.type]){let re={};K.properties.forEach(ae=>{re[ae.name]=new pO(dO[ae.type],ae.type)}),t.components.schemas[K.type]=new wH(re)}R==="array"?u[N]={type:"array",items:{$ref:La+K.type}}:u[N]={$ref:La+K.type}}else R==="array"?v.type==="Any"||v.type=="ID"?u[N]={type:"array",items:{format:v.type}}:u[N]={type:"array",items:new pO(dO[v.type],v.type)}:R==="Any"||R=="ID"?u[N]={format:R}:u[N]=new pO(dO[R],R)}f.push(new hO(N,"query",u[N]))}let d=Object.keys(u),p=new hO(c,"path",{format:"ID"});p.required=!0,p.description="primary key of record";let _=new hO("property","path",{enum:d});_.required=!0,t.components.schemas[i]=new wH(u);let h=l.post!==Resource.prototype.post||l.update,S=typeof l.put=="function",g=typeof l.get=="function",A=typeof l.delete=="function",E="/"+s+"/";h&&(t.paths[E]={},t.paths[E].post=new une(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new fO(f,r,{200:new _O({$ref:La+i})},"search for records by the specified property name and value pairs")),A&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new NH(f,r,"delete all the records that match the provided query",{204:new OH})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new fO([p],r,{200:new _O({$ref:La+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new dne([p],r,i,"create or update the record with the URL path that maps to the record's primary key")),A&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new NH([p],r,"delete a record with the given primary key",{204:new OH})),g&&_.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new fO([p,_],r,{200:new _O({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function une(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:La+e}}}},this.security=t,this.responses={200:{description:mO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function fO(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function _O(e){this.description=mO,this.content={"application/json":{schema:e}}}function OH(){this.description="successfully processed request, no content returned to client"}function dne(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:La+r}}}},this.responses={200:{description:mO}}}function NH(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function wH(e){this.type="object",this.properties=e}function pO(e,t){this.type=e,this.format=t}function hO(e,t,r){this.name=e,this.in=t,this.schema=r}var IH,lne,dO,La,mO,PH=be(()=>{IH=M(nt()),lne="3.0.3",dO={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},La="#/components/schemas/",mO="successful operation";a(CH,"generateJsonApi");a(une,"Post");a(fO,"Get");a(_O,"Response200");a(OH,"Response204");a(dne,"Put");a(NH,"Delete");a(wH,"ResourceSchema");a(pO,"Type");a(hO,"Parameter")});var tg={};ve(tg,{parseHeaderValue:()=>gO,start:()=>pne});async function _ne(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&bm(e);let i=new No;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==DH){let g=eg.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Nc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let A=gO(g);for(let E of A)switch(E.name){case"max-age":e.expiresAt=E.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let g=gO(u).map(A=>(A.next?.name==="confirm"&&A.next.value>=0&&(e.replicatedConfirmation=+A.next.value),A.name));e.replicateTo=g.length===1&&+g[0]>=0?+g[0]:g[0]==="*"?void 0:g}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let d=await Ot(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=po(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Vu.ClientError(g,400)}if(e.authorize=!0,o===DH&&s==="GET"){if(e?.user?.role?.permission?.super_user)return CH(eg);throw new Vu.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new Vu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Vu.ServerError(`Method ${s} is not recognized`,501)}}),p=200,_;if(d==null)p=s==="GET"||s==="HEAD"?404:204,EO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=uO(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Qf(d.data,e,d)),d}else if(_=e.lastModified){fne[0]=_;let g=String.fromCharCode(34,(Mr[0]&63)+62,(Mr[0]>>6)+(Mr[1]<<2&63)+62,(Mr[1]>>4)+(Mr[2]<<4&63)+62,(Mr[2]>>2)+62,(Mr[3]&63)+62,(Mr[3]>>6)+(Mr[4]<<2&63)+62,(Mr[4]>>4)+(Mr[5]<<4&63)+62,(Mr[5]>>2)+62,(Mr[6]&63)+62,(Mr[6]>>6)+(Mr[7]<<2&63)+62,34),A=r["if-none-match"];A&&g==A?(d?.onDone&&d.onDone(),p=304,d=void 0):i.setIfNone("ETag",g),EO.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}e.createdResource&&(p=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:p,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(h.wasCacheMiss=S,!S&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),d!==void 0&&(h.body=Qf(d,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Vi.warn(o):Vi.info(o):Vi.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Qf(o.contentType?o:o.toString(),e,c),c}}function pne(e){EO=e,!LH&&(LH=!0,eg=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return _ne(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{J_++;let s=new kn;MH||(MH=!0,z_(l=>{J_>0&&l.push({metric:"ws-connections",connections:J_,byThread:!0})}));let i;t.on("error",l=>{i=!0,Vi.warn(l)});let o;t.on("message",a(function(u){o||(o=po(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);sr(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{J_--,es(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=eg.getMatch(l,"ws");if(es(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,sr(h=>({count:h.count,total:J_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new Nc(u.relativeURL),d=u.Resource;c=(await Ot(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let h=await ya(_.value,r);t.send(h),sr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Vi.warn(l):Vi.info(l):Vi.error(l),t.close(hne[l.statusCode]||1011,l.toString())}t.close()},e))}function gO(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var Vi,Vu,Mr,fne,EO,DH,LH,eg,MH,J_,hne,vH=be(()=>{fo();$i();Vi=M(Y()),Vu=M(pe());Ff();_u();Oc();Q_();PH();Ff();Mr=new Uint8Array(8),fne=new Float64Array(Mr.buffer,0,1),EO={},DH="openapi";a(_ne,"http");J_=0;a(pne,"start");hne={401:3e3,403:3003};a(gO,"parseHeaderValue")});var SO=I((GCe,xH)=>{var{recordAction:rg,recordActionBinary:UH}=($i(),C(j_)),mne=require("fastify-plugin"),Ene=200;xH.exports=mne(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,f,d;l.config?.isOperation?(u=n.body?.operation,f="operation"):(u=l.url,f="fastify-route",d=l.method),rg(o,"duration",u,d,f),UH(s.raw.statusCode<400,"success",u,d,f),UH(1,"response_"+s.raw.statusCode,u,d,f);let p=Ene;i?.pipe?(i.on("data",g=>{p+=g.length}),i.on("end",()=>{rg(performance.now()-c,"transfer",u,d,f),rg(p,"bytes-sent",u,d,f)})):(p+=i?.length||0,rg(p,"bytes-sent",u,d,f));let _=o.toFixed(3),h=s.getHeader("Server-Timing"),S=`db;dur=${_}`;s.header("Server-Timing",h?`${h}, ${S}`:S)}),r()},{name:"hdb-request-time"})});var HH=I((qCe,BH)=>{var gne=ut(),Sne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};BH.exports=function(e){return gne.validateObject(e,Sne)}});var ng=I(($Ce,kH)=>{"use strict";var Tne=(B(),C(G)).OPERATIONS_ENUM,TO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Tne.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};kH.exports=TO});var ep={};ve(ep,{createTokens:()=>Rne,getJWTRSAKeys:()=>cg,refreshOperationToken:()=>yne,validateOperationToken:()=>yO,validateRefreshToken:()=>lg});async function cg(){if(sg)return sg;try{let e=X_.default.join(Z_.default.getHdbBasePath(),YA),t=await ig.default.readFile(X_.default.join(e,bf.JWT_PASSPHRASE_NAME),"utf8"),r=await ig.default.readFile(X_.default.join(e,bf.JWT_PRIVATE_KEY_NAME),"utf8");return sg={publicKey:await ig.default.readFile(X_.default.join(e,bf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},sg}catch(e){throw ag.default.error(e),new ai.ClientError(Yu.NO_ENCRYPTION_KEYS,Ku.INTERNAL_SERVER_ERROR)}}async function Rne(e){let t=(0,AO.validateBySchema)(e,Ki.default.object({username:Ki.default.string().optional(),password:Ki.default.string().optional(),role:Ki.default.string().optional(),expires_in:Ki.default.alternatives(Ki.default.string(),Ki.default.number()).optional()}));if(t)throw new ai.ClientError(t.message);let r;try{let d=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,d=!1),r=await(0,RO.findAndValidateUser)(e.username,e.password,d)}catch(d){throw ag.default.error(d),new ai.ClientError(Yu.INVALID_CREDENTIALS,Ku.UNAUTHORIZED)}if(!r)throw new ai.ClientError(Yu.INVALID_CREDENTIALS,Ku.UNAUTHORIZED);let n=!1,s=!1;r.role?.permission&&(n=r.role.permission.super_user===!0,s=r.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s};e.role&&(i.role=e.role);let o=await cg(),c=await Wu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??VH,algorithm:og,subject:"operation"}),l=await Wu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:Ane,algorithm:og,subject:"refresh"}),u=By(l,"sha256");if((await(0,FH.update)(new GH.default(yf,du.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new ai.ClientError(Yu.REFRESH_TOKEN_SAVE_FAILED,Ku.INTERNAL_SERVER_ERROR);return qH.default.signalUserChange(new $H.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function yne(e){let t=(0,AO.validateBySchema)(e,Ki.default.object({refresh_token:Ki.default.string().required()}).required());if(t)throw new ai.ClientError(t.message);let{refresh_token:r}=e;await lg(r);let n=await cg(),s=await Wu.default.decode(r);return{operation_token:await Wu.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:VH,algorithm:og,subject:"operation"})}}async function yO(e){return KH(e,"operation")}async function lg(e){return KH(e,"refresh")}async function KH(e,t){try{let r=await cg(),n=await Wu.default.verify(e,r.publicKey,{algorithms:og,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,RO.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!Hy(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw ag.default.warn(r),r?.name==="TokenExpiredError"?new ai.ClientError(Yu.TOKEN_EXPIRED,Ku.FORBIDDEN):new ai.ClientError(Yu.INVALID_TOKEN,Ku.UNAUTHORIZED)}}var Wu,ig,X_,Ki,AO,ai,ag,RO,FH,GH,qH,$H,Z_,Ku,Yu,VH,Ane,og,sg,zu=be(()=>{Wu=M(require("jsonwebtoken")),ig=M(require("fs-extra")),X_=M(require("node:path")),Ki=M(require("joi")),AO=M(ut());B();ai=M(pe()),ag=M(Y());hE();RO=M(Rn()),FH=M(yn()),GH=M(ng()),qH=M(yo()),$H=M(si()),Z_=M(ce()),{HTTP_STATUS_CODES:Ku,AUTHENTICATION_ERROR_MSGS:Yu}=ai.hdb_errors;Z_.default.initSync();VH=Z_.default.get(x.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Ane=Z_.default.get(x.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",og="RS256";a(cg,"getJWTRSAKeys");a(Rne,"createTokens");a(yne,"refreshOperationToken");a(yO,"validateOperationToken");a(lg,"validateRefreshToken");a(KH,"validateToken")});var bO=I((zCe,zH)=>{"use strict";var bne=HH(),ju=require("passport"),One=require("passport-local").Strategy,Nne=require("passport-http").BasicStrategy,wne=require("util"),Ine=Rn(),WH=wne.callbackify(Ine.findAndValidateUser),WCe=Hn(),Cne=(B(),C(G)),YH=(zu(),C(ep));ju.use(new One(function(e,t,r){WH(e,t,r)}));ju.use(new Nne(function(e,t,r){WH(e,t,r)}));ju.serializeUser(function(e,t){t(null,e)});ju.deserializeUser(function(e,t){t(null,e)});function Pne(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":ju.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Cne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?YH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):YH.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:ju.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Pne,"authorize");function Dne(e,t){let r=bne(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(Dne,"checkPermissions");zH.exports={authorize:Pne,checkPermissions:Dne}});var ug=I((QCe,jH)=>{"use strict";var Lne=Wn();jH.exports={writeTransaction:Mne};function Mne(e,t,r){return Lne.writeTransaction(e,t,r)}a(Mne,"writeTransaction")});var ZH=I((ZCe,XH)=>{"use strict";var vne=Wr(),Une=bs(),QH=Y(),xne=yn(),XCe=ug(),Bne=require("clone"),NO=require("alasql"),Hne=aE(),JH=require("util"),kne=JH.promisify(Une.getTableSchema),Fne=JH.promisify(vne.search),Gne=(B(),C(G)),OO=oe();Hne(NO);XH.exports={update:$ne};var qne="There was a problem performing this update. Please check the logs and try again.";async function $ne({statement:e,hdb_user:t}){let r=await kne(e.table.databaseid,e.table.tableid),n=Vne(e.columns);OO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=Bne(s),c=OO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=NO.parse(l).statements[0],f=await Fne(u),d=Kne(n,f);return Yne(o,d,t)}a($ne,"update");function Vne(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=NO.compile(`SELECT ${r.expression.toString()} AS [${Gne.FUNC_VAL}] FROM ?`)}),t}catch(t){throw QH.error(t),new Error(qne)}}a(Vne,"createUpdateRecord");function Kne(e,t){return OO.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(Kne,"buildUpdateRecords");async function Yne(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await xne.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){QH.error(`Error delete new_attributes from update response: ${i}`)}return s}a(Yne,"updateRecords")});var tk=I((nPe,ek)=>{var Wne=require("alasql"),zne=Wr(),jne=Y(),Qne=Wn(),IO=require("util"),wO=oe(),Jne=(B(),C(G)),Xne=bs(),tPe=ug(),rPe=yn(),Zne="record",ese="successfully deleted",tse=IO.callbackify(ise),rse=IO.promisify(zne.search),nse=IO.promisify(Xne.getTableSchema);ek.exports={convertDelete:tse};function sse(e){return`${e.deleted_hashes.length} ${Zne}${e.deleted_hashes.length===1?"":"s"} ${ese}`}a(sse,"generateReturnMessage");async function ise({statement:e,hdb_user:t}){let r=await nse(e.table.databaseid,e.table.tableid);wO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=wO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=Wne.parse(o).statements[0],l={operation:Jne.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await rse(c);let u=await Qne.deleteRecords(l);return wO.isEmptyOrZeroLength(u.message)&&(u.message=sse(u)),delete u.txn_time,u}catch(u){throw jne.error(u),u.hdb_code?u.message:u}}a(ise,"convertDelete")});var ok=I((iPe,ik)=>{"use strict";var ose=Ao(),{hdb_errors:rk}=pe(),{getDatabases:nk}=(Pe(),C(rt));ik.exports={checkSchemaExists:sk,checkSchemaTableExists:ase,schema_describe:ose};async function sk(e){if(!nk()[e])return rk.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(sk,"checkSchemaExists");async function ase(e,t){let r=await sk(e);if(r)return r;if(!nk()[e][t])return rk.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(ase,"checkSchemaTableExists")});var MO=I((uPe,gk)=>{"use strict";var{decode:cse}=require("msgpackr"),{isMainThread:aPe,parentPort:cPe,threadId:lPe}=require("worker_threads"),_g=ir(),Qu=St(),DO=(B(),C(G)),Jr=Y(),PO=ce(),lse=(B(),C(G)),{onMessageByType:use}=tt(),uk=To(),{recordAction:ak,recordActionBinary:dse}=($i(),C(j_)),{publishToStream:fse}=_g,{ConsumerEvents:ck}=require("nats"),_se=Wr(),{promisify:pse}=require("util"),{decodeBlobsWithWrites:hse}=(As(),C(Fm)),dk=pse(setTimeout),pg=1e4,hg,fg,mse,Ese,fk,tp=new Map,Ju=new Map;gk.exports={initialize:_k,ingestConsumer:LO,setSubscription:gse,setIgnoreOrigin:Ase,getDatabaseSubscriptions:Tse,updateConsumer:pk};async function _k(){use(DO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await pk(n)}),fk=!0,Jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await _g.getNATSReferences();hg=e,fg=e.info.server_name,mse=t,Ese=r}a(_k,"initialize");async function pk(e){if(e.status==="start"){let{js:t,jsm:r}=await hk(e.node_domain_name);LO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=tp.get(e.stream_name+e.node_domain_name);t&&(Jr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),tp.set(e.stream_name+e.node_domain_name,"close")),Ju.get(e.node_domain_name)==="failed"&&Ju.set(e.node_domain_name,"close")}}a(pk,"updateConsumer");var mg=new Map;function gse(e,t,r){let n=mg.get(e);n||mg.set(e,n=new Map),n.set(t,r),fk||_k().then(Sse)}a(gse,"setSubscription");async function Sse(){let e=await _se.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Qu.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await hk(r),!n))break;let{schema:o,table:c}=i,l=uk.createNatsTableStreamName(o,c);LO(l,n,s,r)}}}a(Sse,"accessConsumers");async function hk(e){let t,r,n=1;for(;!r;)try{t=await hg.jetstream({domain:e}),r=await hg.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Ju.get(e)==="close")break;Ju.set(e,"failed"),n%10===1&&Jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<pg?n++*100:pg;await dk(i)}return{js:t,jsm:r}}a(hk,"connectToRemoteJS");function Tse(){return mg}a(Tse,"getDatabaseSubscriptions");var mk;function Ase(e){mk=e}a(Ase,"setIgnoreOrigin");var Ek=100,lk=new Array(Ek),dg=0;async function LO(e,t,r,n){let{connection:s}=await _g.getNATSReferences();hg=s,fg=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,fg),Jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Ju.get(n)==="close")break;o%10===1&&Jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(Jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await _g.createConsumer(r,e,fg,new Date(Date.now()).toISOString()));let f=o++*100<pg?o++*100:pg;await dk(f)}let c=!1,l;for(;!c;){if(tp.get(e+n)==="close"||Ju.get(n)==="close"){tp.delete(e+n),c=!0;continue}l=await i.consume({max_messages:PO.get(DO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),tp.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===ck.ConsumerDeleted&&(await l.close(),c=!0),f.type===ck.HeartbeatsMissed){let d=f.data;Jr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(Jr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let f of l)await lk[dg],lk[dg]=Rse(f).catch(d=>{Jr.error(d)}),++dg>=Ek&&(dg=0)}catch(f){f.message==="consumer deleted"?(Jr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):Jr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(LO,"ingestConsumer");async function Rse(e){let t;await hse(()=>{t=cse(e.data)}),ak(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),Jr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=PO.get(DO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Qu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Qu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Qu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!mk),dse(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Qu.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:f,hash_values:d,__origin:p,expiresAt:_}=t;Jr.trace("processing message:",o,c,u,(f?"records: "+f.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Jr.trace(`messageProcessor nats msg id: ${e.headers.get(Qu.MSG_HEADERS.NATS_MSG_ID)}`);let h;f||(f=d);let S=new Promise(v=>h=v),{timestamp:g,user:A,node_name:E}=p||{},R=mg.get(c)?.get(u);if(!R)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,R.send(t);else if(f.length===1&&!l)R.send({type:CO(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:h,user:A,nodeName:E});else{let v=f.map((k,F)=>({type:CO(o),value:k,expiresAt:_,id:d?.[F],table:u}));for(;l;)v.push({type:CO(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;R.send({type:"transaction",writes:v,table:u,timestamp:g,onCommit:h,user:A,nodeName:E})}PO.get(lse.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&fse(e.subject.split(".").slice(0,-1).join("."),uk.createNatsTableStreamName(c,u),e.headers,e.data),await S;let N=Date.now()-g;g&&ak(N,"replication-latency",e.subject,o,"ingest")}catch(o){Jr.error(o)}e.ack()}a(Rse,"messageProcessor");function CO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(CO,"convertOperation")});var ir=I((EPe,Uk)=>{"use strict";var Nr=ce();Nr.initSync();var yse=require("fs-extra"),bse=require("semver"),sp=require("path"),{monotonicFactory:Ose}=require("ulidx"),Tk=Ose(),Nse=require("util"),Ak=require("child_process"),wse=Nse.promisify(Ak.exec),Ise=Ak.spawn,vr=St(),Ve=(B(),C(G)),{packageJson:Cse,PACKAGE_ROOT:Pse}=nt(),Eg=oe(),ci=Y(),gg=To(),Dse=ug(),rp=Rt(),{broadcast:Lse,onMessageByType:Mse,getWorkerIndex:vse}=tt(),{isMainThread:Rk}=require("worker_threads"),{Encoder:Use,decode:BO}=require("msgpackr"),yk=new Use,{isEmpty:ll}=Eg,bk=Rn(),fPe=48*36e11;Rk&&Mse(Ve.ITC_EVENT_TYPES.RESTART,()=>{Xr=void 0,cl=void 0});var{connect:xse,StorageType:Bse,RetentionPolicy:Hse,AckPolicy:HO,DeliverPolicy:kO,DiscardPolicy:kse,NatsConnection:_Pe,JetStreamManager:pPe,JetStreamClient:hPe,StringCodec:mPe,JSONCodec:Fse,createInbox:FO,headers:Gse,ErrorCode:Sk}=require("nats"),{recordAction:qse}=($i(),C(j_)),{encodeBlobsAsBuffers:$se}=(As(),C(Fm)),Ok=Fse(),Vse="clustering",Kse=Cse.engines[vr.NATS_SERVER_NAME],Yse=sp.join(Pse,"dependencies"),xO=sp.join(Yse,`${process.platform}-${process.arch}`,vr.NATS_BINARY_NAME),vO,UO,np,ol,al;Uk.exports={runCommand:Nk,checkNATSServerInstalled:Wse,createConnection:GO,getConnection:ip,getJetStreamManager:op,getJetStream:Ik,getNATSReferences:Yi,getServerList:jse,createLocalStream:qO,listStreams:Ck,deleteLocalStream:Qse,getServerConfig:Xu,listRemoteStreams:Jse,viewStream:Xse,viewStreamIterator:Zse,publishToStream:eie,request:nie,reloadNATS:$O,reloadNATSHub:sie,reloadNATSLeaf:iie,extractServerName:rie,requestErrorHandler:oie,createLocalTableStream:Mk,createTableStreams:lie,purgeTableStream:vk,purgeSchemaTableStreams:uie,getStreamInfo:die,updateLocalStreams:_ie,closeConnection:zse,getJsmServerName:Sg,addNatsMsgHeader:Pk,clearClientCache:wk,updateRemoteConsumer:aie,createConsumer:Dk,updateConsumerIterator:cie};async function Nk(e,t=void 0){let{stdout:r,stderr:n}=await wse(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
22
22
|
`,""));return r.replace(`
|
|
23
|
-
`,"")}a(ak,"runCommand");async function Ose(){try{await tse.access(bO)}catch{return!1}let e=await ak(`${bO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return rse.eq(t,yse)}a(Ose,"checkNATSServerInstalled");async function CO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await ik.getClusterUser();if(ll(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}li.trace("create nats connection called");let i=await hse({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),li.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&li.error("Error with Nats client connection, connection closed",o),i===Zr&&ck()}),i}a(CO,"createConnection");function ck(){Zr=void 0,ol=void 0,al=void 0,cl=void 0}a(ck,"clearClientCache");async function Nse(){Zr&&(await Zr.drain(),Zr=void 0,ol=void 0,al=void 0,cl=void 0)}a(Nse,"closeConnection");var Zr,cl;async function J_(){return cl||(cl=CO(Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Zr=await cl),Zr||cl}a(J_,"getConnection");async function X_(){if(ol)return ol;ll(Zr)&&await J_();let{domain:e}=Vu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ol=await Zr.jetstreamManager({domain:e,timeout:6e4}),ol}a(X_,"getJetStreamManager");async function lk(){if(al)return al;ll(Zr)&&await J_();let{domain:e}=Vu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return al=Zr.jetstream({domain:e,timeout:6e4}),al}a(lk,"getJetStream");async function Ki(){let e=Zr||await J_(),t=ol||await X_(),r=al||await lk();return{connection:e,jsm:t,js:r}}a(Ki,"getNATSReferences");async function wse(e){let t=Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await ik.getClusterUser(),s=await CO(t,r,n),i=IO(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=ok.decode(f.data);d.response_time=Date.now()-l,c.push(d)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await ig.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(wse,"getServerList");async function PO(e,t){let{jsm:r}=await Ki(),n=Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:pse.File,retention:Ese.Limits,subjects:t,discard:mse.Old,max_msgs:s,max_bytes:i,max_age:n})}a(PO,"createLocalStream");async function uk(){let{jsm:e}=await Ki(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(uk,"listStreams");async function Ise(e){let{jsm:t}=await Ki();await t.streams.delete(e)}a(Ise,"deleteLocalStream");async function Cse(e){let{connection:t}=await Ki(),r=[],n=IO(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(ok.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(Cse,"listRemoteStreams");async function Pse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ki(),i=tk(),o={durable_name:i,ack_policy:NO.Explicit};t&&(o.deliver_policy=wO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let f of l){let d=OO(f.data),h={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(h.origin=f.headers.get(xr.MSG_HEADERS.ORIGIN)),u.push(h),f.ack(),f.info.pending===0)break}return await c.delete(),u}a(Pse,"viewStream");async function*Dse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ki(),i=tk(),o={durable_name:i,ack_policy:NO.Explicit};t&&(o.deliver_policy=wO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let f=OO(u.data);f[0]||(f=[f]);for(let d of f){let h={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(h.origin=u.headers.get(xr.MSG_HEADERS.ORIGIN)),yield h}if(u.ack(),u.info.pending===0)break}await c.delete()}a(Dse,"viewStreamIterator");async function Lse(e,t,r,n){li.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=dk(n,r);let{js:s}=await Ki(),i=await ag(),o=`${e}.${i}`,c=await Ase(()=>n instanceof Uint8Array?n:sk.encode(n));try{li.trace(`publishToStream publishing to subject: ${o}`),Tse(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 _k(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){li.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await PO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Lse,"publishToStream");function dk(e,t){t===void 0&&(t=Sse());let r=Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(xr.MSG_HEADERS.ORIGIN)&&r&&t.append(xr.MSG_HEADERS.ORIGIN,r),t}a(dk,"addNatsMsgHeader");function Vu(e){e=e.toLowerCase();let t=Q_.join(Ir.get(Ve.CONFIG_PARAMS.ROOTPATH),Rse);if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return ll(yO)&&(yO={port:z_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:z_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+xr.SERVER_SUFFIX.HUB,config_file:xr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:Q_.join(t,xr.PID_FILES.HUB),hdb_nats_path:t}),yO;if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return ll(RO)&&(RO={port:z_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:z_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+xr.SERVER_SUFFIX.LEAF,config_file:xr.NATS_CONFIG_FILES.LEAF_SERVER,domain:z_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+xr.SERVER_SUFFIX.LEAF,pid_file_path:Q_.join(t,xr.PID_FILES.LEAF),hdb_nats_path:t}),RO;li.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Vu,"getServerConfig");async function fk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:NO.Explicit,durable_name:r,deliver_policy:wO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(fk,"createConsumer");async function Mse(e,t,r){await e.consumers.delete(t,r)}a(Mse,"removeConsumer");function vse(e){return e.split(".")[1]}a(vse,"extractServerName");async function Use(e,t,r=6e4,n=IO()){if(!ig.isObject(t))throw new Error("data param must be an object");let s=sk.encode(t),{connection:i}=await Ki(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return OO(c.data)}a(Use,"request");function DO(e){return new Promise(async(t,r)=>{let n=ose(bO,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(DO,"reloadNATS");async function xse(){let{pid_file_path:e}=Vu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await DO(e)}a(xse,"reloadNATSHub");async function Bse(){let{pid_file_path:e}=Vu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await DO(e)}a(Bse,"reloadNATSLeaf");function Hse(e,t,r){let n;switch(e.code){case ek.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case ek.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(Hse,"requestErrorHandler");async function kse(e,t){let r=t+xr.SERVER_SUFFIX.LEAF,{connection:n}=await Ki(),{jsm:s}=await Wse(r),{schema:i,table:o}=e,c=og.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await _k(async()=>{if(e.subscribe===!0)await fk(s,c,n.info.server_name,l);else try{await Mse(s,c,n.info.server_name)}catch(u){li.trace(u)}})}a(kse,"updateRemoteConsumer");async function Fse(e,t,r,n){let s=og.createNatsTableStreamName(e,t),i=r+xr.SERVER_SUFFIX.LEAF,o={type:Ve.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!nk&&fse()<Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=AO();await c(o)}await use(o),n==="stop"&&await ig.async_set_timeout(1e3)}a(Fse,"updateConsumerIterator");function _k(e){return lse.writeTransaction(Ve.SYSTEM_SCHEMA_NAME,Ve.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(_k,"exclusiveLock");async function hk(e,t){let r=og.createNatsTableStreamName(e,t),n=await ag(),s=Vse(e,t,n);await PO(r,[s])}a(hk,"createLocalTableStream");async function qse(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await hk(n,s)}}a(qse,"createTableStreams");async function pk(e,t,r=void 0){if(Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=og.createNatsTableStreamName(e,t),{domain:s}=Vu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await J_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")li.warn(n);else throw n}}a(pk,"purgeTableStream");async function Gse(e,t){if(Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await pk(e,t[r])}a(Gse,"purgeSchemaTableStreams");async function $se(e){return(await X_()).streams.info(e)}a($se,"getStreamInfo");function Vse(e,t,r){return`${xr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(Vse,"createSubjectName");async function ag(){if(j_)return j_;if(j_=(await X_())?.nc?.info?.server_name,j_===void 0)throw new Error("Unable to get jetstream manager server name");return j_}a(ag,"getJsmServerName");async function Kse(){let e=await X_(),t=await ag(),r=await uk();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=Yse(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let f=u.join(".");li.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(Kse,"updateLocalStreams");function Yse(e){let{config:t}=e,r=!1,n=Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Ir.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(Yse,"updateStreamLimits");async function Wse(e){let t,r;try{t=await Zr.jetstream({domain:e}),r=await Zr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw li.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Wse,"connectToRemoteJS")});function LO(e){let t=e.get(cg),r=t?(0,Ku.unpack)(t):null;r||(r={remoteNameToId:{}});let n=Xe(),s=!1;r.nodeName=Xe();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:eh(e)??1,nodes:[]})})}i[n]=0,e.putSync(cg,(0,Ku.pack)(r))}return r}function Z_(e){return LO(e).remoteNameToId}function gk(e,t){let r=LO(t),n=r.remoteNameToId,s=new Map,i=!1;for(let o in e){let c=e[o],l=n[o];if(l==null){let u=0;for(let f in n){let d=n[f];d>u&&(u=d)}l=u+1,n[o]=l,i=!0}s.set(c,l)}return i&&t.putSync(cg,(0,Ku.pack)(r)),s}function lg(e,t){let r=LO(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(cg,(0,Ku.pack)(r))}return mk.trace?.("The remote node name map",e,n,s),s}var mk,Ku,cg,MO=be(()=>{mk=x(uo());ts();Ku=require("msgpackr"),cg=Symbol.for("remote-ids");a(LO,"getIdMappingRecord");a(Z_,"exportIdMapping");a(gk,"remoteToLocalNodeId");a(lg,"getIdOfRemoteNode")});var vO={};Be(vO,{commits_awaiting_replication:()=>Wu,getHDBNodeTable:()=>Tr,getReplicationSharedStatus:()=>ug,iterateRoutes:()=>rh,shouldReplicateToNode:()=>th,subscribeToNodeUpdates:()=>zu});function Tr(){return Sk||(Sk=at({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 ug(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function zu(e){Tr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;yk.debug?.("adding node",n,"on node",Xe()," on process",process.pid),server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==Xe()&&(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 th(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&Tr().primaryStore.get(Xe())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function zse(){zu(e=>{xa({},(t,r)=>{let n=e.name,s=Tk.get(n);if(s||Tk.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=ug(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of Wu.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*rh(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=Yu.default.get(H.REPLICATION_SECUREPORT)??(!Yu.default.get(H.REPLICATION_PORT)&&Yu.default.get(H.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||Yu.default.get(H.REPLICATION_PORT)||Yu.default.get(H.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){Ak.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime}}}var Ak,Rk,Yu,yk,Sk,Tk,Wu,ul=be(()=>{Ce();ts();dE();Ak=require("worker_threads"),Rk=x(_e()),Yu=x(ce());v();yk=x(uo());server.nodes=[];a(Tr,"getHDBNodeTable");a(ug,"getReplicationSharedStatus");a(zu,"subscribeToNodeUpdates");a(th,"shouldReplicateToNode");Tk=new Map;eL((e,t,r)=>{if(r>server.nodes.length)throw new Rk.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);Wu||(Wu=new Map,zse());let n=Wu.get(e);return n||(n=[],Wu.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(zse,"startSubscriptionToReplications");a(rh,"iterateRoutes")});var wk={};Be(wk,{connectedToNode:()=>dl,disconnectedFromNode:()=>Ju,ensureNode:()=>Lo,requestClusterStatus:()=>Nk,startOnMainThread:()=>xO});async function xO(e){let t=0,r=Je();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){dg.set(i,eh(l.auditStore));break}}}Yi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes.search([]))i.push(o);for(let o of rh(e))try{let c=!o.subscriptions;if(c){let u=Xe();Tr().primaryStore.get(u)===void 0&&await Lo(u,{name:u,url:e.url??Ba(),replicates:!0})}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}zu(s)});let n;function s(i,o=i?.name){let c=Xe()&&o===Xe()||Ba()&&i?.url===Ba();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let h of Tr().search([]))h.replicates&&h.name!==o&&s(h,h.name);n=d}if(it.trace("Setting up node replication for",i),!i){for(let[d,h]of Do){let _;for(let[p,{worker:S,nodes:g}]of h){let T=g[0];if(T&&T.name==o){_=!0;for(let[m,{worker:A}]of h)h.delete(m),it.warn("Node was deleted, unsubscribing from node",o,m,d),A?.postMessage({type:"unsubscribe-from-node",node:o,database:m,url:d});break}}if(_){Do.get(d).iterator.remove(),Do.delete(d);return}}return}if(c)return;if(!i.url){it.info(`Node ${i.name} is missing url`);return}let l=Do.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(it.info(`Added node ${i.name} at ${i.url} for process ${Xe()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,h]of ju)if(i.url===h.url){ju.delete(d);break}ju.set(i.name,i)}let u=Je();if(l||(l=new Map,Do.set(i.url,l)),l.iterator=xa(e,(d,h,_)=>{_?f(h,!0):f(h,!1)}),i.subscriptions)for(let d of i.subscriptions){let h=d.database||d.schema;u[h]||(it.warn(`Database ${h} not found for node ${i.name}, making a subscription anyway`),f(h,!1))}function f(d,h){it.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),p,S=[{replicateByDefault:h,...i}];dg.has(d)&&(S.push({replicateByDefault:h,name:Xe(),start_time:dg.get(d),end_time:Date.now(),replicates:!0}),dg.delete(d));let g=th(i,d),T=Yi.workers.filter(m=>m.name==="http");if(_?(p=_.worker,_.nodes=S):g&&(t=t%T.length,p=T[t++],l.set(d,{worker:p,nodes:S,url:i.url}),p?.on("exit",()=>{l.get(d)?.worker===p&&(l.delete(d),f(d,h))})),g)setTimeout(()=>{let m={type:"subscribe-to-node",database:d,nodes:S};p?p.postMessage(m):Qu(m)},jse);else{it.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],Tr().primaryStore.get(Xe())?.replicates),Tr().primaryStore.get(Xe())?.replicates||(n=!1);let m={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};p?p.postMessage(m):_g(m)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),Ju=a(function(i){try{it.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(ju.keys()),c=o.sort(),l=c.indexOf(i.name||ui(i.url));if(l===-1){it.warn("Disconnected node not found in node map",i.name,o);return}let u=Do.get(i.url),f=u?.get(i.database);if(!f){it.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished)return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let h=(l+1)%c.length;for(;l!==h;){let _=c[h],p=ju.get(_);u=Do.get(p.url);let S=u?.get(i.database);if(!S){h=(h+1)%c.length;continue}let{worker:g,nodes:T}=S,m=!1;for(let A of f.nodes){if(T.some(w=>w.name===A.name)){it.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}T.push(A),m=!0}if(!m){it.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,it.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:T}):Qu({database:i.database,nodes:T});return}it.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){it.error("Error failing over node",o)}},"disconnectedFromNode"),dl=a(function(i){let o=Do.get(i.url),c=o?.get(i.database);if(!c){it.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,f=u.find(d=>d.name===i.name);c.redirectingTo=null,f&&(u.splice(u.indexOf(f),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):Qu({database:i.database,nodes:u}))}},"connectedToNode"),(0,Yi.onMessageByType)("disconnected-from-node",Ju),(0,Yi.onMessageByType)("connected-to-node",dl),(0,Yi.onMessageByType)("request-cluster-status",Nk)}function Nk(e,t){let r=[];for(let[n,s]of ju)try{let i=Do.get(s.url);it.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:f,nodes:d,latency:h}]of i)o.push({database:l,connected:f,latency:h,thread_id:u?.threadId,nodes:d.map(_=>_.name)});let c=(0,UO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){it.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Lo(e,t){let r=Tr();e=e??ui(t.url),t.name=e;try{if(t.ca){let s=new Ok.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){it.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(it.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!bk.default.get(H.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,UO.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}it.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Yi,fg,it,UO,bk,Ok,jse,Do,Ju,dl,ju,dg,nh=be(()=>{Ce();Yi=x(nt());ts();fg=require("worker_threads");ul();it=x(W()),UO=require("lodash"),bk=x(ce());v();Ok=require("crypto"),jse=200,Do=new Map,ju=new Map,dg=new Map;a(xO,"startOnMainThread");a(Nk,"requestClusterStatus");fg.parentPort&&(Ju=a(e=>{fg.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),dl=a(e=>{fg.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Yi.onMessageByType)("subscribe-to-node",e=>{Qu(e)}),(0,Yi.onMessageByType)("unsubscribe-from-node",e=>{_g(e)}));a(Lo,"ensureNode")});var rs=C(Qk=>{"use strict";var cr=require("path"),In=require("fs-extra"),Xu=require("node-forge"),Mk=require("net"),{generateKeyPair:HO,X509Certificate:Mo,createPrivateKey:vk}=require("crypto"),Qse=require("util");HO=Qse.promisify(HO);var Rt=Xu.pki,di=require("joi"),{v4:Uk}=require("uuid"),{validateBySchema:GO}=pt(),lt=W(),Ns=ce(),ws=(v(),D(q)),{CONFIG_PARAMS:Zu}=ws,fi=Oy(),{ClientError:ka}=_e(),hg=require("node:tls"),{relative:xk,join:Jse}=require("node:path"),{CERT_PREFERENCE_APP:wPe,CERTIFICATE_VALUES:Ik}=fi,Xse=pa(),kO=At(),{table:Zse,getDatabases:eie,databases:BO}=(Ce(),D(tt)),{getJWTRSAKeys:Ck}=Fu();Object.assign(Qk,{generateKeys:KO,updateConfigCert:Vk,createCsr:cie,signCertificate:lie,setCertTable:ed,loadCertificates:qk,reviewSelfSignedCert:WO,createTLSSelector:Yk,listCertificates:zk,addCertificate:pie,removeCertificate:mie,createNatsCerts:fie,generateCertsKeys:die,getReplicationCert:ih,getReplicationCertAuth:aie,renewSelfSigned:_ie,hostnamesFromCert:jk,getKey:gie});var{urlToNodeName:Bk,getThisNodeUrl:tie,getThisNodeName:Eg,clearThisNodeName:rie}=(ts(),D(vo)),{readFileSync:nie,watchFile:sie,statSync:Hk}=require("node:fs"),IPe=ce(),{getTicketKeys:iie,onMessageFromWorkers:oie}=nt(),Ha=W(),{isMainThread:kk}=require("worker_threads"),{TLSSocket:Fk,createSecureContext:CPe}=require("node:tls"),$O=3650,sh=["127.0.0.1","localhost","::1"],VO=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];oie(async e=>{e.type===ws.ITC_EVENT_TYPES.RESTART&&(Ns.initSync(!0),await WO())});var Br;function qa(){return Br||(Br=eie().system.hdb_certificate,Br||(Br=Zse({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__"}]}))),Br}a(qa,"getCertTable");async function ih(){let e=Yk("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Eg());if(!r)return;let n=new Mo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(ih,"getReplicationCert");async function aie(){qa();let e=(await ih()).options.cert,r=new Mo(e).issuer.match(/CN=(.*)/)?.[1];return Br.get(r)}a(aie,"getReplicationCertAuth");var Pk,Fa=new Map;function qk(){if(Pk)return;Pk=!0;let e=[{configKey:Zu.TLS},{configKey:Zu.OPERATIONSAPI_TLS}];qa();let t=cr.dirname(kO.getConfigFilePath()),r;for(let{configKey:n}of e){let s=kO.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&xk(Jse(t,"keys"),o);c&&Dk(o,l=>{Fa.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&kk){let f;Dk(u,d=>{if(Ik.cert===d)return;let h=i.hostname??i.hostnames??i.host??i.hosts;h&&!Array.isArray(h)&&(h=[h]);let _=Kk(u),p=new Mo(_),S;try{S=zO(p)}catch(A){lt.error("error extracting common name from certificate",A);return}if(S==null){lt.error("error extracting common name from certificate");return}if(p.checkIssued(new Mo(Ik.cert)))return;let g=Br.primaryStore.get(S),T=Hk(u).mtimeMs,m=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&T<=m){T<m&<.info(`Certificate ${S} at ${u} is older (${new Date(T)}) than the certificate in the database (${m>1?new Date(m):"only self signed certificate available"})`);return}r=Br.put({name:S,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:_,private_key_name:c,is_authority:l,hostnames:h,file_timestamp:T,details:{issuer:p.issuer.replace(/\n/g," "),subject:p.subject.replace(/\n/g," "),subject_alt_name:p.subjectAltName,serial_number:p.serialNumber,valid_from:p.validFrom,valid_to:p.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(qk,"loadCertificates");function Dk(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&kk&<.warn(`Reloading ${r}:`,e),n=c,t(Kk(e)))}catch(c){lt.error(`Error loading ${r}:`,e,c)}},"loadFile");In.existsSync(e)?s(Hk(e)):lt.error(`${r} file not found:`,e),sie(e,{persistent:!1},s)}a(Dk,"loadAndWatch");function FO(){let e=tie();if(e==null){let t=sh[0];return lt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return Bk(e)}a(FO,"getHost");function pg(){let e=Eg();if(e==null){let t=sh[0];return lt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(pg,"getCommonName");async function cie(){let e=await ih(),t=Rt.certificateFromPem(e.options.cert),r=Rt.privateKeyFromPem(e.options.key);lt.info("Creating CSR with cert named:",e.name);let n=Rt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:pg()},...VO];lt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:Gk()}];return lt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),Xu.pki.certificationRequestToPem(n)}a(cie,"createCsr");function Gk(){let e=sh.includes(pg())?sh:[...sh,pg()];return e.includes(FO())||e.push(FO()),[{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=>Mk.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(Gk,"certExtensions");async function lie(e){let t={},r=cr.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;qa();for await(let f of Br.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(Fa.has(f.private_key_name)){n=Fa.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await In.exists(cr.join(r,f.private_key_name))){n=In.readFile(cr.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await qO();s=f.ca,n=f.private_key}n=Rt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=Rt.certificateFromPem(s.certificate);lt.info("Signing CSR with cert named",s.name);let o=Rt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return lt.error(f),new Error("Error verifying CSR: "+f.message)}let c=Xu.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()+$O),lt.info("sign cert setting validity:",c.validity),lt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),lt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;lt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,Xu.md.sha256.create()),t.certificate=Rt.certificateToPem(c)}else lt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(lie,"signCertificate");async function uie(e,t){await ed({name:Eg(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await ed({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:Rt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(uie,"createCertificateTable");async function ed(e){let t=new Mo(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},qa(),await Br.patch(e)}a(ed,"setCertTable");async function KO(){let e=await HO("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:Rt.publicKeyFromPem(e.publicKey),private_key:Rt.privateKeyFromPem(e.privateKey)}}a(KO,"generateKeys");async function YO(e,t,r){let n=Rt.createCertificate();if(!t){let o=await ih();t=Rt.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()+$O);let i=[{name:"commonName",value:pg()},...VO];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(Gk()),n.sign(e,Xu.md.sha256.create()),Rt.certificateToPem(n)}a(YO,"generateCertificates");async function qO(){let e=await zk(),t;for(let r of e){if(!r.is_authority)continue;let n=await Wk(r.private_key_name);if(r.private_key_name&&n&&new Mo(r.certificate).checkPrivateKey(vk(n))){lt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;lt.trace("No CA found with matching private key")}a(qO,"getCertAuthority");async function $k(e,t,r=!0){let n=Rt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+$O);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${Ns.get(Zu.REPLICATION_HOSTNAME)??Bk(Ns.get(Zu.REPLICATION_URL))??Uk().split("-")[0]}`},...VO];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,Xu.md.sha256.create());let o=cr.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),c=cr.join(o,fi.PRIVATEKEY_PEM_NAME);return r&&await In.writeFile(c,Rt.privateKeyToPem(e)),n}a($k,"generateCertAuthority");async function die(){let{private_key:e,public_key:t}=await KO(),r=await $k(e,t),n=await YO(e,t,r);await uie(n,r),Vk()}a(die,"generateCertsKeys");async function fie(){let e=await YO(Rt.privateKeyFromPem(fi.CERTIFICATE_VALUES.key),void 0,Rt.certificateFromPem(fi.CERTIFICATE_VALUES.cert)),t=cr.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),r=cr.join(t,fi.NATS_CERTIFICATE_PEM_NAME);await In.exists(r)||await In.writeFile(r,e);let n=cr.join(t,fi.NATS_CA_PEM_NAME);await In.exists(n)||await In.writeFile(n,fi.CERTIFICATE_VALUES.cert)}a(fie,"createNatsCerts");async function _ie(){qa();for await(let e of Br.search([{attribute:"is_self_signed",value:!0}]))await Br.delete(e.name);await WO()}a(_ie,"renewSelfSigned");async function WO(){rie(),await qk(),qa();let e=await qO();if(!e){lt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=Ns.get(Zu.TLS_PRIVATEKEY),n=cr.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),s,i=xk(n,r);try{s=Rt.privateKeyFromPem(await In.readFile(r))}catch(c){lt.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await KO(),await In.exists(cr.join(n,fi.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${Uk().split("-")[0]}.pem`),await In.writeFile(cr.join(n,i),Rt.privateKeyToPem(s))}let o=await $k(s,Rt.setRsaPublicKey(s.n,s.e),!1);await ed({name:o.subject.getField("CN").value,uses:["https"],certificate:Rt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await ih()){let r=Eg();lt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await qO();let n=Rt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await YO(Rt.privateKeyFromPem(e.private_key),s,n);await ed({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(WO,"reviewSelfSignedCert");function Vk(){let e=Xse(Object.keys(ws.CONFIG_PARAM_MAP),!0),t=cr.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),r=cr.join(t,fi.PRIVATEKEY_PEM_NAME),n=cr.join(t,fi.NATS_CERTIFICATE_PEM_NAME),s=cr.join(t,fi.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),kO.updateConfigValue(void 0,void 0,o,!1,!0)}a(Vk,"updateConfigCert");function Kk(e){return e.startsWith("-----BEGIN")?e:nie(e,"utf8")}a(Kk,"readPEM");var Lk=hg.createSecureContext;hg.createSecureContext=function(e){if(!e.cert||!e.key)return Lk(e);let t={...e};delete t.key,delete t.cert;let r=Lk(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var hie=Fk.prototype._init;Fk.prototype._init=function(e,t){hie.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var fl=new Map;function Yk(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),fl.clear();let f=0;for await(let d of BO.system.hdb_certificate.search([])){let h=d.certificate,_=new Mo(h);d.is_authority&&(_.asString=h,fl.set(_.subject,h))}for await(let d of BO.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let h=e==="operations-api",_=d.is_self_signed?1:2;h&&d.uses?.includes?.("operations")&&(_+=1);let p=await Wk(d.private_key_name),S=d.certificate,g=new Mo(S);if(fl.has(g.issuer)&&(S+=`
|
|
24
|
-
`+fl.get(g.issuer)),!p||!S)throw new Error("Missing private key or certificate for secure server");let T={ciphers:d.ciphers,ticketKeys:iie(),availableCAs:fl,ca:t&&Array.from(fl.values()),cert:S,key:p,key_file:d.private_key_name,is_self_signed:d.is_self_signed};o&&(T.sessionIdContext=o.sessionIdContext);let m=hg.createSecureContext(T);m.name=d.name,m.options=T,m.quality=_,m.certificateAuthorities=Array.from(fl),m.certStart=S.toString().slice(0,100);let A=d.hostnames??jk(g);Array.isArray(A)||(A=[A]);let w;for(let M of A)if(M){M[0]==="*"&&(s=!0,M=M.slice(1)),M===FO()&&(_+=2),Mk.isIP(M)&&(w=!0);let F=r.get(M)?.quality??0;_>F&&r.set(M,m)}else Ha.error("No hostname found for certificate at",hg.certificate);Ha.trace("Adding TLS",m.name,"for",o.ports||"client","cert named",d.name,"hostnames",A,"quality",_,"best quality",f),_>f&&(i.defaultContext=n=m,f=_,o&&(o.defaultContext=m))}catch(h){Ha.error("Error applying TLS for",d.name,h)}o?.secureContextsListeners.forEach(d=>d()),c(n)}catch(f){l(f)}}a(u,"updateTLS"),BO.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){Ha.info("TLS requested for",o||"(no SNI)");let l=o;for(;;){let f=r.get(l);if(f)return Ha.debug("Found certificate for",o,f.certStart),f.updatedContext&&(f=f.updatedContext),c(null,f);if(s&&l){let d=l.indexOf(".",1);d<0?l="":l=l.slice(d)}else break}o?Ha.debug("No certificate found to match",o,"using the default certificate"):Ha.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):Ha.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(Yk,"createTLSSelector");async function Wk(e){let t=Fa.get(e);return!t&&e?await In.readFile(cr.join(Ns.get(Zu.ROOTPATH),ws.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(Wk,"getPrivateKeyByName");async function zk(){qa();let e=[];for await(let t of Br.search([]))e.push(t);return e}a(zk,"listCertificates");async function pie(e){let t=GO(e,di.object({name:di.string().required(),certificate:di.string().required(),is_authority:di.boolean().required(),private_key:di.string(),hosts:di.array(),uses:di.array()}));if(t)throw new ka(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new Mo(n),c=!1,l=!1,u;for(let[_,p]of Fa)!s&&!c&&o.checkPrivateKey(vk(p))&&(c=!0,u=_),s&&s===p&&(l=!0,u=_);if(!i&&!s&&!c)throw new ka("A suitable private key was not found for this certificate");let f;if(!r){try{f=zO(o)}catch(_){lt.error(_)}if(f==null)throw new ka("Error extracting certificate common name, please provide a name parameter")}let d=Eie(r??f);s&&!c&&!l&&(await In.writeFile(cr.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME,d+".pem"),s),Fa.set(d,s));let h={name:r??f,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(h.private_key_name=u??d+".pem"),await ed(h),"Successfully added certificate: "+d}a(pie,"addCertificate");function Eie(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(Eie,"sanitizeName");async function mie(e){let t=GO(e,di.object({name:di.string().required()}));if(t)throw new ka(t.message);let{name:r}=e;qa();let n=await Br.get(r);if(!n)throw new ka(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Br.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(lt.info("Removing private key named",s),await In.remove(cr.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME,s)))}return await Br.delete(r),"Successfully removed "+r}a(mie,"removeCertificate");function zO(e){return e.subject.match(/CN=(.*)/)?.[1]}a(zO,"extractCommonName");function jk(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):[zO(e)]}a(jk,"hostnamesFromCert");async function gie(e){if(e.bypass_auth!==!0)throw new ka("Unauthorized","401");let t=GO(e,di.object({name:di.string().required()}));if(t)throw new ka(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await Ck()).private_key;if(r===".jwtPublic")return(await Ck()).public_key;if(Fa.get(r))return Fa.get(e.name);throw new ka("Key not found")}a(gie,"getKey")});var pF={};Be(pF,{CONFIRMATION_STATUS_POSITION:()=>hF,NodeReplicationConnection:()=>oh,OPERATION_REQUEST:()=>ZO,RECEIVED_TIME_POSITION:()=>tN,RECEIVED_VERSION_POSITION:()=>eN,SENDING_TIME_POSITION:()=>Ag,createWebSocket:()=>yg,database_subscriptions:()=>$a,replicateOverWS:()=>ah,table_update_listeners:()=>nN});async function yg(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Xe(),i;if(e.includes("wss://")){if(!QO){let l=(0,dF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),QO=u.secureContexts}if(i=QO.get(s),i&&ue.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,_F.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=fF.createSecureContext({...i.options,ca:Array.from(hl)})),new lF.WebSocket(e,"harperdb-replication-v1",c)}function ah(e,t,r){let n=t.port||t.securePort,s=_l.pid%1e3+"-"+uF.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,f=t.databaseSubscriptions||$a,d,h,_=!1,p=t.subscription;p?.then&&p.then(R=>p=R);let S=t.tables||u&&Je()[u];if(!r){ue.error?.("No authorization provided"),mt(1008,"Unauthorized");return}let g=new Map,T=[],m=r.name;m&&t.connection&&(t.connection.nodeName=m);let A,w,M,F,G,K,ee,ie=1e3,X,re=0,j=0,he=0,Te=new Map,Ie=[],pe=0,qt;if(t.url){let R=a(()=>{G&&j===e._socket?.bytesRead&&he===e._socket?.bytesWritten?e.terminate():(G=performance.now(),e.ping(),j=e._socket?.bytesRead,he=e._socket?.bytesWritten)},"send_ping");M=setInterval(R,oF).unref(),R()}else Gt();e._socket?.setMaxListeners(200);function Gt(){clearTimeout(F),j=e._socket?.bytesRead,he=e._socket?.bytesWritten,F=setTimeout(()=>{j===e._socket?.bytesRead&&he===e._socket?.bytesWritten&&(ue.warn?.(`Timeout waiting for ping from ${m}, terminating connection and reconnecting`),e.terminate())},oF*2).unref()}a(Gt,"resetPingTimer");function Zt(){return h||(h=ug(d,u,m)),h}a(Zt,"getSharedStatus"),u&&mf(u);let pr,df,gc=[],TA=[],AA,Dt=[],ff=[],_f=[],RA=150,kp=25,hf=0,Le=0,pf=!1,oo,Pr,kn,Sc;e.on("message",R=>{re=performance.now();try{let y=R.dataView=new pl(R.buffer,R.byteOffset,R.byteLength);if(R[0]>127){let L=(0,ze.decode)(R),[B,N,U]=L;switch(B){case Xk:{if(N){if(m){if(m!==N){ue.error?.(s,`Node name mismatch, expecting to connect to ${m}, but peer reported name as ${N}, disconnecting`),e.send((0,ze.encode)([td])),mt(1008,"Node name mismatch");return}}else if(m=N,t.connection?.tentativeNode){let oe=t.connection.tentativeNode;oe.name=m,t.connection.tentativeNode=null,Lo(m,oe)}if(t.connection&&(t.connection.nodeName=m),ue.debug?.(s,"received node name:",m,"db:",u),!u)try{mf(u=L[2]),u==="system"&&(pr=xa(t,(oe,le)=>{ao(le)&&da(le)}),e.on("close",()=>{pr?.remove()}))}catch(oe){ue.warn?.(s,"Error setting database",oe),e.send((0,ze.encode)([td])),mt(1008,oe.message);return}iu()}break}case sF:{ue.debug?.(s,"Received table definitions for",N.map(oe=>oe.table));for(let oe of N){let le=L[2];oe.database=le;let se;ao(le)&&(le==="system"?$e[le]?.[oe.table]||(se=JO(oe,$e[le]?.[oe.table])):se=JO(oe,$e[le]?.[oe.table]),d||(d=se?.auditStore),S||(S=Je()?.[le]))}break}case td:mt();break;case ZO:try{let oe=r?.replicates||r?.subscribers||r?.name;server.operation(N,{user:r},!oe).then(le=>{Array.isArray(le)&&(le={results:le}),le.requestId=N.requestId,e.send((0,ze.encode)([gg,le]))},le=>{e.send((0,ze.encode)([gg,{requestId:N.requestId,error:le instanceof Error?le.toString():le}]))})}catch(oe){e.send((0,ze.encode)([gg,{requestId:N.requestId,error:oe instanceof Error?oe.toString():oe}]))}break;case gg:let{resolve:$,reject:Y}=g.get(N.requestId);N.error?Y(new Error(N.error)):$(N),g.delete(N.requestId);break;case jO:let ne=L[3];S||(u?ue.error?.(s,"No tables found for",u):ue.error?.(s,"Database name never received"));let k=S[ne];k=JO({table:ne,database:u,attributes:N.attributes,schemaDefined:N.schemaDefined},k),gc[U]={name:ne,decoder:new ze.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:N.typedStructs,structures:N.structures}),getEntry(oe){return k.primaryStore.getEntry(oe)},rootStore:k.primaryStore.rootStore};break;case Zk:Sc=d?gk(N,d):new Map,AA=L[2],ue.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${AA}`);break;case eF:let ve=U;_f[ve]=N;break;case nF:Zt()[hF]=N,ue.trace?.(s,"received and broadcasting committed update",N),Zt().buffer.notify();break;case rF:A=N,p.send({type:"end_txn",localTime:A,remoteNodeIds:T});break;case Sg:{let oe=L[1],{fileId:le,size:se,finished:Q,error:fe}=oe,Ee=Te.get(le);ue.debug?.("Received blob",le,"has stream",!!Ee,"connectedToBlob",!!Ee?.connectedToBlob,"length",L[2].length,"finished",Q),Ee||(Ee=new XO.PassThrough,Ee.expectedSize=se,Te.set(le,Ee)),Ee.lastChunk=Date.now(),Q?(fe?(Ee.on("error",()=>{}),Ee.destroy(new Error("Blob error: "+fe))):Ee.end(L[2]),Ee.connectedToBlob&&Te.delete(le)):Ee.write(L[2]);break}case tF:{let oe=N,le;try{let se=L[3],Q=TA[U]||(TA[U]=S[L[4]]);if(!Q)return ue.warn?.("Unknown table id trying to handle record request",U);let fe=Q.primaryStore.getBinaryFast(Symbol.for("structures")),Ee=fe.length;if(Ee!==Le){Le=Ee;let Me=(0,ze.decode)(fe);e.send((0,ze.encode)([jO,{typedStructs:Me.typed,structures:Me.named},U,Q.tableName]))}let ye=Q.primaryStore.getBinaryFast(se);if(ye){let Me=Q.primaryStore.decoder.decode(ye,{valueAsBuffer:!0});le=(0,ze.encode)([mg,oe,{value:Me.value,expiresAt:Me.expiresAt,version:Me.version,residencyId:Me.residencyId,nodeId:Me.nodeId,user:Me.user}])}else le=(0,ze.encode)([mg,oe])}catch(se){le=(0,ze.encode)([mg,oe,{error:se.message}])}e.send(le);break}case mg:{let{resolve:oe,reject:le,tableId:se,key:Q}=g.get(L[1]),fe=L[2];if(fe?.error)le(new Error(fe.error));else if(fe){let Ee=gc[se].decoder.decode(fe.value);fe.value=Ee,fe.key=Q,oe(fe)}else oe();g.delete(L[1]);break}case Jk:{kn=N;let oe,le,se=!1;if(p){if(u!==p.databaseName&&!p.then){ue.error?.("Subscription request for wrong database",u,p.databaseName);return}}else p=f.get(u);if(ue.debug?.(s,"received subscription request for",u,"at",kn),!p){let Ae;p=new Promise(bt=>{ue.debug?.("Waiting for subscription to database "+u),Ae=bt}),p.ready=Ae,$a.set(u,p)}if(r.name)le=Tr().subscribe(r.name),le.then(async Ae=>{oe=Ae;for await(let bt of oe){let er=bt.value;if(!(er?.replicates===!0||er?.replicates?.receives||er?.subscriptions?.some(Er=>(Er.database||Er.schema)===u&&Er.publish!==!1))){se=!0,e.send((0,ze.encode)([td])),mt(1008,`Unauthorized database subscription to ${u}`);return}}},Ae=>{ue.error?.(s,"Error subscribing to HDB nodes",Ae)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,ze.encode)([td])),mt(1008,`Unauthorized database subscription to ${u}`);return}if(Pr&&(ue.debug?.(s,"stopping previous subscription",u),Pr.emit("close")),kn.length===0)return;let Q=kn[0],fe=a(Ae=>{if(Ae&&(Q.replicateByDefault?!Q.tables.includes(Ae.tableName):Q.tables.includes(Ae.tableName)))return{table:Ae}},"tableToTableEntry"),Ee={txnTime:0},ye,Me,et=1/0,$r,Dr=a((Ae,bt)=>{if(Ae.type==="end_txn"){Ee.txnTime&&(o[i]!==66&&ue.error?.("Invalid encoding of message"),fa(9),fa(Rg),E($r=bt),zs()),i=c,Ee.txnTime=0;return}let er=Ae.nodeId,Er=Ae.tableId,$t=Me[Er];if(!$t&&($t=Me[Er]=fe(p.tableById[Er]),!$t))return ue.debug?.("Not subscribed to table",Er);let Vr=$t.table,Tc=Vr.primaryStore,Lt=Tc.encoder;(Ae.extendedType&kE||!Lt.typedStructs)&&(Lt._mergeStructures(Lt.getStructures()),Lt.typedStructs&&(Lt.lastTypedStructuresLength=Lt.typedStructs.length));let Gp=ye[er];if(!(Gp&&Gp.startTime<bt&&(!Gp.endTime||Gp.endTime>bt)))return Tg&&ue.trace?.(s,"skipping replication update",Ae.recordId,"to:",m,"from:",er,"subscribed:",ye),HP();Tg&&ue.trace?.(s,"sending replication update",Ae.recordId,"to:",m,"from:",er,"subscribed:",ye);let yA=Ae.version;Ee.txnTime!==yA&&(Ee.txnTime&&(Tg&&ue.trace?.(s,"new txn time, sending queued txn",Ee.txnTime),o[i]!==66&&ue.error?.("Invalid encoding of message"),zs()),Ee.txnTime=yA,i=c,E(yA));let Ac=Ae.residencyId,bA=Ef(Ac,Vr),$p;if(bA&&!bA.includes(m)){let Rc=Ef(Ae.previousResidencyId,Vr);if(Rc&&!Rc.includes(m)&&(Ae.type==="put"||Ae.type==="patch")||Vr.getResidencyById)return HP();let Sf=Ae.recordId;ue.trace?.(s,"sending invalidation",Sf,m,"from",er);let _a=0;Ac&&(_a|=xc),Ae.previousResidencyId&&(_a|=Bc);let js,dn=null;for(let Vp in Vr.indices){if(!dn){if(js=Ae.getValue(Tc,!0),!js)break;dn={}}dn[Vp]=js[Vp]}$p=Su(Ae.version,Er,Sf,null,er,Ae.user,Ae.type==="put"||Ae.type==="patch"?"invalidate":Ae.type,Lt.encode(dn),_a,Ac,Ae.previousResidencyId,Ae.expiresAt)}function HP(){ue.trace?.(s,"skipping audit record",Ae.recordId),K||(K=setTimeout(()=>{K=null,($r||0)+iF/2<et&&(Tg&&ue.trace?.(s,"sending skipped sequence update",et),e.send((0,ze.encode)([rF,et])))},iF).unref())}a(HP,"skipAuditRecord");let OA=Lt.typedStructs,NA=Lt.structures;if((OA?.length!=$t.typed_length||NA?.length!=$t.structure_length)&&($t.typed_length=OA?.length,$t.structure_length=NA.length,ue.debug?.(s,"send table struct",$t.typed_length,$t.structure_length),$t.sentName||($t.sentName=!0),e.send((0,ze.encode)([jO,{typedStructs:OA,structures:NA,attributes:Vr.attributes,schemaDefined:Vr.schemaDefined},Er,$t.table.tableName]))),Ac&&!ff[Ac]&&(e.send((0,ze.encode)([eF,bA,Ac])),ff[Ac]=!0),$p)fa($p.length),z($p);else{let Rc=Ae.encoded;Ae.extendedType&ei&&fR(()=>Ae.getValue(Tc),async _a=>{let js=wE(_a);try{let dn;pe++;for await(let Vp of _a.stream()){if(dn&&(ue.debug?.("Sending blob chunk",js,"length",dn.length),e.send((0,ze.encode)([Sg,{fileId:js,size:_a.size},dn]))),dn=Vp,se)return;e._socket.writableNeedDrain&&(ue.debug?.("draining",js),await new Promise(xQ=>e._socket.once("drain",xQ)),ue.debug?.("drained",js))}ue.debug?.("Sending final blob chunk",js,"length",dn.length),e.send((0,ze.encode)([Sg,{fileId:js,size:_a.size,finished:!0},dn]))}catch(dn){ue.debug?.("Error sending blob",dn),e.send((0,ze.encode)([Sg,{fileId:js,finished:!0,error:dn.toString()},Buffer.alloc(0)]))}finally{pe--,pe<kp&&qt?.()}});let Sf=Rc[0]===66?8:0;fa(Rc.length-Sf),z(Rc,Sf),ue.trace?.("wrote record",Ae.recordId,"length:",Rc.length)}},"sendAuditRecord"),zs=a(()=>{c-i>8?(e.send(o.subarray(i,c)),ue.debug?.(s,"Sent message, size:",c-i)):ue.debug?.(s,"skipping empty transaction")},"sendQueuedData");Pr=new rN.EventEmitter,Pr.once("close",()=>{se=!0,oe?.end()});for(let{startTime:Ae}of kn)Ae<et&&(et=Ae);(le||Promise.resolve()).then(async()=>{p=await p,d=p.auditStore,Me=p.tableById.map(fe),ye=[];for(let{name:bt,startTime:er,endTime:Er}of kn){let $t=lg(bt,d);ue.debug?.("subscription to",bt,"using local id",$t,"starting",er),ye[$t]={startTime:er,endTime:Er}}da(u),pr||(pr=El(bt=>{bt.databaseName===u&&da(u)}),df=ch(bt=>{bt===u&&(e.send((0,ze.encode)([td])),mt())}),e.on("close",()=>{pr?.remove(),df?.remove()})),e.send((0,ze.encode)([Zk,Z_(p.auditStore),kn.map(({name:bt})=>bt)]));let Ae=!0;do{isFinite(et)||(ue.warn?.("Invalid sequence id "+et),mt(1008,"Invalid sequence id"+et));let bt;if(Ae&&!se&&(Ae=!1,!(iN(d)<=et)&&(cF.default.get(H.REPLICATION_COPYTABLESTOCATCHUP)??Sie)&&server.nodes[0]?.name===m)){ue.info?.("Replicating all tables to",m);let Er=et,$t=bg(d);for(let Vr in S){if(!fe(Vr))continue;let Tc=S[Vr];for(let Lt of Tc.primaryStore.getRange({snapshot:!1})){if(se)return;Lt.localTime>=et&&(ue.trace?.(s,"Copying record from",u,Vr,Lt.key,Lt.localTime),Er=Math.max(Lt.localTime,Er),bt=!0,Zt()[Ag]=1,Dr({recordId:Lt.key,tableId:Tc.tableId,type:"put",getValue(){return Lt.value},encoded:Tc.primaryStore.getBinary(Lt.key),version:Lt.version,residencyId:Lt.residencyId,nodeId:$t,extendedType:Lt.metadataFlags},Lt.localTime))}}et=Er}for(let{key:er,value:Er}of d.getRange({start:et||1,exclusiveStart:!0,snapshot:!1})){if(se)return;let $t=Nt(Er);ue.debug?.("sending audit record",new Date(er)),Zt()[Ag]=er,et=er,Dr($t,er),e._socket.writableNeedDrain?await new Promise(Vr=>{ue.debug?.(`Waiting for remote node ${m} to allow more commits ${e._socket.writableNeedDrain?"due to network backlog":"due to requested flow directive"}`),e._socket.once("drain",Vr)}):pe>kp?await new Promise(Vr=>{qt=Vr}):await new Promise(setImmediate),Pr.startTime=er,bt=!0}bt&&Dr({type:"end_txn"},et),Zt()[Ag]=0,await EF(d)}while(!se)}).catch(Ae=>{ue.error?.(s,"Error handling subscription to node",Ae),mt(1008,"Error handling subscription to node")});break}}return}y.position=8;let b=!0,P,I;do{Zt();let L=y.readInt();if(L===9&&y.getUint8(y.position)==Rg){y.position++,A=I=y.readFloat64(),h[eN]=A,h[tN]=Date.now(),ue.trace?.("received remote sequence update",A,u);break}let B=y.position,N=Nt(R,B,B+L),U=gc[N.tableId];U||ue.error?.(`No table found with an id of ${N.tableId}`);let $;N.residencyId&&($=_f[N.residencyId],ue.trace?.(s,"received residency list",$,N.type,N.recordId));try{dR(()=>{P={table:U.name,id:N.recordId,type:N.type,nodeId:Sc.get(N.nodeId),residencyList:$,timestamp:N.version,value:N.getValue(U),user:N.user,beginTxn:b,expiresAt:N.expiresAt}},Y=>{let ne=wE(Y),k=Te.get(ne);ue.debug?.("Received transaction with blob",ne,"has stream",!!k,"ended",!!k?.writableEnded),k?k.writableEnded&&Te.delete(ne):(k=new XO.PassThrough,Te.set(ne,k)),k.connectedToBlob=!0,k.lastChunk=Date.now(),Y.size===void 0&&k.expectedSize&&(Y.size=k.expectedSize);let ve=createBlob(k,Y),oe=ve.save({primaryStore:p.auditStore});return oe&&(oe.blobId=ne,Ie.push(oe),oe.finally(()=>{ue.debug?.(`Finished receiving blob stream ${ne}`),Ie.splice(Ie.indexOf(oe),1)})),ve})}catch(Y){throw Y.message+="typed structures for current decoder"+JSON.stringify(U.decoder.typedStructs),Y}b=!1,ue.trace?.(s,"received replication message",N.type,"id",P.id,"version",new Date(N.version),"nodeId",P.nodeId),h[eN]=N.version,h[tN]=Date.now(),p.send(P),y.position=B+L}while(y.position<R.byteLength);hf++,or(R.byteLength,"bytes-received",m+"."+u+"."+P.table,"replication","ingest"),hf>RA&&!pf&&(pf=!0,e.pause(),ue.debug?.(`Commit backlog causing replication back-pressure, requesting that ${m} pause replication`)),p.send({type:"end_txn",localTime:A,remoteNodeIds:T,async onCommit(){if(P){let L=Date.now()-P.timestamp;or(L,"replication-latency",m+"."+u+"."+P.table,P.type,"ingest")}hf--,pf&&(pf=!1,e.resume(),ue.debug?.(`Replication resuming ${m}`)),Ie.length>0&&await Promise.all(Ie),ue.trace?.("All blobs finished"),!w&&I&&(ue.trace?.(s,"queuing confirmation of a commit at",I),setTimeout(()=>{e.send((0,ze.encode)([nF,w])),ue.trace?.(s,"sent confirmation of a commit at",w),w=null},Tie)),w=I,ue.debug?.("last sequence committed",new Date(I),u)}})}catch(y){ue.error?.(s,"Error handling incoming replication message",y)}}),e.on("ping",Gt),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-G,dl({name:m,database:u,url:t.url,latency:t.connection.latency})),G=null}),e.on("close",(R,y)=>{clearInterval(M),clearTimeout(F),clearInterval(ee),Pr&&Pr.emit("close"),oo&&oo.end();for(let[b,{reject:P}]of g)P(new Error(`Connection closed ${y?.toString()} ${R}`));ue.debug?.(s,"closed",R,y?.toString())});function Fp(){}a(Fp,"recordRemoteNodeSequence");function mt(R,y){e.isFinished=!0,e.close(R,y)}a(mt,"close");function iu(){if(_||(_=!0,t.connection?.on("subscriptions-updated",iu)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let R=new Map;try{for(let P of p?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let I of P.value.nodes||[])I.lastTxnTime>(R.get(I.id)??0)&&R.set(I.id,I.lastTxnTime)}catch(P){if(!P.message.includes("Can not re"))throw P}let y=t.connection?.nodeSubscriptions?.[0];T=[];let b=t.connection?.nodeSubscriptions.map((P,I)=>{let L=[],{replicateByDefault:B}=P;if(P.subscriptions){for(let Y of P.subscriptions)if(Y.subscribe&&(Y.schema||Y.database)===u){let ne=Y.table;S?.[ne]?.replicate!==!1&&L.push(ne)}B=!1}else for(let Y in S)(B?S[Y].replicate===!1:S[Y].replicate)&&L.push(Y);let N=d&&lg(P.name,d),U=p?.dbisDB?.get([Symbol.for("seq"),N])??1,$=Math.max(U?.seqId??1,(typeof P.start_time=="string"?new Date(P.start_time).getTime():P.start_time)??1);if(ue.debug?.("Starting time recorded in db",P.name,N,u,U?.seqId,"start time:",$,new Date($)),y!==P){let Y=d&&lg(y.name,d),ne=p?.dbisDB?.get([Symbol.for("seq"),Y])??1;for(let k of ne?.nodes||[])k.name===P.name&&($=k.seqId,ue.debug?.("Using sequence id from proxy node",y.name,$))}return T.push(N),R.get(N)>$&&($=R.get(N),ue.debug?.("Updating start time from more recent txn recorded",y.name,$)),{name:P.name,replicateByDefault:B,tables:L,startTime:$,endTime:P.end_time}});if(b)if(ue.debug?.(s,"sending subscription request",b,p?.dbisDB?.path),clearTimeout(X),b.length>0)e.send((0,ze.encode)([Jk,b]));else{let P=a(()=>{let I=performance.now();X=setTimeout(()=>{re<=I?mt(1008,"No nodes to subscribe to"):P()},ie)},"schedule_close");P()}}a(iu,"sendSubscriptionRequestUpdate");function Ef(R,y){if(!R)return;let b=Dt[R];return b||(b=y.getResidencyRecord(R),Dt[R]=b),b}a(Ef,"getResidence");function ao(R){return!(Ga&&Ga!="*"&&!Ga[R]&&!Ga.includes?.(R)&&!Ga.some?.(y=>y.name===R))}a(ao,"checkDatabaseAccess");function mf(R){if(p=p||f.get(R),!ao(R))throw new Error(`Access to database "${R}" is not permitted`);p||ue.warn?.(`No database named "${R}" was declared and registered`),d=p?.auditStore,S||(S=Je()?.[R]);let y=Xe();if(y===m)throw y?new Error("Should not connect to self",y):new Error("Node name not defined");return ou(y,R),!0}a(mf,"setDatabase");function ou(R,y){let b=Je()?.[y],P=[];for(let I in b){let L=b[I];P.push({table:I,schemaDefined:L.schemaDefined,attributes:L.attributes.map(B=>({name:B.name,type:B.type,isPrimaryKey:B.isPrimaryKey}))})}ue.trace?.("Sending database info for node",R,"database name",y),e.send((0,ze.encode)([Xk,R,y,P]))}a(ou,"sendNodeDBName");function da(R){let y=Je()?.[R],b=[];for(let P in y){if(kn&&!kn.some(L=>L.replicateByDefault?!L.tables.includes(P):L.tables.includes(P)))continue;let I=y[P];b.push({table:P,schemaDefined:I.schemaDefined,attributes:I.attributes.map(L=>({name:L.name,type:L.type,isPrimaryKey:L.isPrimaryKey}))})}e.send((0,ze.encode)([sF,b,R]))}a(da,"sendDBSchema"),ee=setInterval(()=>{for(let[R,y]of Te)y.lastChunk+3e4<Date.now()&&(ue.warn?.(`Timeout waiting for blob stream to finish ${R} from ${m}`),Te.delete(R),y.end())},3e4).unref();let gf=1,qp=[];return{end(){oo&&oo.end(),Pr&&Pr.emit("close")},getRecord(R){let y=gf++;return new Promise((b,P)=>{let I=[tF,y,R.table.tableId,R.id];qp[R.table.tableId]||(I.push(R.table.tableName),qp[R.table.tableId]=!0),e.send((0,ze.encode)(I)),g.set(y,{tableId:R.table.tableId,key:R.id,resolve(L){let{table:B,entry:N}=R;b(L),L&&B._recordRelocate(N,L)},reject:P})})},sendOperation(R){let y=gf++;return R.requestId=y,e.send((0,ze.encode)([ZO,R])),new Promise((b,P)=>{g.set(y,{resolve:b,reject:P})})}};function fa(R){O(5),R<128?o[c++]=R:R<16384?(l.setUint16(c,R|32768),c+=2):R<1056964608?(l.setUint32(c,R|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,R),c+=5)}function z(R,y=0,b=R.length){let P=b-y;O(P),R.copy(o,c,y,b),c+=P}function E(R){O(8),l.setFloat64(c,R),c+=8}function O(R){if(R+16>o.length-c){let y=Buffer.allocUnsafeSlow(c+R-i+65536>>10<<11);o.copy(y,0,i,c),c=c-i,i=0,o=y,l=new DataView(o.buffer,0,o.length)}}}function JO(e,t){let r=e.database??"data";if(r!=="data"&&!$e[r]){ue.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?(ue.debug?.("(Re)creating",e),at({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var cF,ze,lF,uF,ue,rN,dF,fF,_l,_F,XO,Jk,Xk,Zk,td,eF,jO,tF,mg,ZO,gg,rF,nF,sF,Sg,hF,eN,tN,Ag,Sie,nN,$a,Tg,iF,Tie,oF,QO,aF,oh,sN=be(()=>{Ce();So();MO();oN();ts();cF=x(ce());v();Tu();ze=require("msgpackr"),lF=require("ws"),uF=require("worker_threads"),ue=x(uo());nh();rN=require("events"),dF=x(rs()),fF=x(require("node:tls"));ul();_l=x(require("node:process")),_F=require("node:net");$i();Ts();XO=require("node:stream"),Jk=129,Xk=140,Zk=141,td=142,eF=130,jO=132,tF=133,mg=134,ZO=136,gg=137,rF=143,nF=144,sF=145,Sg=146,hF=0,eN=1,tN=2,Ag=3,Sie=_l.env.HDB_LEADER_URL||_l.argv.includes("--HDB_LEADER_URL"),nN=new Map,$a=new Map,Tg=!0,iF=300,Tie=2,oF=3e4;a(yg,"createWebSocket");aF=1e3,oh=class extends rN.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??ui(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=aF;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await yg(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;ue.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${_l.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),ue[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=aF,dl({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=ah(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(ue.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?ue.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):ue.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(Ju({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();ue.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(ah,"replicateOverWS");a(JO,"ensureTableIfChanged")});var vo={};Be(vo,{clearThisNodeName:()=>Iie,disableReplication:()=>bie,enabled_databases:()=>Ga,forEachReplicatedDatabase:()=>xa,getThisNodeId:()=>bg,getThisNodeName:()=>Xe,getThisNodeUrl:()=>Ba,hostnameToUrl:()=>Ig,lastTimeInAuditStore:()=>eh,monitorNodeCAs:()=>bF,replicateOperation:()=>Pie,replication_certificate_authorities:()=>hl,sendOperationToNode:()=>uh,servers:()=>Rie,setReplicator:()=>NF,start:()=>yie,startOnMainThread:()=>xO,subscribeToNode:()=>Qu,unsubscribeFromNode:()=>_g,urlToNodeName:()=>ui});function yie(e){if(e.port||(e.port=Is.default.get(H.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=Is.default.get(H.OPERATIONSAPI_NETWORK_SECUREPORT)),!Xe())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of rh(e))t.set(ui(n.url),n);Oie(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=Qe.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),ah(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&Ar.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,Qe.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&Ar.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=Tr().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:Ar.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:Ar.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(hl);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.updatedContext=wg.createSecureContext(l)}catch(c){Ar.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),bF(s),Is.default.get(H.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function bF(e){let t=0;zu(r=>{r?.ca&&(hl.add(r.ca),hl.size!==t&&(t=hl.size,e?.()))})}function bie(e=!0){yF=e}function Oie(e){yF||(Je(),Ga=e.databases,xa(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||$a;for(let[s,i]of lh){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];NF(r,s,e),nN.get(s)?.forEach(i=>i(s))}}))}function NF(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 OF extends Kr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||$a,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(Ar.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new qn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let f;for(let h of c){let _=Nie(h,OF.subscription,e);_?.isConnected&&!u.has(_)&&(!f||_.latency<f.latency)&&(f=_)}if(!f)throw l||new AF.ServerError("No connection to any other nodes are available",502);let d={requestId:Aie++,table:t,entry:i,id:i.key};u.add(f);try{return await f.getRecord(d)}catch(h){if(f.isConnected)throw h;Ar.warn("Error in load from node",Ng,h),l||(l=h)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function wF(e,t,r,n,s){let i=lh.get(e);i||lh.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new oh(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function Nie(e,t,r){let n=mF.get(e)?.get(r);if(n)return n;let s=Tr().primaryStore.get(e);return s?.url&&(n=wF(s.url,t,r,e,s.authorization),mF.set(e,lh.get(s.url))),n}async function uh(e,t,r){r||(r={}),r.serverName=e.name;let n=await yg(e.url,r),s=ah(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{Ar.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function Qu(e){try{RF.isMainThread&&Ar.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=$a.get(e.database);if(!t){let n;t=new Promise(s=>{Ar.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,$a.set(e.database,t)}let r=wF(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>th(n,e.database)),e.replicateByDefault)}catch(t){Ar.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function _g({name:e,url:t,database:r}){Ar.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(Tr().primaryStore.getRange({})));let n=lh.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function wie(){if(aN!==void 0)return aN;let e=Is.default.get(H.OPERATIONSAPI_TLS_CERTIFICATE)||Is.default.get(H.TLS_CERTIFICATE);if(e)return aN=new SF.X509Certificate((0,TF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Xe(){return Ng||(Ng=Is.default.get("replication_hostname")??ui(Is.default.get("replication_url"))??wie()??gF("operationsapi_network_secureport")??gF("operationsapi_network_port")??"127.0.0.1")}function Iie(){Ng=void 0}function gF(e){let t=Is.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Og(e){let t=Is.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function bg(e){return Z_(e)?.[Xe()]}function Ba(){let e=Is.default.get("replication_url");return e||Ig(Xe())}function Ig(e){let t=Og("replication_port");if(t)return`ws://${e}:${t}`;if(t=Og("replication_secureport"),t)return`wss://${e}:${t}`;if(t=Og("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=Og("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function ui(e){if(e)return new URL(e).hostname}function xa(e,t){for(let n of Object.getOwnPropertyNames($e))r(n);return ch(n=>{r(n)}),El((n,s)=>{r(n.databaseName)});function r(n){let s=$e[n];Ar.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):Cie(n)&&t(s,n,!1)}a(r,"forDatabase")}function Cie(e){let t=$e[e];for(let r in t)if(t[r].replicate)return!0}function eh(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function Pie(e){let t={message:""};if(e.replicated){e.replicated=!1,Ar.trace?.("Replicating operation",e.operation,"to nodes",Qe.nodes.map(n=>n.name));let r=await Promise.allSettled(Qe.nodes.map(n=>uh(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=Qe.nodes[s]?.name,i})}return t}var Is,Ar,SF,TF,wg,AF,RF,yF,Aie,Rie,hl,Ga,lh,mF,aN,Ng,ts=be(()=>{Ce();Ra();cu();sN();Yr();Is=x(ce()),Ar=x(W()),SF=require("crypto"),TF=require("fs");nh();ul();v();MO();wg=x(require("node:tls")),AF=x(_e()),RF=require("worker_threads"),Aie=1,Rie=[],hl=Is.default.get(H.REPLICATION_ENABLEROOTCAS)!==!1?new Set(wg.rootCertificates):new Set;a(yie,"start");a(bF,"monitorNodeCAs");a(bie,"disableReplication");a(Oie,"assignReplicationSource");a(NF,"setReplicator");lh=new Map;a(wF,"getConnection");mF=new Map;a(Nie,"getConnectionByName");a(uh,"sendOperationToNode");a(Qu,"subscribeToNode");a(_g,"unsubscribeFromNode");a(wie,"getCommonNameFromCert");a(Xe,"getThisNodeName");a(Iie,"clearThisNodeName");Object.defineProperty(Qe,"hostname",{get(){return Xe()}});a(gF,"getHostFromListeningPort");a(Og,"getPortFromListeningPort");a(bg,"getThisNodeId");Qe.replication={getThisNodeId:bg,exportIdMapping:Z_};a(Ba,"getThisNodeUrl");a(Ig,"hostnameToUrl");a(ui,"urlToNodeName");a(xa,"forEachReplicatedDatabase");a(Cie,"hasExplicitlyReplicatedTable");a(eh,"lastTimeInAuditStore");a(Pie,"replicateOperation")});var Lg=C((rDe,LF)=>{"use strict";var rd=zE(),nd=qH(),Die=W(),Lie=require("uuid").v4,tDe=require("clone"),Pg=wo(),sd=(v(),D(q)),Mie=require("util"),Va=Wn(),{handleHDBError:Cn,hdb_errors:vie}=_e(),{HDB_ERROR_MSGS:Cg,HTTP_STATUS_CODES:Pn}=vie,{SchemaEventMsg:Dg}=oi(),IF=ar(),{getDatabases:Uie}=(Ce(),D(tt)),{transformReq:id}=ae(),{replicateOperation:CF}=(ts(),D(vo));LF.exports={createSchema:xie,createSchemaStructure:PF,createTable:Bie,createTableStructure:DF,createAttribute:Gie,dropSchema:Hie,dropTable:kie,dropAttribute:Fie,getBackup:$ie};async function xie(e){let t=await PF(e);return Pg.signalSchemaChange(new Dg(process.pid,e.operation,e.schema)),t}a(xie,"createSchema");async function PF(e){let t=rd.schema_object(e);if(t)throw Cn(t,t.message,Pn.BAD_REQUEST,void 0,void 0,!0);if(id(e),!await nd.checkSchemaExists(e.schema))throw Cn(new Error,Cg.SCHEMA_EXISTS_ERR(e.schema),Pn.BAD_REQUEST,sd.LOG_LEVELS.ERROR,Cg.SCHEMA_EXISTS_ERR(e.schema),!0);return await Va.createSchema(e),`database '${e.schema}' successfully created`}a(PF,"createSchemaStructure");async function Bie(e){return id(e),e.hash_attribute=e.primary_key??e.hash_attribute,await DF(e)}a(Bie,"createTable");async function DF(e){let t=rd.create_table_object(e);if(t)throw Cn(t,t.message,Pn.BAD_REQUEST,void 0,void 0,!0);if(rd.validateTableResidence(e.residence),!await nd.checkSchemaTableExists(e.schema,e.table))throw Cn(new Error,Cg.TABLE_EXISTS_ERR(e.schema,e.table),Pn.BAD_REQUEST,sd.LOG_LEVELS.ERROR,Cg.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Lie(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await Va.createTable(n,e);else throw Cn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Pn.BAD_REQUEST);else await Va.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(DF,"createTableStructure");async function Hie(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=rd.schema_object(e),n=t??r;if(n)throw Cn(n,n.message,Pn.BAD_REQUEST,void 0,void 0,!0);id(e);let s=await nd.checkSchemaExists(e.schema);if(s)throw Cn(new Error,s,Pn.NOT_FOUND,sd.LOG_LEVELS.ERROR,s,!0);let i=await nd.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await Va.dropSchema(e),Pg.signalSchemaChange(new Dg(process.pid,e.operation,e.schema)),await IF.purgeSchemaTableStreams(e.schema,o);let c=await CF(e);return c.message=`successfully deleted '${e.schema}'`,c}a(Hie,"dropSchema");async function kie(e){let t=rd.table_object(e);if(t)throw Cn(t,t.message,Pn.BAD_REQUEST,void 0,void 0,!0);id(e);let r=await nd.checkSchemaTableExists(e.schema,e.table);if(r)throw Cn(new Error,r,Pn.NOT_FOUND,sd.LOG_LEVELS.ERROR,r,!0);await Va.dropTable(e),await IF.purgeTableStream(e.schema,e.table);let n=await CF(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(kie,"dropTable");async function Fie(e){let t=rd.attribute_object(e);if(t)throw Cn(t,t.message,Pn.BAD_REQUEST,void 0,void 0,!0);id(e);let r=await nd.checkSchemaTableExists(e.schema,e.table);if(r)throw Cn(new Error,r,Pn.NOT_FOUND,sd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Cn(new Error,"You cannot drop a hash attribute",Pn.BAD_REQUEST,void 0,void 0,!0);if(sd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Cn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Pn.BAD_REQUEST,void 0,void 0,!0);try{return await Va.dropAttribute(e),qie(e),Pg.signalSchemaChange(new Dg(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Die.error(`Got an error deleting attribute ${Mie.inspect(e)}.`),n}}a(Fie,"dropAttribute");function qie(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(qie,"dropAttributeFromGlobal");async function Gie(e){id(e);let t=Uie()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Cn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Pn.BAD_REQUEST,void 0,void 0,!0);return await Va.createAttribute(e),Pg.signalSchemaChange(new Dg(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(Gie,"createAttribute");function $ie(e){return Va.getBackup(e)}a($ie,"getBackup")});var vF=C((sDe,MF)=>{"use strict";var{OPERATIONS_ENUM:Vie}=(v(),D(q)),cN=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Vie.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};MF.exports=cN});var lN=C((aDe,kF)=>{"use strict";var Kie=Wn(),oDe=vF(),Mg=ae(),vg=(v(),D(q)),Yie=ce(),{handleHDBError:UF,hdb_errors:Wie}=_e(),{HDB_ERROR_MSGS:xF,HTTP_STATUS_CODES:BF}=Wie,zie=Object.values(vg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),HF="To use this operation audit log must be enabled in harperdb-config.yaml";kF.exports=jie;async function jie(e){if(Mg.isEmpty(e.schema))throw new Error(xF.SCHEMA_REQUIRED_ERR);if(Mg.isEmpty(e.table))throw new Error(xF.TABLE_REQUIRED_ERR);if(!Yie.get(vg.CONFIG_PARAMS.LOGGING_AUDITLOG))throw UF(new Error,HF,BF.BAD_REQUEST,vg.LOG_LEVELS.ERROR,HF,!0);let t=Mg.checkSchemaTableExist(e.schema,e.table);if(t)throw UF(new Error,t,BF.NOT_FOUND,vg.LOG_LEVELS.ERROR,t,!0);if(!Mg.isEmpty(e.search_type)&&zie.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await Kie.readAuditLog(e)}a(jie,"readAuditLog")});var qF=C((lDe,FF)=>{"use strict";var{OPERATIONS_ENUM:Qie}=(v(),D(q)),uN=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Qie.GET_BACKUP,this.schema=t,this.table=r}};FF.exports=uN});var VF=C((_De,$F)=>{"use strict";var Jie=Wn(),dDe=qF(),dN=ae(),Xie=(v(),D(q)),fDe=ce(),{handleHDBError:Zie,hdb_errors:eoe}=_e(),{HDB_ERROR_MSGS:GF,HTTP_STATUS_CODES:toe}=eoe;$F.exports=roe;async function roe(e){if(dN.isEmpty(e.schema))throw new Error(GF.SCHEMA_REQUIRED_ERR);if(dN.isEmpty(e.table))throw new Error(GF.TABLE_REQUIRED_ERR);let t=dN.checkSchemaTableExist(e.schema,e.table);if(t)throw Zie(new Error,t,toe.NOT_FOUND,Xie.LOG_LEVELS.ERROR,t,!0);return await Jie.getBackup(read_audit_log_object)}a(roe,"getBackup")});var zF=C((pDe,WF)=>{"use strict";var noe=ce(),Ka=require("joi"),soe=pt(),KF=require("moment"),ioe=require("fs-extra"),fN=require("path"),ooe=require("lodash"),dh=(v(),D(q)),{LOG_LEVELS:ml}=(v(),D(q)),aoe="YYYY-MM-DD hh:mm:ss",coe=fN.resolve(__dirname,"../logs");WF.exports=function(e){return soe.validateBySchema(e,loe)};var loe=Ka.object({from:Ka.custom(YF),until:Ka.custom(YF),level:Ka.valid(ml.NOTIFY,ml.FATAL,ml.ERROR,ml.WARN,ml.INFO,ml.DEBUG,ml.TRACE),order:Ka.valid("asc","desc"),limit:Ka.number().min(1),start:Ka.number().min(0),log_name:Ka.custom(uoe)});function YF(e,t){if(KF(e,KF.ISO_8601).format(aoe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(YF,"validateDatetime");function uoe(e,t){if(ooe.invert(dh.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=noe.get(dh.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?dh.LOG_NAMES.HDB:e,i=s===dh.LOG_NAMES.INSTALL?fN.join(coe,dh.LOG_NAMES.INSTALL):fN.join(n,s);return ioe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(uoe,"validateReadLogPath")});var hN=C((mDe,QF)=>{"use strict";var Ug=(v(),D(q)),doe=W(),foe=ce(),_oe=zF(),_N=require("path"),jF=require("fs-extra"),{once:hoe}=require("events"),{handleHDBError:poe,hdb_errors:Eoe}=_e(),{PACKAGE_ROOT:moe}=rt(),goe=_N.join(moe,"logs"),Soe=1e3,Toe=200;QF.exports=Aoe;async function Aoe(e){let t=_oe(e);if(t)throw poe(t,t.message,Eoe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=foe.get(Ug.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Ug.LOG_NAMES.HDB:e.log_name,s=n===Ug.LOG_NAMES.INSTALL?_N.join(goe,Ug.LOG_NAMES.INSTALL):_N.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,f=u?new Date(e.until):void 0,d=e.limit===void 0?Soe:e.limit,h=e.order===void 0?void 0:e.order,_=e.start===void 0?0:e.start,p=_+d,S=0;h==="desc"&&!l&&!f&&(S=Math.max(jF.statSync(s).size-(p+5)*Toe,0));let g=jF.createReadStream(s,{start:S});g.on("error",F=>{doe.error(F)});let T=0,m=[],A="",w;g.on("data",F=>{let G=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;F=A+F;let K=0,ee;for(;(ee=G.exec(F))&&!g.destroyed;){w&&(w.message=F.slice(K,ee.index),M(w));let[ie,X,re]=ee,j=re.split("] ["),he=j[0],Te=j[1];j.splice(0,2),w={timestamp:X,thread:he,level:Te,tags:j,message:""},K=ee.index+ie.length}A=F.slice(K)}),g.on("end",F=>{g.destroyed||w&&(w.message=A.trim(),M(w))}),g.resume();function M(F){let G,K,ee;switch(!0){case(i&&c&&u):G=new Date(F.timestamp),K=new Date(l),ee=new Date(f),F.level===o&&G>=K&&G<=ee&&T<_?T++:F.level===o&&G>=K&&G<=ee&&(Ya(F,h,m),T++,T===p&&g.destroy());break;case(i&&c):G=new Date(F.timestamp),K=new Date(l),F.level===o&&G>=K&&T<_?T++:F.level===o&&G>=K&&(Ya(F,h,m),T++,T===p&&g.destroy());break;case(i&&u):G=new Date(F.timestamp),ee=new Date(f),F.level===o&&G<=ee&&T<_?T++:F.level===o&&G<=ee&&(Ya(F,h,m),T++,T===p&&g.destroy());break;case(c&&u):G=new Date(F.timestamp),K=new Date(l),ee=new Date(f),G>=K&&G<=ee&&T<_?T++:G>=K&&G<=ee&&(Ya(F,h,m),T++,T===p&&g.destroy());break;case i:F.level===o&&T<_?T++:F.level===o&&(Ya(F,h,m),T++,T===p&&g.destroy());break;case c:G=new Date(F.timestamp),K=new Date(l),G>=K&&T<_?T++:G>=K&&T>=_&&(Ya(F,h,m),T++,T===p&&g.destroy());break;case u:G=new Date(F.timestamp),ee=new Date(f),G<=ee&&T<_?T++:G<=ee&&T>=_&&(Ya(F,h,m),T++,T===p&&g.destroy());break;default:T<_?T++:(Ya(F,h,m),T++,T===p&&g.destroy())}}return a(M,"onLogMessage"),await hoe(g,"close"),m}a(Aoe,"readLog");function Ya(e,t,r){t==="desc"?Roe(e,r):t==="asc"?yoe(e,r):r.push(e)}a(Ya,"pushLineToResult");function Roe(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(Roe,"insertDescending");function yoe(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(yoe,"insertAscending")});var xg=C((yDe,eq)=>{"use strict";var pN=require("joi"),{string:od,boolean:JF,date:boe}=pN.types(),Ooe=pt(),{validateSchemaExists:SDe,validateTableExists:TDe,validateSchemaName:ADe}=vi(),Noe=(v(),D(q)),woe=gt(),XF=ce();XF.initSync();var RDe=od.invalid(XF.get(Noe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(woe.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),ZF={operation:od.valid("add_node","update_node","set_node_replication"),node_name:od.optional(),subscriptions:pN.array().items({table:od.optional(),schema:od.optional(),database:od.optional(),subscribe:JF.required(),publish:JF.required().custom(Coe),start_time:boe.iso()})};function Ioe(e){return Ooe.validateBySchema(e,pN.object(ZF))}a(Ioe,"addUpdateNodeValidator");function Coe(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(Coe,"checkForFalsy");eq.exports={addUpdateNodeValidator:Ioe,validation_schema:ZF}});var ad=C((ODe,tq)=>{"use strict";var EN=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},mN=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};tq.exports={Node:EN,NodeSubscription:mN}});var nq=C((wDe,rq)=>{"use strict";var Poe=(v(),D(q)).OPERATIONS_ENUM,gN=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Poe.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};rq.exports=gN});var fh=C((CDe,sq)=>{"use strict";var SN=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},TN=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)}};sq.exports={RemotePayloadObject:SN,RemotePayloadSubscription:TN}});var oq=C((DDe,iq)=>{"use strict";var AN=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}};iq.exports=AN});var cq=C((BDe,aq)=>{"use strict";var Doe=oq(),MDe=Mt(),vDe=ct(),Loe=W(),{getSchemaPath:UDe,getTransactionAuditStorePath:xDe}=ht(),{getDatabases:Moe}=(Ce(),D(tt));aq.exports=voe;async function voe(e){let t=new Doe;try{let r=Moe()[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){Loe.warn(`unable to stat table dbi due to ${r}`)}return t}a(voe,"lmdbGetTableSize")});var uq=C((kDe,lq)=>{"use strict";var RN=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}};lq.exports=RN});var Uo=C((KDe,hq)=>{"use strict";var Uoe=require("fs-extra"),xoe=require("path"),en=require("systeminformation"),Wa=W(),dq=ar(),qDe=gt(),cd=(v(),D(q)),Boe=cq(),Hoe=Oo(),{getThreadInfo:fq}=nt(),_h=ce();_h.initSync();var koe=uq(),{openEnvironment:GDe}=ct(),{getSchemaPath:$De}=ht(),{database:VDe,databases:yN}=(Ce(),D(tt)),Bg;hq.exports={getHDBProcessInfo:wN,getNetworkInfo:CN,getDiskInfo:IN,getMemoryInfo:NN,getCPUInfo:ON,getTimeInfo:bN,getSystemInformation:PN,systemInformation:Foe,getTableSize:DN,getMetrics:LN};function bN(){return en.time()}a(bN,"getTimeInfo");async function ON(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...f}=await en.cpu();f.cpu_speed=await en.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:h,raw_currentload_irq:_,raw_currentload_nice:p,raw_currentload_system:S,raw_currentload_user:g,cpus:T,...m}=await en.currentLoad();return m.cpus=[],T.forEach(A=>{let{raw_load:w,raw_load_idle:M,raw_load_irq:F,raw_load_nice:G,raw_load_system:K,raw_load_user:ee,...ie}=A;m.cpus.push(ie)}),f.current_load=m,f}catch(e){return Wa.error(`error in getCPUInfo: ${e}`),{}}}a(ON,"getCPUInfo");async function NN(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await en.mem();return Object.assign(s,process.memoryUsage())}catch(e){return Wa.error(`error in getMemoryInfo: ${e}`),{}}}a(NN,"getMemoryInfo");async function wN(){let e={core:[],clustering:[]};try{let t=await en.processes(),r;try{r=Number.parseInt(await Uoe.readFile(xoe.join(_h.get(cd.CONFIG_PARAMS.ROOTPATH),cd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===cd.NODE_ERROR_CODES.ENOENT)Wa.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 Wa.error(`error in getHDBProcessInfo: ${t}`),e}}a(wN,"getHDBProcessInfo");async function IN(){let e={};try{if(!_h.get(cd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await en.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await en.fsStats();return e.read_write=u,e.size=await en.fsSize(),e}catch(t){return Wa.error(`error in getDiskInfo: ${t}`),e}}a(IN,"getDiskInfo");async function CN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return _h.get(cd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await en.networkInterfaceDefault(),e.latency=await en.inetChecksite("google.com"),(await en.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:f,carrier_changes:d,...h}=n;e.interfaces.push(h)}),(await en.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return Wa.error(`error in getNetworkInfo: ${t}`),e}}a(CN,"getNetworkInfo");async function PN(){if(Bg!==void 0)return Bg;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await en.osInfo();e=c;let l=await en.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,Bg=e,Bg}catch(t){return Wa.error(`error in getSystemInformation: ${t}`),e}}a(PN,"getSystemInformation");async function DN(){let e=[],t=await Hoe.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await Boe(n));return e}a(DN,"getTableSize");async function LN(){let e={};for(let t in yN){let r=e[t]={},n=r.tables={};for(let s in yN[t])try{let i=yN[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,f,d]=l.trim().split(" ");return{pid:u,thread:f,txnid:d}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:h}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:h}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){Wa.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(LN,"getMetrics");async function _q(){if(_h.get(cd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await dq.getNATSReferences(),t=await dq.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(_q,"getNatsStreamInfo");async function Foe(e){let t=new koe;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await PN(),t.time=bN(),t.cpu=await ON(),t.memory=await NN(),t.disk=await IN(),t.network=await CN(),t.harperdb_processes=await wN(),t.table_size=await DN(),t.metrics=await LN(),t.threads=await fq(),t.replication=await _q(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await PN();break;case"time":t.time=bN();break;case"cpu":t.cpu=await ON();break;case"memory":t.memory=await NN();break;case"disk":t.disk=await IN();break;case"network":t.network=await CN();break;case"harperdb_processes":t.harperdb_processes=await wN();break;case"table_size":t.table_size=await DN();break;case"database_metrics":case"metrics":t.metrics=await LN();break;case"threads":t.threads=await fq();break;case"replication":t.replication=await _q();break;default:break}return t}a(Foe,"systemInformation")});var xo=C((jDe,gq)=>{"use strict";var qoe=Rn(),MN=ae(),Goe=require("util"),gl=(v(),D(q)),pq=ce();pq.initSync();var $oe=fO(),Eq=zr(),{Node:WDe,NodeSubscription:zDe}=ad(),Voe=Mu(),Koe=nq(),{RemotePayloadObject:Yoe,RemotePayloadSubscription:Woe}=fh(),{handleHDBError:zoe,hdb_errors:joe}=_e(),{HTTP_STATUS_CODES:Qoe,HDB_ERROR_MSGS:Joe}=joe,Xoe=ai(),Zoe=Uo(),{packageJson:eae}=rt(),{getDatabases:tae}=(Ce(),D(tt)),rae=Goe.promisify($oe.authorize),nae=Eq.searchByHash,sae=Eq.searchByValue;gq.exports={authHeaderToUser:iae,isEmpty:oae,getNodeRecord:aae,upsertNodeRecord:cae,buildNodePayloads:lae,checkClusteringEnabled:uae,getAllNodeRecords:dae,getSystemInfo:fae,reverseSubscription:mq};async function iae(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await rae(t,null),e}a(iae,"authHeaderToUser");function oae(e){return e==null}a(oae,"isEmpty");async function aae(e){let t=new Voe(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return nae(t)}a(aae,"getNodeRecord");async function cae(e){let t=new Koe(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return qoe.upsert(t)}a(cae,"upsertNodeRecord");function mq(e){if(MN.isEmpty(e.subscribe)||MN.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(mq,"reverseSubscription");function lae(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,f=MN.getTableHashAttribute(l,u),{subscribe:d,publish:h}=mq(c),_=tae()[l]?.[u],p=new Woe(l,u,f,h,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(p)}return new Yoe(r,t,s,n)}a(lae,"buildNodePayloads");function uae(){if(!pq.get(gl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw zoe(new Error,Joe.CLUSTERING_NOT_ENABLED,Qoe.BAD_REQUEST,void 0,void 0,!0)}a(uae,"checkClusteringEnabled");async function dae(){let e=new Xoe(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await sae(e))}a(dae,"getAllNodeRecords");async function fae(){let e=await Zoe.getSystemInformation();return{hdb_version:eae.version,node_version:e.node_version,platform:e.platform}}a(fae,"getSystemInfo")});var vN=C((JDe,Nq)=>{"use strict";var Hg=ar(),Sq=ae(),Tq=gt(),Aq=(v(),D(q)),kg=W(),Rq=Lg(),_ae=I_(),{RemotePayloadObject:hae}=fh(),{handleHDBError:yq,hdb_errors:pae}=_e(),{HTTP_STATUS_CODES:bq}=pae,{NodeSubscription:Oq}=ad();Nq.exports=Eae;async function Eae(e,t){let r;try{r=await Hg.request(`${t}.${Tq.REQUEST_SUFFIX}`,new hae(Aq.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),kg.trace("Response from remote describe all request:",r)}catch(o){kg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Hg.requestErrorHandler(o,"add_node",t);throw yq(new Error,c,bq.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===Tq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw yq(new Error,o,bq.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===Aq.SYSTEM_SCHEMA_NAME){await Hg.createLocalTableStream(l,c);let p=new Oq(l,c,o.publish,o.subscribe);p.start_time=o.start_time,i.push(p);continue}let u=Sq.doesSchemaExist(l),f=n[l]!==void 0,d=c?Sq.doesTableExist(l,c):!0,h=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!f||!d&&!h){s.push(o);continue}if(!u&&f&&(kg.trace(`addNode creating schema: ${l}`),await Rq.createSchema({operation:"create_schema",schema:l})),!d&&h){kg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let p=new _ae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(p.attributes=n[l][c].attributes),await Rq.createTable(p)}await Hg.createLocalTableStream(l,c);let _=new Oq(l,c,o.publish,o.subscribe);_.start_time=o.start_time,i.push(_)}return{added:i,skipped:s}}a(Eae,"reviewSubscriptions")});var Sl={};Be(Sl,{addNodeBack:()=>Aae,removeNodeBack:()=>Rae,setNode:()=>Tae});async function Tae(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=ui(t)):t=Ig(r);let n=(0,Iq.validateBySchema)(e,Sae);if(n)throw(0,Bo.handleHDBError)(n,n.message,gae.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Bo.ClientError("url or hostname is required for remove_node operation");let _=r,p=Tr(),S=await p.get(_);if(!S)throw new Bo.ClientError(_+" does not exist");try{await uh({url:S.url},{operation:Vt.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Xe():_},void 0)}catch(g){ns.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await p.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Bo.ClientError("url required for this operation");let s=Ba();if(s==null)throw new Bo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,Cs.getReplicationCert)();let _=await(0,Cs.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,Cs.createCsr)(),ns.info("Sending CSR to target node:",t)):_&&(c=_.certificate,ns.info("Sending CA named",_.name,"to target node",t))}let l={operation:Vt.ADD_NODE_BACK,hostname:(0,Cq.get)(H.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if(e.subscriptions?l.subscriptions=e.subscriptions.map(wq):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=wq(e);l.subscribe=_.subscribe,l.publish=_.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,f;try{u=await uh({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,ns.warn("Error adding node:",t,"to cluster:",_),f=_}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw f?(f.message+=" and connection was required to sign certificate",f):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&(ns.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Cs.setCertTable)({name:mae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Cs.setCertTable)({name:Xe(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let d={url:t,ca:u?.usingCA};if(e.hostname&&(d.name=e.hostname),e.subscriptions?d.subscriptions=e.subscriptions:d.replicates=!0,e.start_time&&(d.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(d.authorization=e.authorization),d.replicates){let _={url:s,ca:c,replicates:!0,subscriptions:null};e.retain_authorization&&(_.authorization=e.authorization),e.start_time&&(_.start_time=e.start_time),await Lo(Xe(),_)}await Lo(u?u.nodeName:d.name??ui(t),d);let h;return e.operation==="update_node"?h=`Successfully updated '${t}'`:h=`Successfully added '${t}' to cluster`,f&&(h+=" but there was an error updating target node: "+f.message),h}async function Aae(e){ns.trace("addNodeBack received request:",e);let t=await(0,Cs.signCertificate)(e),r;e.csr?(r=t.signingCA,ns.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,ns.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization);let s=await(0,Cs.getReplicationCertAuth)();if(n.replicates){let i={url:Ba(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Lo(Xe(),i)}return await Lo(e.hostname,n),t.nodeName=Xe(),t.usingCA=s?.certificate,ns.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Rae(e){ns.trace("removeNodeBack received request:",e),await Tr().delete(e.name)}function wq(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Cs,Iq,ld,Cq,ns,Bo,mae,gae,Sae,Tl=be(()=>{Cs=x(rs()),Iq=x(pt()),ld=x(require("joi")),Cq=x(ce());v();nh();ul();ts();ns=x(W()),Bo=x(_e()),{pki:mae}=require("node-forge"),{HTTP_STATUS_CODES:gae}=Bo.hdb_errors,Sae=ld.default.object({hostname:ld.default.string(),verify_tls:ld.default.boolean(),replicates:ld.default.boolean(),subscriptions:ld.default.array()});a(Tae,"setNode");a(Aae,"addNodeBack");a(Rae,"removeNodeBack");a(wq,"reverseSubscription")});var ud=C((oLe,Dq)=>{"use strict";var{handleHDBError:Fg,hdb_errors:yae}=_e(),{HTTP_STATUS_CODES:qg}=yae,{addUpdateNodeValidator:bae}=xg(),Gg=W(),$g=(v(),D(q)),Pq=gt(),Oae=ae(),hh=ar(),ph=xo(),UN=ce(),Nae=vN(),{Node:wae,NodeSubscription:Iae}=ad(),{broadcast:Cae}=nt(),{setNode:Pae}=(Tl(),D(Sl)),sLe=ce(),iLe=(v(),D(q)),Dae="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Lae="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Mae=UN.get($g.CONFIG_PARAMS.CLUSTERING_NODENAME);Dq.exports=vae;async function vae(e,t=!1){if(Gg.trace("addNode called with:",e),UN.get($g.CONFIG_PARAMS.REPLICATION_URL)||UN.get($g.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Pae(e);ph.checkClusteringEnabled();let r=bae(e);if(r)throw Fg(r,r.message,qg.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await ph.getNodeRecord(n);if(!Oae.isEmptyOrZeroLength(d))throw Fg(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,qg.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Nae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Dae,o;let c=ph.buildNodePayloads(s,Mae,$g.OPERATIONS_ENUM.ADD_NODE,await ph.getSystemInfo()),l=[];for(let d=0,h=s.length;d<h;d++){let _=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new Iae(_.schema,_.table,_.publish,_.subscribe))}Gg.trace("addNode sending remote payload:",c);let u;try{u=await hh.request(`${n}.${Pq.REQUEST_SUFFIX}`,c)}catch(d){Gg.error(`addNode received error from request: ${d}`);for(let _=0,p=s.length;_<p;_++){let S=s[_];S.publish=!1,S.subscribe=!1,await hh.updateRemoteConsumer(S,n)}let h=hh.requestErrorHandler(d,"add_node",n);throw Fg(new Error,h,qg.INTERNAL_SERVER_ERROR,"error",h)}if(u.status===Pq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw Fg(new Error,d,qg.INTERNAL_SERVER_ERROR,"error",d)}Gg.trace(u);for(let d=0,h=s.length;d<h;d++){let _=s[d];await hh.updateRemoteConsumer(_,n),_.subscribe===!0&&await hh.updateConsumerIterator(_.schema,_.table,n,"start")}let f=new wae(n,l,u.system_info);return await ph.upsertNodeRecord(f),Cae({type:"nats_update"}),i.length>0?o.message=Lae:o.message=`Successfully added '${n}' to manifest`,o}a(vae,"addNode")});var kN=C((lLe,Mq)=>{"use strict";var{handleHDBError:xN,hdb_errors:Uae}=_e(),{HTTP_STATUS_CODES:BN}=Uae,{addUpdateNodeValidator:xae}=xg(),Eh=W(),Vg=(v(),D(q)),Lq=gt(),cLe=ae(),mh=ar(),gh=xo(),HN=ce(),{cloneDeep:Bae}=require("lodash"),Hae=vN(),{Node:kae,NodeSubscription:Fae}=ad(),{broadcast:qae}=nt(),{setNode:Gae}=(Tl(),D(Sl)),$ae="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",Vae="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Kae=HN.get(Vg.CONFIG_PARAMS.CLUSTERING_NODENAME);Mq.exports=Yae;async function Yae(e){if(Eh.trace("updateNode called with:",e),HN.get(Vg.CONFIG_PARAMS.REPLICATION_URL)??HN.get(Vg.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Gae(e);gh.checkClusteringEnabled();let t=xae(e);if(t)throw xN(t,t.message,BN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await gh.getNodeRecord(r);s.length>0&&(n=Bae(s));let{added:i,skipped:o}=await Hae(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=$ae,c;let l=gh.buildNodePayloads(i,Kae,Vg.OPERATIONS_ENUM.UPDATE_NODE,await gh.getSystemInfo());for(let f=0,d=i.length;f<d;f++){let h=i[f];Eh.trace(`updateNode updating work stream for node: ${r} subscription:`,h),i[f].start_time===void 0&&delete i[f].start_time}Eh.trace("updateNode sending remote payload:",l);let u;try{u=await mh.request(`${r}.${Lq.REQUEST_SUFFIX}`,l)}catch(f){Eh.error(`updateNode received error from request: ${f}`);let d=mh.requestErrorHandler(f,"update_node",r);throw xN(new Error,d,BN.INTERNAL_SERVER_ERROR,"error",d)}if(u.status===Lq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${r}: ${u.message}`;throw xN(new Error,f,BN.INTERNAL_SERVER_ERROR,"error",f)}Eh.trace(u);for(let f=0,d=i.length;f<d;f++){let h=i[f];await mh.updateRemoteConsumer(h,r),h.subscribe===!0?await mh.updateConsumerIterator(h.schema,h.table,r,"start"):await mh.updateConsumerIterator(h.schema,h.table,r,"stop")}return n||(n=[new kae(r,[],u.system_info)]),await Wae(n[0],i,u.system_info),o.length>0?c.message=Vae:c.message=`Successfully updated '${r}'`,c}a(Yae,"updateNode");async function Wae(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let f=n.subscriptions[l];if(f.schema===o.schema&&f.table===o.table){f.publish=o.publish,f.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new Fae(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await gh.upsertNodeRecord(n),qae({type:"nats_update"})}a(Wae,"updateNodeTable")});var Hq=C((dLe,Bq)=>{"use strict";var xq=require("joi"),{string:vq}=xq.types(),zae=pt(),Uq=(v(),D(q)),jae=ce(),Qae=gt();Bq.exports=Jae;function Jae(e){let t=vq.invalid(jae.get(Uq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Qae.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=xq.object({operation:vq.valid(Uq.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return zae.validateBySchema(e,r)}a(Jae,"removeNodeValidator")});var Kg=C((_Le,$q)=>{"use strict";var{handleHDBError:kq,hdb_errors:Xae}=_e(),{HTTP_STATUS_CODES:Fq}=Xae,Zae=Hq(),Sh=W(),qq=xo(),ece=ae(),dd=(v(),D(q)),Gq=gt(),FN=ar(),qN=ce(),{RemotePayloadObject:tce}=fh(),{NodeSubscription:rce}=ad(),nce=w_(),sce=Vc(),{broadcast:ice}=nt(),{setNode:oce}=(Tl(),D(Sl)),ace=qN.get(dd.CONFIG_PARAMS.CLUSTERING_NODENAME);$q.exports=cce;async function cce(e){if(Sh.trace("removeNode called with:",e),qN.get(dd.CONFIG_PARAMS.REPLICATION_URL)??qN.get(dd.CONFIG_PARAMS.REPLICATION_HOSTNAME))return oce(e);qq.checkClusteringEnabled();let t=Zae(e);if(t)throw kq(t,t.message,Fq.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await qq.getNodeRecord(r);if(ece.isEmptyOrZeroLength(n))throw kq(new Error,`Node '${r}' was not found.`,Fq.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new tce(dd.OPERATIONS_ENUM.REMOVE_NODE,ace,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await FN.updateConsumerIterator(f.schema,f.table,r,"stop");try{await FN.updateRemoteConsumer(new rce(f.schema,f.table,!1,!1),r)}catch(d){Sh.error(d)}}try{i=await FN.request(`${r}.${Gq.REQUEST_SUFFIX}`,s),Sh.trace("Remove node reply from remote node:",r,i)}catch(l){Sh.error("removeNode received error from request:",l),o=!0}let c=new nce(dd.SYSTEM_SCHEMA_NAME,dd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await sce.deleteRecord(c),ice({type:"nats_update"}),i?.status===Gq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Sh.error("Error returned from remote node:",r,i?.message),`Successfully removed '${r}' from local manifest, however there was an error reaching remote node. Check the logs for more details.`):`Successfully removed '${r}' from manifest`}a(cce,"removeNode")});var Yq=C((pLe,Kq)=>{"use strict";var Vq=require("joi"),{string:lce,array:uce}=Vq.types(),dce=pt(),fce=xg();Kq.exports=_ce;function _ce(e){let t=Vq.object({operation:lce.valid("configure_cluster").required(),connections:uce.items(fce.validation_schema).required()});return dce.validateBySchema(e,t)}a(_ce,"configureClusterValidator")});var GN=C((mLe,Jq)=>{"use strict";var Wq=(v(),D(q)),Yg=W(),hce=ae(),pce=ce(),Ece=Kg(),mce=ud(),gce=xo(),Sce=Yq(),{handleHDBError:zq,hdb_errors:Tce}=_e(),{HTTP_STATUS_CODES:jq}=Tce,Ace="Configure cluster complete.",Rce="Failed to configure the cluster. Check the logs for more details.",yce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";Jq.exports=bce;async function bce(e){Yg.trace("configure cluster called with:",e);let t=Sce(e);if(t)throw zq(t,t.message,jq.BAD_REQUEST,void 0,void 0,!0);let r=await gce.getAllNodeRecords(),n=[];if(pce.get(Wq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let h=await Qq(Ece,{operation:Wq.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name);n.push(h)}Yg.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let f=0;f<i;f++){let d=e.connections[f],h=await Qq(mce,d,d.node_name);s.push(h)}Yg.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let f=0,d=u.length;f<d;f++){let h=u[f];h.status==="rejected"&&(Yg.error(h.node_name,h?.error?.message,h?.error?.stack),o.includes(h.node_name)||o.push(h.node_name)),(h?.result?.message?.includes?.("Successfully")||h?.result?.includes?.("Successfully"))&&(l=!0),!(typeof h.result=="string"&&h.result.includes("Successfully removed")||h.status==="rejected")&&c.push({node_name:h?.node_name,response:h?.result})}if(hce.isEmptyOrZeroLength(o))return{message:Ace,connections:c};if(l)return{message:yce,failed_nodes:o,connections:c};throw zq(new Error,Rce,jq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(bce,"configureCluster");async function Qq(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(Qq,"functionWrapper")});var tG=C((SLe,eG)=>{"use strict";var Th=require("joi"),Oce=pt(),{validateSchemaExists:Xq,validateTableExists:Nce,validateSchemaName:Zq}=vi(),wce=Th.object({operation:Th.string().valid("purge_stream"),schema:Th.string().custom(Xq).custom(Zq).optional(),database:Th.string().custom(Xq).custom(Zq).optional(),table:Th.string().custom(Nce).required()});function Ice(e){return Oce.validateBySchema(e,wce)}a(Ice,"purgeStreamValidator");eG.exports=Ice});var $N=C((ALe,rG)=>{"use strict";var{handleHDBError:Cce,hdb_errors:Pce}=_e(),{HTTP_STATUS_CODES:Dce}=Pce,Lce=tG(),Mce=ar(),vce=xo();rG.exports=Uce;async function Uce(e){e.schema=e.schema??e.database;let t=Lce(e);if(t)throw Cce(t,t.message,Dce.BAD_REQUEST,void 0,void 0,!0);vce.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await Mce.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(Uce,"purgeStream")});var jg=C((yLe,lG)=>{"use strict";var KN=xo(),xce=ar(),zg=ce(),fd=(v(),D(q)),Al=gt(),Bce=ae(),VN=W(),{RemotePayloadObject:Hce}=fh(),{ErrorCode:nG}=require("nats"),{parentPort:sG}=require("worker_threads"),{onMessageByType:kce}=nt(),{getThisNodeName:Fce}=(ts(),D(vo)),{requestClusterStatus:qce}=(nh(),D(wk)),{getReplicationSharedStatus:Gce}=(ul(),D(vO)),{CONFIRMATION_STATUS_POSITION:$ce,RECEIVED_VERSION_POSITION:Vce,RECEIVED_TIME_POSITION:Kce,SENDING_TIME_POSITION:Yce}=(sN(),D(pF)),iG=zg.get(fd.CONFIG_PARAMS.CLUSTERING_ENABLED),oG=zg.get(fd.CONFIG_PARAMS.CLUSTERING_NODENAME);lG.exports={clusterStatus:Wce,buildNodeStatus:cG};var aG;kce("cluster-status",async e=>{aG(e)});async function Wce(){if(zg.get(fd.CONFIG_PARAMS.REPLICATION_URL)||zg.get(fd.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(sG){sG.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{aG=s});for(let s of n.connections){let i=s.name;for(let o of s.database_sockets){let c=o.database,l;for(let f of Object.values(databases[c]||{}))if(l=f.auditStore,l)break;if(!l)continue;let u=Gce(l,c,i);o.lastCommitConfirmed=Wg(u[$ce]),o.lastReceivedRemoteTime=Wg(u[Vce]),o.lastReceivedLocalTime=Wg(u[Kce]),o.sendingMessage=Wg(u[Yce])}}}else n=qce();return n.node_name=Fce(),n.is_enabled=!0,n}let e={node_name:oG,is_enabled:iG,connections:[]};if(!iG)return e;let t=await KN.getAllNodeRecords();if(Bce.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(cG(t[n],e.connections));return await Promise.allSettled(r),e}a(Wce,"clusterStatus");function Wg(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}a(Wg,"asDate");async function cG(e,t){let r=e.name,n=new Hce(fd.OPERATIONS_ENUM.CLUSTER_STATUS,oG,void 0,await KN.getSystemInfo()),s,i,o=Al.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await xce.request(Al.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Al.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Al.CLUSTER_STATUS_STATUSES.CLOSED,VN.error(`Error getting node status from ${r} `,s))}catch(l){VN.warn(`Error getting node status from ${r}`,l),l.code===nG.NoResponders?o=Al.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===nG.Timeout?o=Al.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Al.CLUSTER_STATUS_STATUSES.CLOSED}let c=new zce(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!==fd.PRE_4_0_0_VERSION&&await KN.upsertNodeRecord(l)}catch(l){VN.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(cG,"buildNodeStatus");function zce(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(zce,"NodeStatusObject")});var Jg=C((OLe,uG)=>{"use strict";var{handleHDBError:jce,hdb_errors:Qce}=_e(),{HTTP_STATUS_CODES:Jce}=Qce,Xce=ar(),Zce=xo(),YN=ae(),Qg=require("joi"),ele=pt(),tle=2e3,rle=Qg.object({timeout:Qg.number().min(1),connected_nodes:Qg.boolean(),routes:Qg.boolean()});uG.exports=nle;async function nle(e){Zce.checkClusteringEnabled();let t=ele.validateBySchema(e,rle);if(t)throw jce(t,t.message,Jce.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||YN.autoCastBoolean(n),o=s===void 0||YN.autoCastBoolean(s),c={nodes:[]},l=await Xce.getServerList(r??tle),u={};if(i)for(let f=0,d=l.length;f<d;f++){let h=l[f].statsz;h&&(u[l[f].server.name]=h.routes)}for(let f=0,d=l.length;f<d;f++){if(l[f].statsz)continue;let h=l[f].server,_=l[f].data;if(h.name.endsWith("-hub")){let p={name:h.name.slice(0,-4),response_time:l[f].response_time};i&&(p.connected_nodes=[],u[h.name]&&u[h.name].forEach(S=>{p.connected_nodes.includes(S.name.slice(0,-4))||p.connected_nodes.push(S.name.slice(0,-4))})),o&&(p.routes=_.cluster?.urls?_.cluster?.urls.map(S=>({host:S.split(":")[0],port:YN.autoCast(S.split(":")[1])})):[]),c.nodes.push(p)}}return c}a(nle,"clusterNetwork")});var hG=C((wLe,_G)=>{"use strict";var WN=require("joi"),dG=pt(),{route_constraints:fG}=wy();_G.exports={setRoutesValidator:sle,deleteRoutesValidator:ile};function sle(e){let t=WN.object({server:WN.valid("hub","leaf"),routes:fG.required()});return dG.validateBySchema(e,t)}a(sle,"setRoutesValidator");function ile(e){let t=WN.object({routes:fG.required()});return dG.validateBySchema(e,t)}a(ile,"deleteRoutesValidator")});var Xg=C((CLe,AG)=>{"use strict";var Ho=At(),zN=ae(),Ps=(v(),D(q)),_d=ce(),pG=hG(),{handleHDBError:EG,hdb_errors:ole}=_e(),{HTTP_STATUS_CODES:mG}=ole,gG="cluster routes successfully set",SG="cluster routes successfully deleted";AG.exports={setRoutes:cle,getRoutes:lle,deleteRoutes:ule};function ale(e){let t=Ho.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=zN.autoCast(l.port);let u=r.some(d=>d.host===l.host&&d.port===l.port),f=n.some(d=>d.host===l.host&&d.port===l.port);u||f?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?Ho.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):Ho.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:gG,set:i,skipped:s}}a(ale,"setRoutesNats");function cle(e){let t=pG.setRoutesValidator(e);if(t)throw EG(t,t.message,mG.BAD_REQUEST,void 0,void 0,!0);if(_d.get(Ps.CONFIG_PARAMS.CLUSTERING_ENABLED))return ale(e);let r=[],n=[],s=_d.get(Ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{TG(s,i)?n.push(i):(s.push(i),r.push(i))}),Ho.updateConfigValue(Ps.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:gG,set:r,skipped:n}}a(cle,"setRoutes");function TG(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(TG,"existsInArray");function lle(){if(_d.get(Ps.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=Ho.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return _d.get(Ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(lle,"getRoutes");function ule(e){let t=pG.deleteRoutesValidator(e);if(t)throw EG(t,t.message,mG.BAD_REQUEST,void 0,void 0,!0);if(_d.get(Ps.CONFIG_PARAMS.CLUSTERING_ENABLED))return dle(e);let r=[],n=[],s=_d.get(Ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{TG(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),Ho.updateConfigValue(Ps.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:SG,deleted:r,skipped:n}}a(ule,"deleteRoutes");function dle(e){let t=Ho.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let f=e.routes[l],d=!1;for(let h=0,_=r.length;h<_;h++){let p=r[h];if(f.host===p.host&&f.port===p.port){r.splice(h,1),d=!0,o=!0,s.push(f);break}}if(!d){let h=!0;for(let _=0,p=n.length;_<p;_++){let S=n[_];if(f.host===S.host&&f.port===S.port){n.splice(_,1),c=!0,h=!1,s.push(f);break}}h&&i.push(f)}}return o&&(r=zN.isEmptyOrZeroLength(r)?null:r,Ho.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=zN.isEmptyOrZeroLength(n)?null:n,Ho.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:SG,deleted:s,skipped:i}}a(dle,"deleteRoutesNats")});var yG=C((DLe,RG)=>{"use strict";var Ah=require("alasql"),Rl=require("recursive-iterator"),_i=W(),fle=ae(),Rh=(v(),D(q)),jN=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,hle(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=>Rh.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=>!Rh.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][Rh.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=_le(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!Rh.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let f=new Ah.yy.Column({columnid:u});s.tableid&&(f.tableid=s.tableid),this.ast.columns.push(f),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function _le(e){return e.filter(t=>t[Rh.PERMS_CRUD_ENUM.READ])}a(_le,"filterReadRestrictedAttrs");function hle(e,t,r,n,s){ple(e,t,r,n,s)}a(hle,"interpretAST");function yh(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(yh,"addSchemaTableToMap");function ple(e,t,r,n,s){if(!e){_i.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Ah.yy.Insert?Sle(e,t,r):e instanceof Ah.yy.Select?Ele(e,t,r,n,s):e instanceof Ah.yy.Update?mle(e,t,r):e instanceof Ah.yy.Delete?gle(e,t,r):_i.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(ple,"getRecordAttributesAST");function Ele(e,t,r,n,s){if(!e){_i.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(fle.isEmptyOrZeroLength(i)){_i.error("No schema specified");return}e.from.forEach(c=>{yh(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),yh(c.table,t,r,n,s)});let o=new Rl(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{_i.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Rl(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let f=u.tableid?u.tableid:l;if(!t.get(i).has(f))if(r.has(f))f=r.get(f);else{_i.info(`table specified as ${f} not found.`);continue}t.get(i).get(f).indexOf(u.columnid)<0&&t.get(i).get(f).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Rl(c.on);for(let{node:u}of l)if(u&&u.columnid){let f=u.tableid,d=s.get(f);if(!t.get(d).has(f))if(r.has(f))f=r.get(f);else{_i.info(`table specified as ${f} not found.`);continue}t.get(d).get(f).indexOf(u.columnid)<0&&t.get(d).get(f).push(u.columnid)}}),e.order){let c=new Rl(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,f=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(f).has(u))if(r.has(u))u=r.get(u);else{_i.info(`table specified as ${u} not found.`);return}t.get(f).get(u).indexOf(l.columnid)<0&&t.get(f).get(u).push(l.columnid)}}}a(Ele,"getSelectAttributes");function mle(e,t,r){if(!e){_i.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Rl(e.columns),s=e.table.databaseid;yh(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&QN(e.table.tableid,s,i.columnid,t,r)}a(mle,"getUpdateAttributes");function gle(e,t,r){if(!e){_i.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Rl(e.where),s=e.table.databaseid;yh(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&QN(e.table.tableid,s,i.columnid,t,r)}a(gle,"getDeleteAttributes");function Sle(e,t,r){if(!e){_i.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Rl(e.columns),s=e.into.databaseid;yh(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&QN(e.into.tableid,s,i.columnid,t,r)}a(Sle,"getInsertAttributes");function QN(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(QN,"pushAttribute");RG.exports=jN});var OG=C((MLe,bG)=>{"use strict";var Zg=(v(),D(q)),eS=class{static{a(this,"BaseLicense")}constructor(t=0,r=Zg.RAM_ALLOCATION_ENUM.DEFAULT,n=Zg.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},JN=class extends eS{static{a(this,"ExtendedLicense")}constructor(t=0,r=Zg.RAM_ALLOCATION_ENUM.DEFAULT,n=Zg.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};bG.exports={BaseLicense:eS,ExtendedLicense:JN}});var Ed=C((ULe,DG)=>{"use strict";var pd=require("fs-extra"),tS=(am(),D(om)),wG=require("crypto"),Tle=require("moment"),Ale=require("uuid").v4,tn=W(),ZN=require("path"),Rle=ae(),yl=(v(),D(q)),{totalmem:NG}=require("os"),yle=OG().ExtendedLicense,hd="invalid license key format",ble="061183",Ole="mofi25",Nle="aes-256-cbc",wle=16,Ile=32,IG=ce(),{resolvePath:CG}=At();IG.initSync();var XN;DG.exports={validateLicense:PG,generateFingerPrint:Ple,licenseSearch:rw,getLicense:Mle,checkMemoryLimit:vle};function ew(){return ZN.join(IG.getHdbBasePath(),yl.LICENSE_KEY_DIR_NAME,yl.LICENSE_FILE_NAME)}a(ew,"getLicenseDirPath");function Cle(){let e=ew();return CG(ZN.join(e,yl.LICENSE_FILE_NAME))}a(Cle,"getLicenseFilePath");function tw(){let e=ew();return CG(ZN.join(e,yl.REG_KEY_FILE_NAME))}a(tw,"getFingerPrintFilePath");async function Ple(){let e=tw();try{return await pd.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Dle();throw tn.error(`Error writing fingerprint file to ${e}`),tn.error(t),new Error("There was an error generating the fingerprint")}}a(Ple,"generateFingerPrint");async function Dle(){let e=Ale(),t=tS.hash(e,tS.HASH_FUNCTION.MD5),r=tw();try{await pd.mkdirp(ew()),await pd.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw tn.error(`Error writing fingerprint file to ${r}`),tn.error(n),new Error("There was an error generating the fingerprint")}return t}a(Dle,"writeFingerprint");function PG(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:yl.RAM_ALLOCATION_ENUM.DEFAULT,version:yl.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return tn.error("empty license key passed to validate."),r;let n=tw(),s=!1;try{s=pd.statSync(n)}catch(i){tn.error(i)}if(s){let i;try{i=pd.readFileSync(n,"utf8")}catch{tn.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(Ole),c=o[1];c=Buffer.concat([Buffer.from(c)],wle);let l=Buffer.concat([Buffer.from(i)],Ile),u=wG.createDecipheriv(Nle,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let f=null;try{f=u.update(o[0],"hex","utf8"),f.trim(),f+=u.final("utf8")}catch{let _=Lle(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(hd),tn.error(hd),new Error(hd)}let d;if(isNaN(f))try{d=JSON.parse(f),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(hd),tn.error(hd),new Error(hd)}else r.exp_date=f;r.exp_date<Tle().valueOf()&&(r.valid_date=!1),tS.validate(o[1],`${ble}${i}${t}`,tS.HASH_FUNCTION.MD5)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||tn.error("Invalid licence"),r}a(PG,"validateLicense");function Lle(e,t){try{let r=wG.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{tn.warn("Check old license failed")}}a(Lle,"checkOldLicense");function rw(){let e=new yle,t=[];try{t=pd.readFileSync(Cle(),"utf-8").split(`\r
|
|
25
|
-
`)}catch(r){r.code==="ENOENT"?tn.debug("no license file found"):tn.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(Rle.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=PG(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){tn.error("There was an error parsing the license string."),tn.error(s),e.ram_allocation=yl.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return XN=e,e}a(rw,"licenseSearch");async function Mle(){return XN||await rw(),XN}a(Mle,"getLicense");function vle(){let e=rw().ram_allocation,t=process.constrainedMemory?.()||NG();if(t=Math.round(Math.min(t,NG())/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(vle,"checkMemoryLimit")});var nS=C((BLe,UG)=>{var rS=Ed(),LG=require("chalk"),ss=W(),MG=require("prompt"),{promisify:Ule}=require("util"),nw=(v(),D(q)),xle=require("fs-extra"),Ble=require("path"),Hle=ae(),{packageJson:kle}=rt(),vG=ce();vG.initSync();var Fle=require("moment"),qle=Ule(MG.get),Gle=Ble.join(vG.getHdbBasePath(),nw.LICENSE_KEY_DIR_NAME,nw.LICENSE_FILE_NAME,nw.LICENSE_FILE_NAME);UG.exports={getFingerprint:Vle,setLicense:$le,parseLicense:sw,register:Kle,getRegistrationInfo:Wle};async function $le(e){if(e&&e.key&&e.company){try{ss.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await sw(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ss.error(r),ss.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a($le,"setLicense");async function Vle(){let e={};try{e=await rS.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ss.error(r),ss.error(t),new Error(r)}return e}a(Vle,"getFingerprint");async function sw(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ss.info("Validating license input...");let r=rS.validateLicense(e,t);if(ss.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(ss.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(ss.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ss.info("writing license to disk"),await xle.writeFile(Gle,JSON.stringify({license_key:e,company:t}))}catch(n){throw ss.error("Failed to write License"),n}return"Registration successful."}a(sw,"parseLicense");async function Kle(){let e=await Yle();return sw(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Kle,"register");async function Yle(){let e=await rS.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:LG.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:LG.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{MG.start()}catch(n){ss.error(n)}let r;try{r=await qle(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(Yle,"promptForRegistration");async function Wle(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await rS.getLicense()}catch(r){throw ss.error(`There was an error when searching licenses due to: ${r.message}`),r}if(Hle.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=kle.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=Fle.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(Wle,"getRegistrationInfo")});var BG=C((kLe,xG)=>{"use strict";var zle=gt(),iw=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d,h,_,p){this.port=t,o===null&&(o=void 0),this.server_name=r+zle.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:f,port:d,routes:h,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:_},HDB:{users:p}},this.system_account="SYS"}};xG.exports=iw});var FG=C((qLe,kG)=>{"use strict";var HG=gt(),ow=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d){this.port=t,d===null&&(d=void 0),this.server_name=r+HG.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+HG.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:f,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};kG.exports=ow});var GG=C(($Le,qG)=>{"use strict";var aw=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};qG.exports=aw});var VG=C((KLe,$G)=>{"use strict";var jle=gt(),cw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+jle.SERVER_SUFFIX.ADMIN,this.password=r}};$G.exports=cw});var aS=C((WLe,WG)=>{"use strict";var bl=require("path"),Ol=require("fs-extra"),Qle=BG(),Jle=FG(),Xle=GG(),Zle=VG(),lw=An(),gd=ae(),Dn=At(),iS=(v(),D(q)),bh=gt(),{CONFIG_PARAMS:zt}=iS,Sd=W(),Oh=ce(),KG=bo(),uw=ar(),eue=rs(),md="clustering",tue=1e4,YG=50;WG.exports={generateNatsConfig:nue,removeNatsConfig:sue,getHubConfigPath:rue};function rue(){let e=Oh.get(zt.ROOTPATH);return bl.join(e,md,bh.NATS_CONFIG_FILES.HUB_SERVER)}a(rue,"getHubConfigPath");async function nue(e=!1,t=void 0){let r=Oh.get(zt.ROOTPATH);Ol.ensureDirSync(bl.join(r,"clustering","leaf")),Oh.initSync();let n=Dn.getConfigFromFile(zt.CLUSTERING_TLS_CERT_AUTH),s=Dn.getConfigFromFile(zt.CLUSTERING_TLS_PRIVATEKEY),i=Dn.getConfigFromFile(zt.CLUSTERING_TLS_CERTIFICATE);!await Ol.exists(i)&&!await Ol.exists(!n)&&await eue.createNatsCerts();let o=bl.join(r,md,bh.PID_FILES.HUB),c=bl.join(r,md,bh.PID_FILES.LEAF),l=Dn.getConfigFromFile(zt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=bl.join(r,md,bh.NATS_CONFIG_FILES.HUB_SERVER),f=bl.join(r,md,bh.NATS_CONFIG_FILES.LEAF_SERVER),d=Dn.getConfigFromFile(zt.CLUSTERING_TLS_INSECURE),h=Dn.getConfigFromFile(zt.CLUSTERING_TLS_VERIFY),_=Dn.getConfigFromFile(zt.CLUSTERING_NODENAME),p=Dn.getConfigFromFile(zt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await uw.checkNATSServerInstalled()||oS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await lw.listUsers(),g=Dn.getConfigFromFile(zt.CLUSTERING_USER),T=await lw.getClusterUser();(gd.isEmpty(T)||T.active!==!0)&&oS(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await sS(zt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await sS(zt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await sS(zt.CLUSTERING_HUBSERVER_NETWORK_PORT),await sS(zt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let m=[],A=[];for(let[ie,X]of S.entries())X.role?.role===iS.ROLE_TYPES_ENUM.CLUSTER_USER&&X.active&&(m.push(new Zle(X.username,KG.decrypt(X.hash))),A.push(new Xle(X.username,KG.decrypt(X.hash))));let w=[],{hub_routes:M}=Dn.getClusteringRoutes();if(!gd.isEmptyOrZeroLength(M))for(let ie of M)w.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${ie.host}:${ie.port}`);let F=new Qle(Dn.getConfigFromFile(zt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,h,p,Dn.getConfigFromFile(zt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Dn.getConfigFromFile(zt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),w,m,A);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=gd.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===iS.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Ol.writeJson(u,F),Sd.trace(`Hub server config written to ${u}`));let G=`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@0.0.0.0:${p}`,K=`tls://${T.uri_encoded_name}:${T.uri_encoded_d_hash}@0.0.0.0:${p}`,ee=new Jle(Dn.getConfigFromFile(zt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[G],[K],m,A,i,s,n,d);n==null&&delete ee.tls.ca_file,(t===void 0||t===iS.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Ol.writeJson(f,ee),Sd.trace(`Leaf server config written to ${f}`))}a(nue,"generateNatsConfig");async function sS(e){let t=Oh.get(e);return gd.isEmpty(t)&&oS(`port undefined for '${e}'`),await gd.isPortTaken(t)&&oS(`'${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(sS,"isPortAvailable");function oS(e){let t=`Error generating clustering config: ${e}`;Sd.error(t),console.error(t),process.exit(1)}a(oS,"generateNatsConfigError");async function sue(e){let{port:t,config_file:r}=uw.getServerConfig(e),{username:n,decrypt_hash:s}=await lw.getClusterUser(),i=0,o=2e3;for(;i<YG;){try{let f=await uw.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){Sd.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${f}`)}if(i++,i>=YG)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&Sd.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await gd.async_set_timeout(u)}let c="0".repeat(tue),l=bl.join(Oh.get(zt.ROOTPATH),md,r);await Ol.writeFile(l,c),await Ol.remove(l),Sd.notify(e,"started.")}a(sue,"removeNatsConfig")});var ZG=C((jLe,XG)=>{"use strict";var is=ce(),iue=Ed(),qe=(v(),D(q)),Nh=gt(),ko=require("path"),{PACKAGE_ROOT:lS}=rt(),zG=ce(),cS=ae(),Td="/dev/null",oue=ko.join(lS,"launchServiceScripts"),jG=ko.join(lS,"utility/scripts"),aue=ko.join(jG,qe.HDB_RESTART_SCRIPT),QG=ko.resolve(lS,"dependencies",`${process.platform}-${process.arch}`,Nh.NATS_BINARY_NAME);function JG(){let t=iue.licenseSearch().ram_allocation||qe.RAM_ALLOCATION_ENUM.DEFAULT,r=qe.MEM_SETTING_KEY+t,n={[qe.PROCESS_NAME_ENV_PROP]:qe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return cS.noBootFile()&&(n[qe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=cS.getEnvCliRootPath()),{name:qe.PROCESS_DESCRIPTORS.HDB,script:qe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:lS}}a(JG,"generateMainServerConfig");var cue=9930;function lue(){is.initSync(!0);let e=is.get(qe.CONFIG_PARAMS.ROOTPATH),t=ko.join(e,"clustering",Nh.NATS_CONFIG_FILES.HUB_SERVER),r=ko.join(is.get(qe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),qe.LOG_NAMES.HDB),n=zG.get(qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Nh.LOG_LEVEL_FLAGS[is.get(qe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==cue?"-"+n:""),script:QG,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[qe.PROCESS_NAME_ENV_PROP]:qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return is.get(qe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Td,i.error_file=Td),i}a(lue,"generateNatsHubServerConfig");var uue=9940;function due(){is.initSync(!0);let e=is.get(qe.CONFIG_PARAMS.ROOTPATH),t=ko.join(e,"clustering",Nh.NATS_CONFIG_FILES.LEAF_SERVER),r=ko.join(is.get(qe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),qe.LOG_NAMES.HDB),n=zG.get(qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Nh.LOG_LEVEL_FLAGS[is.get(qe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==uue?"-"+n:""),script:QG,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[qe.PROCESS_NAME_ENV_PROP]:qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return is.get(qe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Td,i.error_file=Td),i}a(due,"generateNatsLeafServerConfig");function fue(){is.initSync();let e=ko.join(is.get(qe.CONFIG_PARAMS.LOGGING_ROOT),qe.LOG_NAMES.HDB),t={name:qe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:qe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[qe.PROCESS_NAME_ENV_PROP]:qe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:oue,autorestart:!1};return is.get(qe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Td,t.error_file=Td),t}a(fue,"generateClusteringUpgradeV4ServiceConfig");function _ue(){let e={[qe.PROCESS_NAME_ENV_PROP]:qe.PROCESS_DESCRIPTORS.RESTART_HDB};return cS.noBootFile()&&(e[qe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=cS.getEnvCliRootPath()),{...{name:qe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:jG},script:aue}}a(_ue,"generateRestart");function hue(){return{apps:[JG()]}}a(hue,"generateAllServiceConfigs");XG.exports={generateAllServiceConfigs:hue,generateMainServerConfig:JG,generateRestart:_ue,generateNatsHubServerConfig:lue,generateNatsLeafServerConfig:due,generateClusteringUpgradeV4ServiceConfig:fue}});var Ad=C((XLe,_$)=>{"use strict";var Ze=(v(),D(q)),pue=ae(),qo=aS(),uS=ar(),Fo=gt(),za=ZG(),dS=ce(),Nl=W(),Eue=xo(),{startWorker:e$,onMessageFromWorkers:mue}=nt(),gue=Uo(),JLe=require("util"),Sue=require("child_process"),Tue=require("fs"),{execFile:Aue}=Sue,Ke;_$.exports={enterPM2Mode:Rue,start:ja,stop:dw,reload:r$,restart:n$,list:fw,describe:o$,connect:Go,kill:wue,startAllServices:Iue,startService:_w,getUniqueServicesList:a$,restartAllServices:Cue,isServiceRegistered:c$,reloadStopStart:l$,restartHdb:i$,deleteProcess:Oue,startClusteringProcesses:d$,startClusteringThreads:f$,isHdbRestartRunning:Nue,isClusteringRunning:Due,stopClustering:Pue,reloadClustering:Lue,expectedRestartOfChildren:s$};var wh=!1;mue(e=>{e.type==="restart"&&dS.initSync(!0)});function Rue(){wh=!0}a(Rue,"enterPM2Mode");function Go(){return Ke||(Ke=require("pm2")),new Promise((e,t)=>{Ke.connect((r,n)=>{r&&t(r),e(n)})})}a(Go,"connect");var rn,yue=10,t$;function ja(e,t=!1){if(wh)return bue(e);let r=Aue(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=rn.indexOf(r);o>-1&&rn.splice(o,1),!t$&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<yue&&(Tue.existsSync(qo.getHubConfigPath())?ja(e):(await qo.generateNatsConfig(!0),ja(e),await new Promise(c=>setTimeout(c,3e3)),await qo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await qo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=dS.get(Ze.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,f;for(;l=c.exec(i);){if(l.index&&Fo.LOG_LEVEL_HIERARCHY[o]>=Fo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===Fo.LOG_LEVELS.ERR||f===Fo.LOG_LEVELS.WRN?Nl.OUTPUTS.STDERR:Nl.OUTPUTS.STDOUT;Nl.logCustomLevel(f||"info",_,n,i.slice(u,l.index).trim())}let[d,h]=l;u=l.index+d.length,f=Fo.LOG_LEVELS[h]}if(Fo.LOG_LEVEL_HIERARCHY[o]>=Fo.LOG_LEVEL_HIERARCHY[f||"info"]){let d=f===Fo.LOG_LEVELS.ERR||f===Fo.LOG_LEVELS.WRN?Nl.OUTPUTS.STDERR:Nl.OUTPUTS.STDOUT;Nl.logCustomLevel(f||"info",d,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!rn&&(rn=[],!t)){let i=a(()=>{t$=!0,rn&&(rn.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)}rn.push(r)}a(ja,"start");function bue(e){return new Promise(async(t,r)=>{try{await Go()}catch(n){r(n)}Ke.start(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(bue,"startWithPM2");function dw(e){if(!wh){for(let t of rn||[])t.name===e&&(rn.splice(rn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Go()}catch(n){r(n)}Ke.stop(e,async(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.delete(e,(i,o)=>{i&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(o)})})})}a(dw,"stop");function r$(e){return new Promise(async(t,r)=>{try{await Go()}catch(n){r(n)}Ke.reload(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(r$,"reload");function n$(e){if(!wh){s$();for(let t of rn||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Go()}catch(n){r(n)}Ke.restart(e,(n,s)=>{Ke.disconnect(),t(s)})})}a(n$,"restart");function s$(){for(let e of rn||[])e.config&&(e.config.restarts=0)}a(s$,"expectedRestartOfChildren");function Oue(e){return new Promise(async(t,r)=>{try{await Go()}catch(n){r(n)}Ke.delete(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(Oue,"deleteProcess");async function i$(){await ja(za.generateRestart())}a(i$,"restartHdb");async function Nue(){let e=await fw();for(let t in e)if(e[t].name===Ze.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Nue,"isHdbRestartRunning");function fw(){return new Promise(async(e,t)=>{try{await Go()}catch(r){t(r)}Ke.list((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(fw,"list");function o$(e){return new Promise(async(t,r)=>{try{await Go()}catch(n){r(n)}Ke.describe(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(o$,"describe");function wue(){if(!wh){for(let e of rn||[])e.kill();rn=[];return}return new Promise(async(e,t)=>{try{await Go()}catch(r){t(r)}Ke.killDaemon((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(wue,"kill");async function Iue(){try{await d$(),await f$(),await ja(za.generateAllServiceConfigs())}catch(e){throw Ke?.disconnect(),e}}a(Iue,"startAllServices");async function _w(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Ze.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=za.generateMainServerConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=za.generateNatsIngestServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=za.generateNatsReplyServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=za.generateNatsHubServerConfig(),await ja(r,t),await qo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=za.generateNatsLeafServerConfig(),await ja(r,t),await qo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=za.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await ja(r)}catch(r){throw Ke?.disconnect(),r}}a(_w,"startService");async function a$(){try{let e=await fw(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Ke?.disconnect(),e}}a(a$,"getUniqueServicesList");async function Cue(e=[]){try{let t=!1,r=await a$();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===Ze.PROCESS_DESCRIPTORS.HDB?t=!0:await n$(o))}t&&await l$(Ze.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ke?.disconnect(),t}}a(Cue,"restartAllServices");async function c$(e){if(rn?.find(r=>r.name===e))return!0;let t=await gue.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(c$,"isServiceRegistered");async function l$(e){let t=dS.get(Ze.CONFIG_PARAMS.THREADS_COUNT)??dS.get(Ze.CONFIG_PARAMS.THREADS),r=await o$(e),n=pue.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await dw(e),await _w(e)):e===Ze.PROCESS_DESCRIPTORS.HDB?await i$():await r$(e)}a(l$,"reloadStopStart");var u$;async function d$(e=!1){for(let t in Ze.CLUSTERING_PROCESSES){let r=Ze.CLUSTERING_PROCESSES[t];await _w(r,e)}}a(d$,"startClusteringProcesses");async function f$(){u$=e$(Ze.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Ze.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await uS.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await uS.updateLocalStreams();let e=await Eue.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Ze.PRE_4_0_0_VERSION){Nl.info("Starting clustering upgrade 4.0.0 process"),e$(Ze.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(f$,"startClusteringThreads");async function Pue(){for(let e in Ze.CLUSTERING_PROCESSES)if(e!==Ze.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===Ze.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await u$.terminate();else{let t=Ze.CLUSTERING_PROCESSES[e];await dw(t)}}a(Pue,"stopClustering");async function Due(){for(let e in Ze.CLUSTERING_PROCESSES){let t=Ze.CLUSTERING_PROCESSES[e];if(await c$(t)===!1)return!1}return!0}a(Due,"isClusteringRunning");async function Lue(){await qo.generateNatsConfig(!0),await uS.reloadNATSHub(),await uS.reloadNATSLeaf(),await qo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await qo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Lue,"reloadClustering")});var hS={};Be(hS,{compactOnStart:()=>Mue,copyDb:()=>S$});async function Mue(){Qa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,hw.get)(H.ROOTPATH),t=new Map,r=Je();(0,pw.updateConfigValue)(H.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,fS.join)(e,"backup",n+".mdb"),o=(0,fS.join)(e,yc,n+"-copy.mdb"),c=0;try{c=await h$(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Qa.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await S$(n,o),console.log("Backing up",n,"to",i),await(0,wl.move)(s,i,{overwrite:!0})}try{Rd()}catch(n){Qa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,wl.move)(i,s,{overwrite:!0}),await(0,wl.remove)((0,fS.join)(e,yc,`${n}-copy.mdb-lock`));try{Rd()}catch(n){Qa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Qa.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,pw.updateConfigValue)(H.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,wl.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Rd(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await h$(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
23
|
+
`,"")}a(Nk,"runCommand");async function Wse(){try{await yse.access(xO)}catch{return!1}let e=await Nk(`${xO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return bse.eq(t,Kse)}a(Wse,"checkNATSServerInstalled");async function GO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await bk.getClusterUser();if(ll(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}ci.trace("create nats connection called");let i=await xse({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),ci.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&ci.error("Error with Nats client connection, connection closed",o),i===Xr&&wk()}),i}a(GO,"createConnection");function wk(){Xr=void 0,ol=void 0,al=void 0,cl=void 0}a(wk,"clearClientCache");async function zse(){Xr&&(await Xr.drain(),Xr=void 0,ol=void 0,al=void 0,cl=void 0)}a(zse,"closeConnection");var Xr,cl;async function ip(){return cl||(cl=GO(Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Xr=await cl),Xr||cl}a(ip,"getConnection");async function op(){if(ol)return ol;ll(Xr)&&await ip();let{domain:e}=Xu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ol=await Xr.jetstreamManager({domain:e,timeout:6e4}),ol}a(op,"getJetStreamManager");async function Ik(){if(al)return al;ll(Xr)&&await ip();let{domain:e}=Xu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return al=Xr.jetstream({domain:e,timeout:6e4}),al}a(Ik,"getJetStream");async function Yi(){let e=Xr||await ip(),t=ol||await op(),r=al||await Ik();return{connection:e,jsm:t,js:r}}a(Yi,"getNATSReferences");async function jse(e){let t=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await bk.getClusterUser(),s=await GO(t,r,n),i=FO(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=Ok.decode(f.data);d.response_time=Date.now()-l,c.push(d)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Eg.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(jse,"getServerList");async function qO(e,t){let{jsm:r}=await Yi(),n=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Bse.File,retention:Hse.Limits,subjects:t,discard:kse.Old,max_msgs:s,max_bytes:i,max_age:n})}a(qO,"createLocalStream");async function Ck(){let{jsm:e}=await Yi(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Ck,"listStreams");async function Qse(e){let{jsm:t}=await Yi();await t.streams.delete(e)}a(Qse,"deleteLocalStream");async function Jse(e){let{connection:t}=await Yi(),r=[],n=FO(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(Ok.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(Jse,"listRemoteStreams");async function Xse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Yi(),i=Tk(),o={durable_name:i,ack_policy:HO.Explicit};t&&(o.deliver_policy=kO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let f of l){let d=BO(f.data),p={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(p.origin=f.headers.get(vr.MSG_HEADERS.ORIGIN)),u.push(p),f.ack(),f.info.pending===0)break}return await c.delete(),u}a(Xse,"viewStream");async function*Zse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Yi(),i=Tk(),o={durable_name:i,ack_policy:HO.Explicit};t&&(o.deliver_policy=kO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let f=BO(u.data);f[0]||(f=[f]);for(let d of f){let p={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(p.origin=u.headers.get(vr.MSG_HEADERS.ORIGIN)),yield p}if(u.ack(),u.info.pending===0)break}await c.delete()}a(Zse,"viewStreamIterator");async function eie(e,t,r,n){ci.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Pk(n,r);let{js:s}=await Yi(),i=await Sg(),o=`${e}.${i}`,c=await $se(()=>n instanceof Uint8Array?n:yk.encode(n));try{ci.trace(`publishToStream publishing to subject: ${o}`),qse(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 Lk(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){ci.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await qO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(eie,"publishToStream");function Pk(e,t){t===void 0&&(t=Gse());let r=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(vr.MSG_HEADERS.ORIGIN)&&r&&t.append(vr.MSG_HEADERS.ORIGIN,r),t}a(Pk,"addNatsMsgHeader");function Xu(e){e=e.toLowerCase();let t=sp.join(Nr.get(Ve.CONFIG_PARAMS.ROOTPATH),Vse);if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return ll(UO)&&(UO={port:rp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:rp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.HUB,config_file:vr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:sp.join(t,vr.PID_FILES.HUB),hdb_nats_path:t}),UO;if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return ll(vO)&&(vO={port:rp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:rp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,config_file:vr.NATS_CONFIG_FILES.LEAF_SERVER,domain:rp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,pid_file_path:sp.join(t,vr.PID_FILES.LEAF),hdb_nats_path:t}),vO;ci.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Xu,"getServerConfig");async function Dk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:HO.Explicit,durable_name:r,deliver_policy:kO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(Dk,"createConsumer");async function tie(e,t,r){await e.consumers.delete(t,r)}a(tie,"removeConsumer");function rie(e){return e.split(".")[1]}a(rie,"extractServerName");async function nie(e,t,r=6e4,n=FO()){if(!Eg.isObject(t))throw new Error("data param must be an object");let s=yk.encode(t),{connection:i}=await Yi(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return BO(c.data)}a(nie,"request");function $O(e){return new Promise(async(t,r)=>{let n=Ise(xO,["--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($O,"reloadNATS");async function sie(){let{pid_file_path:e}=Xu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await $O(e)}a(sie,"reloadNATSHub");async function iie(){let{pid_file_path:e}=Xu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await $O(e)}a(iie,"reloadNATSLeaf");function oie(e,t,r){let n;switch(e.code){case Sk.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case Sk.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(oie,"requestErrorHandler");async function aie(e,t){let r=t+vr.SERVER_SUFFIX.LEAF,{connection:n}=await Yi(),{jsm:s}=await hie(r),{schema:i,table:o}=e,c=gg.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await Lk(async()=>{if(e.subscribe===!0)await Dk(s,c,n.info.server_name,l);else try{await tie(s,c,n.info.server_name)}catch(u){ci.trace(u)}})}a(aie,"updateRemoteConsumer");async function cie(e,t,r,n){let s=gg.createNatsTableStreamName(e,t),i=r+vr.SERVER_SUFFIX.LEAF,o={type:Ve.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!Rk&&vse()<Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=MO();await c(o)}await Lse(o),n==="stop"&&await Eg.async_set_timeout(1e3)}a(cie,"updateConsumerIterator");function Lk(e){return Dse.writeTransaction(Ve.SYSTEM_SCHEMA_NAME,Ve.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Lk,"exclusiveLock");async function Mk(e,t){let r=gg.createNatsTableStreamName(e,t),n=await Sg(),s=fie(e,t,n);await qO(r,[s])}a(Mk,"createLocalTableStream");async function lie(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await Mk(n,s)}}a(lie,"createTableStreams");async function vk(e,t,r=void 0){if(Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=gg.createNatsTableStreamName(e,t),{domain:s}=Xu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await ip()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")ci.warn(n);else throw n}}a(vk,"purgeTableStream");async function uie(e,t){if(Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await vk(e,t[r])}a(uie,"purgeSchemaTableStreams");async function die(e){return(await op()).streams.info(e)}a(die,"getStreamInfo");function fie(e,t,r){return`${vr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(fie,"createSubjectName");async function Sg(){if(np)return np;if(np=(await op())?.nc?.info?.server_name,np===void 0)throw new Error("Unable to get jetstream manager server name");return np}a(Sg,"getJsmServerName");async function _ie(){let e=await op(),t=await Sg(),r=await Ck();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=pie(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let f=u.join(".");ci.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(_ie,"updateLocalStreams");function pie(e){let{config:t}=e,r=!1,n=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Nr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(pie,"updateStreamLimits");async function hie(e){let t,r;try{t=await Xr.jetstream({domain:e}),r=await Xr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw ci.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(hie,"connectToRemoteJS")});function VO(e){let t=e.get(Tg),r=t?(0,Zu.unpack)(t):null;r||(r={remoteNameToId:{}});let n=Xe(),s=!1;r.nodeName=Xe();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:cp(e)??1,nodes:[]})})}i[n]=0,e.putSync(Tg,(0,Zu.pack)(r))}return r}function ap(e){return VO(e).remoteNameToId}function Bk(e,t){let r=VO(t),n=r.remoteNameToId,s=new Map,i=!1;for(let o in e){let c=e[o],l=n[o];if(l==null){let u=0;for(let f in n){let d=n[f];d>u&&(u=d)}l=u+1,n[o]=l,i=!0}s.set(c,l)}return i&&t.putSync(Tg,(0,Zu.pack)(r)),s}function Ag(e,t){let r=VO(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Tg,(0,Zu.pack)(r))}return xk.trace?.("The remote node name map",e,n,s),s}var xk,Zu,Tg,KO=be(()=>{xk=M(Ci());ts();Zu=require("msgpackr"),Tg=Symbol.for("remote-ids");a(VO,"getIdMappingRecord");a(ap,"exportIdMapping");a(Bk,"remoteToLocalNodeId");a(Ag,"getIdOfRemoteNode")});var YO={};ve(YO,{commits_awaiting_replication:()=>td,getHDBNodeTable:()=>gr,getReplicationSharedStatus:()=>Rg,iterateRoutes:()=>up,shouldReplicateToNode:()=>lp,subscribeToNodeUpdates:()=>rd});function gr(){return Hk||(Hk=lt({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Rg(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function rd(e){gr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;qk.debug?.("adding node",n,"on node",Xe()," on process",process.pid),server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==Xe()&&(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 lp(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&gr().primaryStore.get(Xe())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function mie(){rd(e=>{Ma({},(t,r)=>{let n=e.name,s=kk.get(n);if(s||kk.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=Rg(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of td.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*up(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=ed.default.get(x.REPLICATION_SECUREPORT)??(!ed.default.get(x.REPLICATION_PORT)&&ed.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||ed.default.get(x.REPLICATION_PORT)||ed.default.get(x.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){Fk.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime,revoked_certificates:t.revokedCertificates}}}var Fk,Gk,ed,qk,Hk,kk,td,ul=be(()=>{Pe();ts();Am();Fk=require("worker_threads"),Gk=M(pe()),ed=M(ce());B();qk=M(Ci());server.nodes=[];a(gr,"getHDBNodeTable");a(Rg,"getReplicationSharedStatus");a(rd,"subscribeToNodeUpdates");a(lp,"shouldReplicateToNode");kk=new Map;EL((e,t,r)=>{if(r>server.nodes.length)throw new Gk.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);td||(td=new Map,mie());let n=td.get(e);return n||(n=[],td.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(mie,"startSubscriptionToReplications");a(up,"iterateRoutes")});var Yk={};ve(Yk,{connectedToNode:()=>dl,disconnectedFromNode:()=>id,ensureNode:()=>Io,requestClusterStatus:()=>Kk,startOnMainThread:()=>zO});async function zO(e){let t=0,r=Je();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){yg.set(i,cp(l.auditStore));break}}}Wi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of up(e))try{let c=!o.subscriptions;if(c){let u=Xe();gr().primaryStore.get(u)===void 0&&await Io(u,{name:u,url:e.url??va(),replicates:!0})}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}rd(s)});let n;function s(i,o=i?.name){let c=Xe()&&o===Xe()||va()&&i?.url===va();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let p of gr().search([]))p.replicates&&p.name!==o&&s(p,p.name);n=d}if(ot.trace("Setting up node replication for",i),!i){for(let[d,p]of wo){let _;for(let[h,{worker:S,nodes:g}]of p){let A=g[0];if(A&&A.name==o){_=!0;for(let[E,{worker:R}]of p)p.delete(E),ot.warn("Node was deleted, unsubscribing from node",o,E,d),R?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){wo.get(d).iterator.remove(),wo.delete(d);return}}return}if(c)return;if(!i.url){ot.info(`Node ${i.name} is missing url`);return}let l=wo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ot.info(`Added node ${i.name} at ${i.url} for process ${Xe()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,p]of nd)if(i.url===p.url){nd.delete(d);break}nd.set(i.name,i)}let u=Je();if(l||(l=new Map,wo.set(i.url,l)),l.iterator=Ma(e,(d,p,_)=>{_?f(p,!0):f(p,!1)}),i.subscriptions)for(let d of i.subscriptions){let p=d.database||d.schema;u[p]||(ot.warn(`Database ${p} not found for node ${i.name}, making a subscription anyway`),f(p,!1))}function f(d,p){ot.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),h,S=[{replicateByDefault:p,...i}];yg.has(d)&&(S.push({replicateByDefault:p,name:Xe(),start_time:yg.get(d),end_time:Date.now(),replicates:!0}),yg.delete(d));let g=lp(i,d),A=Wi.workers.filter(E=>E.name==="http");if(_?(h=_.worker,_.nodes=S):g&&(t=t%A.length,h=A[t++],l.set(d,{worker:h,nodes:S,url:i.url}),h?.on("exit",()=>{l.get(d)?.worker===h&&(l.delete(d),f(d,p))})),g)setTimeout(()=>{let E={type:"subscribe-to-node",database:d,nodes:S};h?h.postMessage(E):sd(E)},Eie);else{ot.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],gr().primaryStore.get(Xe())?.replicates),gr().primaryStore.get(Xe())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};h?h.postMessage(E):Og(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),id=a(function(i){try{ot.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(nd.keys()),c=o.sort(),l=c.indexOf(i.name||li(i.url));if(l===-1){ot.warn("Disconnected node not found in node map",i.name,o);return}let u=wo.get(i.url),f=u?.get(i.database);if(!f){ot.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished)return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let p=(l+1)%c.length;for(;l!==p;){let _=c[p],h=nd.get(_);u=wo.get(h.url);let S=u?.get(i.database);if(!S){p=(p+1)%c.length;continue}let{worker:g,nodes:A}=S,E=!1;for(let R of f.nodes){if(A.some(N=>N.name===R.name)){ot.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}A.push(R),E=!0}if(!E){ot.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,ot.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:A}):sd({database:i.database,nodes:A});return}ot.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){ot.error("Error failing over node",o)}},"disconnectedFromNode"),dl=a(function(i){let o=wo.get(i.url),c=o?.get(i.database);if(!c){ot.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,f=u.find(d=>d.name===i.name);c.redirectingTo=null,f&&(u.splice(u.indexOf(f),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):sd({database:i.database,nodes:u}))}},"connectedToNode"),(0,Wi.onMessageByType)("disconnected-from-node",id),(0,Wi.onMessageByType)("connected-to-node",dl),(0,Wi.onMessageByType)("request-cluster-status",Kk)}function Kk(e,t){let r=[];for(let[n,s]of nd)try{let i=wo.get(s.url);ot.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:f,nodes:d,latency:p}]of i)o.push({database:l,connected:f,latency:p,thread_id:u?.threadId,nodes:d.map(_=>_.name)});let c=(0,WO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ot.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Io(e,t){let r=gr();e=e??li(t.url),t.name=e;try{if(t.ca){let s=new Vk.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){ot.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ot.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!$k.default.get(x.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,WO.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}ot.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Wi,bg,ot,WO,$k,Vk,Eie,wo,id,dl,nd,yg,dp=be(()=>{Pe();Wi=M(tt());ts();bg=require("worker_threads");ul();ot=M(Y()),WO=require("lodash"),$k=M(ce());B();Vk=require("crypto"),Eie=200,wo=new Map,nd=new Map,yg=new Map;a(zO,"startOnMainThread");a(Kk,"requestClusterStatus");bg.parentPort&&(id=a(e=>{bg.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),dl=a(e=>{bg.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Wi.onMessageByType)("subscribe-to-node",e=>{sd(e)}),(0,Wi.onMessageByType)("unsubscribe-from-node",e=>{Og(e)}));a(Io,"ensureNode")});var rs=I(hF=>{"use strict";var or=require("path"),Nn=require("fs-extra"),od=require("node-forge"),Xk=require("net"),{generateKeyPair:QO,X509Certificate:Co,createPrivateKey:Zk}=require("crypto"),gie=require("util");QO=gie.promisify(QO);var yt=od.pki,ui=require("joi"),{v4:eF}=require("uuid"),{validateBySchema:eN}=ut(),ft=Y(),Ns=ce(),ws=(B(),C(G)),{CONFIG_PARAMS:ad}=ws,di=Gy(),{ClientError:xa}=pe(),Ng=require("node:tls"),{relative:tF,join:Sie}=require("node:path"),{CERT_PREFERENCE_APP:vPe,CERTIFICATE_VALUES:Wk}=di,Tie=da(),JO=Rt(),{table:Aie,getDatabases:Rie,databases:jO}=(Pe(),C(rt)),{getJWTRSAKeys:zk}=(zu(),C(ep));Object.assign(hF,{generateKeys:nN,updateConfigCert:lF,createCsr:Pie,signCertificate:Die,setCertTable:cd,loadCertificates:oF,reviewSelfSignedCert:iN,createTLSSelector:dF,listCertificates:_F,addCertificate:Bie,removeCertificate:kie,createNatsCerts:vie,generateCertsKeys:Mie,getReplicationCert:_p,getReplicationCertAuth:Cie,renewSelfSigned:Uie,hostnamesFromCert:pF,getKey:Fie});var{urlToNodeName:rF,getThisNodeUrl:yie,getThisNodeName:Ig,clearThisNodeName:bie}=(ts(),C(Po)),{readFileSync:Oie,watchFile:Nie,statSync:nF}=require("node:fs"),UPe=ce(),{getTicketKeys:wie,onMessageFromWorkers:Iie}=tt(),Ua=Y(),{isMainThread:sF}=require("worker_threads"),{TLSSocket:iF,createSecureContext:xPe}=require("node:tls"),tN=3650,fp=["127.0.0.1","localhost","::1"],rN=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Iie(async e=>{e.type===ws.ITC_EVENT_TYPES.RESTART&&(Ns.initSync(!0),await iN())});var Ur;function Ha(){return Ur||(Ur=Rie().system.hdb_certificate,Ur||(Ur=Aie({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),Ur}a(Ha,"getCertTable");async function _p(){let e=dF("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Ig());if(!r)return;let n=new Co(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(_p,"getReplicationCert");async function Cie(){Ha();let e=(await _p()).options.cert,r=new Co(e).issuer.match(/CN=(.*)/)?.[1];return Ur.get(r)}a(Cie,"getReplicationCertAuth");var jk,Ba=new Map;function oF(){if(jk)return;jk=!0;let e=[{configKey:ad.TLS},{configKey:ad.OPERATIONSAPI_TLS}];Ha();let t=or.dirname(JO.getConfigFilePath()),r;for(let{configKey:n}of e){let s=JO.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&tF(Sie(t,"keys"),o);c&&Qk(o,l=>{Ba.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&sF){let f;Qk(u,d=>{if(Wk.cert===d)return;let p=i.hostname??i.hostnames??i.host??i.hosts;p&&!Array.isArray(p)&&(p=[p]);let _=uF(u),h=new Co(_),S;try{S=oN(h)}catch(R){ft.error("error extracting common name from certificate",R);return}if(S==null){ft.error("error extracting common name from certificate");return}if(h.checkIssued(new Co(Wk.cert)))return;let g=Ur.primaryStore.get(S),A=nF(u).mtimeMs,E=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&A<=E){A<E&&ft.info(`Certificate ${S} at ${u} is older (${new Date(A)}) than the certificate in the database (${E>1?new Date(E):"only self signed certificate available"})`);return}r=Ur.put({name:S,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:_,private_key_name:c,is_authority:l,hostnames:p,file_timestamp:A,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(oF,"loadCertificates");function Qk(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&sF&&ft.warn(`Reloading ${r}:`,e),n=c,t(uF(e)))}catch(c){ft.error(`Error loading ${r}:`,e,c)}},"loadFile");Nn.existsSync(e)?s(nF(e)):ft.error(`${r} file not found:`,e),Nie(e,{persistent:!1},s)}a(Qk,"loadAndWatch");function XO(){let e=yie();if(e==null){let t=fp[0];return ft.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return rF(e)}a(XO,"getHost");function wg(){let e=Ig();if(e==null){let t=fp[0];return ft.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(wg,"getCommonName");async function Pie(){let e=await _p(),t=yt.certificateFromPem(e.options.cert),r=yt.privateKeyFromPem(e.options.key);ft.info("Creating CSR with cert named:",e.name);let n=yt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:wg()},...rN];ft.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:aF()}];return ft.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),od.pki.certificationRequestToPem(n)}a(Pie,"createCsr");function aF(){let e=fp.includes(wg())?fp:[...fp,wg()];return e.includes(XO())||e.push(XO()),[{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=>Xk.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(aF,"certExtensions");async function Die(e){let t={},r=or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;Ha();for await(let f of Ur.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(Ba.has(f.private_key_name)){n=Ba.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await Nn.exists(or.join(r,f.private_key_name))){n=Nn.readFile(or.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await ZO();s=f.ca,n=f.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);ft.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return ft.error(f),new Error("Error verifying CSR: "+f.message)}let c=od.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+tN),ft.info("sign cert setting validity:",c.validity),ft.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),ft.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;ft.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,od.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else ft.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Die,"signCertificate");async function Lie(e,t){await cd({name:Ig(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await cd({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Lie,"createCertificateTable");async function cd(e){let t=new Co(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},Ha(),await Ur.patch(e)}a(cd,"setCertTable");async function nN(){let e=await QO("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(nN,"generateKeys");async function sN(e,t,r){let n=yt.createCertificate();if(!t){let o=await _p();t=yt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+tN);let i=[{name:"commonName",value:wg()},...rN];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(aF()),n.sign(e,od.md.sha256.create()),yt.certificateToPem(n)}a(sN,"generateCertificates");async function ZO(){let e=await _F(),t;for(let r of e){if(!r.is_authority)continue;let n=await fF(r.private_key_name);if(r.private_key_name&&n&&new Co(r.certificate).checkPrivateKey(Zk(n))){ft.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;ft.trace("No CA found with matching private key")}a(ZO,"getCertAuthority");async function cF(e,t,r=!0){let n=yt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+tN);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${Ns.get(ad.REPLICATION_HOSTNAME)??rF(Ns.get(ad.REPLICATION_URL))??eF().split("-")[0]}`},...rN];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,od.md.sha256.create());let o=or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),c=or.join(o,di.PRIVATEKEY_PEM_NAME);return r&&await Nn.writeFile(c,yt.privateKeyToPem(e)),n}a(cF,"generateCertAuthority");async function Mie(){let{private_key:e,public_key:t}=await nN(),r=await cF(e,t),n=await sN(e,t,r);await Lie(n,r),lF()}a(Mie,"generateCertsKeys");async function vie(){let e=await sN(yt.privateKeyFromPem(di.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(di.CERTIFICATE_VALUES.cert)),t=or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),r=or.join(t,di.NATS_CERTIFICATE_PEM_NAME);await Nn.exists(r)||await Nn.writeFile(r,e);let n=or.join(t,di.NATS_CA_PEM_NAME);await Nn.exists(n)||await Nn.writeFile(n,di.CERTIFICATE_VALUES.cert)}a(vie,"createNatsCerts");async function Uie(){Ha();for await(let e of Ur.search([{attribute:"is_self_signed",value:!0}]))await Ur.delete(e.name);await iN()}a(Uie,"renewSelfSigned");async function iN(){bie(),await oF(),Ha();let e=await ZO();if(!e){ft.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=Ns.get(ad.TLS_PRIVATEKEY),n=or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),s,i=tF(n,r);try{s=yt.privateKeyFromPem(await Nn.readFile(r))}catch(c){ft.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await nN(),await Nn.exists(or.join(n,di.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${eF().split("-")[0]}.pem`),await Nn.writeFile(or.join(n,i),yt.privateKeyToPem(s))}let o=await cF(s,yt.setRsaPublicKey(s.n,s.e),!1);await cd({name:o.subject.getField("CN").value,uses:["https"],certificate:yt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await _p()){let r=Ig();ft.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await ZO();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await sN(yt.privateKeyFromPem(e.private_key),s,n);await cd({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(iN,"reviewSelfSignedCert");function lF(){let e=Tie(Object.keys(ws.CONFIG_PARAM_MAP),!0),t=or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME),r=or.join(t,di.PRIVATEKEY_PEM_NAME),n=or.join(t,di.NATS_CERTIFICATE_PEM_NAME),s=or.join(t,di.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),JO.updateConfigValue(void 0,void 0,o,!1,!0)}a(lF,"updateConfigCert");function uF(e){return e.startsWith("-----BEGIN")?e:Oie(e,"utf8")}a(uF,"readPEM");var Jk=Ng.createSecureContext;Ng.createSecureContext=function(e){if(!e.cert||!e.key)return Jk(e);let t={...e};delete t.key,delete t.cert;let r=Jk(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var xie=iF.prototype._init;iF.prototype._init=function(e,t){xie.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var fl=new Map;function dF(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),fl.clear();let f=0;for await(let d of jO.system.hdb_certificate.search([])){let p=d.certificate,_=new Co(p);d.is_authority&&(_.asString=p,fl.set(_.subject,p))}for await(let d of jO.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let p=e==="operations-api",_=d.is_self_signed?1:2;p&&d.uses?.includes?.("operations")&&(_+=1);let h=await fF(d.private_key_name),S=d.certificate,g=new Co(S);if(fl.has(g.issuer)&&(S+=`
|
|
24
|
+
`+fl.get(g.issuer)),!h||!S)throw new Error("Missing private key or certificate for secure server");let A={ciphers:d.ciphers,ticketKeys:wie(),availableCAs:fl,ca:t&&Array.from(fl.values()),cert:S,key:h,key_file:d.private_key_name,is_self_signed:d.is_self_signed};o&&(A.sessionIdContext=o.sessionIdContext);let E=Ng.createSecureContext(A);E.name=d.name,E.options=A,E.quality=_,E.certificateAuthorities=Array.from(fl),E.certStart=S.toString().slice(0,100);let R=d.hostnames??pF(g);Array.isArray(R)||(R=[R]);let N;for(let v of R)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===XO()&&(_+=2),Xk.isIP(v)&&(N=!0);let k=r.get(v)?.quality??0;_>k&&r.set(v,E)}else Ua.error("No hostname found for certificate at",Ng.certificate);Ua.trace("Adding TLS",E.name,"for",o.ports||"client","cert named",d.name,"hostnames",R,"quality",_,"best quality",f),_>f&&(i.defaultContext=n=E,f=_,o&&(o.defaultContext=E))}catch(p){Ua.error("Error applying TLS for",d.name,p)}o?.secureContextsListeners.forEach(d=>d()),c(n)}catch(f){l(f)}}a(u,"updateTLS"),jO.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){Ua.info("TLS requested for",o||"(no SNI)");let l=o;for(;;){let f=r.get(l);if(f)return Ua.debug("Found certificate for",o,f.certStart),f.updatedContext&&(f=f.updatedContext),c(null,f);if(s&&l){let d=l.indexOf(".",1);d<0?l="":l=l.slice(d)}else break}o?Ua.debug("No certificate found to match",o,"using the default certificate"):Ua.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):Ua.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(dF,"createTLSSelector");async function fF(e){let t=Ba.get(e);return!t&&e?await Nn.readFile(or.join(Ns.get(ad.ROOTPATH),ws.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(fF,"getPrivateKeyByName");async function _F(){Ha();let e=[];for await(let t of Ur.search([]))e.push(t);return e}a(_F,"listCertificates");async function Bie(e){let t=eN(e,ui.object({name:ui.string().required(),certificate:ui.string().required(),is_authority:ui.boolean().required(),private_key:ui.string(),hosts:ui.array(),uses:ui.array()}));if(t)throw new xa(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new Co(n),c=!1,l=!1,u;for(let[_,h]of Ba)!s&&!c&&o.checkPrivateKey(Zk(h))&&(c=!0,u=_),s&&s===h&&(l=!0,u=_);if(!i&&!s&&!c)throw new xa("A suitable private key was not found for this certificate");let f;if(!r){try{f=oN(o)}catch(_){ft.error(_)}if(f==null)throw new xa("Error extracting certificate common name, please provide a name parameter")}let d=Hie(r??f);s&&!c&&!l&&(await Nn.writeFile(or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME,d+".pem"),s),Ba.set(d,s));let p={name:r??f,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(p.private_key_name=u??d+".pem"),await cd(p),"Successfully added certificate: "+d}a(Bie,"addCertificate");function Hie(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(Hie,"sanitizeName");async function kie(e){let t=eN(e,ui.object({name:ui.string().required()}));if(t)throw new xa(t.message);let{name:r}=e;Ha();let n=await Ur.get(r);if(!n)throw new xa(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Ur.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(ft.info("Removing private key named",s),await Nn.remove(or.join(Ns.getHdbBasePath(),ws.LICENSE_KEY_DIR_NAME,s)))}return await Ur.delete(r),"Successfully removed "+r}a(kie,"removeCertificate");function oN(e){return e.subject.match(/CN=(.*)/)?.[1]}a(oN,"extractCommonName");function pF(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):[oN(e)]}a(pF,"hostnamesFromCert");async function Fie(e){if(e.bypass_auth!==!0)throw new xa("Unauthorized","401");let t=eN(e,ui.object({name:ui.string().required()}));if(t)throw new xa(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await zk()).privateKey;if(r===".jwtPublic")return(await zk()).publicKey;if(Ba.get(r))return Ba.get(e.name);throw new xa("Key not found")}a(Fie,"getKey")});var vF={};ve(vF,{CONFIRMATION_STATUS_POSITION:()=>MF,NodeReplicationConnection:()=>pp,OPERATION_REQUEST:()=>dN,RECEIVED_TIME_POSITION:()=>_N,RECEIVED_VERSION_POSITION:()=>fN,SENDING_TIME_POSITION:()=>Mg,createWebSocket:()=>Ug,database_subscriptions:()=>Fa,replicateOverWS:()=>hp,table_update_listeners:()=>hN});async function Ug(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Xe(),i;if(e.includes("wss://")){if(!cN){let l=(0,PF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),cN=u.secureContexts}if(i=cN.get(s),i&&de.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,LF.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=DF.createSecureContext({...i.options,ca:Array.from(pl)})),new IF.WebSocket(e,"harperdb-replication-v1",c)}function hp(e,t,r){let n=t.port||t.securePort,s=_l.pid%1e3+"-"+CF.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,f=t.databaseSubscriptions||Fa,d,p,_=!1,h=t.subscription;h?.then&&h.then(T=>h=T);let S=t.tables||u&&Je()[u];if(!r){de.error?.("No authorization provided"),dn(1008,"Unauthorized");return}let g=new Map,A=[],E=r.name;E&&t.connection&&(t.connection.nodeName=E);let R,N,v,k,F,K,re,ae=1e3,Z,se=0,W=0,he=0,Te=new Map,Ce=[],me=0,Xt;if(t.url){let T=a(()=>{F&&W===e._socket?.bytesRead&&he===e._socket?.bytesWritten?e.terminate():(F=performance.now(),e.ping(),W=e._socket?.bytesRead,he=e._socket?.bytesWritten)},"send_ping");v=setInterval(T,OF).unref(),T()}else ct();e._socket?.setMaxListeners(200);function ct(){clearTimeout(k),W=e._socket?.bytesRead,he=e._socket?.bytesWritten,k=setTimeout(()=>{W===e._socket?.bytesRead&&he===e._socket?.bytesWritten&&(de.warn?.(`Timeout waiting for ping from ${E}, terminating connection and reconnecting`),e.terminate())},OF*2).unref()}a(ct,"resetPingTimer");function yr(){return p||(p=Rg(d,u,E)),p}a(yr,"getSharedStatus"),u&&oa(u);let gs,Bn,su=[],iu=[],xA,BA=[],Dt=[],mf=[],jh=150,Qh=25,Ef=0,Jh=0,De=!1,gf,un,Ir,ou;e.on("message",T=>{se=performance.now();try{let O=T.dataView=new hl(T.buffer,T.byteOffset,T.byteLength);if(T[0]>127){let b=(0,je.decode)(T),[U,L,P]=b;switch(U){case EF:{if(L){if(E){if(E!==L){de.error?.(s,`Node name mismatch, expecting to connect to ${E}, but peer reported name as ${L}, disconnecting`),e.send((0,je.encode)([ld])),dn(1008,"Node name mismatch");return}}else if(E=L,t.connection?.tentativeNode){let ue=t.connection.tentativeNode;ue.name=E,t.connection.tentativeNode=null,Io(E,ue)}if(t.connection&&(t.connection.nodeName=E),de.debug?.(s,"received node name:",E,"db:",u),!u)try{oa(u=b[2]),u==="system"&&(gs=Ma(t,(ue,te)=>{cu(te)&&aa(te)}),e.on("close",()=>{gs?.remove()}))}catch(ue){de.warn?.(s,"Error setting database",ue),e.send((0,je.encode)([ld])),dn(1008,ue.message);return}Gr()}break}case yF:{de.debug?.(s,"Received table definitions for",L.map(ue=>ue.table));for(let ue of L){let te=b[2];ue.database=te;let fe;cu(te)&&(te==="system"?$e[te]?.[ue.table]||(fe=lN(ue,$e[te]?.[ue.table])):fe=lN(ue,$e[te]?.[ue.table]),d||(d=fe?.auditStore),S||(S=Je()?.[te]))}break}case ld:dn();break;case dN:try{let ue=r?.replicates||r?.subscribers||r?.name;server.operation(L,{user:r},!ue).then(te=>{Array.isArray(te)&&(te={results:te}),te.requestId=L.requestId,e.send((0,je.encode)([Pg,te]))},te=>{e.send((0,je.encode)([Pg,{requestId:L.requestId,error:te instanceof Error?te.toString():te}]))})}catch(ue){e.send((0,je.encode)([Pg,{requestId:L.requestId,error:ue instanceof Error?ue.toString():ue}]))}break;case Pg:let{resolve:H,reject:$}=g.get(L.requestId);L.error?$(new Error(L.error)):H(L),g.delete(L.requestId);break;case aN:let j=b[3];S||(u?de.error?.(s,"No tables found for",u):de.error?.(s,"Database name never received"));let Q=S[j];Q=lN({table:j,database:u,attributes:L.attributes,schemaDefined:L.schemaDefined},Q),su[P]={name:j,decoder:new je.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:L.typedStructs,structures:L.structures}),getEntry(ue){return Q.primaryStore.getEntry(ue)},rootStore:Q.primaryStore.rootStore};break;case gF:ou=d?Bk(L,d):new Map,xA=b[2],de.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${xA}`);break;case SF:let q=P;mf[q]=L;break;case RF:yr()[MF]=L,de.trace?.(s,"received and broadcasting committed update",L),yr().buffer.notify();break;case AF:R=L,h.send({type:"end_txn",localTime:R,remoteNodeIds:A});break;case Dg:{let ue=b[1],{fileId:te,size:fe,finished:ie,error:J}=ue,le=Te.get(te);de.debug?.("Received blob",te,"has stream",!!le,"connectedToBlob",!!le?.connectedToBlob,"length",b[2].length,"finished",ie),le||(le=new uN.PassThrough,le.expectedSize=fe,Te.set(te,le)),le.lastChunk=Date.now(),ie?(J?(le.on("error",()=>{}),le.destroy(new Error("Blob error: "+J))):le.end(b[2]),le.connectedToBlob&&Te.delete(te)):le.write(b[2]);break}case TF:{let ue=L,te;try{let fe=b[3],ie=iu[P]||(iu[P]=S[b[4]]);if(!ie)return de.warn?.("Unknown table id trying to handle record request",P);let J=ie.primaryStore.getBinaryFast(Symbol.for("structures")),le=J.length;if(le!==Jh){Jh=le;let Re=(0,je.decode)(J);e.send((0,je.encode)([aN,{typedStructs:Re.typed,structures:Re.named},P,ie.tableName]))}let ye=ie.primaryStore.getBinaryFast(fe);if(ye){let Re=ie.primaryStore.decoder.decode(ye,{valueAsBuffer:!0});te=(0,je.encode)([Cg,ue,{value:Re.value,expiresAt:Re.expiresAt,version:Re.version,residencyId:Re.residencyId,nodeId:Re.nodeId,user:Re.user}])}else te=(0,je.encode)([Cg,ue])}catch(fe){te=(0,je.encode)([Cg,ue,{error:fe.message}])}e.send(te);break}case Cg:{let{resolve:ue,reject:te,tableId:fe,key:ie}=g.get(b[1]),J=b[2];if(J?.error)te(new Error(J.error));else if(J){let le=su[fe].decoder.decode(J.value);J.value=le,J.key=ie,ue(J)}else ue();g.delete(b[1]);break}case mF:{Ir=L;let ue,te,fe=!1;if(h){if(u!==h.databaseName&&!h.then){de.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=f.get(u);if(de.debug?.(s,"received subscription request for",u,"at",Ir),!h){let Ae;h=new Promise(et=>{de.debug?.("Waiting for subscription to database "+u),Ae=et}),h.ready=Ae,Fa.set(u,h)}if(r.name)te=gr().subscribe(r.name),te.then(async Ae=>{ue=Ae;for await(let et of ue){let Lt=et.value;if(!(Lt?.replicates===!0||Lt?.replicates?.receives||Lt?.subscriptions?.some(pr=>(pr.database||pr.schema)===u&&pr.publish!==!1))){fe=!0,e.send((0,je.encode)([ld])),dn(1008,`Unauthorized database subscription to ${u}`);return}}},Ae=>{de.error?.(s,"Error subscribing to HDB nodes",Ae)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,je.encode)([ld])),dn(1008,`Unauthorized database subscription to ${u}`);return}if(un&&(de.debug?.(s,"stopping previous subscription",u),un.emit("close")),Ir.length===0)return;let ie=Ir[0],J=a(Ae=>{if(Ae&&(ie.replicateByDefault?!ie.tables.includes(Ae.tableName):ie.tables.includes(Ae.tableName)))return{table:Ae}},"tableToTableEntry"),le={txnTime:0},ye,Re,Be=1/0,it,Cr=a((Ae,et)=>{if(Ae.type==="end_txn"){le.txnTime&&(o[i]!==66&&de.error?.("Invalid encoding of message"),lu(9),lu(vg),z(it=et),qr()),i=c,le.txnTime=0;return}let Lt=Ae.nodeId,pr=Ae.tableId,qt=Re[pr];if(!qt&&(qt=Re[pr]=J(h.tableById[pr]),!qt))return de.debug?.("Not subscribed to table",pr);let $r=qt.table,Tc=$r.primaryStore,Mt=Tc.encoder;(Ae.extendedType&zm||!Mt.typedStructs)&&(Mt._mergeStructures(Mt.getStructures()),Mt.typedStructs&&(Mt.lastTypedStructuresLength=Mt.typedStructs.length));let Zh=ye[Lt];if(!(Zh&&Zh.startTime<et&&(!Zh.endTime||Zh.endTime>et)))return Lg&&de.trace?.(s,"skipping replication update",Ae.recordId,"to:",E,"from:",Lt,"subscribed:",ye),tD();Lg&&de.trace?.(s,"sending replication update",Ae.recordId,"to:",E,"from:",Lt,"subscribed:",ye);let HA=Ae.version;le.txnTime!==HA&&(le.txnTime&&(Lg&&de.trace?.(s,"new txn time, sending queued txn",le.txnTime),o[i]!==66&&de.error?.("Invalid encoding of message"),qr()),le.txnTime=HA,i=c,z(HA));let Ac=Ae.residencyId,kA=au(Ac,$r),em;if(kA&&!kA.includes(E)){let Rc=au(Ae.previousResidencyId,$r);if(Rc&&!Rc.includes(E)&&(Ae.type==="put"||Ae.type==="patch")||$r.getResidencyById)return tD();let Af=Ae.recordId;de.trace?.(s,"sending invalidation",Af,E,"from",Lt);let la=0;Ac&&(la|=xc),Ae.previousResidencyId&&(la|=Bc);let Ws,fn=null;for(let tm in $r.indices){if(!fn){if(Ws=Ae.getValue(Tc,!0),!Ws)break;fn={}}fn[tm]=Ws[tm]}em=bu(Ae.version,pr,Af,null,Lt,Ae.user,Ae.type==="put"||Ae.type==="patch"?"invalidate":Ae.type,Mt.encode(fn),la,Ac,Ae.previousResidencyId,Ae.expiresAt)}function tD(){de.trace?.(s,"skipping audit record",Ae.recordId),K||(K=setTimeout(()=>{K=null,(it||0)+bF/2<Be&&(Lg&&de.trace?.(s,"sending skipped sequence update",Be),e.send((0,je.encode)([AF,Be])))},bF).unref())}a(tD,"skipAuditRecord");let FA=Mt.typedStructs,GA=Mt.structures;if((FA?.length!=qt.typed_length||GA?.length!=qt.structure_length)&&(qt.typed_length=FA?.length,qt.structure_length=GA.length,de.debug?.(s,"send table struct",qt.typed_length,qt.structure_length),qt.sentName||(qt.sentName=!0),e.send((0,je.encode)([aN,{typedStructs:FA,structures:GA,attributes:$r.attributes,schemaDefined:$r.schemaDefined},pr,qt.table.tableName]))),Ac&&!Dt[Ac]&&(e.send((0,je.encode)([SF,kA,Ac])),Dt[Ac]=!0),em)lu(em.length),uu(em);else{let Rc=Ae.encoded;Ae.extendedType&$n&&IR(()=>Ae.getValue(Tc),async la=>{let Ws=Bm(la);try{let fn;me++;for await(let tm of la.stream()){if(fn&&(de.debug?.("Sending blob chunk",Ws,"length",fn.length),e.send((0,je.encode)([Dg,{fileId:Ws,size:la.size},fn]))),fn=tm,fe)return;e._socket.writableNeedDrain&&(de.debug?.("draining",Ws),await new Promise(SJ=>e._socket.once("drain",SJ)),de.debug?.("drained",Ws))}de.debug?.("Sending final blob chunk",Ws,"length",fn.length),e.send((0,je.encode)([Dg,{fileId:Ws,size:la.size,finished:!0},fn]))}catch(fn){de.debug?.("Error sending blob",fn),e.send((0,je.encode)([Dg,{fileId:Ws,finished:!0,error:fn.toString()},Buffer.alloc(0)]))}finally{me--,me<Qh&&Xt?.()}});let Af=Rc[0]===66?8:0;lu(Rc.length-Af),uu(Rc,Af),de.trace?.("wrote record",Ae.recordId,"length:",Rc.length)}},"sendAuditRecord"),qr=a(()=>{c-i>8?(e.send(o.subarray(i,c)),de.debug?.(s,"Sent message, size:",c-i)):de.debug?.(s,"skipping empty transaction")},"sendQueuedData");un=new pN.EventEmitter,un.once("close",()=>{fe=!0,ue?.end()});for(let{startTime:Ae}of Ir)Ae<Be&&(Be=Ae);(te||Promise.resolve()).then(async()=>{h=await h,d=h.auditStore,Re=h.tableById.map(J),ye=[];for(let{name:et,startTime:Lt,endTime:pr}of Ir){let qt=Ag(et,d);de.debug?.("subscription to",et,"using local id",qt,"starting",Lt),ye[qt]={startTime:Lt,endTime:pr}}aa(u),gs||(gs=ml(et=>{et.databaseName===u&&aa(u)}),Bn=mp(et=>{et===u&&(e.send((0,je.encode)([ld])),dn())}),e.on("close",()=>{gs?.remove(),Bn?.remove()})),e.send((0,je.encode)([gF,ap(h.auditStore),Ir.map(({name:et})=>et)]));let Ae=!0;do{isFinite(Be)||(de.warn?.("Invalid sequence id "+Be),dn(1008,"Invalid sequence id"+Be));let et;if(Ae&&!fe&&(Ae=!1,!(EN(d)<=Be)&&(wF.default.get(x.REPLICATION_COPYTABLESTOCATCHUP)??Gie)&&server.nodes[0]?.name===E)){de.info?.("Replicating all tables to",E);let pr=Be,qt=xg(d);for(let $r in S){if(!J($r))continue;let Tc=S[$r];for(let Mt of Tc.primaryStore.getRange({snapshot:!1})){if(fe)return;Mt.localTime>=Be&&(de.trace?.(s,"Copying record from",u,$r,Mt.key,Mt.localTime),pr=Math.max(Mt.localTime,pr),et=!0,yr()[Mg]=1,Cr({recordId:Mt.key,tableId:Tc.tableId,type:"put",getValue(){return Mt.value},encoded:Tc.primaryStore.getBinary(Mt.key),version:Mt.version,residencyId:Mt.residencyId,nodeId:qt,extendedType:Mt.metadataFlags},Mt.localTime))}}Be=pr}for(let{key:Lt,value:pr}of d.getRange({start:Be||1,exclusiveStart:!0,snapshot:!1})){if(fe)return;let qt=Nt(pr);de.debug?.("sending audit record",new Date(Lt)),yr()[Mg]=Lt,Be=Lt,Cr(qt,Lt),e._socket.writableNeedDrain?await new Promise($r=>{de.debug?.(`Waiting for remote node ${E} to allow more commits ${e._socket.writableNeedDrain?"due to network backlog":"due to requested flow directive"}`),e._socket.once("drain",$r)}):me>Qh?await new Promise($r=>{Xt=$r}):await new Promise(setImmediate),un.startTime=Lt,et=!0}et&&Cr({type:"end_txn"},Be),yr()[Mg]=0,await UF(d)}while(!fe)}).catch(Ae=>{de.error?.(s,"Error handling subscription to node",Ae),dn(1008,"Error handling subscription to node")});break}}return}O.position=8;let w=!0,y,D;do{yr();let b=O.readInt();if(b===9&&O.getUint8(O.position)==vg){O.position++,R=D=O.readFloat64(),p[fN]=R,p[_N]=Date.now(),de.trace?.("received remote sequence update",R,u);break}let U=O.position,L=Nt(T,U,U+b),P=su[L.tableId];P||de.error?.(`No table found with an id of ${L.tableId}`);let H;L.residencyId&&(H=mf[L.residencyId],de.trace?.(s,"received residency list",H,L.type,L.recordId));try{wR(()=>{y={table:P.name,id:L.recordId,type:L.type,nodeId:ou.get(L.nodeId),residencyList:H,timestamp:L.version,value:L.getValue(P),user:L.user,beginTxn:w,expiresAt:L.expiresAt}},$=>{let j=Bm($),Q=Te.get(j);de.debug?.("Received transaction with blob",j,"has stream",!!Q,"ended",!!Q?.writableEnded),Q?Q.writableEnded&&Te.delete(j):(Q=new uN.PassThrough,Te.set(j,Q)),Q.connectedToBlob=!0,Q.lastChunk=Date.now(),$.size===void 0&&Q.expectedSize&&($.size=Q.expectedSize);let q=createBlob(Q,$),ue=q.save({primaryStore:h.auditStore});return ue&&(ue.blobId=j,Ce.push(ue),ue.finally(()=>{de.debug?.(`Finished receiving blob stream ${j}`),Ce.splice(Ce.indexOf(ue),1)})),q})}catch($){throw $.message+="typed structures for current decoder"+JSON.stringify(P.decoder.typedStructs),$}w=!1,de.trace?.(s,"received replication message",L.type,"id",y.id,"version",new Date(L.version),"nodeId",y.nodeId),p[fN]=L.version,p[_N]=Date.now(),h.send(y),O.position=U+b}while(O.position<T.byteLength);Ef++,sr(T.byteLength,"bytes-received",`${E}.${u}.${y?.table||"unknown_table"}`,"replication","ingest"),Ef>jh&&!De&&(De=!0,e.pause(),de.debug?.(`Commit backlog causing replication back-pressure, requesting that ${E} pause replication`)),h.send({type:"end_txn",localTime:R,remoteNodeIds:A,async onCommit(){if(y){let b=Date.now()-y.timestamp;sr(b,"replication-latency",E+"."+u+"."+y.table,y.type,"ingest")}Ef--,De&&(De=!1,e.resume(),de.debug?.(`Replication resuming ${E}`)),Ce.length>0&&await Promise.all(Ce),de.trace?.("All blobs finished"),!N&&D&&(de.trace?.(s,"queuing confirmation of a commit at",D),setTimeout(()=>{e.send((0,je.encode)([RF,N])),de.trace?.(s,"sent confirmation of a commit at",N),N=null},qie)),N=D,de.debug?.("last sequence committed",new Date(D),u)}})}catch(O){de.error?.(s,"Error handling incoming replication message",O)}}),e.on("ping",ct),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-F,dl({name:E,database:u,url:t.url,latency:t.connection.latency})),F=null}),e.on("close",(T,O)=>{clearInterval(v),clearTimeout(k),clearInterval(re),un&&un.emit("close"),gf&&gf.end();for(let[w,{reject:y}]of g)y(new Error(`Connection closed ${O?.toString()} ${T}`));de.debug?.(s,"closed",T,O?.toString())});function Sf(){}a(Sf,"recordRemoteNodeSequence");function dn(T,O){e.isFinished=!0,e.close(T,O)}a(dn,"close");function Gr(){if(_||(_=!0,t.connection?.on("subscriptions-updated",Gr)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let T=new Map;try{for(let y of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let D of y.value.nodes||[])D.lastTxnTime>(T.get(D.id)??0)&&T.set(D.id,D.lastTxnTime)}catch(y){if(!y.message.includes("Can not re"))throw y}let O=t.connection?.nodeSubscriptions?.[0];A=[];let w=t.connection?.nodeSubscriptions.map((y,D)=>{let b=[],{replicateByDefault:U}=y;if(y.subscriptions){for(let $ of y.subscriptions)if($.subscribe&&($.schema||$.database)===u){let j=$.table;S?.[j]?.replicate!==!1&&b.push(j)}U=!1}else for(let $ in S)(U?S[$].replicate===!1:S[$].replicate)&&b.push($);let L=d&&Ag(y.name,d),P=h?.dbisDB?.get([Symbol.for("seq"),L])??1,H=Math.max(P?.seqId??1,(typeof y.start_time=="string"?new Date(y.start_time).getTime():y.start_time)??1);if(de.debug?.("Starting time recorded in db",y.name,L,u,P?.seqId,"start time:",H,new Date(H)),O!==y){let $=d&&Ag(O.name,d),j=h?.dbisDB?.get([Symbol.for("seq"),$])??1;for(let Q of j?.nodes||[])Q.name===y.name&&(H=Q.seqId,de.debug?.("Using sequence id from proxy node",O.name,H))}return A.push(L),T.get(L)>H&&(H=T.get(L),de.debug?.("Updating start time from more recent txn recorded",O.name,H)),{name:y.name,replicateByDefault:U,tables:b,startTime:H,endTime:y.end_time}});if(w)if(de.debug?.(s,"sending subscription request",w,h?.dbisDB?.path),clearTimeout(Z),w.length>0)e.send((0,je.encode)([mF,w]));else{let y=a(()=>{let D=performance.now();Z=setTimeout(()=>{se<=D?dn(1008,"No nodes to subscribe to"):y()},ae)},"schedule_close");y()}}a(Gr,"sendSubscriptionRequestUpdate");function au(T,O){if(!T)return;let w=BA[T];return w||(w=O.getResidencyRecord(T),BA[T]=w),w}a(au,"getResidence");function cu(T){return!(ka&&ka!="*"&&!ka[T]&&!ka.includes?.(T)&&!ka.some?.(O=>O.name===T))}a(cu,"checkDatabaseAccess");function oa(T){if(h=h||f.get(T),!cu(T))throw new Error(`Access to database "${T}" is not permitted`);h||de.warn?.(`No database named "${T}" was declared and registered`),d=h?.auditStore,S||(S=Je()?.[T]);let O=Xe();if(O===E)throw O?new Error("Should not connect to self",O):new Error("Node name not defined");return Xh(O,T),!0}a(oa,"setDatabase");function Xh(T,O){let w=Je()?.[O],y=[];for(let D in w){let b=w[D];y.push({table:D,schemaDefined:b.schemaDefined,attributes:b.attributes.map(U=>({name:U.name,type:U.type,isPrimaryKey:U.isPrimaryKey}))})}de.trace?.("Sending database info for node",T,"database name",O),e.send((0,je.encode)([EF,T,O,y]))}a(Xh,"sendNodeDBName");function aa(T){let O=Je()?.[T],w=[];for(let y in O){if(Ir&&!Ir.some(b=>b.replicateByDefault?!b.tables.includes(y):b.tables.includes(y)))continue;let D=O[y];w.push({table:y,schemaDefined:D.schemaDefined,attributes:D.attributes.map(b=>({name:b.name,type:b.type,isPrimaryKey:b.isPrimaryKey}))})}e.send((0,je.encode)([yF,w,T]))}a(aa,"sendDBSchema"),re=setInterval(()=>{for(let[T,O]of Te)O.lastChunk+3e4<Date.now()&&(de.warn?.(`Timeout waiting for blob stream to finish ${T} from ${E}`),Te.delete(T),O.end())},3e4).unref();let ca=1,Tf=[];return{end(){gf&&gf.end(),un&&un.emit("close")},getRecord(T){let O=ca++;return new Promise((w,y)=>{let D=[TF,O,T.table.tableId,T.id];Tf[T.table.tableId]||(D.push(T.table.tableName),Tf[T.table.tableId]=!0),e.send((0,je.encode)(D)),g.set(O,{tableId:T.table.tableId,key:T.id,resolve(b){let{table:U,entry:L}=T;w(b),b&&U._recordRelocate(L,b)},reject:y})})},sendOperation(T){let O=ca++;return T.requestId=O,e.send((0,je.encode)([dN,T])),new Promise((w,y)=>{g.set(O,{resolve:w,reject:y})})}};function lu(T){m(5),T<128?o[c++]=T:T<16384?(l.setUint16(c,T|32768),c+=2):T<1056964608?(l.setUint32(c,T|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,T),c+=5)}function uu(T,O=0,w=T.length){let y=w-O;m(y),T.copy(o,c,O,w),c+=y}function z(T){m(8),l.setFloat64(c,T),c+=8}function m(T){if(T+16>o.length-c){let O=Buffer.allocUnsafeSlow(c+T-i+65536>>10<<11);o.copy(O,0,i,c),c=c-i,i=0,o=O,l=new DataView(o.buffer,0,o.length)}}}function lN(e,t){let r=e.database??"data";if(r!=="data"&&!$e[r]){de.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?(de.debug?.("(Re)creating",e),lt({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var wF,je,IF,CF,de,pN,PF,DF,_l,LF,uN,mF,EF,gF,ld,SF,aN,TF,Cg,dN,Pg,AF,RF,yF,Dg,MF,fN,_N,Mg,Gie,hN,Fa,Lg,bF,qie,OF,cN,NF,pp,mN=be(()=>{Pe();ho();KO();gN();ts();wF=M(ce());B();Ou();je=require("msgpackr"),IF=require("ws"),CF=require("worker_threads"),de=M(Ci());dp();pN=require("events"),PF=M(rs()),DF=M(require("node:tls"));ul();_l=M(require("node:process")),LF=require("node:net");$i();As();uN=require("node:stream"),mF=129,EF=140,gF=141,ld=142,SF=130,aN=132,TF=133,Cg=134,dN=136,Pg=137,AF=143,RF=144,yF=145,Dg=146,MF=0,fN=1,_N=2,Mg=3,Gie=_l.env.HDB_LEADER_URL||_l.argv.includes("--HDB_LEADER_URL"),hN=new Map,Fa=new Map,Lg=!0,bF=300,qie=2,OF=3e4;a(Ug,"createWebSocket");NF=1e3,pp=class extends pN.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??li(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=NF;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await Ug(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;de.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${_l.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),de[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=NF,dl({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=hp(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(de.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"?de.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`):de.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(id({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();de.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(hp,"replicateOverWS");a(lN,"ensureTableIfChanged")});var Po={};ve(Po,{clearThisNodeName:()=>Qie,disableReplication:()=>Yie,enabled_databases:()=>ka,forEachReplicatedDatabase:()=>Ma,getThisNodeId:()=>xg,getThisNodeName:()=>Xe,getThisNodeUrl:()=>va,hostnameToUrl:()=>Fg,lastTimeInAuditStore:()=>cp,monitorNodeCAs:()=>$F,replicateOperation:()=>Xie,replication_certificate_authorities:()=>pl,sendOperationToNode:()=>gp,servers:()=>Vie,setReplicator:()=>KF,start:()=>Kie,startOnMainThread:()=>zO,subscribeToNode:()=>sd,unsubscribeFromNode:()=>Og,urlToNodeName:()=>li});function Kie(e){if(e.port||(e.port=Is.default.get(x.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=Is.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),!Xe())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of up(e))t.set(li(n.url),n);Wie(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=We.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),hp(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&ar.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,We.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&ar.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=gr().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));if(c)if(c?.revoked_certificates?.includes(n.peerCertificate.serialNumber)){ar.warn("Revoked certificate used in attempt to connect to node",c.name,"certificate serial number",n.peerCertificate.serialNumber);return}else n.user=c;else ar.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:ar.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(pl);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.updatedContext=kg.createSecureContext(l)}catch(c){ar.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),$F(s),Is.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function $F(e){let t=0;rd(r=>{r?.ca&&(pl.add(r.ca),pl.size!==t&&(t=pl.size,e?.()))})}function Yie(e=!0){qF=e}function Wie(e){qF||(Je(),ka=e.databases,Ma(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Fa;for(let[s,i]of Ep){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];KF(r,s,e),hN.get(s)?.forEach(i=>i(s))}}))}function KF(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 VF extends Vr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Fa,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(ar.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new kn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let f;for(let p of c){let _=zie(p,VF.subscription,e);_?.isConnected&&!u.has(_)&&(!f||_.latency<f.latency)&&(f=_)}if(!f)throw l||new FF.ServerError("No connection to any other nodes are available",502);let d={requestId:$ie++,table:t,entry:i,id:i.key};u.add(f);try{return await f.getRecord(d)}catch(p){if(f.isConnected)throw p;ar.warn("Error in load from node",Hg,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function YF(e,t,r,n,s){let i=Ep.get(e);i||Ep.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new pp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function zie(e,t,r){let n=xF.get(e)?.get(r);if(n)return n;let s=gr().primaryStore.get(e);return s?.url&&(n=YF(s.url,t,r,e,s.authorization),xF.set(e,Ep.get(s.url))),n}async function gp(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ug(e.url,r),s=hp(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{ar.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function sd(e){try{GF.isMainThread&&ar.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Fa.get(e.database);if(!t){let n;t=new Promise(s=>{ar.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Fa.set(e.database,t)}let r=YF(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>lp(n,e.database)),e.replicateByDefault)}catch(t){ar.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Og({name:e,url:t,database:r}){ar.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(gr().primaryStore.getRange({})));let n=Ep.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function jie(){if(SN!==void 0)return SN;let e=Is.default.get(x.OPERATIONSAPI_TLS_CERTIFICATE)||Is.default.get(x.TLS_CERTIFICATE);if(e)return SN=new HF.X509Certificate((0,kF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Xe(){return Hg||(Hg=Is.default.get("replication_hostname")??li(Is.default.get("replication_url"))??jie()??BF("operationsapi_network_secureport")??BF("operationsapi_network_port")??"127.0.0.1")}function Qie(){Hg=void 0}function BF(e){let t=Is.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Bg(e){let t=Is.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function xg(e){return ap(e)?.[Xe()]}function va(){let e=Is.default.get("replication_url");return e||Fg(Xe())}function Fg(e){let t=Bg("replication_port");if(t)return`ws://${e}:${t}`;if(t=Bg("replication_secureport"),t)return`wss://${e}:${t}`;if(t=Bg("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=Bg("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function li(e){if(e)return new URL(e).hostname}function Ma(e,t){for(let n of Object.getOwnPropertyNames($e))r(n);return mp(n=>{r(n)}),ml((n,s)=>{r(n.databaseName)});function r(n){let s=$e[n];ar.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):Jie(n)&&t(s,n,!1)}a(r,"forDatabase")}function Jie(e){let t=$e[e];for(let r in t)if(t[r].replicate)return!0}function cp(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function Xie(e){let t={message:""};if(e.replicated){e.replicated=!1,ar.trace?.("Replicating operation",e.operation,"to nodes",We.nodes.map(n=>n.name));let r=await Promise.allSettled(We.nodes.map(n=>gp(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=We.nodes[s]?.name,i})}return t}var Is,ar,HF,kF,kg,FF,GF,qF,$ie,Vie,pl,ka,Ep,xF,SN,Hg,ts=be(()=>{Pe();ga();_u();mN();Kr();Is=M(ce()),ar=M(Y()),HF=require("crypto"),kF=require("fs");dp();ul();B();KO();kg=M(require("node:tls")),FF=M(pe()),GF=require("worker_threads"),$ie=1,Vie=[],pl=Is.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1?new Set(kg.rootCertificates):new Set;a(Kie,"start");a($F,"monitorNodeCAs");a(Yie,"disableReplication");a(Wie,"assignReplicationSource");a(KF,"setReplicator");Ep=new Map;a(YF,"getConnection");xF=new Map;a(zie,"getConnectionByName");a(gp,"sendOperationToNode");a(sd,"subscribeToNode");a(Og,"unsubscribeFromNode");a(jie,"getCommonNameFromCert");a(Xe,"getThisNodeName");a(Qie,"clearThisNodeName");Object.defineProperty(We,"hostname",{get(){return Xe()}});a(BF,"getHostFromListeningPort");a(Bg,"getPortFromListeningPort");a(xg,"getThisNodeId");We.replication={getThisNodeId:xg,exportIdMapping:ap};a(va,"getThisNodeUrl");a(Fg,"hostnameToUrl");a(li,"urlToNodeName");a(Ma,"forEachReplicatedDatabase");a(Jie,"hasExplicitlyReplicatedTable");a(cp,"lastTimeInAuditStore");a(Xie,"replicateOperation")});var Vg=I((lDe,JF)=>{"use strict";var ud=nE(),dd=ok(),Zie=Y(),eoe=require("uuid").v4,cDe=require("clone"),qg=yo(),fd=(B(),C(G)),toe=require("util"),Ga=Wn(),{handleHDBError:wn,hdb_errors:roe}=pe(),{HDB_ERROR_MSGS:Gg,HTTP_STATUS_CODES:In}=roe,{SchemaEventMsg:$g}=si(),WF=ir(),{getDatabases:noe}=(Pe(),C(rt)),{transformReq:_d}=oe(),{replicateOperation:zF}=(ts(),C(Po));JF.exports={createSchema:soe,createSchemaStructure:jF,createTable:ioe,createTableStructure:QF,createAttribute:uoe,dropSchema:ooe,dropTable:aoe,dropAttribute:coe,getBackup:doe};async function soe(e){let t=await jF(e);return qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),t}a(soe,"createSchema");async function jF(e){let t=ud.schema_object(e);if(t)throw wn(t,t.message,In.BAD_REQUEST,void 0,void 0,!0);if(_d(e),!await dd.checkSchemaExists(e.schema))throw wn(new Error,Gg.SCHEMA_EXISTS_ERR(e.schema),In.BAD_REQUEST,fd.LOG_LEVELS.ERROR,Gg.SCHEMA_EXISTS_ERR(e.schema),!0);return await Ga.createSchema(e),`database '${e.schema}' successfully created`}a(jF,"createSchemaStructure");async function ioe(e){return _d(e),e.hash_attribute=e.primary_key??e.hash_attribute,await QF(e)}a(ioe,"createTable");async function QF(e){let t=ud.create_table_object(e);if(t)throw wn(t,t.message,In.BAD_REQUEST,void 0,void 0,!0);if(ud.validateTableResidence(e.residence),!await dd.checkSchemaTableExists(e.schema,e.table))throw wn(new Error,Gg.TABLE_EXISTS_ERR(e.schema,e.table),In.BAD_REQUEST,fd.LOG_LEVELS.ERROR,Gg.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:eoe(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await Ga.createTable(n,e);else throw wn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",In.BAD_REQUEST);else await Ga.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(QF,"createTableStructure");async function ooe(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=ud.schema_object(e),n=t??r;if(n)throw wn(n,n.message,In.BAD_REQUEST,void 0,void 0,!0);_d(e);let s=await dd.checkSchemaExists(e.schema);if(s)throw wn(new Error,s,In.NOT_FOUND,fd.LOG_LEVELS.ERROR,s,!0);let i=await dd.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await Ga.dropSchema(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),await WF.purgeSchemaTableStreams(e.schema,o);let c=await zF(e);return c.message=`successfully deleted '${e.schema}'`,c}a(ooe,"dropSchema");async function aoe(e){let t=ud.table_object(e);if(t)throw wn(t,t.message,In.BAD_REQUEST,void 0,void 0,!0);_d(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw wn(new Error,r,In.NOT_FOUND,fd.LOG_LEVELS.ERROR,r,!0);await Ga.dropTable(e),await WF.purgeTableStream(e.schema,e.table);let n=await zF(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(aoe,"dropTable");async function coe(e){let t=ud.attribute_object(e);if(t)throw wn(t,t.message,In.BAD_REQUEST,void 0,void 0,!0);_d(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw wn(new Error,r,In.NOT_FOUND,fd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw wn(new Error,"You cannot drop a hash attribute",In.BAD_REQUEST,void 0,void 0,!0);if(fd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw wn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,In.BAD_REQUEST,void 0,void 0,!0);try{return await Ga.dropAttribute(e),loe(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Zie.error(`Got an error deleting attribute ${toe.inspect(e)}.`),n}}a(coe,"dropAttribute");function loe(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(loe,"dropAttributeFromGlobal");async function uoe(e){_d(e);let t=noe()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw wn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,In.BAD_REQUEST,void 0,void 0,!0);return await Ga.createAttribute(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(uoe,"createAttribute");function doe(e){return Ga.getBackup(e)}a(doe,"getBackup")});var ZF=I((dDe,XF)=>{"use strict";var{OPERATIONS_ENUM:foe}=(B(),C(G)),TN=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=foe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};XF.exports=TN});var AN=I((pDe,sG)=>{"use strict";var _oe=Wn(),_De=ZF(),Kg=oe(),Yg=(B(),C(G)),poe=ce(),{handleHDBError:eG,hdb_errors:hoe}=pe(),{HDB_ERROR_MSGS:tG,HTTP_STATUS_CODES:rG}=hoe,moe=Object.values(Yg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),nG="To use this operation audit log must be enabled in harperdb-config.yaml";sG.exports=Eoe;async function Eoe(e){if(Kg.isEmpty(e.schema))throw new Error(tG.SCHEMA_REQUIRED_ERR);if(Kg.isEmpty(e.table))throw new Error(tG.TABLE_REQUIRED_ERR);if(!poe.get(Yg.CONFIG_PARAMS.LOGGING_AUDITLOG))throw eG(new Error,nG,rG.BAD_REQUEST,Yg.LOG_LEVELS.ERROR,nG,!0);let t=Kg.checkSchemaTableExist(e.schema,e.table);if(t)throw eG(new Error,t,rG.NOT_FOUND,Yg.LOG_LEVELS.ERROR,t,!0);if(!Kg.isEmpty(e.search_type)&&moe.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await _oe.readAuditLog(e)}a(Eoe,"readAuditLog")});var oG=I((mDe,iG)=>{"use strict";var{OPERATIONS_ENUM:goe}=(B(),C(G)),RN=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=goe.GET_BACKUP,this.schema=t,this.table=r}};iG.exports=RN});var lG=I((TDe,cG)=>{"use strict";var Soe=Wn(),gDe=oG(),yN=oe(),Toe=(B(),C(G)),SDe=ce(),{handleHDBError:Aoe,hdb_errors:Roe}=pe(),{HDB_ERROR_MSGS:aG,HTTP_STATUS_CODES:yoe}=Roe;cG.exports=boe;async function boe(e){if(yN.isEmpty(e.schema))throw new Error(aG.SCHEMA_REQUIRED_ERR);if(yN.isEmpty(e.table))throw new Error(aG.TABLE_REQUIRED_ERR);let t=yN.checkSchemaTableExist(e.schema,e.table);if(t)throw Aoe(new Error,t,yoe.NOT_FOUND,Toe.LOG_LEVELS.ERROR,t,!0);return await Soe.getBackup(read_audit_log_object)}a(boe,"getBackup")});var _G=I((RDe,fG)=>{"use strict";var Ooe=ce(),qa=require("joi"),Noe=ut(),uG=require("moment"),woe=require("fs-extra"),bN=require("path"),Ioe=require("lodash"),Sp=(B(),C(G)),{LOG_LEVELS:El}=(B(),C(G)),Coe="YYYY-MM-DD hh:mm:ss",Poe=bN.resolve(__dirname,"../logs");fG.exports=function(e){return Noe.validateBySchema(e,Doe)};var Doe=qa.object({from:qa.custom(dG),until:qa.custom(dG),level:qa.valid(El.NOTIFY,El.FATAL,El.ERROR,El.WARN,El.INFO,El.DEBUG,El.TRACE),order:qa.valid("asc","desc"),limit:qa.number().min(1),start:qa.number().min(0),log_name:qa.custom(Loe)});function dG(e,t){if(uG(e,uG.ISO_8601).format(Coe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(dG,"validateDatetime");function Loe(e,t){if(Ioe.invert(Sp.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Ooe.get(Sp.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Sp.LOG_NAMES.HDB:e,i=s===Sp.LOG_NAMES.INSTALL?bN.join(Poe,Sp.LOG_NAMES.INSTALL):bN.join(n,s);return woe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Loe,"validateReadLogPath")});var NN=I((bDe,hG)=>{"use strict";var Wg=(B(),C(G)),Moe=Y(),voe=ce(),Uoe=_G(),ON=require("path"),pG=require("fs-extra"),{once:xoe}=require("events"),{handleHDBError:Boe,hdb_errors:Hoe}=pe(),{PACKAGE_ROOT:koe}=nt(),Foe=ON.join(koe,"logs"),Goe=1e3,qoe=200;hG.exports=$oe;async function $oe(e){let t=Uoe(e);if(t)throw Boe(t,t.message,Hoe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=voe.get(Wg.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Wg.LOG_NAMES.HDB:e.log_name,s=n===Wg.LOG_NAMES.INSTALL?ON.join(Foe,Wg.LOG_NAMES.INSTALL):ON.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,f=u?new Date(e.until):void 0,d=e.limit===void 0?Goe:e.limit,p=e.order===void 0?void 0:e.order,_=e.start===void 0?0:e.start,h=_+d,S=0;p==="desc"&&!l&&!f&&(S=Math.max(pG.statSync(s).size-(h+5)*qoe,0));let g=pG.createReadStream(s,{start:S});g.on("error",k=>{Moe.error(k)});let A=0,E=[],R="",N;g.on("data",k=>{let F=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;k=R+k;let K=0,re;for(;(re=F.exec(k))&&!g.destroyed;){N&&(N.message=k.slice(K,re.index),v(N));let[ae,Z,se]=re,W=se.split("] ["),he=W[0],Te=W[1];W.splice(0,2),N={timestamp:Z,thread:he,level:Te,tags:W,message:""},K=re.index+ae.length}R=k.slice(K)}),g.on("end",k=>{g.destroyed||N&&(N.message=R.trim(),v(N))}),g.resume();function v(k){let F,K,re;switch(!0){case(i&&c&&u):F=new Date(k.timestamp),K=new Date(l),re=new Date(f),k.level===o&&F>=K&&F<=re&&A<_?A++:k.level===o&&F>=K&&F<=re&&($a(k,p,E),A++,A===h&&g.destroy());break;case(i&&c):F=new Date(k.timestamp),K=new Date(l),k.level===o&&F>=K&&A<_?A++:k.level===o&&F>=K&&($a(k,p,E),A++,A===h&&g.destroy());break;case(i&&u):F=new Date(k.timestamp),re=new Date(f),k.level===o&&F<=re&&A<_?A++:k.level===o&&F<=re&&($a(k,p,E),A++,A===h&&g.destroy());break;case(c&&u):F=new Date(k.timestamp),K=new Date(l),re=new Date(f),F>=K&&F<=re&&A<_?A++:F>=K&&F<=re&&($a(k,p,E),A++,A===h&&g.destroy());break;case i:k.level===o&&A<_?A++:k.level===o&&($a(k,p,E),A++,A===h&&g.destroy());break;case c:F=new Date(k.timestamp),K=new Date(l),F>=K&&A<_?A++:F>=K&&A>=_&&($a(k,p,E),A++,A===h&&g.destroy());break;case u:F=new Date(k.timestamp),re=new Date(f),F<=re&&A<_?A++:F<=re&&A>=_&&($a(k,p,E),A++,A===h&&g.destroy());break;default:A<_?A++:($a(k,p,E),A++,A===h&&g.destroy())}}return a(v,"onLogMessage"),await xoe(g,"close"),E}a($oe,"readLog");function $a(e,t,r){t==="desc"?Voe(e,r):t==="asc"?Koe(e,r):r.push(e)}a($a,"pushLineToResult");function Voe(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(Voe,"insertDescending");function Koe(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(Koe,"insertAscending")});var zg=I((PDe,SG)=>{"use strict";var wN=require("joi"),{string:pd,boolean:mG,date:Yoe}=wN.types(),Woe=ut(),{validateSchemaExists:NDe,validateTableExists:wDe,validateSchemaName:IDe}=vi(),zoe=(B(),C(G)),joe=St(),EG=ce();EG.initSync();var CDe=pd.invalid(EG.get(zoe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(joe.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),gG={operation:pd.valid("add_node","update_node","set_node_replication"),node_name:pd.optional(),subscriptions:wN.array().items({table:pd.optional(),schema:pd.optional(),database:pd.optional(),subscribe:mG.required(),publish:mG.required().custom(Joe),start_time:Yoe.iso()})};function Qoe(e){return Woe.validateBySchema(e,wN.object(gG))}a(Qoe,"addUpdateNodeValidator");function Joe(e,t){if(t.state.ancestors[2].operation==="add_node"&&e===!1&&t.state.ancestors[0].subscribe===!1)return t.message(`'subscriptions[${t.state.path[1]}]' subscribe and/or publish must be set to true when adding a node`)}a(Joe,"checkForFalsy");SG.exports={addUpdateNodeValidator:Qoe,validation_schema:gG}});var hd=I((LDe,TG)=>{"use strict";var IN=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},CN=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};TG.exports={Node:IN,NodeSubscription:CN}});var RG=I((vDe,AG)=>{"use strict";var Xoe=(B(),C(G)).OPERATIONS_ENUM,PN=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Xoe.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};AG.exports=PN});var Tp=I((xDe,yG)=>{"use strict";var DN=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},LN=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)}};yG.exports={RemotePayloadObject:DN,RemotePayloadSubscription:LN}});var OG=I((HDe,bG)=>{"use strict";var MN=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}};bG.exports=MN});var wG=I((VDe,NG)=>{"use strict";var Zoe=OG(),FDe=vt(),GDe=dt(),eae=Y(),{getSchemaPath:qDe,getTransactionAuditStorePath:$De}=Et(),{getDatabases:tae}=(Pe(),C(rt));NG.exports=rae;async function rae(e){let t=new Zoe;try{let r=tae()[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){eae.warn(`unable to stat table dbi due to ${r}`)}return t}a(rae,"lmdbGetTableSize")});var CG=I((YDe,IG)=>{"use strict";var vN=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}};IG.exports=vN});var Do=I((XDe,MG)=>{"use strict";var nae=require("fs-extra"),sae=require("path"),Zr=require("systeminformation"),Va=Y(),PG=ir(),zDe=St(),md=(B(),C(G)),iae=wG(),oae=Ao(),{getThreadInfo:DG}=tt(),Ap=ce();Ap.initSync();var aae=CG(),{openEnvironment:jDe}=dt(),{getSchemaPath:QDe}=Et(),{database:JDe,databases:UN}=(Pe(),C(rt)),jg;MG.exports={getHDBProcessInfo:kN,getNetworkInfo:GN,getDiskInfo:FN,getMemoryInfo:HN,getCPUInfo:BN,getTimeInfo:xN,getSystemInformation:qN,systemInformation:cae,getTableSize:$N,getMetrics:VN};function xN(){return Zr.time()}a(xN,"getTimeInfo");async function BN(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...f}=await Zr.cpu();f.cpu_speed=await Zr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:p,raw_currentload_irq:_,raw_currentload_nice:h,raw_currentload_system:S,raw_currentload_user:g,cpus:A,...E}=await Zr.currentLoad();return E.cpus=[],A.forEach(R=>{let{raw_load:N,raw_load_idle:v,raw_load_irq:k,raw_load_nice:F,raw_load_system:K,raw_load_user:re,...ae}=R;E.cpus.push(ae)}),f.current_load=E,f}catch(e){return Va.error(`error in getCPUInfo: ${e}`),{}}}a(BN,"getCPUInfo");async function HN(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Zr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return Va.error(`error in getMemoryInfo: ${e}`),{}}}a(HN,"getMemoryInfo");async function kN(){let e={core:[],clustering:[]};try{let t=await Zr.processes(),r;try{r=Number.parseInt(await nae.readFile(sae.join(Ap.get(md.CONFIG_PARAMS.ROOTPATH),md.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===md.NODE_ERROR_CODES.ENOENT)Va.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 Va.error(`error in getHDBProcessInfo: ${t}`),e}}a(kN,"getHDBProcessInfo");async function FN(){let e={};try{if(!Ap.get(md.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Zr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Zr.fsStats();return e.read_write=u,e.size=await Zr.fsSize(),e}catch(t){return Va.error(`error in getDiskInfo: ${t}`),e}}a(FN,"getDiskInfo");async function GN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Ap.get(md.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Zr.networkInterfaceDefault(),e.latency=await Zr.inetChecksite("google.com"),(await Zr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:f,carrier_changes:d,...p}=n;e.interfaces.push(p)}),(await Zr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return Va.error(`error in getNetworkInfo: ${t}`),e}}a(GN,"getNetworkInfo");async function qN(){if(jg!==void 0)return jg;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Zr.osInfo();e=c;let l=await Zr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,jg=e,jg}catch(t){return Va.error(`error in getSystemInformation: ${t}`),e}}a(qN,"getSystemInformation");async function $N(){let e=[],t=await oae.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await iae(n));return e}a($N,"getTableSize");async function VN(){let e={};for(let t in UN){let r=e[t]={},n=r.tables={};for(let s in UN[t])try{let i=UN[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,f,d]=l.trim().split(" ");return{pid:u,thread:f,txnid:d}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){Va.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(VN,"getMetrics");async function LG(){if(Ap.get(md.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await PG.getNATSReferences(),t=await PG.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(LG,"getNatsStreamInfo");async function cae(e){let t=new aae;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await qN(),t.time=xN(),t.cpu=await BN(),t.memory=await HN(),t.disk=await FN(),t.network=await GN(),t.harperdb_processes=await kN(),t.table_size=await $N(),t.metrics=await VN(),t.threads=await DG(),t.replication=await LG(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await qN();break;case"time":t.time=xN();break;case"cpu":t.cpu=await BN();break;case"memory":t.memory=await HN();break;case"disk":t.disk=await FN();break;case"network":t.network=await GN();break;case"harperdb_processes":t.harperdb_processes=await kN();break;case"table_size":t.table_size=await $N();break;case"database_metrics":case"metrics":t.metrics=await VN();break;case"threads":t.threads=await DG();break;case"replication":t.replication=await LG();break;default:break}return t}a(cae,"systemInformation")});var Lo=I((rLe,BG)=>{"use strict";var lae=yn(),KN=oe(),uae=require("util"),gl=(B(),C(G)),vG=ce();vG.initSync();var dae=bO(),UG=Wr(),{Node:eLe,NodeSubscription:tLe}=hd(),fae=Hu(),_ae=RG(),{RemotePayloadObject:pae,RemotePayloadSubscription:hae}=Tp(),{handleHDBError:mae,hdb_errors:Eae}=pe(),{HTTP_STATUS_CODES:gae,HDB_ERROR_MSGS:Sae}=Eae,Tae=ii(),Aae=Do(),{packageJson:Rae}=nt(),{getDatabases:yae}=(Pe(),C(rt)),bae=uae.promisify(dae.authorize),Oae=UG.searchByHash,Nae=UG.searchByValue;BG.exports={authHeaderToUser:wae,isEmpty:Iae,getNodeRecord:Cae,upsertNodeRecord:Pae,buildNodePayloads:Dae,checkClusteringEnabled:Lae,getAllNodeRecords:Mae,getSystemInfo:vae,reverseSubscription:xG};async function wae(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await bae(t,null),e}a(wae,"authHeaderToUser");function Iae(e){return e==null}a(Iae,"isEmpty");async function Cae(e){let t=new fae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Oae(t)}a(Cae,"getNodeRecord");async function Pae(e){let t=new _ae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return lae.upsert(t)}a(Pae,"upsertNodeRecord");function xG(e){if(KN.isEmpty(e.subscribe)||KN.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(xG,"reverseSubscription");function Dae(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,f=KN.getTableHashAttribute(l,u),{subscribe:d,publish:p}=xG(c),_=yae()[l]?.[u],h=new hae(l,u,f,p,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(h)}return new pae(r,t,s,n)}a(Dae,"buildNodePayloads");function Lae(){if(!vG.get(gl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw mae(new Error,Sae.CLUSTERING_NOT_ENABLED,gae.BAD_REQUEST,void 0,void 0,!0)}a(Lae,"checkClusteringEnabled");async function Mae(){let e=new Tae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Nae(e))}a(Mae,"getAllNodeRecords");async function vae(){let e=await Aae.getSystemInformation();return{hdb_version:Rae.version,node_version:e.node_version,platform:e.platform}}a(vae,"getSystemInfo")});var YN=I((sLe,KG)=>{"use strict";var Qg=ir(),HG=oe(),kG=St(),FG=(B(),C(G)),Jg=Y(),GG=Vg(),Uae=x_(),{RemotePayloadObject:xae}=Tp(),{handleHDBError:qG,hdb_errors:Bae}=pe(),{HTTP_STATUS_CODES:$G}=Bae,{NodeSubscription:VG}=hd();KG.exports=Hae;async function Hae(e,t){let r;try{r=await Qg.request(`${t}.${kG.REQUEST_SUFFIX}`,new xae(FG.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Jg.trace("Response from remote describe all request:",r)}catch(o){Jg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Qg.requestErrorHandler(o,"add_node",t);throw qG(new Error,c,$G.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===kG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw qG(new Error,o,$G.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===FG.SYSTEM_SCHEMA_NAME){await Qg.createLocalTableStream(l,c);let h=new VG(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=HG.doesSchemaExist(l),f=n[l]!==void 0,d=c?HG.doesTableExist(l,c):!0,p=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!f||!d&&!p){s.push(o);continue}if(!u&&f&&(Jg.trace(`addNode creating schema: ${l}`),await GG.createSchema({operation:"create_schema",schema:l})),!d&&p){Jg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Uae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await GG.createTable(h)}await Qg.createLocalTableStream(l,c);let _=new VG(l,c,o.publish,o.subscribe);_.start_time=o.start_time,i.push(_)}return{added:i,skipped:s}}a(Hae,"reviewSubscriptions")});var Tl={};ve(Tl,{addNodeBack:()=>$ae,removeNodeBack:()=>Vae,setNode:()=>qae});async function qae(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=li(t)):t=Fg(r);let n=(0,WG.validateBySchema)(e,Gae);if(n)throw(0,Mo.handleHDBError)(n,n.message,Fae.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Mo.ClientError("url or hostname is required for remove_node operation");let _=r,h=gr(),S=await h.get(_);if(!S)throw new Mo.ClientError(_+" does not exist");try{await gp({url:S.url},{operation:$t.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Xe():_},void 0)}catch(g){ns.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await h.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Mo.ClientError("url required for this operation");let s=va();if(s==null)throw new Mo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,Cs.getReplicationCert)();let _=await(0,Cs.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,Cs.createCsr)(),ns.info("Sending CSR to target node:",t)):_&&(c=_.certificate,ns.info("Sending CA named",_.name,"to target node",t))}let l={operation:$t.ADD_NODE_BACK,hostname:(0,zG.get)(x.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if(e.subscriptions?l.subscriptions=e.subscriptions.map(YG):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=YG(e);l.subscribe=_.subscribe,l.publish=_.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,f;try{u=await gp({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,ns.warn("Error adding node:",t,"to cluster:",_),f=_}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw f?(f.message+=" and connection was required to sign certificate",f):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&(ns.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Cs.setCertTable)({name:kae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Cs.setCertTable)({name:Xe(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let d={url:t,ca:u?.usingCA};if(e.hostname&&(d.name=e.hostname),e.subscriptions?d.subscriptions=e.subscriptions:d.replicates=!0,e.start_time&&(d.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(d.authorization=e.authorization),e.revoked_certificates&&(d.revoked_certificates=e.revoked_certificates),d.replicates){let _={url:s,ca:c,replicates:!0,subscriptions:null};e.retain_authorization&&(_.authorization=e.authorization),e.start_time&&(_.start_time=e.start_time),await Io(Xe(),_)}await Io(u?u.nodeName:d.name??li(t),d);let p;return e.operation==="update_node"?p=`Successfully updated '${t}'`:p=`Successfully added '${t}' to cluster`,f&&(p+=" but there was an error updating target node: "+f.message),p}async function $ae(e){ns.trace("addNodeBack received request:",e);let t=await(0,Cs.signCertificate)(e),r;e.csr?(r=t.signingCA,ns.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,ns.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization);let s=await(0,Cs.getReplicationCertAuth)();if(n.replicates){let i={url:va(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Io(Xe(),i)}return await Io(e.hostname,n),t.nodeName=Xe(),t.usingCA=s?.certificate,ns.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Vae(e){ns.trace("removeNodeBack received request:",e),await gr().delete(e.name)}function YG(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Cs,WG,Sl,zG,ns,Mo,kae,Fae,Gae,Al=be(()=>{Cs=M(rs()),WG=M(ut()),Sl=M(require("joi")),zG=M(ce());B();dp();ul();ts();ns=M(Y()),Mo=M(pe()),{pki:kae}=require("node-forge"),{HTTP_STATUS_CODES:Fae}=Mo.hdb_errors,Gae=Sl.default.object({hostname:Sl.default.string(),verify_tls:Sl.default.boolean(),replicates:Sl.default.boolean(),subscriptions:Sl.default.array(),revoked_certificates:Sl.default.array()});a(qae,"setNode");a($ae,"addNodeBack");a(Vae,"removeNodeBack");a(YG,"reverseSubscription")});var Ed=I((_Le,QG)=>{"use strict";var{handleHDBError:Xg,hdb_errors:Kae}=pe(),{HTTP_STATUS_CODES:Zg}=Kae,{addUpdateNodeValidator:Yae}=zg(),eS=Y(),tS=(B(),C(G)),jG=St(),Wae=oe(),Rp=ir(),yp=Lo(),WN=ce(),zae=YN(),{Node:jae,NodeSubscription:Qae}=hd(),{broadcast:Jae}=tt(),{setNode:Xae}=(Al(),C(Tl)),dLe=ce(),fLe=(B(),C(G)),Zae="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",ece="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",tce=WN.get(tS.CONFIG_PARAMS.CLUSTERING_NODENAME);QG.exports=rce;async function rce(e,t=!1){if(eS.trace("addNode called with:",e),WN.get(tS.CONFIG_PARAMS.REPLICATION_URL)||WN.get(tS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Xae(e);yp.checkClusteringEnabled();let r=Yae(e);if(r)throw Xg(r,r.message,Zg.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await yp.getNodeRecord(n);if(!Wae.isEmptyOrZeroLength(d))throw Xg(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Zg.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await zae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Zae,o;let c=yp.buildNodePayloads(s,tce,tS.OPERATIONS_ENUM.ADD_NODE,await yp.getSystemInfo()),l=[];for(let d=0,p=s.length;d<p;d++){let _=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new Qae(_.schema,_.table,_.publish,_.subscribe))}eS.trace("addNode sending remote payload:",c);let u;try{u=await Rp.request(`${n}.${jG.REQUEST_SUFFIX}`,c)}catch(d){eS.error(`addNode received error from request: ${d}`);for(let _=0,h=s.length;_<h;_++){let S=s[_];S.publish=!1,S.subscribe=!1,await Rp.updateRemoteConsumer(S,n)}let p=Rp.requestErrorHandler(d,"add_node",n);throw Xg(new Error,p,Zg.INTERNAL_SERVER_ERROR,"error",p)}if(u.status===jG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw Xg(new Error,d,Zg.INTERNAL_SERVER_ERROR,"error",d)}eS.trace(u);for(let d=0,p=s.length;d<p;d++){let _=s[d];await Rp.updateRemoteConsumer(_,n),_.subscribe===!0&&await Rp.updateConsumerIterator(_.schema,_.table,n,"start")}let f=new jae(n,l,u.system_info);return await yp.upsertNodeRecord(f),Jae({type:"nats_update"}),i.length>0?o.message=ece:o.message=`Successfully added '${n}' to manifest`,o}a(rce,"addNode")});var JN=I((mLe,XG)=>{"use strict";var{handleHDBError:zN,hdb_errors:nce}=pe(),{HTTP_STATUS_CODES:jN}=nce,{addUpdateNodeValidator:sce}=zg(),bp=Y(),rS=(B(),C(G)),JG=St(),hLe=oe(),Op=ir(),Np=Lo(),QN=ce(),{cloneDeep:ice}=require("lodash"),oce=YN(),{Node:ace,NodeSubscription:cce}=hd(),{broadcast:lce}=tt(),{setNode:uce}=(Al(),C(Tl)),dce="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",fce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",_ce=QN.get(rS.CONFIG_PARAMS.CLUSTERING_NODENAME);XG.exports=pce;async function pce(e){if(bp.trace("updateNode called with:",e),QN.get(rS.CONFIG_PARAMS.REPLICATION_URL)??QN.get(rS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return uce(e);Np.checkClusteringEnabled();let t=sce(e);if(t)throw zN(t,t.message,jN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Np.getNodeRecord(r);s.length>0&&(n=ice(s));let{added:i,skipped:o}=await oce(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=dce,c;let l=Np.buildNodePayloads(i,_ce,rS.OPERATIONS_ENUM.UPDATE_NODE,await Np.getSystemInfo());for(let f=0,d=i.length;f<d;f++){let p=i[f];bp.trace(`updateNode updating work stream for node: ${r} subscription:`,p),i[f].start_time===void 0&&delete i[f].start_time}bp.trace("updateNode sending remote payload:",l);let u;try{u=await Op.request(`${r}.${JG.REQUEST_SUFFIX}`,l)}catch(f){bp.error(`updateNode received error from request: ${f}`);let d=Op.requestErrorHandler(f,"update_node",r);throw zN(new Error,d,jN.INTERNAL_SERVER_ERROR,"error",d)}if(u.status===JG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${r}: ${u.message}`;throw zN(new Error,f,jN.INTERNAL_SERVER_ERROR,"error",f)}bp.trace(u);for(let f=0,d=i.length;f<d;f++){let p=i[f];await Op.updateRemoteConsumer(p,r),p.subscribe===!0?await Op.updateConsumerIterator(p.schema,p.table,r,"start"):await Op.updateConsumerIterator(p.schema,p.table,r,"stop")}return n||(n=[new ace(r,[],u.system_info)]),await hce(n[0],i,u.system_info),o.length>0?c.message=fce:c.message=`Successfully updated '${r}'`,c}a(pce,"updateNode");async function hce(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let f=n.subscriptions[l];if(f.schema===o.schema&&f.table===o.table){f.publish=o.publish,f.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new cce(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Np.upsertNodeRecord(n),lce({type:"nats_update"})}a(hce,"updateNodeTable")});var nq=I((gLe,rq)=>{"use strict";var tq=require("joi"),{string:ZG}=tq.types(),mce=ut(),eq=(B(),C(G)),Ece=ce(),gce=St();rq.exports=Sce;function Sce(e){let t=ZG.invalid(Ece.get(eq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(gce.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=tq.object({operation:ZG.valid(eq.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return mce.validateBySchema(e,r)}a(Sce,"removeNodeValidator")});var nS=I((TLe,cq)=>{"use strict";var{handleHDBError:sq,hdb_errors:Tce}=pe(),{HTTP_STATUS_CODES:iq}=Tce,Ace=nq(),wp=Y(),oq=Lo(),Rce=oe(),gd=(B(),C(G)),aq=St(),XN=ir(),ZN=ce(),{RemotePayloadObject:yce}=Tp(),{NodeSubscription:bce}=hd(),Oce=U_(),Nce=Vc(),{broadcast:wce}=tt(),{setNode:Ice}=(Al(),C(Tl)),Cce=ZN.get(gd.CONFIG_PARAMS.CLUSTERING_NODENAME);cq.exports=Pce;async function Pce(e){if(wp.trace("removeNode called with:",e),ZN.get(gd.CONFIG_PARAMS.REPLICATION_URL)??ZN.get(gd.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Ice(e);oq.checkClusteringEnabled();let t=Ace(e);if(t)throw sq(t,t.message,iq.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await oq.getNodeRecord(r);if(Rce.isEmptyOrZeroLength(n))throw sq(new Error,`Node '${r}' was not found.`,iq.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new yce(gd.OPERATIONS_ENUM.REMOVE_NODE,Cce,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await XN.updateConsumerIterator(f.schema,f.table,r,"stop");try{await XN.updateRemoteConsumer(new bce(f.schema,f.table,!1,!1),r)}catch(d){wp.error(d)}}try{i=await XN.request(`${r}.${aq.REQUEST_SUFFIX}`,s),wp.trace("Remove node reply from remote node:",r,i)}catch(l){wp.error("removeNode received error from request:",l),o=!0}let c=new Oce(gd.SYSTEM_SCHEMA_NAME,gd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Nce.deleteRecord(c),wce({type:"nats_update"}),i?.status===aq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(wp.error("Error returned from remote node:",r,i?.message),`Successfully removed '${r}' from local manifest, however there was an error reaching remote node. Check the logs for more details.`):`Successfully removed '${r}' from manifest`}a(Pce,"removeNode")});var dq=I((RLe,uq)=>{"use strict";var lq=require("joi"),{string:Dce,array:Lce}=lq.types(),Mce=ut(),vce=zg();uq.exports=Uce;function Uce(e){let t=lq.object({operation:Dce.valid("configure_cluster").required(),connections:Lce.items(vce.validation_schema).required()});return Mce.validateBySchema(e,t)}a(Uce,"configureClusterValidator")});var ew=I((bLe,mq)=>{"use strict";var fq=(B(),C(G)),sS=Y(),xce=oe(),Bce=ce(),Hce=nS(),kce=Ed(),Fce=Lo(),Gce=dq(),{handleHDBError:_q,hdb_errors:qce}=pe(),{HTTP_STATUS_CODES:pq}=qce,$ce="Configure cluster complete.",Vce="Failed to configure the cluster. Check the logs for more details.",Kce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";mq.exports=Yce;async function Yce(e){sS.trace("configure cluster called with:",e);let t=Gce(e);if(t)throw _q(t,t.message,pq.BAD_REQUEST,void 0,void 0,!0);let r=await Fce.getAllNodeRecords(),n=[];if(Bce.get(fq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let p=await hq(Hce,{operation:fq.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name);n.push(p)}sS.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let f=0;f<i;f++){let d=e.connections[f],p=await hq(kce,d,d.node_name);s.push(p)}sS.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let f=0,d=u.length;f<d;f++){let p=u[f];p.status==="rejected"&&(sS.error(p.node_name,p?.error?.message,p?.error?.stack),o.includes(p.node_name)||o.push(p.node_name)),(p?.result?.message?.includes?.("Successfully")||p?.result?.includes?.("Successfully"))&&(l=!0),!(typeof p.result=="string"&&p.result.includes("Successfully removed")||p.status==="rejected")&&c.push({node_name:p?.node_name,response:p?.result})}if(xce.isEmptyOrZeroLength(o))return{message:$ce,connections:c};if(l)return{message:Kce,failed_nodes:o,connections:c};throw _q(new Error,Vce,pq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Yce,"configureCluster");async function hq(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(hq,"functionWrapper")});var Tq=I((NLe,Sq)=>{"use strict";var Ip=require("joi"),Wce=ut(),{validateSchemaExists:Eq,validateTableExists:zce,validateSchemaName:gq}=vi(),jce=Ip.object({operation:Ip.string().valid("purge_stream"),schema:Ip.string().custom(Eq).custom(gq).optional(),database:Ip.string().custom(Eq).custom(gq).optional(),table:Ip.string().custom(zce).required()});function Qce(e){return Wce.validateBySchema(e,jce)}a(Qce,"purgeStreamValidator");Sq.exports=Qce});var tw=I((ILe,Aq)=>{"use strict";var{handleHDBError:Jce,hdb_errors:Xce}=pe(),{HTTP_STATUS_CODES:Zce}=Xce,ele=Tq(),tle=ir(),rle=Lo();Aq.exports=nle;async function nle(e){e.schema=e.schema??e.database;let t=ele(e);if(t)throw Jce(t,t.message,Zce.BAD_REQUEST,void 0,void 0,!0);rle.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await tle.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(nle,"purgeStream")});var aS=I((PLe,Iq)=>{"use strict";var nw=Lo(),sle=ir(),oS=ce(),Sd=(B(),C(G)),Rl=St(),ile=oe(),rw=Y(),{RemotePayloadObject:ole}=Tp(),{ErrorCode:Rq}=require("nats"),{parentPort:yq}=require("worker_threads"),{onMessageByType:ale}=tt(),{getThisNodeName:cle}=(ts(),C(Po)),{requestClusterStatus:lle}=(dp(),C(Yk)),{getReplicationSharedStatus:ule}=(ul(),C(YO)),{CONFIRMATION_STATUS_POSITION:dle,RECEIVED_VERSION_POSITION:fle,RECEIVED_TIME_POSITION:_le,SENDING_TIME_POSITION:ple}=(mN(),C(vF)),bq=oS.get(Sd.CONFIG_PARAMS.CLUSTERING_ENABLED),Oq=oS.get(Sd.CONFIG_PARAMS.CLUSTERING_NODENAME);Iq.exports={clusterStatus:hle,buildNodeStatus:wq};var Nq;ale("cluster-status",async e=>{Nq(e)});async function hle(){if(oS.get(Sd.CONFIG_PARAMS.REPLICATION_URL)||oS.get(Sd.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(yq){yq.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{Nq=s});for(let s of n.connections){let i=s.name;for(let o of s.database_sockets){let c=o.database,l;for(let f of Object.values(databases[c]||{}))if(l=f.auditStore,l)break;if(!l)continue;let u=ule(l,c,i);o.lastCommitConfirmed=iS(u[dle]),o.lastReceivedRemoteTime=iS(u[fle]),o.lastReceivedLocalTime=iS(u[_le]),o.sendingMessage=iS(u[ple])}}}else n=lle();return n.node_name=cle(),n.is_enabled=!0,n}let e={node_name:Oq,is_enabled:bq,connections:[]};if(!bq)return e;let t=await nw.getAllNodeRecords();if(ile.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(wq(t[n],e.connections));return await Promise.allSettled(r),e}a(hle,"clusterStatus");function iS(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}a(iS,"asDate");async function wq(e,t){let r=e.name,n=new ole(Sd.OPERATIONS_ENUM.CLUSTER_STATUS,Oq,void 0,await nw.getSystemInfo()),s,i,o=Rl.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await sle.request(Rl.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Rl.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Rl.CLUSTER_STATUS_STATUSES.CLOSED,rw.error(`Error getting node status from ${r} `,s))}catch(l){rw.warn(`Error getting node status from ${r}`,l),l.code===Rq.NoResponders?o=Rl.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===Rq.Timeout?o=Rl.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Rl.CLUSTER_STATUS_STATUSES.CLOSED}let c=new mle(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Sd.PRE_4_0_0_VERSION&&await nw.upsertNodeRecord(l)}catch(l){rw.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(wq,"buildNodeStatus");function mle(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(mle,"NodeStatusObject")});var lS=I((LLe,Cq)=>{"use strict";var{handleHDBError:Ele,hdb_errors:gle}=pe(),{HTTP_STATUS_CODES:Sle}=gle,Tle=ir(),Ale=Lo(),sw=oe(),cS=require("joi"),Rle=ut(),yle=2e3,ble=cS.object({timeout:cS.number().min(1),connected_nodes:cS.boolean(),routes:cS.boolean()});Cq.exports=Ole;async function Ole(e){Ale.checkClusteringEnabled();let t=Rle.validateBySchema(e,ble);if(t)throw Ele(t,t.message,Sle.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||sw.autoCastBoolean(n),o=s===void 0||sw.autoCastBoolean(s),c={nodes:[]},l=await Tle.getServerList(r??yle),u={};if(i)for(let f=0,d=l.length;f<d;f++){let p=l[f].statsz;p&&(u[l[f].server.name]=p.routes)}for(let f=0,d=l.length;f<d;f++){if(l[f].statsz)continue;let p=l[f].server,_=l[f].data;if(p.name.endsWith("-hub")){let h={name:p.name.slice(0,-4),response_time:l[f].response_time};i&&(h.connected_nodes=[],u[p.name]&&u[p.name].forEach(S=>{h.connected_nodes.includes(S.name.slice(0,-4))||h.connected_nodes.push(S.name.slice(0,-4))})),o&&(h.routes=_.cluster?.urls?_.cluster?.urls.map(S=>({host:S.split(":")[0],port:sw.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(Ole,"clusterNetwork")});var Mq=I((vLe,Lq)=>{"use strict";var iw=require("joi"),Pq=ut(),{route_constraints:Dq}=$y();Lq.exports={setRoutesValidator:Nle,deleteRoutesValidator:wle};function Nle(e){let t=iw.object({server:iw.valid("hub","leaf"),routes:Dq.required()});return Pq.validateBySchema(e,t)}a(Nle,"setRoutesValidator");function wle(e){let t=iw.object({routes:Dq.required()});return Pq.validateBySchema(e,t)}a(wle,"deleteRoutesValidator")});var uS=I((xLe,Fq)=>{"use strict";var vo=Rt(),ow=oe(),Ps=(B(),C(G)),Td=ce(),vq=Mq(),{handleHDBError:Uq,hdb_errors:Ile}=pe(),{HTTP_STATUS_CODES:xq}=Ile,Bq="cluster routes successfully set",Hq="cluster routes successfully deleted";Fq.exports={setRoutes:Ple,getRoutes:Dle,deleteRoutes:Lle};function Cle(e){let t=vo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=ow.autoCast(l.port);let u=r.some(d=>d.host===l.host&&d.port===l.port),f=n.some(d=>d.host===l.host&&d.port===l.port);u||f?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?vo.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):vo.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:Bq,set:i,skipped:s}}a(Cle,"setRoutesNats");function Ple(e){let t=vq.setRoutesValidator(e);if(t)throw Uq(t,t.message,xq.BAD_REQUEST,void 0,void 0,!0);if(Td.get(Ps.CONFIG_PARAMS.CLUSTERING_ENABLED))return Cle(e);let r=[],n=[],s=Td.get(Ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{kq(s,i)?n.push(i):(s.push(i),r.push(i))}),vo.updateConfigValue(Ps.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:Bq,set:r,skipped:n}}a(Ple,"setRoutes");function kq(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(kq,"existsInArray");function Dle(){if(Td.get(Ps.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=vo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Td.get(Ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Dle,"getRoutes");function Lle(e){let t=vq.deleteRoutesValidator(e);if(t)throw Uq(t,t.message,xq.BAD_REQUEST,void 0,void 0,!0);if(Td.get(Ps.CONFIG_PARAMS.CLUSTERING_ENABLED))return Mle(e);let r=[],n=[],s=Td.get(Ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{kq(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),vo.updateConfigValue(Ps.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Hq,deleted:r,skipped:n}}a(Lle,"deleteRoutes");function Mle(e){let t=vo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let f=e.routes[l],d=!1;for(let p=0,_=r.length;p<_;p++){let h=r[p];if(f.host===h.host&&f.port===h.port){r.splice(p,1),d=!0,o=!0,s.push(f);break}}if(!d){let p=!0;for(let _=0,h=n.length;_<h;_++){let S=n[_];if(f.host===S.host&&f.port===S.port){n.splice(_,1),c=!0,p=!1,s.push(f);break}}p&&i.push(f)}}return o&&(r=ow.isEmptyOrZeroLength(r)?null:r,vo.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=ow.isEmptyOrZeroLength(n)?null:n,vo.updateConfigValue(Ps.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Hq,deleted:s,skipped:i}}a(Mle,"deleteRoutesNats")});var qq=I((HLe,Gq)=>{"use strict";var Cp=require("alasql"),yl=require("recursive-iterator"),fi=Y(),vle=oe(),Pp=(B(),C(G)),aw=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,xle(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>Pp.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!Pp.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,o=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][Pp.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Ule(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!Pp.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let f=new Cp.yy.Column({columnid:u});s.tableid&&(f.tableid=s.tableid),this.ast.columns.push(f),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function Ule(e){return e.filter(t=>t[Pp.PERMS_CRUD_ENUM.READ])}a(Ule,"filterReadRestrictedAttrs");function xle(e,t,r,n,s){Ble(e,t,r,n,s)}a(xle,"interpretAST");function Dp(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),s.set(o,i)}}a(Dp,"addSchemaTableToMap");function Ble(e,t,r,n,s){if(!e){fi.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Cp.yy.Insert?Gle(e,t,r):e instanceof Cp.yy.Select?Hle(e,t,r,n,s):e instanceof Cp.yy.Update?kle(e,t,r):e instanceof Cp.yy.Delete?Fle(e,t,r):fi.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(Ble,"getRecordAttributesAST");function Hle(e,t,r,n,s){if(!e){fi.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(vle.isEmptyOrZeroLength(i)){fi.error("No schema specified");return}e.from.forEach(c=>{Dp(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Dp(c.table,t,r,n,s)});let o=new yl(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{fi.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new yl(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let f=u.tableid?u.tableid:l;if(!t.get(i).has(f))if(r.has(f))f=r.get(f);else{fi.info(`table specified as ${f} not found.`);continue}t.get(i).get(f).indexOf(u.columnid)<0&&t.get(i).get(f).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new yl(c.on);for(let{node:u}of l)if(u&&u.columnid){let f=u.tableid,d=s.get(f);if(!t.get(d).has(f))if(r.has(f))f=r.get(f);else{fi.info(`table specified as ${f} not found.`);continue}t.get(d).get(f).indexOf(u.columnid)<0&&t.get(d).get(f).push(u.columnid)}}),e.order){let c=new yl(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,f=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(f).has(u))if(r.has(u))u=r.get(u);else{fi.info(`table specified as ${u} not found.`);return}t.get(f).get(u).indexOf(l.columnid)<0&&t.get(f).get(u).push(l.columnid)}}}a(Hle,"getSelectAttributes");function kle(e,t,r){if(!e){fi.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new yl(e.columns),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&cw(e.table.tableid,s,i.columnid,t,r)}a(kle,"getUpdateAttributes");function Fle(e,t,r){if(!e){fi.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new yl(e.where),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&cw(e.table.tableid,s,i.columnid,t,r)}a(Fle,"getDeleteAttributes");function Gle(e,t,r){if(!e){fi.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new yl(e.columns),s=e.into.databaseid;Dp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&cw(e.into.tableid,s,i.columnid,t,r)}a(Gle,"getInsertAttributes");function cw(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(cw,"pushAttribute");Gq.exports=aw});var Vq=I((FLe,$q)=>{"use strict";var dS=(B(),C(G)),fS=class{static{a(this,"BaseLicense")}constructor(t=0,r=dS.RAM_ALLOCATION_ENUM.DEFAULT,n=dS.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},lw=class extends fS{static{a(this,"ExtendedLicense")}constructor(t=0,r=dS.RAM_ALLOCATION_ENUM.DEFAULT,n=dS.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};$q.exports={BaseLicense:fS,ExtendedLicense:lw}});var yd=I((qLe,Qq)=>{"use strict";var Rd=require("fs-extra"),_S=(hE(),C(pE)),Yq=require("crypto"),qle=require("moment"),$le=require("uuid").v4,en=Y(),dw=require("path"),Vle=oe(),bl=(B(),C(G)),{totalmem:Kq}=require("os"),Kle=Vq().ExtendedLicense,Ad="invalid license key format",Yle="061183",Wle="mofi25",zle="aes-256-cbc",jle=16,Qle=32,Wq=ce(),{resolvePath:zq}=Rt();Wq.initSync();var uw;Qq.exports={validateLicense:jq,generateFingerPrint:Xle,licenseSearch:pw,getLicense:tue,checkMemoryLimit:rue};function fw(){return dw.join(Wq.getHdbBasePath(),bl.LICENSE_KEY_DIR_NAME,bl.LICENSE_FILE_NAME)}a(fw,"getLicenseDirPath");function Jle(){let e=fw();return zq(dw.join(e,bl.LICENSE_FILE_NAME))}a(Jle,"getLicenseFilePath");function _w(){let e=fw();return zq(dw.join(e,bl.REG_KEY_FILE_NAME))}a(_w,"getFingerPrintFilePath");async function Xle(){let e=_w();try{return await Rd.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Zle();throw en.error(`Error writing fingerprint file to ${e}`),en.error(t),new Error("There was an error generating the fingerprint")}}a(Xle,"generateFingerPrint");async function Zle(){let e=$le(),t=_S.hash(e,_S.HASH_FUNCTION.MD5),r=_w();try{await Rd.mkdirp(fw()),await Rd.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw en.error(`Error writing fingerprint file to ${r}`),en.error(n),new Error("There was an error generating the fingerprint")}return t}a(Zle,"writeFingerprint");function jq(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:bl.RAM_ALLOCATION_ENUM.DEFAULT,version:bl.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return en.error("empty license key passed to validate."),r;let n=_w(),s=!1;try{s=Rd.statSync(n)}catch(i){en.error(i)}if(s){let i;try{i=Rd.readFileSync(n,"utf8")}catch{en.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(Wle),c=o[1];c=Buffer.concat([Buffer.from(c)],jle);let l=Buffer.concat([Buffer.from(i)],Qle),u=Yq.createDecipheriv(zle,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let f=null;try{f=u.update(o[0],"hex","utf8"),f.trim(),f+=u.final("utf8")}catch{let _=eue(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Ad),en.error(Ad),new Error(Ad)}let d;if(isNaN(f))try{d=JSON.parse(f),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(Ad),en.error(Ad),new Error(Ad)}else r.exp_date=f;r.exp_date<qle().valueOf()&&(r.valid_date=!1),_S.validate(o[1],`${Yle}${i}${t}`,_S.HASH_FUNCTION.MD5)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||en.error("Invalid licence"),r}a(jq,"validateLicense");function eue(e,t){try{let r=Yq.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{en.warn("Check old license failed")}}a(eue,"checkOldLicense");function pw(){let e=new Kle,t=[];try{t=Rd.readFileSync(Jle(),"utf-8").split(`\r
|
|
25
|
+
`)}catch(r){r.code==="ENOENT"?en.debug("no license file found"):en.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(Vle.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=jq(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){en.error("There was an error parsing the license string."),en.error(s),e.ram_allocation=bl.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return uw=e,e}a(pw,"licenseSearch");async function tue(){return uw||await pw(),uw}a(tue,"getLicense");function rue(){let e=pw().ram_allocation,t=process.constrainedMemory?.()||Kq();if(t=Math.round(Math.min(t,Kq())/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(rue,"checkMemoryLimit")});var hS=I((VLe,e$)=>{var pS=yd(),Jq=require("chalk"),ss=Y(),Xq=require("prompt"),{promisify:nue}=require("util"),hw=(B(),C(G)),sue=require("fs-extra"),iue=require("path"),oue=oe(),{packageJson:aue}=nt(),Zq=ce();Zq.initSync();var cue=require("moment"),lue=nue(Xq.get),uue=iue.join(Zq.getHdbBasePath(),hw.LICENSE_KEY_DIR_NAME,hw.LICENSE_FILE_NAME,hw.LICENSE_FILE_NAME);e$.exports={getFingerprint:fue,setLicense:due,parseLicense:mw,register:_ue,getRegistrationInfo:hue};async function due(e){if(e&&e.key&&e.company){try{ss.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await mw(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ss.error(r),ss.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(due,"setLicense");async function fue(){let e={};try{e=await pS.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ss.error(r),ss.error(t),new Error(r)}return e}a(fue,"getFingerprint");async function mw(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ss.info("Validating license input...");let r=pS.validateLicense(e,t);if(ss.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(ss.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(ss.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ss.info("writing license to disk"),await sue.writeFile(uue,JSON.stringify({license_key:e,company:t}))}catch(n){throw ss.error("Failed to write License"),n}return"Registration successful."}a(mw,"parseLicense");async function _ue(){let e=await pue();return mw(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(_ue,"register");async function pue(){let e=await pS.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Jq.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Jq.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{Xq.start()}catch(n){ss.error(n)}let r;try{r=await lue(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(pue,"promptForRegistration");async function hue(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await pS.getLicense()}catch(r){throw ss.error(`There was an error when searching licenses due to: ${r.message}`),r}if(oue.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=aue.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=cue.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(hue,"getRegistrationInfo")});var r$=I((YLe,t$)=>{"use strict";var mue=St(),Ew=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d,p,_,h){this.port=t,o===null&&(o=void 0),this.server_name=r+mue.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:f,port:d,routes:p,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:_},HDB:{users:h}},this.system_account="SYS"}};t$.exports=Ew});var i$=I((zLe,s$)=>{"use strict";var n$=St(),gw=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d){this.port=t,d===null&&(d=void 0),this.server_name=r+n$.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+n$.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:f,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};s$.exports=gw});var a$=I((QLe,o$)=>{"use strict";var Sw=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};o$.exports=Sw});var l$=I((XLe,c$)=>{"use strict";var Eue=St(),Tw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+Eue.SERVER_SUFFIX.ADMIN,this.password=r}};c$.exports=Tw});var SS=I((eMe,f$)=>{"use strict";var Ol=require("path"),Nl=require("fs-extra"),gue=r$(),Sue=i$(),Tue=a$(),Aue=l$(),Aw=Rn(),Od=oe(),Cn=Rt(),ES=(B(),C(G)),Lp=St(),{CONFIG_PARAMS:Wt}=ES,Nd=Y(),Mp=ce(),u$=To(),Rw=ir(),Rue=rs(),bd="clustering",yue=1e4,d$=50;f$.exports={generateNatsConfig:Oue,removeNatsConfig:Nue,getHubConfigPath:bue};function bue(){let e=Mp.get(Wt.ROOTPATH);return Ol.join(e,bd,Lp.NATS_CONFIG_FILES.HUB_SERVER)}a(bue,"getHubConfigPath");async function Oue(e=!1,t=void 0){let r=Mp.get(Wt.ROOTPATH);Nl.ensureDirSync(Ol.join(r,"clustering","leaf")),Mp.initSync();let n=Cn.getConfigFromFile(Wt.CLUSTERING_TLS_CERT_AUTH),s=Cn.getConfigFromFile(Wt.CLUSTERING_TLS_PRIVATEKEY),i=Cn.getConfigFromFile(Wt.CLUSTERING_TLS_CERTIFICATE);!await Nl.exists(i)&&!await Nl.exists(!n)&&await Rue.createNatsCerts();let o=Ol.join(r,bd,Lp.PID_FILES.HUB),c=Ol.join(r,bd,Lp.PID_FILES.LEAF),l=Cn.getConfigFromFile(Wt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Ol.join(r,bd,Lp.NATS_CONFIG_FILES.HUB_SERVER),f=Ol.join(r,bd,Lp.NATS_CONFIG_FILES.LEAF_SERVER),d=Cn.getConfigFromFile(Wt.CLUSTERING_TLS_INSECURE),p=Cn.getConfigFromFile(Wt.CLUSTERING_TLS_VERIFY),_=Cn.getConfigFromFile(Wt.CLUSTERING_NODENAME),h=Cn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Rw.checkNATSServerInstalled()||gS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await Aw.listUsers(),g=Cn.getConfigFromFile(Wt.CLUSTERING_USER),A=await Aw.getClusterUser();(Od.isEmpty(A)||A.active!==!0)&&gS(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await mS(Wt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await mS(Wt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await mS(Wt.CLUSTERING_HUBSERVER_NETWORK_PORT),await mS(Wt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],R=[];for(let[ae,Z]of S.entries())Z.role?.role===ES.ROLE_TYPES_ENUM.CLUSTER_USER&&Z.active&&(E.push(new Aue(Z.username,u$.decrypt(Z.hash))),R.push(new Tue(Z.username,u$.decrypt(Z.hash))));let N=[],{hub_routes:v}=Cn.getClusteringRoutes();if(!Od.isEmptyOrZeroLength(v))for(let ae of v)N.push(`tls://${A.sys_name_encoded}:${A.uri_encoded_d_hash}@${ae.host}:${ae.port}`);let k=new gue(Cn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,p,h,Cn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Cn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),N,E,R);n==null&&(delete k.tls.ca_file,delete k.leafnodes.tls.ca_file),t=Od.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ES.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Nl.writeJson(u,k),Nd.trace(`Hub server config written to ${u}`));let F=`tls://${A.sys_name_encoded}:${A.uri_encoded_d_hash}@0.0.0.0:${h}`,K=`tls://${A.uri_encoded_name}:${A.uri_encoded_d_hash}@0.0.0.0:${h}`,re=new Sue(Cn.getConfigFromFile(Wt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[F],[K],E,R,i,s,n,d);n==null&&delete re.tls.ca_file,(t===void 0||t===ES.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Nl.writeJson(f,re),Nd.trace(`Leaf server config written to ${f}`))}a(Oue,"generateNatsConfig");async function mS(e){let t=Mp.get(e);return Od.isEmpty(t)&&gS(`port undefined for '${e}'`),await Od.isPortTaken(t)&&gS(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(mS,"isPortAvailable");function gS(e){let t=`Error generating clustering config: ${e}`;Nd.error(t),console.error(t),process.exit(1)}a(gS,"generateNatsConfigError");async function Nue(e){let{port:t,config_file:r}=Rw.getServerConfig(e),{username:n,decrypt_hash:s}=await Aw.getClusterUser(),i=0,o=2e3;for(;i<d$;){try{let f=await Rw.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){Nd.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${f}`)}if(i++,i>=d$)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&Nd.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Od.async_set_timeout(u)}let c="0".repeat(yue),l=Ol.join(Mp.get(Wt.ROOTPATH),bd,r);await Nl.writeFile(l,c),await Nl.remove(l),Nd.notify(e,"started.")}a(Nue,"removeNatsConfig")});var g$=I((rMe,E$)=>{"use strict";var is=ce(),wue=yd(),Ge=(B(),C(G)),vp=St(),Uo=require("path"),{PACKAGE_ROOT:AS}=nt(),_$=ce(),TS=oe(),wd="/dev/null",Iue=Uo.join(AS,"launchServiceScripts"),p$=Uo.join(AS,"utility/scripts"),Cue=Uo.join(p$,Ge.HDB_RESTART_SCRIPT),h$=Uo.resolve(AS,"dependencies",`${process.platform}-${process.arch}`,vp.NATS_BINARY_NAME);function m$(){let t=wue.licenseSearch().ram_allocation||Ge.RAM_ALLOCATION_ENUM.DEFAULT,r=Ge.MEM_SETTING_KEY+t,n={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return TS.noBootFile()&&(n[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TS.getEnvCliRootPath()),{name:Ge.PROCESS_DESCRIPTORS.HDB,script:Ge.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:AS}}a(m$,"generateMainServerConfig");var Pue=9930;function Due(){is.initSync(!0);let e=is.get(Ge.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",vp.NATS_CONFIG_FILES.HUB_SERVER),r=Uo.join(is.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=_$.get(Ge.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[is.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Pue?"-"+n:""),script:h$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return is.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wd,i.error_file=wd),i}a(Due,"generateNatsHubServerConfig");var Lue=9940;function Mue(){is.initSync(!0);let e=is.get(Ge.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",vp.NATS_CONFIG_FILES.LEAF_SERVER),r=Uo.join(is.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=_$.get(Ge.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[is.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Lue?"-"+n:""),script:h$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return is.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wd,i.error_file=wd),i}a(Mue,"generateNatsLeafServerConfig");function vue(){is.initSync();let e=Uo.join(is.get(Ge.CONFIG_PARAMS.LOGGING_ROOT),Ge.LOG_NAMES.HDB),t={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ge.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Iue,autorestart:!1};return is.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=wd,t.error_file=wd),t}a(vue,"generateClusteringUpgradeV4ServiceConfig");function Uue(){let e={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.RESTART_HDB};return TS.noBootFile()&&(e[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TS.getEnvCliRootPath()),{...{name:Ge.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:p$},script:Cue}}a(Uue,"generateRestart");function xue(){return{apps:[m$()]}}a(xue,"generateAllServiceConfigs");E$.exports={generateAllServiceConfigs:xue,generateMainServerConfig:m$,generateRestart:Uue,generateNatsHubServerConfig:Due,generateNatsLeafServerConfig:Mue,generateClusteringUpgradeV4ServiceConfig:vue}});var Id=I((iMe,L$)=>{"use strict";var Ze=(B(),C(G)),Bue=oe(),Bo=SS(),RS=ir(),xo=St(),Ka=g$(),yS=ce(),wl=Y(),Hue=Lo(),{startWorker:S$,onMessageFromWorkers:kue}=tt(),Fue=Do(),sMe=require("util"),Gue=require("child_process"),que=require("fs"),{execFile:$ue}=Gue,Ke;L$.exports={enterPM2Mode:Vue,start:Ya,stop:yw,reload:A$,restart:R$,list:bw,describe:O$,connect:Ho,kill:jue,startAllServices:Que,startService:Ow,getUniqueServicesList:N$,restartAllServices:Jue,isServiceRegistered:w$,reloadStopStart:I$,restartHdb:b$,deleteProcess:Wue,startClusteringProcesses:P$,startClusteringThreads:D$,isHdbRestartRunning:zue,isClusteringRunning:Zue,stopClustering:Xue,reloadClustering:ede,expectedRestartOfChildren:y$};var Up=!1;kue(e=>{e.type==="restart"&&yS.initSync(!0)});function Vue(){Up=!0}a(Vue,"enterPM2Mode");function Ho(){return Ke||(Ke=require("pm2")),new Promise((e,t)=>{Ke.connect((r,n)=>{r&&t(r),e(n)})})}a(Ho,"connect");var tn,Kue=10,T$;function Ya(e,t=!1){if(Up)return Yue(e);let r=$ue(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=tn.indexOf(r);o>-1&&tn.splice(o,1),!T$&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Kue&&(que.existsSync(Bo.getHubConfigPath())?Ya(e):(await Bo.generateNatsConfig(!0),Ya(e),await new Promise(c=>setTimeout(c,3e3)),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=yS.get(Ze.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,f;for(;l=c.exec(i);){if(l.index&&xo.LOG_LEVEL_HIERARCHY[o]>=xo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===xo.LOG_LEVELS.ERR||f===xo.LOG_LEVELS.WRN?wl.OUTPUTS.STDERR:wl.OUTPUTS.STDOUT;wl.logCustomLevel(f||"info",_,n,i.slice(u,l.index).trim())}let[d,p]=l;u=l.index+d.length,f=xo.LOG_LEVELS[p]}if(xo.LOG_LEVEL_HIERARCHY[o]>=xo.LOG_LEVEL_HIERARCHY[f||"info"]){let d=f===xo.LOG_LEVELS.ERR||f===xo.LOG_LEVELS.WRN?wl.OUTPUTS.STDERR:wl.OUTPUTS.STDOUT;wl.logCustomLevel(f||"info",d,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!tn&&(tn=[],!t)){let i=a(()=>{T$=!0,tn&&(tn.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}tn.push(r)}a(Ya,"start");function Yue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.start(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(Yue,"startWithPM2");function yw(e){if(!Up){for(let t of tn||[])t.name===e&&(tn.splice(tn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.stop(e,async(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.delete(e,(i,o)=>{i&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(o)})})})}a(yw,"stop");function A$(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.reload(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(A$,"reload");function R$(e){if(!Up){y$();for(let t of tn||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.restart(e,(n,s)=>{Ke.disconnect(),t(s)})})}a(R$,"restart");function y$(){for(let e of tn||[])e.config&&(e.config.restarts=0)}a(y$,"expectedRestartOfChildren");function Wue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.delete(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(Wue,"deleteProcess");async function b$(){await Ya(Ka.generateRestart())}a(b$,"restartHdb");async function zue(){let e=await bw();for(let t in e)if(e[t].name===Ze.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(zue,"isHdbRestartRunning");function bw(){return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ke.list((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(bw,"list");function O$(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.describe(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(O$,"describe");function jue(){if(!Up){for(let e of tn||[])e.kill();tn=[];return}return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ke.killDaemon((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(jue,"kill");async function Que(){try{await P$(),await D$(),await Ya(Ka.generateAllServiceConfigs())}catch(e){throw Ke?.disconnect(),e}}a(Que,"startAllServices");async function Ow(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Ze.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ka.generateMainServerConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ka.generateNatsIngestServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ka.generateNatsReplyServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ka.generateNatsHubServerConfig(),await Ya(r,t),await Bo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ka.generateNatsLeafServerConfig(),await Ya(r,t),await Bo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ka.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Ya(r)}catch(r){throw Ke?.disconnect(),r}}a(Ow,"startService");async function N$(){try{let e=await bw(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Ke?.disconnect(),e}}a(N$,"getUniqueServicesList");async function Jue(e=[]){try{let t=!1,r=await N$();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===Ze.PROCESS_DESCRIPTORS.HDB?t=!0:await R$(o))}t&&await I$(Ze.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ke?.disconnect(),t}}a(Jue,"restartAllServices");async function w$(e){if(tn?.find(r=>r.name===e))return!0;let t=await Fue.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(w$,"isServiceRegistered");async function I$(e){let t=yS.get(Ze.CONFIG_PARAMS.THREADS_COUNT)??yS.get(Ze.CONFIG_PARAMS.THREADS),r=await O$(e),n=Bue.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await yw(e),await Ow(e)):e===Ze.PROCESS_DESCRIPTORS.HDB?await b$():await A$(e)}a(I$,"reloadStopStart");var C$;async function P$(e=!1){for(let t in Ze.CLUSTERING_PROCESSES){let r=Ze.CLUSTERING_PROCESSES[t];await Ow(r,e)}}a(P$,"startClusteringProcesses");async function D$(){C$=S$(Ze.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Ze.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await RS.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await RS.updateLocalStreams();let e=await Hue.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Ze.PRE_4_0_0_VERSION){wl.info("Starting clustering upgrade 4.0.0 process"),S$(Ze.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(D$,"startClusteringThreads");async function Xue(){for(let e in Ze.CLUSTERING_PROCESSES)if(e!==Ze.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===Ze.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await C$.terminate();else{let t=Ze.CLUSTERING_PROCESSES[e];await yw(t)}}a(Xue,"stopClustering");async function Zue(){for(let e in Ze.CLUSTERING_PROCESSES){let t=Ze.CLUSTERING_PROCESSES[e];if(await w$(t)===!1)return!1}return!0}a(Zue,"isClusteringRunning");async function ede(){await Bo.generateNatsConfig(!0),await RS.reloadNATSHub(),await RS.reloadNATSLeaf(),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Bo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(ede,"reloadClustering")});var NS={};ve(NS,{compactOnStart:()=>tde,copyDb:()=>H$});async function tde(){Wa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,Nw.get)(x.ROOTPATH),t=new Map,r=Je();(0,ww.updateConfigValue)(x.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,bS.join)(e,"backup",n+".mdb"),o=(0,bS.join)(e,yc,n+"-copy.mdb"),c=0;try{c=await M$(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Wa.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await H$(n,o),console.log("Backing up",n,"to",i),await(0,Il.move)(s,i,{overwrite:!0})}try{Cd()}catch(n){Wa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,Il.move)(i,s,{overwrite:!0}),await(0,Il.remove)((0,bS.join)(e,yc,`${n}-copy.mdb-lock`));try{Cd()}catch(n){Wa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Wa.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,ww.updateConfigValue)(x.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,Il.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Cd(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await M$(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
26
26
|
Total record count before compaction: ${i}, total after: ${c}.
|
|
27
|
-
Database backup has not been removed and can be found here: ${s}`;
|
|
28
|
-
${r.stack}`;throw Tw.error(n),w$(new Error)}}}a(Que,"getRolePermissions");function Jue(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Ln.SYSTEM_SCHEMA_NAME]=n[Ln.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]=Xue(t[i]);return}r[i]=D$(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=Zue(c,l);r[i].describe||M$.forEach(f=>{u[f]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=Aw()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=Aw()})}),r}a(Jue,"translateRolePermissions");function Xue(e){let t=D$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=Aw(!0,!0,!0,!0,!0)}),t}a(Xue,"createStructureUserPermissions");function Zue(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,f)=>{let{attribute_name:d}=f,h=f;return Ln.TIME_STAMP_NAMES.includes(d)&&(h=C$(d,f[Lh])),u[d]=h,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=I$(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let f=i[u];f.describe=U$(f),s.attribute_permissions.push(f),c||ede(f,l)}else if(u!==o){let f;Ln.TIME_STAMP_NAMES.includes(u)?f=C$(u):f=I$(u),s.attribute_permissions.push(f)}}),c||s.attribute_permissions.push(l),s.describe=P$(s),s}else return e.describe=P$(e),e}a(Zue,"getTableAttrPerms");function P$(e){return M$.filter(t=>e[t]).length>0}a(P$,"getSchemaTableDescribePerm");function U$(e){return v$.filter(t=>e[t]).length>0}a(U$,"getAttributeDescribePerm");function ede(e,t){v$.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(ede,"checkForHashPerms")});var Mh={};Be(Mh,{authentication:()=>V$,bypassAuth:()=>ade,login:()=>lde,logout:()=>ude,start:()=>cde});function ade(){$$=!0}async function V$(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let _=e.isOperationsServer?sde?nde:[]:rde?tde:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let p=new Po([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return TS&&p.set("Access-Control-Allow-Credentials","true"),{status:200,headers:p}}o.push("Access-Control-Allow-Origin",i),TS&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(TS){i||(i=r.host);let _=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",p=s?.split(/;\s+/)||[];for(let S of p)if(S.startsWith(_)){let g=S.indexOf(";");l=S.slice(_.length,g===-1?S.length:g),u=await H$.get(l);break}e.session=u||(u={})}let f=a((_,p,S)=>{let g=new bd.AuthAuditLog(_,p,ha.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=S,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),p===Qs.SUCCESS?bw.notify(g):bw.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&bw.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let _=e.mtlsConfig.user;_!==null?((_===void 0||_==="Common Name"||_==="CN")&&(_=e.peerCertificate.subject.CN),e.user=await Qe.getUser(_,null,e),f(_,Qs.SUCCESS,"mTLS")):(0,bd.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=Cl.get(n),!d){let _=n.indexOf(" "),p=n.slice(0,_),S=n.slice(_+1),g,T;try{switch(p){case"Basic":let m=atob(S),A=m.indexOf(":");g=m.slice(0,A),T=m.slice(A+1),d=g||T?await Qe.getUser(g,T,e):null;break;case"Bearer":try{d=await(0,AS.validateOperationToken)(S)}catch(w){if(w.message==="invalid token")try{return await(0,AS.validateRefreshToken)(S),c({status:-1})}catch{throw w}}break}}catch(m){return ode&&(Cl.get(S)||(Cl.set(S,S),f(g,Qs.FAILURE,p))),c({status:401,body:Oa({error:m.message},e)})}Cl.set(n,d),ide&&f(d.username,Qs.SUCCESS,p)}e.user=d}else u?.user?e.user=await Qe.getUser(u.user,null,e):($$&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,F$.getSuperUser)());TS&&(e.session.update=function(_){if(!l){l=(0,q$.v4)();let S=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",S):h?.headers?.set&&h.headers.set("Set-Cookie",S)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):h?.headers?.set&&(i&&h.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),h.headers.set("X-Hdb-Session","Secure"))),_.id=l,H$.put(_)},e.login=async function(_,p){let S=e.user=await Qe.getUser(_,p,e);e.session.update({user:S&&(S.getId?.()??S.username)})});let h=await t(e);return h&&(h.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Ci.loginPath?(h.status=302,h.headers.set("Location",Ci.loginPath(e))):h.headers.set("WWW-Authenticate","Basic")),c(h))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let f=l.headers;f||(l.headers=f=new Po);for(let d=0;d<u;){let h=o[d++];f.set(h,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function cde({server:e,port:t,securePort:r}){e.http(V$,t||r?{port:t,securePort:r}:{port:"all"}),k$||(k$=!0,setInterval(()=>{Cl=new Map},Ls.get(H.AUTHENTICATION_CACHETTL)).unref(),G$.user.addListener(()=>{Cl=new Map}))}async function lde(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password??""),"Login successful"}async function ude(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var F$,AS,q$,Ls,bd,G$,bw,tde,rde,nde,sde,H$,TS,$$,ide,ode,Cl,k$,RS=be(()=>{F$=x(An());Yr();hu();AS=x(Fu());Ce();q$=require("uuid"),Ls=x(ce());v();bd=x(W()),G$=x(g_());G_();Eo();bw=(0,bd.loggerWithTag)("auth-event");Ls.initSync();tde=Ls.get(H.HTTP_CORSACCESSLIST),rde=Ls.get(H.HTTP_CORS),nde=Ls.get(H.OPERATIONSAPI_NETWORK_CORSACCESSLIST),sde=Ls.get(H.OPERATIONSAPI_NETWORK_CORS),H$=at({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),TS=Ls.get(H.AUTHENTICATION_ENABLESESSIONS)??!0,$$=process.env.AUTHENTICATION_AUTHORIZELOCAL??Ls.get(H.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,ide=Ls.get(H.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,ode=Ls.get(H.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Cl=new Map;Qe.onInvalidatedUser(()=>{Cl=new Map});a(ade,"bypassAuth");a(V$,"authentication");a(cde,"start");a(lde,"login");a(ude,"logout")});var J$=C((SMe,Q$)=>{"use strict";var Oe=require("joi"),K$=require("fs-extra"),Y$=require("path"),os=pt(),W$=ce(),z$=(v(),D(q)),j$=W(),{hdb_errors:dde}=_e(),{HDB_ERROR_MSGS:nn}=dde,$o=/^[a-zA-Z0-9-_]+$/,fde=/^[a-zA-Z0-9-_]+$/;Q$.exports={getDropCustomFunctionValidator:hde,setCustomFunctionValidator:pde,addComponentValidator:Sde,dropCustomFunctionProjectValidator:Tde,packageComponentValidator:Ade,deployComponentValidator:Rde,setComponentFileValidator:Ede,getComponentFileValidator:gde,dropComponentFileValidator:mde,addSSHKeyValidator:yde,updateSSHKeyValidator:bde,deleteSSHKeyValidator:Ode,setSSHKnownHostsValidator:Nde};function yS(e,t,r){try{let n=W$.get(z$.CONFIG_PARAMS.COMPONENTSROOT),s=Y$.join(n,t);return K$.existsSync(s)?e?t:r.message(nn.PROJECT_EXISTS):e?r.message(nn.NO_PROJECT):t}catch(n){return j$.error(n),r.message(nn.VALIDATION_ERR)}}a(yS,"checkProjectExists");function vh(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(vh,"checkFilePath");function _de(e,t,r,n){try{let s=W$.get(z$.CONFIG_PARAMS.COMPONENTSROOT),i=Y$.join(s,e,t,r+".js");return K$.existsSync(i)?r:n.message(nn.NO_FILE)}catch(s){return j$.error(s),n.message(nn.VALIDATION_ERR)}}a(_de,"checkFileExists");function hde(e){let t=Oe.object({project:Oe.string().pattern($o).custom(yS.bind(null,!0)).required().messages({"string.pattern.base":nn.BAD_PROJECT_NAME}),type:Oe.string().valid("helpers","routes").required(),file:Oe.string().pattern($o).custom(_de.bind(null,e.project,e.type)).custom(vh).required().messages({"string.pattern.base":nn.BAD_FILE_NAME})});return os.validateBySchema(e,t)}a(hde,"getDropCustomFunctionValidator");function pde(e){let t=Oe.object({project:Oe.string().pattern($o).custom(yS.bind(null,!0)).required().messages({"string.pattern.base":nn.BAD_PROJECT_NAME}),type:Oe.string().valid("helpers","routes").required(),file:Oe.string().custom(vh).required(),function_content:Oe.string().required()});return os.validateBySchema(e,t)}a(pde,"setCustomFunctionValidator");function Ede(e){let t=Oe.object({project:Oe.string().pattern($o).required().messages({"string.pattern.base":nn.BAD_PROJECT_NAME}),file:Oe.string().custom(vh).required(),payload:Oe.string().allow("").optional(),encoding:Oe.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return os.validateBySchema(e,t)}a(Ede,"setComponentFileValidator");function mde(e){let t=Oe.object({project:Oe.string().pattern($o).required().messages({"string.pattern.base":nn.BAD_PROJECT_NAME}),file:Oe.string().custom(vh).optional()});return os.validateBySchema(e,t)}a(mde,"dropComponentFileValidator");function gde(e){let t=Oe.object({project:Oe.string().required(),file:Oe.string().custom(vh).required(),encoding:Oe.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return os.validateBySchema(e,t)}a(gde,"getComponentFileValidator");function Sde(e){let t=Oe.object({project:Oe.string().pattern($o).custom(yS.bind(null,!1)).required().messages({"string.pattern.base":nn.BAD_PROJECT_NAME})});return os.validateBySchema(e,t)}a(Sde,"addComponentValidator");function Tde(e){let t=Oe.object({project:Oe.string().pattern($o).custom(yS.bind(null,!0)).required().messages({"string.pattern.base":nn.BAD_PROJECT_NAME})});return os.validateBySchema(e,t)}a(Tde,"dropCustomFunctionProjectValidator");function Ade(e){let t=Oe.object({project:Oe.string().pattern($o).required().messages({"string.pattern.base":nn.BAD_PROJECT_NAME}),skip_node_modules:Oe.boolean(),skip_symlinks:Oe.boolean()});return os.validateBySchema(e,t)}a(Ade,"packageComponentValidator");function Rde(e){let t=Oe.object({project:Oe.string().pattern($o).required().messages({"string.pattern.base":nn.BAD_PROJECT_NAME}),package:Oe.string().optional(),restart:Oe.alternatives().try(Oe.boolean(),Oe.string().valid("rolling")).optional()});return os.validateBySchema(e,t)}a(Rde,"deployComponentValidator");function yde(e){let t=Oe.object({name:Oe.string().pattern(fde).required().messages({"string.pattern.base":nn.BAD_SSH_KEY_NAME}),key:Oe.string().required(),host:Oe.string().required(),hostname:Oe.string().required(),known_hosts:Oe.string().optional()});return os.validateBySchema(e,t)}a(yde,"addSSHKeyValidator");function bde(e){let t=Oe.object({name:Oe.string().required(),key:Oe.string().required()});return os.validateBySchema(e,t)}a(bde,"updateSSHKeyValidator");function Ode(e){let t=Oe.object({name:Oe.string().required()});return os.validateBySchema(e,t)}a(Ode,"deleteSSHKeyValidator");function Nde(e){let t=Oe.object({known_hosts:Oe.string().required()});return os.validateBySchema(e,t)}a(Nde,"setSSHKnownHostsValidator")});var Uh=C((AMe,nV)=>{"use strict";var bS=require("joi"),Xa=require("path"),Od=require("fs-extra"),{exec:wde}=require("child_process"),Ide=require("util"),X$=Ide.promisify(wde),Id=(v(),D(q)),{PACKAGE_ROOT:Cde}=rt(),{handleHDBError:Nd,hdb_errors:Pde}=_e(),{HTTP_STATUS_CODES:wd}=Pde,Pl=ce(),Dde=pt(),Dl=W();Pl.initSync();var Ow=Pl.get(Id.CONFIG_PARAMS.COMPONENTSROOT),Z$="npm install --force --omit=dev --json",Lde=`${Z$} --dry-run`,Mde=Pl.get(Id.CONFIG_PARAMS.ROOTPATH),OS=Xa.join(Mde,"ssh");nV.exports={installModules:Bde,auditModules:Hde,installAllRootModules:vde,uninstallRootModule:Ude,linkHarperdb:xde,runCommand:Cd};async function vde(e=!1,t=Pl.get(Id.CONFIG_PARAMS.ROOTPATH)){await NS();let r=!1,n=process.env;Od.pathExistsSync(OS)&&Od.readdirSync(OS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+Xa.join(OS,"config")+" -o UserKnownHostsFile="+Xa.join(OS,"known_hosts"),...process.env},r=!0)});try{let s=Pl.get(Id.CONFIG_PARAMS.ROOTPATH),i=Xa.join(s,"node_modules","harperdb");Od.lstatSync(i).isSymbolicLink()&&Od.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Dl.error("Error removing symlink:",s)}await Cd(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(vde,"installAllRootModules");async function Ude(e){await Cd(`npm uninstall ${e}`,Pl.get(Id.CONFIG_PARAMS.ROOTPATH))}a(Ude,"uninstallRootModule");async function xde(){await NS(),await Cd(`npm link ${Cde}`,Pl.get(Id.CONFIG_PARAMS.ROOTPATH))}a(xde,"linkHarperdb");async function Cd(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await X$(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
|
|
29
|
-
`,""))}return s&&!s.includes("Debugger listening")&&!s.includes("warn using --force")&&
|
|
30
|
-
`,"")}a(
|
|
31
|
-
`,""):null,h
|
|
32
|
-
`,""):null}catch(_){_.stderr?o[u].npm_error=
|
|
33
|
-
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(eV,"parseNPMStdErr");async function Hde(e){Dl.info(`starting auditModules for request: ${e}`);let t=rV(e);if(t)throw Nd(t,t.message,wd.BAD_REQUEST);let{projects:r}=e;await NS(),await tV(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=Xa.join(Ow,o);n[o]={npm_output:null,npm_error:null};try{let l=await Cd("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=eV(l.stderr)}}return Dl.info(`finished auditModules with response ${n}`),n}a(Hde,"auditModules");async function NS(){try{return await Cd("npm -v"),!0}catch{throw Nd(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",wd.BAD_REQUEST,void 0,void 0,!0)}}a(NS,"checkNPMInstalled");async function tV(e){if(!Array.isArray(e)||e.length===0)throw Nd(new Error,"projects argument must be an array with at least 1 element",wd.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(Ow,i.toString());if(!await Od.pathExists(o)){t.push(i);continue}let l=Xa.join(o,"package.json");await Od.pathExists(l)||r.push(i)}if(t.length>0)throw Nd(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,wd.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw Nd(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,wd.BAD_REQUEST,void 0,void 0,!0)}a(tV,"checkProjectPaths");function rV(e){let t=bS.object({projects:bS.array().min(1).items(bS.string()).required(),dry_run:bS.boolean().default(!1)});return Dde.validateBySchema(e,t)}a(rV,"modulesValidator")});var ww=C((yMe,lV)=>{"use strict";var Ms=require("fs-extra"),Bh=require("path"),xh=W(),sV=ae(),{PACKAGE_ROOT:kde}=rt(),Nw=(v(),D(q)),cV=ce(),Fde=At();lV.exports=qde;async function qde(){let e=Gde(),t=cV.get(Nw.CONFIG_PARAMS.ROOTPATH),r=Bh.join(t,"package.json"),n={dependencies:{harperdb:"file:"+kde}},s=Bh.join(t,"node_modules");Ms.ensureDirSync(s);let i,o=!0,c=!1;try{i=Ms.readJsonSync(r)}catch(l){if(sV.isEmptyOrZeroLength(e))return;if(l.code!==Nw.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!sV.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let f=oV(u);n.dependencies[l]=f+u}if(!o){xh.notify("Installing components"),await aV(r,n,null),await iV(t,e);return}for(let{name:l,package:u}of e){let f=i.dependencies[l],d=oV(u);if(f===void 0||f!==d+u){c=!0;break}if(u.startsWith("file:"))try{if(Ms.statSync(new URL(u+"/package.json")).mtimeMs>Ms.statSync(r).mtimeMs){c=!0;break}}catch(h){xh.info(`Error checking ${u}/package.json modification time`,h);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(xh.notify("Removing component",l),c=!0);c&&(xh.notify("Updating components."),await aV(r,n,i),await iV(t,e))}a(qde,"installComponents");function iV(e,t){return Promise.all(t.map(({name:r})=>{let n=Bh.join(e,"node_modules",r),s=Bh.join(e,"components",r);if(Ms.existsSync(n)&&Ms.lstatSync(n).isDirectory())return Ms.move(n,s,{overwrite:!0}).then(()=>{Ms.symlink(s,n)})}))}a(iV,"moveModuleToComponents");function Gde(){let e=Fde.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(Gde,"getComponentsConfig");function oV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Bh.extname(e)||Ms.existsSync(e)?"file:":"github:"}a(oV,"getPkgPrefix");async function aV(e,t,r){xh.trace("npm installing components package.json",t),Ms.writeFileSync(e,JSON.stringify(t,null," "));try{await Uh().installAllRootModules(cV.get(Nw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Ms.writeFileSync(e,JSON.stringify(r,null," ")):Ms.unlinkSync(e),n}}a(aV,"installPackages")});var Iw={};Be(Iw,{packageDirectory:()=>$de});function $de(e,t={skip_node_modules:!1,skip_symlinks:!1}){return new Promise((r,n)=>{let s=[];dV.default.pack(e,{dereference:!t.skip_symlinks,ignore:t.skip_node_modules?i=>i.includes("node_modules")||i.includes((0,uV.join)("cache","webpack")):void 0}).pipe((0,fV.createGzip)()).on("data",i=>s.push(i)).on("end",()=>{r(Buffer.concat(s))}).on("error",n)})}var uV,dV,fV,Cw=be(()=>{uV=require("path"),dV=x(require("tar-fs")),fV=require("node:zlib");a($de,"packageDirectory")});var Lw=C(EV=>{"use strict";var Re=require("fs-extra"),Pw=require("fast-glob"),Ne=require("path"),Vde=require("tar-fs"),Kde=require("gunzip-maybe"),Dw=require("normalize-path"),Mn=J$(),vt=W(),ot=(v(),D(q)),jt=ce(),wS=At(),Yde=ae(),{PACKAGE_ROOT:Wde}=rt(),{handleHDBError:Ut,hdb_errors:zde}=_e(),{basename:jde}=require("path"),Qde=ww(),hV=ce(),{Readable:Jde}=require("stream"),{isMainThread:Xde}=require("worker_threads"),{HDB_ERROR_MSGS:Ll,HTTP_STATUS_CODES:xt}=zde,pV=nt(),{replicateOperation:pi}=(ts(),D(vo)),{packageDirectory:Zde}=(Cw(),D(Iw)),_V=Uh(),efe=Ne.join(Wde,"application-template"),tfe=jt.get(ot.CONFIG_PARAMS.ROOTPATH),Za=Ne.join(tfe,"ssh"),Vo=Ne.join(Za,"known_hosts");function rfe(){vt.trace("getting custom api status");let e={};try{e={port:jt.get(ot.CONFIG_PARAMS.HTTP_PORT),directory:jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Ut(new Error,Ll.FUNCTION_STATUS,xt.INTERNAL_SERVER_ERROR,vt.ERR,t)}return e}a(rfe,"customFunctionsStatus");function nfe(){vt.trace("getting custom api endpoints");let e={},t=jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT);try{Pw.sync(Dw(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:Pw.sync(Dw(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:Pw.sync(Dw(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Ut(new Error,Ll.GET_FUNCTIONS,xt.INTERNAL_SERVER_ERROR,vt.ERR,r)}return e}a(nfe,"getCustomFunctions");function sfe(e){e.project&&(e.project=Ne.parse(e.project).name),e.file&&(e.file=Ne.parse(e.file).name);let t=Mn.getDropCustomFunctionValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);vt.trace("getting custom api endpoint file content");let r=jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=Ne.join(r,n,s,i+".js");try{return Re.readFileSync(o,{encoding:"utf8"})}catch(c){throw Ut(new Error,Ll.GET_FUNCTION,xt.INTERNAL_SERVER_ERROR,vt.ERR,c)}}a(sfe,"getCustomFunction");async function ife(e){e.project&&(e.project=Ne.parse(e.project).name),e.file&&(e.file=Ne.parse(e.file).name);let t=Mn.setCustomFunctionValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);vt.trace("setting custom function file content");let r=jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Re.outputFileSync(Ne.join(r,n,s,i+".js"),o);let c=await pi(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Ut(new Error,Ll.SET_FUNCTION,xt.INTERNAL_SERVER_ERROR,vt.ERR,c)}}a(ife,"setCustomFunction");async function ofe(e){e.project&&(e.project=Ne.parse(e.project).name),e.file&&(e.file=Ne.parse(e.file).name);let t=Mn.getDropCustomFunctionValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);vt.trace("dropping custom function file");let r=jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Re.unlinkSync(Ne.join(r,n,s,i+".js"));let o=await pi(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Ut(new Error,Ll.DROP_FUNCTION,xt.INTERNAL_SERVER_ERROR,vt.ERR,o)}}a(ofe,"dropCustomFunction");async function afe(e){e.project&&(e.project=Ne.parse(e.project).name);let t=Mn.addComponentValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);vt.trace("adding component");let r=jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=Ne.join(r,n);Re.mkdirSync(s,{recursive:!0}),Re.copySync(efe,s);let i=await pi(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Ut(new Error,Ll.ADD_FUNCTION,xt.INTERNAL_SERVER_ERROR,vt.ERR,s)}}a(afe,"addComponent");async function cfe(e){e.project&&(e.project=Ne.parse(e.project).name);let t=Mn.dropCustomFunctionProjectValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);vt.trace("dropping custom function project");let r=jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=jt.get(ot.CONFIG_PARAMS.APPS);if(!Yde.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 wS.updateConfigValue(ot.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=Ne.join(r,n);Re.rmSync(i,{recursive:!0});let o=await pi(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Ut(new Error,Ll.DROP_FUNCTION_PROJECT,xt.INTERNAL_SERVER_ERROR,vt.ERR,i)}}a(cfe,"dropCustomFunctionProject");async function lfe(e){e.project&&(e.project=Ne.parse(e.project).name);let t=Mn.packageComponentValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);let r=jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;vt.trace("packaging component",n);let s;try{s=await Re.realpath(Ne.join(r,n))}catch(o){if(o.code!==ot.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Re.realpath(Ne.join(jt.get(ot.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===ot.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await Zde(s,e)).toString("base64");return{project:n,payload:i}}a(lfe,"packageComponent");async function ufe(e){e.project?e.project=Ne.parse(e.project).name:e.package&&(e.project=dfe(e.package));let t=Mn.deployComponentValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);let r=jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(vt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=Ne.join(r,n),i="file:"+c,await Re.emptyDir(c);let S=Jde.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((m,A)=>{S.pipe(Kde()).pipe(Vde.extract(c,{finish:m})).on("error",A)});let g=await Re.readdir(c);g.length===1&&g[0]==="package"&&(await Re.copy(Ne.join(c,"package"),c),await Re.remove(Ne.join(c,"package")));let T=Ne.join(c,"node_modules");o?await _V.runCommand(o,c):Re.existsSync(T)||await _V.installAllRootModules(!1,c)}else{await wS.addConfig(n,{package:i}),await Qde();let S=hV.get(ot.CONFIG_PARAMS.ROOTPATH);c=Ne.join(S,"node_modules",n)}if(Xde)return;let l=new Map;l.isWorker=!0;let u=(kh(),D(Hh)),f;u.setErrorReporter(S=>f=S);let d=jde(c),h=u.component_errors.get(d);try{await u.loadComponent(c,l)}finally{u.component_errors.set(d,h)}if(f)throw f;vt.info("Installed component");let _=e.restart==="rolling";e.restart=_?!1:e.restart;let p=await pi(e);if(e.restart===!0)pV.restartWorkers("http"),p.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(_){let g=await Mw().executeJob({operation:"restart_service",service:"http",replicated:!0});p.restartJobId=g.job_id,p.message=`Successfully deployed: ${n}, restarting HarperDB`}else p.message=`Successfully deployed: ${n}`;return p}a(ufe,"deployComponent");function dfe(e){if(e.startsWith("git+ssh://"))return Ne.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return Ne.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Re.readFileSync(Ne.join(e,"package.json"),"utf8"));return Ne.basename(t)}catch{}return Ne.basename(e)}a(dfe,"getProjectNameFromPackage");async function ffe(){let e=a(async(s,i)=>{try{let o=await Re.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=Ne.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let f={name:l,entries:[]};i.entries.push(f),await e(u,f)}else{let f=await Re.stat(u),d={name:Ne.basename(l),mtime:f.mtime,size:f.size};i.entries.push(d)}}return i}catch(o){return vt.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),{name:jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT).split(Ne.sep).slice(-1).pop(),entries:[]}),n=(kh(),D(Hh)).component_errors;for(let s of t.entries){let i=n.get(s.name);i?s.error=n.get(s.name):i===void 0&&(s.error="The component has not been loaded yet (may need a restart)")}return t}a(ffe,"getComponents");async function _fe(e){let t=Mn.getComponentFileValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);let n=wS.getConfigObj()[e.project]||e.project==="harperdb"?Ne.join(hV.get(ot.CONFIG_PARAMS.ROOTPATH),"node_modules"):jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Re.stat(Ne.join(n,e.project,e.file));return{message:await Re.readFile(Ne.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===ot.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${Ne.join(e.project,e.file)}'`):i}}a(_fe,"getComponentFile");async function hfe(e){let t=Mn.setComponentFileValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=Ne.join(jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Re.ensureFile(n),await Re.outputFile(n,e.payload,r)):await Re.ensureDir(n);let s=await pi(e);return s.message="Successfully set component: "+e.file,s}a(hfe,"setComponentFile");async function pfe(e){let t=Mn.dropComponentFileValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?Ne.join(r,n):r,i=Ne.join(jt.get(ot.CONFIG_PARAMS.COMPONENTSROOT),s),o=Ne.join(jt.get(ot.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await Re.pathExists(o)&&await Re.unlink(o),await Re.pathExists(i)&&await Re.remove(i);let c=Ne.join(jt.get(ot.CONFIG_PARAMS.ROOTPATH),"package.json");if(await Re.pathExists(c)){let u=JSON.parse(await Re.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await Re.writeFile(c,JSON.stringify(u,null,2),"utf8")}wS.deleteConfigFromFile([r]);let l=await pi(e);return e.restart===!0?(pV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(pfe,"dropComponent");async function Efe(e){let t=Mn.addSSHKeyValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;vt.trace("adding ssh key",r);let c=Ne.join(Za,r+".key"),l=Ne.join(Za,"config");if(await Re.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Re.outputFile(c,n),await Re.chmod(c,"0600");let u=`#${r}
|
|
27
|
+
Database backup has not been removed and can be found here: ${s}`;Wa.error(l),console.error(l)}(0,Nw.get)(x.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Il.remove)(s))}}async function M$(e){let t=await(0,B$.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function H$(e,t){console.log("copyDb start");let r=Je()[e],n;for(let d in r){n=r[d].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,v$.open)(new U$.default(t)),c=o.openDB(OS.INTERNAL_DBIS_NAME),l,u=0,f=s.useReadTransaction();try{for(let{key:p,value:_}of s.getRange({transaction:f})){let h=_.is_hash_attribute||_.isPrimaryKey,S,g;if(h&&(S=_.compression,g=IS(),g?_.compression=g:delete _.compression,S?.dictionary?.toString()===g?.dictionary?.toString()&&(S=null,g=null)),c.put(p,_),!(h||_.indexed))continue;let A=new x$.default(!h,h);A.encoding="binary",A.compression=S;let E=n.openDB(p,A);E.decoder=null,E.decoderCopies=!1,E.encoding="binary",A.compression=g;let R=o.openDB(p,A);R.encoder=null,console.log("copying",p,"from",e,"to",t),await d(E,R,h,f)}if(i){let p=n.openDB(OS.AUDIT_STORE_NAME,xp);console.log("copying audit log for",e,"to",t),d(i,p,!1,f)}async function d(p,_,h,S){let g=0,A=0,E=1e7,R=null;for(;E-- >0;)try{for(let N of p.getKeys({start:R,transaction:S}))try{R=N;let{value:v,version:k}=p.getEntry(N,{transaction:S});l=_.put(N,v,h?k:void 0),g++,S.openTimer&&(S.openTimer=0),A+=(N?.length||10)+v.length,u++>5e3&&(await l,console.log("copied",g,"entries",A,"bytes"),u=0)}catch(v){console.error("Error copying record",typeof N=="symbol"?"symbol":N,"from",e,"to",t,v)}console.log("finish copying, copied",g,"entries",A,"bytes");return}catch{if(typeof R=="string"){if(R==="z")return console.error("Reached end of dbi",R,"for",e,"to",t);R=R.slice(0,-2)+"z"}else if(typeof R=="number")R++;else return console.error("Unknown key type",R,"for",e,"to",t)}}a(d,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{f.done(),o.close()}}var v$,bS,Il,Nw,U$,x$,OS,B$,ww,Wa,wS=be(()=>{Pe();v$=require("lmdb"),bS=require("path"),Il=require("fs-extra"),Nw=M(ce()),U$=M(i_()),x$=M(s_()),OS=M(vt());B();ho();B$=M(Ao()),ww=M(Rt()),Wa=M(Y());a(tde,"compactOnStart");a(M$,"getTotalDBRecordCount");a(H$,"copyDb")});var za=I((pMe,K$)=>{"use strict";var rde=require("minimist"),{isMainThread:Cw,parentPort:Hp,threadId:dMe}=require("worker_threads"),st=(B(),C(G)),zi=Y(),Pw=oe(),PS=SS(),CS=ir(),fMe=St(),q$=Rt(),_i=Id(),k$=Do(),{compactOnStart:nde}=(wS(),C(NS)),sde=da(),{restartWorkers:DS,onMessageByType:ide}=tt(),{handleHDBError:ode,hdb_errors:ade}=pe(),{HTTP_STATUS_CODES:cde}=ade,kp=ce(),{sendOperationToNode:F$,getThisNodeName:lde,monitorNodeCAs:ude}=(ts(),C(Po)),{getHDBNodeTable:_Me}=(ul(),C(YO));kp.initSync();var Bp=`Restarting HarperDB. This may take up to ${st.RESTART_TIMEOUT_MS/1e3} seconds.`,dde="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",G$="Clustering is not enabled so cannot be restarted",fde="Invalid service",Pd,Ds;K$.exports={restart:$$,restartService:Dw};Cw&&ide(st.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await Dw({service:e.workerType}):$$({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function $$(e){Ds=Object.keys(e).length===0,Pd=await _i.isServiceRegistered(st.PROCESS_DESCRIPTORS.HDB);let t=rde(process.argv);if(t.service){await Dw(t);return}if(Ds&&!Pd){console.error(dde);return}if(Ds&&console.log(Bp),Pd){_i.enterPM2Mode(),zi.notify(Bp);let r=sde(Object.keys(st.CONFIG_PARAM_MAP),!0);return Pw.isEmptyOrZeroLength(Object.keys(r))||q$.updateConfigValue(void 0,void 0,r,!0,!0),_de(),Bp}return Cw?(zi.notify(Bp),kp.get(st.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await nde(),setTimeout(()=>{DS()},50)):Hp.postMessage({type:st.ITC_EVENT_TYPES.RESTART}),Bp}a($$,"restart");async function Dw(e){let{service:t}=e;if(st.HDB_PROCESS_SERVICES[t]===void 0)throw ode(new Error,fde,cde.BAD_REQUEST,void 0,void 0,!0);if(_i.expectedRestartOfChildren(),Pd=await _i.isServiceRegistered(st.PROCESS_DESCRIPTORS.HDB),!Cw){e.replicated&&ude(),Hp.postMessage({type:st.ITC_EVENT_TYPES.RESTART,workerType:t}),Hp.ref(),await new Promise(s=>{Hp.on("message",i=>{i.type==="restart-complete"&&(s(),Hp.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===lde())continue;let{job_id:i}=await F$(s,e);n.push(await new Promise((o,c)=>{let u=2400,f=setInterval(async()=>{if(u--<=0){clearInterval(f);let _=new Error("Timed out waiting for restart job to complete");_.replicated=n,c(_)}let p=(await F$(s,{operation:"get_job",id:i})).results[0];if(p.status==="COMPLETE"&&(clearInterval(f),o({node:s.name,message:p.message})),p.status==="ERROR"){clearInterval(f);let _=new Error(p.message);_.replicated=n,c(_)}},250)}))}return{replicated:n}}return}let r;switch(t){case st.HDB_PROCESS_SERVICES.clustering:if(!kp.get(st.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=G$;break}Ds&&console.log("Restarting clustering"),zi.notify("Restarting clustering"),await V$();break;case st.HDB_PROCESS_SERVICES.clustering_config:case st.HDB_PROCESS_SERVICES["clustering config"]:if(!kp.get(st.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=G$;break}Ds&&console.log("Restarting clustering_config"),zi.notify("Restarting clustering_config"),await _i.reloadClustering();break;case"custom_functions":case"custom functions":case st.HDB_PROCESS_SERVICES.harperdb:case st.HDB_PROCESS_SERVICES.http_workers:case st.HDB_PROCESS_SERVICES.http:if(Ds&&!Pd){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}Ds&&console.log("Restarting http_workers"),zi.notify("Restarting http_workers"),Ds?await _i.restart(st.PROCESS_DESCRIPTORS.HDB):await DS("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(zi.error(r),Ds&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(Dw,"restartService");async function _de(){await V$(),await _i.restart(st.PROCESS_DESCRIPTORS.HDB),await Pw.async_set_timeout(2e3),kp.get(st.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await Iw(),Ds&&(await CS.closeConnection(),process.exit(0))}a(_de,"restartPM2Mode");async function V$(){if(!q$.getConfigFromFile(st.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await k$.getHDBProcessInfo()).clustering.length===0)zi.trace("Clustering not running, restart will start clustering services"),await PS.generateNatsConfig(!0),await _i.startClusteringProcesses(),await _i.startClusteringThreads(),await Iw(),Ds&&await CS.closeConnection();else{await PS.generateNatsConfig(!0),Pd?(zi.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await _i.restart(st.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await _i.restart(st.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await k$.getHDBProcessInfo()).clustering.forEach(s=>{zi.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await Pw.async_set_timeout(3e3),await Iw(),await CS.updateLocalStreams(),Ds&&await CS.closeConnection(),zi.trace("Restart clustering restarting ingest and reply service threads");let t=DS(st.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=DS(st.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(V$,"restartClustering");async function Iw(){await PS.removeNatsConfig(st.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await PS.removeNatsConfig(st.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(Iw,"removeNatsConfig")});var rV=I((EMe,tV)=>{"use strict";var mMe=require("lodash"),Pn=(B(),C(G)),{handleHDBError:Y$,hdb_errors:pde}=pe(),{HDB_ERROR_MSGS:hde,HTTP_STATUS_CODES:mde}=pde,Lw=Y();tV.exports={getRolePermissions:gde};var Cl=Object.create(null),Ede=a(e=>({key:e,perms:{}}),"perms_template_obj"),Q$=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),J$=a((e=!1,t=!1,r=!1,n=!1)=>({[Pn.PERMS_CRUD_ENUM.READ]:e,[Pn.PERMS_CRUD_ENUM.INSERT]:t,[Pn.PERMS_CRUD_ENUM.UPDATE]:r,[Pn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),Mw=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...J$(t,r,n,s)}),"table_perms_template"),W$=a((e,t=J$())=>({attribute_name:e,describe:eV(t),[Fp]:t[Fp],[vw]:t[vw],[Uw]:t[Uw]}),"attr_perms_template"),z$=a((e,t=!1)=>({attribute_name:e,describe:t,[Fp]:t}),"timestamp_attr_perms_template"),{READ:Fp,INSERT:vw,UPDATE:Uw}=Pn.PERMS_CRUD_ENUM,X$=Object.values(Pn.PERMS_CRUD_ENUM),Z$=[Fp,vw,Uw];function gde(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[Pn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Cl[t]&&Cl[t].key===n)return Cl[t].perms;let s=Sde(e,r);return Cl[t]?Cl[t].key=n:Cl[t]=Ede(n),Cl[t].perms=s,s}catch(r){if(!e[Pn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Pn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Pn.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 Lw.error(n),Lw.debug(r),Y$(new Error,hde.OUTDATED_PERMS_TRANSLATION_ERROR,mde.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
28
|
+
${r.stack}`;throw Lw.error(n),Y$(new Error)}}}a(gde,"getRolePermissions");function Sde(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Pn.SYSTEM_SCHEMA_NAME]=n[Pn.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]=Tde(t[i]);return}r[i]=Q$(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=Ade(c,l);r[i].describe||X$.forEach(f=>{u[f]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=Mw()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=Mw()})}),r}a(Sde,"translateRolePermissions");function Tde(e){let t=Q$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=Mw(!0,!0,!0,!0,!0)}),t}a(Tde,"createStructureUserPermissions");function Ade(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,f)=>{let{attribute_name:d}=f,p=f;return Pn.TIME_STAMP_NAMES.includes(d)&&(p=z$(d,f[Fp])),u[d]=p,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=W$(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let f=i[u];f.describe=eV(f),s.attribute_permissions.push(f),c||Rde(f,l)}else if(u!==o){let f;Pn.TIME_STAMP_NAMES.includes(u)?f=z$(u):f=W$(u),s.attribute_permissions.push(f)}}),c||s.attribute_permissions.push(l),s.describe=j$(s),s}else return e.describe=j$(e),e}a(Ade,"getTableAttrPerms");function j$(e){return X$.filter(t=>e[t]).length>0}a(j$,"getSchemaTableDescribePerm");function eV(e){return Z$.filter(t=>e[t]).length>0}a(eV,"getAttributeDescribePerm");function Rde(e,t){Z$.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(Rde,"checkForHashPerms")});var Gp={};ve(Gp,{authentication:()=>lV,bypassAuth:()=>Cde,login:()=>Dde,logout:()=>Lde,start:()=>Pde});function Cde(){cV=!0}async function lV(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let _=e.isOperationsServer?Nde?Ode:[]:bde?yde:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let h=os.get(x.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",S=new No([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",h],["Access-Control-Allow-Origin",i]]);return LS&&S.set("Access-Control-Allow-Credentials","true"),{status:200,headers:S}}o.push("Access-Control-Allow-Origin",i),LS&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(LS){i||(i=r.host);let _=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let S of h)if(S.startsWith(_)){let g=S.indexOf(";");l=S.slice(_.length,g===-1?S.length:g),u=await nV.get(l);break}e.session=u||(u={})}let f=a((_,h,S)=>{let g=new Dd.AuthAuditLog(_,h,ua.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=S,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),h===zs.SUCCESS?xw.notify(g):xw.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&xw.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let _=e.mtlsConfig.user;_!==null?((_===void 0||_==="Common Name"||_==="CN")&&(_=e.peerCertificate.subject.CN),e.user=await We.getUser(_,null,e),f(_,zs.SUCCESS,"mTLS")):(0,Dd.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=Pl.get(n),!d){let _=n.indexOf(" "),h=n.slice(0,_),S=n.slice(_+1),g,A;try{switch(h){case"Basic":let E=atob(S),R=E.indexOf(":");g=E.slice(0,R),A=E.slice(R+1),d=g||A?await We.getUser(g,A,e):null;break;case"Bearer":try{d=await yO(S)}catch(N){if(N.message==="invalid token")try{return await lg(S),c({status:-1})}catch{throw N}}break}}catch(E){return Ide&&(Pl.get(S)||(Pl.set(S,S),f(g,zs.FAILURE,h))),c({status:401,body:ya({error:E.message},e)})}Pl.set(n,d),wde&&f(d.username,zs.SUCCESS,h)}e.user=d}else u?.user?e.user=await We.getUser(u.user,null,e):(cV&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,iV.getSuperUser)());LS&&(e.session.update=function(_){if(!l){l=(0,oV.v4)();let S=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",S):p?.headers?.set&&p.headers.set("Set-Cookie",S)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):p?.headers?.set&&(i&&p.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),p.headers.set("X-Hdb-Session","Secure"))),_.id=l,nV.put(_)},e.login=async function(_,h){let S=e.user=await We.authenticateUser(_,h,e);e.session.update({user:S&&(S.getId?.()??S.username)})});let p=await t(e);return p&&(p.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Ii.loginPath?(p.status=302,p.headers.set("Location",Ii.loginPath(e))):p.headers.set("WWW-Authenticate","Basic")),c(p))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let f=l.headers;f||(l.headers=f=new No);for(let d=0;d<u;){let p=o[d++];f.set(p,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function Pde({server:e,port:t,securePort:r}){e.http(lV,t||r?{port:t,securePort:r}:{port:"all"}),sV||(sV=!0,setInterval(()=>{Pl=new Map},os.get(x.AUTHENTICATION_CACHETTL)).unref(),aV.user.addListener(()=>{Pl=new Map}))}async function Dde(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 Lde(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var iV,oV,os,Dd,aV,xw,yde,bde,Ode,Nde,nV,LS,cV,wde,Ide,Pl,sV,MS=be(()=>{iV=M(Rn());Kr();Su();zu();Pe();oV=require("uuid"),os=M(ce());B();Dd=M(Y()),aV=M(N_());Q_();fo();xw=(0,Dd.loggerWithTag)("auth-event");os.initSync();yde=os.get(x.HTTP_CORSACCESSLIST),bde=os.get(x.HTTP_CORS),Ode=os.get(x.OPERATIONSAPI_NETWORK_CORSACCESSLIST),Nde=os.get(x.OPERATIONSAPI_NETWORK_CORS),nV=lt({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),LS=os.get(x.AUTHENTICATION_ENABLESESSIONS)??!0,cV=process.env.AUTHENTICATION_AUTHORIZELOCAL??os.get(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,wde=os.get(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ide=os.get(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Pl=new Map;We.onInvalidatedUser(()=>{Pl=new Map});a(Cde,"bypassAuth");a(lV,"authentication");a(Pde,"start");a(Dde,"login");a(Lde,"logout")});var mV=I((wMe,hV)=>{"use strict";var Ne=require("joi"),uV=require("fs-extra"),dV=require("path"),as=ut(),fV=ce(),_V=(B(),C(G)),pV=Y(),{hdb_errors:Mde}=pe(),{HDB_ERROR_MSGS:rn}=Mde,ko=/^[a-zA-Z0-9-_]+$/,vde=/^[a-zA-Z0-9-_]+$/;hV.exports={getDropCustomFunctionValidator:xde,setCustomFunctionValidator:Bde,addComponentValidator:Gde,dropCustomFunctionProjectValidator:qde,packageComponentValidator:$de,deployComponentValidator:Vde,setComponentFileValidator:Hde,getComponentFileValidator:Fde,dropComponentFileValidator:kde,addSSHKeyValidator:Kde,updateSSHKeyValidator:Yde,deleteSSHKeyValidator:Wde,setSSHKnownHostsValidator:zde};function vS(e,t,r){try{let n=fV.get(_V.CONFIG_PARAMS.COMPONENTSROOT),s=dV.join(n,t);return uV.existsSync(s)?e?t:r.message(rn.PROJECT_EXISTS):e?r.message(rn.NO_PROJECT):t}catch(n){return pV.error(n),r.message(rn.VALIDATION_ERR)}}a(vS,"checkProjectExists");function qp(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(qp,"checkFilePath");function Ude(e,t,r,n){try{let s=fV.get(_V.CONFIG_PARAMS.COMPONENTSROOT),i=dV.join(s,e,t,r+".js");return uV.existsSync(i)?r:n.message(rn.NO_FILE)}catch(s){return pV.error(s),n.message(rn.VALIDATION_ERR)}}a(Ude,"checkFileExists");function xde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(ko).custom(Ude.bind(null,e.project,e.type)).custom(qp).required().messages({"string.pattern.base":rn.BAD_FILE_NAME})});return as.validateBySchema(e,t)}a(xde,"getDropCustomFunctionValidator");function Bde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom(qp).required(),function_content:Ne.string().required()});return as.validateBySchema(e,t)}a(Bde,"setCustomFunctionValidator");function Hde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).required(),payload:Ne.string().allow("").optional(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return as.validateBySchema(e,t)}a(Hde,"setComponentFileValidator");function kde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).optional()});return as.validateBySchema(e,t)}a(kde,"dropComponentFileValidator");function Fde(e){let t=Ne.object({project:Ne.string().required(),file:Ne.string().custom(qp).required(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return as.validateBySchema(e,t)}a(Fde,"getComponentFileValidator");function Gde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!1)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME})});return as.validateBySchema(e,t)}a(Gde,"addComponentValidator");function qde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME})});return as.validateBySchema(e,t)}a(qde,"dropCustomFunctionProjectValidator");function $de(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean(),skip_symlinks:Ne.boolean()});return as.validateBySchema(e,t)}a($de,"packageComponentValidator");function Vde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.alternatives().try(Ne.boolean(),Ne.string().valid("rolling")).optional()});return as.validateBySchema(e,t)}a(Vde,"deployComponentValidator");function Kde(e){let t=Ne.object({name:Ne.string().pattern(vde).required().messages({"string.pattern.base":rn.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return as.validateBySchema(e,t)}a(Kde,"addSSHKeyValidator");function Yde(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return as.validateBySchema(e,t)}a(Yde,"updateSSHKeyValidator");function Wde(e){let t=Ne.object({name:Ne.string().required()});return as.validateBySchema(e,t)}a(Wde,"deleteSSHKeyValidator");function zde(e){let t=Ne.object({known_hosts:Ne.string().required()});return as.validateBySchema(e,t)}a(zde,"setSSHKnownHostsValidator")});var Kp=I((CMe,RV)=>{"use strict";var US=require("joi"),ja=require("path"),Ld=require("fs-extra"),{exec:jde}=require("child_process"),Qde=require("util"),EV=Qde.promisify(jde),Md=(B(),C(G)),{PACKAGE_ROOT:Jde}=nt(),{handleHDBError:$p,hdb_errors:Xde}=pe(),{HTTP_STATUS_CODES:Vp}=Xde,Dl=ce(),Zde=ut(),Ll=Y();Dl.initSync();var Bw=Dl.get(Md.CONFIG_PARAMS.COMPONENTSROOT),gV="npm install --force --omit=dev --json",efe=`${gV} --dry-run`,tfe=Dl.get(Md.CONFIG_PARAMS.ROOTPATH),xS=ja.join(tfe,"ssh");RV.exports={installModules:ife,auditModules:ofe,installAllRootModules:rfe,uninstallRootModule:nfe,linkHarperdb:sfe,runCommand:vd};async function rfe(e=!1,t=Dl.get(Md.CONFIG_PARAMS.ROOTPATH)){await BS();let r=!1,n=process.env;Ld.pathExistsSync(xS)&&Ld.readdirSync(xS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+ja.join(xS,"config")+" -o UserKnownHostsFile="+ja.join(xS,"known_hosts"),...process.env},r=!0)});try{let s=Dl.get(Md.CONFIG_PARAMS.ROOTPATH),i=ja.join(s,"node_modules","harperdb");Ld.lstatSync(i).isSymbolicLink()&&Ld.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Ll.error("Error removing symlink:",s)}await vd(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(rfe,"installAllRootModules");async function nfe(e){await vd(`npm uninstall ${e}`,Dl.get(Md.CONFIG_PARAMS.ROOTPATH))}a(nfe,"uninstallRootModule");async function sfe(){await BS(),await vd(`npm link ${Jde}`,Dl.get(Md.CONFIG_PARAMS.ROOTPATH))}a(sfe,"linkHarperdb");async function vd(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await EV(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
|
|
29
|
+
`,""))}return s&&!s.includes("Debugger listening")&&!s.includes("warn using --force")&&Ll.error("Error running NPM command:",e,s),Ll.trace(n,s),n?.replace(`
|
|
30
|
+
`,"")}a(vd,"runCommand");async function ife(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Ll.warn(t,e);let r=AV(e);if(r)throw $p(r,r.message,Vp.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?efe:gV;await BS(),await TV(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let f=ja.join(Bw,u),d,p=null;try{let{stdout:_,stderr:h}=await EV(i,{cwd:f});d=_?_.replace(`
|
|
31
|
+
`,""):null,p=h?h.replace(`
|
|
32
|
+
`,""):null}catch(_){_.stderr?o[u].npm_error=SV(_.stderr):o[u].npm_error=_.message;continue}try{o[u].npm_output=JSON.parse(d)}catch{o[u].npm_output=d}try{o[u].npm_error=JSON.parse(p)}catch{o[u].npm_error=p}}return Ll.info(`finished installModules with response ${o}`),o.warning=t,o}a(ife,"installModules");function SV(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
|
|
33
|
+
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(SV,"parseNPMStdErr");async function ofe(e){Ll.info(`starting auditModules for request: ${e}`);let t=AV(e);if(t)throw $p(t,t.message,Vp.BAD_REQUEST);let{projects:r}=e;await BS(),await TV(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=ja.join(Bw,o);n[o]={npm_output:null,npm_error:null};try{let l=await vd("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=SV(l.stderr)}}return Ll.info(`finished auditModules with response ${n}`),n}a(ofe,"auditModules");async function BS(){return await vd("npm -v"),!0}a(BS,"checkNPMInstalled");async function TV(e){if(!Array.isArray(e)||e.length===0)throw $p(new Error,"projects argument must be an array with at least 1 element",Vp.BAD_REQUEST,void 0,void 0,!0);let t=[],r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n],o=ja.join(Bw,i.toString());if(!await Ld.pathExists(o)){t.push(i);continue}let l=ja.join(o,"package.json");await Ld.pathExists(l)||r.push(i)}if(t.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Vp.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Vp.BAD_REQUEST,void 0,void 0,!0)}a(TV,"checkProjectPaths");function AV(e){let t=US.object({projects:US.array().min(1).items(US.string()).required(),dry_run:US.boolean().default(!1)});return Zde.validateBySchema(e,t)}a(AV,"modulesValidator")});var kw=I((DMe,IV)=>{"use strict";var Ls=require("fs-extra"),Wp=require("path"),Yp=Y(),yV=oe(),{PACKAGE_ROOT:afe}=nt(),Hw=(B(),C(G)),wV=ce(),cfe=Rt();IV.exports=lfe;async function lfe(){let e=ufe(),t=wV.get(Hw.CONFIG_PARAMS.ROOTPATH),r=Wp.join(t,"package.json"),n={dependencies:{harperdb:"file:"+afe}},s=Wp.join(t,"node_modules");Ls.ensureDirSync(s);let i,o=!0,c=!1;try{i=Ls.readJsonSync(r)}catch(l){if(yV.isEmptyOrZeroLength(e))return;if(l.code!==Hw.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!yV.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let f=OV(u);n.dependencies[l]=f+u}if(!o){Yp.notify("Installing components"),await NV(r,n,null),await bV(t,e);return}for(let{name:l,package:u}of e){let f=i.dependencies[l],d=OV(u);if(f===void 0||f!==d+u){c=!0;break}if(u.startsWith("file:"))try{if(Ls.statSync(new URL(u+"/package.json")).mtimeMs>Ls.statSync(r).mtimeMs){c=!0;break}}catch(p){Yp.info(`Error checking ${u}/package.json modification time`,p);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Yp.notify("Removing component",l),c=!0);c&&(Yp.notify("Updating components."),await NV(r,n,i),await bV(t,e))}a(lfe,"installComponents");function bV(e,t){return Promise.all(t.map(({name:r})=>{let n=Wp.join(e,"node_modules",r),s=Wp.join(e,"components",r);if(Ls.existsSync(n)&&Ls.lstatSync(n).isDirectory())return Ls.move(n,s,{overwrite:!0}).then(()=>{Ls.symlink(s,n)})}))}a(bV,"moveModuleToComponents");function ufe(){let e=cfe.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(ufe,"getComponentsConfig");function OV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Wp.extname(e)||Ls.existsSync(e)?"file:":"github:"}a(OV,"getPkgPrefix");async function NV(e,t,r){Yp.trace("npm installing components package.json",t),Ls.writeFileSync(e,JSON.stringify(t,null," "));try{await Kp().installAllRootModules(wV.get(Hw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Ls.writeFileSync(e,JSON.stringify(r,null," ")):Ls.unlinkSync(e),n}}a(NV,"installPackages")});var Fw={};ve(Fw,{packageDirectory:()=>dfe});function dfe(e,t={skip_node_modules:!1,skip_symlinks:!1}){return new Promise((r,n)=>{let s=[];PV.default.pack(e,{dereference:!t.skip_symlinks,ignore:t.skip_node_modules?i=>i.includes("node_modules")||i.includes((0,CV.join)("cache","webpack")):void 0}).pipe((0,DV.createGzip)()).on("data",i=>s.push(i)).on("end",()=>{r(Buffer.concat(s))}).on("error",n)})}var CV,PV,DV,Gw=be(()=>{CV=require("path"),PV=M(require("tar-fs")),DV=require("node:zlib");a(dfe,"packageDirectory")});var Vw=I(UV=>{"use strict";var Oe=require("fs-extra"),qw=require("fast-glob"),we=require("path"),ffe=require("tar-fs"),_fe=require("gunzip-maybe"),$w=require("normalize-path"),Dn=mV(),Ut=Y(),at=(B(),C(G)),zt=ce(),HS=Rt(),pfe=oe(),{PACKAGE_ROOT:hfe}=nt(),{handleHDBError:xt,hdb_errors:mfe}=pe(),{basename:Efe}=require("path"),gfe=kw(),MV=ce(),{Readable:Sfe}=require("stream"),{isMainThread:Tfe}=require("worker_threads"),{HDB_ERROR_MSGS:Ml,HTTP_STATUS_CODES:Bt}=mfe,vV=tt(),{replicateOperation:pi}=(ts(),C(Po)),{packageDirectory:Afe}=(Gw(),C(Fw)),LV=Kp(),Rfe=we.join(hfe,"application-template"),yfe=zt.get(at.CONFIG_PARAMS.ROOTPATH),Qa=we.join(yfe,"ssh"),Fo=we.join(Qa,"known_hosts");function bfe(){Ut.trace("getting custom api status");let e={};try{e={port:zt.get(at.CONFIG_PARAMS.HTTP_PORT),directory:zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw xt(new Error,Ml.FUNCTION_STATUS,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,t)}return e}a(bfe,"customFunctionsStatus");function Ofe(){Ut.trace("getting custom api endpoints");let e={},t=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT);try{qw.sync($w(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:qw.sync($w(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:qw.sync($w(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw xt(new Error,Ml.GET_FUNCTIONS,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,r)}return e}a(Ofe,"getCustomFunctions");function Nfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Dn.getDropCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("getting custom api endpoint file content");let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=we.join(r,n,s,i+".js");try{return Oe.readFileSync(o,{encoding:"utf8"})}catch(c){throw xt(new Error,Ml.GET_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,c)}}a(Nfe,"getCustomFunction");async function wfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Dn.setCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("setting custom function file content");let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Oe.outputFileSync(we.join(r,n,s,i+".js"),o);let c=await pi(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw xt(new Error,Ml.SET_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,c)}}a(wfe,"setCustomFunction");async function Ife(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Dn.getDropCustomFunctionValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("dropping custom function file");let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Oe.unlinkSync(we.join(r,n,s,i+".js"));let o=await pi(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw xt(new Error,Ml.DROP_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,o)}}a(Ife,"dropCustomFunction");async function Cfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Dn.addComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("adding component");let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=we.join(r,n);Oe.mkdirSync(s,{recursive:!0}),Oe.copySync(Rfe,s);let i=await pi(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw xt(new Error,Ml.ADD_FUNCTION,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,s)}}a(Cfe,"addComponent");async function Pfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Dn.dropCustomFunctionProjectValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);Ut.trace("dropping custom function project");let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=zt.get(at.CONFIG_PARAMS.APPS);if(!pfe.isEmptyOrZeroLength(s)){let i=!1;for(let[o,c]of s.entries())if(c.name===n){s.splice(o,1),i=!0;break}if(i)return HS.updateConfigValue(at.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=we.join(r,n);Oe.rmSync(i,{recursive:!0});let o=await pi(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw xt(new Error,Ml.DROP_FUNCTION_PROJECT,Bt.INTERNAL_SERVER_ERROR,Ut.ERR,i)}}a(Pfe,"dropCustomFunctionProject");async function Dfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Dn.packageComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ut.trace("packaging component",n);let s;try{s=await Oe.realpath(we.join(r,n))}catch(o){if(o.code!==at.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Oe.realpath(we.join(zt.get(at.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===at.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await Afe(s,e)).toString("base64");return{project:n,payload:i}}a(Dfe,"packageComponent");async function Lfe(e){e.project?e.project=we.parse(e.project).name:e.package&&(e.project=Mfe(e.package));let t=Dn.deployComponentValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(Ut.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=we.join(r,n),i="file:"+c,await Oe.emptyDir(c);let S=Sfe.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((E,R)=>{S.pipe(_fe()).pipe(ffe.extract(c,{finish:E})).on("error",R)});let g=await Oe.readdir(c);g.length===1&&g[0]==="package"&&(await Oe.copy(we.join(c,"package"),c),await Oe.remove(we.join(c,"package")));let A=we.join(c,"node_modules");o?await LV.runCommand(o,c):Oe.existsSync(A)||await LV.installAllRootModules(!1,c)}else{await HS.addConfig(n,{package:i}),await gfe();let S=MV.get(at.CONFIG_PARAMS.ROOTPATH);c=we.join(S,"node_modules",n)}if(Tfe)return;let l=new Map;l.isWorker=!0;let u=(jp(),C(zp)),f;u.setErrorReporter(S=>f=S);let d=Efe(c),p=u.component_errors.get(d);try{await u.loadComponent(c,l)}finally{u.component_errors.set(d,p)}if(f)throw f;Ut.info("Installed component");let _=e.restart==="rolling";e.restart=_?!1:e.restart;let h=await pi(e);if(e.restart===!0)vV.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(_){let g=await Kw().executeJob({operation:"restart_service",service:"http",replicated:!0});h.restartJobId=g.job_id,h.message=`Successfully deployed: ${n}, restarting HarperDB`}else h.message=`Successfully deployed: ${n}`;return h}a(Lfe,"deployComponent");function Mfe(e){if(e.startsWith("git+ssh://"))return we.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return we.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Oe.readFileSync(we.join(e,"package.json"),"utf8"));return we.basename(t)}catch{}return we.basename(e)}a(Mfe,"getProjectNameFromPackage");async function vfe(){let e=a(async(s,i)=>{try{let o=await Oe.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=we.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let f={name:l,entries:[]};i.entries.push(f),await e(u,f)}else{let f=await Oe.stat(u),d={name:we.basename(l),mtime:f.mtime,size:f.size};i.entries.push(d)}}return i}catch(o){return Ut.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),{name:zt.get(at.CONFIG_PARAMS.COMPONENTSROOT).split(we.sep).slice(-1).pop(),entries:[]}),n=(jp(),C(zp)).component_errors;for(let s of t.entries){let i=n.get(s.name);i?s.error=n.get(s.name):i===void 0&&(s.error="The component has not been loaded yet (may need a restart)")}return t}a(vfe,"getComponents");async function Ufe(e){let t=Dn.getComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let n=HS.getConfigObj()[e.project]||e.project==="harperdb"?we.join(MV.get(at.CONFIG_PARAMS.ROOTPATH),"node_modules"):zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Oe.stat(we.join(n,e.project,e.file));return{message:await Oe.readFile(we.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===at.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${we.join(e.project,e.file)}'`):i}}a(Ufe,"getComponentFile");async function xfe(e){let t=Dn.setComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=we.join(zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Oe.ensureFile(n),await Oe.outputFile(n,e.payload,r)):await Oe.ensureDir(n);let s=await pi(e);return s.message="Successfully set component: "+e.file,s}a(xfe,"setComponentFile");async function Bfe(e){let t=Dn.dropComponentFileValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?we.join(r,n):r,i=we.join(zt.get(at.CONFIG_PARAMS.COMPONENTSROOT),s),o=we.join(zt.get(at.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await Oe.pathExists(o)&&await Oe.unlink(o),await Oe.pathExists(i)&&await Oe.remove(i);let c=we.join(zt.get(at.CONFIG_PARAMS.ROOTPATH),"package.json");if(await Oe.pathExists(c)){let u=JSON.parse(await Oe.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await Oe.writeFile(c,JSON.stringify(u,null,2),"utf8")}HS.deleteConfigFromFile([r]);let l=await pi(e);return e.restart===!0?(vV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(Bfe,"dropComponent");async function Hfe(e){let t=Dn.addSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Ut.trace("adding ssh key",r);let c=we.join(Qa,r+".key"),l=we.join(Qa,"config");if(await Oe.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Oe.outputFile(c,n),await Oe.chmod(c,"0600");let u=`#${r}
|
|
34
34
|
Host ${s}
|
|
35
35
|
HostName ${i}
|
|
36
36
|
User git
|
|
37
37
|
IdentityFile ${c}
|
|
38
|
-
IdentitiesOnly yes`;await
|
|
39
|
-
`+u):await
|
|
40
|
-
`)}catch{f=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Re.appendFile(Vo,o);let d=await pi(e);return d.message=`Added ssh key: ${r}${f}`,d}a(Efe,"addSSHKey");async function mfe(e){let t=Mn.updateSSHKeyValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);let{name:r,key:n}=e;vt.trace("updating ssh key",r);let s=Ne.join(Za,r+".key");if(!await Re.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Re.outputFile(s,n);let i=await pi(e);return i.message=`Updated ssh key: ${r}`,i}a(mfe,"updateSSHKey");async function gfe(e){let t=Mn.deleteSSHKeyValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);let{name:r}=e;vt.trace("deleting ssh key",r);let n=Ne.join(Za,r+".key"),s=Ne.join(Za,"config");if(!await Re.pathExists(n))throw new Error("Key does not exist");let i=await Re.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Re.outputFile(s,i),Re.removeSync(n);let c=await pi(e);return c.message=`Deleted ssh key: ${r}`,c}a(gfe,"deleteSSHKey");async function Sfe(e){let t=[];return await Re.pathExists(Za)&&(await Re.readdir(Za)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(Sfe,"listSSHKeys");async function Tfe(e){let t=Mn.setSSHKnownHostsValidator(e);if(t)throw Ut(t,t.message,xt.BAD_REQUEST);let{known_hosts:r}=e;await Re.outputFile(Vo,r);let n=await pi(e);return n.message="Known hosts successfully set",n}a(Tfe,"setSSHKnownHosts");async function Afe(e){return await Re.pathExists(Vo)?{known_hosts:await Re.readFile(Vo,"utf8")}:{known_hosts:null}}a(Afe,"getSSHKnownHosts");Object.assign(EV,{customFunctionsStatus:rfe,getCustomFunctions:nfe,getCustomFunction:sfe,setCustomFunction:ife,dropCustomFunction:ofe,addComponent:afe,dropCustomFunctionProject:cfe,packageComponent:lfe,deployComponent:ufe,getComponents:ffe,getComponentFile:_fe,setComponentFile:hfe,dropComponent:pfe,addSSHKey:Efe,updateSSHKey:mfe,deleteSSHKey:gfe,listSSHKeys:Sfe,setSSHKnownHosts:Tfe,getSSHKnownHosts:Afe})});var vw=C((IMe,gV)=>{"use strict";var vs=require("joi"),mV=pt();gV.exports={readTransactionLogValidator:Rfe,deleteTransactionLogsBeforeValidator:yfe};function Rfe(e){let t=vs.object({schema:vs.string(),database:vs.string(),table:vs.string().required(),from:vs.date().timestamp(),to:vs.date().timestamp(),limit:vs.number().min(1)});return mV.validateBySchema(e,t)}a(Rfe,"readTransactionLogValidator");function yfe(e){let t=vs.object({schema:vs.string(),database:vs.string(),table:vs.string().required(),timestamp:vs.date().timestamp().required()});return mV.validateBySchema(e,t)}a(yfe,"deleteTransactionLogsBeforeValidator")});var PS=C((PMe,bV)=>{"use strict";var Uw=(v(),D(q)),Fh=ar(),SV=ae(),TV=ce(),AV=bo(),RV=W(),{handleHDBError:IS,hdb_errors:bfe}=_e(),{HTTP_STATUS_CODES:CS}=bfe,{readTransactionLogValidator:Ofe,deleteTransactionLogsBeforeValidator:Nfe}=vw(),yV=Wn(),wfe="Logs successfully deleted from transaction log.",Ife="All logs successfully deleted from transaction log.";bV.exports={readTransactionLog:Cfe,deleteTransactionLogsBefore:Dfe};async function Cfe(e){let t=Ofe(e);if(t)throw IS(t,t.message,CS.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=SV.checkSchemaTableExist(e.database,e.table);if(r)throw IS(new Error,r,CS.NOT_FOUND,void 0,void 0,!0);return TV.get(Uw.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Pfe(e):(RV.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)),yV.readAuditLog(e))}a(Cfe,"readTransactionLog");async function*Pfe(e){let t=AV.createNatsTableStreamName(e.database,e.table),r=await Fh.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===Uw.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Pfe,"readTransactionLogNats");async function Dfe(e){let t=Nfe(e);if(t)throw IS(t,t.message,CS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!TV.get(Uw.CONFIG_PARAMS.CLUSTERING_ENABLED))return RV.info("Delete transaction logs called for Plexus"),yV.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=SV.checkSchemaTableExist(r,n);if(i)throw IS(new Error,i,CS.NOT_FOUND,void 0,void 0,!0);let o=AV.createNatsTableStreamName(r,n),{jsm:c}=await Fh.getNATSReferences(),l=await Fh.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let f=wfe,d,h=new Date(l.state.last_ts).getTime();return s>h?(d=l.state.last_seq+1,f=Ife):d=(await Fh.viewStream(o,parseInt(s),1))[0].nats_sequence,await Fh.purgeTableStream(r,n,{seq:d}),f}a(Dfe,"deleteTransactionLogsBefore")});var NV=C((LMe,OV)=>{"use strict";var xw=class{static{a(this,"PermissionTableResponseObject")}constructor(t,r,n=[],s=[]){this.schema=t,this.table=r,this.required_table_permissions=n,this.required_attribute_permissions=s}};OV.exports=xw});var IV=C((vMe,wV)=>{"use strict";var Bw=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};wV.exports=Bw});var kw=C((xMe,PV)=>{"use strict";var CV=NV(),Lfe=IV(),{HDB_ERROR_MSGS:Mfe}=Fn(),Hw=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=Mfe.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 CV(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new Lfe(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 CV(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}};PV.exports=Hw});var vS=C((FMe,WV)=>{"use strict";var Fw=Rn(),DS=zr(),Us=Lg(),$h=Oo(),qw=Vc(),vfe=lN(),Ufe=VF(),Vh=An(),LS=v_(),Rr=W(),xfe=hN(),Bfe=ud(),Hfe=kN(),kfe=Kg(),Ffe=GN(),qfe=$N(),Gfe=jg(),$fe=Jg(),Gw=Xg(),Ko=ae(),Vfe=yG(),$w=nS(),MV=Ja(),sn=(v(),D(q)),vV=B$(),Kfe=Uo(),UV=Fu(),xV=(RS(),D(Mh)),BV=At(),lr=Lw(),Yfe=require("alasql"),HV=PS(),kV=Uh(),Pd=rs(),FV=(Tl(),D(Sl)),qV=kw(),{handleHDBError:vn,hdb_errors:GV}=_e(),{addNodeBack:HMe,removeNodeBack:kMe}=(Tl(),D(Sl)),{HDB_ERROR_MSGS:Hr,HTTP_STATUS_CODES:qh}=GV,J=new Map,$V="delete",ec="insert",Yo="read",Ml="update",Gh="describe",DV=$h.describeSchema.name,LV=$h.describeTable.name,VV={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},Wfe={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},zfe="catchup",jfe="handleGetJob",Qfe="handleGetJobsByStartDate",MS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},Jfe=[Us.createTable.name,Us.createAttribute.name,Us.dropTable.name,Us.dropAttribute.name],KV={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},te=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};J.set(Fw.insert.name,new te(!1,[ec]));J.set(Fw.update.name,new te(!1,[Ml]));J.set(Fw.upsert.name,new te(!1,[ec,Ml]));J.set(DS.searchByConditions.name,new te(!1,[Yo]));J.set(DS.searchByHash.name,new te(!1,[Yo]));J.set(DS.searchByValue.name,new te(!1,[Yo]));J.set(DS.search.name,new te(!1,[Yo]));J.set(Us.createSchema.name,new te(!0,[]));J.set(Us.createTable.name,new te(!0,[]));J.set(Us.createAttribute.name,new te(!1,[ec]));J.set(Us.dropSchema.name,new te(!0,[]));J.set(Us.dropTable.name,new te(!0,[]));J.set(Us.dropAttribute.name,new te(!0,[]));J.set($h.describeSchema.name,new te(!1,[Yo]));J.set($h.describeTable.name,new te(!1,[Yo]));J.set(qw.deleteRecord.name,new te(!1,[$V]));J.set(Vh.addUser.name,new te(!0,[]));J.set(Vh.alterUser.name,new te(!0,[]));J.set(Vh.dropUser.name,new te(!0,[]));J.set(Vh.listUsersExternal.name,new te(!0,[]));J.set(LS.listRoles.name,new te(!0,[]));J.set(LS.addRole.name,new te(!0,[]));J.set(LS.alterRole.name,new te(!0,[]));J.set(LS.dropRole.name,new te(!0,[]));J.set(xfe.name,new te(!0,[]));J.set(Bfe.name,new te(!0,[]));J.set(Hfe.name,new te(!0,[]));J.set(kfe.name,new te(!0,[]));J.set(Ffe.name,new te(!0,[]));J.set(qfe.name,new te(!0,[]));J.set(Gw.setRoutes.name,new te(!0,[]));J.set(Gw.getRoutes.name,new te(!0,[]));J.set(Gw.deleteRoutes.name,new te(!0,[]));J.set(BV.setConfiguration.name,new te(!0,[]));J.set(Gfe.clusterStatus.name,new te(!0,[]));J.set($fe.name,new te(!0,[]));J.set($w.getFingerprint.name,new te(!0,[]));J.set($w.setLicense.name,new te(!0,[]));J.set(qw.deleteFilesBefore.name,new te(!0,[]));J.set(qw.deleteAuditLogsBefore.name,new te(!0,[]));J.set(MV.restart.name,new te(!0,[]));J.set(MV.restartService.name,new te(!0,[]));J.set(vfe.name,new te(!0,[]));J.set(Ufe.name,new te(!0,[Yo]));J.set(Kfe.systemInformation.name,new te(!0,[]));J.set(BV.getConfiguration.name,new te(!0,[]));J.set(HV.readTransactionLog.name,new te(!0,[]));J.set(HV.deleteTransactionLogsBefore.name,new te(!0,[]));J.set(kV.installModules.name,new te(!0,[]));J.set(kV.auditModules.name,new te(!0,[]));J.set(Pd.createCsr.name,new te(!0,[]));J.set(Pd.signCertificate.name,new te(!0,[]));J.set(Pd.listCertificates.name,new te(!0,[]));J.set(Pd.addCertificate.name,new te(!0,[]));J.set(Pd.removeCertificate.name,new te(!0,[]));J.set(Pd.getKey.name,new te(!0,[]));J.set(FV.addNodeBack.name,new te(!0,[]));J.set(FV.removeNodeBack.name,new te(!0,[]));J.set(UV.createTokens.name,new te(!1,[]));J.set(UV.refreshOperationToken.name,new te(!1,[]));J.set(xV.login.name,new te(!1,[]));J.set(xV.logout.name,new te(!1,[]));J.set(lr.customFunctionsStatus.name,new te(!0,[]));J.set(lr.getCustomFunctions.name,new te(!0,[]));J.set(lr.getComponents.name,new te(!0,[]));J.set(lr.getComponentFile.name,new te(!0,[]));J.set(lr.setComponentFile.name,new te(!0,[]));J.set(lr.dropComponent.name,new te(!0,[]));J.set(lr.getCustomFunction.name,new te(!0,[]));J.set(lr.setCustomFunction.name,new te(!0,[]));J.set(lr.dropCustomFunction.name,new te(!0,[]));J.set(lr.addComponent.name,new te(!0,[]));J.set(lr.dropCustomFunctionProject.name,new te(!0,[]));J.set(lr.packageComponent.name,new te(!0,[]));J.set(lr.deployComponent.name,new te(!0,[]));J.set(lr.addSSHKey.name,new te(!0,[]));J.set(lr.updateSSHKey.name,new te(!0,[]));J.set(lr.deleteSSHKey.name,new te(!0,[]));J.set(lr.listSSHKeys.name,new te(!0,[]));J.set(lr.setSSHKnownHosts.name,new te(!0,[]));J.set(lr.getSSHKnownHosts.name,new te(!0,[]));J.set($w.getRegistrationInfo.name,new te(!1,[]));J.set(Vh.userInfo.name,new te(!1,[]));J.set($h.describeAll.name,new te(!1,[]));J.set(jfe,new te(!1,[]));J.set(Qfe,new te(!0,[]));J.set(zfe,new te(!0,[]));J.set(MS.CSV_DATA_LOAD,new te(!1,[ec,Ml]));J.set(MS.CSV_URL_LOAD,new te(!1,[ec,Ml]));J.set(MS.CSV_FILE_LOAD,new te(!1,[ec,Ml]));J.set(MS.IMPORT_FROM_S3,new te(!1,[ec,Ml]));J.set(KV.EXPORT_TO_S3,new te(!0,[]));J.set(KV.EXPORT_LOCAL,new te(!0,[]));J.set(sn.VALID_SQL_OPS_ENUM.DELETE,new te(!1,[$V]));J.set(sn.VALID_SQL_OPS_ENUM.SELECT,new te(!1,[Yo]));J.set(sn.VALID_SQL_OPS_ENUM.INSERT,new te(!1,[ec]));J.set(sn.VALID_SQL_OPS_ENUM.UPDATE,new te(!1,[Ml]));WV.exports={verifyPerms:Zfe,verifyPermsAst:Xfe,verifyBulkLoadAttributePerms:t_e};function Xfe(e,t,r){if(Ko.isEmptyOrZeroLength(e))throw Rr.info("verify_perms_ast has an empty user parameter"),vn(new Error);if(Ko.isEmptyOrZeroLength(t))throw Rr.info("verify_perms_ast has an empty user parameter"),vn(new Error);if(Ko.isEmptyOrZeroLength(r))throw Rr.info("verify_perms_ast has a null operation parameter"),vn(new Error);try{let n=new qV,s=new Vfe(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Rr.info("No schemas defined in verifyPermsAst(), will not continue."),vn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&VV[r])throw vn(new Error,Hr.DROP_SYSTEM,qh.FORBIDDEN);if(c&&!l)return null;let u=vV.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof Yfe.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let d=0;d<i.length;d++){let h=s.getTablesBySchemaName(i[d]);h&&o.set(i[d],h)}let f=YV(t,r,o,n);return f||(o.forEach((d,h)=>{for(let _=0;_<d.length;_++){let p=s.getAttributesBySchemaTableName(h,d[_]),S=Kw(t.role.permission,h,d[_]);Vw(p,S,r,d[_],h,n)}}),n.getPermsResponse())}catch(n){throw vn(n)}}a(Xfe,"verifyPermsAst");function Zfe(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Rr.info("null required parameter in verifyPerms"),vn(new Error,Hr.DEFAULT_INVALID_REQUEST,qh.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 qV;if(Ko.isEmptyOrZeroLength(e.hdb_user?.role)||Ko.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return Rr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(Hr.USER_HAS_NO_PERMS(e.hdb_user?.username));let l=!!e.hdb_user?.role?.permission?.super_user,u=e.hdb_user?.role?.permission?.structure_user,f=o.has(sn.SYSTEM_SCHEMA_NAME)||s===sn.SYSTEM_SCHEMA_NAME;if(l&&f&&Wfe[e.operation]&&(i===sn.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===sn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===sn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(f&&VV[r])throw vn(new Error,Hr.DROP_SYSTEM,qh.FORBIDDEN);if(l&&!f||u===!0&&(r===Us.createSchema.name||r===Us.dropSchema.name))return null;if(Jfe.indexOf(r)>=0&&(u===!0||Array.isArray(u)))return u===!0||u.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let d=vV.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=d),(r===DV||r===LV)&&!d.super_user){if(s===sn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Hr.SCHEMA_PERM_ERROR(s));if(r===DV&&(!d[s]||!d[s][Gh]))return c.handleInvalidItem(Hr.SCHEMA_NOT_FOUND(s));if(r===LV&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Gh]))return c.handleInvalidItem(Hr.TABLE_NOT_FOUND(s,i))}let h=YV(e.hdb_user,r,o,c,n);if(h)return h;if(J.get(r)&&J.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&sn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let S=[],g=d[s].tables[i];g[sn.PERMS_CRUD_ENUM.READ]&&(g.attribute_permissions.length>0?g.attribute_permissions.filter(m=>m[sn.PERMS_CRUD_ENUM.READ]).forEach(m=>{S.push(m.attribute_name)}):S=global.hdb_schema[s][i].attributes.map(T=>T.attribute),e.get_attributes=S)}let _=e_e(e),p=Kw(e.hdb_user?.role?.permission,s,i);return Vw(_,p,r,i,s,c,n),c.getPermsResponse()}a(Zfe,"verifyPerms");function YV(e,t,r,n,s){if(Ko.arrayHasEmptyValues([e,t,r]))throw Rr.info("hasPermissions has an invalid parameter"),vn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||J.get(t).requires_su))return null;if(!J.get(t))throw Rr.info(`operation ${t} not found.`),vn(new Error,Hr.OP_NOT_FOUND(t),qh.BAD_REQUEST);if(J.get(t)&&J.get(t).requires_su)return Rr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Hr.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Gh]===!1){n.addInvalidItem(Hr.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(Hr.SCHEMA_NOT_FOUND(l));continue}let u=r.get(l);for(let f of u){let d=o[l].tables[f];if(!d||d[Gh]===!1)n.addInvalidItem(Hr.TABLE_NOT_FOUND(l,f));else try{let h=[],_=J.get(t).perms;!Ko.isEmpty(s)&&_.includes(s)&&(_=[s]);for(let p=0;p<_.length;p++){let S=_[p],g=d[S];(g==null||g===!1)&&(Rr.info(`Required ${S} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),h.push(S))}h.length>0&&n.addUnauthorizedTable(l,f,h)}catch(h){let _=Hr.UNKNOWN_OP_AUTH_ERROR(t,l,f);throw Rr.error(_),Rr.error(h),vn(GV.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(YV,"hasPermissions");function Vw(e,t,r,n,s,i,o){if(!e||!t)throw Rr.info("no attributes specified in checkAttributePerms."),vn(new Error);let c=J.get(r).perms;if(!c||c==="")throw Rr.info(`no permissions found for ${r} in checkAttributePerms().`),vn(new Error);if(Ko.isEmptyOrZeroLength(t))return Rr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let f of e){let d=t.get(f);if(d){if(d[Gh]===!1){i.addInvalidItem(Hr.ATTR_NOT_FOUND(s,n,f),s,n);continue}if(c)for(let h of c){if(sn.TIME_STAMP_NAMES.includes(d.attribute_name)&&h!==Yo)throw vn(new Error,Hr.SYSTEM_TIMESTAMP_PERMS_ERR,qh.FORBIDDEN);d[h]===!1&&(l[d.attribute_name]?l[d.attribute_name].push(h):l[d.attribute_name]=[h])}}else i.addInvalidItem(Hr.ATTR_NOT_FOUND(s,n,f),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(Vw,"checkAttributePerms");function e_e(e){let t=new Set;try{if(e.action)return t;if(e.operation===sn.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){Rr.info(r)}return t}a(e_e,"getRecordAttributes");function Kw(e,t,r){let n=new Map;if(Ko.isEmpty(e))return Rr.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{Rr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(Kw,"getAttributePermissions");function t_e(e,t,r,n,s,i,o){let c=new Set(i),l=Kw(e,n,s);Vw(c,l,t,s,n,o,r)}a(t_e,"verifyBulkLoadAttributePerms")});var xS=C((GMe,XV)=>{"use strict";XV.exports={evaluateSQL:h_e,processAST:JV,convertSQLToAST:QV,checkASTPermissions:jV};var r_e=Rn(),zV=require("util"),n_e=zV.callbackify(r_e.insert),s_e=zr().search,i_e=vH().update,o_e=zV.callbackify(i_e),a_e=xH().convertDelete,tc=require("alasql"),c_e=vS(),US=W(),l_e=XE(),u_e=ae(),Kh=(v(),D(q)),{hdb_errors:d_e,handleHDBError:Yw}=_e(),{HTTP_STATUS_CODES:Ww}=d_e;l_e(tc);var f_e=403,__e="There was a problem performing this insert. Please check the logs and try again.",zw=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function h_e(e,t){let r=e.parsed_sql_object;if(!r){r=QV(e.sql);let n,s=r.ast.statements[0];if(s instanceof tc.yy.Insert?n=s.into.databaseid:s instanceof tc.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof tc.yy.Update||s instanceof tc.yy.Delete?n=s.table.databaseid:US.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof tc.yy.Select)&&u_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}JV(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(h_e,"evaluateSQL");function jV(e,t){let r;try{r=c_e.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(jV,"checkASTPermissions");function QV(e){let t=new zw;if(!e)throw Yw(new Error,"The 'sql' parameter is missing from the request body",Ww.BAD_REQUEST);try{let r=e.trim(),n=tc.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
41
|
-
`);throw n[1]?Yw(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,Ww.BAD_REQUEST):Yw(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",Ww.BAD_REQUEST)}return t}a(QV,"convertSQLToAST");function JV(e,t,r){try{let n=p_e;if(!e.bypass_auth&&!t.permissions_checked){let i=jV(e,t);if(i&&i.length>0)return r(f_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case Kh.VALID_SQL_OPS_ENUM.SELECT:n=s_e,s=t.ast.statements[0];break;case Kh.VALID_SQL_OPS_ENUM.INSERT:n=E_e;break;case Kh.VALID_SQL_OPS_ENUM.UPDATE:n=o_e;break;case Kh.VALID_SQL_OPS_ENUM.DELETE:n=a_e;break;default:throw new Error(`unsupported SQL type ${t.variant} in SQL: ${e}`)}n(s,(i,o)=>{if(i){r(i);return}r(null,o)})}catch(n){return r(n)}}a(JV,"processAST");function p_e(e,t){US.info(e),t("unknown sql statement")}a(p_e,"nullFunction");function E_e({statement:e,hdb_user:t},r){let n=e.into,s={schema:n.databaseid,table:n.tableid,operation:"insert",hdb_user:t},i=e.columns.map(o=>o.columnid);try{s.records=m_e(i,e.values)}catch(o){return r(o)}n_e(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){US.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(E_e,"convertInsert");function m_e(e,t){try{return t.map(r=>{if(e.length!==r.length)throw"number of values do not match number of columns in insert";let n={};return r.forEach((s,i)=>{if(s.columnid)throw"cannot use a column in insert value";"value"in s?n[e[i]]=s.value:n[e[i]]=tc.compile(`SELECT ${s.toString()} AS [${Kh.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw US.error(r),new Error(__e)}}a(m_e,"createDataObjects")});var eI=C((YMe,r1)=>{var FS=require("clone"),qS=pt(),g_e=ae(),HS=(v(),D(q)),VMe=W(),jw=require("fs"),Jw=require("joi"),{string:kS}=Jw.types(),{hdb_errors:S_e,handleHDBError:BS}=_e(),{HDB_ERROR_MSGS:KMe,HTTP_STATUS_CODES:Qw}=S_e,{common_validators:Dd}=vi(),ZV=" is required",T_e=["insert","update","upsert"],Xw={database:{presence:!1,format:Dd.schema_format,length:Dd.schema_length},schema:{presence:!1,format:Dd.schema_format,length:Dd.schema_length},table:{presence:!0,format:Dd.schema_format,length:Dd.schema_length},action:{inclusion:{within:T_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},A_e={schema:kS.required(),table:kS.required(),action:kS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:R_e,AWS_SECRET:y_e,AWS_BUCKET:b_e,AWS_FILE_KEY:O_e,REGION:N_e}=HS.S3_BUCKET_AUTH_KEYS,w_e={s3:{presence:!0},[`s3.${R_e}`]:{presence:!0,type:"String"},[`s3.${y_e}`]:{presence:!0,type:"String"},[`s3.${b_e}`]:{presence:!0,type:"String"},[`s3.${O_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${N_e}`]:{presence:!0,type:"String"}},e1=FS(Xw);e1.data.presence={message:ZV};var t1=FS(Xw);t1.file_path.presence={message:ZV};var I_e=Object.assign(FS(Xw),w_e),Zw=FS(A_e);Zw.csv_url=kS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();Zw.passthrough_headers=Jw.object();function C_e(e){let t=qS.validateObject(e,e1);return GS(e,t)}a(C_e,"dataObject");function P_e(e){let t=qS.validateBySchema(e,Jw.object(Zw));return GS(e,t)}a(P_e,"urlObject");function D_e(e){let t=qS.validateObject(e,t1);return GS(e,t)}a(D_e,"fileObject");function L_e(e){let t=qS.validateObject(e,I_e);return GS(e,t)}a(L_e,"s3FileObject");function GS(e,t){if(!t){let r=g_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return BS(new Error,r,Qw.BAD_REQUEST);if(e.operation===HS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{jw.accessSync(e.file_path,jw.constants.R_OK|jw.constants.F_OK)}catch(n){return n.code===HS.NODE_ERROR_CODES.ENOENT?BS(n,`No such file or directory ${n.path}`,Qw.BAD_REQUEST):n.code===HS.NODE_ERROR_CODES.EACCES?BS(n,`Permission denied ${n.path}`,Qw.BAD_REQUEST):BS(n)}}return t}a(GS,"postValidateChecks");r1.exports={dataObject:C_e,urlObject:P_e,fileObject:D_e,s3FileObject:L_e}});var tI=C((zMe,n1)=>{"use strict";var Yh=W(),$S=(v(),D(q));async function M_e(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===$S.OPERATIONS_ENUM.INSERT||t.operation===$S.OPERATIONS_ENUM.UPDATE||t.operation===$S.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===$S.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(Yh.info(i.message),i):i.http_resp_msg?(Yh.error(`Error calling operation: ${e.name}`),Yh.error(i.http_resp_msg),i):(Yh.error(`Error calling operation: ${e.name}`),Yh.error(i),i)}}a(M_e,"callOperationFunctionAsAwait");n1.exports={callOperationFunctionAsAwait:M_e}});var rI=C((QMe,i1)=>{"use strict";var{S3:v_e,GetObjectCommand:U_e}=require("@aws-sdk/client-s3");i1.exports={getFileStreamFromS3:x_e,getS3AuthObj:s1};async function x_e(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await s1(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new U_e(r))).Body}a(x_e,"getFileStreamFromS3");function s1(e,t,r){return new v_e({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(s1,"getS3AuthObj")});var a1=C((XMe,o1)=>{"use strict";var nI=class{static{a(this,"BulkLoadFileObject")}constructor(t,r,n,s,i,o,c=null){this.op=t,this.action=r,this.schema=n,this.table=s,this.file_path=i,this.file_type=o,this.role_perms=c}},sI=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};o1.exports={BulkLoadFileObject:nI,BulkLoadDataObject:sI}});var l1=C((eve,c1)=>{"use strict";var iI=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};c1.exports=iI});var dI=C((ove,N1)=>{"use strict";var VS=Rn(),YS=eI(),B_e=require("needle"),Ei=(v(),D(q)),rve=gt(),Ld=ae(),{handleHDBError:Bt,hdb_errors:g1}=_e(),{HTTP_STATUS_CODES:kr,HDB_ERROR_MSGS:yr,CHECK_LOGS_WRAPPER:Ul}=g1,Md=W(),oI=require("papaparse");Ld.promisifyPapaParse();var mi=require("fs-extra"),H_e=require("path"),{chain:u1}=require("stream-chain"),d1=require("stream-json/streamers/StreamArray"),f1=require("stream-json/utils/Batch"),_1=require("stream-chain/utils/comp"),{finished:h1}=require("stream"),k_e=ce(),S1=tI(),F_e=rI(),{BulkLoadFileObject:cI,BulkLoadDataObject:q_e}=a1(),lI=kw(),{verifyBulkLoadAttributePerms:T1}=vS(),nve=l1(),sve=ar(),ive=bo(),{databases:G_e}=(Ce(),D(tt)),{coerceType:$_e}=(Bf(),D(fI)),p1="No records parsed from csv file.",vl=`${k_e.get("HDB_ROOT")}/tmp`,{schema_regex:V_e}=vi(),E1=1024*1024*2,m1=5e3,K_e={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};N1.exports={csvDataLoad:Y_e,csvURLLoad:W_e,csvFileLoad:z_e,importFromS3:j_e};async function Y_e(e,t){let r=YS.dataObject(e);if(r)throw Bt(r,r.message,kr.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=y1(e.schema,e.table),i=oI.parse(e.data,{header:!0,skipEmptyLines:!0,transform:aI.bind(null,s),dynamicTyping:!1}),o=new lI;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&T1(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,kr.BAD_REQUEST,void 0,void 0,!0);let l=new q_e(e.action,e.schema,e.table,i.data);return n=await S1.callOperationFunctionAsAwait(b1,l,null),n.message===p1?p1:O1(n.records,n.number_written)}catch(s){throw xl(s)}}a(Y_e,"csvDataLoad");async function W_e(e){let t=YS.urlObject(e);if(t)throw Bt(t,t.message,kr.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${vl}/${r}`;try{await Q_e(e,r)}catch(s){throw Md.error(yr.DOWNLOAD_FILE_ERR(r)+" - "+s),Bt(s,Ul(yr.DOWNLOAD_FILE_ERR(r)))}try{let s=new cI(this.job_operation_function.name,e.action,e.schema,e.table,n,Ei.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await uI(s);return await KS(n),i}catch(s){throw await KS(n),xl(s)}}a(W_e,"csvURLLoad");async function z_e(e){let t=YS.fileObject(e);if(t)throw Bt(t,t.message,kr.BAD_REQUEST,void 0,void 0,!0);let r=new cI(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,Ei.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await uI(r)}catch(n){throw xl(n)}}a(z_e,"csvFileLoad");async function j_e(e){let t=YS.s3FileObject(e);if(t)throw Bt(t,t.message,kr.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=H_e.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${vl}/${s}`;let i=new cI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await J_e(s,e);let o=await uI(i);return await KS(r),o}catch(n){throw await KS(r),xl(n)}}a(j_e,"importFromS3");async function Q_e(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await B_e("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,Ei.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Z_e(r,e.csv_url),await X_e(t,r.raw)}a(Q_e,"downloadCSVFile");async function J_e(e,t){try{let r=`${vl}/${e}`;await mi.mkdirp(vl),await mi.writeFile(`${vl}/${e}`,"",{flag:"a+"});let n=await mi.createWriteStream(r),s=await F_e.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(){Md.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Md.error(yr.S3_DOWNLOAD_ERR+" - "+r),Bt(r,Ul(yr.S3_DOWNLOAD_ERR))}}a(J_e,"downloadFileFromS3");async function X_e(e,t){try{await mi.mkdirp(vl),await mi.writeFile(`${vl}/${e}`,t)}catch(r){throw Md.error(yr.WRITE_TEMP_FILE_ERR),Bt(r,Ul(yr.DEFAULT_BULK_LOAD_ERR))}}a(X_e,"writeFileToTempFolder");async function KS(e){if(e)try{await mi.access(e),await mi.unlink(e)}catch{Md.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(KS,"deleteTempFile");function Z_e(e,t){if(e.statusCode!==g1.HTTP_STATUS_CODES.OK)throw Bt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,kr.BAD_REQUEST);if(!K_e[e.headers["content-type"]])throw Bt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,kr.BAD_REQUEST);if(!e.raw)throw Bt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,kr.BAD_REQUEST)}a(Z_e,"validateURLResponse");async function uI(e){try{let t;switch(e.file_type){case Ei.VALID_S3_FILE_TYPES.CSV:t=await ehe(e);break;case Ei.VALID_S3_FILE_TYPES.JSON:t=await the(e);break;default:throw Bt(new Error,yr.DEFAULT_BULK_LOAD_ERR,kr.BAD_REQUEST,Ei.LOG_LEVELS.ERROR,yr.INVALID_FILE_EXT_ERR(e))}return O1(t.records,t.number_written)}catch(t){throw xl(t)}}a(uI,"fileLoad");async function A1(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 VS.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&T1(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(A1,"validateChunk");async function R1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Ld.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Ld.isEmpty(c)&&!Ld.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(u=>c.add(u))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await S1.callOperationFunctionAsAwait(b1,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=Bt(c,Ul(yr.INSERT_CSV_ERR),kr.INTERNAL_SERVER_ERROR,Ei.LOG_LEVELS.ERROR,yr.INSERT_CSV_ERR+" - "+c);r(l)}}a(R1,"insertChunk");async function ehe(e){let t={records:0,number_written:0},r=y1(e.schema,e.table);try{let n=new lI,s=mi.createReadStream(e.file_path,{highWaterMark:E1});s.setEncoding("utf8"),await oI.parsePromise(s,A1.bind(null,e,n),aI.bind(null,r));let i=n.getPermsResponse();if(i)throw Bt(new Error,i,kr.BAD_REQUEST);return s=mi.createReadStream(e.file_path,{highWaterMark:E1}),s.setEncoding("utf8"),await oI.parsePromise(s,R1.bind(null,e,t),aI.bind(null,r)),s.destroy(),t}catch(n){throw Bt(n,Ul(yr.PAPA_PARSE_ERR),kr.INTERNAL_SERVER_ERROR,Ei.LOG_LEVELS.ERROR,yr.PAPA_PARSE_ERR+n)}}a(ehe,"callPapaParse");function y1(e,t){let r=G_e[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>$_e(i,s));return n}a(y1,"createTransformMap");function aI(e,t,r){let n=e.get(r);return n?n(t):Ld.autoCast(t)}a(aI,"typeFunction");async function the(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new lI,s=u1([mi.createReadStream(e.file_path,{encoding:"utf-8"}),d1.withParser(),c=>c.value,new f1({batchSize:m1}),_1(async c=>{await A1(e,n,r,c)})]);await new Promise((c,l)=>{h1(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw Bt(new Error,i,kr.BAD_REQUEST);let o=u1([mi.createReadStream(e.file_path,{encoding:"utf-8"}),d1.withParser(),c=>c.value,new f1({batchSize:m1}),_1(async c=>{await R1(e,t,r,c)})]);return await new Promise((c,l)=>{h1(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw Bt(n,Ul(yr.INSERT_JSON_ERR),kr.INTERNAL_SERVER_ERROR,Ei.LOG_LEVELS.ERROR,yr.INSERT_JSON_ERR+n)}}a(the,"insertJson");async function b1(e){let t={};try{e.data&&e.data.length>0&&rhe(e.data[0])?t=await nhe(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Md.info(t.message))}catch(r){throw xl(r)}return t}a(b1,"callBulkFileLoad");function rhe(e){let t=Object.keys(e);for(let r of t)if(!V_e.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(rhe,"validateColumnNames");async function nhe(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=VS.insert;break;case"update":i=VS.update;break;case"upsert":i=VS.upsert;break;default:throw Bt(new Error,yr.INVALID_ACTION_PARAM_ERR(n),kr.BAD_REQUEST,Ei.LOG_LEVELS.ERROR,yr.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let f=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][f])>=0&&e.splice(d,1)}let l=Ld.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw xl(o)}}a(nhe,"bulkFileLoad");function O1(e,t){return`successfully loaded ${t} of ${e} records`}a(O1,"buildResponseMsg");function xl(e){return Bt(e,Ul(yr.DEFAULT_BULK_LOAD_ERR),kr.INTERNAL_SERVER_ERROR,Ei.LOG_LEVELS.ERROR,yr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(xl,"buildTopLevelErrMsg")});var pI=C((cve,v1)=>{"use strict";var hI=zr(),she=rI(),{AsyncParser:ihe}=require("json2csv"),WS=require("stream"),as=ae(),_I=require("fs-extra"),ohe=require("path"),xs=W(),{promisify:C1}=require("util"),Wh=ae(),{handleHDBError:ur,hdb_errors:ahe}=_e(),{HDB_ERROR_MSGS:Un,HTTP_STATUS_CODES:dr}=ahe,{streamAsJSON:che}=(aR(),D(yL)),{Upload:lhe}=require("@aws-sdk/lib-storage"),{toCsvStream:uhe}=(Eo(),D(SR)),w1=["search_by_value","search_by_hash","sql","search_by_conditions"],I1=["json","csv"],P1="json",D1="csv",dhe="Successfully exported JSON locally.",fhe="Successfully exported CSV locally.",_he=1e3,hhe=hI.searchByHash,phe=hI.searchByValue,Ehe=C1(WS.finished);v1.exports={export_to_s3:The,export_local:mhe};async function mhe(e){xs.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=L1(e);if(!as.isEmpty(t))throw xs.error(t),ur(new Error,t,dr.BAD_REQUEST,void 0,void 0,!0);if(as.isEmpty(e.path))throw xs.error(Un.MISSING_VALUE("path")),ur(new Error,Un.MISSING_VALUE("path"),dr.BAD_REQUEST,void 0,void 0,!0);let r=(as.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(ohe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=as.buildFolderPath(e.path,r);await ghe(e.path);let s=await M1(e);return await She(n,e.format,s)}a(mhe,"export_local");async function ghe(e){if(xs.trace("in confirmPath"),as.isEmptyOrZeroLength(e))throw ur(new Error,`Invalid path: ${e}`,dr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await _I.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,xs.error(n),ur(new Error,n,dr.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 xs.error(r),ur(new Error,r,dr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(ghe,"confirmPath");async function She(e,t,r){if(xs.trace("in saveToLocal"),Wh.isEmptyOrZeroLength(e))throw ur(new Error,Un.INVALID_VALUE("file_path"),dr.BAD_REQUEST,void 0,void 0,!0);if(Wh.isEmptyOrZeroLength(t))throw ur(new Error,Un.INVALID_VALUE("Source format"),dr.BAD_REQUEST,void 0,void 0,!0);if(Wh.isEmpty(r))throw ur(new Error,Un.NOT_FOUND("Data"),dr.BAD_REQUEST,void 0,void 0,!0);if(t===P1){let n=_I.createWriteStream(e);return che(r).pipe(n),await Ehe(n),{message:dhe,path:e}}else if(t===D1){let n=_I.createWriteStream(e),s=WS.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(f=>({label:f,value:f})));let c={objectMode:!0};return await new ihe(i,c).fromInput(s).toOutput(n).promise(!1),{message:fhe,path:e}}throw ur(new Error,Un.INVALID_VALUE("format"),dr.BAD_REQUEST)}a(She,"saveToLocal");async function The(e){if(!e.s3||Object.keys(e.s3).length===0)throw ur(new Error,Un.MISSING_VALUE("S3 object"),dr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw ur(new Error,Un.MISSING_VALUE("aws_access_key_id"),dr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw ur(new Error,Un.MISSING_VALUE("aws_secret_access_key"),dr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.bucket))throw ur(new Error,Un.MISSING_VALUE("bucket"),dr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.key))throw ur(new Error,Un.MISSING_VALUE("key"),dr.BAD_REQUEST);if(as.isEmptyOrZeroLength(e.s3.region))throw ur(new Error,Un.MISSING_VALUE("region"),dr.BAD_REQUEST);let t=L1(e);if(!as.isEmpty(t))throw ur(new Error,t,dr.BAD_REQUEST);xs.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await M1(e)}catch(l){throw xs.error(l),l}let n,s=await she.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new WS.PassThrough;if(e.format===D1){i=e.s3.key+".csv";let l=uhe(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===P1){i=e.s3.key+".json";let l=new WS.Readable;l.pipe(o),l.on("error",d=>{throw d}),l.push("[");let u=r.length,f="";for(let[d,h]of r.entries()){let _=d===u-1?JSON.stringify(h):JSON.stringify(h)+",";f+=_,d!==0&&d%_he===0&&(l.push(f),f="")}f.length!==0&&l.push(f),l.push("]"),l.push(null)}else throw ur(new Error,Un.INVALID_VALUE("format"),dr.BAD_REQUEST);return new lhe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(The,"export_to_s3");function L1(e){if(xs.trace("in exportCoreValidation"),as.isEmpty(e.format))return"format missing";if(I1.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${I1.join(", ")}`;let t=e.search_operation.operation;if(as.isEmpty(t))return"search_operation.operation missing";if(w1.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${w1.join(", ")}`}a(L1,"exportCoreValidation");async function M1(e){xs.trace("in getRecords");let t,r;if(Wh.isEmpty(e.search_operation)||Wh.isEmptyOrZeroLength(e.search_operation.operation))throw ur(new Error,Un.INVALID_VALUE("Search operation"),dr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=phe;break;case"search_by_hash":t=hhe;break;case"search_by_conditions":t=hI.searchByConditions;break;case"sql":{let n=xS();t=C1(n.evaluateSQL);break}default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,xs.error(r),ur(new Error,r,dr.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(M1,"getRecords")});var x1=C((uve,U1)=>{"use strict";var EI=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};U1.exports=EI});var k1=C((fve,H1)=>{"use strict";var Ahe=(v(),D(q)),B1=require("moment"),Rhe=require("uuid").v4,mI=class{static{a(this,"JobObject")}constructor(){this.id=Rhe(),this.type=void 0,this.start_datetime=B1().valueOf(),this.created_datetime=B1().valueOf(),this.end_datetime=void 0,this.status=Ahe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};H1.exports=mI});var gI=C((hve,W1)=>{"use strict";var yhe=require("uuid").v4,V1=Rn(),K1=zr(),bhe=ai(),Ohe=Mu(),Nhe=x1(),yt=(v(),D(q)),whe=k1(),Ihe=zm(),gi=W(),Che=Pf(),vd=ae(),{promisify:Phe}=require("util"),Bl=require("moment"),Dhe=xS(),zS=eI(),F1=_y(),{deleteTransactionLogsBeforeValidator:Lhe}=vw(),{handleHDBError:q1,hdb_errors:Mhe,ClientError:vhe}=_e(),{HTTP_STATUS_CODES:G1}=Mhe,$1=K1.searchByValue,Uhe=K1.searchByHash,xhe=V1.insert,Bhe=Phe(Dhe.evaluateSQL),Hhe=V1.update;W1.exports={addJob:qhe,updateJob:$he,handleGetJob:khe,handleGetJobsByStartDate:Fhe,getJobById:Y1};async function khe(e){if(e.id===void 0)throw new vhe("'id' is required");let t=await Y1(e.id);return vd.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}a(khe,"handleGetJob");async function Fhe(e){try{let t=await Ghe(e);if(gi.trace(`Searching for jobs from ${e.from_date} to ${e.to_date}`),t&&t.length>0)for(let r of t)r.start_datetime&&(r.start_datetime_converted=Bl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Bl(r.end_datetime)),r.request!==void 0&&delete r.request,delete r.__createdtime__,delete r.__updatedtime__;return t}catch(t){let r=`There was an error searching jobs by date: ${t}`;throw gi.error(r),new Error(r)}}a(Fhe,"handleGetJobsByStartDate");async function qhe(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||vd.isEmptyOrZeroLength(e.operation)){let f="job parameter is invalid";return gi.info(f),t.error=f,t}if(!yt.JOB_TYPE_ENUM[e.operation])return gi.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case yt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=zS.fileObject(e);break;case yt.OPERATIONS_ENUM.CSV_URL_LOAD:n=zS.urlObject(e);break;case yt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=zS.dataObject(e);break;case yt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=zS.s3FileObject(e);break;case yt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case yt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=F1(e,"date");break;case yt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=F1(e,"timestamp");break;case yt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=Lhe(e);break;case yt.OPERATIONS_ENUM.RESTART_SERVICE:if(yt.HDB_PROCESS_SERVICES[e.service]===void 0)throw q1(new Error,"Invalid service",G1.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw q1(n,n.message,G1.BAD_REQUEST,void 0,void 0,!0);let s=new whe;s.type=e.operation===yt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?yt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new bhe(yt.SYSTEM_SCHEMA_NAME,yt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await $1(i))}catch(f){let d=`There was an error inserting a new job: ${f}`;return gi.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=yhe();try{o=await $1(i)}catch(f){let d=`There was an error inserting a new job: ${f}`;return gi.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return gi.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Che(yt.SYSTEM_SCHEMA_NAME,yt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await xhe(l)}catch(f){return gi.error(`There was an error inserting a job for job type: ${e.operation} -- ${f}`),t.success=!1,t}if(u.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let f=`Created a job with type ${s.type} and id ${s.id}`;t.message=f,t.createdJob=s,t.success=!0,gi.trace(f)}return t}a(qhe,"addJob");async function Ghe(e){let t=Bl(e.from_date,Bl.ISO_8601),r=Bl(e.to_date,Bl.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new Nhe(n,e.hdb_user);try{return await Bhe(s)}catch(i){throw gi.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(Ghe,"getJobsInDateRange");async function Y1(e){if(vd.isEmptyOrZeroLength(e))return vd.errorizeMessage("Invalid job ID specified.");let t=new Ohe(yt.SYSTEM_SCHEMA_NAME,yt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await Uhe(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return gi.error(n),vd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(Y1,"getJobById");async function $he(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(vd.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===yt.JOB_STATUS_ENUM.COMPLETE||e.status===yt.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Bl().valueOf());let t=new Ihe(yt.SYSTEM_SCHEMA_NAME,yt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await Hhe(t),r}a($he,"updateJob")});var tK=C((Eve,eK)=>{"use strict";var z1=ae(),br=(v(),D(q)),Vhe=require("moment"),jS=dI(),zh=W(),j1=gI(),Q1=pI(),J1=Vc(),X1=nt(),Khe=PS(),Yhe=Ja(),{parentPort:Whe,isMainThread:Z1}=require("worker_threads"),{onMessageByType:zhe}=nt(),SI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function jhe(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(z1.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(z1.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case br.JOB_TYPE_ENUM.csv_file_load:await zi(e,jS.csvFileLoad);break;case br.JOB_TYPE_ENUM.csv_url_load:await zi(e,jS.csvURLLoad);break;case br.JOB_TYPE_ENUM.csv_data_load:await zi(e,jS.csvDataLoad);break;case br.JOB_TYPE_ENUM.import_from_s3:await zi(e,jS.importFromS3);break;case br.JOB_TYPE_ENUM.empty_trash:break;case br.JOB_TYPE_ENUM.export_local:await zi(e,Q1.export_local);break;case br.JOB_TYPE_ENUM.export_to_s3:await zi(e,Q1.export_to_s3);break;case br.JOB_TYPE_ENUM.delete_files_before:case br.JOB_TYPE_ENUM.delete_records_before:await zi(e,J1.deleteFilesBefore);break;case br.JOB_TYPE_ENUM.delete_audit_logs_before:await zi(e,J1.deleteAuditLogsBefore);break;case br.JOB_TYPE_ENUM.delete_transaction_logs_before:await zi(e,Khe.deleteTransactionLogsBefore);break;case br.JOB_TYPE_ENUM.restart_service:return await zi(e,Yhe.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(jhe,"parseMessage");async function zi(e,t){try{e.job.status=br.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=Vhe().valueOf(),await j1.updateJob(e.job),await Qhe(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):zh.error(`There was an error running ${t.name} job with id ${e.job.id}`),zh.error(n),e.job.message=n,e.job.status=br.JOB_STATUS_ENUM.ERROR;try{await j1.updateJob(e.job)}catch(s){throw zh.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(zi,"runJob");async function Qhe(e){zh.trace("launching job thread:",e),Z1?X1.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[br.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):Whe.postMessage({type:br.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(Qhe,"launchJobThread");Z1&&zhe(br.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{X1.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[br.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){zh.error(r)}});eK.exports={parseMessage:jhe,RunnerMessage:SI}});var nK=C((gve,rK)=>{"use strict";var TI=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};rK.exports=TI});var Mw=C((Ave,NI)=>{"use strict";var eT=zr(),yI=xS(),QS=dI(),Wo=Lg(),JS=Oo(),Qh=Vc(),Jhe=lN(),jh=An(),XS=v_(),It=Lw(),ZS=W(),Xhe=hN(),Zhe=ud(),sK=kN(),epe=Kg(),tpe=GN(),rpe=$N(),npe=jg(),spe=Jg(),AI=Xg(),iK=pI(),ipe=vS(),bI=gI(),V=(v(),D(q)),{hdb_errors:Xh,handleHDBError:Jh}=_e(),{HTTP_STATUS_CODES:oK}=Xh,RI=nS(),aK=Ja(),mK=require("util"),xd=Rn(),ope=ys(),ape=Uo(),cK=tK(),lK=Fu(),uK=(RS(),D(Mh)),dK=At(),fK=PS(),_K=Uh(),{setServerUtilities:cpe}=(Bf(),D(fI)),{CONTEXT:Tve}=(Ra(),D(eR)),{_assignPackageExport:lpe}=bi(),{transformReq:upe}=ae(),{server:dpe}=(Yr(),D(Ic)),on=ZS.loggerWithTag("operation"),Ud=rs(),hK=(Tl(),D(Sl)),fpe=tI(),pK=eT.searchByHash,_pe=eT.searchByValue,hpe=mK.promisify(eT.search),ppe=mK.promisify(yI.evaluateSQL),Epe={[V.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[V.OPERATIONS_ENUM.CREATE_TABLE]:!0,[V.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[V.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[V.OPERATIONS_ENUM.DROP_TABLE]:!0,[V.OPERATIONS_ENUM.DROP_SCHEMA]:!0},Z=nK();async function gK(e,t){try{if(e.body.operation!=="read_log"&&(ZS.log_level===V.LOG_LEVELS.INFO||ZS.log_level===V.LOG_LEVELS.DEBUG||ZS.log_level===V.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;on.info(c)}}catch(n){on.error(n)}let r=await fpe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Epe[e.body.operation]&&ope.setSchemaDataToGlobal(n=>{n&&on.error(n)}),r}a(gK,"processLocalTransaction");var EK=gpe();NI.exports={chooseOperation:SK,getOperationFunction:TK,operation:OI,processLocalTransaction:gK,executeJob:Bs};cpe(NI.exports);dpe.operation=OI;function SK(e){let t;try{t=TK(e)}catch(s){throw on.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=yI.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=yI.checkASTPermissions(e,i);if(o)throw on.error(`${oK.FORBIDDEN} from operation ${e.operation}`),on.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),Jh(new Error,o,Xh.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==V.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==V.OPERATIONS_ENUM.LOGIN&&e.operation!==V.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=ipe.verifyPerms(i,s);if(o)throw on.error(`${oK.FORBIDDEN} from operation ${e.operation}`),on.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),Jh(new Error,o,Xh.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw Jh(s,"There was an error when trying to choose an operation path")}return r}a(SK,"chooseOperation");function TK(e){if(on.trace(`getOperationFunction with operation: ${e.operation}`),EK.has(e.operation))return EK.get(e.operation);throw Jh(new Error,Xh.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),Xh.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(TK,"getOperationFunction");lpe("operation",OI);function OI(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=SK(e);return gK({body:e},n)}a(OI,"operation");async function mpe(e){on.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[V.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case V.OPERATIONS_ENUM.INSERT:o=await xd.insert(i);break;case V.OPERATIONS_ENUM.UPDATE:o=await xd.update(i);break;case V.OPERATIONS_ENUM.UPSERT:o=await xd.upsert(i);break;case V.OPERATIONS_ENUM.DELETE:o=await Qh.deleteRecord(i);break;default:on.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){on.info("Invalid operation in transaction"),on.error(o)}}a(mpe,"catchup");async function Bs(e){upe(e);let t,r;try{r=await bI.addJob(e),t=r.createdJob,on.info("addJob result",r);let n=new cK.RunnerMessage(t,e);return{message:await cK.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw on.error(s),Jh(n,s)}}a(Bs,"executeJob");function gpe(){let e=new Map;return e.set(V.OPERATIONS_ENUM.INSERT,new Z(xd.insert)),e.set(V.OPERATIONS_ENUM.UPDATE,new Z(xd.update)),e.set(V.OPERATIONS_ENUM.UPSERT,new Z(xd.upsert)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new Z(eT.searchByConditions)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_HASH,new Z(pK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_ID,new Z(pK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_VALUE,new Z(_pe)),e.set(V.OPERATIONS_ENUM.SEARCH,new Z(hpe)),e.set(V.OPERATIONS_ENUM.SQL,new Z(ppe)),e.set(V.OPERATIONS_ENUM.CSV_DATA_LOAD,new Z(Bs,QS.csvDataLoad)),e.set(V.OPERATIONS_ENUM.CSV_FILE_LOAD,new Z(Bs,QS.csvFileLoad)),e.set(V.OPERATIONS_ENUM.CSV_URL_LOAD,new Z(Bs,QS.csvURLLoad)),e.set(V.OPERATIONS_ENUM.IMPORT_FROM_S3,new Z(Bs,QS.importFromS3)),e.set(V.OPERATIONS_ENUM.CREATE_SCHEMA,new Z(Wo.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_DATABASE,new Z(Wo.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_TABLE,new Z(Wo.createTable)),e.set(V.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new Z(Wo.createAttribute)),e.set(V.OPERATIONS_ENUM.DROP_SCHEMA,new Z(Wo.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_DATABASE,new Z(Wo.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_TABLE,new Z(Wo.dropTable)),e.set(V.OPERATIONS_ENUM.DROP_ATTRIBUTE,new Z(Wo.dropAttribute)),e.set(V.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new Z(JS.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_DATABASE,new Z(JS.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_TABLE,new Z(JS.describeTable)),e.set(V.OPERATIONS_ENUM.DESCRIBE_ALL,new Z(JS.describeAll)),e.set(V.OPERATIONS_ENUM.DELETE,new Z(Qh.deleteRecord)),e.set(V.OPERATIONS_ENUM.ADD_USER,new Z(jh.addUser)),e.set(V.OPERATIONS_ENUM.ALTER_USER,new Z(jh.alterUser)),e.set(V.OPERATIONS_ENUM.DROP_USER,new Z(jh.dropUser)),e.set(V.OPERATIONS_ENUM.LIST_USERS,new Z(jh.listUsersExternal)),e.set(V.OPERATIONS_ENUM.LIST_ROLES,new Z(XS.listRoles)),e.set(V.OPERATIONS_ENUM.ADD_ROLE,new Z(XS.addRole)),e.set(V.OPERATIONS_ENUM.ALTER_ROLE,new Z(XS.alterRole)),e.set(V.OPERATIONS_ENUM.DROP_ROLE,new Z(XS.dropRole)),e.set(V.OPERATIONS_ENUM.USER_INFO,new Z(jh.userInfo)),e.set(V.OPERATIONS_ENUM.READ_LOG,new Z(Xhe)),e.set(V.OPERATIONS_ENUM.ADD_NODE,new Z(Zhe)),e.set(V.OPERATIONS_ENUM.UPDATE_NODE,new Z(sK)),e.set(V.OPERATIONS_ENUM.SET_NODE_REPLICATION,new Z(sK)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE,new Z(epe)),e.set(V.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new Z(tpe)),e.set(V.OPERATIONS_ENUM.PURGE_STREAM,new Z(rpe)),e.set(V.OPERATIONS_ENUM.SET_CONFIGURATION,new Z(dK.setConfiguration)),e.set(V.OPERATIONS_ENUM.CLUSTER_STATUS,new Z(npe.clusterStatus)),e.set(V.OPERATIONS_ENUM.CLUSTER_NETWORK,new Z(spe)),e.set(V.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new Z(AI.setRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new Z(AI.getRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new Z(AI.deleteRoutes)),e.set(V.OPERATIONS_ENUM.EXPORT_TO_S3,new Z(Bs,iK.export_to_s3)),e.set(V.OPERATIONS_ENUM.CREATE_CSR,new Z(Ud.createCsr)),e.set(V.OPERATIONS_ENUM.SIGN_CERTIFICATE,new Z(Ud.signCertificate)),e.set(V.OPERATIONS_ENUM.LIST_CERTIFICATES,new Z(Ud.listCertificates)),e.set(V.OPERATIONS_ENUM.ADD_CERTIFICATES,new Z(Ud.addCertificate)),e.set(V.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new Z(Ud.removeCertificate)),e.set(V.OPERATIONS_ENUM.GET_KEY,new Z(Ud.getKey)),e.set(V.OPERATIONS_ENUM.ADD_NODE_BACK,new Z(hK.addNodeBack)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE_BACK,new Z(hK.removeNodeBack)),e.set(V.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new Z(Bs,Qh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new Z(Bs,Qh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.EXPORT_LOCAL,new Z(Bs,iK.export_local)),e.set(V.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new Z(bI.handleGetJobsByStartDate)),e.set(V.OPERATIONS_ENUM.GET_JOB,new Z(bI.handleGetJob)),e.set(V.OPERATIONS_ENUM.GET_FINGERPRINT,new Z(RI.getFingerprint)),e.set(V.OPERATIONS_ENUM.SET_LICENSE,new Z(RI.setLicense)),e.set(V.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new Z(RI.getRegistrationInfo)),e.set(V.OPERATIONS_ENUM.RESTART,new Z(aK.restart)),e.set(V.OPERATIONS_ENUM.RESTART_SERVICE,new Z(Bs,aK.restartService)),e.set(V.OPERATIONS_ENUM.CATCHUP,new Z(mpe)),e.set(V.OPERATIONS_ENUM.SYSTEM_INFORMATION,new Z(ape.systemInformation)),e.set(V.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new Z(Bs,Qh.deleteAuditLogsBefore)),e.set(V.OPERATIONS_ENUM.READ_AUDIT_LOG,new Z(Jhe)),e.set(V.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new Z(lK.createTokens)),e.set(V.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new Z(lK.refreshOperationToken)),e.set(V.OPERATIONS_ENUM.LOGIN,new Z(uK.login)),e.set(V.OPERATIONS_ENUM.LOGOUT,new Z(uK.logout)),e.set(V.OPERATIONS_ENUM.GET_CONFIGURATION,new Z(dK.getConfiguration)),e.set(V.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new Z(It.customFunctionsStatus)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new Z(It.getCustomFunctions)),e.set(V.OPERATIONS_ENUM.GET_COMPONENT_FILE,new Z(It.getComponentFile)),e.set(V.OPERATIONS_ENUM.GET_COMPONENTS,new Z(It.getComponents)),e.set(V.OPERATIONS_ENUM.SET_COMPONENT_FILE,new Z(It.setComponentFile)),e.set(V.OPERATIONS_ENUM.DROP_COMPONENT,new Z(It.dropComponent)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new Z(It.getCustomFunction)),e.set(V.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new Z(It.setCustomFunction)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new Z(It.dropCustomFunction)),e.set(V.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new Z(It.addComponent)),e.set(V.OPERATIONS_ENUM.ADD_COMPONENT,new Z(It.addComponent)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new Z(It.dropCustomFunctionProject)),e.set(V.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new Z(It.packageComponent)),e.set(V.OPERATIONS_ENUM.PACKAGE_COMPONENT,new Z(It.packageComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new Z(It.deployComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_COMPONENT,new Z(It.deployComponent)),e.set(V.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new Z(fK.readTransactionLog)),e.set(V.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new Z(Bs,fK.deleteTransactionLogsBefore)),e.set(V.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new Z(_K.installModules)),e.set(V.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new Z(_K.auditModules)),e.set(V.OPERATIONS_ENUM.GET_BACKUP,new Z(Wo.getBackup)),e.set(V.OPERATIONS_ENUM.ADD_SSH_KEY,new Z(It.addSSHKey)),e.set(V.OPERATIONS_ENUM.UPDATE_SSH_KEY,new Z(It.updateSSHKey)),e.set(V.OPERATIONS_ENUM.DELETE_SSH_KEY,new Z(It.deleteSSHKey)),e.set(V.OPERATIONS_ENUM.LIST_SSH_KEYS,new Z(It.listSSHKeys)),e.set(V.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new Z(It.setSSHKnownHosts)),e.set(V.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new Z(It.getSSHKnownHosts)),e}a(gpe,"initializeOperationFunctionMap")});var rT=C((yve,yK)=>{"use strict";var wI=(v(),D(q)),Spe=ae(),Zh=W(),{handleHDBError:II,hdb_errors:tT}=_e(),{isMainThread:Tpe}=require("worker_threads"),{Readable:Ape}=require("stream"),AK=require("os"),Rpe=require("util"),ype=fO(),bpe=Rpe.promisify(ype.authorize),RK=Mw(),{createGzip:Ope,constants:Npe}=require("zlib");function wpe(e){let t=`Found an uncaught exception with message: ${e.message}. ${AK.EOL}Stack: ${e.stack} ${AK.EOL}Terminating ${Tpe?"HDB":"thread"}.`;console.error(t),Zh.fatal(t),process.exit(1)}a(wpe,"handleServerUncaughtException");function Ipe(e,t,r){if(Zh[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:tT.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(Ipe,"serverErrorHandler");function Cpe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=II(new Error,"Invalid JSON.",tT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(Spe.isEmpty(e.body.operation)){let n=II(new Error,"Request body must include an 'operation' property.",tT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Cpe,"reqBodyValidationHandler");function Ppe(e,t,r){let n;e.body.operation!==wI.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==wI.OPERATIONS_ENUM.LOGIN&&e.body.operation!==wI.OPERATIONS_ENUM.LOGOUT?bpe(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{Zh.warn(s),Zh.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(II(s,i,tT.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(Ppe,"authHandler");async function Dpe(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=RK.chooseOperation(e.body);let s=await RK.processLocalTransaction(e,n);if(s instanceof Ape&&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(Ope({level:Npe.Z_BEST_SPEED})))}return s}catch(s){throw Zh.error(s),s}}a(Dpe,"handlePostRequest");yK.exports={authHandler:Ppe,handlePostRequest:Dpe,handleServerUncaughtException:wpe,serverErrorHandler:Ipe,reqBodyValidationHandler:Cpe}});var wK=C((Ove,NK)=>{"use strict";var Lpe=require("fastify-plugin"),{handlePostRequest:bK,authHandler:Mpe,reqBodyValidationHandler:vpe}=rT();async function Upe(e){e.decorate("hdbCore",{preValidation:[vpe,Mpe],request:a(t=>OK(bK(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>OK(bK(t,r,!0)),"requestWithoutAuthentication")})}a(Upe,"hdbCore");async function OK(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(OK,"convertAsyncIterators");NK.exports=Lpe(Upe)});var CK=C((Ive,IK)=>{"use strict";var wve=require("fs"),nT=ce();nT.initSync();var{CONFIG_PARAMS:CI}=(v(),D(q)),xpe=1024*1024*1024;function Bpe(e){let t=nT.get(CI.HTTP_TIMEOUT),r=nT.get(CI.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:xpe,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:nT.get(CI.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(Bpe,"getServerOptions");IK.exports=Bpe});var LK=C((Pve,DK)=>{"use strict";var PI=ce();PI.initSync();var{CONFIG_PARAMS:PK}=(v(),D(q));function Hpe(){let e=PI.get(PK.HTTP_CORSACCESSLIST),t=PI.get(PK.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(Hpe,"getCORSOptions");DK.exports=Hpe});var UK=C((Lve,vK)=>{"use strict";var MK=ce();MK.initSync();var kpe=(v(),D(q));function Fpe(){return MK.get(kpe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(Fpe,"getHeaderTimeoutConfig");vK.exports=Fpe});var LI={};Be(LI,{customFunctionsServer:()=>$pe,ready:()=>jK,start:()=>Gpe});function Gpe(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){zo||(zo=zK(t),Qe.http((await zo).server));let o=await zo,c=(0,DI.dirname)(s),l=(0,DI.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!xK.has(c)){xK.add(c);try{o.register(Kpe(c,l))}catch(u){if(u.message==="Root plugin has already booted")ut.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:jK}}async function $pe(){try{ut.info("In Custom Functions Fastify server"+process.cwd()),ut.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ut.debug(`Custom Functions server process ${process.pid} starting up.`),await Vpe();let e=GK.get(H.HTTP_SECUREPORT)>0,t;try{t=zo=await zK(e)}catch(r){throw ut.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw ut.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){ut.error(`Custom Functions ${process.pid} Error: ${e}`),ut.error(e),process.exit(1)}}async function Vpe(){try{ut.info("Custom Functions starting configuration."),await $K.setUsersWithRolesCache(),ut.info("Custom Functions completed configuration.")}catch(e){ut.error(e)}}function Kpe(e,t){return async function(r){try{ut.info("Custom Functions starting buildRoutes"),ut.trace("Loading fastify routes folder "+e),(0,BK.existsSync)(e)&&r.register(qK.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:ut.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?ut.error(s.message):s&&ut.error(s),o()})}catch(n){ut.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function zK(e){ut.info("Custom Functions starting buildServer.");let t=(0,VK.default)(e),r=(0,HK.default)(t);r.server.headersTimeout=(0,YK.default)(),r.setErrorHandler(WK.serverErrorHandler);let n=(0,KK.default)();return n&&r.register(kK.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(FK.default),await r.register(qpe),await r.after(),gR(r),ut.info("Custom Functions completed buildServer."),r}function jK(){if(zo)return zo.then?zo.then(e=>e.ready()):zo.ready()}var DI,BK,HK,kK,FK,qK,GK,ut,qpe,$K,VK,KK,YK,WK,zo,xK,QK=be(()=>{DI=require("path"),BK=require("fs"),HK=x(require("fastify")),kK=x(require("@fastify/cors")),FK=x(nO()),qK=x(require("@fastify/autoload")),GK=x(ce());v();ut=x(W()),qpe=x(wK()),$K=x(An()),VK=x(CK()),KK=x(LK()),YK=x(UK()),WK=x(rT());Eo();Yr();xK=new Set;a(Gpe,"start");a($pe,"customFunctionsServer");a(Vpe,"setUp");a(Kpe,"buildRouteFolder");a(zK,"buildServer");a(jK,"ready")});var MI={};Be(MI,{start:()=>Ype});function Ype(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,tY.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){XK||(XK=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=JK.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,ZK.default)(s,(0,eY.realpathSync)(o))}}return i(s)},{runFirst:!0})),JK.set(r,n)}}}var ZK,eY,tY,JK,XK,rY=be(()=>{ZK=x(require("send")),eY=require("fs"),tY=x(require("serve-static")),JK=new Map;a(Ype,"start")});var sY={};Be(sY,{Request:()=>vI,createReuseportFd:()=>sT});var nY,vI,UI,xI,sT,BI=be(()=>{nY=require("os"),vI=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new xI(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new UI(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},UI=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},xI=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,nY.platform)()!="win32"&&(sT=require("node-unix-socket").createReuseportFd)});var kI=C((Fve,iY)=>{"use strict";var ep=ce();ep.initSync();var Bd=require("fs-extra"),HI=require("path"),Hd=(v(),D(q)),Wpe=require("crypto"),zpe=require("uuid").v4;iY.exports=jpe;function jpe(){if(ep.getHdbBasePath()!==void 0){let e=HI.join(ep.getHdbBasePath(),Hd.LICENSE_KEY_DIR_NAME,Hd.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=HI.join(ep.getHdbBasePath(),Hd.LICENSE_KEY_DIR_NAME,Hd.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=HI.join(ep.getHdbBasePath(),Hd.LICENSE_KEY_DIR_NAME,Hd.JWT_ENUM.JWT_PASSPHRASE_NAME);try{Bd.accessSync(r),Bd.accessSync(e),Bd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=zpe(),i=Wpe.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});Bd.writeFileSync(r,s),Bd.writeFileSync(e,i.privateKey),Bd.writeFileSync(t,i.publicKey)}else throw n}}}a(jpe,"checkJWTTokenExist")});var aY=C((Gve,oY)=>{"use strict";var FI=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};oY.exports={HdbInfoInsertObject:FI}});var uY=C((Vve,lY)=>{"use strict";var cY=(v(),D(q)),qI=class{static{a(this,"UpgradeObject")}constructor(t,r){this[cY.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[cY.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};lY.exports={UpgradeObject:qI}});var iT=C((Yve,fY)=>{"use strict";var Hs=require("prompt"),kd=require("chalk"),dY=W(),Si=require("os"),GI=pa(),$I=["yes","y"];async function Qpe(e){let t=`${Si.EOL}`+kd.bold.green("Your current HarperDB version requires that we complete an update process.")+`${Si.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${Si.EOL}${Si.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${Si.EOL}`;Hs.override=GI(["CONFIRM_UPGRADE"]),Hs.start(),Hs.message=t;let r={properties:{CONFIRM_UPGRADE:{description:kd.magenta(`${Si.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 Hs.get([r])}catch(s){return dY.error("There was an error when prompting user about an upgrade."),dY.error(s),!1}return $I.includes(n.CONFIRM_UPGRADE)}a(Qpe,"forceUpdatePrompt");async function Jpe(e){let t=`${Si.EOL}`+kd.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${Si.EOL}`);Hs.override=GI(["CONFIRM_DOWNGRADE"]),Hs.start(),Hs.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:kd.magenta(`${Si.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 Hs.get([r]);return $I.includes(n.CONFIRM_DOWNGRADE)}a(Jpe,"forceDowngradePrompt");async function Xpe(){let e=`${Si.EOL}`+kd.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");Hs.override=GI(["GENERATE_CERTS"]),Hs.start(),Hs.message=e;let t={properties:{GENERATE_CERTS:{description:kd.magenta(`${Si.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 Hs.get([t]);return $I.includes(r.GENERATE_CERTS)}a(Xpe,"upgradeCertsPrompt");fY.exports={forceUpdatePrompt:Qpe,forceDowngradePrompt:Jpe,upgradeCertsPrompt:Xpe}});var KI=C((zve,_Y)=>{"use strict";var VI=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};_Y.exports=VI});var pY=C((eUe,hY)=>{"use strict";var Zpe=ae(),eEe=At(),Qve=W(),Jve=require("path"),Xve=require("fs"),Zve=(v(),D(q));hY.exports={getOldPropsValue:tEe};function tEe(e,t,r=!1){let n=t.getRaw(e);return Zpe.isNotEmptyAndHasValue(n)?n:r?eEe.getDefaultConfig(e):""}a(tEe,"getOldPropsValue")});var SY=C((rUe,gY)=>{"use strict";var rc=require("path"),nc=require("fs-extra"),rEe=require("properties-reader"),nEe=KI(),fr=W(),{getOldPropsValue:dt}=pY(),{HDB_SETTINGS_NAMES:me,CONFIG_PARAMS:Hl}=(v(),D(q)),kl=At(),oT=ce(),EY=ae(),ji=(v(),D(q)),YI=new nEe("3.1.0"),mY=[];function sEe(){let e=rEe(oT.get(me.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),fr.info(t);let r=` ;Settings for the HarperDB process.
|
|
38
|
+
IdentitiesOnly yes`;await Oe.pathExists(l)?await Oe.appendFile(l,`
|
|
39
|
+
`+u):await Oe.outputFile(l,u);let f="";if(await Oe.pathExists(Fo)||(await Oe.writeFile(Fo,""),await Oe.chmod(Fo,"0600")),i=="github.com"&&!(await Oe.readFile(Fo,"utf8")).includes("github.com"))try{let S=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let g of S)Oe.appendFile(Fo,"github.com "+g+`
|
|
40
|
+
`)}catch{f=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Oe.appendFile(Fo,o);let d=await pi(e);return d.message=`Added ssh key: ${r}${f}`,d}a(Hfe,"addSSHKey");async function kfe(e){let t=Dn.updateSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r,key:n}=e;Ut.trace("updating ssh key",r);let s=we.join(Qa,r+".key");if(!await Oe.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Oe.outputFile(s,n);let i=await pi(e);return i.message=`Updated ssh key: ${r}`,i}a(kfe,"updateSSHKey");async function Ffe(e){let t=Dn.deleteSSHKeyValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{name:r}=e;Ut.trace("deleting ssh key",r);let n=we.join(Qa,r+".key"),s=we.join(Qa,"config");if(!await Oe.pathExists(n))throw new Error("Key does not exist");let i=await Oe.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Oe.outputFile(s,i),Oe.removeSync(n);let c=await pi(e);return c.message=`Deleted ssh key: ${r}`,c}a(Ffe,"deleteSSHKey");async function Gfe(e){let t=[];return await Oe.pathExists(Qa)&&(await Oe.readdir(Qa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(Gfe,"listSSHKeys");async function qfe(e){let t=Dn.setSSHKnownHostsValidator(e);if(t)throw xt(t,t.message,Bt.BAD_REQUEST);let{known_hosts:r}=e;await Oe.outputFile(Fo,r);let n=await pi(e);return n.message="Known hosts successfully set",n}a(qfe,"setSSHKnownHosts");async function $fe(e){return await Oe.pathExists(Fo)?{known_hosts:await Oe.readFile(Fo,"utf8")}:{known_hosts:null}}a($fe,"getSSHKnownHosts");Object.assign(UV,{customFunctionsStatus:bfe,getCustomFunctions:Ofe,getCustomFunction:Nfe,setCustomFunction:wfe,dropCustomFunction:Ife,addComponent:Cfe,dropCustomFunctionProject:Pfe,packageComponent:Dfe,deployComponent:Lfe,getComponents:vfe,getComponentFile:Ufe,setComponentFile:xfe,dropComponent:Bfe,addSSHKey:Hfe,updateSSHKey:kfe,deleteSSHKey:Ffe,listSSHKeys:Gfe,setSSHKnownHosts:qfe,getSSHKnownHosts:$fe})});var Yw=I((xMe,BV)=>{"use strict";var Ms=require("joi"),xV=ut();BV.exports={readTransactionLogValidator:Vfe,deleteTransactionLogsBeforeValidator:Kfe};function Vfe(e){let t=Ms.object({schema:Ms.string(),database:Ms.string(),table:Ms.string().required(),from:Ms.date().timestamp(),to:Ms.date().timestamp(),limit:Ms.number().min(1)});return xV.validateBySchema(e,t)}a(Vfe,"readTransactionLogValidator");function Kfe(e){let t=Ms.object({schema:Ms.string(),database:Ms.string(),table:Ms.string().required(),timestamp:Ms.date().timestamp().required()});return xV.validateBySchema(e,t)}a(Kfe,"deleteTransactionLogsBeforeValidator")});var GS=I((HMe,$V)=>{"use strict";var Ww=(B(),C(G)),Qp=ir(),HV=oe(),kV=ce(),FV=To(),GV=Y(),{handleHDBError:kS,hdb_errors:Yfe}=pe(),{HTTP_STATUS_CODES:FS}=Yfe,{readTransactionLogValidator:Wfe,deleteTransactionLogsBeforeValidator:zfe}=Yw(),qV=Wn(),jfe="Logs successfully deleted from transaction log.",Qfe="All logs successfully deleted from transaction log.";$V.exports={readTransactionLog:Jfe,deleteTransactionLogsBefore:Zfe};async function Jfe(e){let t=Wfe(e);if(t)throw kS(t,t.message,FS.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=HV.checkSchemaTableExist(e.database,e.table);if(r)throw kS(new Error,r,FS.NOT_FOUND,void 0,void 0,!0);return kV.get(Ww.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Xfe(e):(GV.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)),qV.readAuditLog(e))}a(Jfe,"readTransactionLog");async function*Xfe(e){let t=FV.createNatsTableStreamName(e.database,e.table),r=await Qp.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===Ww.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Xfe,"readTransactionLogNats");async function Zfe(e){let t=zfe(e);if(t)throw kS(t,t.message,FS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!kV.get(Ww.CONFIG_PARAMS.CLUSTERING_ENABLED))return GV.info("Delete transaction logs called for Plexus"),qV.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=HV.checkSchemaTableExist(r,n);if(i)throw kS(new Error,i,FS.NOT_FOUND,void 0,void 0,!0);let o=FV.createNatsTableStreamName(r,n),{jsm:c}=await Qp.getNATSReferences(),l=await Qp.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let f=jfe,d,p=new Date(l.state.last_ts).getTime();return s>p?(d=l.state.last_seq+1,f=Qfe):d=(await Qp.viewStream(o,parseInt(s),1))[0].nats_sequence,await Qp.purgeTableStream(r,n,{seq:d}),f}a(Zfe,"deleteTransactionLogsBefore")});var KV=I((FMe,VV)=>{"use strict";var zw=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}};VV.exports=zw});var WV=I((qMe,YV)=>{"use strict";var jw=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};YV.exports=jw});var Jw=I((VMe,jV)=>{"use strict";var zV=KV(),e_e=WV(),{HDB_ERROR_MSGS:t_e}=Hn(),Qw=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=t_e.OP_AUTH_PERMS_ERROR,this.unauthorized_access={},this.invalid_schema_items=[]}handleUnauthorizedItem(t){return this.invalid_schema_items=[],this.unauthorized_access=[t],this}handleInvalidItem(t){return this.invalid_schema_items=[t],this.unauthorized_access=[],this}addInvalidItem(t,r,n){if(r&&n){let s=`${r}_${n}`;if(this.unauthorized_access[s])return}this.invalid_schema_items.push(t)}addUnauthorizedTable(t,r,n){let s=new zV(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new e_e(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new zV(r,n,[],i);this.unauthorized_access[o]=c}}getPermsResponse(){let t=Object.values(this.unauthorized_access);return t.length>0||this.invalid_schema_items.length>0?(this.unauthorized_access=t,this):null}};jV.exports=Qw});var KS=I((zMe,f1)=>{"use strict";var Xw=yn(),qS=Wr(),vs=Vg(),Zp=Ao(),Zw=Vc(),r_e=AN(),n_e=lG(),eh=Rn(),$S=q_(),Sr=Y(),s_e=NN(),i_e=Ed(),o_e=JN(),a_e=nS(),c_e=ew(),l_e=tw(),u_e=aS(),d_e=lS(),eI=uS(),Go=oe(),f_e=qq(),tI=hS(),XV=za(),nn=(B(),C(G)),ZV=rV(),__e=Do(),e1=(zu(),C(ep)),t1=(MS(),C(Gp)),r1=Rt(),cr=Vw(),p_e=require("alasql"),n1=GS(),s1=Kp(),Ud=rs(),i1=(Al(),C(Tl)),o1=Jw(),{handleHDBError:Ln,hdb_errors:a1}=pe(),{addNodeBack:YMe,removeNodeBack:WMe}=(Al(),C(Tl)),{HDB_ERROR_MSGS:xr,HTTP_STATUS_CODES:Jp}=a1,X=new Map,c1="delete",Ja="insert",qo="read",vl="update",Xp="describe",QV=Zp.describeSchema.name,JV=Zp.describeTable.name,l1={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},h_e={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},m_e="catchup",E_e="handleGetJob",g_e="handleGetJobsByStartDate",VS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},S_e=[vs.createTable.name,vs.createAttribute.name,vs.dropTable.name,vs.dropAttribute.name],u1={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},ne=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};X.set(Xw.insert.name,new ne(!1,[Ja]));X.set(Xw.update.name,new ne(!1,[vl]));X.set(Xw.upsert.name,new ne(!1,[Ja,vl]));X.set(qS.searchByConditions.name,new ne(!1,[qo]));X.set(qS.searchByHash.name,new ne(!1,[qo]));X.set(qS.searchByValue.name,new ne(!1,[qo]));X.set(qS.search.name,new ne(!1,[qo]));X.set(vs.createSchema.name,new ne(!0,[]));X.set(vs.createTable.name,new ne(!0,[]));X.set(vs.createAttribute.name,new ne(!1,[Ja]));X.set(vs.dropSchema.name,new ne(!0,[]));X.set(vs.dropTable.name,new ne(!0,[]));X.set(vs.dropAttribute.name,new ne(!0,[]));X.set(Zp.describeSchema.name,new ne(!1,[qo]));X.set(Zp.describeTable.name,new ne(!1,[qo]));X.set(Zw.deleteRecord.name,new ne(!1,[c1]));X.set(eh.addUser.name,new ne(!0,[]));X.set(eh.alterUser.name,new ne(!0,[]));X.set(eh.dropUser.name,new ne(!0,[]));X.set(eh.listUsersExternal.name,new ne(!0,[]));X.set($S.listRoles.name,new ne(!0,[]));X.set($S.addRole.name,new ne(!0,[]));X.set($S.alterRole.name,new ne(!0,[]));X.set($S.dropRole.name,new ne(!0,[]));X.set(s_e.name,new ne(!0,[]));X.set(i_e.name,new ne(!0,[]));X.set(o_e.name,new ne(!0,[]));X.set(a_e.name,new ne(!0,[]));X.set(c_e.name,new ne(!0,[]));X.set(l_e.name,new ne(!0,[]));X.set(eI.setRoutes.name,new ne(!0,[]));X.set(eI.getRoutes.name,new ne(!0,[]));X.set(eI.deleteRoutes.name,new ne(!0,[]));X.set(r1.setConfiguration.name,new ne(!0,[]));X.set(u_e.clusterStatus.name,new ne(!0,[]));X.set(d_e.name,new ne(!0,[]));X.set(tI.getFingerprint.name,new ne(!0,[]));X.set(tI.setLicense.name,new ne(!0,[]));X.set(Zw.deleteFilesBefore.name,new ne(!0,[]));X.set(Zw.deleteAuditLogsBefore.name,new ne(!0,[]));X.set(XV.restart.name,new ne(!0,[]));X.set(XV.restartService.name,new ne(!0,[]));X.set(r_e.name,new ne(!0,[]));X.set(n_e.name,new ne(!0,[qo]));X.set(__e.systemInformation.name,new ne(!0,[]));X.set(r1.getConfiguration.name,new ne(!0,[]));X.set(n1.readTransactionLog.name,new ne(!0,[]));X.set(n1.deleteTransactionLogsBefore.name,new ne(!0,[]));X.set(s1.installModules.name,new ne(!0,[]));X.set(s1.auditModules.name,new ne(!0,[]));X.set(Ud.createCsr.name,new ne(!0,[]));X.set(Ud.signCertificate.name,new ne(!0,[]));X.set(Ud.listCertificates.name,new ne(!0,[]));X.set(Ud.addCertificate.name,new ne(!0,[]));X.set(Ud.removeCertificate.name,new ne(!0,[]));X.set(Ud.getKey.name,new ne(!0,[]));X.set(i1.addNodeBack.name,new ne(!0,[]));X.set(i1.removeNodeBack.name,new ne(!0,[]));X.set(e1.createTokens.name,new ne(!1,[]));X.set(e1.refreshOperationToken.name,new ne(!1,[]));X.set(t1.login.name,new ne(!1,[]));X.set(t1.logout.name,new ne(!1,[]));X.set(cr.customFunctionsStatus.name,new ne(!0,[]));X.set(cr.getCustomFunctions.name,new ne(!0,[]));X.set(cr.getComponents.name,new ne(!0,[]));X.set(cr.getComponentFile.name,new ne(!0,[]));X.set(cr.setComponentFile.name,new ne(!0,[]));X.set(cr.dropComponent.name,new ne(!0,[]));X.set(cr.getCustomFunction.name,new ne(!0,[]));X.set(cr.setCustomFunction.name,new ne(!0,[]));X.set(cr.dropCustomFunction.name,new ne(!0,[]));X.set(cr.addComponent.name,new ne(!0,[]));X.set(cr.dropCustomFunctionProject.name,new ne(!0,[]));X.set(cr.packageComponent.name,new ne(!0,[]));X.set(cr.deployComponent.name,new ne(!0,[]));X.set(cr.addSSHKey.name,new ne(!0,[]));X.set(cr.updateSSHKey.name,new ne(!0,[]));X.set(cr.deleteSSHKey.name,new ne(!0,[]));X.set(cr.listSSHKeys.name,new ne(!0,[]));X.set(cr.setSSHKnownHosts.name,new ne(!0,[]));X.set(cr.getSSHKnownHosts.name,new ne(!0,[]));X.set(tI.getRegistrationInfo.name,new ne(!1,[]));X.set(eh.userInfo.name,new ne(!1,[]));X.set(Zp.describeAll.name,new ne(!1,[]));X.set(E_e,new ne(!1,[]));X.set(g_e,new ne(!0,[]));X.set(m_e,new ne(!0,[]));X.set(VS.CSV_DATA_LOAD,new ne(!1,[Ja,vl]));X.set(VS.CSV_URL_LOAD,new ne(!1,[Ja,vl]));X.set(VS.CSV_FILE_LOAD,new ne(!1,[Ja,vl]));X.set(VS.IMPORT_FROM_S3,new ne(!1,[Ja,vl]));X.set(u1.EXPORT_TO_S3,new ne(!0,[]));X.set(u1.EXPORT_LOCAL,new ne(!0,[]));X.set(nn.VALID_SQL_OPS_ENUM.DELETE,new ne(!1,[c1]));X.set(nn.VALID_SQL_OPS_ENUM.SELECT,new ne(!1,[qo]));X.set(nn.VALID_SQL_OPS_ENUM.INSERT,new ne(!1,[Ja]));X.set(nn.VALID_SQL_OPS_ENUM.UPDATE,new ne(!1,[vl]));f1.exports={verifyPerms:A_e,verifyPermsAst:T_e,verifyBulkLoadAttributePerms:y_e};function T_e(e,t,r){if(Go.isEmptyOrZeroLength(e))throw Sr.info("verify_perms_ast has an empty user parameter"),Ln(new Error);if(Go.isEmptyOrZeroLength(t))throw Sr.info("verify_perms_ast has an empty user parameter"),Ln(new Error);if(Go.isEmptyOrZeroLength(r))throw Sr.info("verify_perms_ast has a null operation parameter"),Ln(new Error);try{let n=new o1,s=new f_e(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Sr.info("No schemas defined in verifyPermsAst(), will not continue."),Ln(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&l1[r])throw Ln(new Error,xr.DROP_SYSTEM,Jp.FORBIDDEN);if(c&&!l)return null;let u=ZV.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof p_e.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let d=0;d<i.length;d++){let p=s.getTablesBySchemaName(i[d]);p&&o.set(i[d],p)}let f=d1(t,r,o,n);return f||(o.forEach((d,p)=>{for(let _=0;_<d.length;_++){let h=s.getAttributesBySchemaTableName(p,d[_]),S=nI(t.role.permission,p,d[_]);rI(h,S,r,d[_],p,n)}}),n.getPermsResponse())}catch(n){throw Ln(n)}}a(T_e,"verifyPermsAst");function A_e(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Sr.info("null required parameter in verifyPerms"),Ln(new Error,xr.DEFAULT_INVALID_REQUEST,Jp.BAD_REQUEST);let r;t instanceof Function?r=t.name:r=t;let n=e.action,s=e.schema??e.database,i=e.table,o=new Map;s&&i&&o.set(s,[i]);let c=new o1;if(Go.isEmptyOrZeroLength(e.hdb_user?.role)||Go.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return Sr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(xr.USER_HAS_NO_PERMS(e.hdb_user?.username));let l=!!e.hdb_user?.role?.permission?.super_user,u=e.hdb_user?.role?.permission?.structure_user,f=o.has(nn.SYSTEM_SCHEMA_NAME)||s===nn.SYSTEM_SCHEMA_NAME;if(l&&f&&h_e[e.operation]&&(i===nn.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===nn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===nn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(f&&l1[r])throw Ln(new Error,xr.DROP_SYSTEM,Jp.FORBIDDEN);if(l&&!f||u===!0&&(r===vs.createSchema.name||r===vs.dropSchema.name))return null;if(S_e.indexOf(r)>=0&&(u===!0||Array.isArray(u)))return u===!0||u.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let d=ZV.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=d),(r===QV||r===JV)&&!d.super_user){if(s===nn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(xr.SCHEMA_PERM_ERROR(s));if(r===QV&&(!d[s]||!d[s][Xp]))return c.handleInvalidItem(xr.SCHEMA_NOT_FOUND(s));if(r===JV&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Xp]))return c.handleInvalidItem(xr.TABLE_NOT_FOUND(s,i))}let p=d1(e.hdb_user,r,o,c,n);if(p)return p;if(X.get(r)&&X.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&nn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let S=[],g=d[s].tables[i];g[nn.PERMS_CRUD_ENUM.READ]&&(g.attribute_permissions.length>0?g.attribute_permissions.filter(E=>E[nn.PERMS_CRUD_ENUM.READ]).forEach(E=>{S.push(E.attribute_name)}):S=global.hdb_schema[s][i].attributes.map(A=>A.attribute),e.get_attributes=S)}let _=R_e(e),h=nI(e.hdb_user?.role?.permission,s,i);return rI(_,h,r,i,s,c,n),c.getPermsResponse()}a(A_e,"verifyPerms");function d1(e,t,r,n,s){if(Go.arrayHasEmptyValues([e,t,r]))throw Sr.info("hasPermissions has an invalid parameter"),Ln(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||X.get(t).requires_su))return null;if(!X.get(t))throw Sr.info(`operation ${t} not found.`),Ln(new Error,xr.OP_NOT_FOUND(t),Jp.BAD_REQUEST);if(X.get(t)&&X.get(t).requires_su)return Sr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(xr.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Xp]===!1){n.addInvalidItem(xr.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(xr.SCHEMA_NOT_FOUND(l));continue}let u=r.get(l);for(let f of u){let d=o[l].tables[f];if(!d||d[Xp]===!1)n.addInvalidItem(xr.TABLE_NOT_FOUND(l,f));else try{let p=[],_=X.get(t).perms;!Go.isEmpty(s)&&_.includes(s)&&(_=[s]);for(let h=0;h<_.length;h++){let S=_[h],g=d[S];(g==null||g===!1)&&(Sr.info(`Required ${S} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),p.push(S))}p.length>0&&n.addUnauthorizedTable(l,f,p)}catch(p){let _=xr.UNKNOWN_OP_AUTH_ERROR(t,l,f);throw Sr.error(_),Sr.error(p),Ln(a1.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(d1,"hasPermissions");function rI(e,t,r,n,s,i,o){if(!e||!t)throw Sr.info("no attributes specified in checkAttributePerms."),Ln(new Error);let c=X.get(r).perms;if(!c||c==="")throw Sr.info(`no permissions found for ${r} in checkAttributePerms().`),Ln(new Error);if(Go.isEmptyOrZeroLength(t))return Sr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let f of e){let d=t.get(f);if(d){if(d[Xp]===!1){i.addInvalidItem(xr.ATTR_NOT_FOUND(s,n,f),s,n);continue}if(c)for(let p of c){if(nn.TIME_STAMP_NAMES.includes(d.attribute_name)&&p!==qo)throw Ln(new Error,xr.SYSTEM_TIMESTAMP_PERMS_ERR,Jp.FORBIDDEN);d[p]===!1&&(l[d.attribute_name]?l[d.attribute_name].push(p):l[d.attribute_name]=[p])}}else i.addInvalidItem(xr.ATTR_NOT_FOUND(s,n,f),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(rI,"checkAttributePerms");function R_e(e){let t=new Set;try{if(e.action)return t;if(e.operation===nn.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){Sr.info(r)}return t}a(R_e,"getRecordAttributes");function nI(e,t,r){let n=new Map;if(Go.isEmpty(e))return Sr.info("no hdb_user specified in getAttributePermissions"),n;if(e.super_user||!t||!r)return n;try{e[t].tables[r].attribute_permissions.forEach(s=>{n.has(s.attribute_name)||n.set(s.attribute_name,s)})}catch{Sr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(nI,"getAttributePermissions");function y_e(e,t,r,n,s,i,o){let c=new Set(i),l=nI(e,n,s);rI(c,l,t,s,n,o,r)}a(y_e,"verifyBulkLoadAttributePerms")});var WS=I((QMe,E1)=>{"use strict";E1.exports={evaluateSQL:x_e,processAST:m1,convertSQLToAST:h1,checkASTPermissions:p1};var b_e=yn(),_1=require("util"),O_e=_1.callbackify(b_e.insert),N_e=Wr().search,w_e=ZH().update,I_e=_1.callbackify(w_e),C_e=tk().convertDelete,Xa=require("alasql"),P_e=KS(),YS=Y(),D_e=aE(),L_e=oe(),th=(B(),C(G)),{hdb_errors:M_e,handleHDBError:sI}=pe(),{HTTP_STATUS_CODES:iI}=M_e;D_e(Xa);var v_e=403,U_e="There was a problem performing this insert. Please check the logs and try again.",oI=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function x_e(e,t){let r=e.parsed_sql_object;if(!r){r=h1(e.sql);let n,s=r.ast.statements[0];if(s instanceof Xa.yy.Insert?n=s.into.databaseid:s instanceof Xa.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Xa.yy.Update||s instanceof Xa.yy.Delete?n=s.table.databaseid:YS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Xa.yy.Select)&&L_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}m1(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(x_e,"evaluateSQL");function p1(e,t){let r;try{r=P_e.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(p1,"checkASTPermissions");function h1(e){let t=new oI;if(!e)throw sI(new Error,"The 'sql' parameter is missing from the request body",iI.BAD_REQUEST);try{let r=e.trim(),n=Xa.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
41
|
+
`);throw n[1]?sI(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,iI.BAD_REQUEST):sI(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",iI.BAD_REQUEST)}return t}a(h1,"convertSQLToAST");function m1(e,t,r){try{let n=B_e;if(!e.bypass_auth&&!t.permissions_checked){let i=p1(e,t);if(i&&i.length>0)return r(v_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case th.VALID_SQL_OPS_ENUM.SELECT:n=N_e,s=t.ast.statements[0];break;case th.VALID_SQL_OPS_ENUM.INSERT:n=H_e;break;case th.VALID_SQL_OPS_ENUM.UPDATE:n=I_e;break;case th.VALID_SQL_OPS_ENUM.DELETE:n=C_e;break;default:throw new Error(`unsupported SQL type ${t.variant} in SQL: ${e}`)}n(s,(i,o)=>{if(i){r(i);return}r(null,o)})}catch(n){return r(n)}}a(m1,"processAST");function B_e(e,t){YS.info(e),t("unknown sql statement")}a(B_e,"nullFunction");function H_e({statement:e,hdb_user:t},r){let n=e.into,s={schema:n.databaseid,table:n.tableid,operation:"insert",hdb_user:t},i=e.columns.map(o=>o.columnid);try{s.records=k_e(i,e.values)}catch(o){return r(o)}O_e(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){YS.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(H_e,"convertInsert");function k_e(e,t){try{return t.map(r=>{if(e.length!==r.length)throw"number of values do not match number of columns in insert";let n={};return r.forEach((s,i)=>{if(s.columnid)throw"cannot use a column in insert value";"value"in s?n[e[i]]=s.value:n[e[i]]=Xa.compile(`SELECT ${s.toString()} AS [${th.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw YS.error(r),new Error(U_e)}}a(k_e,"createDataObjects")});var fI=I((eve,A1)=>{var JS=require("clone"),XS=ut(),F_e=oe(),jS=(B(),C(G)),XMe=Y(),aI=require("fs"),lI=require("joi"),{string:QS}=lI.types(),{hdb_errors:G_e,handleHDBError:zS}=pe(),{HDB_ERROR_MSGS:ZMe,HTTP_STATUS_CODES:cI}=G_e,{common_validators:xd}=vi(),g1=" is required",q_e=["insert","update","upsert"],uI={database:{presence:!1,format:xd.schema_format,length:xd.schema_length},schema:{presence:!1,format:xd.schema_format,length:xd.schema_length},table:{presence:!0,format:xd.schema_format,length:xd.schema_length},action:{inclusion:{within:q_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},$_e={schema:QS.required(),table:QS.required(),action:QS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:V_e,AWS_SECRET:K_e,AWS_BUCKET:Y_e,AWS_FILE_KEY:W_e,REGION:z_e}=jS.S3_BUCKET_AUTH_KEYS,j_e={s3:{presence:!0},[`s3.${V_e}`]:{presence:!0,type:"String"},[`s3.${K_e}`]:{presence:!0,type:"String"},[`s3.${Y_e}`]:{presence:!0,type:"String"},[`s3.${W_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${z_e}`]:{presence:!0,type:"String"}},S1=JS(uI);S1.data.presence={message:g1};var T1=JS(uI);T1.file_path.presence={message:g1};var Q_e=Object.assign(JS(uI),j_e),dI=JS($_e);dI.csv_url=QS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();dI.passthrough_headers=lI.object();function J_e(e){let t=XS.validateObject(e,S1);return ZS(e,t)}a(J_e,"dataObject");function X_e(e){let t=XS.validateBySchema(e,lI.object(dI));return ZS(e,t)}a(X_e,"urlObject");function Z_e(e){let t=XS.validateObject(e,T1);return ZS(e,t)}a(Z_e,"fileObject");function epe(e){let t=XS.validateObject(e,Q_e);return ZS(e,t)}a(epe,"s3FileObject");function ZS(e,t){if(!t){let r=F_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return zS(new Error,r,cI.BAD_REQUEST);if(e.operation===jS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{aI.accessSync(e.file_path,aI.constants.R_OK|aI.constants.F_OK)}catch(n){return n.code===jS.NODE_ERROR_CODES.ENOENT?zS(n,`No such file or directory ${n.path}`,cI.BAD_REQUEST):n.code===jS.NODE_ERROR_CODES.EACCES?zS(n,`Permission denied ${n.path}`,cI.BAD_REQUEST):zS(n)}}return t}a(ZS,"postValidateChecks");A1.exports={dataObject:J_e,urlObject:X_e,fileObject:Z_e,s3FileObject:epe}});var _I=I((rve,R1)=>{"use strict";var rh=Y(),eT=(B(),C(G));async function tpe(e,t,r,n=void 0){if(!e||typeof e!="function")throw new Error("Invalid function parameter");let s;try{return s=await e(t),r&&await r(t,s,n),t.operation===eT.OPERATIONS_ENUM.INSERT||t.operation===eT.OPERATIONS_ENUM.UPDATE||t.operation===eT.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===eT.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(rh.info(i.message),i):i.http_resp_msg?(rh.error(`Error calling operation: ${e.name}`),rh.error(i.http_resp_msg),i):(rh.error(`Error calling operation: ${e.name}`),rh.error(i),i)}}a(tpe,"callOperationFunctionAsAwait");R1.exports={callOperationFunctionAsAwait:tpe}});var pI=I((sve,b1)=>{"use strict";var{S3:rpe,GetObjectCommand:npe}=require("@aws-sdk/client-s3");b1.exports={getFileStreamFromS3:spe,getS3AuthObj:y1};async function spe(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await y1(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new npe(r))).Body}a(spe,"getFileStreamFromS3");function y1(e,t,r){return new rpe({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(y1,"getS3AuthObj")});var N1=I((ove,O1)=>{"use strict";var hI=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}},mI=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};O1.exports={BulkLoadFileObject:hI,BulkLoadDataObject:mI}});var I1=I((cve,w1)=>{"use strict";var EI=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};w1.exports=EI});var yI=I((pve,K1)=>{"use strict";var tT=yn(),nT=fI(),ipe=require("needle"),hi=(B(),C(G)),uve=St(),Bd=oe(),{handleHDBError:Ht,hdb_errors:B1}=pe(),{HTTP_STATUS_CODES:Br,HDB_ERROR_MSGS:Tr,CHECK_LOGS_WRAPPER:xl}=B1,Hd=Y(),gI=require("papaparse");Bd.promisifyPapaParse();var mi=require("fs-extra"),ope=require("path"),{chain:C1}=require("stream-chain"),P1=require("stream-json/streamers/StreamArray"),D1=require("stream-json/utils/Batch"),L1=require("stream-chain/utils/comp"),{finished:M1}=require("stream"),ape=ce(),H1=_I(),cpe=pI(),{BulkLoadFileObject:TI,BulkLoadDataObject:lpe}=N1(),AI=Jw(),{verifyBulkLoadAttributePerms:k1}=KS(),dve=I1(),fve=ir(),_ve=To(),{databases:upe}=(Pe(),C(rt)),{coerceType:dpe}=(Gf(),C(bI)),v1="No records parsed from csv file.",Ul=`${ape.get("HDB_ROOT")}/tmp`,{schema_regex:fpe}=vi(),U1=1024*1024*2,x1=5e3,_pe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};K1.exports={csvDataLoad:ppe,csvURLLoad:hpe,csvFileLoad:mpe,importFromS3:Epe};async function ppe(e,t){let r=nT.dataObject(e);if(r)throw Ht(r,r.message,Br.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=q1(e.schema,e.table),i=gI.parse(e.data,{header:!0,skipEmptyLines:!0,transform:SI.bind(null,s),dynamicTyping:!1}),o=new AI;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&k1(e.hdb_user?.role?.permission,this.job_operation_function.name,e.action,e.schema,e.table,i.meta.fields,o);let c=o.getPermsResponse();if(c)throw Ht(new Error,c,Br.BAD_REQUEST,void 0,void 0,!0);let l=new lpe(e.action,e.schema,e.table,i.data);return n=await H1.callOperationFunctionAsAwait($1,l,null),n.message===v1?v1:V1(n.records,n.number_written)}catch(s){throw Bl(s)}}a(ppe,"csvDataLoad");async function hpe(e){let t=nT.urlObject(e);if(t)throw Ht(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Ul}/${r}`;try{await gpe(e,r)}catch(s){throw Hd.error(Tr.DOWNLOAD_FILE_ERR(r)+" - "+s),Ht(s,xl(Tr.DOWNLOAD_FILE_ERR(r)))}try{let s=new TI(this.job_operation_function.name,e.action,e.schema,e.table,n,hi.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await RI(s);return await rT(n),i}catch(s){throw await rT(n),Bl(s)}}a(hpe,"csvURLLoad");async function mpe(e){let t=nT.fileObject(e);if(t)throw Ht(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=new TI(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,hi.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await RI(r)}catch(n){throw Bl(n)}}a(mpe,"csvFileLoad");async function Epe(e){let t=nT.s3FileObject(e);if(t)throw Ht(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=ope.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Ul}/${s}`;let i=new TI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Spe(s,e);let o=await RI(i);return await rT(r),o}catch(n){throw await rT(r),Bl(n)}}a(Epe,"importFromS3");async function gpe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await ipe("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw Ht(n,s,n.statusCode,hi.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Ape(r,e.csv_url),await Tpe(t,r.raw)}a(gpe,"downloadCSVFile");async function Spe(e,t){try{let r=`${Ul}/${e}`;await mi.mkdirp(Ul),await mi.writeFile(`${Ul}/${e}`,"",{flag:"a+"});let n=await mi.createWriteStream(r),s=await cpe.getFileStreamFromS3(t);await new Promise((i,o)=>{s.on("error",function(c){o(c)}),s.pipe(n).on("error",function(c){o(c)}).on("close",function(){Hd.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Hd.error(Tr.S3_DOWNLOAD_ERR+" - "+r),Ht(r,xl(Tr.S3_DOWNLOAD_ERR))}}a(Spe,"downloadFileFromS3");async function Tpe(e,t){try{await mi.mkdirp(Ul),await mi.writeFile(`${Ul}/${e}`,t)}catch(r){throw Hd.error(Tr.WRITE_TEMP_FILE_ERR),Ht(r,xl(Tr.DEFAULT_BULK_LOAD_ERR))}}a(Tpe,"writeFileToTempFolder");async function rT(e){if(e)try{await mi.access(e),await mi.unlink(e)}catch{Hd.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(rT,"deleteTempFile");function Ape(e,t){if(e.statusCode!==B1.HTTP_STATUS_CODES.OK)throw Ht(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Br.BAD_REQUEST);if(!_pe[e.headers["content-type"]])throw Ht(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Br.BAD_REQUEST);if(!e.raw)throw Ht(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Br.BAD_REQUEST)}a(Ape,"validateURLResponse");async function RI(e){try{let t;switch(e.file_type){case hi.VALID_S3_FILE_TYPES.CSV:t=await Rpe(e);break;case hi.VALID_S3_FILE_TYPES.JSON:t=await ype(e);break;default:throw Ht(new Error,Tr.DEFAULT_BULK_LOAD_ERR,Br.BAD_REQUEST,hi.LOG_LEVELS.ERROR,Tr.INVALID_FILE_EXT_ERR(e))}return V1(t.records,t.number_written)}catch(t){throw Bl(t)}}a(RI,"fileLoad");async function F1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;s&&s.pause();let o={operation:e.action,schema:e.schema,table:e.table,records:i};try{let{attributes:c}=await tT.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&k1(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=Ht(c);r(l)}}a(F1,"validateChunk");async function G1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Bd.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Bd.isEmpty(c)&&!Bd.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(u=>c.add(u))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await H1.callOperationFunctionAsAwait($1,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=Ht(c,xl(Tr.INSERT_CSV_ERR),Br.INTERNAL_SERVER_ERROR,hi.LOG_LEVELS.ERROR,Tr.INSERT_CSV_ERR+" - "+c);r(l)}}a(G1,"insertChunk");async function Rpe(e){let t={records:0,number_written:0},r=q1(e.schema,e.table);try{let n=new AI,s=mi.createReadStream(e.file_path,{highWaterMark:U1});s.setEncoding("utf8"),await gI.parsePromise(s,F1.bind(null,e,n),SI.bind(null,r));let i=n.getPermsResponse();if(i)throw Ht(new Error,i,Br.BAD_REQUEST);return s=mi.createReadStream(e.file_path,{highWaterMark:U1}),s.setEncoding("utf8"),await gI.parsePromise(s,G1.bind(null,e,t),SI.bind(null,r)),s.destroy(),t}catch(n){throw Ht(n,xl(Tr.PAPA_PARSE_ERR),Br.INTERNAL_SERVER_ERROR,hi.LOG_LEVELS.ERROR,Tr.PAPA_PARSE_ERR+n)}}a(Rpe,"callPapaParse");function q1(e,t){let r=upe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>dpe(i,s));return n}a(q1,"createTransformMap");function SI(e,t,r){let n=e.get(r);return n?n(t):Bd.autoCast(t)}a(SI,"typeFunction");async function ype(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new AI,s=C1([mi.createReadStream(e.file_path,{encoding:"utf-8"}),P1.withParser(),c=>c.value,new D1({batchSize:x1}),L1(async c=>{await F1(e,n,r,c)})]);await new Promise((c,l)=>{M1(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw Ht(new Error,i,Br.BAD_REQUEST);let o=C1([mi.createReadStream(e.file_path,{encoding:"utf-8"}),P1.withParser(),c=>c.value,new D1({batchSize:x1}),L1(async c=>{await G1(e,t,r,c)})]);return await new Promise((c,l)=>{M1(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw Ht(n,xl(Tr.INSERT_JSON_ERR),Br.INTERNAL_SERVER_ERROR,hi.LOG_LEVELS.ERROR,Tr.INSERT_JSON_ERR+n)}}a(ype,"insertJson");async function $1(e){let t={};try{e.data&&e.data.length>0&&bpe(e.data[0])?t=await Ope(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Hd.info(t.message))}catch(r){throw Bl(r)}return t}a($1,"callBulkFileLoad");function bpe(e){let t=Object.keys(e);for(let r of t)if(!fpe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(bpe,"validateColumnNames");async function Ope(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=tT.insert;break;case"update":i=tT.update;break;case"upsert":i=tT.upsert;break;default:throw Ht(new Error,Tr.INVALID_ACTION_PARAM_ERR(n),Br.BAD_REQUEST,hi.LOG_LEVELS.ERROR,Tr.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let f=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][f])>=0&&e.splice(d,1)}let l=Bd.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw Bl(o)}}a(Ope,"bulkFileLoad");function V1(e,t){return`successfully loaded ${t} of ${e} records`}a(V1,"buildResponseMsg");function Bl(e){return Ht(e,xl(Tr.DEFAULT_BULK_LOAD_ERR),Br.INTERNAL_SERVER_ERROR,hi.LOG_LEVELS.ERROR,Tr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(Bl,"buildTopLevelErrMsg")});var wI=I((mve,Z1)=>{"use strict";var NI=Wr(),Npe=pI(),{AsyncParser:wpe}=require("json2csv"),sT=require("stream"),cs=oe(),OI=require("fs-extra"),Ipe=require("path"),Us=Y(),{promisify:z1}=require("util"),nh=oe(),{handleHDBError:lr,hdb_errors:Cpe}=pe(),{HDB_ERROR_MSGS:Mn,HTTP_STATUS_CODES:ur}=Cpe,{streamAsJSON:Ppe}=(yR(),C(FL)),{Upload:Dpe}=require("@aws-sdk/lib-storage"),{toCsvStream:Lpe}=(fo(),C(oM)),Y1=["search_by_value","search_by_hash","sql","search_by_conditions"],W1=["json","csv"],j1="json",Q1="csv",Mpe="Successfully exported JSON locally.",vpe="Successfully exported CSV locally.",Upe=1e3,xpe=NI.searchByHash,Bpe=NI.searchByValue,Hpe=z1(sT.finished);Z1.exports={export_to_s3:qpe,export_local:kpe};async function kpe(e){Us.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=J1(e);if(!cs.isEmpty(t))throw Us.error(t),lr(new Error,t,ur.BAD_REQUEST,void 0,void 0,!0);if(cs.isEmpty(e.path))throw Us.error(Mn.MISSING_VALUE("path")),lr(new Error,Mn.MISSING_VALUE("path"),ur.BAD_REQUEST,void 0,void 0,!0);let r=(cs.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Ipe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=cs.buildFolderPath(e.path,r);await Fpe(e.path);let s=await X1(e);return await Gpe(n,e.format,s)}a(kpe,"export_local");async function Fpe(e){if(Us.trace("in confirmPath"),cs.isEmptyOrZeroLength(e))throw lr(new Error,`Invalid path: ${e}`,ur.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await OI.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,Us.error(n),lr(new Error,n,ur.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 Us.error(r),lr(new Error,r,ur.BAD_REQUEST,void 0,void 0,!0)}return!0}a(Fpe,"confirmPath");async function Gpe(e,t,r){if(Us.trace("in saveToLocal"),nh.isEmptyOrZeroLength(e))throw lr(new Error,Mn.INVALID_VALUE("file_path"),ur.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmptyOrZeroLength(t))throw lr(new Error,Mn.INVALID_VALUE("Source format"),ur.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmpty(r))throw lr(new Error,Mn.NOT_FOUND("Data"),ur.BAD_REQUEST,void 0,void 0,!0);if(t===j1){let n=OI.createWriteStream(e);return Ppe(r).pipe(n),await Hpe(n),{message:Mpe,path:e}}else if(t===Q1){let n=OI.createWriteStream(e),s=sT.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(f=>({label:f,value:f})));let c={objectMode:!0};return await new wpe(i,c).fromInput(s).toOutput(n).promise(!1),{message:vpe,path:e}}throw lr(new Error,Mn.INVALID_VALUE("format"),ur.BAD_REQUEST)}a(Gpe,"saveToLocal");async function qpe(e){if(!e.s3||Object.keys(e.s3).length===0)throw lr(new Error,Mn.MISSING_VALUE("S3 object"),ur.BAD_REQUEST);if(cs.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw lr(new Error,Mn.MISSING_VALUE("aws_access_key_id"),ur.BAD_REQUEST);if(cs.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw lr(new Error,Mn.MISSING_VALUE("aws_secret_access_key"),ur.BAD_REQUEST);if(cs.isEmptyOrZeroLength(e.s3.bucket))throw lr(new Error,Mn.MISSING_VALUE("bucket"),ur.BAD_REQUEST);if(cs.isEmptyOrZeroLength(e.s3.key))throw lr(new Error,Mn.MISSING_VALUE("key"),ur.BAD_REQUEST);if(cs.isEmptyOrZeroLength(e.s3.region))throw lr(new Error,Mn.MISSING_VALUE("region"),ur.BAD_REQUEST);let t=J1(e);if(!cs.isEmpty(t))throw lr(new Error,t,ur.BAD_REQUEST);Us.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await X1(e)}catch(l){throw Us.error(l),l}let n,s=await Npe.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new sT.PassThrough;if(e.format===Q1){i=e.s3.key+".csv";let l=Lpe(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===j1){i=e.s3.key+".json";let l=new sT.Readable;l.pipe(o),l.on("error",d=>{throw d}),l.push("[");let u=r.length,f="";for(let[d,p]of r.entries()){let _=d===u-1?JSON.stringify(p):JSON.stringify(p)+",";f+=_,d!==0&&d%Upe===0&&(l.push(f),f="")}f.length!==0&&l.push(f),l.push("]"),l.push(null)}else throw lr(new Error,Mn.INVALID_VALUE("format"),ur.BAD_REQUEST);return new Dpe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(qpe,"export_to_s3");function J1(e){if(Us.trace("in exportCoreValidation"),cs.isEmpty(e.format))return"format missing";if(W1.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${W1.join(", ")}`;let t=e.search_operation.operation;if(cs.isEmpty(t))return"search_operation.operation missing";if(Y1.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${Y1.join(", ")}`}a(J1,"exportCoreValidation");async function X1(e){Us.trace("in getRecords");let t,r;if(nh.isEmpty(e.search_operation)||nh.isEmptyOrZeroLength(e.search_operation.operation))throw lr(new Error,Mn.INVALID_VALUE("Search operation"),ur.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=Bpe;break;case"search_by_hash":t=xpe;break;case"search_by_conditions":t=NI.searchByConditions;break;case"sql":{let n=WS();t=z1(n.evaluateSQL);break}default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,Us.error(r),lr(new Error,r,ur.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(X1,"getRecords")});var tK=I((gve,eK)=>{"use strict";var II=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};eK.exports=II});var sK=I((Tve,nK)=>{"use strict";var $pe=(B(),C(G)),rK=require("moment"),Vpe=require("uuid").v4,CI=class{static{a(this,"JobObject")}constructor(){this.id=Vpe(),this.type=void 0,this.start_datetime=rK().valueOf(),this.created_datetime=rK().valueOf(),this.end_datetime=void 0,this.status=$pe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};nK.exports=CI});var PI=I((Rve,fK)=>{"use strict";var Kpe=require("uuid").v4,lK=yn(),uK=Wr(),Ype=ii(),Wpe=Hu(),zpe=tK(),bt=(B(),C(G)),jpe=sK(),Qpe=ng(),Ei=Y(),Jpe=vf(),kd=oe(),{promisify:Xpe}=require("util"),Hl=require("moment"),Zpe=WS(),iT=fI(),iK=wy(),{deleteTransactionLogsBeforeValidator:ehe}=Yw(),{handleHDBError:oK,hdb_errors:the,ClientError:rhe}=pe(),{HTTP_STATUS_CODES:aK}=the,cK=uK.searchByValue,nhe=uK.searchByHash,she=lK.insert,ihe=Xpe(Zpe.evaluateSQL),ohe=lK.update;fK.exports={addJob:lhe,updateJob:dhe,handleGetJob:ahe,handleGetJobsByStartDate:che,getJobById:dK};async function ahe(e){if(e.id===void 0)throw new rhe("'id' is required");let t=await dK(e.id);return kd.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}a(ahe,"handleGetJob");async function che(e){try{let t=await uhe(e);if(Ei.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=Hl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Hl(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 Ei.error(r),new Error(r)}}a(che,"handleGetJobsByStartDate");async function lhe(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||kd.isEmptyOrZeroLength(e.operation)){let f="job parameter is invalid";return Ei.info(f),t.error=f,t}if(!bt.JOB_TYPE_ENUM[e.operation])return Ei.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case bt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=iT.fileObject(e);break;case bt.OPERATIONS_ENUM.CSV_URL_LOAD:n=iT.urlObject(e);break;case bt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=iT.dataObject(e);break;case bt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=iT.s3FileObject(e);break;case bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=iK(e,"date");break;case bt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=iK(e,"timestamp");break;case bt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=ehe(e);break;case bt.OPERATIONS_ENUM.RESTART_SERVICE:if(bt.HDB_PROCESS_SERVICES[e.service]===void 0)throw oK(new Error,"Invalid service",aK.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw oK(n,n.message,aK.BAD_REQUEST,void 0,void 0,!0);let s=new jpe;s.type=e.operation===bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new Ype(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await cK(i))}catch(f){let d=`There was an error inserting a new job: ${f}`;return Ei.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Kpe();try{o=await cK(i)}catch(f){let d=`There was an error inserting a new job: ${f}`;return Ei.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return Ei.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Jpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await she(l)}catch(f){return Ei.error(`There was an error inserting a job for job type: ${e.operation} -- ${f}`),t.success=!1,t}if(u.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let f=`Created a job with type ${s.type} and id ${s.id}`;t.message=f,t.createdJob=s,t.success=!0,Ei.trace(f)}return t}a(lhe,"addJob");async function uhe(e){let t=Hl(e.from_date,Hl.ISO_8601),r=Hl(e.to_date,Hl.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new zpe(n,e.hdb_user);try{return await ihe(s)}catch(i){throw Ei.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(uhe,"getJobsInDateRange");async function dK(e){if(kd.isEmptyOrZeroLength(e))return kd.errorizeMessage("Invalid job ID specified.");let t=new Wpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await nhe(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return Ei.error(n),kd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(dK,"getJobById");async function dhe(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(kd.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===bt.JOB_STATUS_ENUM.COMPLETE||e.status===bt.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Hl().valueOf());let t=new Qpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await ohe(t),r}a(dhe,"updateJob")});var TK=I((bve,SK)=>{"use strict";var _K=oe(),Ar=(B(),C(G)),fhe=require("moment"),oT=yI(),sh=Y(),pK=PI(),hK=wI(),mK=Vc(),EK=tt(),_he=GS(),phe=za(),{parentPort:hhe,isMainThread:gK}=require("worker_threads"),{onMessageByType:mhe}=tt(),DI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Ehe(e){if(!e||Object.keys(e).length===0)throw new Error("Empty runner passed to parseMessage");if(!e.json||Object.keys(e.json).length===0)throw new Error("Empty JSON passed to parseMessage");if(!e.job||Object.keys(e.job).length===0)throw new Error("Empty job passed to parseMessage");if(_K.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(_K.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Ar.JOB_TYPE_ENUM.csv_file_load:await ji(e,oT.csvFileLoad);break;case Ar.JOB_TYPE_ENUM.csv_url_load:await ji(e,oT.csvURLLoad);break;case Ar.JOB_TYPE_ENUM.csv_data_load:await ji(e,oT.csvDataLoad);break;case Ar.JOB_TYPE_ENUM.import_from_s3:await ji(e,oT.importFromS3);break;case Ar.JOB_TYPE_ENUM.empty_trash:break;case Ar.JOB_TYPE_ENUM.export_local:await ji(e,hK.export_local);break;case Ar.JOB_TYPE_ENUM.export_to_s3:await ji(e,hK.export_to_s3);break;case Ar.JOB_TYPE_ENUM.delete_files_before:case Ar.JOB_TYPE_ENUM.delete_records_before:await ji(e,mK.deleteFilesBefore);break;case Ar.JOB_TYPE_ENUM.delete_audit_logs_before:await ji(e,mK.deleteAuditLogsBefore);break;case Ar.JOB_TYPE_ENUM.delete_transaction_logs_before:await ji(e,_he.deleteTransactionLogsBefore);break;case Ar.JOB_TYPE_ENUM.restart_service:return await ji(e,phe.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(Ehe,"parseMessage");async function ji(e,t){try{e.job.status=Ar.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=fhe().valueOf(),await pK.updateJob(e.job),await ghe(e.job.id)}catch(r){let n=r.message!==void 0?r.message:r;typeof n=="string"?(n=`There was an error running ${t.name} job with id ${e.job.id} - ${n}`,r.message=n):sh.error(`There was an error running ${t.name} job with id ${e.job.id}`),sh.error(n),e.job.message=n,e.job.status=Ar.JOB_STATUS_ENUM.ERROR;try{await pK.updateJob(e.job)}catch(s){throw sh.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(ji,"runJob");async function ghe(e){sh.trace("launching job thread:",e),gK?EK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):hhe.postMessage({type:Ar.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(ghe,"launchJobThread");gK&&mhe(Ar.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{EK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){sh.error(r)}});SK.exports={parseMessage:Ehe,RunnerMessage:DI}});var RK=I((Nve,AK)=>{"use strict";var LI=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};AK.exports=LI});var Kw=I((Cve,HI)=>{"use strict";var dT=Wr(),UI=WS(),aT=yI(),$o=Vg(),cT=Ao(),oh=Vc(),She=AN(),ih=Rn(),lT=q_(),It=Vw(),uT=Y(),The=NN(),Ahe=Ed(),yK=JN(),Rhe=nS(),yhe=ew(),bhe=tw(),Ohe=aS(),Nhe=lS(),MI=uS(),bK=wI(),whe=KS(),xI=PI(),V=(B(),C(G)),{hdb_errors:ch,handleHDBError:ah}=pe(),{HTTP_STATUS_CODES:OK}=ch,vI=hS(),NK=za(),xK=require("util"),Gd=yn(),Ihe=bs(),Che=Do(),wK=TK(),IK=(zu(),C(ep)),CK=(MS(),C(Gp)),PK=Rt(),DK=GS(),LK=Kp(),{setServerUtilities:Phe}=(Gf(),C(bI)),{CONTEXT:Ive}=(ga(),C(mR)),{_assignPackageExport:Dhe}=yi(),{transformReq:Lhe}=oe(),{server:Mhe}=(Kr(),C(Tu)),sn=uT.loggerWithTag("operation"),Fd=rs(),MK=(Al(),C(Tl)),vhe=_I(),vK=dT.searchByHash,Uhe=dT.searchByValue,xhe=xK.promisify(dT.search),Bhe=xK.promisify(UI.evaluateSQL),Hhe={[V.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[V.OPERATIONS_ENUM.CREATE_TABLE]:!0,[V.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[V.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[V.OPERATIONS_ENUM.DROP_TABLE]:!0,[V.OPERATIONS_ENUM.DROP_SCHEMA]:!0},ee=RK();async function BK(e,t){try{if(e.body.operation!=="read_log"&&(uT.log_level===V.LOG_LEVELS.INFO||uT.log_level===V.LOG_LEVELS.DEBUG||uT.log_level===V.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;sn.info(c)}}catch(n){sn.error(n)}let r=await vhe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Hhe[e.body.operation]&&Ihe.setSchemaDataToGlobal(n=>{n&&sn.error(n)}),r}a(BK,"processLocalTransaction");var UK=Fhe();HI.exports={chooseOperation:HK,getOperationFunction:kK,operation:BI,processLocalTransaction:BK,executeJob:xs};Phe(HI.exports);Mhe.operation=BI;function HK(e){let t;try{t=kK(e)}catch(s){throw sn.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=UI.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=UI.checkASTPermissions(e,i);if(o)throw sn.error(`${OK.FORBIDDEN} from operation ${e.operation}`),sn.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==V.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==V.OPERATIONS_ENUM.LOGIN&&e.operation!==V.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=whe.verifyPerms(i,s);if(o)throw sn.error(`${OK.FORBIDDEN} from operation ${e.operation}`),sn.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw ah(s,"There was an error when trying to choose an operation path")}return r}a(HK,"chooseOperation");function kK(e){if(sn.trace(`getOperationFunction with operation: ${e.operation}`),UK.has(e.operation))return UK.get(e.operation);throw ah(new Error,ch.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),ch.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(kK,"getOperationFunction");Dhe("operation",BI);function BI(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=HK(e);return BK({body:e},n)}a(BI,"operation");async function khe(e){sn.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[V.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case V.OPERATIONS_ENUM.INSERT:o=await Gd.insert(i);break;case V.OPERATIONS_ENUM.UPDATE:o=await Gd.update(i);break;case V.OPERATIONS_ENUM.UPSERT:o=await Gd.upsert(i);break;case V.OPERATIONS_ENUM.DELETE:o=await oh.deleteRecord(i);break;default:sn.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){sn.info("Invalid operation in transaction"),sn.error(o)}}a(khe,"catchup");async function xs(e){Lhe(e);let t,r;try{r=await xI.addJob(e),t=r.createdJob,sn.info("addJob result",r);let n=new wK.RunnerMessage(t,e);return{message:await wK.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw sn.error(s),ah(n,s)}}a(xs,"executeJob");function Fhe(){let e=new Map;return e.set(V.OPERATIONS_ENUM.INSERT,new ee(Gd.insert)),e.set(V.OPERATIONS_ENUM.UPDATE,new ee(Gd.update)),e.set(V.OPERATIONS_ENUM.UPSERT,new ee(Gd.upsert)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new ee(dT.searchByConditions)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_HASH,new ee(vK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_ID,new ee(vK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_VALUE,new ee(Uhe)),e.set(V.OPERATIONS_ENUM.SEARCH,new ee(xhe)),e.set(V.OPERATIONS_ENUM.SQL,new ee(Bhe)),e.set(V.OPERATIONS_ENUM.CSV_DATA_LOAD,new ee(xs,aT.csvDataLoad)),e.set(V.OPERATIONS_ENUM.CSV_FILE_LOAD,new ee(xs,aT.csvFileLoad)),e.set(V.OPERATIONS_ENUM.CSV_URL_LOAD,new ee(xs,aT.csvURLLoad)),e.set(V.OPERATIONS_ENUM.IMPORT_FROM_S3,new ee(xs,aT.importFromS3)),e.set(V.OPERATIONS_ENUM.CREATE_SCHEMA,new ee($o.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_DATABASE,new ee($o.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_TABLE,new ee($o.createTable)),e.set(V.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new ee($o.createAttribute)),e.set(V.OPERATIONS_ENUM.DROP_SCHEMA,new ee($o.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_DATABASE,new ee($o.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_TABLE,new ee($o.dropTable)),e.set(V.OPERATIONS_ENUM.DROP_ATTRIBUTE,new ee($o.dropAttribute)),e.set(V.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new ee(cT.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_DATABASE,new ee(cT.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_TABLE,new ee(cT.describeTable)),e.set(V.OPERATIONS_ENUM.DESCRIBE_ALL,new ee(cT.describeAll)),e.set(V.OPERATIONS_ENUM.DELETE,new ee(oh.deleteRecord)),e.set(V.OPERATIONS_ENUM.ADD_USER,new ee(ih.addUser)),e.set(V.OPERATIONS_ENUM.ALTER_USER,new ee(ih.alterUser)),e.set(V.OPERATIONS_ENUM.DROP_USER,new ee(ih.dropUser)),e.set(V.OPERATIONS_ENUM.LIST_USERS,new ee(ih.listUsersExternal)),e.set(V.OPERATIONS_ENUM.LIST_ROLES,new ee(lT.listRoles)),e.set(V.OPERATIONS_ENUM.ADD_ROLE,new ee(lT.addRole)),e.set(V.OPERATIONS_ENUM.ALTER_ROLE,new ee(lT.alterRole)),e.set(V.OPERATIONS_ENUM.DROP_ROLE,new ee(lT.dropRole)),e.set(V.OPERATIONS_ENUM.USER_INFO,new ee(ih.userInfo)),e.set(V.OPERATIONS_ENUM.READ_LOG,new ee(The)),e.set(V.OPERATIONS_ENUM.ADD_NODE,new ee(Ahe)),e.set(V.OPERATIONS_ENUM.UPDATE_NODE,new ee(yK)),e.set(V.OPERATIONS_ENUM.SET_NODE_REPLICATION,new ee(yK)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE,new ee(Rhe)),e.set(V.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new ee(yhe)),e.set(V.OPERATIONS_ENUM.PURGE_STREAM,new ee(bhe)),e.set(V.OPERATIONS_ENUM.SET_CONFIGURATION,new ee(PK.setConfiguration)),e.set(V.OPERATIONS_ENUM.CLUSTER_STATUS,new ee(Ohe.clusterStatus)),e.set(V.OPERATIONS_ENUM.CLUSTER_NETWORK,new ee(Nhe)),e.set(V.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new ee(MI.setRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new ee(MI.getRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new ee(MI.deleteRoutes)),e.set(V.OPERATIONS_ENUM.EXPORT_TO_S3,new ee(xs,bK.export_to_s3)),e.set(V.OPERATIONS_ENUM.CREATE_CSR,new ee(Fd.createCsr)),e.set(V.OPERATIONS_ENUM.SIGN_CERTIFICATE,new ee(Fd.signCertificate)),e.set(V.OPERATIONS_ENUM.LIST_CERTIFICATES,new ee(Fd.listCertificates)),e.set(V.OPERATIONS_ENUM.ADD_CERTIFICATES,new ee(Fd.addCertificate)),e.set(V.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new ee(Fd.removeCertificate)),e.set(V.OPERATIONS_ENUM.GET_KEY,new ee(Fd.getKey)),e.set(V.OPERATIONS_ENUM.ADD_NODE_BACK,new ee(MK.addNodeBack)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE_BACK,new ee(MK.removeNodeBack)),e.set(V.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new ee(xs,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new ee(xs,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.EXPORT_LOCAL,new ee(xs,bK.export_local)),e.set(V.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new ee(xI.handleGetJobsByStartDate)),e.set(V.OPERATIONS_ENUM.GET_JOB,new ee(xI.handleGetJob)),e.set(V.OPERATIONS_ENUM.GET_FINGERPRINT,new ee(vI.getFingerprint)),e.set(V.OPERATIONS_ENUM.SET_LICENSE,new ee(vI.setLicense)),e.set(V.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new ee(vI.getRegistrationInfo)),e.set(V.OPERATIONS_ENUM.RESTART,new ee(NK.restart)),e.set(V.OPERATIONS_ENUM.RESTART_SERVICE,new ee(xs,NK.restartService)),e.set(V.OPERATIONS_ENUM.CATCHUP,new ee(khe)),e.set(V.OPERATIONS_ENUM.SYSTEM_INFORMATION,new ee(Che.systemInformation)),e.set(V.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new ee(xs,oh.deleteAuditLogsBefore)),e.set(V.OPERATIONS_ENUM.READ_AUDIT_LOG,new ee(She)),e.set(V.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new ee(IK.createTokens)),e.set(V.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new ee(IK.refreshOperationToken)),e.set(V.OPERATIONS_ENUM.LOGIN,new ee(CK.login)),e.set(V.OPERATIONS_ENUM.LOGOUT,new ee(CK.logout)),e.set(V.OPERATIONS_ENUM.GET_CONFIGURATION,new ee(PK.getConfiguration)),e.set(V.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new ee(It.customFunctionsStatus)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new ee(It.getCustomFunctions)),e.set(V.OPERATIONS_ENUM.GET_COMPONENT_FILE,new ee(It.getComponentFile)),e.set(V.OPERATIONS_ENUM.GET_COMPONENTS,new ee(It.getComponents)),e.set(V.OPERATIONS_ENUM.SET_COMPONENT_FILE,new ee(It.setComponentFile)),e.set(V.OPERATIONS_ENUM.DROP_COMPONENT,new ee(It.dropComponent)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new ee(It.getCustomFunction)),e.set(V.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new ee(It.setCustomFunction)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new ee(It.dropCustomFunction)),e.set(V.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new ee(It.addComponent)),e.set(V.OPERATIONS_ENUM.ADD_COMPONENT,new ee(It.addComponent)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new ee(It.dropCustomFunctionProject)),e.set(V.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new ee(It.packageComponent)),e.set(V.OPERATIONS_ENUM.PACKAGE_COMPONENT,new ee(It.packageComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new ee(It.deployComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_COMPONENT,new ee(It.deployComponent)),e.set(V.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new ee(DK.readTransactionLog)),e.set(V.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new ee(xs,DK.deleteTransactionLogsBefore)),e.set(V.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new ee(LK.installModules)),e.set(V.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new ee(LK.auditModules)),e.set(V.OPERATIONS_ENUM.GET_BACKUP,new ee($o.getBackup)),e.set(V.OPERATIONS_ENUM.ADD_SSH_KEY,new ee(It.addSSHKey)),e.set(V.OPERATIONS_ENUM.UPDATE_SSH_KEY,new ee(It.updateSSHKey)),e.set(V.OPERATIONS_ENUM.DELETE_SSH_KEY,new ee(It.deleteSSHKey)),e.set(V.OPERATIONS_ENUM.LIST_SSH_KEYS,new ee(It.listSSHKeys)),e.set(V.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new ee(It.setSSHKnownHosts)),e.set(V.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new ee(It.getSSHKnownHosts)),e}a(Fhe,"initializeOperationFunctionMap")});var pT=I((Dve,qK)=>{"use strict";var fT=(B(),C(G)),Ghe=oe(),lh=Y(),{handleHDBError:kI,hdb_errors:_T}=pe(),{isMainThread:qhe}=require("worker_threads"),{Readable:$he}=require("stream"),FK=require("os"),Vhe=require("util"),Khe=bO(),Yhe=Vhe.promisify(Khe.authorize),GK=Kw(),{createGzip:Whe,constants:zhe}=require("zlib"),jhe=[fT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,fT.OPERATIONS_ENUM.LOGIN,fT.OPERATIONS_ENUM.LOGOUT];function Qhe(e){let t=`Found an uncaught exception with message: ${e.message}. ${FK.EOL}Stack: ${e.stack} ${FK.EOL}Terminating ${qhe?"HDB":"thread"}.`;console.error(t),lh.fatal(t),process.exit(1)}a(Qhe,"handleServerUncaughtException");function Jhe(e,t,r){if(lh[e.logLevel||"error"](e),e.statusCode)return typeof e.http_resp_msg!="object"?r.code(e.statusCode).send({error:e.http_resp_msg||e.message}):r.code(e.statusCode).send(e.http_resp_msg);let n=e.statusCode?e.statusCode:_T.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR;return typeof e=="string"?r.code(n).send({error:e}):r.code(n).send(e.message?{error:e.message}:e)}a(Jhe,"serverErrorHandler");function Xhe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=kI(new Error,"Invalid JSON.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(Ghe.isEmpty(e.body.operation)){let n=kI(new Error,"Request body must include an 'operation' property.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Xhe,"reqBodyValidationHandler");function Zhe(e,t,r){let n;!jhe.includes(e.body.operation)||e.body.operation===fT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&!e.body.username&&!e.body.password?Yhe(e,t).then(i=>{n=i,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(i=>{lh.warn(i),lh.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${i.stack}"`);let o=typeof i=="string"?{error:i}:{error:i.message};r(kI(i,o,_T.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.hdb_auth_header=e.headers.authorization,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(Zhe,"authHandler");async function eme(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=GK.chooseOperation(e.body);let s=await GK.processLocalTransaction(e,n);if(s instanceof $he&&s.headers){for(let[i,o]of s.headers)t.header(i,o);e.headers["accept-encoding"]?.includes("gzip")&&(t.header("content-encoding","gzip"),s=s.pipe(Whe({level:zhe.Z_BEST_SPEED})))}return s}catch(s){throw lh.error(s),s}}a(eme,"handlePostRequest");qK.exports={authHandler:Zhe,handlePostRequest:eme,handleServerUncaughtException:Qhe,serverErrorHandler:Jhe,reqBodyValidationHandler:Xhe}});var YK=I((Mve,KK)=>{"use strict";var tme=require("fastify-plugin"),{handlePostRequest:$K,authHandler:rme,reqBodyValidationHandler:nme}=pT();async function sme(e){e.decorate("hdbCore",{preValidation:[nme,rme],request:a(t=>VK($K(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>VK($K(t,r,!0)),"requestWithoutAuthentication")})}a(sme,"hdbCore");async function VK(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(VK,"convertAsyncIterators");KK.exports=tme(sme)});var zK=I((xve,WK)=>{"use strict";var Uve=require("fs"),hT=ce();hT.initSync();var{CONFIG_PARAMS:FI}=(B(),C(G)),ime=1024*1024*1024;function ome(e){let t=hT.get(FI.HTTP_TIMEOUT),r=hT.get(FI.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:ime,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:hT.get(FI.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(ome,"getServerOptions");WK.exports=ome});var JK=I((Hve,QK)=>{"use strict";var GI=ce();GI.initSync();var{CONFIG_PARAMS:jK}=(B(),C(G));function ame(){let e=GI.get(jK.HTTP_CORSACCESSLIST),t=GI.get(jK.HTTP_CORS),r;return t&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},e&&e.length>0&&e[0]!==null&&e[0]!=="*"&&(r.origin=(n,s)=>s(null,e.indexOf(n)!==-1))),r}a(ame,"getCORSOptions");QK.exports=ame});var eY=I((Fve,ZK)=>{"use strict";var XK=ce();XK.initSync();var cme=(B(),C(G));function lme(){return XK.get(cme.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(lme,"getHeaderTimeoutConfig");ZK.exports=lme});var $I={};ve($I,{customFunctionsServer:()=>fme,ready:()=>pY,start:()=>dme});function dme(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Vo||(Vo=_Y(t),We.http((await Vo).server));let o=await Vo,c=(0,qI.dirname)(s),l=(0,qI.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!tY.has(c)){tY.add(c);try{o.register(pme(c,l))}catch(u){if(u.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 u}}},ready:pY}}async function fme(){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 _me();let e=aY.get(x.HTTP_SECUREPORT)>0,t;try{t=Vo=await _Y(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 _me(){try{_t.info("Custom Functions starting configuration."),await cY.setUsersWithRolesCache(),_t.info("Custom Functions completed configuration.")}catch(e){_t.error(e)}}function pme(e,t){return async function(r){try{_t.info("Custom Functions starting buildRoutes"),_t.trace("Loading fastify routes folder "+e),(0,rY.existsSync)(e)&&r.register(oY.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 _Y(e){_t.info("Custom Functions starting buildServer.");let t=(0,lY.default)(e),r=(0,nY.default)(t);r.server.headersTimeout=(0,dY.default)(),r.setErrorHandler(fY.serverErrorHandler);let n=(0,uY.default)();return n&&r.register(sY.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(iY.default),await r.register(ume),await r.after(),jf(r),_t.info("Custom Functions completed buildServer."),r}function pY(){if(Vo)return Vo.then?Vo.then(e=>e.ready()):Vo.ready()}var qI,rY,nY,sY,iY,oY,aY,_t,ume,cY,lY,uY,dY,fY,Vo,tY,hY=be(()=>{qI=require("path"),rY=require("fs"),nY=M(require("fastify")),sY=M(require("@fastify/cors")),iY=M(SO()),oY=M(require("@fastify/autoload")),aY=M(ce());B();_t=M(Y()),ume=M(YK()),cY=M(Rn()),lY=M(zK()),uY=M(JK()),dY=M(eY()),fY=M(pT());fo();Kr();tY=new Set;a(dme,"start");a(fme,"customFunctionsServer");a(_me,"setUp");a(pme,"buildRouteFolder");a(_Y,"buildServer");a(pY,"ready")});var VI={};ve(VI,{start:()=>hme});function hme(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,TY.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){EY||(EY=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=mY.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,gY.default)(s,(0,SY.realpathSync)(o))}}return i(s)},{runFirst:!0})),mY.set(r,n)}}}var gY,SY,TY,mY,EY,AY=be(()=>{gY=M(require("send")),SY=require("fs"),TY=M(require("serve-static")),mY=new Map;a(hme,"start")});var KI={};ve(KI,{start:()=>mme});function mme({override:e}){return{handleFile:a((t,r,n)=>{mT.default.debug(`Loading env file: ${n}`);for(let[s,i]of Object.entries((0,RY.parse)(t))){if(process.env[s]!==void 0)if(mT.default.warn(`Environment variable conflict: ${s} from ${n} is already set on process.env`),e)mT.default.debug(`override option enabled. overriding environment variable: ${s}`);else continue;process.env[s]=i}},"handleFile")}}var RY,mT,yY=be(()=>{RY=require("dotenv"),mT=M(Y());a(mme,"start")});var OY={};ve(OY,{Request:()=>YI,createReuseportFd:()=>ET});var bY,YI,WI,zI,ET,jI=be(()=>{bY=require("os"),YI=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 zI(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 WI(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},WI=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)}},zI=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,bY.platform)()!="win32"&&(ET=require("node-unix-socket").createReuseportFd)});var JI=I((jve,NY)=>{"use strict";var uh=ce();uh.initSync();var qd=require("fs-extra"),QI=require("path"),$d=(B(),C(G)),Eme=require("crypto"),gme=require("uuid").v4;NY.exports=Sme;function Sme(){if(uh.getHdbBasePath()!==void 0){let e=QI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=QI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=QI.join(uh.getHdbBasePath(),$d.LICENSE_KEY_DIR_NAME,$d.JWT_ENUM.JWT_PASSPHRASE_NAME);try{qd.accessSync(r),qd.accessSync(e),qd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=gme(),i=Eme.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});qd.writeFileSync(r,s),qd.writeFileSync(e,i.privateKey),qd.writeFileSync(t,i.publicKey)}else throw n}}}a(Sme,"checkJWTTokenExist")});var IY=I((Jve,wY)=>{"use strict";var XI=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};wY.exports={HdbInfoInsertObject:XI}});var DY=I((Zve,PY)=>{"use strict";var CY=(B(),C(G)),ZI=class{static{a(this,"UpgradeObject")}constructor(t,r){this[CY.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[CY.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};PY.exports={UpgradeObject:ZI}});var gT=I((tUe,MY)=>{"use strict";var Bs=require("prompt"),Vd=require("chalk"),LY=Y(),gi=require("os"),eC=da(),tC=["yes","y"];async function Tme(e){let t=`${gi.EOL}`+Vd.bold.green("Your current HarperDB version requires that we complete an update process.")+`${gi.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${gi.EOL}${gi.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${gi.EOL}`;Bs.override=eC(["CONFIRM_UPGRADE"]),Bs.start(),Bs.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Vd.magenta(`${gi.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 Bs.get([r])}catch(s){return LY.error("There was an error when prompting user about an upgrade."),LY.error(s),!1}return tC.includes(n.CONFIRM_UPGRADE)}a(Tme,"forceUpdatePrompt");async function Ame(e){let t=`${gi.EOL}`+Vd.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${gi.EOL}`);Bs.override=eC(["CONFIRM_DOWNGRADE"]),Bs.start(),Bs.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Vd.magenta(`${gi.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 Bs.get([r]);return tC.includes(n.CONFIRM_DOWNGRADE)}a(Ame,"forceDowngradePrompt");async function Rme(){let e=`${gi.EOL}`+Vd.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");Bs.override=eC(["GENERATE_CERTS"]),Bs.start(),Bs.message=e;let t={properties:{GENERATE_CERTS:{description:Vd.magenta(`${gi.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 Bs.get([t]);return tC.includes(r.GENERATE_CERTS)}a(Rme,"upgradeCertsPrompt");MY.exports={forceUpdatePrompt:Tme,forceDowngradePrompt:Ame,upgradeCertsPrompt:Rme}});var nC=I((nUe,vY)=>{"use strict";var rC=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};vY.exports=rC});var xY=I((lUe,UY)=>{"use strict";var yme=oe(),bme=Rt(),iUe=Y(),oUe=require("path"),aUe=require("fs"),cUe=(B(),C(G));UY.exports={getOldPropsValue:Ome};function Ome(e,t,r=!1){let n=t.getRaw(e);return yme.isNotEmptyAndHasValue(n)?n:r?bme.getDefaultConfig(e):""}a(Ome,"getOldPropsValue")});var FY=I((dUe,kY)=>{"use strict";var Za=require("path"),ec=require("fs-extra"),Nme=require("properties-reader"),wme=nC(),dr=Y(),{getOldPropsValue:pt}=xY(),{HDB_SETTINGS_NAMES:Ee,CONFIG_PARAMS:kl}=(B(),C(G)),Fl=Rt(),ST=ce(),BY=oe(),Qi=(B(),C(G)),sC=new wme("3.1.0"),HY=[];function Ime(){let e=Nme(ST.get(Ee.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),dr.info(t);let r=` ;Settings for the HarperDB process.
|
|
42
42
|
|
|
43
43
|
;The directory selected during install where the database files reside.
|
|
44
|
-
${
|
|
44
|
+
${Ee.HDB_ROOT_KEY} = ${pt(Ee.HDB_ROOT_KEY,e)}
|
|
45
45
|
;The port the HarperDB REST interface will listen on.
|
|
46
|
-
${
|
|
46
|
+
${Ee.SERVER_PORT_KEY} = ${pt(Ee.SERVER_PORT_KEY,e)}
|
|
47
47
|
;Set to true to enable HTTPS on the HarperDB REST endpoint. Requires a valid certificate and key.
|
|
48
|
-
${
|
|
48
|
+
${Ee.HTTP_SECURE_ENABLED_KEY} = ${pt(Ee.HTTP_SECURE_ENABLED_KEY,e)}
|
|
49
49
|
;The path to the SSL certificate used when running with HTTPS enabled.
|
|
50
|
-
${
|
|
50
|
+
${Ee.CERT_KEY} = ${pt(Ee.CERT_KEY,e)}
|
|
51
51
|
;The path to the SSL private key used when running with HTTPS enabled.
|
|
52
|
-
${
|
|
52
|
+
${Ee.PRIVATE_KEY_KEY} = ${pt(Ee.PRIVATE_KEY_KEY,e)}
|
|
53
53
|
;Set to true to enable Cross Origin Resource Sharing, which allows requests across a domain.
|
|
54
|
-
${
|
|
54
|
+
${Ee.CORS_ENABLED_KEY} = ${pt(Ee.CORS_ENABLED_KEY,e)}
|
|
55
55
|
;Allows for setting allowable domains with CORS. Comma separated list.
|
|
56
|
-
${
|
|
56
|
+
${Ee.CORS_WHITELIST_KEY} = ${pt(Ee.CORS_WHITELIST_KEY,e)}
|
|
57
57
|
;Length of time in milliseconds after which a request will timeout. Defaults to 120,000 ms (2 minutes).
|
|
58
|
-
${
|
|
58
|
+
${Ee.SERVER_TIMEOUT_KEY} = ${pt(Ee.SERVER_TIMEOUT_KEY,e,!0)}
|
|
59
59
|
;The number of milliseconds of inactivity a server needs to wait for additional incoming data, after it has finished writing the last response. Defaults to 5,000 ms (5 seconds).
|
|
60
|
-
${
|
|
60
|
+
${Ee.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${pt(Ee.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0)}
|
|
61
61
|
;Limit the amount of time the parser will wait to receive the complete HTTP headers.. Defaults to 60,000 ms (1 minute).
|
|
62
|
-
${
|
|
62
|
+
${Ee.SERVER_HEADERS_TIMEOUT_KEY} = ${pt(Ee.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
|
|
63
63
|
;Define whether to log to file or not.
|
|
64
|
-
${
|
|
64
|
+
${Ee.LOG_TO_FILE} = ${Fl.getDefaultConfig(kl.LOGGING_FILE)}
|
|
65
65
|
;Define whether to log to stdout/stderr or not. NOTE HarperDB must run in foreground in order to receive the std stream from HarperDB.
|
|
66
|
-
${
|
|
66
|
+
${Ee.LOG_TO_STDSTREAMS} = ${Fl.getDefaultConfig(kl.LOGGING_STDSTREAMS)}
|
|
67
67
|
;Set to control amount of logging generated. Accepted levels are trace, debug, warn, error, fatal.
|
|
68
|
-
${
|
|
68
|
+
${Ee.LOG_LEVEL_KEY} = ${pt(Ee.LOG_LEVEL_KEY,e)}
|
|
69
69
|
;The path where log files will be written. If there is no file name included in the path, the log file will be created by default as 'hdb_log.log'
|
|
70
|
-
${
|
|
70
|
+
${Ee.LOG_PATH_KEY} = ${pt(Ee.LOG_PATH_KEY,e)}
|
|
71
71
|
;Set to true to enable daily log file rotations - each log file name will be prepended with YYYY-MM-DD.
|
|
72
|
-
${
|
|
72
|
+
${Ee.LOG_DAILY_ROTATE_KEY} = ${pt(Ee.LOG_DAILY_ROTATE_KEY,e)}
|
|
73
73
|
;Set the number of daily log files to maintain when LOG_DAILY_ROTATE is enabled. If no integer value is set, no limit will be set for
|
|
74
74
|
;daily log files which may consume a large amount of storage depending on your log settings.
|
|
75
|
-
${
|
|
75
|
+
${Ee.LOG_MAX_DAILY_FILES_KEY} = ${pt(Ee.LOG_MAX_DAILY_FILES_KEY,e)}
|
|
76
76
|
;The environment used by NodeJS. Setting to production will be the most performant, settings to development will generate more logging.
|
|
77
|
-
${
|
|
77
|
+
${Ee.PROPS_ENV_KEY} = ${pt(Ee.PROPS_ENV_KEY,e)}
|
|
78
78
|
;This allows self signed certificates to be used in clustering. This is a security risk
|
|
79
79
|
;as clustering will not validate the cert, so should only be used internally.
|
|
80
80
|
;The HDB install creates a self signed certificate, if you use that cert this must be set to true.
|
|
81
|
-
${
|
|
81
|
+
${Ee.ALLOW_SELF_SIGNED_SSL_CERTS} = ${pt(Ee.ALLOW_SELF_SIGNED_SSL_CERTS,e,!0)}
|
|
82
82
|
;Set the max number of processes HarperDB will start. This can also be limited by number of cores and licenses.
|
|
83
|
-
${
|
|
83
|
+
${Ee.MAX_HDB_PROCESSES} = ${pt(Ee.MAX_HDB_PROCESSES,e)}
|
|
84
84
|
;Set to true to enable clustering. Requires a valid enterprise license.
|
|
85
|
-
${
|
|
85
|
+
${Ee.CLUSTERING_ENABLED_KEY} = ${pt(Ee.CLUSTERING_ENABLED_KEY,e,!0)}
|
|
86
86
|
;The port that will be used for HarperDB clustering.
|
|
87
|
-
${
|
|
87
|
+
${Ee.CLUSTERING_PORT_KEY} = ${pt(Ee.CLUSTERING_PORT_KEY,e)}
|
|
88
88
|
;The name of this node in your HarperDB cluster topology. This must be a value unique from the rest of your cluster node names.
|
|
89
|
-
${
|
|
89
|
+
${Ee.CLUSTERING_NODE_NAME_KEY} = ${pt(Ee.CLUSTERING_NODE_NAME_KEY,e)}
|
|
90
90
|
;The user used to connect to other instances of HarperDB, this user must have a role of cluster_user.
|
|
91
|
-
${
|
|
91
|
+
${Ee.CLUSTERING_USER_KEY} = ${pt(Ee.CLUSTERING_USER_KEY,e)}
|
|
92
92
|
;Defines if this instance does not record transactions. Note, if Clustering is enabled and Transaction Log is disabled your nodes will not catch up.
|
|
93
|
-
${
|
|
93
|
+
${Ee.DISABLE_TRANSACTION_LOG_KEY} = ${pt(Ee.DISABLE_TRANSACTION_LOG_KEY,e,!0)}
|
|
94
94
|
;Defines the length of time an operation token will be valid until it expires. Example values: https://github.com/vercel/ms
|
|
95
|
-
${
|
|
95
|
+
${Ee.OPERATION_TOKEN_TIMEOUT_KEY} = ${pt(Ee.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
|
|
96
96
|
;Defines the length of time a refresh token will be valid until it expires. Example values: https://github.com/vercel/ms
|
|
97
|
-
${
|
|
97
|
+
${Ee.REFRESH_TOKEN_TIMEOUT_KEY} = ${pt(Ee.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
|
|
98
98
|
;The port the IPC server will run on.
|
|
99
|
-
${
|
|
99
|
+
${Ee.IPC_SERVER_PORT} = ${Fl.getDefaultConfig(kl.IPC_NETWORK_PORT)}
|
|
100
100
|
;Run HDB in the foreground.
|
|
101
|
-
${
|
|
101
|
+
${Ee.RUN_IN_FOREGROUND} = ${Fl.getDefaultConfig(kl.OPERATIONSAPI_FOREGROUND)}
|
|
102
102
|
;Set to true to enable custom API endpoints. Requires a valid enterprise license.
|
|
103
|
-
${
|
|
103
|
+
${Ee.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${Fl.getDefaultConfig(kl.CUSTOMFUNCTIONS_ENABLED)}
|
|
104
104
|
;The port used to access the custom functions server.
|
|
105
|
-
${
|
|
105
|
+
${Ee.CUSTOM_FUNCTIONS_PORT_KEY} = ${Fl.getDefaultConfig(kl.HTTP_PORT)}
|
|
106
106
|
;The path to the folder containing HarperDB custom function files.
|
|
107
|
-
${
|
|
107
|
+
${Ee.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${Za.join(pt(Ee.HDB_ROOT_KEY,e),"custom_functions")}
|
|
108
108
|
;Set the max number of processes HarperDB will start for the Custom Functions server
|
|
109
|
-
${
|
|
110
|
-
`,n=
|
|
109
|
+
${Ee.MAX_CUSTOM_FUNCTION_PROCESSES} = ${Fl.getDefaultConfig(kl.HTTP_THREADS)}
|
|
110
|
+
`,n=ST.get("settings_path"),s=Za.dirname(n),i=Za.join(s,"3_1_0_upgrade_settings.bak");try{dr.info(`Backing up old settings file to: ${i}`),ec.copySync(n,i)}catch(c){throw dr.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{dr.info("New settings file values for 3.1.0 upgrade:",r),dr.info(`Creating new/upgraded settings file at '${n}'`),ec.writeFileSync(n,r),dr.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."),dr.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),dr.error(c),ec.copySync(i,n),c}ST.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),dr.info(o),o}a(Ime,"updateSettingsFile_3_1_0");function Cme(){let e=Za.join(BY.getHomeDir(),Qi.HDB_HOME_DIR_NAME,Qi.LICENSE_KEY_DIR_NAME,Qi.LICENSE_FILE_NAME),t=Za.join(BY.getHomeDir(),Qi.HDB_HOME_DIR_NAME,Qi.LICENSE_KEY_DIR_NAME,Qi.REG_KEY_FILE_NAME),r=Za.join(ST.getHdbBasePath(),Qi.LICENSE_KEY_DIR_NAME,Qi.LICENSE_FILE_NAME),n=Za.join(r,Qi.LICENSE_FILE_NAME),s=Za.join(r,Qi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),dr.info(i);let o="Creating .license directory";console.log(o),dr.info(o),ec.mkdirpSync(r);try{ec.accessSync(e);try{let c="Moving licence file";console.log(c),dr.info(c),ec.moveSync(e,n);let l="License file successfully moved.";console.log(l),dr.info(l)}catch{let l="moving license file failed";console.error(l),dr.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),dr.warn(l)}try{ec.accessSync(t);try{let c="Moving registration file";console.log(c),dr.info(c),ec.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),dr.info(l)}catch{let l="moving registration file failed";console.error(l),dr.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),dr.warn(l)}}a(Cme,"moveLicenseFiles");sC.sync_functions.push(Ime);sC.sync_functions.push(Cme);HY.push(sC);kY.exports=HY});var KY=I((_Ue,VY)=>{"use strict";var ls=dt(),{insertRecords:Pme}=kc(),Dme=pn(),tc=vt(),Lme=oe(),Ko=Y(),Mme=oe(),Ji=require("fs-extra"),Yo=require("path"),vme=require("cli-progress"),dh=require("assert"),Ume=require("pino"),xme=ce();VY.exports=Bme;var TT,GY,AT,iC,on,fh=!1;async function Bme(e=!0){return TT=xme.getHdbBasePath(),GY=Yo.join(TT,"schema"),AT=Yo.join(TT,"4_0_0_upgrade_tmp"),iC=Yo.join(TT,"transactions"),console.info("Reindexing upgrade started for schemas"),Ko.notify("Reindexing upgrade started for schemas"),await qY(GY,!1,e),await Ji.pathExists(iC)&&(console.info(`
|
|
111
111
|
|
|
112
|
-
Reindexing upgrade started for transaction logs`),
|
|
113
|
-
install_user = ${l}`;try{ic.writeFileSync(o,u)}catch(d){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),d}try{zI.initSync(!0)}catch(d){throw console.error("Unable to initialize new properties. Please check the log for details."),d}let f="New settings file for 4.0.0 upgrade successfully created.";try{ic.removeSync(r),console.log(f),Fl.info(f)}catch(d){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),d}}a(MEe,"updateSettingsFile_4_0_0");ip.async_functions.push(MEe);ip.async_functions.push(DEe);ip.async_functions.push(CEe);ip.async_functions.push(LEe);wY.push(ip);IY.exports=wY});var jI=C((lUe,MY)=>{"use strict";var ql=ae(),vEe=(v(),D(q)),PY=W(),{DATA_VERSION:UEe,UPGRADE_VERSION:xEe}=vEe.UPGRADE_JSON_FIELD_NAMES_ENUM,DY=SY(),dT=CY(),Gl=new Map;DY&&DY.forEach(e=>{Gl.set(e.version,e)});dT&&dT.forEach(e=>{Gl.set(e.version,e)});dT&&dT.forEach(e=>{Gl.set(e.version,e)});function BEe(){return[...Gl.keys()].sort(ql.compareVersions)}a(BEe,"getSortedVersions");function LY(e){let t=e[UEe],r=e[xEe];return ql.isEmptyOrZeroLength(t)||ql.isEmptyOrZeroLength(r)?(PY.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),PY.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."),[]):[...Gl.keys()].sort(ql.compareVersions).filter(function(n){return ql.compareVersions(n,t)>0&&ql.compareVersions(n,r)<=0})}a(LY,"getVersionsForUpgrade");function HEe(e){return LY(e).length>0}a(HEe,"hasUpgradesRequired");function kEe(e){return ql.isEmptyOrZeroLength(e)?null:Gl.has(e)?Gl.get(e):null}a(kEe,"getDirectiveByVersion");MY.exports={getSortedVersions:BEe,getDirectiveByVersion:kEe,getVersionsForUpgrade:LY,hasUpgradesRequired:HEe}});var op=C((dUe,HY)=>{"use strict";var FEe=require("util"),QI=require("chalk"),qEe=require("os"),UY=Rn(),GEe=zr(),ls=(v(),D(q)),xY=aY(),XI=gy(),{UpgradeObject:vY}=uY(),{forceDowngradePrompt:$Ee}=iT(),{packageJson:VEe}=rt(),fT=W(),Fd=ae(),ZI=ys(),KEe=(Ce(),D(tt)),YEe=jI(),WEe=FEe.promisify(ZI.setSchemaDataToGlobal),zEe=GEe.searchByValue,jEe="info_id",QEe="2.9.9",JEe="3.0.0";async function XEe(e){let t=new xY.HdbInfoInsertObject(1,e,e),r=new XI.InsertObject(ls.OPERATIONS_ENUM.INSERT,ls.SYSTEM_SCHEMA_NAME,ls.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,ls.INFO_TABLE_HASH_ATTRIBUTE,[t]);return ZI.setSchemaDataToGlobal(),UY.insert(r)}a(XEe,"insertHdbInstallInfo");async function JI(e){let t,r=await BY(),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 xY.HdbInfoInsertObject(i,e,e);let o=new XI.InsertObject(ls.OPERATIONS_ENUM.INSERT,ls.SYSTEM_SCHEMA_NAME,ls.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,ls.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await WEe(),UY.insert(o)}a(JI,"insertHdbUpgradeInfo");async function BY(){let e=new XI.NoSQLSeachObject(ls.SYSTEM_SCHEMA_NAME,ls.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,jEe,ls.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await zEe(e))}catch(r){console.error(r)}return t}a(BY,"getAllHdbInfoRecords");async function ZEe(){let e=await BY();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(ZEe,"getLatestHdbInfoRecord");async function eme(){fT.info("Checking if HDB software has been updated");try{let e=VEe.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await ZEe(),r;if(Fd.isEmpty(t))r=QEe;else if(r=t.data_version_num,Fd.compareVersions(r.toString(),e.toString())>0){if(!Fd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(QI.yellow(`This instance's data was last run on version ${r}`)),console.error(QI.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.${qEe.EOL}${ls.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Fd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(QI.yellow(`This instance's data was last run on version ${r}`)),await $Ee(new vY(r,e))?await JI(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(ZI.setSchemaDataToGlobal(),tme(r),e.toString()===r.toString())return;let n=new vY(r,e);if(YEe.hasUpgradesRequired(n))return n;Fd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await JI(n.upgrade_version),fT.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw fT.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),fT.fatal(e),e}}a(eme,"getVersionUpdateInfo");function tme(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${ls.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in KEe.databases.system))throw console.log(t),new Error(t);if(!Fd.isEmpty(e)&&e<JEe)throw console.log(t),new Error(t)}a(tme,"checkIfInstallIsSupported");HY.exports={insertHdbInstallInfo:XEe,insertHdbUpgradeInfo:JI,getVersionUpdateInfo:eme}});var GY=C((_Ue,qY)=>{"use strict";var _T=require("joi"),{boolean:rme,string:eC,number:nme}=_T.types(),kY=require("fs-extra"),ap=(v(),D(q)),FY=require("path"),sme=pt();qY.exports=ime;function ime(e){let t=eC.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=_T.object({[ap.INSTALL_PROMPTS.ROOTPATH]:_T.custom(ome),[ap.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:_T.alternatives([nme.min(0),eC]).allow("null",null),[ap.INSTALL_PROMPTS.TC_AGREEMENT]:eC.valid("yes","YES","Yes"),[ap.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[ap.INSTALL_PROMPTS.CLUSTERING_ENABLED]:rme});return sme.validateBySchema(e,r)}a(ime,"installValidator");function ome(e,t){if(kY.existsSync(FY.join(e,"system/hdb_user/data.mdb"))||kY.existsSync(FY.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(ome,"validateRootAvailable")});var nC=C((pUe,$Y)=>{"use strict";var{mkdirpSync:ame,copySync:cme}=require("fs-extra"),oc=require("path"),cp=(v(),D(q)),{PACKAGE_ROOT:lme}=rt(),rC=W(),ume=Wn(),tC=Ao(),dme=ht();$Y.exports=fme;async function fme(e){rC.trace("Mounting HarperDB"),$l(e),$l(oc.join(e,"backup")),$l(oc.join(e,"keys")),$l(oc.join(e,"keys",cp.LICENSE_FILE_NAME)),$l(oc.join(e,"log")),$l(oc.join(e,"database")),$l(oc.join(e,"components")),cme(oc.resolve(lme,"./utility/install/README.md"),oc.join(e,"README.md")),await _me()}a(fme,"mountHdb");async function _me(){let e=I_(),t=Object.keys(tC);for(let r=0;r<t.length;r++){let n=t[r],s=tC[n].hash_attribute;try{dme.initSystemSchemaPaths(cp.SYSTEM_SCHEMA_NAME,n);let i=new e(cp.SYSTEM_SCHEMA_NAME,n,s);i.attributes=tC[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await ume.createTable(n,i)}catch(i){throw rC.error(`issue creating environment for ${cp.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(_me,"createLMDBTables");function $l(e){ame(e,{mode:cp.HDB_FILE_PERMISSIONS}),rC.info(`Directory ${e} created`)}a($l,"makeDirectory")});var ET=C((SUe,rW)=>{"use strict";var iC=require("os"),zY=require("inquirer"),Fs=require("fs-extra"),hme=require("properties-reader"),Kl=require("chalk"),Xi=require("path"),pme=require("human-readable-ids").hri,Eme=require("ora"),mme=require("yaml"),_r=W(),ac=ce(),lp=ae(),pT=pa(),jY=op(),{packageJson:QY}=rt(),de=(v(),D(q)),{CONFIG_PARAM_MAP:mUe,CONFIG_PARAMS:Ct}=de,gme=GY(),Sme=nC(),oC=At(),Tme=An(),Ame=v_(),Rme=kI(),yme=ys(),bme=require("util").promisify,Ome=bme(yme.setSchemaDataToGlobal),VY=rs(),Vl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),qr=a(e=>Kl.magenta.bold(e),"HDB_PROMPT_MSG"),Nme="https://harperdb.io/legal/end-user-license-agreement",cc=iC.EOL,Jo="",wme="yes",KY="Starting HarperDB install...",YY="HarperDB installation was successful.",WY="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",Ime="An out of date version of HarperDB is already installed.",sC="It appears that HarperDB is already installed. Exiting install...",Cme="Aborting install",gUe=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])$/),Pme=new RegExp(/^[^\s.,*>]+$/),Dme=iC.homedir(),Lme=Xi.join(Dme,de.HDB_ROOT_DIR_NAME),Mme="HDB_ADMIN",vme="CLUSTER_USER",Ume="dev",xme="localhost",hT={[Ct.HTTP_CORS]:!0,[Ct.HTTP_CORSACCESSLIST]:["*"],[Ct.HTTP_PORT]:9926,[Ct.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Ct.THREADS_COUNT]:1,[Ct.THREADS_DEBUG]:!0,[Ct.LOGGING_STDSTREAMS]:!0,[Ct.LOGGING_LEVEL]:"info",[Ct.OPERATIONSAPI_NETWORK_PORT]:9925,[Ct.LOCALSTUDIO_ENABLED]:!0},Fr={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:"},lc=pT([de.INSTALL_PROMPTS.HDB_CONFIG]),Ji,JY=!1,aC=!1,XY=!1;rW.exports={install:ZY,updateConfigEnv:Wme,setIgnoreExisting:zme};ZY.createSuperUser=tW;async function ZY(){console.log(qr(cc+KY+cc)),_r.notify(KY);let e;lc[de.INSTALL_PROMPTS.HDB_CONFIG]&&(e=Bme());let t=kme();Object.assign(t,e),t[de.INSTALL_PROMPTS.TC_AGREEMENT]&&t[de.INSTALL_PROMPTS.ROOTPATH]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[de.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(XY=!0,t[de.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=gme(t);if(r)throw r.message;await Fme(),await qme(t);let n=await Hme(t);Ji=n[de.INSTALL_PROMPTS.ROOTPATH],lc[de.INSTALL_PROMPTS.HDB_CONFIG]&&Xi.dirname(lc[de.INSTALL_PROMPTS.HDB_CONFIG])===Ji&&(JY=!0),!aC&&!lc[de.INSTALL_PROMPTS.HDB_CONFIG]&&await Fs.pathExists(Xi.join(Ji,de.HDB_CONFIG_FILE))&&(console.error(sC),process.exit());let s=Eme({prefixText:qr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),lp.isEmpty(Ji))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");ac.setHdbBasePath(Ji),await Sme(Ji),await Gme(),await $me(n),_r.initLogSettings(!0),await tW(n),await Kme(n),await VY.updateConfigCert(),await VY.generateCertsKeys(),await Yme(),Rme(),s.stop(),console.log(qr(cc+YY+cc)),_r.notify(YY)}a(ZY,"install");function Bme(){let e=mme.parseDocument(Fs.readFileSync(lc[de.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=oC.flattenConfig(e.toJSON());return t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(Bme,"getConfigFromFile");async function Hme(e){_r.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:Vl,when:Xo(e[de.INSTALL_PROMPTS.ROOTPATH],Fr.DESTINATION),name:de.INSTALL_PROMPTS.ROOTPATH,prefix:Jo,default:Lme,validate:a(async s=>ks(s)?ks(s):await Fs.pathExists(Xi.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:qr(Fr.DESTINATION)},{type:"input",transformer:Vl,when:Xo(e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Fr.HDB_USERNAME),name:de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Jo,default:Mme,validate:a(s=>ks(s)?ks(s):(t=s,!0),"validate"),message:qr(Fr.HDB_USERNAME)},{type:"password",when:Xo(e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Fr.HDB_PASS),name:de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Jo,validate:a(s=>ks(s)?ks(s):!0,"validate"),message:qr(Fr.HDB_PASS)},{type:"input",transformer:Vl,when:Xo(e[de.INSTALL_PROMPTS.DEFAULTS_MODE],Fr.DEFAULTS_MODE),name:de.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Jo,default:Ume,validate:a(s=>ks(s)?ks(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:qr(Fr.DEFAULTS_MODE)}];if(XY||r.push({type:"input",name:de.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:Vl,when:Xo(e[de.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Fr.REPLICATION_HOSTNAME),prefix:Jo,default:xme,message:qr(Fr.REPLICATION_HOSTNAME)}),lp.autoCastBoolean(e[de.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:Vl,when:Xo(e[de.INSTALL_PROMPTS.CLUSTERING_NODENAME],Fr.NODE_NAME),name:de.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Jo,default:pme.random(),validate:a(i=>Pme.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:qr(Fr.NODE_NAME)},{type:"input",transformer:Vl,when:Xo(e[de.INSTALL_PROMPTS.CLUSTERING_USER],Fr.CLUSTER_USERNAME),name:de.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Jo,default:vme,validate:a(i=>ks(i)?ks(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:qr(Fr.CLUSTER_USERNAME)},{type:"password",when:Xo(e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Fr.CLUSTER_PASS),name:de.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Jo,validate:a(i=>ks(i)?ks(i):!0,"validate"),message:qr(Fr.CLUSTER_PASS)}];r.push(...s)}let n=await zY.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(Hme,"installPrompts");function Xo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${qr(t)} ${Kl.gray("[hidden]")}`),_r.trace(`${qr(t)} [hidden]`)):(console.log(`${qr(t)} ${e}`),_r.trace(`${qr(t)} ${e}`)),!1):!0}a(Xo,"displayCmdEnvVar");function ks(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(ks,"checkForEmptyValue");function kme(){let e=Object.keys(de.INSTALL_PROMPTS),t=pT(e),r=pT(Object.keys(de.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=de.CONFIG_PARAM_MAP[s.toLowerCase()];t[s]?i===void 0?n[s]=t[s]:n[i.toUpperCase()]=t[s]:i!==void 0&&r[i.toLowerCase()]&&(n[s]=r[i.toLowerCase()])}return n}a(kme,"checkForPromptOverride");async function Fme(){_r.trace("Checking for existing install.");let e=lp.getPropsFilePath(),t=await Fs.pathExists(e),r;if(t){_r.trace(`Install found an existing boot prop file at:${e}`);let n=hme(e),s=oC.getConfigValue(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Fs.pathExists(s)}if(!t&&lp.noBootFile()&&(r=!0),r&&!aC){if(_r.trace(`Install found existing HDB config at:${e}`),await jY.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${QY.version}. Exiting install...`;console.log(cc+Kl.magenta.bold(Ime)),console.log(Kl.magenta.bold(s)),_r.error(s)}else console.log(cc+Kl.magenta.bold(sC)),_r.error(sC);process.exit(0)}}a(Fme,"checkForExistingInstall");async function qme(e){_r.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${Nme}${cc}and can be viewed by typing or copying and pasting the URL into your web browser.${cc}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Jo,transformer:Vl,when:Xo(e[de.INSTALL_PROMPTS.TC_AGREEMENT],t),name:de.INSTALL_PROMPTS.TC_AGREEMENT,message:qr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:Kl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await zY.prompt([r]);n[de.INSTALL_PROMPTS.TC_AGREEMENT]&&n[de.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==wme&&(console.log(Kl.yellow(WY)),_r.error(WY),process.exit(0))}a(qme,"termsAgreement");async function Gme(){let e=Xi.join(Ji,de.HDB_CONFIG_FILE),t;try{t=iC.userInfo().username}catch{t=process.env.USERNAME||process.env.USER||process.env.LOGNAME||process.env.LNAME||process.env.SUDO_USER}if(t){let r=`settings_path = ${e}
|
|
114
|
-
install_user = ${t}`,n=lp.getHomeDir(),s=Xi.join(n,de.HDB_HOME_DIR_NAME),i=Xi.join(s,de.LICENSE_KEY_DIR_NAME);try{Fs.mkdirpSync(s,{mode:de.HDB_FILE_PERMISSIONS}),Fs.mkdirpSync(i,{mode:de.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${de.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Xi.join(s,de.BOOT_PROPS_FILE_NAME);try{await Fs.writeFile(o,r)}catch(c){throw _r.error(`There was an error creating the boot file at path: ${o}`),c}ac.setProperty(de.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),ac.setProperty(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),ac.setProperty(ac.BOOT_PROPS_FILE_PATH,o)}}a(Gme,"createBootPropertiesFile");async function $me(e){_r.trace("Creating HarperDB config file");let t=pT(Object.keys(de.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[de.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in hT){if(r===Ct.HTTP_PORT&&t[Ct.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??hT[r],t[Ct.HTTP_SECUREPORT]=null;continue}else if(r===Ct.HTTP_PORT)continue;if(r===Ct.OPERATIONSAPI_NETWORK_PORT&&t[Ct.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??hT[r],t[Ct.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Ct.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=hT[r])}}else t[Ct.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Ct.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Ct.HTTP_PORT.toLowerCase()]&&(t[Ct.HTTP_SECUREPORT]=null);try{lc[de.INSTALL_PROMPTS.HDB_CONFIG]||oC.createConfigFile(t),ac.initSync()}catch(r){Vme(r)}}a($me,"createConfigFile");function Vme(e){_r.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(Cme);let t=Xi.resolve(ac.get(ac.BOOT_PROPS_FILE_PATH),"../");t&&Fs.removeSync(t),Ji&&(JY?Fs.readdirSync(Ji,{withFileTypes:!0}).forEach(n=>{let s=Xi.join(n.path,n.name);s!==lc[de.INSTALL_PROMPTS.HDB_CONFIG]&&Fs.removeSync(s)}):Fs.removeSync(Ji)),process.exit(1)}a(Vme,"rollbackInstall");async function eW(e,t){_r.trace("Creating admin user"),await Ome();let r;try{r=await Ame.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 Tme.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(eW,"createAdminUser");async function tW(e){_r.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await eW(t,r),delete e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(tW,"createSuperUser");async function Kme(e){_r.trace("Creating Cluster user.");let t;e[de.INSTALL_PROMPTS.CLUSTERING_USER]&&e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[de.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await eW({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[de.INSTALL_PROMPTS.CLUSTERING_USER],delete e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(Kme,"createClusterUser");async function Yme(){let e=QY.version;if(e)await jY.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(Yme,"insertHdbVersionInfo");function Wme(e){lc[de.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Wme,"updateConfigEnv");function zme(e){aC=e}a(zme,"setIgnoreExisting")});var iW=C((AUe,sW)=>{"use strict";var cC=ae(),us=W(),nW=jI();sW.exports={processDirectives:jme};async function jme(e){console.log("Starting upgrade process...");let t=nW.getVersionsForUpgrade(e),r=Xme(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;us.notify(c),console.log(c);let l=[],u=[];try{l=Qme(o.sync_functions)}catch(f){throw us.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await Jme(o.async_functions)}catch(f){throw us.error(`Error while running an upgrade script for ${o.version}`),f}n.push(...l,...u)}return n}a(jme,"processDirectives");function Qme(e){if(cC.isEmptyOrZeroLength(e))return us.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return us.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(us.info(`Running function ${r.name}`),!(r instanceof Function)){us.info("Variable being processed is not a function");continue}let n=r();us.info(n),t.push(n)}return t}a(Qme,"runSyncFunctions");async function Jme(e){if(cC.isEmptyOrZeroLength(e))return us.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return us.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(us.info(`Running function ${s.name}`),!(s instanceof Function)){us.info("Variable being processed is not a function");continue}let i=await s();us.info(i),t.push(i)}return t}a(Jme,"runAsyncFunctions");function Xme(e){if(cC.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=nW.getDirectiveByVersion(r);n&&t.push(n)}return t}a(Xme,"getUpgradeDirectivesToInstall")});var fC=C((yUe,dW)=>{"use strict";var mT=ce();mT.initSync();var lW=require("chalk"),oW=require("fs-extra"),ea=W(),Zo=(v(),D(q)),Zme=iW(),lC=ae(),uW=op(),ege=iT(),aW=qA(),tge=ys(),{packageJson:cW}=rt(),rge=require("util").promisify,nge=rge(tge.setSchemaDataToGlobal),uC,{UPGRADE_VERSION:dC}=Zo.UPGRADE_JSON_FIELD_NAMES_ENUM;dW.exports={upgrade:sge};async function sge(e){await nge(),uC===void 0&&(uC=Ad()),oW.existsSync(mT.get(mT.BOOT_PROPS_FILE_PATH))||(up("The hdb_boot_properties file was not found. Please install HDB.",Zo.LOG_LEVELS.ERROR),process.exit(1)),oW.existsSync(mT.get(Zo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(up("The hdb settings file was not found. Please make sure HDB is installed.",Zo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await uW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),up(`This version of HarperDB is ${cW.version}`,Zo.LOG_LEVELS.INFO);let r=t[dC]??cW.version;r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${Zo.HDB_SUPPORT_ADDRESS}`),ea.notify("Missing new version field from upgrade info object"),process.exit(1)),await ige();let n,s=0;try{n=await ege.forceUpdatePrompt(t)}catch(i){ea.error("There was an error when prompting user about upgrade."),ea.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),ea.info(`Starting upgrade to version ${r}`),await oge(t),up(`HarperDB was successfully upgraded to version ${t[dC]}`,Zo.LOG_LEVELS.INFO)}a(sge,"upgrade");async function ige(){let e=!1,t=await aW.findPs(Zo.HDB_PROC_NAME);if(lC.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await aW.findPs("hdb_express");lC.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await uC.list();lC.isEmptyOrZeroLength(r)||(e=!0)}if(e){let r="HarperDB is running, please stop all HarperDB services with 'harperdb stop' and run the upgrade command again.";console.log(lW.red(r)),ea.error(r),process.exit(1)}}a(ige,"checkIfRunning");async function oge(e){try{await Zme.processDirectives(e)}catch(t){throw up("There was an error during the data upgrade. Please check the logs.",Zo.LOG_LEVELS.ERROR),t}try{await uW.insertHdbUpgradeInfo(e[dC])}catch(t){ea.error("Error updating the 'hdb_info' system table."),ea.error(t)}}a(oge,"runUpgrade");function up(e,t=void 0){t||(t=ea.info),ea[t](e),console.log(lW.magenta(e))}a(up,"printToLogAndConsole")});var EW=C((OUe,pW)=>{"use strict";var{promises:hC,createReadStream:age,createWriteStream:cge}=require("fs"),{createGzip:lge}=require("zlib"),{promisify:uge}=require("util"),{pipeline:dge}=require("stream"),fge=uge(dge),_ge=require("path"),Wl=ce();Wl.initSync();var Yl=W(),{CONFIG_PARAMS:dp,ITC_EVENT_TYPES:hge}=(v(),D(q)),{onMessageFromWorkers:pge}=nt(),Ege=6e4,mge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",gge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",_C,_W;pW.exports=hW;pge(e=>{e.type===hge.RESTART&&(Wl.initSync(!0),clearInterval(_W),Wl.get(dp.LOGGING_ROTATION_ENABLED)&&hW())});async function hW(){try{let e=Yl.getLogFilePath(),t=Wl.get(dp.LOGGING_ROTATION_MAXSIZE),r=Wl.get(dp.LOGGING_ROTATION_INTERVAL);if(!t&&!r){Yl.error(mge);return}let n=Wl.get(dp.LOGGING_ROTATION_PATH);if(!n){Yl.error(gge);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}_C=Date.now()/6e4,Yl.trace("Log rotate enabled, maxSize:",t,"interval:",r),_W=setInterval(async()=>{if(s){let o;o=await hC.stat(e),o.size>=s&&await fW(e,n)}i&&Date.now()/6e4-_C>=i&&(await fW(e,n),_C=Date.now()/6e4)},Ege).unref()}catch(e){Yl.error(e)}}a(hW,"logRotator");async function fW(e,t){let r=Wl.get(dp.LOGGING_ROTATION_COMPRESS),n=_ge.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.${r?"log.gz":"log"}`);r?(await fge(age(e),lge(),cge(n)),await hC.unlink(e)):await hC.rename(e,n),Yl.closeLogFile(),Yl.notify(`hdb.log rotated, old log moved to ${n}`)}a(fW,"moveLogFile")});var Gd=C(yW=>{"use strict";var ge=ce();ge.initSync();Ja();var Ht=(v(),D(q)),{CONFIG_PARAMS:we}=Ht,ds=W(),ta=require("fs-extra"),ra=require("path"),Sge=kI(),{install:Tge}=ET(),pC=require("chalk"),{packageJson:Age,PACKAGE_ROOT:Rge}=rt(),na=ae(),EC=At(),gW=pa(),mW=aS(),yge=fC(),bge=EW(),{compactOnStart:Oge}=(pS(),D(hS)),Nge=require("minimist"),wge=rs(),{startHTTPThreads:Ige}=(mC(),D(bW)),Cge=op(),{isMainThread:Pge}=require("worker_threads"),wUe=Ao(),IUe=Oo(),CUe=db(),PUe=I_(),gT=(v(),D(q)),Zi,qd,SW=!1,Dge="Upgrade complete. Starting HarperDB.",Lge="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",Mge="HarperDB not found, starting install process.",vge="There was an error during install, check install_log.log for more details. Exiting.",Uge="HarperDB successfully started.";function xge(){if(!SW){let e=a(()=>{ta.removeSync(ra.join(ge.get(Ht.CONFIG_PARAMS.ROOTPATH),Ht.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(xge,"addExitListeners");async function TW(e=!1,t=!1){if(console.log(pC.magenta("Starting HarperDB...")),ds.suppressLogging?.(()=>{console.log(pC.magenta(""+ta.readFileSync(ra.join(Rge,"utility/install/ascii_logo.txt"))))}),await RW()===!1){console.log(Mge);try{await Tge()}catch(l){console.error(vge,l),ds.error(l),process.exit(1)}}if(!e){let l=gW(Object.keys(Ht.CONFIG_PARAM_MAP),!0);!na.isEmpty(l)&&!na.isEmptyOrZeroLength(Object.keys(l))&&EC.updateConfigValue(void 0,void 0,l,!0,!0)}let r,n=qd?.service==="clustering";qd?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));let s=ra.join(ge.get(Ht.CONFIG_PARAMS.ROOTPATH),Ht.HDB_PID_FILE),i=qge(s);i&&i!==1&&Gge(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),Zi===void 0&&(Zi=Ad()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),ge.get(Ht.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await mW.generateNatsConfig(),await Zi.startClusteringProcesses(!0),process.exit()),xge(),await ta.writeFile(ra.join(ge.get(gT.CONFIG_PARAMS.ROOTPATH),gT.HDB_PID_FILE),`${process.pid}`),ds.info("HarperDB PID",process.pid);let o;try{let l=await Cge.getVersionUpdateInfo();l!==void 0&&(o=l[Ht.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await yge.upgrade(l),console.log(Dge))}catch(l){o?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${o}. Exiting HarperDB.`,l),ds.error(l)):(console.error(Lge,l),ds.error(l)),process.exit(1)}Sge(),kge(),await wge.reviewSelfSignedCert(),na.autoCastBoolean(ge.get(Ht.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&Pge&&await mW.generateNatsConfig(t)}a(TW,"initialize");async function Bge(e=!1){try{qd=Nge(process.argv),qd.ROOTPATH&&EC.updateConfigObject("settings_path",ra.join(qd.ROOTPATH,Ht.HDB_CONFIG_FILE)),await TW(e,!0),ge.get(Ht.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Oge();let t=process.env.IS_SCRIPTED_SERVICE&&!qd.service;na.autoCastBoolean(ge.get(Ht.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Zi.startClusteringProcesses(),await Zi.startClusteringThreads()),await Ige(process.env.DEV_MODE?1:ge.get(gT.CONFIG_PARAMS.THREADS_COUNT)??ge.get(gT.CONFIG_PARAMS.THREADS)),ge.get(Ht.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await bge(),t||AW()}catch(t){console.error(t),ds.error(t),process.exit(1)}}a(Bge,"main");function AW(){ds.suppressLogging(()=>{console.log(pC.magenta(`HarperDB ${Age.version} successfully started`))}),ds.notify(Uge)}a(AW,"started");async function Hge(e=!0){SW=!e;try{Zi===void 0&&(Zi=Ad()),Zi.enterPM2Mode(),await TW(),na.autoCastBoolean(ge.get(Ht.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Zi.startClusteringProcesses(),await Zi.startService(Ht.PROCESS_DESCRIPTORS.HDB),AW(),e&&process.exit(0)}catch(t){console.error(t),ds.error(t),process.exit(1)}}a(Hge,"launch");function kge(){let e=ra.join(ge.get(Ht.CONFIG_PARAMS.ROOTPATH),Ht.LICENSE_KEY_DIR_NAME,Ht.LICENSE_FILE_NAME),t=ra.join(e,Ht.LICENSE_FILE_NAME),r=ra.join(e,Ht.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=gW(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(na.isEmpty(n)||na.isEmpty(s))return;ta.mkdirpSync(e),ta.writeFileSync(r,n),ta.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),ds.error(s)}}a(kge,"writeLicenseFromVars");Object.assign(yW,{launch:Hge,main:Bge,isHdbInstalled:RW,startupLog:Fge});async function RW(){try{await ta.stat(na.getPropsFilePath()),await ta.stat(ge.get(Ht.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(na.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw ds.error(`Error checking for HDB install - ${e}`),e}return!0}a(RW,"isHdbInstalled");function Fge(e){let r=a(_=>_.padEnd(20),"pad"),n=`
|
|
115
|
-
`;ge.get(
|
|
116
|
-
`),ge.get(
|
|
117
|
-
`),n+=`${r("Worker Threads:")}${ge.get(
|
|
118
|
-
`,n+=`${r("Root Path:")}${ge.get(
|
|
119
|
-
`,ge.get(
|
|
112
|
+
Reindexing upgrade started for transaction logs`),Ko.notify("Reindexing upgrade started for transaction logs"),await qY(iC,!0,e)),Ko.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(fh?", but errors occurred":"")}a(Bme,"reindexUpgrade");async function qY(e,t,r){let n=await Ji.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Yo.join(e,o.toString());if(o===".DS_Store")continue;let l=await Ji.readdir(c),u=l.length;for(let f=0;f<u;f++){let d=l[f];if(d!==".DS_Store"&&Ji.statSync(Yo.join(c,d)).isDirectory())try{await Hme(o,d,t),on.info(`Reindexing started for ${o}.${d}`),Ko.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${d}`),await Fme(o,d,c,t,r),on.info(`Reindexing completed for ${o}.${d}`),Ko.notify(`Reindexing completed for ${o}.${d}`)}catch(p){fh=!0,p.schema_path=c,p.table_name=d,Ko.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Ko.error(p),on.error(p),console.error(p)}}}if(!fh)try{await Ji.rm(AT,{recursive:!0})}catch{}}a(qY,"processTables");async function Hme(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Yo.join(AT,s);await Ji.ensureDir(AT),await Ji.writeFile(i,""),on=Ume({level:"debug",formatters:{bindings(){}}},i)}a(Hme,"initPinoLogger");var kme=20;async function Fme(e,t,r,n,s){let i;try{i=await ls.openEnvironment(r,t,n)}catch(E){if(E.message==="MDB_INVALID: File is not an LMDB file"){Ko.notify(`${e}.${t} file is not from the old environment and has been skipped`),console.info(`${e}.${t} file is not from the old environment and has been skipped`),on.error(E);return}throw E}let o=$me(i.dbis),c=ls.openDBI(i,o),l=Object.keys(i.dbis),u=ls.statDBI(i,o);on.info(`Old environment stats: ${JSON.stringify(u)}`);let f=new vme.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});f.start(u.entryCount,0,{});let d=await ls.createEnvironment(r,t,!1);ls.createDBI(d,o,!1,!0);let p=[];try{for(let E of c.getRange({start:!1}))E.value={...E.value},p.push(E),n||e==="system"&&(t==="hdb_schema"&&(E.key=E.key.toString(),E.value.name=E.value.name.toString()),t==="hdb_table"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.name=E.value.name.toString()),t==="hdb_attribute"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.table=E.value.table.toString(),E.value.attribute=E.value.attribute.toString())),p.length>kme&&await _();await _()}catch(E){throw fh=!0,on.error(E),E}async function _(){let E,R=p.map(({value:v})=>v);n?E=await Promise.all(R.map(v=>Gme(d,v))):E=await Pme(d,o,l.filter(v=>v!=="__blob__"),R,!1);for(let v=0,k=p.length;v<k;v++){let{key:F,value:K}=p[v];on.info(`Record hash value: ${F} hash: ${o}`);let re;n?re=E[v]:re=E.written_hashes.indexOf(F)>-1,dh(re,!0),qme(d,o,K[o],n),on.info(`Insert success, written hashes: ${E.written_hashes}`),f.increment()}p=[],f.value/f.total*100%10===0&&Ko.notify(`${e}.${t} ${f.value}/${f.total} records inserted`),on.info(`${f.value}/${f.total} records inserted`)}a(_,"finishOutstanding"),f.stop();let h=ls.statDBI(i,o),S=ls.statDBI(d,o);if(on.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${S.entryCount}`),dh.deepStrictEqual(h.entryCount,S.entryCount),await ls.closeEnvironment(i),await ls.closeEnvironment(d),delete global.lmdb_map[`${e}.${t}`],s){let E=Yo.join(r,t),R=Yo.join(E,"data.mdb"),N=Yo.join(E,"lock.mdb");await Ji.unlink(R),await Ji.unlink(N),await Ji.rmdir(E),on.info(`Deleted old environment files from schema folder: ${R}, ${N}`)}let g=await ls.openEnvironment(r,t),A=ls.statDBI(g,o);on.info(`New stats: ${JSON.stringify(S)}. New stats after move: ${JSON.stringify(A)}`),dh.deepStrictEqual(A.entryCount,S.entryCount),await ls.closeEnvironment(g),delete global.lmdb_map[`${e}.${t}`]}a(Fme,"processTable");async function Gme(e,t){ls.initializeDBIs(e,tc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,tc.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),Mme.isEmpty(t.user_name)||e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[tc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(Gme,"insertTransaction");function qme(e,t,r,n){let i=e.dbis[t].get(r);dh.deepStrictEqual(typeof i,"object");let o;if(n){let c={[tc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[tc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE]:i.hash_values};o=Object.entries(c)}else o=Object.entries(i);for(let[c,l]of o)if(c!==t&&e.dbis[c]!==void 0&&!Lme.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let u=0,f=l.length;u<f;u++){let d=l[u];$Y(e,c,d,r)}else $Y(e,c,l,r)}a(qme,"validateIndices");function $Y(e,t,r,n){try{let s=!1,i=Dme.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||on.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),dh.deepStrictEqual(s,!0)}catch(s){fh=!0,on.error(s),console.error(s)}}a($Y,"validateIndex");function $me(e){let t;for(let[r,n]of Object.entries(e))if(n.__dbi_defintion__.is_hash_attribute===!0){t=r;break}return t}a($me,"getHashDBI")});var QY=I((mUe,jY)=>{"use strict";var RT=require("path"),rc=require("fs-extra"),Vme=nC(),Gl=Y(),YY=Rt(),oC=ce(),Si=(B(),C(G)),yT=oe(),Kme=require("properties-reader"),Yme=ii(),Wme=ng(),zme=Wr(),hUe=require("util"),jme=zme.searchByValue,Qme=yn(),Jme=uS(),Xme=St(),Zme=KY(),WY=rs(),eEe=gT(),hh=new Vme("4.0.0"),zY=[],_h,ph;async function tEe(){try{if(await eEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),_h){let t=yT.changeExtension(_h,".bak");await rc.move(_h,t)}if(ph){let t=yT.changeExtension(ph,".bak");await rc.move(ph,t)}await WY.generateKeys()}else console.log("Using existing certificates."),WY.updateConfigCert(_h,ph,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(tEe,"generateNewKeys");async function rEe(){console.log("Updating HarperDB nodes."),Gl.info("Updating HarperDB nodes.");let e=[];try{let t=new Yme(Si.SYSTEM_SCHEMA_NAME,Si.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await jme(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!Xme.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let f=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(f),f}let l={host:c.host,port:c.port};e.push(l);let u=[];for(let f=0,d=c.subscriptions.length;f<d;f++){let p=c.subscriptions[f],_=p.channel.split(":");u.push({schema:_[0],table:_[1],publish:p.publish,subscribe:p.subscribe})}n.push({name:c.name,subscriptions:u,system_info:{hdb_version:Si.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(yT.isEmptyOrZeroLength(n))return;let s=new Wme(Si.SYSTEM_SCHEMA_NAME,Si.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await Qme.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{Jme.setRoutes({server:"hub",routes:e})}catch(t){throw console.error("There was a problem setting the clustering routes. Please check the log for details."),t}}a(rEe,"updateNodes");async function nEe(){let e=oC.get(Si.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(RT.join("config","settings.js"))){Gl.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),Gl.info(t);let r=RT.dirname(e),n=oC.get(Si.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=RT.join(n,"backup","4_0_0_upgrade_settings.bak"),i=RT.join(n,Si.HDB_CONFIG_FILE);try{Gl.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),rc.copySync(e,s)}catch(d){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),d}try{Gl.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),Gl.info("Updating env variables with new settings values");let d=YY.initOldConfig(e);_h=d[Si.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],ph=d[Si.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],YY.createConfigFile(d)}catch(d){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),d}let o=yT.getPropsFilePath();rc.accessSync(o,rc.constants.F_OK|rc.constants.R_OK);let l=Kme(o).get(Si.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
|
|
113
|
+
install_user = ${l}`;try{rc.writeFileSync(o,u)}catch(d){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),d}try{oC.initSync(!0)}catch(d){throw console.error("Unable to initialize new properties. Please check the log for details."),d}let f="New settings file for 4.0.0 upgrade successfully created.";try{rc.removeSync(r),console.log(f),Gl.info(f)}catch(d){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),d}}a(nEe,"updateSettingsFile_4_0_0");hh.async_functions.push(nEe);hh.async_functions.push(tEe);hh.async_functions.push(Zme);hh.async_functions.push(rEe);zY.push(hh);jY.exports=zY});var aC=I((gUe,eW)=>{"use strict";var ql=oe(),sEe=(B(),C(G)),JY=Y(),{DATA_VERSION:iEe,UPGRADE_VERSION:oEe}=sEe.UPGRADE_JSON_FIELD_NAMES_ENUM,XY=FY(),bT=QY(),$l=new Map;XY&&XY.forEach(e=>{$l.set(e.version,e)});bT&&bT.forEach(e=>{$l.set(e.version,e)});bT&&bT.forEach(e=>{$l.set(e.version,e)});function aEe(){return[...$l.keys()].sort(ql.compareVersions)}a(aEe,"getSortedVersions");function ZY(e){let t=e[iEe],r=e[oEe];return ql.isEmptyOrZeroLength(t)||ql.isEmptyOrZeroLength(r)?(JY.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),JY.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."),[]):[...$l.keys()].sort(ql.compareVersions).filter(function(n){return ql.compareVersions(n,t)>0&&ql.compareVersions(n,r)<=0})}a(ZY,"getVersionsForUpgrade");function cEe(e){return ZY(e).length>0}a(cEe,"hasUpgradesRequired");function lEe(e){return ql.isEmptyOrZeroLength(e)?null:$l.has(e)?$l.get(e):null}a(lEe,"getDirectiveByVersion");eW.exports={getSortedVersions:aEe,getDirectiveByVersion:lEe,getVersionsForUpgrade:ZY,hasUpgradesRequired:cEe}});var mh=I((TUe,iW)=>{"use strict";var uEe=require("util"),cC=require("chalk"),dEe=require("os"),rW=yn(),fEe=Wr(),us=(B(),C(G)),nW=IY(),uC=Ly(),{UpgradeObject:tW}=DY(),{forceDowngradePrompt:_Ee}=gT(),{packageJson:pEe}=nt(),OT=Y(),Kd=oe(),dC=bs(),hEe=(Pe(),C(rt)),mEe=aC(),EEe=uEe.promisify(dC.setSchemaDataToGlobal),gEe=fEe.searchByValue,SEe="info_id",TEe="2.9.9",AEe="3.0.0";async function REe(e){let t=new nW.HdbInfoInsertObject(1,e,e),r=new uC.InsertObject(us.OPERATIONS_ENUM.INSERT,us.SYSTEM_SCHEMA_NAME,us.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,us.INFO_TABLE_HASH_ATTRIBUTE,[t]);return dC.setSchemaDataToGlobal(),rW.insert(r)}a(REe,"insertHdbInstallInfo");async function lC(e){let t,r=await sW(),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 nW.HdbInfoInsertObject(i,e,e);let o=new uC.InsertObject(us.OPERATIONS_ENUM.INSERT,us.SYSTEM_SCHEMA_NAME,us.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,us.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await EEe(),rW.insert(o)}a(lC,"insertHdbUpgradeInfo");async function sW(){let e=new uC.NoSQLSeachObject(us.SYSTEM_SCHEMA_NAME,us.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,SEe,us.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await gEe(e))}catch(r){console.error(r)}return t}a(sW,"getAllHdbInfoRecords");async function yEe(){let e=await sW();if(e.length===0)return;let t,r=new Map;for(let s of e)r.set(s.info_id,s);let n=Math.max.apply(null,[...r.keys()]);return t=r.get(n),t}a(yEe,"getLatestHdbInfoRecord");async function bEe(){OT.info("Checking if HDB software has been updated");try{let e=pEe.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await yEe(),r;if(Kd.isEmpty(t))r=TEe;else if(r=t.data_version_num,Kd.compareVersions(r.toString(),e.toString())>0){if(!Kd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(cC.yellow(`This instance's data was last run on version ${r}`)),console.error(cC.red(`You have installed a version lower than the version that your data was created on or was upgraded to. This may cause issues and is currently not supported.${dEe.EOL}${us.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Kd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(cC.yellow(`This instance's data was last run on version ${r}`)),await _Ee(new tW(r,e))?await lC(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(dC.setSchemaDataToGlobal(),OEe(r),e.toString()===r.toString())return;let n=new tW(r,e);if(mEe.hasUpgradesRequired(n))return n;Kd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await lC(n.upgrade_version),OT.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw OT.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),OT.fatal(e),e}}a(bEe,"getVersionUpdateInfo");function OEe(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${us.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in hEe.databases.system))throw console.log(t),new Error(t);if(!Kd.isEmpty(e)&&e<AEe)throw console.log(t),new Error(t)}a(OEe,"checkIfInstallIsSupported");iW.exports={insertHdbInstallInfo:REe,insertHdbUpgradeInfo:lC,getVersionUpdateInfo:bEe}});var lW=I((RUe,cW)=>{"use strict";var NT=require("joi"),{boolean:NEe,string:fC,number:wEe}=NT.types(),oW=require("fs-extra"),Eh=(B(),C(G)),aW=require("path"),IEe=ut();cW.exports=CEe;function CEe(e){let t=fC.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=NT.object({[Eh.INSTALL_PROMPTS.ROOTPATH]:NT.custom(PEe),[Eh.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:NT.alternatives([wEe.min(0),fC]).allow("null",null),[Eh.INSTALL_PROMPTS.TC_AGREEMENT]:fC.valid("yes","YES","Yes"),[Eh.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[Eh.INSTALL_PROMPTS.CLUSTERING_ENABLED]:NEe});return IEe.validateBySchema(e,r)}a(CEe,"installValidator");function PEe(e,t){if(oW.existsSync(aW.join(e,"system/hdb_user/data.mdb"))||oW.existsSync(aW.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(PEe,"validateRootAvailable")});var hC=I((bUe,uW)=>{"use strict";var{mkdirpSync:DEe,copySync:LEe}=require("fs-extra"),nc=require("path"),gh=(B(),C(G)),{PACKAGE_ROOT:MEe}=nt(),pC=Y(),vEe=Wn(),_C=Eo(),UEe=Et();uW.exports=xEe;async function xEe(e){pC.trace("Mounting HarperDB"),Vl(e),Vl(nc.join(e,"backup")),Vl(nc.join(e,"keys")),Vl(nc.join(e,"keys",gh.LICENSE_FILE_NAME)),Vl(nc.join(e,"log")),Vl(nc.join(e,"database")),Vl(nc.join(e,"components")),LEe(nc.resolve(MEe,"./utility/install/README.md"),nc.join(e,"README.md")),await BEe()}a(xEe,"mountHdb");async function BEe(){let e=x_(),t=Object.keys(_C);for(let r=0;r<t.length;r++){let n=t[r],s=_C[n].hash_attribute;try{UEe.initSystemSchemaPaths(gh.SYSTEM_SCHEMA_NAME,n);let i=new e(gh.SYSTEM_SCHEMA_NAME,n,s);i.attributes=_C[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await vEe.createTable(n,i)}catch(i){throw pC.error(`issue creating environment for ${gh.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(BEe,"createLMDBTables");function Vl(e){DEe(e,{mode:gh.HDB_FILE_PERMISSIONS}),pC.info(`Directory ${e} created`)}a(Vl,"makeDirectory")});var CT=I((IUe,yW)=>{"use strict";var EC=require("os"),hW=require("inquirer"),ks=require("fs-extra"),HEe=require("properties-reader"),Yl=require("chalk"),Zi=require("path"),kEe=require("human-readable-ids").hri,FEe=require("ora"),GEe=require("yaml"),fr=Y(),sc=ce(),Sh=oe(),IT=da(),mW=mh(),{packageJson:EW}=nt(),_e=(B(),C(G)),{CONFIG_PARAM_MAP:NUe,CONFIG_PARAMS:Ct}=_e,qEe=lW(),$Ee=hC(),gC=Rt(),VEe=Rn(),KEe=q_(),YEe=JI(),WEe=bs(),zEe=require("util").promisify,jEe=zEe(WEe.setSchemaDataToGlobal),dW=rs(),Kl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),kr=a(e=>Yl.magenta.bold(e),"HDB_PROMPT_MSG"),QEe="https://harperdb.io/legal/end-user-license-agreement",ic=EC.EOL,Wo="",JEe="yes",fW="Starting HarperDB install...",_W="HarperDB installation was successful.",pW="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",XEe="An out of date version of HarperDB is already installed.",mC="It appears that HarperDB is already installed. Exiting install...",ZEe="Aborting install",wUe=new RegExp(/^([0-9]{1,4}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5])$/),ege=new RegExp(/^[^\s.,*>]+$/),tge=EC.homedir(),rge=Zi.join(tge,_e.HDB_ROOT_DIR_NAME),nge="HDB_ADMIN",sge="CLUSTER_USER",ige="dev",oge="localhost",wT={[Ct.HTTP_CORS]:!0,[Ct.HTTP_CORSACCESSLIST]:["*"],[Ct.HTTP_PORT]:9926,[Ct.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Ct.THREADS_COUNT]:1,[Ct.THREADS_DEBUG]:!0,[Ct.LOGGING_STDSTREAMS]:!0,[Ct.LOGGING_LEVEL]:"info",[Ct.OPERATIONSAPI_NETWORK_PORT]:9925,[Ct.LOCALSTUDIO_ENABLED]:!0},Hr={DESTINATION:"Please enter a destination for HarperDB:",HDB_USERNAME:"Please enter a username for the administrative user:",HDB_PASS:"Please enter a password for the administrative user:",NODE_NAME:"Please enter a unique name for this node:",CLUSTER_USERNAME:"Please enter a username for the CLUSTER_USER:",CLUSTER_PASS:"Please enter a password for the CLUSTER_USER:",DEFAULTS_MODE:"Default Config - dev (easy access/debugging) or prod (security/performance): (dev/prod)",REPLICATION_HOSTNAME:"Please enter the hostname for this server:"},oc=IT([_e.INSTALL_PROMPTS.HDB_CONFIG]),Xi,gW=!1,SC=!1,SW=!1;yW.exports={install:TW,updateConfigEnv:Ege,setIgnoreExisting:gge};TW.createSuperUser=RW;async function TW(){console.log(kr(ic+fW+ic)),fr.notify(fW);let e;oc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&(e=age());let t=lge();Object.assign(t,e),t[_e.INSTALL_PROMPTS.TC_AGREEMENT]&&t[_e.INSTALL_PROMPTS.ROOTPATH]&&t[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[_e.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(SW=!0,t[_e.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=qEe(t);if(r)throw r.message;await uge(),await dge(t);let n=await cge(t);Xi=n[_e.INSTALL_PROMPTS.ROOTPATH],oc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&Zi.dirname(oc[_e.INSTALL_PROMPTS.HDB_CONFIG])===Xi&&(gW=!0),!SC&&!oc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&await ks.pathExists(Zi.join(Xi,_e.HDB_CONFIG_FILE))&&(console.error(mC),process.exit());let s=FEe({prefixText:kr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),Sh.isEmpty(Xi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");sc.setHdbBasePath(Xi),await $Ee(Xi),await fge(),await _ge(n),fr.initLogSettings(!0),await RW(n),await hge(n),await dW.updateConfigCert(),await dW.generateCertsKeys(),await mge(),YEe(),s.stop(),console.log(kr(ic+_W+ic)),fr.notify(_W)}a(TW,"install");function age(){let e=GEe.parseDocument(ks.readFileSync(oc[_e.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=gC.flattenConfig(e.toJSON());return t[_e.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[_e.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(age,"getConfigFromFile");async function cge(e){fr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:_e.INSTALL_PROMPTS.ROOTPATH,prefix:Wo,default:rge,validate:a(async s=>Hs(s)?Hs(s):await ks.pathExists(Zi.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:kr(Hr.DESTINATION)},{type:"input",transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Wo,default:nge,validate:a(s=>Hs(s)?Hs(s):(t=s,!0),"validate"),message:kr(Hr.HDB_USERNAME)},{type:"password",when:zo(e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Hr.HDB_PASS),name:_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Wo,validate:a(s=>Hs(s)?Hs(s):!0,"validate"),message:kr(Hr.HDB_PASS)},{type:"input",transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:_e.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Wo,default:ige,validate:a(s=>Hs(s)?Hs(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:kr(Hr.DEFAULTS_MODE)}];if(SW||r.push({type:"input",name:_e.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Wo,default:oge,message:kr(Hr.REPLICATION_HOSTNAME)}),Sh.autoCastBoolean(e[_e.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:_e.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Wo,default:kEe.random(),validate:a(i=>ege.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:kr(Hr.NODE_NAME)},{type:"input",transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:_e.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Wo,default:sge,validate:a(i=>Hs(i)?Hs(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:kr(Hr.CLUSTER_USERNAME)},{type:"password",when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Hr.CLUSTER_PASS),name:_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Wo,validate:a(i=>Hs(i)?Hs(i):!0,"validate"),message:kr(Hr.CLUSTER_PASS)}];r.push(...s)}let n=await hW.prompt(r);if(Object.keys(n).length===0)return e;for(let s in n)e[s]===void 0&&(e[s]=n[s]);return e}a(cge,"installPrompts");function zo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${kr(t)} ${Yl.gray("[hidden]")}`),fr.trace(`${kr(t)} [hidden]`)):(console.log(`${kr(t)} ${e}`),fr.trace(`${kr(t)} ${e}`)),!1):!0}a(zo,"displayCmdEnvVar");function Hs(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(Hs,"checkForEmptyValue");function lge(){let e=Object.keys(_e.INSTALL_PROMPTS),t=IT(e),r=IT(Object.keys(_e.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=_e.CONFIG_PARAM_MAP[s.toLowerCase()];t[s]?i===void 0?n[s]=t[s]:n[i.toUpperCase()]=t[s]:i!==void 0&&r[i.toLowerCase()]&&(n[s]=r[i.toLowerCase()])}return n}a(lge,"checkForPromptOverride");async function uge(){fr.trace("Checking for existing install.");let e=Sh.getPropsFilePath(),t=await ks.pathExists(e),r;if(t){fr.trace(`Install found an existing boot prop file at:${e}`);let n=HEe(e),s=gC.getConfigValue(_e.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(_e.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await ks.pathExists(s)}if(!t&&Sh.noBootFile()&&(r=!0),r&&!SC){if(fr.trace(`Install found existing HDB config at:${e}`),await mW.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${EW.version}. Exiting install...`;console.log(ic+Yl.magenta.bold(XEe)),console.log(Yl.magenta.bold(s)),fr.error(s)}else console.log(ic+Yl.magenta.bold(mC)),fr.error(mC);process.exit(0)}}a(uge,"checkForExistingInstall");async function dge(e){fr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${QEe}${ic}and can be viewed by typing or copying and pasting the URL into your web browser.${ic}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Wo,transformer:Kl,when:zo(e[_e.INSTALL_PROMPTS.TC_AGREEMENT],t),name:_e.INSTALL_PROMPTS.TC_AGREEMENT,message:kr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:Yl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await hW.prompt([r]);n[_e.INSTALL_PROMPTS.TC_AGREEMENT]&&n[_e.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==JEe&&(console.log(Yl.yellow(pW)),fr.error(pW),process.exit(0))}a(dge,"termsAgreement");async function fge(){let e=Zi.join(Xi,_e.HDB_CONFIG_FILE),t;try{t=EC.userInfo().username}catch{t=process.env.USERNAME||process.env.USER||process.env.LOGNAME||process.env.LNAME||process.env.SUDO_USER}if(t){let r=`settings_path = ${e}
|
|
114
|
+
install_user = ${t}`,n=Sh.getHomeDir(),s=Zi.join(n,_e.HDB_HOME_DIR_NAME),i=Zi.join(s,_e.LICENSE_KEY_DIR_NAME);try{ks.mkdirpSync(s,{mode:_e.HDB_FILE_PERMISSIONS}),ks.mkdirpSync(i,{mode:_e.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${_e.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Zi.join(s,_e.BOOT_PROPS_FILE_NAME);try{await ks.writeFile(o,r)}catch(c){throw fr.error(`There was an error creating the boot file at path: ${o}`),c}sc.setProperty(_e.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),sc.setProperty(_e.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),sc.setProperty(sc.BOOT_PROPS_FILE_PATH,o)}}a(fge,"createBootPropertiesFile");async function _ge(e){fr.trace("Creating HarperDB config file");let t=IT(Object.keys(_e.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[_e.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in wT){if(r===Ct.HTTP_PORT&&t[Ct.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??wT[r],t[Ct.HTTP_SECUREPORT]=null;continue}else if(r===Ct.HTTP_PORT)continue;if(r===Ct.OPERATIONSAPI_NETWORK_PORT&&t[Ct.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??wT[r],t[Ct.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Ct.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=wT[r])}}else t[Ct.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Ct.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Ct.HTTP_PORT.toLowerCase()]&&(t[Ct.HTTP_SECUREPORT]=null);try{oc[_e.INSTALL_PROMPTS.HDB_CONFIG]||gC.createConfigFile(t),sc.initSync()}catch(r){pge(r)}}a(_ge,"createConfigFile");function pge(e){fr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(ZEe);let t=Zi.resolve(sc.get(sc.BOOT_PROPS_FILE_PATH),"../");t&&ks.removeSync(t),Xi&&(gW?ks.readdirSync(Xi,{withFileTypes:!0}).forEach(n=>{let s=Zi.join(n.path,n.name);s!==oc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&ks.removeSync(s)}):ks.removeSync(Xi)),process.exit(1)}a(pge,"rollbackInstall");async function AW(e,t){fr.trace("Creating admin user"),await jEe();let r;try{r=await KEe.addRole(e)}catch(n){if(n.message.includes("already exists"))t=void 0;else throw n.message+="Error creating role",n}if(t)try{t.role=r.role,await VEe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(AW,"createAdminUser");async function RW(e){fr.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await AW(t,r),delete e[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(RW,"createSuperUser");async function hge(e){fr.trace("Creating Cluster user.");let t;e[_e.INSTALL_PROMPTS.CLUSTERING_USER]&&e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[_e.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await AW({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[_e.INSTALL_PROMPTS.CLUSTERING_USER],delete e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(hge,"createClusterUser");async function mge(){let e=EW.version;if(e)await mW.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(mge,"insertHdbVersionInfo");function Ege(e){oc[_e.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Ege,"updateConfigEnv");function gge(e){SC=e}a(gge,"setIgnoreExisting")});var NW=I((PUe,OW)=>{"use strict";var TC=oe(),ds=Y(),bW=aC();OW.exports={processDirectives:Sge};async function Sge(e){console.log("Starting upgrade process...");let t=bW.getVersionsForUpgrade(e),r=Rge(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;ds.notify(c),console.log(c);let l=[],u=[];try{l=Tge(o.sync_functions)}catch(f){throw ds.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await Age(o.async_functions)}catch(f){throw ds.error(`Error while running an upgrade script for ${o.version}`),f}n.push(...l,...u)}return n}a(Sge,"processDirectives");function Tge(e){if(TC.isEmptyOrZeroLength(e))return ds.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return ds.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(ds.info(`Running function ${r.name}`),!(r instanceof Function)){ds.info("Variable being processed is not a function");continue}let n=r();ds.info(n),t.push(n)}return t}a(Tge,"runSyncFunctions");async function Age(e){if(TC.isEmptyOrZeroLength(e))return ds.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return ds.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(ds.info(`Running function ${s.name}`),!(s instanceof Function)){ds.info("Variable being processed is not a function");continue}let i=await s();ds.info(i),t.push(i)}return t}a(Age,"runAsyncFunctions");function Rge(e){if(TC.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=bW.getDirectiveByVersion(r);n&&t.push(n)}return t}a(Rge,"getUpgradeDirectivesToInstall")});var bC=I((LUe,LW)=>{"use strict";var PT=ce();PT.initSync();var PW=require("chalk"),wW=require("fs-extra"),Qo=Y(),jo=(B(),C(G)),yge=NW(),AC=oe(),DW=mh(),bge=gT(),IW=nR(),Oge=bs(),{packageJson:CW}=nt(),Nge=require("util").promisify,wge=Nge(Oge.setSchemaDataToGlobal),RC,{UPGRADE_VERSION:yC}=jo.UPGRADE_JSON_FIELD_NAMES_ENUM;LW.exports={upgrade:Ige};async function Ige(e){await wge(),RC===void 0&&(RC=Id()),wW.existsSync(PT.get(PT.BOOT_PROPS_FILE_PATH))||(Th("The hdb_boot_properties file was not found. Please install HDB.",jo.LOG_LEVELS.ERROR),process.exit(1)),wW.existsSync(PT.get(jo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(Th("The hdb settings file was not found. Please make sure HDB is installed.",jo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await DW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),Th(`This version of HarperDB is ${CW.version}`,jo.LOG_LEVELS.INFO);let r=t[yC]??CW.version;r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${jo.HDB_SUPPORT_ADDRESS}`),Qo.notify("Missing new version field from upgrade info object"),process.exit(1)),await Cge();let n,s=0;try{n=await bge.forceUpdatePrompt(t)}catch(i){Qo.error("There was an error when prompting user about upgrade."),Qo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),Qo.info(`Starting upgrade to version ${r}`),await Pge(t),Th(`HarperDB was successfully upgraded to version ${t[yC]}`,jo.LOG_LEVELS.INFO)}a(Ige,"upgrade");async function Cge(){let e=!1,t=await IW.findPs(jo.HDB_PROC_NAME);if(AC.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await IW.findPs("hdb_express");AC.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await RC.list();AC.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(PW.red(r)),Qo.error(r),process.exit(1)}}a(Cge,"checkIfRunning");async function Pge(e){try{await yge.processDirectives(e)}catch(t){throw Th("There was an error during the data upgrade. Please check the logs.",jo.LOG_LEVELS.ERROR),t}try{await DW.insertHdbUpgradeInfo(e[yC])}catch(t){Qo.error("Error updating the 'hdb_info' system table."),Qo.error(t)}}a(Pge,"runUpgrade");function Th(e,t=void 0){t||(t=Qo.info),Qo[t](e),console.log(PW.magenta(e))}a(Th,"printToLogAndConsole")});var BW={};ve(BW,{onStorageReclamation:()=>Ah,runReclamationHandlers:()=>IC,setAvailableSpaceRatioGetter:()=>Lge});function Ah(e,t,r){(r||(0,LT.getWorkerIndex)()===(0,LT.getWorkerCount)()-1)&&(DT.has(e)||DT.set(e,[]),DT.get(e).push({priority:0,handler:t}),wC||(wC=setTimeout(IC,vW).unref()))}async function IC(){for(let[e,t]of DT)try{let r=await xW(e),n=Dge/r;for(let s of t){let{priority:i,handler:o}=s;if(s.priority=n,n>1||i>1){let c=o(n>1?n:0);c&&(NC.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){NC.default.error?.("Error running storage reclamation handlers",r)}wC=setTimeout(IC,vW).unref()}function Lge(e){xW=e??UW}var OC,LT,NC,MT,MW,DT,Dge,vW,wC,UW,xW,vT=be(()=>{OC=require("node:fs/promises"),LT=M(tt()),NC=M(Ci());B();MT=M(ce()),MW=M(oe());MT.default.initSync();DT=new Map,Dge=MT.default.get(x.STORAGE_RECLAMATION_THRESHOLD)??.4,vW=(0,MW.convertToMS)(MT.default.get(x.STORAGE_RECLAMATION_INTERVAL))||36e5;a(Ah,"onStorageReclamation");UW=a(async e=>{if(OC.statfs){let t=await(0,OC.statfs)(e);return t.bavail/t.blocks}else return new Promise((t,r)=>{import("hdd-space").then(n=>{n.default(s=>{for(let i of s.parts)if(e.startsWith(i.place))return t(i.free/i.size);return t(1)})})})},"defaultGetAvailableSpaceRatio"),xW=UW;a(IC,"runReclamationHandlers");a(Lge,"setAvailableSpaceRatioGetter")});var qW=I((xUe,GW)=>{"use strict";var{promises:Yd,createReadStream:Mge,createWriteStream:vge}=require("fs"),{createGzip:Uge}=require("zlib"),{promisify:xge}=require("util"),{pipeline:Bge}=require("stream"),Hge=xge(Bge),PC=require("path"),cc=ce();cc.initSync();var ac=Y(),{CONFIG_PARAMS:Wd,ITC_EVENT_TYPES:kge}=(B(),C(G)),{onMessageFromWorkers:Fge}=tt(),{convertToMS:Gge}=oe(),{onStorageReclamation:qge}=(vT(),C(BW)),$ge=6e4,Vge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Kge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",CC,kW;GW.exports=FW;Fge(e=>{e.type===kge.RESTART&&(cc.initSync(!0),clearInterval(kW),cc.get(Wd.LOGGING_ROTATION_ENABLED)&&FW())});async function FW(){try{let e=ac.getLogFilePath(),t=cc.get(Wd.LOGGING_ROTATION_MAXSIZE),r=cc.get(Wd.LOGGING_ROTATION_INTERVAL),n=cc.get(Wd.LOGGING_ROTATION_RETENTION),s=0;if(qge(e,l=>{s=l},!0),!t&&!r){ac.error(Vge);return}let i=cc.get(Wd.LOGGING_ROTATION_PATH);if(!i){ac.error(Kge);return}let o;if(t){let l=t.slice(-1),u=t.slice(0,-1);l==="G"?o=u*1e9:l==="M"?o=u*1e6:o=u*1e3}let c;if(r){let l=r.slice(-1),u=r.slice(0,-1);l==="D"?c=u*1440:l==="H"?c=u*60:c=u}CC=Date.now()/6e4,ac.trace("Log rotate enabled, maxSize:",t,"interval:",r),kW=setInterval(async()=>{if(o){let l;l=await Yd.stat(e),l.size>=o&&await HW(e,i)}if(c&&Date.now()/6e4-CC>=c&&(await HW(e,i),CC=Date.now()/6e4),n||s){let l=Gge(n??"1M")/(1+s);s=0;let u=await Yd.readdir(i);for(let f of u)try{let d=await Yd.stat(PC.join(i,f));Date.now()-d.mtimeMs>l&&await Yd.unlink(PC.join(i,f))}catch(d){ac.error("Error trying to remove log",f,d)}}},$ge).unref()}catch(e){ac.error(e)}}a(FW,"logRotator");async function HW(e,t){let r=cc.get(Wd.LOGGING_ROTATION_COMPRESS),n=PC.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);await Yd.rename(e,n),r&&(e=n,n+=".gz",await Hge(Mge(e),Uge(),vge(n)),await Yd.unlink(e)),ac.closeLogFile(),ac.notify(`hdb.log rotated, old log moved to ${n}`)}a(HW,"moveLogFile")});var jd=I(jW=>{"use strict";var ge=ce();ge.initSync();za();var kt=(B(),C(G)),{CONFIG_PARAMS:Ie}=kt,fs=Y(),Jo=require("fs-extra"),Xo=require("path"),Yge=JI(),{install:Wge}=CT(),DC=require("chalk"),{packageJson:zge,PACKAGE_ROOT:jge}=nt(),Zo=oe(),LC=Rt(),VW=da(),$W=SS(),Qge=bC(),Jge=qW(),{compactOnStart:Xge}=(wS(),C(NS)),Zge=require("minimist"),eSe=rs(),{startHTTPThreads:tSe}=(MC(),C(QW)),rSe=mh(),{isMainThread:nSe}=require("worker_threads"),HUe=Eo(),kUe=Ao(),FUe=wb(),GUe=x_(),UT=(B(),C(G)),eo,zd,KW=!1,sSe="Upgrade complete. Starting HarperDB.",iSe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",oSe="HarperDB not found, starting install process.",aSe="There was an error during install, check install_log.log for more details. Exiting.",cSe="HarperDB successfully started.";function lSe(){if(!KW){let e=a(()=>{Jo.removeSync(Xo.join(ge.get(kt.CONFIG_PARAMS.ROOTPATH),kt.HDB_PID_FILE)),process.exit(0)},"remove_hdb_pid");process.on("exit",()=>{e()}),process.on("SIGINT",()=>{e()}),process.on("SIGQUIT",()=>{e()}),process.on("SIGTERM",()=>{e()})}}a(lSe,"addExitListeners");async function YW(e=!1,t=!1){if(console.log(DC.magenta("Starting HarperDB...")),fs.suppressLogging?.(()=>{console.log(DC.magenta(""+Jo.readFileSync(Xo.join(jge,"utility/install/ascii_logo.txt"))))}),await zW()===!1){console.log(oSe);try{await Wge()}catch(l){console.error(aSe,l),fs.error(l),process.exit(1)}}if(!e){let l=VW(Object.keys(kt.CONFIG_PARAM_MAP),!0);!Zo.isEmpty(l)&&!Zo.isEmptyOrZeroLength(Object.keys(l))&&LC.updateConfigValue(void 0,void 0,l,!0,!0)}let r,n=zd?.service==="clustering";zd?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));let s=Xo.join(ge.get(kt.CONFIG_PARAMS.ROOTPATH),kt.HDB_PID_FILE),i=pSe(s);i&&i!==1&&hSe(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),eo===void 0&&(eo=Id()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),ge.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await $W.generateNatsConfig(),await eo.startClusteringProcesses(!0),process.exit()),lSe(),await Jo.writeFile(Xo.join(ge.get(UT.CONFIG_PARAMS.ROOTPATH),UT.HDB_PID_FILE),`${process.pid}`),fs.info("HarperDB PID",process.pid);let o;try{let l=await rSe.getVersionUpdateInfo();l!==void 0&&(o=l[kt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Qge.upgrade(l),console.log(sSe))}catch(l){o?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${o}. Exiting HarperDB.`,l),fs.error(l)):(console.error(iSe,l),fs.error(l)),process.exit(1)}Yge(),fSe(),await eSe.reviewSelfSignedCert(),Zo.autoCastBoolean(ge.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&nSe&&await $W.generateNatsConfig(t)}a(YW,"initialize");async function uSe(e=!1){try{zd=Zge(process.argv),zd.ROOTPATH&&LC.updateConfigObject("settings_path",Xo.join(zd.ROOTPATH,kt.HDB_CONFIG_FILE)),await YW(e,!0),ge.get(kt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Xge();let t=process.env.IS_SCRIPTED_SERVICE&&!zd.service;Zo.autoCastBoolean(ge.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await eo.startClusteringProcesses(),await eo.startClusteringThreads()),await tSe(process.env.DEV_MODE?1:ge.get(UT.CONFIG_PARAMS.THREADS_COUNT)??ge.get(UT.CONFIG_PARAMS.THREADS)),ge.get(kt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Jge(),t||WW()}catch(t){console.error(t),fs.error(t),process.exit(1)}}a(uSe,"main");function WW(){fs.suppressLogging(()=>{console.log(DC.magenta(`HarperDB ${zge.version} successfully started`))}),fs.notify(cSe)}a(WW,"started");async function dSe(e=!0){KW=!e;try{eo===void 0&&(eo=Id()),eo.enterPM2Mode(),await YW(),Zo.autoCastBoolean(ge.get(kt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await eo.startClusteringProcesses(),await eo.startService(kt.PROCESS_DESCRIPTORS.HDB),WW(),e&&process.exit(0)}catch(t){console.error(t),fs.error(t),process.exit(1)}}a(dSe,"launch");function fSe(){let e=Xo.join(ge.get(kt.CONFIG_PARAMS.ROOTPATH),kt.LICENSE_KEY_DIR_NAME,kt.LICENSE_FILE_NAME),t=Xo.join(e,kt.LICENSE_FILE_NAME),r=Xo.join(e,kt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=VW(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Zo.isEmpty(n)||Zo.isEmpty(s))return;Jo.mkdirpSync(e),Jo.writeFileSync(r,n),Jo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),fs.error(s)}}a(fSe,"writeLicenseFromVars");Object.assign(jW,{launch:dSe,main:uSe,isHdbInstalled:zW,startupLog:_Se});async function zW(){try{await Jo.stat(Zo.getPropsFilePath()),await Jo.stat(ge.get(kt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Zo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw fs.error(`Error checking for HDB install - ${e}`),e}return!0}a(zW,"isHdbInstalled");function _Se(e){let r=a(_=>_.padEnd(20),"pad"),n=`
|
|
115
|
+
`;ge.get(Ie.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${ge.get(Ie.REPLICATION_HOSTNAME)}
|
|
116
|
+
`),ge.get(Ie.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${ge.get(Ie.REPLICATION_URL)}
|
|
117
|
+
`),n+=`${r("Worker Threads:")}${ge.get(Ie.THREADS_COUNT)}
|
|
118
|
+
`,n+=`${r("Root Path:")}${ge.get(Ie.ROOTPATH)}
|
|
119
|
+
`,ge.get(Ie.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=ge.get(Ie.THREADS_DEBUG_PORT)?`, TCP: ${ge.get(Ie.THREADS_DEBUG_PORT)}
|
|
120
120
|
`:`
|
|
121
|
-
`);let s=
|
|
122
|
-
`,n+=r("Default:"),n+=ge.get(
|
|
123
|
-
`,n+=r("Operations API:"),n+=ge.get(
|
|
124
|
-
`,n+=r("MQTT:"),n+=ge.get(
|
|
121
|
+
`);let s=Xo.join(ge.get(Ie.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${ge.get(Ie.LOGGING_LEVEL)}, location: ${s+(ge.get(Ie.LOGGING_STDSTREAMS)?", stdout/err":"")}
|
|
122
|
+
`,n+=r("Default:"),n+=ge.get(Ie.HTTP_PORT)?`HTTP (and WS): ${ge.get(Ie.HTTP_PORT)}, `:"",n+=ge.get(Ie.HTTP_SECUREPORT)?`HTTPS (and WS): ${ge.get(Ie.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${ge.get(Ie.HTTP_CORS)?`enabled for ${ge.get(Ie.HTTP_CORSACCESSLIST)}`:"disabled"}
|
|
123
|
+
`,n+=r("Operations API:"),n+=ge.get(Ie.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${ge.get(Ie.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=ge.get(Ie.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${ge.get(Ie.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${ge.get(Ie.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${ge.get(Ie.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${ge.get(Ie.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
|
|
124
|
+
`,n+=r("MQTT:"),n+=ge.get(Ie.MQTT_NETWORK_PORT)?`TCP: ${ge.get(Ie.MQTT_NETWORK_PORT)}, `:"",n+=ge.get(Ie.MQTT_NETWORK_SECUREPORT)?`TLS: ${ge.get(Ie.MQTT_NETWORK_SECUREPORT)}`:"",n+=ge.get(Ie.MQTT_WEBSOCKET)&&ge.get(Ie.HTTP_PORT)?`, WS: ${ge.get(Ie.HTTP_PORT)}`:"",n+=ge.get(Ie.MQTT_WEBSOCKET)&&ge.get(Ie.HTTP_SECUREPORT)?`, WSS: ${ge.get(Ie.HTTP_SECUREPORT)}
|
|
125
125
|
`:`
|
|
126
|
-
`;let i=ge.get(
|
|
127
|
-
`;let l=[],u=
|
|
128
|
-
`);let
|
|
129
|
-
`:n+=`${r(_+": ")}${
|
|
130
|
-
`;console.log(n),ge.get(
|
|
126
|
+
`;let i=ge.get(Ie.REPLICATION_PORT)??ge.get(Ie.OPERATIONSAPI_NETWORK_PORT),o=ge.get(Ie.REPLICATION_SECUREPORT)??ge.get(Ie.OPERATIONSAPI_NETWORK_SECUREPORT),c=r("Replication:");c+=i?`WS: ${i}, `:"",c+=o?`WSS: ${o} `:"",n+=`${c.slice(0,-2)}
|
|
127
|
+
`;let l=[],u=LC.getConfigObj();for(let _ in u)u[_].package&&l.push(_);let f={},d=`${r("REST:")}`;for(let[_,h]of e)for(let S of h){let g=S.name;g==="rest"&&(d+=`${S.protocol_name}: ${_}, `),l.includes(g)&&(f[g]?f[g]+=`${S.protocol_name}: ${_}, `:f[g]=`${S.protocol_name}: ${_}, `)}d.length>21&&(d=d.slice(0,-2),n+=`${d}
|
|
128
|
+
`);let p=ge.get(Ie.HTTP_PORT)?`HTTP: ${ge.get(Ie.HTTP_PORT)}, `:"";p+=ge.get(Ie.HTTP_SECUREPORT)?`HTTPS: ${ge.get(Ie.HTTP_SECUREPORT)}, `:"",p.length>21&&(p=p.slice(0,-2));for(let _ of l)f[_]?n+=`${r(_+": ")}${f[_].slice(0,-2)}
|
|
129
|
+
`:n+=`${r(_+": ")}${p}
|
|
130
|
+
`;console.log(n),ge.get(Ie.LOGGING_STDSTREAMS)&&fs.logsAtLevel("info")&&fs.suppressLogging(()=>{console.log(`Note that log messages are being sent to the console (stdout and stderr) in addition to the log file ${s}. This can be disabled by setting logging.stdStreams to false, and the log file can be directly monitored/tailed.`)})}a(_Se,"startupLog");function pSe(e){try{return Number.parseInt(Jo.readFileSync(e,"utf8"),10)}catch{return null}}a(pSe,"readPidFile");function hSe(e){try{return process.kill(e,0),!0}catch(t){return t.code==="EPERM"}}a(hSe,"isProcessRunning")});var $C=I(ea=>{"use strict";rm();var{isMainThread:vC,parentPort:Oh,threadId:BT,workerData:mSe}=require("node:worker_threads"),{Socket:ESe,createServer:gSe}=require("node:net"),{createServer:SSe,IncomingMessage:TSe}=require("node:http"),{createServer:ASe}=require("node:https"),{createSecureServer:RSe}=require("node:http2"),{Blob:ySe}=(As(),C(Fm)),{unlinkSync:sz,existsSync:bSe}=require("fs"),vn=Y(),ht=ce(),jt=(B(),C(G)),{server:Nh}=(Kr(),C(Tu)),{WebSocketServer:OSe}=require("ws"),{createServer:NSe}=require("node:tls"),{getTicketKeys:wSe,restartNumber:ISe,getWorkerIndex:Qd}=tt(),{Headers:UC,appendHeader:CSe}=(Q_(),C(bH)),{recordAction:Rh,recordActionBinary:JW}=($i(),C(j_)),{Request:iz,createReuseportFd:bh}=(jI(),C(OY)),{checkMemoryLimit:PSe}=yd(),{createTLSSelector:oz}=rs(),{resolvePath:az}=Rt(),{startupLog:DSe}=jd(),{Readable:XW}=require("node:stream"),LSe=yi(),cz=ht.get(jt.CONFIG_PARAMS.THREADS_DEBUG);if(cz){let e;if(vC)e=ht.get(jt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){vn.info("Could not close debugger",t)}});else{let t=ht.get(jt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&Qd()>=0&&(e=t+Qd())}if(e){let t=ht.get(jt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=ht.get(jt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){vn.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&vC)try{require("inspector").open(9229)}catch(e){ISe<=1&&vn.trace("Could not start debugging on port 9229, you may already be debugging:",e.message)}process.on("uncaughtException",e=>{e.isHandled||e.code==="ECONNRESET"||e.code==="ECONNREFUSED"||e.message!=="write EIO"&&console.error("uncaughtException",e)});var{HDB_SETTINGS_NAMES:VUe,CONFIG_PARAMS:MSe}=jt;ht.initSync();var vSe=ht.get(MSe.HTTP_SESSIONAFFINITY),to={},xC=new Map;ea.registerServer=FC;ea.httpServer=qC;ea.deliverSocket=kC;ea.startServers=lz;ea.listenOnPorts=uz;ea.globals=LSe;ea.when_components_loaded=null;Nh.http=qC;Nh.request=xSe;Nh.socket=BSe;Nh.ws=HSe;Nh.upgrade=_z;var yh={},xT={},HT={},BC=[];function lz(){return ea.when_components_loaded=qT().loadRootComponents(!0).then(()=>{Oh?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)kC(n,r,s);else if(t.requestId)USe(t);else if(t.type===jt.ITC_EVENT_TYPES.SHUTDOWN){vn.trace("received shutdown request",BT);for(let i in to){let o=to[i],c;if(o.closeIdleConnections){let u=Object.getOwnPropertySymbols(o).find(p=>p.description.includes("connections")),f=0,d=setInterval(()=>{f++;let p=f>=100,_=o[u][p?"all":"idle"]();if(_.length===0){p&&clearInterval(d);return}f===1?vn.info(`Closing ${_.length} idle connections`):p&&vn.warn(`Forcefully closing ${_.length} active connections`);for(let h=0,S=_.length;h<S;h++){let g=_[h].socket;g._httpMessage&&!g._httpMessage.finished&&!p||(p?g.destroySoon():g.end(`HTTP/1.1 408 Request Timeout\r
|
|
131
131
|
Connection: close\r
|
|
132
132
|
\r
|
|
133
|
-
`))}},25).unref()}o.close?.(()=>{if(
|
|
134
|
-
`)}a(DW,"defaultNotFound")});var bW={};Be(bW,{startHTTPThreads:()=>_Se,startSocketServer:()=>LC,updateWorkerIdleness:()=>QW});async function _Se(e=2,t){try{if(t)PC(0,1,!0);else{let{loadRootComponents:r}=OT();if(e===0)return(0,qs.setMainIsWorker)(!0),await wC().startServers(),Promise.resolve([]);await r()}jW();for(let r=0;r<e;r++)PC(r,e);return Promise.all(zW)}finally{(0,qs.threadsHaveStarted)()}}function jW(){let e=(0,KW.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),CC=setInterval(()=>{IT.notify(e)},fSe).unref())}function PC(e,t=1,r){if(IC++,(0,qs.startWorker)("server/threads/threadServer.js",{name:UA.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===LA.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});zW.push(s),await s,Vd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=wT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Vd.indexOf(n);o>-1&&Vd.splice(o,1)}if(a(i,"removeWorker"),Kd){let o=Kd;Kd=[];for(let c of o)WW[c.localPort](null,c)}}}),r){let n=setInterval(()=>{DC?DC=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,qs.shutdownWorkers)(),IC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function LC(e=0,t){if(typeof e=="string")try{(0,CT.existsSync)(e)&&(0,CT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=hSe:r=pSe(t):r=MC;let n=(0,Yd.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);return n._handle&&(n._handle.onconnection=WW[e]=function(s,i){r.readsData||(i.reading=!1,i.readStop()),DC=!0,r(i,(o,c)=>{if(!o){if(GW){let u=i._socket||new Yd.Socket({handle:i,writable:!0,readable:!0});GW.deliverSocket(u,e,c),u.resume()}else IC>0?(Kd.length===0&&setTimeout(()=>{Kd.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),i.localPort=e,Kd.push(i)):(console.log("start up a dynamic thread to handle request"),PC(0));or(!1,"socket-routed");return}o.requests++;let l=i.fd;if(l>=0)o.postMessage({port:e,fd:l,data:c});else{let u=i._socket||new Yd.Socket({handle:i,writable:!0,readable:!0});gSe(u,o,e)}or(!0,"socket-routed")})},IT.info(`HarperDB ${YW.packageJson.version} Server running on port ${e}`)),n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function MC(e,t){let r,n=0;for(let s of Vd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=NT)return NT=i,t(r);n=i}NT=0,t(r)}function hSe(e,t){let r={};e.getpeername(r);let n=r.address,s=Wd.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);MC(e,o=>{Wd.set(n,{worker:o,lastUsed:i}),t(o)})}function pSe(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new Yd.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],u=Wd.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);MC(n,d=>{Wd.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function QW(){NT=0;for(let e of Vd)e.expectedIdle=e.recentELU.idle+ESe,e.requests=1;Vd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function gSe(e,t,r){let n=mSe++;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(),wT.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")),wT.delete(n)),s.event=="destroy"&&(e.destroy(),wT.delete(n))})}var qs,Yd,IT,CT,VW,KW,YW,Vd,Kd,WW,GW,IC,zW,CC,fSe,DC,NT,$W,Wd,ESe,wT,mSe,mC=be(()=>{qs=x(nt()),Yd=require("net");v();IT=x(W()),CT=require("fs");$i();VW=require("worker_threads"),KW=x(Ed()),YW=x(rt()),Vd=[],Kd=[],WW=[],IC=0,zW=[];VW.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,qs.onMessageFromWorkers)(e=>{e.type===vA.RESTART&&CC&&(clearInterval(CC),jW())}));fSe=6e5;a(_Se,"startHTTPThreads");a(jW,"licenseWarning");a(PC,"startHTTPWorker");a(LC,"startSocketServer");NT=0;a(MC,"findMostIdleWorker");$W=36e5,Wd=new Map;a(hSe,"findByRemoteAddressAffinity");a(pSe,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Wd)r.lastUsed+$W<e&&Wd.delete(t)},$W).unref();ESe=1e3;a(QW,"updateWorkerIdleness");(0,qs.setMonitorListener)(QW);wT=new Map,mSe=1;a(gSe,"proxySocket")});var ez=C((HUe,ZW)=>{"use strict";var SSe=require("cluster"),zl=ce();zl.initSync();var XW=(v(),D(q)),ia=W(),TSe=require("fastify"),ASe=require("@fastify/cors"),RSe=require("@fastify/compress"),ySe=require("@fastify/static"),bSe=nO(),OSe=require("path"),{PACKAGE_ROOT:NSe}=rt(),wSe=ys(),ISe=ae(),CSe=An(),PSe=Ed(),{server:DSe}=(Yr(),D(Ic)),{authHandler:LSe,handlePostRequest:MSe,serverErrorHandler:vSe,reqBodyValidationHandler:USe}=rT(),{registerContentHandlers:xSe}=(Eo(),D(SR)),BSe=6e4,HSe=1024*1024*1024,kSe="TRUE",{CONFIG_PARAMS:mp}=XW,zd;ZW.exports={hdbServer:JW,start:JW};async function JW(e){try{ia.debug("In Fastify server"+process.cwd()),ia.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ia.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=SSe.isMaster,await FSe();let t=e.securePort>0;zd=qSe(t),await zd.ready(),e||(e={}),e.isOperationsServer=!0;try{DSe.http(zd.server,e),zd.server.closeIdleConnections||await zd.listen({port:0,host:"::"})}catch(r){throw zd.close(),ia.error(r),ia.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),ia.fatal(t),process.exit(1)}}a(JW,"operationsServer");async function FSe(){ia.trace("Configuring HarperDB process."),wSe.setSchemaDataToGlobal(),await CSe.setUsersWithRolesCache(),await PSe.getLicense()}a(FSe,"setUp");function qSe(e){ia.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=GSe(e),r=TSe(t);r.server.headersTimeout=VSe(),r.setErrorHandler(vSe);let n=$Se();n&&r.register(ASe,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(bSe),r.register(RSe),r.register(ySe,{root:OSe.join(NSe,"studio/build-local")}),xSe(r);let s=zl.get(XW.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!ISe.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[USe,LSe],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),MSe(i,o)}),r.get("/health",()=>"HarperDB is running."),ia.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(qSe,"buildServer");function GSe(e){let t=zl.get(mp.OPERATIONSAPI_NETWORK_TIMEOUT),r=zl.get(mp.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:HSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(GSe,"getServerOptions");function $Se(){let e=zl.get(mp.OPERATIONSAPI_NETWORK_CORS),t=zl.get(mp.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===kSe)&&(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($Se,"getCORSOpts");function VSe(){return zl.get(mp.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??BSe}a(VSe,"getHeaderTimeoutConfig")});var kC={};Be(kC,{disableNATS:()=>YSe,publishToStream:()=>LT,setNATSReplicator:()=>vC,setPublishToStream:()=>WSe,setSubscription:()=>HC,start:()=>KSe});function KSe(){gp.default.get(H.CLUSTERING_ENABLED)&&jSe()}function YSe(e=!0){iz=e}function WSe(e,t){LT=e,HC=t}function jSe(){if(iz||process.env._DISABLE_NATS)return;let e=Je(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];vC(s,r,i)}}El((r,n)=>{vC(r.tableName,r.databaseName,r),n&&az(r)}),!tz&&(tz=!0)}function vC(e,t,r){if(t==="system"&&QSe.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 Kr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this.getId(),record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this.getId()})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this.getId(),record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this.getId(),record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this.getId()})}static defineSchema(i){az(i)}static subscribe(){let i=new qn;return HC(t,e,i),i}static subscribeOnThisThread(i){return i<(gp.default.get(H.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??zSe)}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 PT(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=oz;return i}a(n,"getNATSTransaction")}function az(e){let t=gp.default.get(H.CLUSTERING_NODENAME);LT(`${xC.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,BC.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 rz,xC,BC,nz,sz,gp,DT,iz,LT,HC,zSe,oz,tz,QSe,PT,UC,cz=be(()=>{Ce();Ra();rz=x(ar()),xC=x(gt()),BC=x(bo());cu();nz=x(AO()),sz=x(_n()),gp=x(ce());v();DT=x(W());a(KSe,"start");a(YSe,"disableNATS");LT=rz.publishToStream,HC=nz.setSubscription;a(WSe,"setPublishToStream");zSe=2;a(jSe,"assignReplicationSource");QSe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(vC,"setNATSReplicator");a(az,"publishSchema");PT=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=gp.default.get(H.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let f of i){let d=f.table,h=f.operation=="put"?"upsert":f.operation;l||(DT.trace(`Sending transaction event ${h}`),u=l={operation:h,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,h!=="delete"&&h!=="invalidate"&&(l.records=o)),l.table===d&&l.operation===h?(o.push(f.record),c.push(f.id)):u=u.next={operation:h,table:d,id:f.id,record:f.record},f.expiresAt&&(u.expiresAt=f.expiresAt)}l&&n.push(LT(`${xC.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,BC.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(f=>{throw DT.error("An error has occurred trying to replicate transaction",l,f),f.statusCode=504,f}))}return Promise.all(n)}},UC=class extends PT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,sz.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};oz=new UC});async function _z({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await FC.get(e,{returnNonexistent:!0});i=new $C(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await FC.get(e);o&&o.delete()}i=new vT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Sp.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function qC(){return MT++,MT>65500&&(MT=1),MT}function GC(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Ci.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 Ot(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var uz,uc,dz,fz,lz,FC,Sp,MT,vT,$C,hz=be(()=>{Ce();hu();uz=x(_n()),uc=x(W());Oc();dz=x(nt()),fz=x(wC());Yr();lz=100,FC=at({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"}]}}]}),Sp=at({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,dz.getWorkerIndex)()===0&&(async()=>{await fz.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of Sp.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await Qe.getUser(r.user.username));try{await GC(r,t,r)}catch{(0,uc.warn)("Failed to publish will",t)}Sp.delete(e.id)}})();a(_z,"getSession");MT=1;a(qC,"getNextMessageId");vT=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let f=this.subscriptions.find(T=>T.topic===s),d;f?(d=i>0,f.end(),this.subscriptions.splice(this.subscriptions.indexOf(f),1)):d=i===2;let h={search:l,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,uc.trace)("Resuming subscription from",s,"from",o);let _=Ci.getMatch(u,"mqtt");if(!_){let T=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw T.statusCode=404,T}if(h.url=_.relativeURL,h.url.indexOf("+")>-1||h.url.indexOf("#")>-1){let T=h.url.slice(1);if(T.indexOf("#")>-1&&T.indexOf("#")!==T.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(h.isCollection=!0,T.indexOf("+")===T.length-1)h.onlyChildren=!0,h.url="/"+T.slice(0,T.length-1);else{let m=T.split("/"),A;for(let F=0;F<m.length;F++)if(m[F].indexOf("+")>-1)if(m[F]==="+")A=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&A)throw new Error("Filters can not be combined");let w=!0;m[m.length-1]==="#"&&(m.length--,w=!1),A&&(n=a(F=>{let G=F.id;if(!Array.isArray(G)||w&&G.length!==m.length)return!1;for(let K=0;K<m.length;K++)if(m[K]!=="+"&&m[K]!==G[K])return!1;return!0},"filter"));let M=m.indexOf("+");h.url="/"+(M>-1?m.slice(0,M):m).concat("").join("/")}}let p=_.path,S=_.Resource,g=await Ot(h,async()=>{let T=this.createContext();T.topic=s,T.retainHandling=i;let m=await S.subscribe(h,T);if(!m)return;if(!m[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let A=(async()=>{for await(let w of m)try{let M;if(w.type&&w.type!=="put"&&w.type!=="delete"&&w.type!=="message"&&w.type!=="patch"||n&&!n(w))continue;r?(w.topic=s,M=this.needsAcknowledge(w)):(w.acknowledge?.(),M=qC());let F=w.id;if(Array.isArray(F)&&(F=_u(F)),F==null&&(F=""),await this.listener(p+"/"+F,w.value,M,t)===!1)break;this.awaitingAcks?.size>lz?await new Promise(K=>setTimeout(K,this.awaitingAcks.size-lz)):await new Promise(setImmediate)}catch(M){(0,uc.warn)(M)}})();return m});if(g)return g.topic=s,g.qos=t.qos,this.subscriptions.push(g),g}resume(){}needsAcknowledge(t){let r=qC();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return GC(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();Ot(r,async()=>{try{if(!t){let n=await Sp.get(this.sessionId);n?.doesExist()&&await GC(n,n.data,r)}}finally{await Sp.delete(this.sessionId)}}).catch(n=>{(0,uc.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(GC,"publish");$C=class extends vT{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=qC(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,uc.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,uz.getNextMonotonicTime)()),(0,uc.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),FC.put(this.sessionRecord)}}});var KC={};Be(KC,{bypassAuth:()=>JSe,start:()=>XSe});function JSe(){Sz=!0}function XSe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new gz.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,f,d,h)=>{if(f.headers.get("sec-websocket-protocol")!=="mqtt")return h(u,f,d);o.events.emit("connection",u),hr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:_,onClose:p}=Ez(u,S=>{u.send(S)},f,Promise.resolve(d).then(()=>f?.user),o);u.on("message",_),u.on("close",p),u.on("error",S=>{hr.info?.("WebSocket error",S)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let f;if(o.events.emit("connection",u),hr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let _=l.user;if(_!==null){(_===void 0||_==="Common Name"||_==="CN")&&(_=u.getPeerCertificate().subject.CN);try{f=await e.getUser(_,null,null),(0,jd.get)(H.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&xT.notify?.({username:f?.username,status:Qs.SUCCESS,type:ha.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(p){throw(0,jd.get)(H.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&xT.error?.({username:_,status:Qs.FAILURE,type:ha.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),p}}else hr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(_){o.events.emit("error",_,u),hr.error?.(_)}else if(l.required)return hr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!f&&Sz&&u.remoteAddress.includes("127.0.0.1")&&(f=await(0,mz.getSuperUser)(),hr.debug?.("Auto-authorizing local connection",f?.username));let{onMessage:d,onClose:h}=Ez(u,_=>u.write(_),null,f,o);u.on("data",d),u.on("close",h),u.on("error",_=>{hr.info?.("Socket error",_)})},{port:t,securePort:s,mtls:l})),c}function Ez(e,t,r,n,s){pz||(pz=!0,F_(d=>{UT>0&&d.push({metric:"mqtt-connections",connections:UT,byThread:!0})}));let i;UT++;let o,c={protocolVersion:4},l=(0,BT.parser)({protocolVersion:5});function u(d){l.parse(d)}a(u,"onMessage");function f(){UT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),es(!1,"connection","mqtt","disconnect"),hr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(f,"onClose"),l.on("packet",async d=>{n?.then&&(n=await n);let h=d.cmd;if(o)o.then&&await o;else if(h!=="connect"){hr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let _=d.topic,p=_?.indexOf("/",1),S=p>0?_.slice(0,p):_;or(d.length,"bytes-received",S,T(d),"mqtt");try{switch(o?.receivedPacket?.(),h){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await Qe.getUser(d.username,d.password.toString(),r),(0,jd.get)(H.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&xT.notify?.({username:n?.username,status:Qs.SUCCESS,type:ha.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(ie){return(0,jd.get)(H.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&xT.error?.({username:d.username,status:Qs.FAILURE,type:ha.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,ie),es(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),es(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let ie=e.deserialize||(e.deserialize=go(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?ie(d.will.payload):void 0,delete d.will.payload}o=_z({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(ie){return hr.error?.(ie),s.events.emit("auth-failed",d,e,ie),es(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:ie.code||5,returnCode:ie.code||128})}s.events.emit("connected",o,e),es(!0,"connection","mqtt","connect"),g({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0});let A=a(async(ie,X,re,j)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",ie);let he=ie.indexOf("/",1),Te=he>0?ie.slice(0,he):ie;g({cmd:"publish",topic:ie,payload:await m(X),messageId:re||Math.floor(Math.random()*1e8),qos:j.qos},Te);let Ie=e._socket??e;return Ie.writableNeedDrain?new Promise(pe=>Ie.once("drain",pe)):!Ie.closed}catch(he){return hr.error?.(he),o?.disconnect(),s.sessions.delete(o),!1}},"listener");o.setListener(A),o.sessionWasPresent&&await o.resume();break;case"subscribe":let w=[];for(let ie of d.subscriptions){let X;try{let re=await o.addSubscription(ie,ie.qos>=1);X=re?re.qos||0:c.protocolVersion<5?128:143}catch(re){s.events.emit("error",re,e,ie,o),re.statusCode?re.statusCode===500?hr.warn?.(re):hr.info?.(re):hr.error?.(re),X=c.protocolVersion<5?128:re.statusCode===403?135:re.statusCode===404?143:128}w.push(X)}await o.committed,g({cmd:"suback",granted:w,messageId:d.messageId});break;case"unsubscribe":{let ie=[];for(let X of d.unsubscriptions)ie.push(o.removeSubscription(X)?0:17);g({cmd:"unsuback",granted:ie,messageId:d.messageId});break}case"pubrel":g({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let M=d.qos===2?"pubrec":"puback",F=e.deserialize||(e.deserialize=go(r?.headers.get?.("content-type"))),K=(d.payload?.length||0)>0?F(d.payload):void 0,ee;try{ee=await o.publish(d,K)}catch(ie){s.events.emit("error",ie,e,d,o),hr.warn?.(ie),d.qos>0&&g({cmd:M,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&g({cmd:M,messageId:d.messageId,reasonCode:ee===!1?144:0},d.topic);break;case"pubrec":g({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":g({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),es(!0,"connection","mqtt","disconnect"),hr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(A){s.events.emit("error",A,e,d,o),hr.error?.(A),g({cmd:"disconnect"})}function g(A,w){let M=(0,BT.generate)(A,c);t(M),or(M.length,"bytes-sent",w,T(A),"mqtt")}a(g,"sendPacket");function T(A){return A.qos>0?A.cmd+",qos="+A.qos:A.cmd}a(T,"packetMethodName");function m(A){return Oa(A,r)}a(m,"serialize")}),l.on("error",d=>{hr.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:f}}var BT,mz,jd,VC,gz,xT,hr,Sz,pz,UT,Tz=be(()=>{BT=require("mqtt-packet");hz();mz=x(An());Eo();$i();Yr();jd=x(ce());v();VC=x(uo()),gz=require("events"),xT=(0,VC.loggerWithTag)("auth-event"),hr=(0,VC.loggerWithTag)("mqtt"),Sz=(0,jd.get)(H.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(JSe,"bypassAuth");a(XSe,"start");UT=0;a(Ez,"onSocket")});var Hh={};Be(Hh,{component_errors:()=>Jd,getComponentName:()=>nTe,loadComponent:()=>FT,loadComponentDirectories:()=>Nz,setErrorReporter:()=>rTe});function Nz(e,t){t&&(WC=t),e&&(QC=e);let r=[];if((0,_t.existsSync)(YC)){let s=(0,_t.readdirSync)(YC,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Et.join)(YC,o);r.push(FT(c,WC,IA,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(FT(n,WC,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{Oz=!0})}function rTe(e){Tp=e}async function FT(e,t,r,n,s,i){let o=(0,_t.realpathSync)(e);if(HT.has(o))return HT.get(o);HT.set(o,!0),s&&(QC=s);try{let c;n&&(Jd=new Map);let l=(0,Et.join)(e,"harperdb-config.yaml");(0,_t.existsSync)(l)?c=n?(0,qT.getConfigObj)():(0,zC.parseDocument)((0,_t.readFileSync)(l,"utf8")).toJSON():!n&&(0,_t.existsSync)(l=(0,Et.join)(e,"config.yaml"))?c=(0,zC.parseDocument)((0,_t.readFileSync)(l,"utf8")).toJSON():c=JC;let u=(0,Et.join)(e,"node_modules","harperdb");try{jl.isMainThread&&(n||(0,_t.existsSync)(u)&&(0,_t.realpathSync)(jC.PACKAGE_ROOT)!==(0,_t.realpathSync)(u))&&((0,_t.rmSync)(u,{recursive:!0,force:!0}),(0,_t.existsSync)((0,Et.join)(e,"node_modules"))||(0,_t.mkdirSync)((0,Et.join)(e,"node_modules")),(0,_t.symlinkSync)(jC.PACKAGE_ROOT,u,"dir"))}catch(h){Qd.default.error("Error symlinking harperdb module",h)}let f=kT,d=n;for(let h in c){kT=h;let _=c[h];if(Jd.set(n?h:(0,Et.basename)(e),!1),!_)continue;let p,S=_.package;try{if(S){let w=e,M;for(;!(0,_t.existsSync)(M=(0,Et.join)(w,"node_modules",h));)if(w=(0,Et.dirname)(w),w.length<(0,bz.getHdbBasePath)().length){M=null;break}if(M)p=await FT(M,t,r,!1),d=!0;else throw new Error(`Unable to find package ${h}:${S}`)}else p=tTe[h];if(!p)continue;let g=a(w=>(w.origin=r,at(w)),"ensureTable"),T=_.network||(_.port||_.securePort)&&_,m=T?.securePort||T?.https&&T.port,A=!T?.https&&T?.port;if(jl.isMainThread&&(p=await p.startOnMainThread?.({server:Qe,ensureTable:g,port:A,securePort:m,resources:t,..._})||p,n&&T))for(let w of[A,m])try{if(+w&&!Az.includes(w)){let M=XC.get(H.HTTP_SESSIONAFFINITY);M&&Qd.default.warn("Session affinity is not recommended and may cause memory leaks"),(M||!sT)&&(Az.push(w),LC(w,M))}}catch(M){console.error("Error listening on socket",w,M,h)}if(t.isWorker&&(p=await p.start?.({server:Qe,ensureTable:g,port:A,securePort:m,resources:t,..._})||p),QC.set(p,!0),(p.handleFile||p.handleDirectory||p.setupFile||p.setupDirectory)&&_.files!=null){if(_.files.includes(".."))throw(0,yz.handleHDBError)("Can not reference parent directories");let w=(0,Et.join)(e,_.files).replace(/\\/g,"/"),M=w.indexOf("/*");if(M>-1&&_.files!==JC[h]?.files&&!(0,_t.existsSync)(w.slice(0,M)))throw new Error(`The path '${w.slice(0,M)}' does not exist and cannot be used as the base of the resolved 'files' path value '${_.files}'`);let F=(0,Et.basename)(e),G=_.path||"/";G=G.startsWith("/")?G:G.startsWith("./")?"/"+F+G.slice(2):G==="."?"/"+F:"/"+F+"/"+G;let K,ee,ie;if(_.root){let re=_.root;re.startsWith("/")&&(re=re.slice(1)),re.endsWith("/")&&(re=re.slice(0,-1)),re+="/",ee=(0,Et.join)(e,re)}else(ie=w.indexOf("/*"))>-1?(ee=w.slice(0,ie+1),K=(0,Et.relative)(e,ee)):_.files.indexOf("/")>-1&&(ee=w.slice(0,w.lastIndexOf("/")+1),K=(0,Et.relative)(e,ee));let X=!1;if(jl.isMainThread&&p.setupDirectory&&(X=await p.setupDirectory?.(G,ee,t)),t.isWorker&&p.handleDirectory&&(X=await p.handleDirectory?.(G,ee,t)),X){d=!0;continue}for(let re of await(0,Rz.default)(w,{onlyFiles:!1,objectMode:!0})){let{path:j,dirent:he}=re;d=!0;let Te=(0,Et.relative)(e,j).replace(/\\/g,"/");if(K)if(Te.startsWith(K))Te=Te.slice(K.length+1);else throw new Error(`The root path '${_.root}' does not reference a valid part of the file path '${Te}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ie=G+(G.endsWith("/")?"":"/")+Te;try{if(he.isFile()){let pe=await eTe(j);jl.isMainThread&&await p.setupFile?.(pe,Ie,j,t),t.isWorker&&await p.handleFile?.(pe,Ie,j,t)}else jl.isMainThread&&await p.setupDirectory?.(Ie,j,t),t.isWorker&&await p.handleDirectory?.(Ie,j,t)}catch(pe){pe.message=`Could not load ${he.isFile()?"file":"directory"} '${j}'${_.module?" using '"+_.module+"'":""} for application '${e}' due to: ${pe.message}`,Tp?.(pe),((0,Xd.getWorkerIndex)()===0?console:Qd.default).error(pe),t.set(_.path||"/",new ya(pe)),Jd.set(n?h:(0,Et.basename)(e),pe.message)}}}}catch(g){g.message=`Could not load component '${h}' for application '${(0,Et.basename)(e)}' due to: ${g.message}`,Tp?.(g),((0,Xd.getWorkerIndex)()===0?console:Qd.default).error(g),t.set(_.path||"/",new ya(g),null,!0),Jd.set(n?h:(0,Et.basename)(e),g.message)}}if(kT=f,jl.isMainThread&&!Oz&&i&&(0,Xd.watchDir)(e,async()=>Nz()),c.extensionModule){let h=await Fm((0,Et.join)(e,c.extensionModule));return HT.set(o,h),h}if(!d&&t.isWorker){let h=`${e} did not load any modules, resources, or files, is this a valid component?`;Tp?.(new Error(h)),((0,Xd.getWorkerIndex)()===0?console:Qd.default).error(h),Jd.set((0,Et.basename)(e),h)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Tp?.(c),t.set("",new ya(c))}}var _t,Et,jl,zC,XC,jC,Rz,Xd,Qd,yz,bz,ZSe,qT,eTe,YC,QC,Oz,WC,Jd,tTe,JC,Az,HT,Tp,kT,nTe,kh=be(()=>{_t=require("fs"),Et=require("path"),jl=require("worker_threads"),zC=require("yaml"),XC=x(ce()),jC=x(rt());v();EL();XL();CB();MB();vB();EH();QK();rY();Rz=x(require("fast-glob")),Xd=x(nt()),Qd=x(W());qb();Yr();yz=x(_e());Ce();mC();bz=x(ce()),ZSe=x(ez());RS();cz();ts();Tz();qT=x(At());BI();tR();({readFile:eTe}=_t.promises),YC=(0,qT.resolvePath)(XC.get(H.COMPONENTSROOT)),QC=new Map,Jd=new Map;a(Nz,"loadComponentDirectories");tTe={REST:Ym,rest:Ym,graphql:AR,graphqlSchema:sR,roles:Fb,jsResource:$b,fastifyRoutes:LI,login:Kb,static:MI,operationsApi:ZSe,customFunctions:{},http:{},clustering:kC,replication:vo,authentication:Mh,mqtt:KC},JC={rest:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(JC,"static",{value:{files:"web/**"}});Az=[],HT=new Map;a(rTe,"setErrorReporter");nTe=a(()=>kT,"getComponentName");a(FT,"loadComponent")});var OT=C((h0e,Iz)=>{var{isMainThread:wz}=require("worker_threads"),{getTables:sTe,getDatabases:f0e,table:_0e}=(Ce(),D(tt)),{loadComponentDirectories:iTe,loadComponent:oTe}=(kh(),D(Hh)),{resetResources:aTe}=(hu(),D(fL)),cTe=ww(),lTe=At(),{dirname:uTe}=require("path"),{getConnection:dTe}=ar(),fTe=ce(),{CONFIG_PARAMS:_Te}=(v(),D(q)),{loadCertificates:hTe}=rs(),ZC=new Map;async function pTe(e=!1){!wz&&fTe.get(_Te.CLUSTERING_ENABLED)&&dTe();try{wz&&await cTe()}catch(n){console.error(n)}let t=aTe();sTe(),t.isWorker=e,await hTe(),await oTe(uTe(lTe.getConfigFilePath()),t,"hdb",!0,ZC),await iTe(ZC,t);let r=[];for(let[n]of ZC)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(pTe,"loadRootComponents");Iz.exports.loadRootComponents=pTe});var nt=C((E0e,Ai)=>{"use strict";Kp();var{Worker:ETe,MessageChannel:mTe,parentPort:to,isMainThread:sP,threadId:gTe,workerData:ro}=require("worker_threads"),{PACKAGE_ROOT:STe}=rt(),{join:Lz,isAbsolute:TTe,extname:ATe}=require("path"),{server:Mz}=(Yr(),D(Ic)),{watch:RTe,readdir:yTe}=require("fs/promises"),{totalmem:Cz}=require("os"),Zd=(v(),D(q)),vz=ce(),no=W(),{randomBytes:bTe}=require("crypto"),{_assignPackageExport:OTe}=bi(),Pz=1024*1024,dc=[],Gs=[],NTe=50,iP=1e4,wTe="restart",Uz="request_thread_info",xz="resource_report",Bz="thread_info",Hz="added-port",ITe="ack",eP;OTe("threads",Gs);Ai.exports={startWorker:tP,restartWorkers:aP,shutdownWorkers:MTe,workers:dc,setMonitorListener:qTe,onMessageFromWorkers:vTe,onMessageByType:Kz,broadcast:xTe,broadcastWithAcknowledgement:HTe,setChildListenerByType:LTe,getWorkerIndex:kz,getWorkerCount:Fz,getTicketKeys:Gz,setMainIsWorker:PTe,setTerminateTimeout:CTe,restartNumber:ro?.restartNumber||1};Gs.onMessageByType=Kz;Gs.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Gs.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Ai.exports.whenThreadsStarted=new Promise(e=>{Ai.exports.threadsHaveStarted=e});var oP;function CTe(e){iP=e}a(CTe,"setTerminateTimeout");function kz(){return ro?ro.workerIndex:oP?0:void 0}a(kz,"getWorkerIndex");function Fz(){return ro?ro.workerCount:oP?1:void 0}a(Fz,"getWorkerCount");function PTe(e){oP=e,Ai.exports.threadsHaveStarted()}a(PTe,"setMainIsWorker");var qz=1,GT;function Gz(){return GT||(GT=sP?bTe(48):ro.ticketKeys,GT)}a(Gz,"getTicketKeys");Object.defineProperty(Mz,"workerIndex",{get(){return kz()}});Object.defineProperty(Mz,"workerCount",{get(){return Fz()}});var $z={[Uz](e,t){kTe(t)},[xz](e,t){FTe(t,e)}};function tP(e,t={}){let r=process.constrainedMemory?.()||Cz();r=Math.min(r,Cz(),2e4*Pz);let n=vz.get(Zd.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/Pz/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Gs){let u=new mTe;u.existingPort=l,i.push(u),o.push(u.port2)}ATe(e)||(e+=".js");let c=new ETe(TTe(e)?e:Lz(STe,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:qz=t.threadCount,name:t.name,restartNumber:Ai.exports.restartNumber,ticketKeys:Gz()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:Hz,port:l,threadId:c.threadId},[l]);return VT(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>tP(e,t),c.on("error",l=>{no.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{dc.splice(dc.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<NTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,tP(e,t)):no.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{$z[l.type]?.(l,c)}),dc.push(c),$Te(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(tP,"startWorker");var DTe=[Zd.THREAD_TYPES.HTTP];async function aP(e=null,t=Math.max(qz>3,1),r=!0){if(sP){if(r){let{loadRootComponents:o}=OT();await o()}Ai.exports.restartNumber++,t<1&&(t=t*dc.length);let n=[],s=[];for(let o of dc.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;no.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ai.exports.restartNumber,type:Zd.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=DTe.indexOf(o.name)>-1,l=new Promise(u=>{let f=setTimeout(()=>{no.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},iP*2).unref();o.on("exit",()=>{clearTimeout(f),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),f=new Promise(d=>{let h=a(_=>{_.type===Zd.ITC_EVENT_TYPES.CHILD_STARTED&&(no.trace("Worker has started",u.threadId),d(),s.splice(s.indexOf(f)),u.off("message",h))},"startListener");no.trace("Waiting for worker to start",u.threadId),u.on("message",h)});s.push(f),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=Ja();r&&(e==="http"||!e)&&vz.get(Zd.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else to.postMessage({type:wTe,workerType:e})}a(aP,"restartWorkers");function LTe(e,t){$z[e]=t}a(LTe,"setChildListenerByType");function MTe(e){return aP(e,1/0,!1)}a(MTe,"shutdownWorkers");var Vz=[];function vTe(e){Vz.push(e)}a(vTe,"onMessageFromWorkers");var rP=new Map;function Kz(e,t){let r=rP.get(e);r||rP.set(e,r=[]),r.push(t)}a(Kz,"onMessageByType");var UTe=10;async function xTe(e,t){let r=0;for(let n of Gs)try{n.postMessage(e),r++>UTe&&(r=0,await new Promise(setImmediate))}catch(s){no.error("Unable to send message to worker",s)}t&&Wz(e,null)}a(xTe,"broadcast");var $T=new Map,BTe=1;function HTe(e){return new Promise(t=>{let r=0;for(let n of Gs)try{let s=BTe++,i=a(()=>{$T.delete(s),--r===0&&t(),n!==to&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,$T.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of $T)o.port===n&&o()})),n.postMessage(e),r++}catch(s){no.error("Unable to send message to worker",s)}r===0&&t()})}a(HTe,"broadcastWithAcknowledgement");function kTe(e){e.postMessage({type:Bz,workers:Yz()})}a(kTe,"sendThreadInfo");function Yz(){let e=Date.now();return dc.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(Yz,"getChildWorkerInfo");function FTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(FTe,"recordResourceReport");var nP;function qTe(e){nP=e}a(qTe,"setMonitorListener");var GTe=1e3,Dz=!1;function $Te(){Dz||(Dz=!0,setInterval(()=>{for(let e of dc){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}nP&&nP()},GTe).unref())}a($Te,"startMonitoring");var VTe=1e3;if(to&&ro?.addPorts){VT(to);for(let e=0,t=ro.addPorts.length;e<t;e++){let r=ro.addPorts[e];r.threadId=ro.addThreadIds[e],VT(r)}setInterval(()=>{let e=process.memoryUsage();to.postMessage({type:xz,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},VTe).unref(),eP=a(()=>new Promise((e,t)=>{to.on("message",r),to.postMessage({type:Uz});function r(n){n.type===Bz&&(to.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else eP=Yz;Ai.exports.getThreadInfo=eP;function VT(e,t){Gs.push(e),e.on("message",r=>{if(r.type===Hz)r.port.threadId=r.threadId,VT(r.port);else if(r.type===ITe){let n=$T.get(r.id);n&&n()}else Wz(r,e)}).on("close",()=>{Gs.splice(Gs.indexOf(e),1)}).on("exit",()=>{Gs.splice(Gs.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(VT,"addPort");function Wz(e,t){for(let n of Vz)n(e,t);let r=rP.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){no.error(s)}}a(Wz,"notifyMessageListeners");if(sP){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await yTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(Lz(s,o.name));try{for await(let{filename:o}of RTe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await aP(),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");Ai.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else to.on("message",async e=>{let{type:t}=e;t===Zd.ITC_EVENT_TYPES.SHUTDOWN&&(Ai.exports.restartNumber=e.restartNumber,to.unref(),setTimeout(()=>{no.warn("Thread did not voluntarily terminate",gTe),process.exit(0)},iP).unref())})});var zx={};Be(zx,{ACTION_32_BIT:()=>HE,ACTION_64_BIT:()=>WTe,AUDIT_STORE_OPTIONS:()=>Ih,Decoder:()=>pl,HAS_BLOBS:()=>ei,HAS_CURRENT_RESIDENCY_ID:()=>xc,HAS_EXPIRATION_EXTENDED_TYPE:()=>Qf,HAS_ORIGINATING_OPERATION:()=>jf,HAS_PREVIOUS_RESIDENCY_ID:()=>Bc,REMOTE_SEQUENCE_UPDATE:()=>Rg,createAuditEntry:()=>Su,getLastRemoved:()=>iN,openAuditStore:()=>zT,readAuditEntry:()=>Nt,removeAuditEntry:()=>jT,setAuditRetention:()=>YTe,transactionKeyEncoder:()=>rj});function zT(e){let t=e.auditStore=e.openDB(cP.AUDIT_STORE_NAME,{create:!1,...Ih});t||(t=e.auditStore=e.openDB(cP.AUDIT_STORE_NAME,Ih),jz(t,1)),t.rootStore=e,t.tableStores=[];let r=[];t.addDeleteRemovalCallback=function(i,o,c){return r[i]=c,t.tableStores[i]=o,t.deleteCallbacks=r,{remove(){delete r[i]}}};let n=null;function s(i=KT){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:u,value:f}of t.getRange({start:1,snapshot:!1,end:Date.now()-lP})){try{c=jT(t,u,f)}catch(d){ef.warn("Error removing audit entry",d)}if(l=u,await new Promise(setImmediate),++o>=KTe){i=10;break}}await c}finally{o===0?i=Math.min(i<<1,lP/10):jz(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,Rp.getWorkerIndex)()===(0,Rp.getWorkerCount)()-1&&s(KT),(0,Rp.getWorkerIndex)()===0&&!zz)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(zz=!0,ef.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 jT(e,t,r){let n=zTe(r),s;if(n&ei){s=Nt(r);let i=e.tableStores[s.tableId];i.getEntry(s.recordId).version!==s.version&&Dc(()=>po(s.getValue(i)),i.rootStore)}if((n&15)===uP){s=s||Nt(r);let i=s.tableId;e.tableStores[s.tableId].getEntry(s.recordId).version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function jz(e,t){dP[0]=t,e.put(Symbol.for("last-removed"),nj)}function iN(e){let t=e.get(Symbol.for("last-removed"));if(t)return nj.set(t),dP[0]}function YTe(e,t=KT){lP=e,KT=t}function Su(e,t,r,n,s,i,o,c,l,u,f,d,h){let _=sj[o];if(!_)throw new Error(`Invalid audit entry type ${o}`);let p=1;if(n&&(n>1?fc.setFloat64(0,n):$s.set(DR),p=9),l){if(l&255)throw new Error("Illegal extended type");p+=3}T(s),T(t),g(r),fc.setFloat64(p,e),p+=8,l&xc&&T(u),l&Bc&&T(f),l&Qf&&(fc.setFloat64(p,d),p+=8),l&jf&&T(ij[h]),i?g(i):$s[p++]=0,l?fc.setUint32(n?8:0,_|l|3221225472):$s[n?8:0]=_;let S=$s.subarray(0,p);if(c)return Buffer.concat([S,c]);return S;function g(m){let A=p;p+=1,p=(0,Ql.writeKey)(m,$s,p);let w=p-A-1;w>127?w>16383?(ef.error("Key or username was too large for audit entry",m),p=A+1,$s[A]=0):($s.copyWithin(A+2,A+1,p),fc.setUint16(A,w|32768),p++):$s[A]=w}function T(m){m<128?$s[p++]=m:m<16384?(fc.setUint16(p,m|32768),p+=2):m<1056964608?(fc.setUint32(p,m|3221225472),p+=4):($s[p]=255,fc.setUint32(p+1,m),p+=5)}}function zTe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new pl(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Nt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new pl(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,f=n.position+=l,d=n.readFloat64(),h,_,p,S;if(i&xc&&(h=n.readInt()),i&Bc&&(_=n.readInt()),i&Qf&&(p=n.readFloat64()),i&jf){let m=n.readInt();S=ij[m]}l=n.readInt();let g=n.position,T=n.position+=l;return{type:sj[i&7],tableId:c,nodeId:o,get recordId(){return(0,Ql.readKey)(e,u,f)},getBinaryRecordId(){return e.subarray(u,f)},version:d,previousLocalTime:s,get user(){return T>g?(0,Ql.readKey)(e,g,T):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(m,A,w){if(i&YT||i&Ap&&!A)return Dc(()=>m.decoder.decode(e.subarray(n.position,r)),m.rootStore);if(i&Ap&&w)return Ob(m.getEntry(this.recordId),w,m)},getBinaryValue(){return i&(YT|Ap)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:h,previousResidencyId:_,expiresAt:p,originatingOperation:S}}catch(n){return ef.error("Reading audit entry error",n,e),{}}}var Ql,WT,cP,Rp,tj,ef,$s,fc,rj,Ih,lP,KTe,dP,nj,KT,zz,YT,Ap,Qz,uP,Jz,Xz,Zz,ej,HE,WTe,Rg,xc,Bc,jf,Qf,ei,sj,ij,pl,So=be(()=>{Ql=require("ordered-binary"),WT=x(ce()),cP=x(Mt());v();Rp=x(nt()),tj=x(ae());Tu();ef=x(W());wm();Ts();(0,WT.initSync)();$s=Buffer.alloc(2816),fc=new DataView($s.buffer,$s.byteOffset,2816),rj={writeKey(e,t,r){return e===zf?(t.set(zf,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)}},Ih={encoding:"binary",keyEncoder:rj},lP=(0,tj.convertToMS)((0,WT.get)(H.LOGGING_AUDITRETENTION))||86400*3,KTe=1e3,dP=new Float64Array(1),nj=new Uint8Array(dP.buffer),KT=1e4,zz=!1;a(zT,"openAuditStore");a(jT,"removeAuditEntry");a(jz,"updateLastRemoved");a(iN,"getLastRemoved");a(YTe,"setAuditRetention");YT=16,Ap=32,Qz=1,uP=2,Jz=3,Xz=4,Zz=5,ej=6,HE=14,WTe=15,Rg=11,xc=512,Bc=1024,jf=2048,Qf=4096,ei=8192,sj={put:Qz|YT,[Qz]:"put",delete:uP,[uP]:"delete",message:Jz|YT,[Jz]:"message",invalidate:Xz|Ap,[Xz]:"invalidate",patch:Zz|Ap,[Zz]:"patch",relocate:ej,[ej]:"relocate"},ij={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Su,"createAuditEntry");a(zTe,"readAction");a(Nt,"readAuditEntry");pl=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});function hP(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=aj,jTe(e.primaryStore,e.auditStore)):(c=oj,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{cj(oj[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=_u(t);let f=new _P(r);f.startTime=n;let d=u.get(t);return d?d.push(f):(u.set(t,d=[f]),d.tables=u,d.key=t),f.subscriptions=d,f}function cj(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),lj(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Nt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=_u(c),u=0;do{let f=o.get(l);if(f){for(let h of f)if(!(u>0&&!(h.includeDescendants&&!(h.onlyChildren&&u>1)))){if(h.startTime>=n){(0,fP.info)("omitting",c,h.startTime,n);continue}try{let _;h.supportsTransactions&&h.txnInProgress!==i.version&&(_=!0,h.txnInProgress||(r?r.push(h):r=[h]),h.txnInProgress=i.version),h.listener(c,i,n,_)}catch(_){console.error(_),(0,fP.info)(_)}}}if(l==null)break;let d=l.lastIndexOf?.("/",l.length-2);d>-1?l=l.slice(0,d):l=null,u++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function jTe(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=aj[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{cj(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function lj(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function EF(e){return e.nextTransaction||(hP({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),lj(e)),e.nextTransaction}var fP,oj,aj,_P,oN=be(()=>{fP=x(W());cu();hu();So();oj=Object.create(null),aj=Object.create(null);a(hP,"addSubscription");_P=class extends qn{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(cj,"notifyFromTransactionData");a(jTe,"listenToCommits");a(lj,"nextTransaction");a(EF,"whenNextTransaction")});var fI={};Be(fI,{EVICTED:()=>Aa,INVALIDATED:()=>Ss,coerceType:()=>XT,makeTable:()=>eA,setServerUtilities:()=>nAe});function eA(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:f,sealed:d,splitSegments:h,replicate:_}=e,{expirationMS:p,evictionMS:S,audit:g,trackDeletes:T}=e,{attributes:m}=e;m||(m=[]);let A=vR(i,n,l),w,M,F={},G=Promise.resolve(),K,ee,ie;for(let z of m)(z.assignCreatedTime||z.name==="__createdtime__")&&(K=z),(z.assignUpdatedTime||z.name==="__updatedtime__")&&(ee=z),z.expiresAt&&(ie=z),z.isPrimaryKey&&(F=z);let X,re=[],j=[],he=1,Te=2,Ie={},pe={},qt=864e5,Gt,Zt,pr,df=!1,gc,TA=new Map,AA=new Map,Dt,ff,_f=rf.get(H.REPLICATION_DATABASES);if(Array.isArray(_f)){for(let z of _f)if(z.name===c&&z.replicateTo>=0){ff=z.replicateTo;break}}let RA=i.getRange({start:!1,end:!1}).constructor,kp=10,hf=6;g&&gf();class Le extends Kr{#e;#t;#n;#r;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=o;static databaseName=c;static attributes=m;static replicate=_;static sealed=d;static splitSegments=h??!0;static createdTimeProperty=K;static updatedTimeProperty=ee;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return p}static dbisDB=f;static schemaDefined=u;static sourcedFrom(E,O){if(O&&(this.sourceOptions=O,(O.expiration||O.eviction||O.scanInterval)&&this.setTTLExpiration(O)),O?.intermediateSource)E.intermediateSource=!0,this.sources.unshift(E);else{if(this.sources.some(I=>!I.intermediateSource)){if(this.sources.some(I=>I.name===E.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(E)}M=M||E.get&&(!E.get.reliesOnPrototype||E.prototype.get),w=w||E.load;let R=a(I=>{let L=this.sources;if(L=L.filter(B=>B.intermediateSource&&B[I]&&(!B[I].reliesOnPrototype||B.prototype[I])),L.length>0)if(L.length===1){let B=L[0];return(N,U,$)=>{if(N?.source!==B)return B[I](U,$,N)}}else return(B,N,U)=>{let $=[];for(let Y of L){if(B?.source===Y)break;$.push(Y[I](N,U,B))}return Promise.all($)}},"getApplyToIntermediateSource"),y=this.sources[this.sources.length-1];y.intermediateSource&&(y={});let b=a(I=>{if(y[I]&&(!y[I].reliesOnPrototype||y.prototype[I]))return(L,B,N)=>{if(!L?.source)return y[I](B,N,L)}},"getApplyToCanonicalSource");Ie={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},pe={put:R("put"),patch:R("patch"),delete:R("delete"),publish:R("publish"),invalidate:R("invalidate")};let P=y.shouldRevalidateEvents;return(async()=>{let I=!1,L,B=a(async(N,U)=>{let $=N.value,Y=N.table?$e[c][N.table]:Le;if(c===DA&&(N.table===jp.ROLE_TABLE_NAME||N.table===jp.USER_TABLE_NAME)&&(I=!0),N.id===void 0&&(N.id=$[Y.primaryKey],N.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(N));N.source=E;let ne={residencyId:fa(N.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:N.nodeId},k=await Y.getResource(N.id,U,ne);switch(N.finished&&await N.finished,N.type){case"put":return P?k._writeInvalidate(ne):k._writeUpdate($,!0,ne);case"patch":return P?k._writeInvalidate(ne):k._writeUpdate($,!1,ne);case"delete":return k._writeDelete(ne);case"publish":return k._writePublish($,ne);case"invalidate":return k._writeInvalidate(ne);case"relocate":return k._writeRelocate(ne);default:xe.default.error?.("Unknown operation",N.type,N.id)}},"writeUpdate");try{let N=E.subscribe;N&&T==null&&(T=!0);let U={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},$=E.subscribeOnThisThread?E.subscribeOnThisThread((0,Jl.getWorkerIndex)(),U):(0,Jl.getWorkerIndex)()===0,Y=N&&$&&await E.subscribe?.(U);if(Y){let ne;for await(let k of Y)try{if(!(k.type==="transaction"?k.writes[0]:k)){xe.default.error?.("Bad subscription event",k);continue}if(k.source=E,k.type==="end_txn"){if(ne?.resolve(),k.localTime&&L!==k.localTime){if(k.remoteNodeIds?.length>0){let le=[Symbol.for("seq"),k.remoteNodeIds[0]],se=f.get(le),Q=se?.nodes;Q||(Q=[]);for(let Ee of k.remoteNodeIds.slice(1)){let ye=Q.find(Me=>Me.id===Ee);Q=Q.filter(Me=>Me.id!==Ee||Me===ye),ye||(ye={id:Ee,seqId:0},Q.push(ye)),ye.seqId=Math.max(se?.seqId??1,k.localTime),Ee===ne?.nodeId&&(ye.lastTxnTime=k.timestamp)}let fe=Math.max(se?.seqId??1,k.localTime);xe.default.trace?.("Received txn",c,new Date(fe),new Date(k.localTime),k.remoteNodeIds),f.put(le,{seqId:fe,nodes:Q})}L=k.localTime}k.onCommit&&ne?.committed.then(k.onCommit);continue}if(ne)if(k.beginTxn)ne.resolve();else{ne.write_promises.push(B(k,ne));continue}!k.timestamp&&k.version&&(k.timestamp=k.version);let oe=Ot(k,()=>{if(k.type==="transaction"){let le=[];for(let se of k.writes)try{le.push(B(se,k))}catch(Q){throw Q.message+=" writing "+JSON.stringify(se)+" of event "+JSON.stringify(k),Q}return Promise.all(le)}else if(k.type==="define_schema"){let le=this.attributes.slice(0),se;for(let Q of k.attributes)le.find(fe=>fe.name===Q.name)||(le.push(Q),se=!0);se&&(at({table:s,database:c,attributes:le,origin:"cluster"}),bp.signalSchemaChange(new Op.SchemaEventMsg(process.pid,Vt.CREATE_TABLE,c,s)))}else return k.beginTxn?(ne=k,ne.write_promises=[B(k,k)],new Promise(le=>{ne.resolve=()=>le(Promise.all(ne.write_promises))})):B(k,k)});ne&&(ne.committed=oe),I&&oe&&!oe?.waitingForUserChange&&(oe.then(()=>bp.signalUserChange(new Op.UserEventMsg(process.pid))),oe.waitingForUserChange=!0),k.onCommit&&(oe?oe.then(k.onCommit):k.onCommit())}catch(ve){xe.default.error?.("error in subscription handler",ve)}}}catch(N){xe.default.error?.(N)}})(),this}static get isCaching(){return M}static get shouldRevalidateEvents(){return this.prototype.get!==Le.prototype.get}static getResource(E,O,R){let y=super.getResource(E,O,R);if(E!=null){Pr(E);try{if(y.getRecord?.())return y;if(typeof E=="object"&&E&&!Array.isArray(E))throw new Error(`Invalid id ${JSON.stringify(E)}`);let b=!R?.async||i.cache?.get?.(E),P=mt(O),I=P.getReadTxn();if(I?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return kn(E,O,{transaction:I,ensureLoaded:R?.ensureLoaded},b,L=>{if(L?Le._updateResource(y,L):y.#e=null,O.onlyIfCached&&O.noCacheStore){if(!y.doesExist())throw new Cr.ServerError("Entry is not cached",504)}else if(R?.ensureLoaded){let B=Fp(E,L,O,y);if(B)return P?.disregardReadTxn(),y.#i=!0,EP(B,N=>(Le._updateResource(y,N),y))}return y})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(E)),b}}return y}static _updateResource(E,O){E.#r=O,E.#e=O?.value??null,E.#n=O?.version}ensureLoaded(){let E=Fp(this.getId(),this.#r,this.getContext());if(E)return this.#i=!0,EP(E,O=>{this.#r=O,this.#e=O.value,this.#n=O.version})}static getNewId(){let E=F?.type;if(E==="String"||E==="ID")return super.getNewId();if(!Dt){let b=i.getEntry(Symbol.for("id_allocation")),P=b?.value,I;if(P&&P.nodeName===server.hostname&&(!iAe(i)||P.pid===process.pid)){let L=P.start,B=P.end;I=L;for(let N of i.getKeys({start:B,end:L,limit:1,reverse:!0}))I=N}else P=y(b?.version??null),I=P.start;Dt=new BigInt64Array([BigInt(I)+1n]),Dt=new BigInt64Array(i.getUserSharedBuffer("id",Dt.buffer)),Dt.maxSafeId=P.end}let O=Number(Atomics.add(Dt,0,1n)),R=E==="Int"?512:1048576;if(O+R>=Dt.maxSafeId){let b=a(P=>{Dt.maxSafeId=O+(E==="Int"?1023:4194303);let I=(E==="Int"?Math.pow(2,31):Math.pow(2,49))-1,L=P?void 0:i.useReadTransaction(),B=Number(Dt[0]);for(let $ of i.getKeys({start:B+1,end:I,limit:1,transaction:L}))I=$;L?.done();let{value:N,version:U}=i.getEntry(Symbol.for("id_allocation"));if(Dt.maxSafeId<I){if(N.end>Dt.maxSafeId-100)return;xe.default.info?.("New id allocation",O,Dt.maxSafeId,U),i.put(Symbol.for("id_allocation"),{start:N.start,end:Dt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),U)}else{xe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${Dt.maxSafeId}, but id of ${I} detected`);let $=y(U);$.alreadyUpdated||Atomics.store(Dt,0,BigInt($.start+1)),Dt.maxSafeId=$.end}},"updateEnd");O+R===Dt.maxSafeId?setImmediate(b):O+100>=Dt.maxSafeId&&(xe.default.warn?.(`Synchronous id allocation required on table ${s}${E=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>b(!0)))}return O;function y(b){let P=(E==="Int"?Math.pow(2,31):Math.pow(2,49))-1,I=P/4,L,B,N=!1,U,$;do{U=Math.floor(Math.random()*P),$={start:U,end:U+(E==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},L=0;for(let Y of i.getKeys({start:U,limit:1,reverse:!0}))L=Y;B=P;for(let Y of i.getKeys({start:U+1,end:P,limit:1}))B=Y;I*=.875,I<1e3&&!N&&(N=!0,xe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${E==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,U,L,B,I))}while(!(I<B-U&&(I<U-L||L===0)));return i.transactionSync(()=>{let Y=i.getEntry(Symbol.for("id_allocation"));return(Y?.version??null)==b?(xe.default.info?.("Allocated new id range",$),i.put(Symbol.for("id_allocation"),$,Date.now()),$):(xe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...Y.value})})}}static setTTLExpiration(E){if(typeof E=="number")p=E*1e3,S||(S=0);else if(E&&typeof E=="object")p=E.expiration*1e3,S=(E.eviction||0)*1e3,qt=E.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(p<0)throw new Error("Expiration can not be negative");qt=qt||(p+S)/4,da()}static getResidencyRecord(E){return f.get([Symbol.for("residency_by_id"),E])}static setResidency(E){Le.getResidency=E}static setResidencyById(E){Le.getResidencyById=E}static getResidency(E,O,R){if(Le.getResidencyById)return Le.getResidencyById(E[t]);let y=ff;if(O.replicateTo!=null){if(Array.isArray(O.replicateTo))return O.replicateTo.includes(server.hostname)?O.replicateTo:[server.hostname,...O.replicateTo];O.replicateTo>=0&&(y=O.replicateTo)}if(y>=0&&server.nodes){let b=[server.hostname];if(R)b.push(...R.slice(0,y));else{let P=server.nodes.map(B=>B.name),I=Math.floor(P.length*Math.random());b.push(...P.slice(I,I+y));let L=I+y-P.length;L>0&&b.push(...P.slice(0,L))}return b}}static enableAuditing(E=!0){g=E,E&&gf(),Le.audit=E}static coerceId(E){return E===""?null:XT(E,F)}static async dropTable(){delete $e[c][s];for(let E of i.getRange({versions:!0,snapshot:!1,lazy:!0}))E.metadataFlags&ei&&E.value&&po(E.value);if(c===o){for(let E of m)f.remove(Le.tableName+"/"+E.name),r[E.name]?.drop();f.remove(Le.tableName+"/"),i.drop(),await f.committed}else console.log("legacy dropTable"),await i.close(),await JT.default.remove(data_path),await JT.default.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));bp.signalSchemaChange(new Op.SchemaEventMsg(process.pid,Vt.DROP_TABLE,c,s))}get(E){if(typeof E=="string")return this.getProperty(E);if(this.isCollection)return this.search(E);if(this.getId()===null){if(E?.conditions)return this.search(E);let O=Le.getRecordCount();return{recordCount:O.recordCount,estimatedRecordRange:O.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:m}}if(E?.property)return this.getProperty(E.property);if(this.doesExist()||E?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(E,O){let R=Sc(E);if(R?.read){if(R.isSuperUser)return!0;let y=R.attribute_permissions,b=O?.select;if(y?.length>0||df&&b){if(O||(O={}),b){let P=y?.length>0&&pP(y,"read");O.select=b.map(I=>{let L=I.name||I;if(!P||P[L]){let B=pr[L]?.definition?.tableClass;if(B){if(I.name||(I={name:I}),!B.prototype.allowRead.call(null,E,I))return!1;if(!I.select)return I.name}return I}}).filter(Boolean)}else O.select=y.filter(P=>P.read&&!pr[P.attribute_name]).map(P=>P.attribute_name);return O}else return!0}}allowUpdate(E,O){let R=Sc(E);if(R?.update){let y=R.attribute_permissions;if(y?.length>0){let b=pP(y,"update");for(let P in O)if(!b[P])return!1;for(let P of y){let I=P.attribute_name;!P.update&&!(I in O)&&(O[I]=this.getProperty(I))}}return ou(this.getContext())}}allowCreate(E,O){if(this.isCollection){let R=Sc(E);if(R?.insert){let y=R.attribute_permissions;if(y?.length>0){let b=pP(y,"insert");for(let P in O)if(!b[P])return!1;return ou(this.getContext())}else return ou(this.getContext())}}else return this.allowUpdate(E,{})}allowDelete(E){return Sc(E)?.delete&&ou(this.getContext())}update(E,O){if(!mt(this.getContext()))throw new Error("Can not update a table resource outside of a transaction");if(E===!1)return this;let y;return typeof E=="object"&&E&&(O?(Object.isFrozen(E)&&(E={...E}),this.#e={},this.#t=E):(y=this.#t,y&&(E=Object.assign(y,E)),this.#t=E)),this._writeUpdate(this.#t,O),this}addTo(E,O){if(typeof O=="number"||typeof O=="bigint")this.#s===dj?this.set(E,(+this.getProperty(E)||0)+O):(this.#s||this.update(),this.set(E,new Pm(O)));else throw new Error("Can not add a non-numeric value")}subtractFrom(E,O){if(typeof O=="number")return this.addTo(E,-O);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#r}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(E){this.#t=E}setRecord(E){this.#e=E}invalidate(){this._writeInvalidate()}_writeInvalidate(E){let O=this.getContext(),R=this.getId();Pr(R),mt(this.getContext()).addWrite({key:R,store:i,invalidated:!0,entry:this.#r,before:Ie.invalidate?.bind(this,O,R),beforeIntermediate:pe.invalidate?.bind(this,O,R),commit:a((b,P)=>{if(ao(b,P,E?.nodeId)<=0)return;let I=null;for(let L in r)I||(I={}),I[L]=this.getProperty(L);xe.default.trace?.(`Invalidating entry id: ${R}, timestamp: ${new Date(b).toISOString()}`),A(R,I,this.#r,b,Ss,g,{user:O?.user,residencyId:E?.residencyId,nodeId:E?.nodeId},"invalidate")},"commit")})}_writeRelocate(E){let O=this.getContext(),R=this.getId();Pr(R),mt(this.getContext()).addWrite({key:R,store:i,invalidated:!0,entry:this.#r,before:Ie.relocate?.bind(this,O,R),beforeIntermediate:pe.relocate?.bind(this,O,R),commit:a((b,P)=>{if(ao(b,P,E?.nodeId)<=0)return;let I=Le.getResidencyRecord(E.residencyId),L=0,B=null,N=P?.value;if(I&&!I.includes(server.hostname)){for(let U in r)B||(B={}),B[U]=N(U);L=Ss}else B=N;xe.default.trace?.(`Relocating entry id: ${R}, timestamp: ${new Date(b).toISOString()}`),A(R,B,this.#r,b,L,g,{user:O.user,residencyId:E.residencyId,nodeId:E.nodeId,expiresAt:E.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(E,O){let R={previousResidency:this.getResidencyRecord(E.residencyId),isRelocation:!0},y=this.getResidency(O.value,R),b;if(y){if(!Array.isArray(y))throw new Error("Residency must be an array, but was: "+y);if(!y.includes(server.hostname))return;b=fa(y)}let I=A(E.key,O.value,E,E.version,0,!0,{residencyId:b,expiresAt:O.expiresAt},"relocate",!1,null)}static evict(E,O,R){let y=this.Source,b;if(!((M||g)&&(!O||(b=i.getEntry(E),!b||!O)||b.version!==R))){if(M){if(i.hasLock(E,b.version))return;let P;for(let I in r)P||(P={}),P[I]=O[I];if(P)return A(E,P,b,R,Aa,null,null,null,!0)}if(i.ifVersion(E,R,()=>{oo(E,O,null)}),g)return A(E,null,b,R,Aa,null,null,null,!0);Uc(i,b??i.getEntry(E),R)}}lock(){throw new Error("Not yet implemented")}static operation(E,O){return E.table||=s,E.schema||=c,Sj.operation(E,O)}put(E){this.update(E,!0)}patch(E){this.update(E,!1)}_writeUpdate(E,O,R){let y=this.getContext(),b=mt(y),P=this.getId();Pr(P);let I=this.#r;this.#s=O?dj:eAe;let L={key:P,store:i,entry:I,nodeName:y?.nodeName,validate:a(B=>{E||(E=this.#t),O||E&&Im(this.#t===E?this:E)?y?.source||(b.checkOverloaded(),this.validate(E,!O),ee&&(E[ee.name]=ee.type==="Date"?new Date(B):ee.type==="String"?new Date(B).toISOString():B),O&&(t&&E[t]!==P&&(E[t]=P),K&&(I?.value?E[K.name]=I?.value[K.name]:E[K.name]=K.type==="Date"?new Date(B):K.type==="String"?new Date(B).toISOString():B),E=el(E))):b.removeWrite(L)},"validate"),before:O?Ie.put?()=>Ie.put(y,P,E):null:Ie.patch?()=>Ie.patch(y,P,E):Ie.put?()=>Ie.put(y,P,el(this)):null,beforeIntermediate:O?pe.put?()=>pe.put(y,P,E):null:pe.patch?()=>pe.patch(y,P,E):pe.put?()=>pe.put(y,P,el(this)):null,commit:a((B,N,U)=>{if(U){if(y&&N?.version>(y.lastModified||0)&&(y.lastModified=N.version),this.#r=N,N?.value&&N.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");O||(this.#e=N?.value??null)}this.#t=void 0,this.#n=B;let $=N?.value,Y=E;this.#s=0;let ne=ao(B,N,R?.nodeId),k;if(ne<=0)if(g){let Q=N.localTime,fe=N.version;xe.default.trace?.("Applying CRDT update to record with id: ",P,"applying later update:",fe);let Ee=[];for(;Q>B||fe>=B&&Q>0;){let ye=l.get(Q);if(!ye)break;let Me=Nt(ye);if(fe=Me.version,fe>=B){if(fe===B){if(ne=ao(B,{version:fe,localTime:Q},R?.nodeId),ne===0)return;if(ne>0)continue}if(Me.type==="patch")Ee.push(Me),k=E;else if(Me.type==="put"||Me.type==="delete")return}Q=Me.previousLocalTime}Ee.sort((ye,Me)=>ye.version-Me.version);for(let ye of Ee){let Me=ye.getValue(i);if(Y=Nm(Y,Me,O),xe.default.debug?.("Rebuilding update with future patch:",Y),!Y)return}}else{if(O)return;Y=Nm(Y,$,O),xe.default.debug?.("Rebuilding update without audit:",Y)}let ve;if(O?ve=Y:(this.#e=$,ve=el(this,Y)),this.#e=ve,ve&&ve.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let oe;if(R?.residencyId!=null)oe=R.residencyId;else{I?.residencyId&&(y.previousResidency=Le.getResidencyRecord(I.residencyId));let Q=Le.getResidency(ve,y);if(Q){if(!Array.isArray(Q))throw new Error("Residency must be an array, got: "+Q);Q.includes(server.hostname)||Q.push(server.hostname)}oe=fa(Q)}O||(k=E);let le=y?.expiresAt??(p?p+Date.now():-1);xe.default.trace?.(`Saving record with id: ${P}, timestamp: ${new Date(B).toISOString()}${le?", expires at: "+new Date(le).toISOString():""}${N?", replaces entry from: "+new Date(N.version).toISOString():", new entry"}`,ve),oo(P,$,ve);let se=O?"put":"patch";A(P,ve,N,B,0,g,{user:y?.user,residencyId:oe,expiresAt:le,nodeId:R?.nodeId,originatingOperation:y?.originatingOperation},se,!1,k),y.expiresAt&&da()},"commit")};b.addWrite(L)}async delete(E){if(typeof E=="string")return this.deleteProperty(E);if(this.isCollection){for await(let O of this.search(E))(await Le.getResource(O[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(E);return}return this.#e?this._writeDelete(E):!1}_writeDelete(E){let O=mt(this.getContext()),R=this.getId();Pr(R);let y=this.getContext();return O.addWrite({key:R,store:i,entry:this.#r,nodeName:y?.nodeName,before:Ie.delete?.bind(this,y,R),beforeIntermediate:pe.delete?.bind(this,y,R),commit:a((b,P,I)=>{let L=P?.value;I&&(y&&P?.version>(y.lastModified||0)&&(y.lastModified=P.version),Le._updateResource(this,P)),!(ao(b,P,E?.nodeId)<=0)&&(oo(this.getId(),L),xe.default.trace?.(`Deleting record with id: ${R}, txn timestamp: ${new Date(b).toISOString()}`),g||T?(A(R,null,this.#r,b,0,g,{user:y?.user,nodeId:E?.nodeId},"delete"),g||da()):Uc(i,P))},"commit")}),!0}search(E){let O=this.getContext(),R=mt(O);if(!E)throw new Error("No query provided");let y=E.conditions;y?y.length===void 0&&(y=y[Symbol.iterator]?Array.from(y):[y]):y=Array.isArray(E)?E:E[Symbol.iterator]?Array.from(E):[],this.getId()&&(y=[{attribute:null,comparator:Array.isArray(this.getId())?"prefix":"starts_with",value:this.getId()}].concat(y));let b,P={};function I(Q,fe){let Ee;switch(fe){case"and":case void 0:if(Q.length<1)throw new Error('An "and" operator requires at least one condition');Ee=!0;break;case"or":if(Q.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+fe)}for(let ye of Q){if(ye.conditions){ye.conditions=I(ye.conditions,ye.operator);continue}let Me=ye[0]??ye.attribute,et=Me==null?F:Ii(m,Me);if(et)(et.type||QA[ye.comparator])&&(ye[1]===void 0?ye.value=B(ye.value,et):ye[1]=B(ye[1],et));else if(Me!=null)throw(0,Cr.handleHDBError)(new Error,`${Me} is not a defined attribute`,404);if(ye.chainedConditions)if(ye.chainedConditions.length===1&&(!ye.operator||ye.operator=="and")){let $r=ye.chainedConditions[0],Dr,zs;if($r.comparator==="gt"||$r.comparator==="greater_than"||$r.comparator==="ge"||$r.comparator==="greater_than_equal"?(Dr=ye,zs=$r):(Dr=$r,zs=ye),Dr.comparator!=="lt"&&Dr.comparator!=="less_than"&&Dr.comparator!=="le"&&Dr.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let Ae=zs.comparator==="ge"||zs.comparator==="greater_than_equal",bt=Dr.comparator==="le"||Dr.comparator==="less_than_equal";ye.comparator=(Ae?"ge":"gt")+(bt?"le":"lt"),ye.value=[zs.value,Dr.value]}else throw new Error("Multiple chained conditions are not currently supported")}return Q}a(I,"prepareConditions");function L(Q,fe){if(E.enforceExecutionOrder)return Q;for(let Ee of Q)Ee.conditions&&(Ee.conditions=L(Ee.conditions,Ee.operator));return Q.length>1&&fe!=="or"?(0,mj.sortBy)(Q,_E(Le)):Q}a(L,"orderConditions");function B(Q,fe){return Array.isArray(Q)?Q.map(Ee=>XT(Ee,fe)):XT(Q,fe)}a(B,"coerceTypedValues");let N=E.operator;(y.length>0||N)&&(y=I(y,N));let U=typeof E.sort=="object"&&E.sort,$;if(U&&N!=="or"){let Q=U.attribute;if(Q==null)throw new Cr.ClientError("Sort requires an attribute");if(b=y.find(fe=>fu(fe.attribute)===fu(Q)),!b){let fe=Ii(m,Q);if(!fe)throw(0,Cr.handleHDBError)(new Error,`${Array.isArray(Q)?Q.join("."):Q} is not a defined attribute`,404);if(fe.indexed)b={attribute:Q,comparator:"sort"},y.push(b);else if(y.length===0&&!E.allowFullScan)throw(0,Cr.handleHDBError)(new Error,`${Array.isArray(Q)?Q.join("."):Q} is not indexed and not combined with any other conditions`,404)}b&&(b.descending=!!U.descending)}y=L(y,N),U&&(b&&y[0]===b?U.next&&($={dbOrderedAttribute:U.attribute,attribute:U.next.attribute,descending:U.next.descending,next:U.next.next}):(b&&y.splice(y.indexOf(b),1),$=U));let Y=E.select;if(y.length===0&&(y=[{attribute:t,comparator:"greater_than",value:!0}]),E.explain)return{conditions:y,operator:N,postOrdering:$,selectApplied:!!Y};let ne=R.useReadTxn(),k=JA(y,N,Le,ne,E,O,(Q,fe)=>Ef(Q,Y,O,ne,fe),P),ve=E.ensureLoaded!==!1;$||(k=se(k));let oe=Le.transformEntryForSelect(Y,O,ne,P,ve,!0),le=Le.transformToOrderedSelect(k,Y,$,ne,O,oe);function se(Q){return E.offset||E.limit!==void 0?Q.slice(E.offset,E.limit!==void 0?(E.offset||0)+E.limit:void 0):Q}return a(se,"applyOffset"),$&&(le=se(le)),le.onDone=()=>{le.onDone=null,R.doneReadTxn()},le.selectApplied=!0,le.getColumns=()=>{if(Y){let Q=[];for(let fe of Y)fe==="*"?Q.push(...m.map(Ee=>Ee.name)):Q.push(fe.name||fe);return Q}return m.filter(Q=>!Q.computed&&!Q.relationship).map(Q=>Q.name)},le}static transformToOrderedSelect(E,O,R,y,b,P){let I=new RA;if(R){E=Ef(E,O,y,b,null);let L;I.iterate=function(){let N,U=E[Symbol.asyncIterator]?E[Symbol.asyncIterator]():E[Symbol.iterator](),$,Y=R.dbOrderedAttribute,ne,k,ve=!0;function oe(se){let Q=se.next&&oe(se.next),fe=se.descending;return(Ee,ye)=>{let Me=iu(Ee,se.attribute,y),et=iu(ye,se.attribute,y),$r=fe?(0,Xl.compareKeys)(et,Me):(0,Xl.compareKeys)(Me,et);return $r===0?Q?.(Ee,ye)||0:$r}}a(oe,"createComparator");let le=oe(R);return{async next(){let se;if(N)if(se=N.next(),se.done){if($)return I.onDone&&I.onDone(),se}else return{value:await P.call(this,se.value)};L=[],ne&&L.push(ne);do if(se=await U.next(),se.done){if($=!0,L.length)break;return I.onDone&&I.onDone(),se}else{let Q=se.value;if(Q?.then&&(Q=await Q),Y){let fe=iu(Q,Y,y);if(ve)ve=!1,k=fe;else if(fe!==k){k=fe,ne=Q;break}}L.push(Q)}while(!0);return R.isGrouped,L.sort(le),N=L[Symbol.iterator](),se=N.next(),se.done?(I.onDone&&I.onDone(),se):{value:await P.call(this,se.value)}},return(){I.onDone&&I.onDone(),U.return()},throw(){I.onDone&&I.onDone(),U.throw()}}};let B=a(N=>{if(typeof O=="object"&&Array.isArray(N.attribute))for(let U=0;U<O.length;U++){let $=O[U],Y;if($.name===N.attribute[0]){for(Y=$.sort||($.sort={});Y.next;)Y=Y.next;Y.attribute=N.attribute.slice(1),Y.descending=N.descending}else $===N.attribute[0]&&(O[U]=Y={name:$,sort:{attribute:N.attribute.slice(1),descending:N.descending}})}N.next&&B(N.next)},"applySortingOnSelect");B(R)}else I.iterate=(E[Symbol.asyncIterator]||E[Symbol.iterator]).bind(E),I=I.map(function(L){try{let B=P.call(this,L);return typeof B?.catch=="function"?B.catch(N=>{throw N.partialObject={[t]:L.key},N}):B}catch(B){throw B.partialObject={[t]:L.key},B}});return I}static transformEntryForSelect(E,O,R,y,b,P){if(E&&(E===t||E?.length===1&&E[0]===t&&Array.isArray(E))){let N=a(U=>(O?.transaction?.stale&&(O.transaction.stale=!1),U?.key??U),"transform");return E===t?N:E.asArray?U=>[N(U)]:U=>({[t]:N(U)})}let I;b&&M&&!(typeof E=="string"?[E]:E)?.every(N=>{let U;return typeof N=="object"?U=N.name:U=N,r[U]||U===t})&&(I=!0);let L,B=a(function(N){let U;if(O?.transaction?.stale&&(O.transaction.stale=!1),N!=null){if(U=N.value||N.deref?.()?.value,!U&&(N.key===void 0||N.deref)||N.metadataFlags&Ss){if(N.metadataFlags&Ss&&O.replicateFrom===!1&&P&&N.residencyId)return _c.SKIP;if(N=kn(N.key??N,O,{transaction:R,lazy:E?.length<4,ensureLoaded:b},this?.isSync,$=>$),N?.then)return N.then(B.bind(this));U=N?.value}if(I&&N?.metadataFlags&(Ss|Aa)||N?.expiresAt!=null&&N?.expiresAt<Date.now()){if(O.onlyIfCached&&O.noCacheStore)return{[t]:N.key,message:"This entry has expired"};let $=Fp(N.key??N,N,O);if($?.then)return $.then(B)}}if(U==null)return P?_c.SKIP:U;if(E&&!(E[0]==="*"&&E.length===1)){let $,Y=a((k,ve)=>{let oe;typeof k=="object"?oe=k.name:oe=k;let le=pr?.[oe],se;if(le){let Q=y?.[oe];if(Q)if(Q.hasMappings){let Ee=le.from?U[le.from]:fu(N.key);se=Q.get(Ee),se||(se=[])}else se=Q.fromRecord?.(U);else se=le(U,O,N);let fe=a(Ee=>{if(Ee&&typeof Ee=="object"){let ye=le.definition?.tableClass||Le;L||(L={});let Me=L[oe]||(L[oe]=ye.transformEntryForSelect(oe===k?null:k.select||(Array.isArray(k)?k:null),O,R,Q,b));if(Array.isArray(Ee)){let et=[],$r=ye.transformToOrderedSelect(Ee,k.select,typeof k.sort=="object"&&k.sort,O,R,Me)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Dr=a(Ae=>{for(;!Ae.done;){if(Ae?.then)return Ae.then(Dr);et.push(Ae.value),Ae=$r.next()}ve(et,oe)},"nextValue"),zs=Dr($r.next());zs&&($||($=[]),$.push(zs));return}else if(Ee=Me.call(this,Ee),Ee?.then){$||($=[]),$.push(Ee.then(et=>ve(et,oe)));return}}ve(Ee,oe)},"handleResolvedValue");se?.then?($||($=[]),$.push(se.then(fe))):fe(se);return}else se=U[oe],se&&typeof se=="object"&&oe!==k&&(se=Le.transformEntryForSelect(k.select||k,O,R,null)({value:se}));ve(se,oe)},"selectAttribute"),ne;if(typeof E=="string")Y(E,k=>{ne=k});else if(Array.isArray(E))if(E.asArray)ne=[],E.forEach((k,ve)=>{k==="*"?E[ve]=U:Y(k,oe=>ne[ve]=oe)});else{ne={};let k=E.forceNulls;for(let ve of E)if(ve==="*")for(let oe in U)ne[oe]=U[oe];else Y(ve,(oe,le)=>{oe===void 0&&k&&(oe=null),ne[le]=oe})}else throw new Cr.ClientError("Invalid select"+E);return $?Promise.all($).then(()=>ne):ne}return U},"transform");return B}async subscribe(E){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||at({table:s,database:c,schemaDefined:u,attributes:m,audit:!0}),E||(E={});let O=!E.rawEvents,R=[],y=this,b=hP(Le,this.getId()??null,function(I,L,B,N){try{let U=L.getValue?.(i,O),$=L.type;if(!U&&$==="patch"&&O){let ne=i.getEntry(I);ne?.version===L.version?U=ne.value:U=L.getValue?.(i,!0,B),$="put"}let Y={id:I,localTime:B,value:U,version:L.version,type:$,beginTxn:N};R?R.push(Y):this.send(Y)}catch(U){xe.default.error?.(U)}},E.startTime||0,E),P=(async()=>{this.isCollection&&(b.includeDescendants=!0,E.onlyChildren&&(b.onlyChildren=!0)),E.supportsTransactions&&(b.supportsTransactions=!0);let I=this.getId(),L=E.previousCount;L>1e3&&(L=1e3);let B=E.startTime;if(this.isCollection){if(B){if(L)throw new Cr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:N,value:U}of l.getRange({start:B,exclusiveStart:!0,snapshot:!1})){let $=Nt(U);if($.tableId!==n)continue;let Y=$.recordId;if(I==null||pj(I,Y)){let ne=$.getValue(i,O,N);if(b.send({id:Y,localTime:N,value:ne,version:$.version,type:$.type}),b.queue?.length>_j&&await b.waitForDrain()===!1)return}b.startTime=N}}else if(L){let N=[];for(let{key:U,value:$}of l.getRange({start:"z",end:!1,reverse:!0}))try{let Y=Nt($);if(Y.tableId!==n)continue;let ne=Y.recordId;if(I==null||pj(I,ne)){let k=Y.getValue(i,O,U);if(N.push({id:ne,localTime:U,value:k,version:Y.version,type:Y.type}),--L<=0)break}}catch(Y){xe.default.error("Error getting history entry",U,Y)}for(let U=N.length;U>0;)b.send(N[--U]);N[0]&&(b.startTime=N[0].localTime)}else if(!E.omitCurrent){for(let{key:N,value:U,version:$,localTime:Y}of i.getRange({start:I??!1,end:I==null?void 0:[I,Xl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(U&&(b.send({id:N,localTime:Y,value:U,version:$,type:"put"}),b.queue?.length>_j&&await b.waitForDrain()===!1))return}}else{L&&!B&&(B=0);let N=this.#r?.localTime;if(N===MR&&(i.cache?.delete(I),this.#r=i.getEntry(I),xe.default.trace?.("re-retrieved record",N,this.#r?.localTime),N=this.#r?.localTime),xe.default.trace?.("Subscription from",B,"from",I,N),B<N){let U=[],$=N;do{let Y=l.get($);if(Y){E.omitCurrent=!0;let ne=Nt(Y),k=ne.getValue(i,O,$);O&&(ne.type="put"),U.push({id:I,value:k,localTime:$,...ne}),$=ne.previousLocalTime}else break;L&&L--}while($>B&&L!==0);for(let Y=U.length;Y>0;)b.send(U[--Y]);b.startTime=N}!E.omitCurrent&&this.doesExist()&&b.send({id:I,localTime:N,value:this.#e,version:this.#n,type:"put"})}for(let N of R)b.send(N);R=null})();return E.listener&&b.on("data",E.listener),b}static subscribeOnThisThread(E,O){return E===0||O?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(E,O){this._writePublish(E,O)}_writePublish(E,O){let R=mt(this.getContext()),y=this.getId()||null;y!=null&&Pr(y);let b=this.getContext();R.addWrite({key:y,store:i,entry:this.#r,nodeName:b?.nodeName,validate:a(()=>{b?.source||(R.checkOverloaded(),this.validate(E))},"validate"),before:Ie.publish?.bind(this,b,y,E),beforeIntermediate:pe.publish?.bind(this,b,y,E),commit:a((P,I,L)=>{I===void 0&&T&&!g&&da(),xe.default.trace?.(`Publishing message to id: ${y}, timestamp: ${new Date(P).toISOString()}`),A(y,I?.value??null,I,I?.version||P,0,!0,{user:b?.user,residencyId:O?.residencyId,expiresAt:b?.expiresAt,nodeId:O?.nodeId},"message",!1,E)},"commit")})}validate(E,O){let R,y=a((b,P,I)=>{if(P.type&&b!=null)if(O&&b.__op__&&(b=b.value),P.properties){typeof b!="object"&&(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be an object${P.type?" ("+P.type+")":""}`);let L=P.properties;for(let B=0,N=L.length;B<N;B++){let U=L[B],$=y(b[U.name],U,I+"."+U.name);$&&(b[U.name]=$)}if(P.sealed&&b!=null&&typeof b=="object")for(let B in b)L.find(N=>N.name===B)||(R||(R=[])).push(`Property ${B} is not allowed within object in property ${I}`)}else switch(P.type){case"Int":(typeof b!="number"||b>>0!==b)&&(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(L=>typeof L=="string")||(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be a string`);break;case"Boolean":typeof b!="boolean"&&(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be a bigint`)}break;case"Bytes":if(!(b instanceof Uint8Array)){if(typeof b=="string")return Buffer.from(b);(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(b instanceof Pi)){if(typeof b=="string"&&(b=Buffer.from(b)),b instanceof Buffer)return createBlob(b,{type:"text/plain"});(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be a Blob`)}break;case"array":if(Array.isArray(b)){if(P.elements)for(let L=0,B=b.length;L<B;L++){let N=b[L],U=y(N,P.elements,I+"[*]");U&&(b[L]=U)}}else(R||(R=[])).push(`Value ${Vs(b)} in property ${I} must be an Array`);break}P.nullable===!1&&b==null&&(R||(R=[])).push(`Property ${I} is required (and not does not allow null values)`)},"validateValue");for(let b=0,P=m.length;b<P;b++){let I=m[b];if(!(I.relationship||I.computed)&&(!O||I.name in E)){let L=y(E[I.name],I,I.name);L&&(E[I.name]=L)}}if(d)for(let b in E)m.find(P=>P.name===b)||(R||(R=[])).push(`Property ${b} is not allowed`);if(R)throw new Cr.ClientError(R.join(". "))}getUpdatedTime(){return this.#n}wasLoadedFromSource(){return M?!!this.#i:void 0}static async addAttributes(E){let O=m.slice(0);for(let R of E){if(!R.name)throw new Cr.ClientError("Attribute name is required");if(R.name.match(/[`/]/))throw new Cr.ClientError("Attribute names cannot include backticks or forward slashes");(0,gj.validateAttribute)(R.name),O.push(R)}return at({table:s,database:c,schemaDefined:u,attributes:O}),Le.indexingOperation}static async removeAttributes(E){let O=m.filter(R=>!E.includes(R.name));return at({table:s,database:c,schemaDefined:u,attributes:O}),Le.indexingOperation}static getSize(){let E=i.getStats();return(E.treeBranchPageCount+E.treeLeafPageCount+E.overflowPages)*E.pageSize}static getAuditSize(){let E=l?.getStats();return E&&(E.treeBranchPageCount+E.treeLeafPageCount+E.overflowPages)*E.pageSize}static getStorageStats(){let E=i.env.path,O=JT.default.statfsSync(E);return{available:O.bavail*O.bsize,free:O.bfree*O.bsize,size:O.blocks*O.bsize}}static getRecordCount(E){let O=i.getStats().entryCount,R=1e3/2,y=performance.now(),b=Math.floor(O/2),P=E?.exactCount,I=0,L=0,B;for(let{value:N}of i.getRange({start:!0,lazy:!0}))if(N!=null&&I++,L++,!P&&L<b&&performance.now()-y>R){B=L;break}if(B){let N=I;I=0;for(let{value:se}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:B}))se!=null&&I++;let U=B*2,$=(I+N)/U,Y=Math.pow((I-N+1)/B/2,2)+$*(1-$)/U,ne=Math.max(Math.sqrt(Y)*O,1),k=Math.round($*O),ve=Math.max(k-1.96*ne,I+N),oe=Math.min(k+1.96*ne,O),le=Math.pow(10,Math.round(Math.log10(ne)));return le>k&&(le=le/10),I=Math.round(k/le)*le,{recordCount:I,estimatedRange:[Math.round(ve),Math.round(oe)]}}return{recordCount:I}}static updatedAttributes(){pr=this.propertyResolvers={$id:a((E,O,R)=>({value:R.key}),"$id"),$updatedtime:a((E,O,R)=>R.version,"$updatedtime"),$record:a((E,O,R)=>R?{value:E}:E,"$record")};for(let E of this.attributes){E.resolve=null;let O=E.relationship,R=E.computed;if(O)if(E.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),R&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),df=!0,O.to)E.elements?.definition?(pr[E.name]=E.resolve=(y,b,P)=>{let I=y[O.from?O.from:t],L=E.elements.definition.tableClass;return P?du({attribute:O.to,value:I},mt(b).getReadTxn(),!1,L,!1).asArray:L.search([{attribute:O.to,value:I}],b).asArray},E.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},E.resolve.definition=E.elements.definition,O.from&&(E.resolve.from=O.from)):console.error(`The one-to-many/many-to-many relationship property "${E.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(O.from){let y=E.definition||E.elements?.definition;y?(pr[E.name]=E.resolve=(b,P,I)=>{let L=b[O.from];if(L!==void 0){if(E.elements){let B,N=L?.map(U=>{let $=I?y.tableClass.primaryStore.getEntry(U,{transaction:mt(P).getReadTxn()}):y.tableClass.get(U,P);return $?.then&&(B=!0),$});return O.filterMissing?B?Promise.all(N).then(U=>U.filter(Ej)):N.filter(Ej):B?Promise.all(N):N}return I?y.tableClass.primaryStore.getEntry(L,{transaction:mt(P).getReadTxn()}):y.tableClass.get(L,P)}},E.set=(b,P)=>{if(Array.isArray(P)){let I=P.map(L=>L.getId?.()||L[y.tableClass.primaryKey]);b[O.from]=I}else{let I=P.getId?.()||P[y.tableClass.primaryKey];b[O.from]=I}},E.resolve.definition=E.definition||E.elements?.definition,E.resolve.from=O.from):console.error(`The relationship property "${E.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${E.name}" in table "${s}" must use either "from" or "to" arguments`);else R&&(typeof R.from=="function"&&this.setComputedAttribute(E.name,R.from),pr[E.name]=E.resolve=(y,b,P)=>{let I=typeof R.from=="string"?y[R.from]:y,L=this.userResolvers[E.name];if(L)return L(I,b,P);xe.default.warn(`Computed attribute "${E.name}" does not have a function assigned to it. Please use setComputedAttribute('${E.name}', resolver) to assign a resolver function.`),this.userResolvers[E.name]=()=>{}})}Dm(this,this)}static setComputedAttribute(E,O){let R=Ii(m,E);if(!R){console.error(`The attribute "${E}" does not exist in the table "${s}"`);return}if(!R.computed){console.error(`The attribute "${E}" is not defined as computed in the table "${s}"`);return}this.userResolvers[E]=O}static async deleteHistory(E=0,O=!1){let R;for(let{key:y,value:b}of l.getRange({start:0,end:E}))await tf(),Nt(b).tableId===n&&(R=jT(l,y,b));if(O)for(let y of i.getRange({start:0,versions:!0})){let{key:b,value:P,localTime:I}=y;await tf(),P===null&&I<E&&(R=Uc(i,y))}await R}static async*getHistory(E=0,O=1/0){for(let{key:R,value:y}of l.getRange({start:E||1,end:O})){await tf();let b=Nt(y);b.tableId===n&&(yield{id:b.recordId,localTime:R,version:b.version,type:b.type,value:b.getValue(i,!0,R),user:b.user,operation:b.originatingOperation})}}static async getHistoryOfRecord(E){let O=[];if(E==null)throw new Error("An id is required");let R=i.getEntry(E);if(!R)return O;let y=R.localTime;if(!y)throw new Error("The entry does not have a local audit time");let b=0;do{await tf();let P=l.get(y);if(P){let I=Nt(P);O.push({id:I.recordId,localTime:y,version:I.version,type:I.type,value:I.getValue(i,!0,y),user:I.user}),y=I.previousLocalTime}else break}while(b<1e3&&y);return O.reverse()}static cleanup(){X?.remove()}}Le.updatedAttributes();let pf=Le.prototype;return p&&Le.setTTLExpiration(p/1e3),ie&&qp(),Le;function oo(z,E,O){let R;for(let y in r){let b=r[y],P=b.isIndexing,I=pr[y],L=O&&(I?I(O):O[y]),B=E&&(I?I(E):E[y]);if(L===B&&!P)continue;R=!0;let N=b.indexNulls,U=(0,yp.getIndexedValues)(L,N),$=(0,yp.getIndexedValues)(B,N);if($?.length>0){let Y=new Set($);if(U=U?U.filter(ne=>{if(Y.has(ne))Y.delete(ne);else return!0}):[],$=Array.from(Y),($.length>0||U.length>0)&&uj){let ne=$.concat(U).map(k=>({key:k,value:z}));b.prefetch(ne,hj)}for(let ne=0,k=$.length;ne<k;ne++)b.remove($[ne],z)}else U?.length>0&&uj&&b.prefetch(U.map(Y=>({key:Y,value:z})),hj);if(U)for(let Y=0,ne=U.length;Y<ne;Y++)b.put(U[Y],z)}return R}a(oo,"updateIndices");function Pr(z){switch(typeof z){case"number":return!0;case"string":if(z.length<659)return!0;if(z.length>fj)throw new Error("Primary key size is too large: "+z.length);break;case"object":if(z===null)throw new Error("Invalid primary key of null");break;case"bigint":if(z<2n**64n&&z>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof z)}if((0,Xl.writeKey)(z,tAe,0)>fj)throw new Error("Primary key size is too large: "+z.length);return!0}a(Pr,"checkValidId");function kn(z,E,O,R,y){if(Le.getResidencyById&&O.ensureLoaded&&E?.replicateFrom!==!1){let P=Le.getResidencyById(z);if(P&&!P.includes(server.hostname)&&w)return w({key:z,residency:P}).then(y)}let b=a(()=>{if(E?.transaction?.stale&&(E.transaction.stale=!1),O.transaction?.isDone)return y(null,z);let P=i.getEntry(z,O);return P?.residencyId&&P.metadataFlags&Ss&&w&&O.ensureLoaded&&E?.replicateFrom!==!1?w(P).then(I=>y(I,z),I=>(xe.default.error?.("Error loading remote record",z,P,O,I),y(null,z))):(P&&E&&(P?.version>(E.lastModified||0)&&(E.lastModified=P.version),P?.localTime&&!E.lastRefreshed&&(E.lastRefreshed=P.localTime)),y(P,z))},"whenPrefetched");return R?b():he>0?(he--,b()):new Promise((P,I)=>{he===0?(he--,i.prefetch([z],()=>{L(),B()})):(re.push(z),j.push(B),re.length>hf&&(he--,L()));function L(){if(re.length>0){let N=j;i.prefetch(re,()=>{he===-1?L():he++;for(let U of N)U()}),re=[],j=[],Te>2&&Te--}else he=Te,Te<kp&&Te++}a(L,"prefetch");function B(){try{P(b())}catch(N){I(N)}}a(B,"load")})}a(kn,"loadLocalRecord");function Sc(z){if(!z?.role)return;let E=z.role.permission;if(E.super_user)return rAe;let O=E[c],R,y=O?.tables;if(y)return y[s];if(c==="data"&&(R=E[s])&&!R.tables)return R}a(Sc,"getTablePermissions");function Fp(z,E,O,R){if(M){let y=!1;if(O.noCache?y=!0:(E?(!E.value||E.metadataFlags&(Ss|Aa)||E.expiresAt!=null&&E.expiresAt<Date.now())&&(y=!0):y=!0,es(!y,"cache-hit",s)),y){let b=mf(z,E,O).then(P=>(P?.value&&P?.value.getRecord?.()&&xe.default.error?.("Can not assign a record that is already a resource"),O&&(P?.version>(O.lastModified||0)&&(O.lastModified=P.version),O.lastRefreshed=Date.now()),P));if(O?.onlyIfCached||E?.value&&R?.allowStaleWhileRevalidate?.(E,z)){if(b.catch(P=>xe.default.warn?.(P)),O?.onlyIfCached&&!R.doesExist())throw new Cr.ServerError("Entry is not cached",504);return}else return b}}else if(E?.value&&E.expiresAt!=null&&E.expiresAt<Date.now())return Le.evict(E.key,E.value,E.version),E.value=null,{then(y){return y(E)}}}a(Fp,"ensureLoadedFromSource");function mt(z){let E=z?.transaction;if(E){if(!E.lmdbDb)return E.lmdbDb=i,E;do{if(E.lmdbDb?.path===i.path)return E;let O=E.next;if(!O)return E=E.next=new bc,E.lmdbDb=i,E;E=O}while(!0)}else return new uE}a(mt,"txnForContext");function iu(z,E,O){if(!z)return;let R=z.value||i.getEntry(z.key)?.value;if(typeof E=="object"){let b=pr,P=R;for(let I=0,L=E.length;I<L;I++){let B=E[I],N=b?.[B];P=N&&P?N(P,O,!0)?.value:P?.[B],b=N?.definition?.tableClass?.propertyResolvers}return P}let y=pr[E];return y?y(R,O):R[E]}a(iu,"getAttributeValue");function Ef(z,E,O,R,y){let b=y?.length,P={transaction:R,lazy:b>0||typeof E=="string"||E?.length<4,alwaysPrefetch:!0},I;function L(B,N){let U=B?.value;if(!U)return _c.SKIP;for(let $=0;$<b;$++)if(!I?.includes($)&&!y[$](U,B))return _c.SKIP;return N!==void 0&&(B.key=N),B}if(a(L,"processEntry"),b>0||!z.hasEntries){let B=z.map(N=>{if(I=null,typeof N=="object"&&N?.key!==void 0)return b>0?L(N):N;if(N==null)return _c.SKIP;for(let U=0;U<b;U++){let Y=y[U].idFilter;if(Y){if(!Y(N))return _c.SKIP;I||(I=[]),I.push(U)}}return kn(N,O,P,!1,L)});return Array.isArray(z)&&(B=B.filter(N=>N!==_c.SKIP)),B.hasEntries=!0,B}return z}a(Ef,"transformToEntries");function ao(z,E,O=server.replication?.getThisNodeId(l)){if(z<=E?.version){if(E?.version===z&&O!==void 0){let R=server.replication?.exportIdMapping(l),y=E.localTime,b=y&&l.get(y);if(b){let P,I,L=Nt(b);for(let B in R)R[B]===O&&(P=B),R[B]===L.nodeId&&(I=B);if(P>I)return 1;if(P===I)return 0}}return-1}return 1}a(ao,"precedesExistingVersion");async function mf(z,E,O){let R=E?.metadataFlags,y=E?.version,b,P;if(!i.attemptLock(z,y,()=>{clearTimeout(P);let N=i.getEntry(z);!N||!N.value||N.metadataFlags&(Ss|Aa)?b(mf(z,i.getEntry(z),O)):b(N)}))return new Promise(N=>{b=N,P=setTimeout(()=>{i.unlock(z,y)},ZTe)});let I=E?.value,L={requestContext:O,replacingRecord:I,replacingEntry:E,replacingVersion:y,noCacheStore:!1,source:null,resourceCache:O?.resourceCache},B=O?.responseHeaders;return new Promise((N,U)=>{let $;EP(Ot(L,async Y=>{let ne=performance.now(),k,ve,oe;try{for(let fe of Le.sources)if(fe.get&&(!fe.get.reliesOnPrototype||fe.prototype.get)){if(fe.available?.(E)===!1)continue;if(L.source=fe,k=await fe.get(z,L),k)break}oe=R&Ss;let se=L.lastModified||oe&&y;ve=oe||se>y||!I,se||(se=(0,yp.getNextMonotonicTime)());let Q=performance.now()-ne;if(or(Q,"cache-resolution",s,null,"success"),B&&Vm(B,"Server-Timing",`cache-resolve;dur=${Q.toFixed(2)}`,!0),Y.timestamp=se,p&&L.expiresAt==null&&(L.expiresAt=Date.now()+p),k){if(typeof k!="object")throw new Error("Only objects can be cached and stored in tables");if(k.status>0&&k.headers)if(k.status>=300)if(k.status===304)k=I,se=y;else throw new Cr.ServerError(k.body||"Error from source",k.status);else k=k.body;typeof k.toJSON=="function"&&(k=k.toJSON()),t&&k[t]!==z&&(k[t]=z)}$=!0,N({key:z,version:se,value:k})}catch(se){se.message+=` while resolving record ${z} for ${s}`,I&&((se.code==="ECONNRESET"||se.code==="ECONNREFUSED"||se.code==="EAI_AGAIN")&&!O?.mustRevalidate||O?.staleIfError&&(se.statusCode===500||se.statusCode===502||se.statusCode===503||se.statusCode===504))?(N({key:z,version:y,value:I}),xe.default.trace?.(se.message,"(returned stale record)")):U(se);let Q=performance.now()-ne;or(Q,"cache-resolution",s,null,"fail"),B&&Vm(B,"Server-Timing",`cache-resolve;dur=${Q.toFixed(2)}`,!0),L.transaction.abort();return}if(O?.noCacheStore||L.noCacheStore){L.transaction.abort();return}mt(L).addWrite({key:z,store:i,entry:E,nodeName:"source",commit:a((se,Q)=>{if(Q?.version!==y)return;let fe=oo(z,I,k);k?(pe.put?.(L,z,k),xe.default.trace?.(`Writing resolved record from source with id: ${z}, timestamp: ${new Date(se).toISOString()}`),A(z,k,Q,se,0,g&&ve||null,{user:L?.user,expiresAt:L.expiresAt},"put",!!oe)):Q&&(pe.delete?.(L,z),xe.default.trace?.(`Deleting resolved record from source with id: ${z}, timestamp: ${new Date(se).toISOString()}`),g||T?A(z,null,Q,se,0,g&&ve||null,{user:L?.user},"delete",!!oe):Uc(i,Q,y))},"commit")})}),()=>{i.unlock(z,y)},Y=>{i.unlock(z,y),$&&xe.default.error?.("Error committing cache update",Y)})})}a(mf,"getFromSource");function ou(z){if(!z||z.user?.role?.permission?.super_user)return!0;if(z.replicateTo)throw new Cr.ClientError("Can not specify replication parameters without super user permissions",403);if(z.replicatedConfirmation)throw new Cr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(ou,"checkContextPermissions");function da(){if(qt!==Gt&&(Gt=qt,(0,Jl.getWorkerIndex)()===(0,Jl.getWorkerCount)()-1)){if(Zt&&clearTimeout(Zt),!qt)return;let z=new Date;z.setMonth(0),z.setDate(1),z.setHours(0),z.setMinutes(0),z.setSeconds(0);let E=Math.ceil((Date.now()-z.getTime())/qt)*qt+z.getTime(),O=a(R=>{xe.default.trace?.(`Scheduled next cleanup scan at ${new Date(R)}ms`),Zt=setTimeout(()=>G=G.then(async()=>{if(O(Math.max(R+qt,Date.now())),i.rootStore.status!=="open"){clearTimeout(Zt);return}let y=50,b=new Array(y),P=0;xe.default.info?.(`Starting cleanup scan for ${s}`);try{let I=0;for(let L of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:B,value:N,version:U,expiresAt:$}=L,Y;N===null&&!g&&U+XTe<Date.now()?Y=Uc(i,L,U):$!=null&&$+S<Date.now()&&(Y=Le.evict(B,N,U),I++),Y&&(await b[P],b[P]=Y.catch(ne=>{xe.default.error?.("Cleanup error",ne)}),++P>=y&&(P=0)),await tf()}xe.default.info?.(`Finished cleanup scan for ${s}, evicted ${I} entries`)}catch(I){xe.default.warn?.(`Error in cleanup scan for ${s}:`,I)}}),Math.min(R-Date.now(),2147483647)).unref()},"startNextTimer");O(E)}}a(da,"scheduleCleanup");function gf(){X=l?.addDeleteRemovalCallback(n,i,(z,E)=>{i.remove(z,E)})}a(gf,"addDeleteRemoval");function qp(){(0,Jl.getWorkerIndex)()===0&&setInterval(async()=>{if(!gc){gc=!0;try{let z=ie.name,E=r[z];if(!E)throw new Error(`expiresAt attribute ${ie} must be indexed`);for(let O of E.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let R of E.getValues(O)){let y=i.getEntry(R);y?.value?y.value[z]<Date.now()&&Le.evict(R,y.value,y.version):i.ifVersion(R,y?.version,()=>E.remove(O,R))}await tf()}}catch(z){xe.default.error?.("Error in evicting old records",z)}finally{gc=!1}}},JTe).unref()}a(qp,"runRecordExpirationEviction");function fa(z){if(z){let E=z.join(","),O=f.get([Symbol.for("residency_by_set"),E]);return O||(f.put([Symbol.for("residency_by_set"),E],O=Math.floor(Math.random()*2147483647)),f.put([Symbol.for("residency_by_id"),O],z),O)}}a(fa,"getResidencyId")}function pP(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 hj(){}function nAe(e){Sj=e}function XT(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 QT(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return QT(+e);case"Float":return e==="null"?null:QT(+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;sAe.test(e)||(e+="Z");let n=new Date(e);return QT(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,ZT.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function QT(e){if(isNaN(e))throw new SyntaxError;return e}function pj(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 EP(e,t,r){return e?.then?e.then(t,r):t(e)}function Ej(e){return e!=null}function Vs(e){try{return JSON.stringify(e)}catch{return e}}function iAe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var _c,yp,mj,gj,rf,Cr,bp,Op,xe,Xl,Jl,ZT,JT,QTe,Sj,JTe,XTe,uj,ZTe,dj,eAe,Ss,Aa,tAe,fj,_j,rAe,K0e,sAe,tf,Bf=be(()=>{v();_c=require("lmdb"),yp=x(_n()),mj=require("lodash"),gj=x(Df());Ra();dE();rf=x(ce());oN();Cr=x(_e()),bp=x(wo()),Op=x(oi());Ce();xf();xe=x(uo());Ib();Oc();Xl=require("ordered-binary"),Jl=x(nt());So();ZT=x(ae());Tu();$i();wm();G_();JT=x(require("node:fs"));Ts();QTe=new Uint8Array(9);QTe[8]=192;JTe=6e4,XTe=864e5;rf.initSync();uj=rf.get(H.STORAGE_PREFETCHWRITES),ZTe=1e4,dj=1,eAe=2,Ss=1,Aa=8,tAe=Buffer.allocUnsafeSlow(8192),fj=1978,_j=100,rAe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},K0e=(0,ZT.convertToMS)(rf.get(H.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(eA,"makeTable");a(pP,"attributesAsObject");a(hj,"noop");a(nAe,"setServerUtilities");sAe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(XT,"coerceType");a(QT,"rejectNaN");a(pj,"isDescendantId");tf=a(()=>new Promise(setImmediate),"rest");a(EP,"when");a(Ej,"exists");a(Vs,"stringify");a(iAe,"hasOtherProcesses")});var tt={};Be(tt,{database:()=>Uu,database_envs:()=>oa,databases:()=>$e,dropDatabase:()=>Mb,dropTableMeta:()=>uAe,getDatabases:()=>Je,getDefaultCompression:()=>ES,getTables:()=>oAe,onRemovedDB:()=>ch,onUpdatedTable:()=>El,readMetaDb:()=>Np,resetDatabases:()=>Rd,table:()=>at,tables:()=>Zn});function oAe(){return sA||Je(),Zn||{}}function Je(){if(sA)return $e;sA=!0,of=new Map;let e=(0,Jt.getHdbBasePath)()&&(0,Pt.join)((0,Jt.getHdbBasePath)(),yc),t=(0,Jt.get)(H.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Jt.get)(H.STORAGE_PATH)||e&&((0,fs.existsSync)(e)?e:(0,Pt.join)((0,Jt.getHdbBasePath)(),zp)),!e)return;if((0,fs.existsSync)(e))for(let n of(0,fs.readdirSync)(e,{withFileTypes:!0})){let s=(0,Pt.basename)(n.name,".mdb");n.isFile()&&(0,Pt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&Np((0,Pt.join)(e,n.name),null,s)}if((0,fs.existsSync)((0,sf.getBaseSchemaPath)())){for(let n of(0,fs.readdirSync)((0,sf.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Pt.join)((0,sf.getBaseSchemaPath)(),n.name),i=(0,Pt.join)((0,sf.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,fs.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Pt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Pt.join)(i,o.name);Np((0,Pt.join)(s,o.name),(0,Pt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,fs.existsSync)(i))for(let c of(0,fs.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Pt.extname)(c.name).toLowerCase()===".mdb"&&Np((0,Pt.join)(i,c.name),(0,Pt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Pt.join)(l.path,(0,Pt.basename)(c+".mdb"));(0,fs.existsSync)(u)&&Np(u,c,n,null,!0)}}for(let n in $e){let s=of.get(n);if(s){let i=$e[n];n.includes("delete")&&kt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(kt.trace(`delete table class ${o}`),delete i[o])}else if(delete $e[n],n==="data"){for(let i in Zn)delete Zn[i];delete Zn[iA]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if($e.system)for(let n of r)$e.system[n]&&($e.system[n].replicate=!1);return of=null,$e}function Rd(){sA=!1;for(let[,e]of oa)e.needsDeletion=!0;Je();for(let[e,t]of oa)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),oa.delete(e),delete $e[t.databaseName],Ip.forEach(r=>r(t.databaseName)));return $e}function Np(e,t,r=SP,n,s){let i=new mP.default(e,!1);try{let o=oa.get(e);o?o.needsDeletion=!1:(o=(0,af.open)(i),oa.set(e,o));let c=new Zl.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(tA.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,fs.existsSync)(n)&&(i.path=n,u=(0,af.open)(i),u.isLegacy=!0):u=zT(o));let f=yj(r),d=f[iA],h=new Map;for(let{key:_,value:p}of l.getRange({start:!1})){let[S,g]=_.toString().split("/");g===""?g=p.name:g||(g=S,S=t,p.name||(p.name=g,p.indexed=!p.is_hash_attribute)),d?.add(S);let T=h.get(S);T||h.set(S,T={attributes:[]}),(g==null||p.is_hash_attribute)&&(T.primary=p),g!=null&&T.attributes.push(p),Object.defineProperty(p,"key",{value:_,configurable:!0})}for(let[_,p]of h){let{attributes:S,primary:g}=p;if(!g){for(let j of S)if(j.is_hash_attribute||j.isPrimaryKey){g=j;break}if(!g){kt.warn(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(S)}`);continue}}let T=f[_],m={},A=[],w,M,F=typeof g.audit=="boolean"?g.audit:(0,Jt.get)(H.LOGGING_AUDITLOG),G=g.trackDeletes,K=g.expiration,ee=g.eviction,ie=g.sealed,X=g.splitSegments,re=g.replicate;if(T)m=T.indices,A=T.attributes,T.schemaVersion++;else{w=g.tableId,w?w>=(l.get(nf)||0)&&(l.putSync(nf,w+1),kt.info(`Updating next table id (it was out of sync) to ${w+1} for ${_}`)):(g.tableId=w=l.get(nf),w||(w=1),kt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(nf,w+1),l.putSync(g.key,g));let j=new Zl.default(!g.is_hash_attribute,g.is_hash_attribute);if(j.compression=g.compression,j.compression){let he=(0,Jt.get)(H.STORAGE_COMPRESSION_THRESHOLD)||Rj;j.compression.threshold=he}M=FE(o.openDB(g.key,j),o),o.databaseName=r,M.tableId=w}for(let j of S){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!m[j.name]){let Te=new Zl.default(!j.is_hash_attribute,j.is_hash_attribute);m[j.name]=o.openDB(j.key,Te),m[j.name].indexNulls=j.indexNulls}let he=A.find(Te=>Te.name===j.name);he?A.splice(A.indexOf(he),1,j):A.push(j)}}catch(he){kt.error("Error trying to update attribute",j,A,m,he)}}if(!T){T=bj(f,_,eA({primaryStore:M,auditStore:u,audit:F,sealed:ie,splitSegments:X,replicate:re,expirationMS:K&&K*1e3,evictionMS:ee&&ee*1e3,trackDeletes:G,tableName:_,tableId:w,primaryKey:g.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:m,attributes:S,schemaDefined:g.schemaDefined,dbisDB:l})),T.schemaVersion=1;for(let j of wp)j(T)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function yj(e){let t=$e[e];if(t||(e==="data"?t=$e[e]=Zn:e==="system"?Object.defineProperty($e,"system",{value:t=Object.create(null),configurable:!0}):t=$e[e]=Object.create(null)),of&&!of.has(e)){let r=new Set;t[iA]=r,of.set(e,r)}return t}function bj(e,t,r){return e[t]=r,r}function Uu({database:e,table:t}){e||(e=SP),Je();let r=yj(e),n=(0,Pt.join)((0,Jt.getHdbBasePath)(),yc),s=(0,Jt.get)(H.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Jt.get)(H.STORAGE_PATH)||((0,fs.existsSync)(n)?n:(0,Pt.join)((0,Jt.getHdbBasePath)(),zp));let o=(0,Pt.join)(n,(i?t:e)+".mdb"),c=oa.get(o);if(!c||c.status==="closed"){let l=new mP.default(o,!1);c=(0,af.open)(l),oa.set(o,c)}return c.auditStore||(c.auditStore=zT(c)),c}async function Mb(e){if(!$e[e])throw new Error("Schema does not exist");let t=$e[e],r;for(let n in t)r=t[n].primaryStore.rootStore,oa.delete(r.path),r.status==="open"&&(await r.close(),await Cp.remove(r.path));if(r||(r=Uu({database:e,table:null}),r.status==="open"&&(await r.close(),await Cp.remove(r.path))),e==="data"){for(let n in Zn)delete Zn[n];delete Zn[iA]}delete $e[e],Ip.forEach(n=>n(e)),await uR(r)}function at(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,schemaDefined:h,origin:_}=e;r||(r=SP);let p=Uu({database:r,table:t}),S=$e[r];kt.trace(`Defining ${t} in ${r}`);let g=S?.[t];if(p.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let T,m,A;h==null&&(h=!0);let w=new Zl.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 M,F;if(g){if(T=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...o)}else{let X=p.auditStore;m=o.find(Te=>Te.isPrimaryKey)||{},T=m.name,m.is_hash_attribute=m.isPrimaryKey=!0,m.schemaDefined=h,m.compression=ES(),d&&(m.trackDeletes=!0),c=m.audit=typeof c=="boolean"?c:(0,Jt.get)(H.LOGGING_AUDITLOG),n&&(m.expiration=n),s&&(m.eviction=s),m.splitSegments=!1,typeof l=="boolean"&&(m.sealed=l),typeof f=="boolean"&&(m.replicate=f),_&&(m.origins?m.origins.includes(_)||m.origins.push(_):m.origins=[_]),kt.trace(`${t} table loading, opening primary store`);let re=new Zl.default(!1,!0);re.compression=m.compression;let j=t+"/";if(A=p.dbisDb=p.openDB(tA.INTERNAL_DBIS_NAME,w),ie(),A.get(j))return F&&F(),Rd(),at(e);let he=FE(p.openDB(j,re),p);p.databaseName=r,he.tableId=A.get(nf),kt.trace(`Assigning new table id ${he.tableId} for ${t}`),he.tableId||(he.tableId=1),A.put(nf,he.tableId+1),m.tableId=he.tableId,g=bj(S,t,eA({primaryStore:he,auditStore:X,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:T,tableName:t,tableId:he.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:h,dbisDB:A})),g.schemaVersion=1,M=!0,A.put(j,m)}let G=g.indices;A=A||(p.dbisDb=p.openDB(tA.INTERNAL_DBIS_NAME,w)),g.dbisDB=A;let K=[];for(let{key:X,value:re}of A.getRange({start:!0})){let[j,he]=X.toString().split("/");if(he===""&&(he=re.name),he){if(j!==t)continue}else continue;let Te=o.find(pe=>pe.name===he),Ie=!Te?.indexed&&re.indexed&&!re.isPrimaryKey;if((!Te||Ie)&&(ie(),M=!0,Te||A.remove(X),Ie)){let pe=g.indices[j];pe&&K.push(pe)}}let ee=[];try{for(let X of o||[]){if((X.relationship||X.computed)&&(M=!0,X.relationship))continue;let re=t+"/"+(X.name||"");Object.defineProperty(X,"key",{value:re,configurable:!0});let j=A.get(re);if(X.isPrimaryKey){if(j=j||A.get(re=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||f!==void 0&&f!==g.replicate||(+n||void 0)!==(+j.expiration||void 0)||(+s||void 0)!==(+j.eviction||void 0)){let Te={...j};typeof c=="boolean"&&(c&&g.enableAuditing(c),Te.audit=c),n&&(Te.expiration=+n),s&&(Te.eviction=+s),l!==void 0&&(Te.sealed=l),f!==void 0&&(Te.replicate=f),M=!0,ie(),A.put(re,Te)}continue}j?.attribute&&!j.name&&(j.indexed=!0);let he=!j||j.type!==X.type||j.indexed!==X.indexed||j.nullable!==X.nullable||j.version!==X.version||JSON.stringify(j.properties)!==JSON.stringify(X.properties)||JSON.stringify(j.elements)!==JSON.stringify(X.elements);if(X.indexed){let Te=new Zl.default(!0,!1),Ie=p.openDB(re,Te);(he||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<Pp.workerData?.restartNumber)&&(M=!0,ie(),j=A.get(re),(he||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<Pp.workerData?.restartNumber)&&(M=!0,X.indexNulls===void 0&&(X.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(X.lastIndexedKey=j?.lastIndexedKey??void 0,X.indexingPID=process.pid,Ie.isIndexing=!0,Object.defineProperty(X,"dbi",{value:Ie}),ee.push(X))),A.put(re,X)),j?.indexNulls&&X.indexNulls===void 0&&(X.indexNulls=!0),Ie.indexNulls=X.indexNulls,G[X.name]=Ie}else he&&(M=!0,ie(),A.put(re,X))}}finally{F&&F()}if(M&&(g.schemaVersion++,g.updatedAttributes()),kt.trace(`${t} table loading, running index`),ee.length>0||K.length>0?g.indexingOperation=lAe(g,ee,K):M&&rA.signalSchemaChange(new nA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,M)for(let X of wp)X(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),kt.trace(`${t} table loaded`),g;function ie(){F||p.transactionSync(()=>({then(X){F=X}}))}a(ie,"startTxn")}async function lAe(e,t,r){try{kt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await rA.signalSchemaChange(new nA.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let d of t)(0,af.compareKeys)(d.lastIndexedKey,u)<0&&(u=d.lastIndexedKey),d.lastIndexedKey==null&&d.dbi.clearAsync();let f=0;for(let{key:d,value:h,version:_}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(h){if(f++,s=e.primaryStore.ifVersion(d,_,()=>{for(let p=0;p<l;p++){let S=t[p],g=S.name;try{let T=S.resolve,m=h&&(T?T(h):h[g]),A=(0,Tj.getIndexedValues)(m);if(A)for(let w=0,M=A.length;w<M;w++)S.dbi.put(A[w],d)}catch(T){o[g]||(o[g]=!0,kt.error(`Error indexing attribute ${g}`,T))}}}),s.then(()=>f--,p=>{f--,kt.error(p)}),Pp.workerData&&Pp.workerData.restartNumber!==Aj.restartNumber&&(i=!0),++c%100===0||i){for(let p of t)p.lastIndexedKey=d,e.dbisDB.put(p.key,p);if(i)return}f>aAe?await s:f>cAe&&await new Promise(p=>setImmediate(p))}for(let d of t)delete d.lastIndexedKey,delete d.indexingPID,d.dbi.isIndexing=!1,s=e.dbisDB.put(d.key,d)}await s,await rA.signalSchemaChange(new nA.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),kt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){kt.error("Error in indexing",n)}}function uAe({table:e,database:t}){let r=Uu({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 El(e){return wp.push(e),{remove(){let t=wp.indexOf(e);t>-1&&wp.splice(t,1)}}}function ch(e){return Ip.push(e),{remove(){let t=Ip.indexOf(e);t>-1&&Ip.splice(t,1)}}}function ES(){let e=(0,Jt.get)(H.STORAGE_COMPRESSION),t=(0,Jt.get)(H.STORAGE_COMPRESSION_DICTIONARY),r=(0,Jt.get)(H.STORAGE_COMPRESSION_THRESHOLD)||Rj,n={startingOffset:32};return t&&(n.dictionary=Cp.readFileSync(t)),r&&(n.threshold=r),e&&n}var Jt,tA,af,Pt,fs,sf,Zl,mP,Cp,gP,Tj,rA,nA,Pp,kt,Aj,SP,iA,Rj,Zn,$e,nf,wp,Ip,sA,oa,of,aAe,cAe,Ce=be(()=>{Jt=x(ce()),tA=x(Mt()),af=require("lmdb"),Pt=require("path"),fs=require("fs"),sf=x(ht());Bf();Zl=x(Jf()),mP=x(Xf());v();Cp=x(require("fs-extra")),gP=x(bi()),Tj=x(_n()),rA=x(wo()),nA=x(oi()),Pp=require("worker_threads"),kt=x(W()),Aj=x(nt());So();Tu();Ts();SP="data",iA=Symbol("defined-tables"),Rj=((0,Jt.get)(H.STORAGE_PAGESIZE)||4096)-60;(0,Jt.initSync)();Zn=Object.create(null),$e=Object.create(null);(0,gP._assignPackageExport)("databases",$e);(0,gP._assignPackageExport)("tables",Zn);nf=Symbol.for("next-table-id"),wp=[],Ip=[],oa=new Map;a(oAe,"getTables");a(Je,"getDatabases");a(Rd,"resetDatabases");a(Np,"readMetaDb");a(yj,"ensureDB");a(bj,"setTable");a(Uu,"database");a(Mb,"dropDatabase");a(at,"table");aAe=1e3,cAe=10;a(lAe,"runIndexing");a(uAe,"dropTableMeta");a(El,"onUpdatedTable");a(ch,"onRemovedDB");a(ES,"getDefaultCompression")});var ae=C((rxe,Hj)=>{"use strict";var hc=require("path"),Cj=require("fs-extra"),Bn=W(),Oj=require("fs-extra"),oA=require("os"),dAe=require("net"),fAe=require("recursive-iterator"),Or=(v(),D(q)),{PACKAGE_ROOT:_Ae}=rt(),hAe=qA(),Nj=require("papaparse"),aA=require("moment"),{inspect:pAe}=require("util"),wj=require("is-number"),txe=require("lodash"),EAe=require("minimist"),mAe=require("https"),gAe=require("http"),{hdb_errors:cA}=_e(),SAe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,Pj=require("util").promisify(setTimeout),TAe=100,AAe=5,RAe="",yAe=4,Ij={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};Hj.exports={isEmpty:_s,isEmptyOrZeroLength:so,arrayHasEmptyValues:NAe,arrayHasEmptyOrZeroLengthValues:wAe,buildFolderPath:IAe,isBoolean:Dj,errorizeMessage:bAe,stripFileExtension:PAe,autoCast:DAe,autoCastJSON:Lj,autoCastJSONDeep:AP,removeDir:LAe,compareVersions:MAe,isCompatibleDataVersion:vAe,escapeRawValue:UAe,unescapeValue:xAe,stringifyProps:BAe,timeoutPromise:kAe,isClusterOperation:qAe,getClusterUser:$Ae,checkGlobalSchemaTable:GAe,getHomeDir:vj,getPropsFilePath:HAe,promisifyPapaParse:VAe,removeBOM:Uj,createEventPromise:KAe,checkProcessRunning:YAe,checkSchemaTableExist:WAe,checkSchemaExists:xj,checkTableExists:Bj,getStartOfTomorrowInSeconds:zAe,getLimitKey:jAe,isObject:CAe,isNotEmptyAndHasValue:OAe,autoCasterIsNumberCheck:Mj,backtickASTSchemaItems:QAe,isPortTaken:FAe,createForkArgs:JAe,autoCastBoolean:XAe,async_set_timeout:Pj,getTableHashAttribute:ZAe,doesSchemaExist:eRe,doesTableExist:tRe,stringifyObj:rRe,ms_to_time:nRe,changeExtension:sRe,getEnvCliRootPath:RP,noBootFile:iRe,httpRequest:oRe,transformReq:aRe,convertToMS:cRe,PACKAGE_ROOT:_Ae};function bAe(e){return e instanceof Error?e:new Error(e)}a(bAe,"errorizeMessage");function _s(e){return e==null}a(_s,"isEmpty");function OAe(e){return!_s(e)&&(e||e===0||e===""||Dj(e))}a(OAe,"isNotEmptyAndHasValue");function so(e){return _s(e)||e.length===0||e.size===0}a(so,"isEmptyOrZeroLength");function NAe(e){if(_s(e))return!0;for(let t=0;t<e.length;t++)if(_s(e[t]))return!0;return!1}a(NAe,"arrayHasEmptyValues");function wAe(e){if(so(e))return!0;for(let t=0;t<e.length;t++)if(so(e[t]))return!0;return!1}a(wAe,"arrayHasEmptyOrZeroLengthValues");function IAe(...e){try{return e.join(hc.sep)}catch{console.error(e)}}a(IAe,"buildFolderPath");function Dj(e){return _s(e)?!1:e===!0||e===!1}a(Dj,"isBoolean");function CAe(e){return _s(e)?!1:typeof e=="object"}a(CAe,"isObject");function PAe(e){return so(e)?RAe:e.slice(0,-yAe)}a(PAe,"stripFileExtension");function DAe(e){return _s(e)||e===""||typeof e!="string"?e:Ij[e]!==void 0?Ij[e]:Mj(e)===!0?Number(e):SAe.test(e)?new Date(e):e}a(DAe,"autoCast");function Lj(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(Lj,"autoCastJSON");function AP(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=AP(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=AP(r);n!==r&&(e[t]=n)}return e}else return Lj(e)}a(AP,"autoCastJSONDeep");function Mj(e){if(e.startsWith("0.")&&wj(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&wj(e))}a(Mj,"autoCasterIsNumberCheck");async function LAe(e){if(so(e))throw new Error(`Directory path: ${e} does not exist`);try{await Oj.emptyDir(e),await Oj.remove(e)}catch(t){throw Bn.error(`Error removing files in ${e} -- ${t}`),t}}a(LAe,"removeDir");function MAe(e,t){if(so(e)){Bn.info("Invalid current version sent as parameter.");return}if(so(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 u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(MAe,"compareVersions");function vAe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(vAe,"isCompatibleDataVersion");function UAe(e){if(_s(e))return e;let t=String(e);return t==="."?Or.UNICODE_PERIOD:t===".."?Or.UNICODE_PERIOD+Or.UNICODE_PERIOD:t.replace(Or.FORWARD_SLASH_REGEX,Or.UNICODE_FORWARD_SLASH)}a(UAe,"escapeRawValue");function xAe(e){if(_s(e))return e;let t=String(e);return t===Or.UNICODE_PERIOD?".":t===Or.UNICODE_PERIOD+Or.UNICODE_PERIOD?"..":String(e).replace(Or.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(xAe,"unescapeValue");function BAe(e,t){if(_s(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+oA.EOL}!so(n)&&n[0]===";"?r+=" "+n+s+oA.EOL:so(n)||(r+=n+"="+s+oA.EOL)}catch{Bn.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(BAe,"stringifyProps");function vj(){let e;try{e=oA.homedir()}catch{e=process.env.HOME}return e}a(vj,"getHomeDir");function HAe(){let e=hc.join(vj(),Or.HDB_HOME_DIR_NAME,Or.BOOT_PROPS_FILE_NAME);return Cj.existsSync(e)||(e=hc.join(__dirname,"../","hdb_boot_properties.file")),e}a(HAe,"getPropsFilePath");function kAe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(kAe,"timeoutPromise");async function FAe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=dAe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(FAe,"isPortTaken");function qAe(e){try{return Or.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Bn.error(`Error checking operation against cluster ops ${t}`)}return!1}a(qAe,"isClusterOperation");function GAe(e,t){let r=(Ce(),D(tt)).getDatabases();if(!r[e])return cA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return cA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(GAe,"checkGlobalSchemaTable");function $Ae(e,t){if(_s(t)){Bn.warn("No CLUSTERING_USER defined, clustering disabled");return}if(_s(e)||so(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($Ae,"getClusterUser");function VAe(){Nj.parsePromise=function(e,t,r){return new Promise(function(n,s){Nj.parse(e,{header:!0,transformHeader:Uj,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(VAe,"promisifyPapaParse");function Uj(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(Uj,"removeBOM");function KAe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Bn.info(`Got cluster status event response: ${pAe(s)}`);try{i.cancel()}catch{Bn.error("Error trying to cancel timeout.")}n(s)})})}a(KAe,"createEventPromise");async function YAe(e){let t=!0,r=0;do await Pj(TAe*r++),(await hAe.findPs(e)).length>0&&(t=!1);while(t&&r<AAe);if(t)throw new Error(`process ${e} was not started`)}a(YAe,"checkProcessRunning");function WAe(e,t){let r=xj(e);if(r)return r;let n=Bj(e,t);if(n)return n}a(WAe,"checkSchemaTableExist");function xj(e){let{getDatabases:t}=(Ce(),D(tt));if(!t()[e])return cA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(xj,"checkSchemaExists");function Bj(e,t){let{getDatabases:r}=(Ce(),D(tt));if(!r()[e][t])return cA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Bj,"checkTableExists");function zAe(){let e=aA().utc().add(1,"d").startOf("d").unix(),t=aA().utc().unix();return e-t}a(zAe,"getStartOfTomorrowInSeconds");function jAe(){return aA().utc().format("DD-MM-YYYY")}a(jAe,"getLimitKey");function QAe(e){try{let t=new fAe(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(QAe,"backtickASTSchemaItems");function JAe(e){return[e]}a(JAe,"createForkArgs");function XAe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(XAe,"autoCastBoolean");function ZAe(e,t){let{getDatabases:r}=(Ce(),D(tt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(ZAe,"getTableHashAttribute");function eRe(e){let{getDatabases:t}=(Ce(),D(tt));return t()[e]!==void 0}a(eRe,"doesSchemaExist");function tRe(e,t){let{getDatabases:r}=(Ce(),D(tt));return r()[e]?.[t]!==void 0}a(tRe,"doesTableExist");function rRe(e){try{return JSON.stringify(e)}catch{return e}}a(rRe,"stringifyObj");function nRe(e){let t=aA.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(nRe,"ms_to_time");function sRe(e,t){let r=hc.basename(e,hc.extname(e));return hc.join(hc.dirname(e),r+t)}a(sRe,"changeExtension");function RP(){if(process.env[Or.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Or.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=EAe(process.argv);if(e[Or.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Or.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(RP,"getEnvCliRootPath");var TP;function iRe(){if(TP)return TP;let e=RP();if(RP()&&Cj.pathExistsSync(hc.join(e,Or.HDB_CONFIG_FILE)))return TP=!0,!0}a(iRe,"noBootFile");function oRe(e,t){let r;return e.protocol==="http:"?r=gAe:r=mAe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(oRe,"httpRequest");function aRe(e){if(!e.schema&&!e.database){e.schema=Or.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(aRe,"transformReq");function cRe(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(cRe,"convertToMS")});var ce=C(($j,Vj)=>{"use strict";var yP=require("fs-extra"),eu=require("path"),kj=require("os"),lRe=require("properties-reader"),Lp=W(),Dp=ae(),De=(v(),D(q)),lA=At(),uRe="Error initializing environment manager",uA="BOOT_PROPS_FILE_PATH",Fj=!1,dRe={[De.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},aa={};Object.assign($j,Vj.exports={BOOT_PROPS_FILE_PATH:uA,getHdbBasePath:fRe,setHdbBasePath:_Re,get:qj,initSync:pRe,setProperty:Ye,initTestEnvironment:mRe,setCloneVar:ERe});function fRe(){return aa[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(fRe,"getHdbBasePath");function _Re(e){aa[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(_Re,"setHdbBasePath");function qj(e){let t=lA.getConfigValue(e);return t===void 0?aa[e]:t}a(qj,"get");function Ye(e,t){dRe[e]&&(aa[e]=t),lA.updateConfigObject(e,t)}a(Ye,"setProperty");function hRe(){let e;try{e=Dp.getPropsFilePath(),yP.accessSync(e,yP.constants.F_OK|yP.constants.R_OK),Fj=!0;let t=lRe(e);return aa[De.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(De.HDB_SETTINGS_NAMES.INSTALL_USER),aa[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),aa[uA]=e,!0}catch{return Lp.trace(`Environment manager found no properties file at ${e}`),!1}}a(hRe,"doesPropFileExist");function pRe(e=!1){try{((Fj||hRe()||Dp.noBootFile())&&!Gj||e)&&(lA.initConfig(e),aa[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=lA.getConfigValue(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Lp.error(uRe),Lp.error(t),console.error(t),process.exit(1)}}a(pRe,"initSync");var Gj=!1;function ERe(e){Gj=e}a(ERe,"setCloneVar");function mRe(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=eu.join(__dirname,"../../","unitTests");aa[uA]=eu.join(l,"hdb_boot_properties.file"),Ye(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,eu.join(l,"settings.test")),Ye(De.HDB_SETTINGS_NAMES.INSTALL_USER,kj.userInfo()?kj.userInfo().username:void 0),Ye(De.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ye(De.HDB_SETTINGS_NAMES.LOG_PATH_KEY,eu.join(l,"envDir","log")),Ye(De.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ye(De.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ye(De.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ye(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,eu.join(l,"envDir")),Ye(De.CONFIG_PARAMS.STORAGE_PATH,eu.join(l,"envDir")),s&&(Ye(De.CONFIG_PARAMS.HTTP_SECUREPORT,qj(De.CONFIG_PARAMS.HTTP_PORT)),Ye(De.CONFIG_PARAMS.HTTP_PORT,null)),Ye(De.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ye(De.CONFIG_PARAMS.HTTP_PORT,9926),Ye(De.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ye(De.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Ye(De.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Dp.isEmpty(i)?!1:i),Ye(De.CONFIG_PARAMS.HTTP_CORS,Dp.isEmpty(i)?!1:i),Ye(De.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ye(De.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ye(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ye(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ye(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,eu.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ye(De.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Dp.isEmpty(c)?!1:c),o&&(Ye("CORS_ACCESSLIST",o),Ye(De.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ye(De.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ye(De.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ye(De.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ye(De.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ye(De.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ye(De.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${uA}. Please check your boot props and settings files`;Lp.fatal(r),Lp.error(t)}}a(mRe,"initTestEnvironment")});var jj=C((ixe,zj)=>{"use strict";var fA=ce();fA.initSync();var dA=(v(),D(q)),{httpRequest:gRe}=ae(),Wj=require("path"),Kj=require("fs-extra"),SRe=require("yaml"),{packageDirectory:TRe}=(Cw(),D(Iw)),{encode:ARe}=require("cbor-x"),RRe=["describe_table","describe_all","describe_database","list_users","list_roles","drop_role","add_user","alter_user","drop_user","restart_service","restart","create_database","drop_database","create_table","drop_table","create_attribute","drop_attribute","search_by_id","insert","update","upsert","delete","search_by_value","csv_file_load","csv_url_load","cluster_get_routes","cluster_network","cluster_status","remove_node","add_component","deploy_component","package_component","drop_component","get_components","get_component_file","set_component_file","registration_info","get_fingerprint","set_license","get_job","search_jobs_by_start_date","read_log","read_transaction_log","read_audit_log","delete_transaction_logs_before","purge_stream","delete_records_before","install_node_modules","set_configuration","get_configuration","create_authentication_tokens","refresh_operation_token","system_information","sql","create_csr","sign_certificate","list_certificates","add_certificate","remove_certificate","add_ssh_key","update_ssh_key","delete_ssh_key","list_ssh_keys","set_ssh_known_hosts","get_ssh_known_hosts"],Yj={deploy:"deploy_component",package:"package_component"};zj.exports={cliOperations:ORe,buildRequest:bRe};var yRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await TRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=Wj.basename(t))},"deploy_component")};function bRe(){let e={};for(let t of process.argv.slice(2))if(RRe.includes(t))e.operation=t;else if(Yj.hasOwnProperty(t))e.operation=Yj[t];else if(t.includes("=")){let[r,...n]=t.split("=");n=n.join("=");try{n=JSON.parse(n)}catch{}e[r]=n}return e}a(bRe,"buildRequest");async function ORe(e){e.target||(e.target=process.env.CLI_TARGET);let t;if(e.target){try{t=new URL(e.target)}catch(r){try{t=new URL(`https://${e.target}:9925`)}catch{throw r}}t={protocol:t.protocol,hostname:t.hostname,port:t.port,username:e.username||t.username||process.env.CLI_TARGET_USERNAME,password:e.password||t.password||process.env.CLI_TARGET_PASSWORD,rejectUnauthorized:e.rejectUnauthorized}}else Kj.existsSync(Wj.join(fA.get(dA.CONFIG_PARAMS.ROOTPATH),dA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),Kj.existsSync(fA.get(dA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await yRe[e.operation]?.(e);try{let r=t??{protocol:"http:",socketPath:fA.get(dA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)};r.method="POST",r.headers={"Content-Type":"application/json"},t?.username&&(r.headers.Authorization=`Basic ${Buffer.from(`${t.username}:${t.password}`).toString("base64")}`),e.cborEncode&&(r.headers["Content-Type"]="application/cbor",e=ARe(e));let n=await gRe(r,e),s;try{s=JSON.parse(n.body)}catch{s={status:n.statusCode+" "+(n.statusMessage||"Unknown"),body:n.body}}e.json?console.log(JSON.stringify(s,null,2)):console.log(SRe.stringify(s).trim())}catch(r){let n="Error: ";if(r?.response?.data?.error)n+=r.response.data.error;else if(r?.response?.data)n+=r?.response?.data;else return console.error(r);console.error(n)}}a(ORe,"cliOperations")});var Xj=C((axe,Jj)=>{"use strict";var Qj=require("semver/functions/major"),{packageJson:NRe}=rt(),bP=process.versions&&process.versions.node?process.versions.node:void 0;Jj.exports=wRe;function wRe(){let e=NRe.engines["minimum-node"];if(bP&&Qj(bP)<Qj(e))return{error:`The minimum version of Node.js HarperDB supports is: ${e}, the currently installed Node.js version is: ${bP}. Please install a version of Node.js that is withing the defined range.`}}a(wRe,"checkNodeVersion")});var DP=C((uxe,TQ)=>{"use strict";var Zj=require("os"),_A=require("https"),eQ=require("http"),Xt=require("fs-extra"),tQ=require("yaml"),{pipeline:rQ}=require("stream/promises"),{createWriteStream:hA,ensureDir:Mp,writeFileSync:nQ}=require("fs-extra"),{join:Ri}=require("path"),aQ=require("lodash"),IRe=require("minimist"),ca=require("path"),CRe=require("node:crypto"),PRe=require("properties-reader"),Ys=ce(),DRe=Uo(),IP=W(),pA=At(),{restart:LRe}=Ja(),EA=ae(),MRe=pa(),vRe=ys(),{main:mA,launch:URe}=Gd(),{install:cQ,updateConfigEnv:xRe,setIgnoreExisting:gA}=ET(),lQ=nC(),ln=(v(),D(q)),{packageJson:BRe}=rt(),HRe=op(),{sendOperationToNode:wP}=(ts(),D(vo)),{updateConfigCert:kRe}=rs(),{restartWorkers:FRe}=nt(),{databases:qRe}=(Ce(),D(tt)),{SYSTEM_TABLE_NAMES:OP,SYSTEM_SCHEMA_NAME:lxe,CONFIG_PARAMS:vp,OPERATIONS_ENUM:Es}=ln,GRe=1e4,$Re="clone-node-config.yaml",uQ=[OP.ROLE_TABLE_NAME,OP.USER_TABLE_NAME,OP.NODE_TABLE_NAME],VRe={clustering_nodename:!0,clustering_leafserver_streams_path:!0,clustering_tls_certificate:!0,clustering_tls_privatekey:!0,clustering_tls_certificateauthority:!0,logging_file:!0,logging_root:!0,logging_rotation_path:!0,operationsapi_network_domainsocket:!0,operationsapi_tls_certificate:!0,operationsapi_tls_privatekey:!0,operationsapi_tls_certificateauthority:!0,rootpath:!0,storage_path:!0,storage_audit_path:!0,databases:!0,mqtt_network_mtls_certificateauthority:!0,componentsroot:!0,tls_certificate:!0,tls_privatekey:!0,tls_certificateauthority:!0,replication_hostname:!0,replication_url:!0,cloned:!0},Gr={HDB_LEADER_USERNAME:"HDB_LEADER_USERNAME",HDB_LEADER_PASSWORD:"HDB_LEADER_PASSWORD",HDB_LEADER_URL:"HDB_LEADER_URL",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",HDB_CLONE_OVERTOP:"HDB_CLONE_OVERTOP",CLONE_KEYS:"CLONE_KEYS",CLONE_USING_WS:"CLONE_USING_WS",NO_START:"NO_START"},ua=IRe(process.argv),cf=ua[Gr.HDB_LEADER_USERNAME]??process.env[Gr.HDB_LEADER_USERNAME],lf=ua[Gr.HDB_LEADER_PASSWORD]??process.env[Gr.HDB_LEADER_PASSWORD],ru=ua[Gr.HDB_LEADER_URL]??process.env[Gr.HDB_LEADER_URL],la=ua[Gr.REPLICATION_HOSTNAME]??process.env[Gr.REPLICATION_HOSTNAME],dQ,fQ;la&&([dQ,fQ]=la.split(":"));var CP=(ua[Gr.HDB_CLONE_OVERTOP]??process.env[Gr.HDB_CLONE_OVERTOP])==="true",_Q=ua[vp.CLONED.toUpperCase()]??process.env[vp.CLONED.toUpperCase()],KRe=ua[Gr.CLONE_KEYS]!=="false"&&process.env[Gr.CLONE_KEYS]!=="false",hQ=(ua[Gr.CLONE_USING_WS]??process.env[Gr.CLONE_USING_WS])==="true",pQ=(ua[Gr.NO_START]??process.env[Gr.NO_START])==="true",ps,pc={},sQ,iQ,tu={},cn,Ft,Ks,io,nu=!1,PP=!1,hs,uf;TQ.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${ru}`),delete process.env.HDB_LEADER_URL,Ft=EA.getEnvCliRootPath(),!Ft)try{let i=Ri(Zj.homedir(),ln.HDB_HOME_DIR_NAME,ln.BOOT_PROPS_FILE_NAME);if(await Xt.pathExists(i)){let o=PRe(i);Ft=ca.parse(o.get(ln.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)).dir}}catch{throw new Error("There was an error setting the clone default root path. Please set ROOTPATH using an environment or CLI variable.")}Ft?await Xt.pathExists(Ft)?console.log(`Existing HarperDB install found at ${Ft}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Ft} starting fresh clone`),nu=!0):(console.log("No HarperDB install found, starting fresh clone"),nu=!0),Ft||(Ft=Ri(Zj.homedir(),ln.HDB_ROOT_DIR_NAME),console.log("Using default root path",Ft));let n;try{n=Ri(Ft,$Re),ps=tQ.parseDocument(await Xt.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=Ri(Ft,ln.HDB_CONFIG_FILE);if(await Xt.pathExists(s))try{sQ=tQ.parseDocument(await Xt.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),pc=pA.flattenConfig(sQ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(la){let i=new URL(ru);uf=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${fQ||9933}`}if(hQ){await YRe();return}if(pc?.cloned&&_Q!=="false")return console.log("Instance marked as cloned, clone will not run"),Ys.setCloneVar(!1),Ys.initSync(),mA();cn=await EQ({operation:Es.DESCRIBE_ALL}),await gQ(),Ys.setCloneVar(!1),Ys.setHdbBasePath(Ft),Xt.ensureDir(Ys.get(ln.CONFIG_PARAMS.LOGGING_ROOT)),IP.initLogSettings(),await WRe(),PP||await zRe(),await JRe(t,r),la&&(await ZRe(),await mQ()),console.info(`
|
|
135
|
-
Successfully cloned node: `+ru),(t||pQ)&&process.exit()},"cloneNode");async function YRe(){if(pc?.cloned&&_Q!=="false")return console.log("Instance marked as cloned, clone will not run"),Ys.setCloneVar(!1),Ys.initSync(),mA();console.log("Cloning using WebSockets");let e=Ec("system"),t=Ri(e,"system.mdb"),r=Xt.existsSync(t);nu||!r||CP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Ft,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=CRe.randomBytes(10).toString("base64").slice(0,10),gA(!0),await cQ()):(Ys.setCloneVar(!1),Ys.initSync()),await mA(),await gQ(!0),await kRe(),r||await qRe.system.hdb_user.delete({username:"clone-temp-admin"}),await FRe(),console.log("Adding node to the cluster");let s=await ud()({operation:Es.ADD_NODE,url:uf});console.log("Add node response: ",s),await mQ(),console.log(`Successfully cloned node: ${ru} using WebSockets`),pA.updateConfigValue(vp.CLONED,!0),pQ&&process.exit()}a(YRe,"cloneUsingWS");async function EQ(e){return hQ?wP({url:uf},e,{rejectUnauthorized:!1}):JSON.parse((await eye(e)).body)}a(EQ,"leaderReq");async function mQ(){try{if(KRe!==!1){console.log("Cloning JWT keys");let e=ca.join(Ft,ln.LICENSE_KEY_DIR_NAME),t=await wP({url:uf},{operation:Es.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});nQ(ca.join(e,ln.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await wP({url:uf},{operation:Es.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});nQ(ca.join(e,ln.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r.message)}}catch(e){console.error("Error cloning JWT keys",e)}}a(mQ,"cloneKeys");async function gQ(e=!1){console.info("Cloning configuration"),iQ=await EQ({operation:Es.GET_CONFIGURATION}),tu=pA.flattenConfig(iQ);let t=ps?.componentConfig?.exclude,r={rootpath:Ft};la&&(r.replication_hostname=dQ);for(let i in tu)if(!(tu[i]!==null&&typeof tu[i]=="object"&&!(tu[i]instanceof Array)||VRe[i])){if(i.includes("_package")||i.includes("_port")){if(tu[i]?.includes?.("hdb/components"))continue;if(t){let o=!1;for(let c of t)if(i.includes(c.name)){o=!0;break}if(o)continue}}pc[i]||(r[i]=tu[i])}for(let i in pc)i!=="databases"&&typeof pc[i]=="object"&&!(pc[i]instanceof Array)||(r[i]=pc[i]);let n={};if(ps?.databaseConfig?.excludeDatabases&&ps.databaseConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),ps?.clusteringConfig?.excludeDatabases&&ps.clusteringConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),Object.keys(n).length>0){r.replication_databases=[],n.system||r.replication_databases.push("system");for(let i in cn)n[i]||r.replication_databases.push(i)}let s=MRe(Object.keys(ln.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),pA.createConfigFile(r,!0)}a(gQ,"cloneConfig");async function WRe(){process.env.HDB_FETCH==="true"?(await QRe(),process.env.NODE_TLS_REJECT_UNAUTHORIZED&&delete process.env.NODE_TLS_REJECT_UNAUTHORIZED):await jRe()}a(WRe,"cloneDatabases");async function zRe(){if(console.info("Clone node installing HarperDB."),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Ft,!cf)throw new Error("HDB_LEADER_USERNAME is undefined.");if(process.env.HDB_ADMIN_USERNAME=cf,!lf)throw new Error("HDB_LEADER_PASSWORD is undefined.");process.env.HDB_ADMIN_PASSWORD=lf,process.env.OPERATIONSAPI_NETWORK_PORT=Ys.get(vp.OPERATIONSAPI_NETWORK_PORT),xRe(ca.join(Ft,ln.HDB_CONFIG_FILE)),gA(!0),await cQ()}a(zRe,"installHDB");function Ec(e){return Ys.get(ln.CONFIG_PARAMS.DATABASES)?.[e]?.path||Ys.get(vp.STORAGE_PATH)||ca.join(Ft,ln.DATABASES_DIR_NAME)}a(Ec,"getDBPath");async function jRe(){let e=Ec("system"),t=Ri(e,"system.mdb");if(await Mp(e),nu||!await Xt.exists(t)||CP){if(!la){console.info("Cloning system database"),await Mp(e);let r=hA(t,{overwrite:!0}),n={operation:Es.GET_BACKUP,database:"system",tables:uQ},s=await oQ(n,r),i=new Date(s.date);(!hs||i<hs)&&(hs=i),await Xt.utimes(t,Date.now(),i)}nu||(await lQ(Ft),await SQ(),gA(!0))}else PP=!0,console.log("Not cloning system database due to it already existing on clone");Ks=ps?.databaseConfig?.excludeDatabases,Ks=Ks?Ks.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in cn)await Xt.exists(ca.join(Ec(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Ks[r]=!0);io=ps?.databaseConfig?.excludeTables,io=io?io.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in cn){if(Ks[r]){cn[r]="excluded";continue}if(aQ.isEmpty(cn[r]))continue;let n=[],s=!1;for(let d in cn[r])io[r+d]?(s=!0,cn[r][d]="excluded"):n.push(cn[r][d]);if(n.length===0)continue;if(la){IP.debug("Setting up tables for #{db}");let d=(Ce(),D(tt)).table;for(let h of n){for(let _ of h.attributes)(_.is_hash_attribute||_.is_primary_key)&&(_.isPrimaryKey=!0);d({database:r,table:h.name,attributes:h.attributes})}continue}n=n.map(d=>d.name);let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i={operation:Es.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:Es.GET_BACKUP,database:r});let o=Ec(r);await Mp(o);let c=Ri(o,r+".mdb"),l=hA(c,{overwrite:!0}),u=await oQ(i,l),f=new Date(u.date);(!hs||f<hs)&&(hs=f),await Xt.utimes(c,Date.now(),f)}}a(jRe,"cloneTablesHttp");async function QRe(){let e=Ec("system"),t=Ri(e,"system.mdb");if(nu||!await Xt.exists(t)||CP){if(!la){console.info("Cloning system database using fetch");let r={operation:Es.GET_BACKUP,database:"system",tables:uQ},n=await NP(r,!0),s=Ec("system");await Mp(s);let i=Ri(s,"system.mdb");await rQ(n.body,hA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!hs||o<hs)&&(hs=o),await Xt.utimes(i,Date.now(),new Date(n.headers.get("date")))}nu||(await lQ(Ft),await SQ(),gA(!0))}else PP=!0,console.log("Not cloning system database due to it already existing on clone");if(la){IP.info("Replication hostname set, not using backup to clone databases, replication will clone");return}Ks=ps?.databaseConfig?.excludeDatabases,Ks=Ks?Ks.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in cn)await Xt.exists(ca.join(Ec(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Ks[r]=!0);io=ps?.databaseConfig?.excludeTables,io=io?io.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in cn){if(Ks[r]){cn[r]="excluded";continue}if(aQ.isEmpty(cn[r]))continue;let n=[],s=!1;for(let f in cn[r])io[r+f]?(s=!0,cn[r][f]="excluded"):n.push(f);if(n.length===0)return;let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i=await NP({operation:Es.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await NP({operation:Es.GET_BACKUP,database:r},!0));let o=Ec(r);await Mp(o);let c=new Date(i.headers.get("date")),l=Ri(o,`${c.getTime()}-${r}.mdb`);await rQ(i.body,hA(l,{overwrite:!0}));let u=Ri(o,r+".mdb");await Xt.rename(l,u),(!hs||c<hs)&&(hs=c),await Xt.utimes(u,Date.now(),c)}}a(QRe,"cloneTablesFetch");async function NP(e,t=!1){let r=ps?.httpsRejectUnauthorized??!1,n=new _A.Agent({rejectUnauthorized:r});r||(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0");let i={Authorization:"Basic "+Buffer.from(cf+":"+lf).toString("base64"),"Content-Type":"application/json"};t&&(i["Accept-Encoding"]="gzip");let o=await fetch(ru,{method:"POST",headers:i,body:JSON.stringify(e),agent:n,compress:!0});if(o.ok)return o;throw console.error(`HTTP Error Response: ${o.status} ${o.statusText}`),new Error(await o.text())}a(NP,"leaderHttpReqFetch");async function JRe(e,t=!1){let r=await DRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await URe(!1):(t&&await XRe(),await mA()):(console.info(await LRe({operation:Es.RESTART})),await EA.async_set_timeout(GRe)),e&&await EA.async_set_timeout(2e3)}a(JRe,"startHDB");async function XRe(){let e=process.argv[3];e&&e[0]!=="-"&&(await Xt.exists(e)||console.error(`The folder ${e} does not exist`),Xt.statSync(e).isDirectory()||console.error(`The path ${e} is not a folder`),e=await Xt.realpath(e),await Xt.exists(ca.join(e,ln.HDB_CONFIG_FILE))?process.env.ROOTPATH=e:process.env.RUN_HDB_APP=e)}a(XRe,"setAppPath");async function ZRe(){console.info("Setting up replication"),await vRe.setSchemaDataToGlobalAsync();let t=await ud()({operation:Es.ADD_NODE,verify_tls:!1,url:uf,start_time:hs,authorization:{username:cf,password:lf}},!0);console.log("Add node response: ",t)}a(ZRe,"setupReplication");async function eye(e){let t=new _A.Agent({rejectUnauthorized:ps?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(cf+":"+lf).toString("base64"),"Content-Type":"application/json"},s=new URL(ru),i={protocol:s.protocol,host:s.hostname,method:"POST",headers:n};return s.protocol==="https:"&&(i.agent=t),s.port&&(i.port=s.port),await EA.httpRequest(i,e)}a(eye,"leaderHttpReq");async function oQ(e,t){let r=new _A.Agent({rejectUnauthorized:ps?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(cf+":"+lf).toString("base64"),"Content-Type":"application/json"},i=new URL(ru),o={protocol:i.protocol,host:i.hostname,method:"POST",headers:s};return i.protocol==="https:"&&(o.agent=r,eQ=_A),i.port&&(o.port=i.port),new Promise((c,l)=>{let u=eQ.request(o,f=>{f.statusCode!==200&&l("Request to leader node failed with code: "+f.statusCode),f.pipe(t),f.on("end",()=>{t.close(),c(f.headers)})});u.on("error",f=>{l(f)}),u.write(JSON.stringify(e)),u.end()})}a(oQ,"leaderHttpStream");async function SQ(){let e=BRe.version;if(e)await HRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(SQ,"insertHdbVersionInfo")});var RQ=C((fxe,AQ)=>{var tye=ET(),rye=W();AQ.exports=nye;async function nye(){try{await tye.install()}catch(e){console.error("There was an error during the install."),console.error(e),rye.error(e),process.exit(1)}}a(nye,"install")});var OQ=C((hxe,bQ)=>{"use strict";var sye=nS(),iye=W(),yQ="Registration failed.";async function oye(){let e;try{e=await sye.register()}catch(t){return iye.error(`Registration error ${t}`),yQ}return e||yQ}a(oye,"register");bQ.exports={register:oye}});var CQ=C((Exe,IQ)=>{"use strict";var aye=W(),cye=(v(),D(q)),lye=require("util"),uye=require("child_process"),NQ=lye.promisify(uye.exec),dye=Uo(),Up=Ad(),wQ="Stopping HarperDB.";IQ.exports=fye;async function fye(){if(console.log(wQ),aye.notify(wQ),await Up.isServiceRegistered(cye.PROCESS_DESCRIPTORS.HDB)){Up.enterPM2Mode();let r=await Up.getUniqueServicesList();for(let n in r)await Up.stop(n)}await Up.kill();let t=await dye.getHDBProcessInfo();t.clustering.forEach(r=>{NQ(`kill ${r.pid}`)}),t.core.forEach(r=>{NQ(`kill ${r.pid}`)})}a(fye,"stop")});var LQ=C((gxe,DQ)=>{"use strict";var MP=require("fs-extra"),vP=require("path"),LP=require("yaml"),xp=ar(),mc=(v(),D(q)),PQ=gt(),UP=W(),_ye=An(),hye=Jg(),pye=jg(),Eye=Uo(),Bp=ce(),mye=Gd(),gye=ae();Bp.initSync();var Ws={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},Hn={LEAF:"leaf server",HUB:"hub server"},SA;DQ.exports=Sye;async function Sye(){let e={harperdb:{status:Ws.STOPPED}};if(!await mye.isHdbInstalled()){e.harperdb.status=Ws.NOT_INSTALLED,console.log(LP.stringify(e));return}SA=Bp.get(mc.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await MP.readFile(vP.join(SA,mc.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===mc.NODE_ERROR_CODES.ENOENT){UP.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Ws.STOPPED,console.log(LP.stringify(e));return}throw n}let r=await Eye.getHDBProcessInfo();for(let n of r.core)if(n.pid===t){e.harperdb.status=Ws.RUNNING,e.harperdb.pid=t;break}if((Bp.get(mc.CONFIG_PARAMS.REPLICATION_URL)||Bp.get(mc.CONFIG_PARAMS.REPLICATION_HOSTNAME))&&(e.replication=await Aye()),e.clustering=await Tye(r),e.clustering[Hn.HUB].status===Ws.RUNNING&&e.clustering[Hn.LEAF].status===Ws.RUNNING){let n=[],s=await hye({});for(let o of s.nodes){let c={};for(let l in o)c[l.replace("_"," ")]=o[l];n.push(c)}e.clustering.network=n;let i=await pye.clusterStatus();e.clustering.replication={"node name":i.node_name,"is enabled":i.is_enabled,connections:[]};for(let o of i.connections){let c={};c["node name"]=o?.node_name,c.status=o?.status,c.ports={clustering:o?.ports?.clustering,"operations api":o?.ports?.operations_api},c["latency ms"]=o?.latency_ms,c.uptime=o?.uptime,c.subscriptions=o?.subscriptions,c["system info"]={"hdb version":o?.system_info?.hdb_version,"node version":o?.system_info?.node_version,platform:o?.system_info?.platform},e.clustering.replication.connections.push(c)}await xp.closeConnection()}console.log(LP.stringify(e)),process.exit()}a(Sye,"status");async function Tye(e){let t={[Hn.HUB]:{},[Hn.LEAF]:{}};if(e.clustering.length===0)return t[Hn.HUB].status=Ws.STOPPED,t[Hn.LEAF].status=Ws.STOPPED,t;let{port:r}=xp.getServerConfig(mc.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await _ye.getClusterUser();try{(await xp.createConnection(r,n,s,!1)).close(),t[Hn.HUB].status=Ws.RUNNING}catch{t[Hn.HUB].status=Ws.ERRORED}let{port:i}=xp.getServerConfig(mc.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await xp.createConnection(i,n,s,!1)).close(),t[Hn.LEAF].status=Ws.RUNNING}catch{t[Hn.LEAF].status=Ws.ERRORED}try{t[Hn.HUB].pid=Number.parseInt(await MP.readFile(vP.join(SA,"clustering",PQ.PID_FILES.HUB),"utf8"))}catch(o){UP.error(o),t[Hn.HUB].pid=void 0}try{t[Hn.LEAF].pid=Number.parseInt(await MP.readFile(vP.join(SA,"clustering",PQ.PID_FILES.LEAF),"utf8"))}catch(o){UP.error(o),t[Hn.LEAF].pid=void 0}return t}a(Tye,"getHubLeafStatus");async function Aye(){let e=await gye.httpRequest({method:"POST",protocol:"http:",socketPath:Bp.get(mc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),headers:{"Content-Type":"application/json"}},{operation:"cluster_status"});e=JSON.parse(e.body);let t={"node name":e.node_name,"is enabled":e.is_enabled,connections:[]};for(let r of e.connections)t.connections.push({"node name":r.name,url:r.url,subscriptions:r.subscriptions,replicates:r.replicates,"database sockets":r.database_sockets.map(n=>({database:n.database,connected:n.connected,latency:n.latency,"catching up from":n.catching_up_from,"thread id":n.thread_id,nodes:n.nodes}))});return t}a(Aye,"getReplicationStatus")});Kp();var xP=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");xP&&ce().setCloneVar(!0);var Hp=require("node:fs"),MQ=require("node:path"),su=W(),vQ=jj(),{packageJson:Rye,PACKAGE_ROOT:UQ}=rt(),yye=Xj(),BP=(v(),D(q)),{SERVICE_ACTIONS_ENUM:un}=BP,bye=`
|
|
133
|
+
`))}},25).unref()}o.close?.(()=>{if(ht.get(jt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Qd()==0)try{sz(az(ht.get(jt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,BT),o.cantCleanupProperly||vn.warn("Had to forcefully exit the thread",BT),process.exit(0)},5e3).unref()})}if(cz||process.env.DEV_MODE)try{require("inspector").close()}catch(i){vn.info("Could not close debugger",i)}}}).ref();let e;bh&&!vSe&&(e=uz()),Promise.resolve(e).then(()=>{if(Qd()===0)try{DSe(xC)}catch(t){console.error("Error displaying start-up log",t)}Oh?.postMessage({type:jt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(lz,"startServers");function uz(){let e=[];for(let t in to){let r=to[t];if(t.includes?.("/")&&Qd()==0){bSe(t)&&sz(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),vn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=ht.get(jt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=Qd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?bh?n={fd:bh(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:bh?n={fd:bh(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),vn.trace("Listening on port "+t,BT)}).on("error",c)}))}return Promise.all(e)}a(uz,"listenOnPorts");!vC&&!mSe?.noServerStart&&lz();function kC(e,t,r){let n=e?.read?e:new ESe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=to[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=to[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(vn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(kC,"deliverSocket");var ZW=new Map;function USe(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=ZW.get(s),r){case"connection":i=kC(void 0,t),ZW.set(s,i),i.write=(c,l,u)=>(Oh.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(Oh.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Oh.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(USe,"proxyRequest");var{getComponentName:kT}=(jp(),C(zp));function FC(e,t,r=!0){t||(t=ht.get(jt.CONFIG_PARAMS.HTTP_PORT));let n=to[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",nz),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else to[t]=e;e.on("unhandled",nz)}a(FC,"registerServer");function GC(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=[],ht.get(jt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:ht.get(jt.CONFIG_PARAMS.HTTP_PORT),secure:ht.get(jt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),ht.get(jt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:ht.get(jt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&ht.get(jt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:az(ht.get(jt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(GC,"getPorts");function qC(e,t){let r=[];for(let{port:n,secure:s}of GC(t))r.push(dz(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?BC[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,FC(e,n,!1)),HT[n]=GT(BC,n);return r}a(qC,"httpServer");function FT(e,t){let r=xC.get(e)??[];xC.set(e,[...r,t])}a(FT,"setPortServerMap");function dz(e,t,r,n){if(FT(e,{protocol_name:t?"HTTPS":"HTTP",name:kT()}),!xT[e]){let s=r?"operationsApi_network":"http",i=ht.get(s+"_keepAliveTimeout"),o=ht.get(s+"_timeout"),c=ht.get(s+"_headersTimeout"),l={keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:ht.get(jt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=ht.get(s+"_mtls"),f=ht.get(s+"_mtls_required"),d;t&&(d=ht.get(s+"_http2")??!r,Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!f,requestCert:!!(u||n),ticketKeys:wSe(),SNICallback:oz(r?"operations-api":"server",u)}));let p=PSe(),_=xT[e]=(t?d?RSe:ASe:SSe)(l,async(h,S)=>{try{let A=performance.now(),E=new iz(h,S);r&&(E.isOperationsServer=!0);let R=await HT[e](E);if(!R){if(E._nodeResponse.statusCode)return;R=fz(E)}if(R.headers?.set||(R.headers=new UC(R.headers)),p?R.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):R.headers?.set?.("Server","HarperDB"),R.status===-1){for(let se of R.headers||[])S.setHeader(se[0],se[1]);return h.baseRequest=E,S.baseResponse=R,xT[e].emit("unhandled",h,S)}let N=R.status||200,v=performance.now(),k=v-A,F=R.body,K,re=!1;if(!R.handlesHeaders){let se=R.headers||new UC;F?F.length>=0?(typeof F=="string"?se.set("Content-Length",Buffer.byteLength(F)):se.set("Content-Length",F.length),K=!0):F instanceof ySe&&(F.size?se.set("Content-Length",F.size):F.on&&(re=!0,F.on("size",he=>{S.headersSent||S.setHeader("Content-Length",he)})),F=F.stream()):(se.set("Content-Length","0"),K=!0);let W=`hdb;dur=${k.toFixed(2)}`;if(R.wasCacheMiss&&(W+=", miss"),CSe(se,"Server-Timing",W,!0),!S.headersSent)if(re){if(S.statusCode=N,se)if(se[Symbol.iterator])for(let[he,Te]of se)S.setHeader(he,Te);else for(let he in se)S.setHeader(he,se[he])}else S.writeHead(N,se&&(se[Symbol.iterator]?Array.from(se):se));K&&S.end(F)}let ae=E.handlerPath,Z=E.method;if(Rh(k,"duration",ae,Z,R.wasCacheMiss==null?void 0:R.wasCacheMiss?"cache-miss":"cache-hit"),JW(N<400,"success",ae,Z),JW(1,"response_"+N,ae,Z),!K)if(F instanceof ReadableStream&&(F=XW.fromWeb(F)),(F[Symbol.iterator]||F[Symbol.asyncIterator])&&(F=XW.from(F)),F?.pipe){F.pipe(S),F.destroy&&S.on("close",()=>{F.destroy()});let se=0;F.on("data",W=>{se+=W.length}),F.on("end",()=>{Rh(performance.now()-v,"transfer",ae,Z),Rh(se,"bytes-sent",ae,Z)})}else F?.then?F.then(se=>{S.end(se)},g):S.end(F)}catch(A){g(A)}function g(A){let E=A.headers;S.writeHead(A.statusCode||500,E&&(E[Symbol.iterator]?Array.from(E):E)),S.end(A.toString()),A.statusCode?A.statusCode===500?vn.warn(A):vn.info(A):vn.error(A)}a(g,"onError")});i>=0&&(_.keepAliveTimeout=i),c>=0&&(_.headersTimeout=c),t&&(_.ports||(_.ports=[]),_.ports.push(e),l.SNICallback.initialize(_),u&&(_.mtlsConfig=u),_.on("secureConnection",h=>{h._parent.startTime&&Rh(performance.now()-h._parent.startTime,"tls-handshake",e),Rh(h.isSessionReused(),"tls-reused",e)}),_.isSecure=!0),FC(_,e)}return xT[e]}a(dz,"getHTTPServer");function GT(e,t){let r=fz;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(GT,"makeCallbackChain");function fz(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new UC}}a(fz,"unhandled");function xSe(e,t){qC(e,{requestOnly:!0,...t})}a(xSe,"onRequest");function BSe(e,t){let r;if(t.securePort){FT(t.securePort,{protocol_name:"TLS",name:kT()});let n=oz("server",t.mtls);r=NSe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),to[t.securePort]=r}return t.port&&(FT(t.port,{protocol_name:"TCP",name:kT()}),r=gSe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),to[t.port]=r),r}a(BSe,"onSocket");Object.defineProperty(TSe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.toLowerCase().includes("upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var ez=[],HC={};function _z(e,t){for(let{port:r}of GC(t))ez[t?.runFirst?"unshift":"push"]({listener:e,port:r}),HC[r]=GT(ez,r)}a(_z,"onUpgrade");var tz=[],rz={};function HSe(e,t){let r=[];for(let{port:n,secure:s}of GC(t)){FT(n,{protocol_name:s?"WSS":"WS",name:kT()});let i=dz(n,s,t?.isOperationsServer,t?.mtls);yh[n]||(yh[n]=new OSe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),yh[n].on("connection",(o,c)=>{let l=new iz(c);l.isWebSocket=!0;let u=HT[n](l);rz[n](o,l,u)}),_z((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):yh[n].handleUpgrade(o,c,l,f=>{o.__harperdb_request_upgraded=!0,u(o,c,l),yh[n].emit("connection",f,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{HC[n]&&HC[n](o,c,l)})),r.push(i),tz[t?.runFirst?"unshift":"push"]({listener:e,port:n}),rz[n]=GT(tz,n),HT[n]=GT(BC,n)}return r}a(HSe,"onWebSocket");function nz(e,t){t.writeHead(404),t.end(`Not found
|
|
134
|
+
`)}a(nz,"defaultNotFound")});var QW={};ve(QW,{startHTTPThreads:()=>FSe,startSocketServer:()=>zC,updateWorkerIdleness:()=>Rz});async function FSe(e=2,t){try{if(t)YC(0,1,!0);else{let{loadRootComponents:r}=qT();if(e===0)return(0,Fs.setMainIsWorker)(!0),await $C().startServers(),Promise.resolve([]);await r()}Az();for(let r=0;r<e;r++)YC(r,e);return Promise.all(Tz)}finally{(0,Fs.threadsHaveStarted)()}}function Az(){let e=(0,Ez.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),KC=setInterval(()=>{KT.notify(e)},kSe).unref())}function YC(e,t=1,r){if(VC++,(0,Fs.startWorker)("server/threads/threadServer.js",{name:JA.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===zA.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Tz.push(s),await s,Jd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=VT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Jd.indexOf(n);o>-1&&Jd.splice(o,1)}if(a(i,"removeWorker"),Xd){let o=Xd;Xd=[];for(let c of o)Sz[c.localPort](null,c)}}}),r){let n=setInterval(()=>{WC?WC=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Fs.shutdownWorkers)(),VC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function zC(e=0,t){if(typeof e=="string")try{(0,YT.existsSync)(e)&&(0,YT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=GSe:r=qSe(t):r=jC;let n=(0,Zd.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);return n._handle&&(n._handle.onconnection=Sz[e]=function(s,i){r.readsData||(i.reading=!1,i.readStop()),WC=!0,r(i,(o,c)=>{if(!o){if(pz){let u=i._socket||new Zd.Socket({handle:i,writable:!0,readable:!0});pz.deliverSocket(u,e,c),u.resume()}else VC>0?(Xd.length===0&&setTimeout(()=>{Xd.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),i.localPort=e,Xd.push(i)):(console.log("start up a dynamic thread to handle request"),YC(0));sr(!1,"socket-routed");return}o.requests++;let l=i.fd;if(l>=0)o.postMessage({port:e,fd:l,data:c});else{let u=i._socket||new Zd.Socket({handle:i,writable:!0,readable:!0});KSe(u,o,e)}sr(!0,"socket-routed")})},KT.info(`HarperDB ${gz.packageJson.version} Server running on port ${e}`)),n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function jC(e,t){let r,n=0;for(let s of Jd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=$T)return $T=i,t(r);n=i}$T=0,t(r)}function GSe(e,t){let r={};e.getpeername(r);let n=r.address,s=ef.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);jC(e,o=>{ef.set(n,{worker:o,lastUsed:i}),t(o)})}function qSe(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new Zd.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],u=ef.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);jC(n,d=>{ef.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function Rz(){$T=0;for(let e of Jd)e.expectedIdle=e.recentELU.idle+$Se,e.requests=1;Jd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function KSe(e,t,r){let n=VSe++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),VT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),VT.delete(n)),s.event=="destroy"&&(e.destroy(),VT.delete(n))})}var Fs,Zd,KT,YT,mz,Ez,gz,Jd,Xd,Sz,pz,VC,Tz,KC,kSe,WC,$T,hz,ef,$Se,VT,VSe,MC=be(()=>{Fs=M(tt()),Zd=require("net");B();KT=M(Y()),YT=require("fs");$i();mz=require("worker_threads"),Ez=M(yd()),gz=M(nt()),Jd=[],Xd=[],Sz=[],VC=0,Tz=[];mz.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Fs.onMessageFromWorkers)(e=>{e.type===QA.RESTART&&KC&&(clearInterval(KC),Az())}));kSe=6e5;a(FSe,"startHTTPThreads");a(Az,"licenseWarning");a(YC,"startHTTPWorker");a(zC,"startSocketServer");$T=0;a(jC,"findMostIdleWorker");hz=36e5,ef=new Map;a(GSe,"findByRemoteAddressAffinity");a(qSe,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of ef)r.lastUsed+hz<e&&ef.delete(t)},hz).unref();$Se=1e3;a(Rz,"updateWorkerIdleness");(0,Fs.setMonitorListener)(Rz);VT=new Map,VSe=1;a(KSe,"proxySocket")});var Bz=I((XUe,xz)=>{var bz=M(require("cluster")),lc=M(ce());B();var ro=M(Y()),Oz=M(require("fastify")),Nz=M(require("@fastify/cors")),wz=M(require("@fastify/compress")),Iz=M(require("@fastify/static")),Cz=M(SO()),Pz=M(require("path")),Dz=M(nt()),Lz=M(bs()),Mz=M(oe()),vz=M(Rn()),Uz=M(yd());Kr();var uc=M(pT());fo();lc.default.initSync();var YSe=6e4,WSe=1024*1024*1024,zSe="TRUE",{CONFIG_PARAMS:wh}=G,tf;xz.exports={hdbServer:yz,start:yz};async function yz(e){try{ro.default.debug("In Fastify server"+process.cwd()),ro.default.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ro.default.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=bz.default.isMaster,await jSe();let t=e.securePort>0;tf=QSe(t),await tf.ready(),e||(e={}),e.isOperationsServer=!0;try{We.http(tf.server,e),tf.server.closeIdleConnections||await tf.listen({port:0,host:"::"})}catch(r){throw tf.close(),ro.default.error(r),ro.default.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),ro.default.fatal(t),process.exit(1)}}a(yz,"operationsServer");async function jSe(){ro.default.trace("Configuring HarperDB process."),Lz.default.setSchemaDataToGlobal(),await vz.default.setUsersWithRolesCache(),await Uz.default.getLicense()}a(jSe,"setUp");function QSe(e){ro.default.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=JSe(e),r=(0,Oz.default)(t);r.server.headersTimeout=ZSe(),r.setErrorHandler(uc.serverErrorHandler);let n=XSe();n&&r.register(Nz.default,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(Cz.default),r.register(wz.default),r.register(Iz.default,{root:Pz.default.join(Dz.PACKAGE_ROOT,"studio/build-local")}),jf(r);let s=lc.default.get(WA.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Mz.default.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[uc.reqBodyValidationHandler,uc.authHandler],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),(0,uc.handlePostRequest)(i,o)}),r.get("/health",()=>"HarperDB is running."),ro.default.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(QSe,"buildServer");function JSe(e){let t=lc.default.get(wh.OPERATIONSAPI_NETWORK_TIMEOUT),r=lc.default.get(wh.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:WSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(JSe,"getServerOptions");function XSe(){let e=lc.default.get(wh.OPERATIONSAPI_NETWORK_CORS),t=lc.default.get(wh.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===zSe)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(XSe,"getCORSOpts");function ZSe(){return lc.default.get(wh.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??YSe}a(ZSe,"getHeaderTimeoutConfig")});var tP={};ve(tP,{disableNATS:()=>tTe,publishToStream:()=>jT,setNATSReplicator:()=>QC,setPublishToStream:()=>rTe,setSubscription:()=>eP,start:()=>eTe});function eTe(){Ih.default.get(x.CLUSTERING_ENABLED)&&sTe()}function tTe(e=!0){qz=e}function rTe(e,t){jT=e,eP=t}function sTe(){if(qz||process.env._DISABLE_NATS)return;let e=Je(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];QC(s,r,i)}}ml((r,n)=>{QC(r.tableName,r.databaseName,r),n&&Vz(r)}),!Hz&&(Hz=!0)}function QC(e,t,r){if(t==="system"&&iTe.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends Vr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this.getId(),record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this.getId()})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this.getId(),record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this.getId(),record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this.getId()})}static defineSchema(i){Vz(i)}static subscribe(){let i=new kn;return eP(t,e,i),i}static subscribeOnThisThread(i){return i<(Ih.default.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??nTe)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new WT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=$z;return i}a(n,"getNATSTransaction")}function Vz(e){let t=Ih.default.get(x.CLUSTERING_NODENAME);jT(`${XC.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,ZC.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 kz,XC,ZC,Fz,Gz,Ih,zT,qz,jT,eP,nTe,$z,Hz,iTe,WT,JC,Kz=be(()=>{Pe();ga();kz=M(ir()),XC=M(St()),ZC=M(To());_u();Fz=M(MO()),Gz=M(pn()),Ih=M(ce());B();zT=M(Y());a(eTe,"start");a(tTe,"disableNATS");jT=kz.publishToStream,eP=Fz.setSubscription;a(rTe,"setPublishToStream");nTe=2;a(sTe,"assignReplicationSource");iTe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(QC,"setNATSReplicator");a(Vz,"publishSchema");WT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=Ih.default.get(x.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let f of i){let d=f.table,p=f.operation=="put"?"upsert":f.operation;l||(zT.trace(`Sending transaction event ${p}`),u=l={operation:p,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,p!=="delete"&&p!=="invalidate"&&(l.records=o)),l.table===d&&l.operation===p?(o.push(f.record),c.push(f.id)):u=u.next={operation:p,table:d,id:f.id,record:f.record},f.expiresAt&&(u.expiresAt=f.expiresAt)}l&&n.push(jT(`${XC.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,ZC.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(f=>{throw zT.error("An error has occurred trying to replicate transaction",l,f),f.statusCode=504,f}))}return Promise.all(n)}},JC=class extends WT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,Gz.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};$z=new JC});async function Qz({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await rP.get(e,{returnNonexistent:!0});i=new iP(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await rP.get(e);o&&o.delete()}i=new JT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ch.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function nP(){return QT++,QT>65500&&(QT=1),QT}function sP(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Ii.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 Ot(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var Wz,dc,zz,jz,Yz,rP,Ch,QT,JT,iP,Jz=be(()=>{Pe();Su();Wz=M(pn()),dc=M(Y());Oc();zz=M(tt()),jz=M($C());Kr();Yz=100,rP=lt({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),Ch=lt({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,zz.getWorkerIndex)()===0&&(async()=>{await jz.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of Ch.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await We.getUser(r.user.username));try{await sP(r,t,r)}catch{(0,dc.warn)("Failed to publish will",t)}Ch.delete(e.id)}})();a(Qz,"getSession");QT=1;a(nP,"getNextMessageId");JT=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let f=this.subscriptions.find(A=>A.topic===s),d;f?(d=i>0,f.end(),this.subscriptions.splice(this.subscriptions.indexOf(f),1)):d=i===2;let p={search:l,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,dc.trace)("Resuming subscription from",s,"from",o);let _=Ii.getMatch(u,"mqtt");if(!_){let A=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw A.statusCode=404,A}if(p.url=_.relativeURL,p.url.indexOf("+")>-1||p.url.indexOf("#")>-1){let A=p.url.slice(1);if(A.indexOf("#")>-1&&A.indexOf("#")!==A.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(p.isCollection=!0,A.indexOf("+")===A.length-1)p.onlyChildren=!0,p.url="/"+A.slice(0,A.length-1);else{let E=A.split("/"),R;for(let k=0;k<E.length;k++)if(E[k].indexOf("+")>-1)if(E[k]==="+")R=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&R)throw new Error("Filters can not be combined");let N=!0;E[E.length-1]==="#"&&(E.length--,N=!1),R&&(n=a(k=>{let F=k.id;if(!Array.isArray(F))if(F?.indexOf?.("/")>-1)F=F.split("/");else return!1;if(N&&F.length!==E.length)return!1;for(let K=0;K<E.length;K++)if(E[K]!=="+"&&E[K]!==F[K])return!1;return!0},"filter"));let v=E.indexOf("+");p.url="/"+(v>-1?E.slice(0,v):E).concat("").join("/")}}let h=_.path,S=_.Resource,g=await Ot(p,async()=>{let A=this.createContext();A.topic=s,A.retainHandling=i;let E=await S.subscribe(p,A);if(!E)return;if(!E[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let R=(async()=>{for await(let N of E)try{let v;if(N.type&&N.type!=="put"&&N.type!=="delete"&&N.type!=="message"&&N.type!=="patch"||n&&!n(N))continue;r?(N.topic=s,v=this.needsAcknowledge(N)):(N.acknowledge?.(),v=nP());let k=N.id;if(Array.isArray(k)&&(k=gu(k)),k==null&&(k=""),await this.listener(h+"/"+k,N.value,v,t)===!1)break;this.awaitingAcks?.size>Yz?await new Promise(K=>setTimeout(K,this.awaitingAcks.size-Yz)):await new Promise(setImmediate)}catch(v){(0,dc.warn)(v)}})();return E});if(g)return g.topic=s,g.qos=t.qos,this.subscriptions.push(g),g}resume(){}needsAcknowledge(t){let r=nP();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return sP(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();Ot(r,async()=>{try{if(!t){let n=await Ch.get(this.sessionId);n?.doesExist()&&await sP(n,n.data,r)}}finally{await Ch.delete(this.sessionId)}}).catch(n=>{(0,dc.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(sP,"publish");iP=class extends JT{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=nP(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,dc.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,Wz.getNextMonotonicTime)()),(0,dc.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),rP.put(this.sessionRecord)}}});var aP={};ve(aP,{bypassAuth:()=>oTe,start:()=>aTe});function oTe(){rj=!0}function aTe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new tj.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,f,d,p)=>{if(f.headers.get("sec-websocket-protocol")!=="mqtt")return p(u,f,d);o.events.emit("connection",u),_r.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:_,onClose:h}=Zz(u,S=>{u.send(S)},f,Promise.resolve(d).then(()=>f?.user),o);u.on("message",_),u.on("close",h),u.on("error",S=>{_r.info?.("WebSocket error",S)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let f;if(o.events.emit("connection",u),_r.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let _=l.user;if(_!==null){(_===void 0||_==="Common Name"||_==="CN")&&(_=u.getPeerCertificate().subject.CN);try{f=await e.getUser(_,null,null),(0,rf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:f?.username,status:zs.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,rf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.error?.({username:_,status:zs.FAILURE,type:ua.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else _r.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(_){o.events.emit("error",_,u),_r.error?.(_)}else if(l.required)return _r.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!f&&rj&&u.remoteAddress.includes("127.0.0.1")&&(f=await(0,ej.getSuperUser)(),_r.debug?.("Auto-authorizing local connection",f?.username));let{onMessage:d,onClose:p}=Zz(u,_=>u.write(_),null,f,o);u.on("data",d),u.on("close",p),u.on("error",_=>{_r.info?.("Socket error",_)})},{port:t,securePort:s,mtls:l})),c}function Zz(e,t,r,n,s){Xz||(Xz=!0,z_(d=>{XT>0&&d.push({metric:"mqtt-connections",connections:XT,byThread:!0})}));let i;XT++;let o,c={protocolVersion:4},l=(0,eA.parser)({protocolVersion:5});function u(d){l.parse(d)}a(u,"onMessage");function f(){XT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),es(!1,"connection","mqtt","disconnect"),_r.debug?.("MQTT connection was closed",e.remoteAddress))}return a(f,"onClose"),l.on("packet",async d=>{n?.then&&(n=await n);let p=d.cmd;if(o)o.then&&await o;else if(p!=="connect"){_r.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let _=d.topic,h=_?.indexOf("/",1),S=h>0?_.slice(0,h):_;sr(d.length,"bytes-received",S,A(d),"mqtt");try{switch(o?.receivedPacket?.(),p){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await We.getUser(d.username,d.password.toString(),r),(0,rf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:n?.username,status:zs.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(ae){return(0,rf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.error?.({username:d.username,status:zs.FAILURE,type:ua.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,ae),es(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),es(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let ae=e.deserialize||(e.deserialize=po(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?ae(d.will.payload):void 0,delete d.will.payload}o=Qz({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(ae){return _r.error?.(ae),s.events.emit("auth-failed",d,e,ae),es(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:ae.code||5,returnCode:ae.code||128})}s.events.emit("connected",o,e),es(!0,"connection","mqtt","connect"),g({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0});let R=a(async(ae,Z,se,W)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",ae);let he=ae.indexOf("/",1),Te=he>0?ae.slice(0,he):ae;g({cmd:"publish",topic:ae,payload:await E(Z),messageId:se||Math.floor(Math.random()*1e8),qos:W.qos},Te);let Ce=e._socket??e;return Ce.writableNeedDrain?new Promise(me=>Ce.once("drain",me)):!Ce.closed}catch(he){return _r.error?.(he),o?.disconnect(),s.sessions.delete(o),!1}},"listener");o.setListener(R),o.sessionWasPresent&&await o.resume();break;case"subscribe":let N=[];for(let ae of d.subscriptions){let Z;try{let se=await o.addSubscription(ae,ae.qos>=1);Z=se?se.qos||0:c.protocolVersion<5?128:143}catch(se){s.events.emit("error",se,e,ae,o),se.statusCode?se.statusCode===500?_r.warn?.(se):_r.info?.(se):_r.error?.(se),Z=c.protocolVersion<5?128:se.statusCode===403?135:se.statusCode===404?143:128}N.push(Z)}await o.committed,g({cmd:"suback",granted:N,messageId:d.messageId});break;case"unsubscribe":{let ae=[];for(let Z of d.unsubscriptions)ae.push(o.removeSubscription(Z)?0:17);g({cmd:"unsuback",granted:ae,messageId:d.messageId});break}case"pubrel":g({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let v=d.qos===2?"pubrec":"puback",k=e.deserialize||(e.deserialize=po(r?.headers.get?.("content-type"))),K=(d.payload?.length||0)>0?k(d.payload):void 0,re;try{re=await o.publish(d,K)}catch(ae){s.events.emit("error",ae,e,d,o),_r.warn?.(ae),d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:re===!1?144:0},d.topic);break;case"pubrec":g({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":g({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),es(!0,"connection","mqtt","disconnect"),_r.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(R){s.events.emit("error",R,e,d,o),_r.error?.(R),g({cmd:"disconnect"})}function g(R,N){let v=(0,eA.generate)(R,c);t(v),sr(v.length,"bytes-sent",N,A(R),"mqtt")}a(g,"sendPacket");function A(R){return R.qos>0?R.cmd+",qos="+R.qos:R.cmd}a(A,"packetMethodName");function E(R){return ya(R,r)}a(E,"serialize")}),l.on("error",d=>{_r.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:f}}var eA,ej,rf,oP,tj,ZT,_r,rj,Xz,XT,nj=be(()=>{eA=require("mqtt-packet");Jz();ej=M(Rn());fo();$i();Kr();rf=M(ce());B();oP=M(Ci()),tj=require("events"),ZT=(0,oP.loggerWithTag)("auth-event"),_r=(0,oP.loggerWithTag)("mqtt"),rj=(0,rf.get)(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(oTe,"bypassAuth");a(aTe,"start");XT=0;a(Zz,"onSocket")});var zp={};ve(zp,{component_errors:()=>sf,getComponentName:()=>fTe,loadComponent:()=>nA,loadComponentDirectories:()=>lj,setErrorReporter:()=>dTe});function lj(e,t){t&&(lP=t),e&&(fP=e);let r=[];if((0,mt.existsSync)(cP)){let s=(0,mt.readdirSync)(cP,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,gt.join)(cP,o);r.push(nA(c,lP,$A,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(nA(n,lP,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{cj=!0})}function dTe(e){Ph=e}async function nA(e,t,r,n,s,i){let o=(0,mt.realpathSync)(e);if(tA.has(o))return tA.get(o);tA.set(o,!0),s&&(fP=s);try{let c;n&&(sf=new Map);let l=(0,gt.join)(e,"harperdb-config.yaml");(0,mt.existsSync)(l)?c=n?(0,sA.getConfigObj)():(0,uP.parseDocument)((0,mt.readFileSync)(l,"utf8")).toJSON():!n&&(0,mt.existsSync)(l=(0,gt.join)(e,"config.yaml"))?c=(0,uP.parseDocument)((0,mt.readFileSync)(l,"utf8")).toJSON():c=_P;let u=(0,gt.join)(e,"node_modules","harperdb");try{Wl.isMainThread&&(n||(0,mt.existsSync)(u)&&(0,mt.realpathSync)(dP.PACKAGE_ROOT)!==(0,mt.realpathSync)(u))&&((0,mt.rmSync)(u,{recursive:!0,force:!0}),(0,mt.existsSync)((0,gt.join)(e,"node_modules"))||(0,mt.mkdirSync)((0,gt.join)(e,"node_modules")),(0,mt.symlinkSync)(dP.PACKAGE_ROOT,u,"dir"))}catch(p){nf.default.error("Error symlinking harperdb module",p)}let f=rA,d=n;for(let p in c){rA=p;let _=c[p];if(sf.set(n?p:(0,gt.basename)(e),!1),!_)continue;let h,S=_.package;try{if(S){let N=e,v;for(;!(0,mt.existsSync)(v=(0,gt.join)(N,"node_modules",p));)if(N=(0,gt.dirname)(N),N.length<(0,aj.getHdbBasePath)().length){v=null;break}if(v)h=await nA(v,t,r,!1),d=!0;else throw new Error(`Unable to find package ${p}:${S}`)}else h=uTe[p];if(!h)continue;let g=a(N=>(N.origin=r,lt(N)),"ensureTable"),A=_.network||(_.port||_.securePort)&&_,E=A?.securePort||A?.https&&A.port,R=!A?.https&&A?.port;if(Wl.isMainThread&&(h=await h.startOnMainThread?.({server:We,ensureTable:g,port:R,securePort:E,resources:t,..._})||h,n&&A))for(let N of[R,E])try{if(+N&&!sj.includes(N)){let v=pP.get(x.HTTP_SESSIONAFFINITY);v&&nf.default.warn("Session affinity is not recommended and may cause memory leaks"),(v||!ET)&&(sj.push(N),zC(N,v))}}catch(v){console.error("Error listening on socket",N,v,p)}if(t.isWorker&&(h=await h.start?.({server:We,ensureTable:g,port:R,securePort:E,resources:t,..._})||h),fP.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&_.files!=null){if(_.files.includes(".."))throw(0,oj.handleHDBError)("Can not reference parent directories");let N=(0,gt.join)(e,_.files).replace(/\\/g,"/"),v=N.indexOf("/*");if(v>-1&&_.files!==_P[p]?.files&&!(0,mt.existsSync)(N.slice(0,v)))throw new Error(`The path '${N.slice(0,v)}' does not exist and cannot be used as the base of the resolved 'files' path value '${_.files}'`);let k=(0,gt.basename)(e),F=_.path||"/";F=F.startsWith("/")?F:F.startsWith("./")?"/"+k+F.slice(2):F==="."?"/"+k:"/"+k+"/"+F;let K,re,ae;if(_.root){let se=_.root;se.startsWith("/")&&(se=se.slice(1)),se.endsWith("/")&&(se=se.slice(0,-1)),se+="/",re=(0,gt.join)(e,se)}else(ae=N.indexOf("/*"))>-1?(re=N.slice(0,ae+1),K=(0,gt.relative)(e,re)):_.files.indexOf("/")>-1&&(re=N.slice(0,N.lastIndexOf("/")+1),K=(0,gt.relative)(e,re));let Z=!1;if(Wl.isMainThread&&h.setupDirectory&&(Z=await h.setupDirectory?.(F,re,t)),t.isWorker&&h.handleDirectory&&(Z=await h.handleDirectory?.(F,re,t)),Z){d=!0;continue}for(let se of await(0,ij.default)(N,{onlyFiles:!1,objectMode:!0})){let{path:W,dirent:he}=se;d=!0;let Te=(0,gt.relative)(e,W).replace(/\\/g,"/");if(K)if(Te.startsWith(K))Te=Te.slice(K.length+1);else throw new Error(`The root path '${_.root}' does not reference a valid part of the file path '${Te}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ce=F+(F.endsWith("/")?"":"/")+Te;try{if(he.isFile()){let me=await lTe(W);Wl.isMainThread&&await h.setupFile?.(me,Ce,W,t),t.isWorker&&await h.handleFile?.(me,Ce,W,t)}else Wl.isMainThread&&await h.setupDirectory?.(Ce,W,t),t.isWorker&&await h.handleDirectory?.(Ce,W,t)}catch(me){me.message=`Could not load ${he.isFile()?"file":"directory"} '${W}'${_.module?" using '"+_.module+"'":""} for application '${e}' due to: ${me.message}`,Ph?.(me),((0,of.getWorkerIndex)()===0?console:nf.default).error(me),t.set(_.path||"/",new Sa(me)),sf.set(n?p:(0,gt.basename)(e),me.message)}}}}catch(g){g.message=`Could not load component '${p}' for application '${(0,gt.basename)(e)}' due to: ${g.message}`,Ph?.(g),((0,of.getWorkerIndex)()===0?console:nf.default).error(g),t.set(_.path||"/",new Sa(g),null,!0),sf.set(n?p:(0,gt.basename)(e),g.message)}}if(rA=f,Wl.isMainThread&&!cj&&i&&(0,of.watchDir)(e,async()=>lj()),c.extensionModule){let p=await jE((0,gt.join)(e,c.extensionModule));return tA.set(o,p),p}if(!d&&t.isWorker){let p=`${e} did not load any modules, resources, or files, is this a valid component?`;Ph?.(new Error(p)),((0,of.getWorkerIndex)()===0?console:nf.default).error(p),sf.set((0,gt.basename)(e),p)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Ph?.(c),t.set("",new Sa(c))}}var mt,gt,Wl,uP,pP,dP,ij,of,nf,oj,aj,cTe,sA,lTe,cP,fP,cj,lP,sf,uTe,_P,sj,tA,Ph,rA,fTe,jp=be(()=>{mt=require("fs"),gt=require("path"),Wl=require("worker_threads"),uP=require("yaml"),pP=M(ce()),dP=M(nt());B();ML();mM();WB();JB();XB();vH();hY();AY();yY();ij=M(require("fast-glob")),of=M(tt()),nf=M(Y());nO();Kr();oj=M(pe());Pe();MC();aj=M(ce()),cTe=M(Bz());MS();Kz();ts();nj();sA=M(Rt());jI();ER();({readFile:lTe}=mt.promises),cP=(0,sA.resolvePath)(pP.get(x.COMPONENTSROOT)),fP=new Map,sf=new Map;a(lj,"loadComponentDirectories");uTe={REST:tg,rest:tg,graphql:UR,graphqlSchema:TR,roles:rO,jsResource:iO,fastifyRoutes:$I,login:aO,static:VI,operationsApi:cTe,customFunctions:{},http:{},clustering:tP,replication:Po,authentication:Gp,mqtt:aP,loadEnv:KI},_P={rest:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(_P,"static",{value:{files:"web/**"}});sj=[],tA=new Map;a(dTe,"setErrorReporter");fTe=a(()=>rA,"getComponentName");a(nA,"loadComponent")});var qT=I((I0e,dj)=>{var{isMainThread:uj}=require("worker_threads"),{getTables:_Te,getDatabases:N0e,table:w0e}=(Pe(),C(rt)),{loadComponentDirectories:pTe,loadComponent:hTe}=(jp(),C(zp)),{resetResources:mTe}=(Su(),C(CL)),ETe=kw(),gTe=Rt(),{dirname:STe}=require("path"),{getConnection:TTe}=ir(),ATe=ce(),{CONFIG_PARAMS:RTe}=(B(),C(G)),{loadCertificates:yTe}=rs(),hP=new Map;async function bTe(e=!1){!uj&&ATe.get(RTe.CLUSTERING_ENABLED)&&TTe();try{uj&&await ETe()}catch(n){console.error(n)}let t=mTe();_Te(),t.isWorker=e,await yTe(),await hTe(STe(gTe.getConfigFilePath()),t,"hdb",!0,hP),await pTe(hP,t);let r=[];for(let[n]of hP)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(bTe,"loadRootComponents");dj.exports.loadRootComponents=bTe});var tt=I((P0e,Ai)=>{"use strict";rm();var{Worker:OTe,MessageChannel:NTe,parentPort:no,isMainThread:TP,threadId:wTe,workerData:so}=require("worker_threads"),{PACKAGE_ROOT:ITe}=nt(),{join:hj,isAbsolute:CTe,extname:PTe}=require("path"),{server:mj}=(Kr(),C(Tu)),{watch:DTe,readdir:LTe}=require("fs/promises"),{totalmem:fj}=require("os"),af=(B(),C(G)),Ej=ce(),Ti=Y(),{randomBytes:MTe}=require("crypto"),{_assignPackageExport:vTe}=yi(),_j=1024*1024,fc=[],Gs=[],UTe=50,AP=1e4,xTe="restart",gj="request_thread_info",Sj="resource_report",Tj="thread_info",Aj="added-port",BTe="ack",mP;vTe("threads",Gs);Ai.exports={startWorker:EP,restartWorkers:yP,shutdownWorkers:qTe,workers:fc,setMonitorListener:QTe,onMessageFromWorkers:$Te,onMessageByType:Ij,broadcast:KTe,broadcastWithAcknowledgement:WTe,setChildListenerByType:GTe,getWorkerIndex:Rj,getWorkerCount:yj,getTicketKeys:Oj,setMainIsWorker:kTe,setTerminateTimeout:HTe,restartNumber:so?.restartNumber||1};Gs.onMessageByType=Ij;Gs.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Gs.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Ai.exports.whenThreadsStarted=new Promise(e=>{Ai.exports.threadsHaveStarted=e});var RP;function HTe(e){AP=e}a(HTe,"setTerminateTimeout");function Rj(){return so?so.workerIndex:RP?0:void 0}a(Rj,"getWorkerIndex");function yj(){return so?so.workerCount:RP?1:void 0}a(yj,"getWorkerCount");function kTe(e){RP=e,Ai.exports.threadsHaveStarted()}a(kTe,"setMainIsWorker");var bj=1,iA;function Oj(){return iA||(iA=TP?MTe(48):so.ticketKeys,iA)}a(Oj,"getTicketKeys");Object.defineProperty(mj,"workerIndex",{get(){return Rj()}});Object.defineProperty(mj,"workerCount",{get(){return yj()}});var Nj={[gj](e,t){zTe(t)},[Sj](e,t){jTe(t,e)}};function EP(e,t={}){let r=process.constrainedMemory?.()||fj();r=Math.min(r,fj(),2e4*_j);let n=Ej.get(af.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/_j/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Gs){let u=new NTe;u.existingPort=l,i.push(u),o.push(u.port2)}PTe(e)||(e+=".js");let c=new OTe(CTe(e)?e:hj(ITe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:bj=t.threadCount,name:t.name,restartNumber:Ai.exports.restartNumber,ticketKeys:Oj()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:Aj,port:l,threadId:c.threadId},[l]);return aA(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>EP(e,t),c.on("error",l=>{Ti.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{fc.splice(fc.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<UTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,EP(e,t)):Ti.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{Nj[l.type]?.(l,c)}),fc.push(c),XTe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(EP,"startWorker");var FTe=[af.THREAD_TYPES.HTTP];async function yP(e=null,t=Math.max(bj>3,1),r=!0){if(TP){try{process.chdir(process.cwd())}catch(o){Ti.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=qT();await o()}Ai.exports.restartNumber++,t<1&&(t=t*fc.length);let n=[],s=[];for(let o of fc.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Ti.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ai.exports.restartNumber,type:af.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=FTe.indexOf(o.name)>-1,l=new Promise(u=>{let f=setTimeout(()=>{Ti.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},AP*2).unref();o.on("exit",()=>{clearTimeout(f),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),f=new Promise(d=>{let p=a(_=>{_.type===af.ITC_EVENT_TYPES.CHILD_STARTED&&(Ti.trace("Worker has started",u.threadId),d(),s.splice(s.indexOf(f)),u.off("message",p))},"startListener");Ti.trace("Waiting for worker to start",u.threadId),u.on("message",p)});s.push(f),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=za();r&&(e==="http"||!e)&&Ej.get(af.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else no.postMessage({type:xTe,workerType:e})}a(yP,"restartWorkers");function GTe(e,t){Nj[e]=t}a(GTe,"setChildListenerByType");function qTe(e){return yP(e,1/0,!1)}a(qTe,"shutdownWorkers");var wj=[];function $Te(e){wj.push(e)}a($Te,"onMessageFromWorkers");var gP=new Map;function Ij(e,t){let r=gP.get(e);r||gP.set(e,r=[]),r.push(t)}a(Ij,"onMessageByType");var VTe=10;async function KTe(e,t){let r=0;for(let n of Gs)try{n.postMessage(e),r++>VTe&&(r=0,await new Promise(setImmediate))}catch(s){Ti.error("Unable to send message to worker",s)}t&&Pj(e,null)}a(KTe,"broadcast");var oA=new Map,YTe=1;function WTe(e){return new Promise(t=>{let r=0;for(let n of Gs)try{let s=YTe++,i=a(()=>{oA.delete(s),--r===0&&t(),n!==no&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,oA.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of oA)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Ti.error("Unable to send message to worker",s)}r===0&&t()})}a(WTe,"broadcastWithAcknowledgement");function zTe(e){e.postMessage({type:Tj,workers:Cj()})}a(zTe,"sendThreadInfo");function Cj(){let e=Date.now();return fc.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(Cj,"getChildWorkerInfo");function jTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(jTe,"recordResourceReport");var SP;function QTe(e){SP=e}a(QTe,"setMonitorListener");var JTe=1e3,pj=!1;function XTe(){pj||(pj=!0,setInterval(()=>{for(let e of fc){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}SP&&SP()},JTe).unref())}a(XTe,"startMonitoring");var ZTe=1e3;if(no&&so?.addPorts){aA(no);for(let e=0,t=so.addPorts.length;e<t;e++){let r=so.addPorts[e];r.threadId=so.addThreadIds[e],aA(r)}setInterval(()=>{let e=process.memoryUsage();no.postMessage({type:Sj,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},ZTe).unref(),mP=a(()=>new Promise((e,t)=>{no.on("message",r),no.postMessage({type:gj});function r(n){n.type===Tj&&(no.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else mP=Cj;Ai.exports.getThreadInfo=mP;function aA(e,t){Gs.push(e),e.on("message",r=>{if(r.type===Aj)r.port.threadId=r.threadId,aA(r.port);else if(r.type===BTe){let n=oA.get(r.id);n&&n()}else Pj(r,e)}).on("close",()=>{Gs.splice(Gs.indexOf(e),1)}).on("exit",()=>{Gs.splice(Gs.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(aA,"addPort");function Pj(e,t){for(let n of wj)n(e,t);let r=gP.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Ti.error(s)}}a(Pj,"notifyMessageListeners");if(TP){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await LTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(hj(s,o.name));try{for await(let{filename:o}of DTe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await yP(),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");Ai.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else no.on("message",async e=>{let{type:t}=e;t===af.ITC_EVENT_TYPES.SHUTDOWN&&(Ai.exports.restartNumber=e.restartNumber,no.unref(),setTimeout(()=>{Ti.warn("Thread did not voluntarily terminate",wTe),process.exit(0)},AP).unref())})});var fB={};ve(fB,{ACTION_32_BIT:()=>Wm,ACTION_64_BIT:()=>rAe,AUDIT_STORE_OPTIONS:()=>xp,Decoder:()=>hl,HAS_BLOBS:()=>$n,HAS_CURRENT_RESIDENCY_ID:()=>xc,HAS_EXPIRATION_EXTENDED_TYPE:()=>n_,HAS_ORIGINATING_OPERATION:()=>r_,HAS_PREVIOUS_RESIDENCY_ID:()=>Bc,REMOTE_SEQUENCE_UPDATE:()=>vg,createAuditEntry:()=>bu,getLastRemoved:()=>EN,openAuditStore:()=>uA,readAuditEntry:()=>Nt,removeAuditEntry:()=>dA,setAuditRetention:()=>tAe,transactionKeyEncoder:()=>kj});function uA(e){let t=e.auditStore=e.openDB(bP.AUDIT_STORE_NAME,{create:!1,...xp});t||(t=e.auditStore=e.openDB(bP.AUDIT_STORE_NAME,xp),Lj(t,1)),t.rootStore=e,t.tableStores=[];let r=[];t.addDeleteRemovalCallback=function(l,u,f){return r[l]=f,t.tableStores[l]=u,t.deleteCallbacks=r,{remove(){delete r[l]}}};let n=null,s,i=0,o=NP;Ah(t.env.path,l=>{if(i=l,l)return c(100)});function c(l){l&&(o=l),clearTimeout(n);let u=new Promise(f=>{n=setTimeout(async()=>{if(await s,s=u,t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let d=0,p,_;try{for(let{key:h,value:S}of t.getRange({start:1,snapshot:!1,end:Date.now()-OP/(1+i*i)})){try{p=dA(t,h,S)}catch(g){cf.warn("Error removing audit entry",g)}if(_=h,await new Promise(setImmediate),++d>=eAe){o=10;break}}await p}finally{d===0?o=Math.min(o<<1,OP/10):(Lj(t,_),o>100&&(o=o>>1)),f(void 0),c()}},o).unref()});return u}if(a(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,Lh.getWorkerIndex)()===(0,Lh.getWorkerCount)()-1&&c(),(0,Lh.getWorkerIndex)()===0&&!Dj)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Dj=!0,cf.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function dA(e,t,r){let n=nAe(r),s;if(n&$n){s=Nt(r);let i=e.tableStores[s.tableId],o=i.getEntry(s.recordId);(!o||o.version!==s.version||!o.value)&&Dc(()=>Aa(s.getValue(i)),i.rootStore)}if((n&15)===wP){s=s||Nt(r);let i=s.tableId;e.tableStores[s.tableId].getEntry(s.recordId).version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function Lj(e,t){IP[0]=t,e.put(Symbol.for("last-removed"),Fj)}function EN(e){let t=e.get(Symbol.for("last-removed"));if(t)return Fj.set(t),IP[0]}function tAe(e,t=NP){OP=e,NP=t}function bu(e,t,r,n,s,i,o,c,l,u,f,d,p){let _=Gj[o];if(!_)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?_c.setFloat64(0,n):qs.set(KR),h=9),l){if(l&255)throw new Error("Illegal extended type");h+=3}A(s),A(t),g(r),_c.setFloat64(h,e),h+=8,l&xc&&A(u),l&Bc&&A(f),l&n_&&(_c.setFloat64(h,d),h+=8),l&r_&&A(qj[p]),i?g(i):qs[h++]=0,l?_c.setUint32(n?8:0,_|l|3221225472):qs[n?8:0]=_;let S=qs.subarray(0,h);if(c)return Buffer.concat([S,c]);return S;function g(E){let R=h;h+=1,h=(0,zl.writeKey)(E,qs,h);let N=h-R-1;N>127?N>16383?(cf.error("Key or username was too large for audit entry",E),h=R+1,qs[R]=0):(qs.copyWithin(R+2,R+1,h),_c.setUint16(R,N|32768),h++):qs[R]=N}function A(E){E<128?qs[h++]=E:E<16384?(_c.setUint16(h,E|32768),h+=2):E<1056964608?(_c.setUint32(h,E|3221225472),h+=4):(qs[h]=255,_c.setUint32(h+1,E),h+=5)}}function nAe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new hl(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Nt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new hl(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,f=n.position+=l,d=n.readFloat64(),p,_,h,S;if(i&xc&&(p=n.readInt()),i&Bc&&(_=n.readInt()),i&n_&&(h=n.readFloat64()),i&r_){let E=n.readInt();S=qj[E]}l=n.readInt();let g=n.position,A=n.position+=l;return{type:Gj[i&7],tableId:c,nodeId:o,get recordId(){return(0,zl.readKey)(e,u,f)},getBinaryRecordId(){return e.subarray(u,f)},version:d,previousLocalTime:s,get user(){return A>g?(0,zl.readKey)(e,g,A):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(E,R,N){if(i&cA||i&Dh&&!R)return Dc(()=>E.decoder.decode(e.subarray(n.position,r)),E.rootStore);if(i&Dh&&N)return Gb(E.getEntry(this.recordId),N,E)},getBinaryValue(){return i&(cA|Dh)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:p,previousResidencyId:_,expiresAt:h,originatingOperation:S}}catch(n){return cf.error("Reading audit entry error",n,e),{}}}var zl,lA,bP,Lh,Hj,cf,qs,_c,kj,xp,OP,eAe,IP,Fj,NP,Dj,cA,Dh,Mj,wP,vj,Uj,xj,Bj,Wm,rAe,vg,xc,Bc,r_,n_,$n,Gj,qj,hl,ho=be(()=>{zl=require("ordered-binary"),lA=M(ce()),bP=M(vt());B();Lh=M(tt()),Hj=M(oe());Ou();cf=M(Y());xE();As();vT();(0,lA.initSync)();qs=Buffer.alloc(2816),_c=new DataView(qs.buffer,qs.byteOffset,2816),kj={writeKey(e,t,r){return e===t_?(t.set(t_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,zl.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,zl.readKey)(e,t,r)}},xp={encoding:"binary",keyEncoder:kj},OP=(0,Hj.convertToMS)((0,lA.get)(x.LOGGING_AUDITRETENTION))||86400*3,eAe=1e3,IP=new Float64Array(1),Fj=new Uint8Array(IP.buffer),NP=1e4,Dj=!1;a(uA,"openAuditStore");a(dA,"removeAuditEntry");a(Lj,"updateLastRemoved");a(EN,"getLastRemoved");a(tAe,"setAuditRetention");cA=16,Dh=32,Mj=1,wP=2,vj=3,Uj=4,xj=5,Bj=6,Wm=14,rAe=15,vg=11,xc=512,Bc=1024,r_=2048,n_=4096,$n=8192,Gj={put:Mj|cA,[Mj]:"put",delete:wP,[wP]:"delete",message:vj|cA,[vj]:"message",invalidate:Uj|Dh,[Uj]:"invalidate",patch:xj|Dh,[xj]:"patch",relocate:Bj,[Bj]:"relocate"},qj={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(bu,"createAuditEntry");a(nAe,"readAction");a(Nt,"readAuditEntry");hl=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});function DP(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Vj,sAe(e.primaryStore,e.auditStore)):(c=$j,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{Kj($j[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=gu(t);let f=new PP(r);f.startTime=n;let d=u.get(t);return d?d.push(f):(u.set(t,d=[f]),d.tables=u,d.key=t),f.subscriptions=d,f}function Kj(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),Yj(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Nt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=gu(c),u=0;do{let f=o.get(l);if(f){for(let p of f)if(!(u>0&&!(p.includeDescendants&&!(p.onlyChildren&&u>1)))){if(p.startTime>=n){(0,CP.info)("omitting",c,p.startTime,n);continue}try{let _;p.supportsTransactions&&p.txnInProgress!==i.version&&(_=!0,p.txnInProgress||(r?r.push(p):r=[p]),p.txnInProgress=i.version),p.listener(c,i,n,_)}catch(_){console.error(_),(0,CP.info)(_)}}}if(l==null)break;let d=l.lastIndexOf?.("/",l.length-2);d!==l.length-1&&u++,d>-1?l=l.slice(0,d+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function sAe(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=Vj[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{Kj(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function Yj(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function UF(e){return e.nextTransaction||(DP({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),Yj(e)),e.nextTransaction}var CP,$j,Vj,PP,gN=be(()=>{CP=M(Y());_u();Su();ho();$j=Object.create(null),Vj=Object.create(null);a(DP,"addSubscription");PP=class extends kn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(Kj,"notifyFromTransactionData");a(sAe,"listenToCommits");a(Yj,"nextTransaction");a(UF,"whenNextTransaction")});var bI={};ve(bI,{EVICTED:()=>Ea,INVALIDATED:()=>Fn,coerceType:()=>pA,makeTable:()=>mA,setServerUtilities:()=>fAe});function mA(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:f,sealed:d,splitSegments:p,replicate:_}=e,{expirationMS:h,evictionMS:S,audit:g,trackDeletes:A}=e;S??=0;let{attributes:E}=e;E||(E=[]);let R=zR(i,n,l),N,v,k={},F=Promise.resolve(),K,re,ae;for(let z of E)(z.assignCreatedTime||z.name==="__createdtime__")&&(K=z),(z.assignUpdatedTime||z.name==="__updatedtime__")&&(re=z),z.expiresAt&&(ae=z),z.isPrimaryKey&&(k=z);let Z,se=[],W=[],he=1,Te=2,Ce={},me={},Xt=864e5,ct=0,yr,gs,Bn,su=!1,iu,xA=new Map,BA=new Map,Dt,mf,jh=Ql.get(x.REPLICATION_DATABASES);if(Array.isArray(jh)){for(let z of jh)if(z.name===c&&z.replicateTo>=0){mf=z.replicateTo;break}}let Qh=i.getRange({start:!1,end:!1}).constructor,Ef=10,Jh=6;g&&Tf(),Ah(i.env.path,z=>{if(v)return ca(z)});class De extends Vr{#e;#t;#n;#r;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=o;static databaseName=c;static attributes=E;static replicate=_;static sealed=d;static splitSegments=p??!0;static createdTimeProperty=K;static updatedTimeProperty=re;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=f;static schemaDefined=u;static sourcedFrom(m,T){if(T&&(this.sourceOptions=T,(T.expiration||T.eviction||T.scanInterval)&&this.setTTLExpiration(T)),T?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(b=>!b.intermediateSource)){if(this.sources.some(b=>b.name===m.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(m)}v=v||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),N=N||m.load;let O=a(b=>{let U=this.sources;if(U=U.filter(L=>L.intermediateSource&&L[b]&&(!L[b].reliesOnPrototype||L.prototype[b])),U.length>0)if(U.length===1){let L=U[0];return(P,H,$)=>{if(P?.source!==L)return L[b](H,$,P)}}else return(L,P,H)=>{let $=[];for(let j of U){if(L?.source===j)break;$.push(j[b](P,H,L))}return Promise.all($)}},"getApplyToIntermediateSource"),w=this.sources[this.sources.length-1];w.intermediateSource&&(w={});let y=a(b=>{if(w[b]&&(!w[b].reliesOnPrototype||w.prototype[b]))return(U,L,P)=>{if(!U?.source)return w[b](L,P,U)}},"getApplyToCanonicalSource");Ce={put:y("put"),patch:y("patch"),delete:y("delete"),publish:y("publish")},me={put:O("put"),patch:O("patch"),delete:O("delete"),publish:O("publish"),invalidate:O("invalidate")};let D=w.shouldRevalidateEvents;return(async()=>{let b=!1,U,L=a(async(P,H)=>{let $=P.value,j=P.table?$e[c][P.table]:De;if(c===yf&&(P.table===du.ROLE_TABLE_NAME||P.table===du.USER_TABLE_NAME)&&(b=!0),P.id===void 0&&(P.id=$[j.primaryKey],P.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(P));P.source=m;let Q={residencyId:uu(P.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:P.nodeId},q=await j.getResource(P.id,H,Q);switch(P.finished&&await P.finished,P.type){case"put":return D?q._writeInvalidate(Q):q._writeUpdate($,!0,Q);case"patch":return D?q._writeInvalidate(Q):q._writeUpdate($,!1,Q);case"delete":return q._writeDelete(Q);case"publish":return q._writePublish($,Q);case"invalidate":return q._writeInvalidate(Q);case"relocate":return q._writeRelocate(Q);default:xe.default.error?.("Unknown operation",P.type,P.id)}},"writeUpdate");try{let P=m.subscribe;P&&A==null&&(A=!0);let H={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},$=m.subscribeOnThisThread?m.subscribeOnThisThread((0,jl.getWorkerIndex)(),H):(0,jl.getWorkerIndex)()===0,j=P&&$&&await m.subscribe?.(H);if(j){let Q;for await(let q of j)try{if(!(q.type==="transaction"?q.writes[0]:q)){xe.default.error?.("Bad subscription event",q);continue}if(q.source=m,q.type==="end_txn"){if(Q?.resolve(),q.localTime&&U!==q.localTime){if(q.remoteNodeIds?.length>0){let fe=[Symbol.for("seq"),q.remoteNodeIds[0]],ie=f.get(fe),J=ie?.nodes;J||(J=[]);for(let ye of q.remoteNodeIds.slice(1)){let Re=J.find(Be=>Be.id===ye);J=J.filter(Be=>Be.id!==ye||Be===Re),Re||(Re={id:ye,seqId:0},J.push(Re)),Re.seqId=Math.max(ie?.seqId??1,q.localTime),ye===Q?.nodeId&&(Re.lastTxnTime=q.timestamp)}let le=Math.max(ie?.seqId??1,q.localTime);xe.default.trace?.("Received txn",c,new Date(le),new Date(q.localTime),q.remoteNodeIds),f.put(fe,{seqId:le,nodes:J})}U=q.localTime}q.onCommit&&Q?.committed.then(q.onCommit);continue}if(Q)if(q.beginTxn)Q.resolve();else{Q.write_promises.push(L(q,Q));continue}!q.timestamp&&q.version&&(q.timestamp=q.version);let te=Ot(q,()=>{if(q.type==="transaction"){let fe=[];for(let ie of q.writes)try{fe.push(L(ie,q))}catch(J){throw J.message+=" writing "+JSON.stringify(ie)+" of event "+JSON.stringify(q),J}return Promise.all(fe)}else if(q.type==="define_schema"){let fe=this.attributes.slice(0),ie;for(let J of q.attributes)fe.find(le=>le.name===J.name)||(fe.push(J),ie=!0);ie&&(lt({table:s,database:c,attributes:fe,origin:"cluster"}),vh.signalSchemaChange(new Uh.SchemaEventMsg(process.pid,$t.CREATE_TABLE,c,s)))}else return q.beginTxn?(Q=q,Q.write_promises=[L(q,q)],new Promise(fe=>{Q.resolve=()=>fe(Promise.all(Q.write_promises))})):L(q,q)});Q&&(Q.committed=te),b&&te&&!te?.waitingForUserChange&&(te.then(()=>vh.signalUserChange(new Uh.UserEventMsg(process.pid))),te.waitingForUserChange=!0),q.onCommit&&(te?te.then(q.onCommit):q.onCommit())}catch(ue){xe.default.error?.("error in subscription handler",ue)}}}catch(P){xe.default.error?.(P)}})(),this}static get isCaching(){return v}static get shouldRevalidateEvents(){return this.prototype.get!==De.prototype.get}static getResource(m,T,O){let w=super.getResource(m,T,O);if(m!=null){Ir(m);try{if(w.getRecord?.())return w;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let y=!O?.async||i.cache?.get?.(m),D=Gr(T),b=D.getReadTxn();if(b?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return ou(m,T,{transaction:b,ensureLoaded:O?.ensureLoaded},y,U=>{if(U?De._updateResource(w,U):w.#e=null,T.onlyIfCached&&T.noCacheStore){if(!w.doesExist())throw new wr.ServerError("Entry is not cached",504)}else if(O?.ensureLoaded){let L=dn(m,U,T,w);if(L)return D?.disregardReadTxn(),w.#i=!0,MP(L,P=>(De._updateResource(w,P),w))}return w})}catch(y){throw y.message.includes("Unable to serialize object")&&(y.message+=": "+JSON.stringify(m)),y}}return w}static _updateResource(m,T){m.#r=T,m.#e=T?.value??null,m.#n=T?.version}ensureLoaded(){let m=dn(this.getId(),this.#r,this.getContext());if(m)return this.#i=!0,MP(m,T=>{this.#r=T,this.#e=T.value,this.#n=T.version})}static getNewId(){let m=k?.type;if(m==="String"||m==="ID")return super.getNewId();if(!Dt){let y=i.getEntry(Symbol.for("id_allocation")),D=y?.value,b;if(D&&D.nodeName===server.hostname&&(!pAe(i)||D.pid===process.pid)){let U=D.start,L=D.end;b=U;for(let P of i.getKeys({start:L,end:U,limit:1,reverse:!0}))b=P}else D=w(y?.version??null),b=D.start;Dt=new BigInt64Array([BigInt(b)+1n]),Dt=new BigInt64Array(i.getUserSharedBuffer("id",Dt.buffer)),Dt.maxSafeId=D.end}let T=Number(Atomics.add(Dt,0,1n)),O=m==="Int"?512:1048576;if(T+O>=Dt.maxSafeId){let y=a(D=>{Dt.maxSafeId=T+(m==="Int"?1023:4194303);let b=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,U=D?void 0:i.useReadTransaction(),L=Number(Dt[0]);for(let $ of i.getKeys({start:L+1,end:b,limit:1,transaction:U}))b=$;U?.done();let{value:P,version:H}=i.getEntry(Symbol.for("id_allocation"));if(Dt.maxSafeId<b){if(P.end>Dt.maxSafeId-100)return;xe.default.info?.("New id allocation",T,Dt.maxSafeId,H),i.put(Symbol.for("id_allocation"),{start:P.start,end:Dt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),H)}else{xe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${Dt.maxSafeId}, but id of ${b} detected`);let $=w(H);$.alreadyUpdated||Atomics.store(Dt,0,BigInt($.start+1)),Dt.maxSafeId=$.end}},"updateEnd");T+O===Dt.maxSafeId?setImmediate(y):T+100>=Dt.maxSafeId&&(xe.default.warn?.(`Synchronous id allocation required on table ${s}${m=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>y(!0)))}return T;function w(y){let D=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,b=D/4,U,L,P=!1,H,$;do{H=Math.floor(Math.random()*D),$={start:H,end:H+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},U=0;for(let j of i.getKeys({start:H,limit:1,reverse:!0}))U=j;L=D;for(let j of i.getKeys({start:H+1,end:D,limit:1}))L=j;b*=.875,b<1e3&&!P&&(P=!0,xe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${m==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,H,U,L,b))}while(!(b<L-H&&(b<H-U||U===0)));return i.transactionSync(()=>{let j=i.getEntry(Symbol.for("id_allocation"));return(j?.version??null)==y?(xe.default.info?.("Allocated new id range",$),i.put(Symbol.for("id_allocation"),$,Date.now()),$):(xe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...j.value})})}}static setTTLExpiration(m){if(typeof m=="number")h=m*1e3,S||(S=0);else if(m&&typeof m=="object")h=m.expiration*1e3,S=(m.eviction||0)*1e3,Xt=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Xt=Xt||(h+S)/4,ca()}static getResidencyRecord(m){return f.get([Symbol.for("residency_by_id"),m])}static setResidency(m){De.getResidency=m}static setResidencyById(m){De.getResidencyById=m}static getResidency(m,T,O){if(De.getResidencyById)return De.getResidencyById(m[t]);let w=mf;if(T.replicateTo!=null){if(Array.isArray(T.replicateTo))return T.replicateTo.includes(server.hostname)?T.replicateTo:[server.hostname,...T.replicateTo];T.replicateTo>=0&&(w=T.replicateTo)}if(w>=0&&server.nodes){let y=[server.hostname];if(O)y.push(...O.slice(0,w));else{let D=server.nodes.map(L=>L.name),b=Math.floor(D.length*Math.random());y.push(...D.slice(b,b+w));let U=b+w-D.length;U>0&&y.push(...D.slice(0,U))}return y}}static enableAuditing(m=!0){g=m,m&&Tf(),De.audit=m}static coerceId(m){return m===""?null:pA(m,k)}static async dropTable(){delete $e[c][s];for(let m of i.getRange({versions:!0,snapshot:!1,lazy:!0}))m.metadataFlags&$n&&m.value&&Aa(m.value);if(c===o){for(let m of E)f.remove(De.tableName+"/"+m.name),r[m.name]?.drop();f.remove(De.tableName+"/"),i.drop(),await f.committed}else console.log("legacy dropTable"),await i.close(),await _A.default.remove(data_path),await _A.default.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));vh.signalSchemaChange(new Uh.SchemaEventMsg(process.pid,$t.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this.isCollection)return this.search(m);if(this.getId()===null)return m?.conditions?this.search(m):{records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:E};if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(m,T){let O=Sf(m);if(O?.read){if(O.isSuperUser)return!0;let w=O.attribute_permissions,y=T?.select;if(w?.length>0||su&&y){if(T||(T={}),y){let D=w?.length>0&&LP(w,"read");T.select=y.map(b=>{let U=b.name||b;if(!D||D[U]){let L=Bn[U]?.definition?.tableClass;if(L){if(b.name||(b={name:b}),!L.prototype.allowRead.call(null,m,b))return!1;if(!b.select)return b.name}return b}}).filter(Boolean)}else T.select=w.filter(D=>D.read&&!Bn[D.attribute_name]).map(D=>D.attribute_name);return T}else return!0}}allowUpdate(m,T){let O=Sf(m);if(O?.update){let w=O.attribute_permissions;if(w?.length>0){let y=LP(w,"update");for(let D in T)if(!y[D])return!1;for(let D of w){let b=D.attribute_name;!D.update&&!(b in T)&&(T[b]=this.getProperty(b))}}return aa(this.getContext())}}allowCreate(m,T){if(this.isCollection){let O=Sf(m);if(O?.insert){let w=O.attribute_permissions;if(w?.length>0){let y=LP(w,"insert");for(let D in T)if(!y[D])return!1;return aa(this.getContext())}else return aa(this.getContext())}}else return this.allowUpdate(m,{})}allowDelete(m){return Sf(m)?.delete&&aa(this.getContext())}update(m,T){if(!Gr(this.getContext()))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let w;return typeof m=="object"&&m&&(T?(Object.isFrozen(m)&&(m={...m}),this.#e={},this.#t=m):(w=this.#t,w&&(m=Object.assign(w,m)),this.#t=m)),this._writeUpdate(this.#t,T),this}addTo(m,T){if(typeof T=="number"||typeof T=="bigint")this.#s===zj?this.set(m,(+this.getProperty(m)||0)+T):(this.#s||this.update(),this.set(m,new kE(T)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,T){if(typeof T=="number")return this.addTo(m,-T);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#r}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(m){this.#t=m}setRecord(m){this.#e=m}invalidate(){this._writeInvalidate()}_writeInvalidate(m){let T=this.getContext(),O=this.getId();Ir(O),Gr(this.getContext()).addWrite({key:O,store:i,invalidated:!0,entry:this.#r,before:Ce.invalidate?.bind(this,T,O),beforeIntermediate:me.invalidate?.bind(this,T,O),commit:a((y,D)=>{if(oa(y,D,m?.nodeId)<=0)return;let b=null;for(let U in r)b||(b={}),b[U]=this.getProperty(U);xe.default.trace?.(`Invalidating entry id: ${O}, timestamp: ${new Date(y).toISOString()}`),R(O,b,this.#r,y,Fn,g,{user:T?.user,residencyId:m?.residencyId,nodeId:m?.nodeId},"invalidate")},"commit")})}_writeRelocate(m){let T=this.getContext(),O=this.getId();Ir(O),Gr(this.getContext()).addWrite({key:O,store:i,invalidated:!0,entry:this.#r,before:Ce.relocate?.bind(this,T,O),beforeIntermediate:me.relocate?.bind(this,T,O),commit:a((y,D)=>{if(oa(y,D,m?.nodeId)<=0)return;let b=De.getResidencyRecord(m.residencyId),U=0,L=null,P=D?.value;if(b&&!b.includes(server.hostname)){for(let H in r)L||(L={}),L[H]=P(H);U=Fn}else L=P;xe.default.trace?.(`Relocating entry id: ${O}, timestamp: ${new Date(y).toISOString()}`),R(O,L,this.#r,y,U,g,{user:T.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(m,T){let O={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},w=this.getResidency(T.value,O),y;if(w){if(!Array.isArray(w))throw new Error("Residency must be an array, but was: "+w);if(!w.includes(server.hostname))return;y=uu(w)}let b=R(m.key,T.value,m,m.version,0,!0,{residencyId:y,expiresAt:T.expiresAt},"relocate",!1,null)}static evict(m,T,O){let w=this.Source,y;if(!((v||g)&&(!T||(y=i.getEntry(m),!y||!T)||y.version!==O))){if(v){if(i.hasLock(m,y.version))return;let D;for(let b in r)D||(D={}),D[b]=T[b];if(D)return R(m,D,y,O,Ea,null,null,null,!0)}if(i.ifVersion(m,O,()=>{un(m,T,null)}),g)return R(m,null,y,O,Ea,null,null,null,!0);Uc(i,y??i.getEntry(m),O)}}lock(){throw new Error("Not yet implemented")}static operation(m,T){return m.table||=s,m.schema||=c,rQ.operation(m,T)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,T,O){let w=this.getContext(),y=Gr(w),D=this.getId();Ir(D);let b=this.#r;this.#s=T?zj:lAe;let U={key:D,store:i,entry:b,nodeName:w?.nodeName,validate:a(L=>{m||(m=this.#t),T||m&&BE(this.#t===m?this:m)?w?.source||(y.checkOverloaded(),this.validate(m,!T),re&&(m[re.name]=re.type==="Date"?new Date(L):re.type==="String"?new Date(L).toISOString():L),T&&(t&&m[t]!==D&&(m[t]=D),K&&(b?.value?m[K.name]=b?.value[K.name]:m[K.name]=K.type==="Date"?new Date(L):K.type==="String"?new Date(L).toISOString():L),m=el(m))):y.removeWrite(U)},"validate"),before:T?Ce.put?()=>Ce.put(w,D,m):null:Ce.patch?()=>Ce.patch(w,D,m):Ce.put?()=>Ce.put(w,D,el(this)):null,beforeIntermediate:T?me.put?()=>me.put(w,D,m):null:me.patch?()=>me.patch(w,D,m):me.put?()=>me.put(w,D,el(this)):null,commit:a((L,P,H)=>{if(H){if(w&&P?.version>(w.lastModified||0)&&(w.lastModified=P.version),this.#r=P,P?.value&&P.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");T||(this.#e=P?.value??null)}this.#t=void 0,this.#n=L;let $=P?.value,j=m;this.#s=0;let Q=!1,q=oa(L,P,O?.nodeId),ue;if(q<=0)if(g){let le=P.localTime,ye=P.version;xe.default.trace?.("Applying CRDT update to record with id: ",D,"applying later update:",ye);let Re=[];for(;le>L||ye>=L&&le>0;){let Be=l.get(le);if(!Be)break;let it=Nt(Be);if(ye=it.version,ye>=L){if(ye===L){if(q=oa(L,{version:ye,localTime:le},O?.nodeId),q===0)return;if(q>0)continue}if(it.type==="patch")Re.push(it),ue=m;else if(it.type==="put"||it.type==="delete")return}le=it.previousLocalTime}Re.sort((Be,it)=>Be.version-it.version);for(let Be of Re){let it=Be.getValue(i);if(j=UE(j,it,T),xe.default.debug?.("Rebuilding update with future patch:",j),!j)return}}else{if(T)return;j=UE(j,$,T),xe.default.debug?.("Rebuilding update without audit:",j)}let te;if(T?te=j:(this.#e=$,te=el(this,j)),this.#e=te,te&&te.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let fe;if(O?.residencyId!=null)fe=O.residencyId;else{b?.residencyId&&(w.previousResidency=De.getResidencyRecord(b.residencyId));let le=De.getResidency(te,w);if(le){if(!Array.isArray(le))throw new Error("Residency must be an array, got: "+le);if(!le.includes(server.hostname))if(ue??=te,Q=!0,De.getResidencyById)te=void 0;else{te=null;for(let ye in r)te||(te={}),te[ye]=ue[ye]}}fe=uu(le)}T||(ue=m);let ie=w?.expiresAt??(h?h+Date.now():-1);xe.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(L).toISOString()}${ie?", expires at: "+new Date(ie).toISOString():""}${P?", replaces entry from: "+new Date(P.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(te).slice(0,100)}catch{return""}})()),un(D,$,te);let J=T?"put":"patch";R(D,te,P,L,Q?Fn:0,g,{omitLocalRecord:Q,user:w?.user,residencyId:fe,expiresAt:ie,nodeId:O?.nodeId,originatingOperation:w?.originatingOperation},J,!1,ue),w.expiresAt&&ca()},"commit")};y.addWrite(U)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this.isCollection){for await(let T of this.search(m))(await De.getResource(T[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this.#e?this._writeDelete(m):!1}_writeDelete(m){let T=Gr(this.getContext()),O=this.getId();Ir(O);let w=this.getContext();return T.addWrite({key:O,store:i,entry:this.#r,nodeName:w?.nodeName,before:Ce.delete?.bind(this,w,O),beforeIntermediate:me.delete?.bind(this,w,O),commit:a((y,D,b)=>{let U=D?.value;b&&(w&&D?.version>(w.lastModified||0)&&(w.lastModified=D.version),De._updateResource(this,D)),!(oa(y,D,m?.nodeId)<=0)&&(un(this.getId(),U),xe.default.trace?.(`Deleting record with id: ${O}, txn timestamp: ${new Date(y).toISOString()}`),g||A?(R(O,null,this.#r,y,0,g,{user:w?.user,nodeId:m?.nodeId},"delete"),g||ca()):Uc(i,D))},"commit")}),!0}search(m){let T=this.getContext(),O=Gr(T);if(!m)throw new Error("No query provided");let w=m.conditions;w?w.length===void 0&&(w=w[Symbol.iterator]?Array.from(w):[w]):w=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this.getId()&&(w=[{attribute:null,comparator:Array.isArray(this.getId())?"prefix":"starts_with",value:this.getId()}].concat(w));let y,D={};function b(J,le){let ye;switch(le){case"and":case void 0:if(J.length<1)throw new Error('An "and" operator requires at least one condition');ye=!0;break;case"or":if(J.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+le)}for(let Re of J){if(Re.conditions){Re.conditions=b(Re.conditions,Re.operator);continue}let Be=Re[0]??Re.attribute,it=Be==null?k:wi(E,Be);if(it)(it.type||fR[Re.comparator])&&(Re[1]===void 0?Re.value=L(Re.value,it):Re[1]=L(Re[1],it));else if(Be!=null)throw(0,wr.handleHDBError)(new Error,`${Be} is not a defined attribute`,404);if(Re.chainedConditions)if(Re.chainedConditions.length===1&&(!Re.operator||Re.operator=="and")){let Cr=Re.chainedConditions[0],qr,Ae;if(Cr.comparator==="gt"||Cr.comparator==="greater_than"||Cr.comparator==="ge"||Cr.comparator==="greater_than_equal"?(qr=Re,Ae=Cr):(qr=Cr,Ae=Re),qr.comparator!=="lt"&&qr.comparator!=="less_than"&&qr.comparator!=="le"&&qr.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let et=Ae.comparator==="ge"||Ae.comparator==="greater_than_equal",Lt=qr.comparator==="le"||qr.comparator==="less_than_equal";Re.comparator=(et?"ge":"gt")+(Lt?"le":"lt"),Re.value=[Ae.value,qr.value]}else throw new Error("Multiple chained conditions are not currently supported")}return J}a(b,"prepareConditions");function U(J,le){if(m.enforceExecutionOrder)return J;for(let ye of J)ye.conditions&&(ye.conditions=U(ye.conditions,ye.operator));return J.length>1&&le!=="or"?(0,eQ.sortBy)(J,ym(De)):J}a(U,"orderConditions");function L(J,le){return Array.isArray(J)?J.map(ye=>pA(ye,le)):pA(J,le)}a(L,"coerceTypedValues");let P=m.operator;(w.length>0||P)&&(w=b(w,P));let H=typeof m.sort=="object"&&m.sort,$;if(H&&P!=="or"){let J=H.attribute;if(J==null)throw new wr.ClientError("Sort requires an attribute");if(y=w.find(le=>Eu(le.attribute)===Eu(J)),!y){let le=wi(E,J);if(!le)throw(0,wr.handleHDBError)(new Error,`${Array.isArray(J)?J.join("."):J} is not a defined attribute`,404);if(le.indexed)y={attribute:J,comparator:"sort"},w.push(y);else if(w.length===0&&!m.allowFullScan)throw(0,wr.handleHDBError)(new Error,`${Array.isArray(J)?J.join("."):J} is not indexed and not combined with any other conditions`,404)}y&&(y.descending=!!H.descending)}w=U(w,P),H&&(y&&w[0]===y?H.next&&($={dbOrderedAttribute:H.attribute,attribute:H.next.attribute,descending:H.next.descending,next:H.next.next}):(y&&w.splice(w.indexOf(y),1),$=H));let j=m.select;if(w.length===0&&(w=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:w,operator:P,postOrdering:$,selectApplied:!!j};let Q=O.useReadTxn(),q=_R(w,P,De,Q,m,T,(J,le)=>cu(J,j,T,Q,le),D),ue=m.ensureLoaded!==!1;$||(q=ie(q));let te=De.transformEntryForSelect(j,T,Q,D,ue,!0),fe=De.transformToOrderedSelect(q,j,$,Q,T,te);function ie(J){return m.offset||m.limit!==void 0?J.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):J}return a(ie,"applyOffset"),$&&(fe=ie(fe)),fe.onDone=()=>{fe.onDone=null,O.doneReadTxn()},fe.selectApplied=!0,fe.getColumns=()=>{if(j){let J=[];for(let le of j)le==="*"?J.push(...E.map(ye=>ye.name)):J.push(le.name||le);return J}return E.filter(J=>!J.computed&&!J.relationship).map(J=>J.name)},fe}static transformToOrderedSelect(m,T,O,w,y,D){let b=new Qh;if(O){m=cu(m,T,w,y,null);let U;b.iterate=function(){let P,H=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),$,j=O.dbOrderedAttribute,Q,q,ue=!0;function te(ie){let J=ie.next&&te(ie.next),le=ie.descending;return(ye,Re)=>{let Be=au(ye,ie.attribute,w),it=au(Re,ie.attribute,w),Cr=le?(0,Jl.compareKeys)(it,Be):(0,Jl.compareKeys)(Be,it);return Cr===0?J?.(ye,Re)||0:Cr}}a(te,"createComparator");let fe=te(O);return{async next(){let ie;if(P)if(ie=P.next(),ie.done){if($)return b.onDone&&b.onDone(),ie}else return{value:await D.call(this,ie.value)};U=[],Q&&U.push(Q);do if(ie=await H.next(),ie.done){if($=!0,U.length)break;return b.onDone&&b.onDone(),ie}else{let J=ie.value;if(J?.then&&(J=await J),j){let le=au(J,j,w);if(ue)ue=!1,q=le;else if(le!==q){q=le,Q=J;break}}U.push(J)}while(!0);return O.isGrouped,U.sort(fe),P=U[Symbol.iterator](),ie=P.next(),ie.done?(b.onDone&&b.onDone(),ie):{value:await D.call(this,ie.value)}},return(){b.onDone&&b.onDone(),H.return()},throw(){b.onDone&&b.onDone(),H.throw()}}};let L=a(P=>{if(typeof T=="object"&&Array.isArray(P.attribute))for(let H=0;H<T.length;H++){let $=T[H],j;if($.name===P.attribute[0]){for(j=$.sort||($.sort={});j.next;)j=j.next;j.attribute=P.attribute.slice(1),j.descending=P.descending}else $===P.attribute[0]&&(T[H]=j={name:$,sort:{attribute:P.attribute.slice(1),descending:P.descending}})}P.next&&L(P.next)},"applySortingOnSelect");L(O)}else b.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),b=b.map(function(U){try{let L=D.call(this,U);return typeof L?.catch=="function"?L.catch(P=>{throw P.partialObject={[t]:U.key},P}):L}catch(L){throw L.partialObject={[t]:U.key},L}});return b}static transformEntryForSelect(m,T,O,w,y,D){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let P=a(H=>(T?.transaction?.stale&&(T.transaction.stale=!1),H?.key??H),"transform");return m===t?P:m.asArray?H=>[P(H)]:H=>({[t]:P(H)})}let b;y&&v&&!(typeof m=="string"?[m]:m)?.every(P=>{let H;return typeof P=="object"?H=P.name:H=P,r[H]||H===t})&&(b=!0);let U,L=a(function(P){let H;if(T?.transaction?.stale&&(T.transaction.stale=!1),P!=null){if(H=P.value||P.deref?.()?.value,!H&&(P.key===void 0||P.deref)||P.metadataFlags&Fn){if(P.metadataFlags&Fn&&T.replicateFrom===!1&&D&&P.residencyId)return hc.SKIP;if(P=ou(P.key??P,T,{transaction:O,lazy:m?.length<4,ensureLoaded:y},this?.isSync,$=>$),P?.then)return P.then(L.bind(this));H=P?.value}if(b&&P?.metadataFlags&(Fn|Ea)||P?.expiresAt!=null&&P?.expiresAt<Date.now()){if(T.onlyIfCached&&T.noCacheStore)return{[t]:P.key,message:"This entry has expired"};let $=dn(P.key??P,P,T);if($?.then)return $.then(L)}}if(H==null)return D?hc.SKIP:H;if(m&&!(m[0]==="*"&&m.length===1)){let $,j=a((q,ue)=>{let te;typeof q=="object"?te=q.name:te=q;let fe=Bn?.[te],ie;if(fe){let J=w?.[te];if(J)if(J.hasMappings){let ye=fe.from?H[fe.from]:Eu(P.key);ie=J.get(ye),ie||(ie=[])}else ie=J.fromRecord?.(H);else ie=fe(H,T,P);let le=a(ye=>{if(ye&&typeof ye=="object"){let Re=fe.definition?.tableClass||De;U||(U={});let Be=U[te]||(U[te]=Re.transformEntryForSelect(te===q?null:q.select||(Array.isArray(q)?q:null),T,O,J,y));if(Array.isArray(ye)){let it=[],Cr=Re.transformToOrderedSelect(ye,q.select,typeof q.sort=="object"&&q.sort,T,O,Be)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),qr=a(et=>{for(;!et.done;){if(et?.then)return et.then(qr);it.push(et.value),et=Cr.next()}ue(it,te)},"nextValue"),Ae=qr(Cr.next());Ae&&($||($=[]),$.push(Ae));return}else if(ye=Be.call(this,ye),ye?.then){$||($=[]),$.push(ye.then(it=>ue(it,te)));return}}ue(ye,te)},"handleResolvedValue");ie?.then?($||($=[]),$.push(ie.then(le))):le(ie);return}else ie=H[te],ie&&typeof ie=="object"&&te!==q&&(ie=De.transformEntryForSelect(q.select||q,T,O,null)({value:ie}));ue(ie,te)},"selectAttribute"),Q;if(typeof m=="string")j(m,q=>{Q=q});else if(Array.isArray(m))if(m.asArray)Q=[],m.forEach((q,ue)=>{q==="*"?m[ue]=H:j(q,te=>Q[ue]=te)});else{Q={};let q=m.forceNulls;for(let ue of m)if(ue==="*")for(let te in H)Q[te]=H[te];else j(ue,(te,fe)=>{te===void 0&&q&&(te=null),Q[fe]=te})}else throw new wr.ClientError("Invalid select"+m);return $?Promise.all($).then(()=>Q):Q}return H},"transform");return L}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||lt({table:s,database:c,schemaDefined:u,attributes:E,audit:!0}),m||(m={});let T=!m.rawEvents,O=[],w=this,y=DP(De,this.getId()??null,function(b,U,L,P){try{let H=U.getValue?.(i,T),$=U.type;if(!H&&$==="patch"&&T){let Q=i.getEntry(b);Q?.version===U.version?H=Q.value:H=U.getValue?.(i,!0,L),$="put"}let j={id:b,localTime:L,value:H,version:U.version,type:$,beginTxn:P};O?O.push(j):this.send(j)}catch(H){xe.default.error?.(H)}},m.startTime||0,m),D=(async()=>{this.isCollection&&(y.includeDescendants=!0,m.onlyChildren&&(y.onlyChildren=!0)),m.supportsTransactions&&(y.supportsTransactions=!0);let b=this.getId(),U=m.previousCount;U>1e3&&(U=1e3);let L=m.startTime;if(this.isCollection){if(L){if(U)throw new wr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:P,value:H}of l.getRange({start:L,exclusiveStart:!0,snapshot:!1})){let $=Nt(H);if($.tableId!==n)continue;let j=$.recordId;if(b==null||Xj(b,j)){let Q=$.getValue(i,T,P);if(y.send({id:j,localTime:P,value:Q,version:$.version,type:$.type}),y.queue?.length>Qj&&await y.waitForDrain()===!1)return}y.startTime=P}}else if(U){let P=[];for(let{key:H,value:$}of l.getRange({start:"z",end:!1,reverse:!0}))try{let j=Nt($);if(j.tableId!==n)continue;let Q=j.recordId;if(b==null||Xj(b,Q)){let q=j.getValue(i,T,H);if(P.push({id:Q,localTime:H,value:q,version:j.version,type:j.type}),--U<=0)break}}catch(j){xe.default.error("Error getting history entry",H,j)}for(let H=P.length;H>0;)y.send(P[--H]);P[0]&&(y.startTime=P[0].localTime)}else if(!m.omitCurrent){for(let{key:P,value:H,version:$,localTime:j}of i.getRange({start:b??!1,end:b==null?void 0:[b,Jl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(H&&(y.send({id:P,localTime:j,value:H,version:$,type:"put"}),y.queue?.length>Qj&&await y.waitForDrain()===!1))return}}else{U&&!L&&(L=0);let P=this.#r?.localTime;if(P===WR&&(i.cache?.delete(b),this.#r=i.getEntry(b),xe.default.trace?.("re-retrieved record",P,this.#r?.localTime),P=this.#r?.localTime),xe.default.trace?.("Subscription from",L,"from",b,P),L<P){let H=[],$=P;do{let j=l.get($);if(j){m.omitCurrent=!0;let Q=Nt(j),q=Q.getValue(i,T,$);T&&(Q.type="put"),H.push({id:b,value:q,localTime:$,...Q}),$=Q.previousLocalTime}else break;U&&U--}while($>L&&U!==0);for(let j=H.length;j>0;)y.send(H[--j]);y.startTime=P}!m.omitCurrent&&this.doesExist()&&y.send({id:b,localTime:P,value:this.#e,version:this.#n,type:"put"})}for(let P of O)y.send(P);O=null})();return m.listener&&y.on("data",m.listener),y}static subscribeOnThisThread(m,T){return m===0||T?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(m,T){this._writePublish(m,T)}_writePublish(m,T){let O=Gr(this.getContext()),w=this.getId()||null;w!=null&&Ir(w);let y=this.getContext();O.addWrite({key:w,store:i,entry:this.#r,nodeName:y?.nodeName,validate:a(()=>{y?.source||(O.checkOverloaded(),this.validate(m))},"validate"),before:Ce.publish?.bind(this,y,w,m),beforeIntermediate:me.publish?.bind(this,y,w,m),commit:a((D,b,U)=>{b===void 0&&A&&!g&&ca(),xe.default.trace?.(`Publishing message to id: ${w}, timestamp: ${new Date(D).toISOString()}`),R(w,b?.value??null,b,b?.version||D,0,!0,{user:y?.user,residencyId:T?.residencyId,expiresAt:y?.expiresAt,nodeId:T?.nodeId},"message",!1,m)},"commit")})}validate(m,T){let O,w=a((y,D,b)=>{if(D.type&&y!=null)if(T&&y.__op__&&(y=y.value),D.properties){typeof y!="object"&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be an object${D.type?" ("+D.type+")":""}`);let U=D.properties;for(let L=0,P=U.length;L<P;L++){let H=U[L],$=w(y[H.name],H,b+"."+H.name);$&&(y[H.name]=$)}if(D.sealed&&y!=null&&typeof y=="object")for(let L in y)U.find(P=>P.name===L)||(O||(O=[])).push(`Property ${L} is not allowed within object in property ${b}`)}else switch(D.type){case"Int":(typeof y!="number"||y>>0!==y)&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof y!="number"||!(Math.floor(y)===y&&Math.abs(y)<=9007199254740992))&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof y!="number"&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a number`);break;case"ID":typeof y=="string"||y?.length>0&&y.every?.(U=>typeof U=="string")||(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a string, or an array of strings`);break;case"String":typeof y!="string"&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a string`);break;case"Boolean":typeof y!="boolean"&&(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a boolean`);break;case"Date":if(!(y instanceof Date)){if(typeof y=="string"||typeof y=="number")return new Date(y);(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a Date`)}break;case"BigInt":if(typeof y!="bigint"){if(typeof y=="string"||typeof y=="number")return BigInt(y);(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a bigint`)}break;case"Bytes":if(!(y instanceof Uint8Array)){if(typeof y=="string")return Buffer.from(y);(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(y instanceof Pi)){if(typeof y=="string"&&(y=Buffer.from(y)),y instanceof Buffer)return createBlob(y,{type:"text/plain"});(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be a Blob`)}break;case"array":if(Array.isArray(y)){if(D.elements)for(let U=0,L=y.length;U<L;U++){let P=y[U],H=w(P,D.elements,b+"[*]");H&&(y[U]=H)}}else(O||(O=[])).push(`Value ${$s(y)} in property ${b} must be an Array`);break}D.nullable===!1&&y==null&&(O||(O=[])).push(`Property ${b} is required (and not does not allow null values)`)},"validateValue");for(let y=0,D=E.length;y<D;y++){let b=E[y];if(!(b.relationship||b.computed)&&(!T||b.name in m)){let U=w(m[b.name],b,b.name);U&&(m[b.name]=U)}}if(d)for(let y in m)E.find(D=>D.name===y)||(O||(O=[])).push(`Property ${y} is not allowed`);if(O)throw new wr.ClientError(O.join(". "))}getUpdatedTime(){return this.#n}wasLoadedFromSource(){return v?!!this.#i:void 0}static async addAttributes(m){let T=E.slice(0);for(let O of m){if(!O.name)throw new wr.ClientError("Attribute name is required");if(O.name.match(/[`/]/))throw new wr.ClientError("Attribute names cannot include backticks or forward slashes");(0,tQ.validateAttribute)(O.name),T.push(O)}return lt({table:s,database:c,schemaDefined:u,attributes:T}),De.indexingOperation}static async removeAttributes(m){let T=E.filter(O=>!m.includes(O.name));return lt({table:s,database:c,schemaDefined:u,attributes:T}),De.indexingOperation}static getSize(){let m=i.getStats();return(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getAuditSize(){let m=l?.getStats();return m&&(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getStorageStats(){let m=i.env.path,T=_A.default.statfsSync?.(m)??{};return{available:T.bavail*T.bsize,free:T.bfree*T.bsize,size:T.blocks*T.bsize}}static async getRecordCount(m){let T=i.getStats().entryCount,O=1e3/2,w=performance.now(),y=Math.floor(T/2),D=m?.exactCount,b=0,U=0,L;for(let{value:P}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(P!=null&&b++,U++,await pc(),!D&&U<y&&performance.now()-w>O){L=U;break}if(L){let P=b;b=0;for(let{value:ie}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:L,snapshot:!1}))ie!=null&&b++,await pc();let H=L*2,$=(b+P)/H,j=Math.pow((b-P+1)/L/2,2)+$*(1-$)/H,Q=Math.max(Math.sqrt(j)*T,1),q=Math.round($*T),ue=Math.max(q-1.96*Q,b+P),te=Math.min(q+1.96*Q,T),fe=Math.pow(10,Math.round(Math.log10(Q)));return fe>q&&(fe=fe/10),b=Math.round(q/fe)*fe,{recordCount:b,estimatedRange:[Math.round(ue),Math.round(te)]}}return{recordCount:b}}static updatedAttributes(){Bn=this.propertyResolvers={$id:a((m,T,O)=>({value:O.key}),"$id"),$updatedtime:a((m,T,O)=>O.version,"$updatedtime"),$record:a((m,T,O)=>O?{value:m}:m,"$record")};for(let m of this.attributes){m.resolve=null;let T=m.relationship,O=m.computed;if(T)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),O&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),su=!0,T.to)m.elements?.definition?(Bn[m.name]=m.resolve=(w,y,D)=>{let b=w[T.from?T.from:t],U=m.elements.definition.tableClass;return D?mu({attribute:T.to,value:b},Gr(y).getReadTxn(),!1,U,!1).asArray:U.search([{attribute:T.to,value:b}],y).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,T.from&&(m.resolve.from=T.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(T.from){let w=m.definition||m.elements?.definition;w?(Bn[m.name]=m.resolve=(y,D,b)=>{let U=y[T.from];if(U!==void 0){if(m.elements){let L,P=U?.map(H=>{let $=b?w.tableClass.primaryStore.getEntry(H,{transaction:Gr(D).getReadTxn()}):w.tableClass.get(H,D);return $?.then&&(L=!0),$});return T.filterMissing?L?Promise.all(P).then(H=>H.filter(Zj)):P.filter(Zj):L?Promise.all(P):P}return b?w.tableClass.primaryStore.getEntry(U,{transaction:Gr(D).getReadTxn()}):w.tableClass.get(U,D)}},m.set=(y,D)=>{if(Array.isArray(D)){let b=D.map(U=>U.getId?.()||U[w.tableClass.primaryKey]);y[T.from]=b}else{let b=D.getId?.()||D[w.tableClass.primaryKey];y[T.from]=b}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=T.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else O&&(typeof O.from=="function"&&this.setComputedAttribute(m.name,O.from),Bn[m.name]=m.resolve=(w,y,D)=>{let b=typeof O.from=="string"?w[O.from]:w,U=this.userResolvers[m.name];if(U)return U(b,y,D);xe.default.warn(`Computed attribute "${m.name}" does not have a function assigned to it. Please use setComputedAttribute('${m.name}', resolver) to assign a resolver function.`),this.userResolvers[m.name]=()=>{}})}FE(this,this)}static setComputedAttribute(m,T){let O=wi(E,m);if(!O){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!O.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=T}static async deleteHistory(m=0,T=!1){let O;for(let{key:w,value:y}of l.getRange({start:0,end:m}))await pc(),Nt(y).tableId===n&&(O=dA(l,w,y));if(T)for(let w of i.getRange({start:0,versions:!0})){let{key:y,value:D,localTime:b}=w;await pc(),D===null&&b<m&&(O=Uc(i,w))}await O}static async*getHistory(m=0,T=1/0){for(let{key:O,value:w}of l.getRange({start:m||1,end:T})){await pc();let y=Nt(w);y.tableId===n&&(yield{id:y.recordId,localTime:O,version:y.version,type:y.type,value:y.getValue(i,!0,O),user:y.user,operation:y.originatingOperation})}}static async getHistoryOfRecord(m){let T=[];if(m==null)throw new Error("An id is required");let O=i.getEntry(m);if(!O)return T;let w=O.localTime;if(!w)throw new Error("The entry does not have a local audit time");let y=0;do{await pc();let D=l.get(w);if(D){let b=Nt(D);T.push({id:b.recordId,localTime:w,version:b.version,type:b.type,value:b.getValue(i,!0,w),user:b.user}),w=b.previousLocalTime}else break}while(y<1e3&&w);return T.reverse()}static cleanup(){Z?.remove()}}De.updatedAttributes();let gf=De.prototype;return h&&De.setTTLExpiration(h/1e3),ae&&lu(),De;function un(z,m,T){let O;for(let w in r){let y=r[w],D=y.isIndexing,b=Bn[w],U=T&&(b?b(T):T[w]),L=m&&(b?b(m):m[w]);if(U===L&&!D)continue;O=!0;let P=y.indexNulls,H=(0,Mh.getIndexedValues)(U,P),$=(0,Mh.getIndexedValues)(L,P);if($?.length>0){let j=new Set($);if(H=H?H.filter(Q=>{if(j.has(Q))j.delete(Q);else return!0}):[],$=Array.from(j),($.length>0||H.length>0)&&Wj){let Q=$.concat(H).map(q=>({key:q,value:z}));y.prefetch(Q,Jj)}for(let Q=0,q=$.length;Q<q;Q++)y.remove($[Q],z)}else H?.length>0&&Wj&&y.prefetch(H.map(j=>({key:j,value:z})),Jj);if(H)for(let j=0,Q=H.length;j<Q;j++)y.put(H[j],z)}return O}a(un,"updateIndices");function Ir(z){switch(typeof z){case"number":return!0;case"string":if(z.length<659)return!0;if(z.length>jj)throw new Error("Primary key size is too large: "+z.length);break;case"object":if(z===null)throw new Error("Invalid primary key of null");break;case"bigint":if(z<2n**64n&&z>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof z)}if((0,Jl.writeKey)(z,uAe,0)>jj)throw new Error("Primary key size is too large: "+z.length);return!0}a(Ir,"checkValidId");function ou(z,m,T,O,w){if(De.getResidencyById&&T.ensureLoaded&&m?.replicateFrom!==!1){let D=De.getResidencyById(z);if(D&&!D.includes(server.hostname)&&N)return N({key:z,residency:D}).then(w)}let y=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),T.transaction?.isDone)return w(null,z);let D=i.getEntry(z,T);return D?.residencyId&&D.metadataFlags&Fn&&N&&T.ensureLoaded&&m?.replicateFrom!==!1?N(D).then(b=>w(b,z),b=>(xe.default.error?.("Error loading remote record",z,D,T,b),w(null,z))):(D&&m&&(D?.version>(m.lastModified||0)&&(m.lastModified=D.version),D?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=D.localTime)),w(D,z))},"whenPrefetched");return O?y():he>0?(he--,y()):new Promise((D,b)=>{he===0?(he--,i.prefetch([z],()=>{U(),L()})):(se.push(z),W.push(L),se.length>Jh&&(he--,U()));function U(){if(se.length>0){let P=W;i.prefetch(se,()=>{he===-1?U():he++;for(let H of P)H()}),se=[],W=[],Te>2&&Te--}else he=Te,Te<Ef&&Te++}a(U,"prefetch");function L(){try{D(y())}catch(P){b(P)}}a(L,"load")})}a(ou,"loadLocalRecord");function Sf(z){if(!z?.role)return;let m=z.role.permission;if(m.super_user)return dAe;let T=m[c],O,w=T?.tables;if(w)return w[s];if(c==="data"&&(O=m[s])&&!O.tables)return O}a(Sf,"getTablePermissions");function dn(z,m,T,O){if(v){let w=!1;if(T.noCache?w=!0:(m?(!m.value||m.metadataFlags&(Fn|Ea)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(w=!0):w=!0,es(!w,"cache-hit",s)),w){let y=Xh(z,m,T).then(D=>(D?.value&&D?.value.getRecord?.()&&xe.default.error?.("Can not assign a record that is already a resource"),T&&(D?.version>(T.lastModified||0)&&(T.lastModified=D.version),T.lastRefreshed=Date.now()),D));if(T?.onlyIfCached||m?.value&&O?.allowStaleWhileRevalidate?.(m,z)){if(y.catch(D=>xe.default.warn?.(D)),T?.onlyIfCached&&!O.doesExist())throw new wr.ServerError("Entry is not cached",504);return}else return y}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return De.evict(m.key,m.value,m.version),m.value=null,{then(w){return w(m)}}}a(dn,"ensureLoadedFromSource");function Gr(z){let m=z?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let T=m.next;if(!T)return m=m.next=new bc,m.lmdbDb=i,m;m=T}while(!0)}else return new Tm}a(Gr,"txnForContext");function au(z,m,T){if(!z)return;let O=z.value||i.getEntry(z.key)?.value;if(typeof m=="object"){let y=Bn,D=O;for(let b=0,U=m.length;b<U;b++){let L=m[b],P=y?.[L];D=P&&D?P(D,T,!0)?.value:D?.[L],y=P?.definition?.tableClass?.propertyResolvers}return D}let w=Bn[m];return w?w(O,T):O[m]}a(au,"getAttributeValue");function cu(z,m,T,O,w){let y=w?.length,D={transaction:O,lazy:y>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},b;function U(L,P){let H=L?.value;if(!H)return hc.SKIP;for(let $=0;$<y;$++)if(!b?.includes($)&&!w[$](H,L))return hc.SKIP;return P!==void 0&&(L.key=P),L}if(a(U,"processEntry"),y>0||!z.hasEntries){let L=z.map(P=>{if(b=null,typeof P=="object"&&P?.key!==void 0)return y>0?U(P):P;if(P==null)return hc.SKIP;for(let H=0;H<y;H++){let j=w[H].idFilter;if(j){if(!j(P))return hc.SKIP;b||(b=[]),b.push(H)}}return ou(P,T,D,!1,U)});return Array.isArray(z)&&(L=L.filter(P=>P!==hc.SKIP)),L.hasEntries=!0,L}return z}a(cu,"transformToEntries");function oa(z,m,T=server.replication?.getThisNodeId(l)){if(z<=m?.version){if(m?.version===z&&T!==void 0){let O=server.replication?.exportIdMapping(l),w=m.localTime,y=w&&l.get(w);if(y){let D,b,U=Nt(y);for(let L in O)O[L]===T&&(D=L),O[L]===U.nodeId&&(b=L);if(D>b)return 1;if(D===b)return 0}}return-1}return 1}a(oa,"precedesExistingVersion");async function Xh(z,m,T){let O=m?.metadataFlags,w=m?.version,y,D;if(!i.attemptLock(z,w,()=>{clearTimeout(D);let P=i.getEntry(z);!P||!P.value||P.metadataFlags&(Fn|Ea)?y(Xh(z,i.getEntry(z),T)):y(P)}))return new Promise(P=>{y=P,D=setTimeout(()=>{i.unlock(z,w)},cAe)});let b=m?.value,U={requestContext:T,replacingRecord:b,replacingEntry:m,replacingVersion:w,noCacheStore:!1,source:null,resourceCache:T?.resourceCache},L=T?.responseHeaders;return new Promise((P,H)=>{let $;MP(Ot(U,async j=>{let Q=performance.now(),q,ue,te;try{for(let le of De.sources)if(le.get&&(!le.get.reliesOnPrototype||le.prototype.get)){if(le.available?.(m)===!1)continue;if(U.source=le,q=await le.get(z,U),q)break}te=O&Fn;let ie=U.lastModified||te&&w;ue=te||ie>w||!b,ie||(ie=(0,Mh.getNextMonotonicTime)());let J=performance.now()-Q;if(sr(J,"cache-resolution",s,null,"success"),L&&ZE(L,"Server-Timing",`cache-resolve;dur=${J.toFixed(2)}`,!0),j.timestamp=ie,h&&U.expiresAt==null&&(U.expiresAt=Date.now()+h),q){if(typeof q!="object")throw new Error("Only objects can be cached and stored in tables");if(q.status>0&&q.headers)if(q.status>=300)if(q.status===304)q=b,ie=w;else throw new wr.ServerError(q.body||"Error from source",q.status);else q=q.body;typeof q.toJSON=="function"&&(q=q.toJSON()),t&&q[t]!==z&&(q[t]=z)}$=!0,P({key:z,version:ie,value:q})}catch(ie){ie.message+=` while resolving record ${z} for ${s}`,b&&((ie.code==="ECONNRESET"||ie.code==="ECONNREFUSED"||ie.code==="EAI_AGAIN")&&!T?.mustRevalidate||T?.staleIfError&&(ie.statusCode===500||ie.statusCode===502||ie.statusCode===503||ie.statusCode===504))?(P({key:z,version:w,value:b}),xe.default.trace?.(ie.message,"(returned stale record)")):H(ie);let J=performance.now()-Q;sr(J,"cache-resolution",s,null,"fail"),L&&ZE(L,"Server-Timing",`cache-resolve;dur=${J.toFixed(2)}`,!0),U.transaction.abort();return}if(T?.noCacheStore||U.noCacheStore){U.transaction.abort();return}Gr(U).addWrite({key:z,store:i,entry:m,nodeName:"source",commit:a((ie,J)=>{if(J?.version!==w)return;let le=un(z,b,q);q?(me.put?.(U,z,q),xe.default.trace?.(`Writing resolved record from source with id: ${z}, timestamp: ${new Date(ie).toISOString()}`),R(z,q,J,ie,0,g&&ue||null,{user:U?.user,expiresAt:U.expiresAt},"put",!!te)):J&&(me.delete?.(U,z),xe.default.trace?.(`Deleting resolved record from source with id: ${z}, timestamp: ${new Date(ie).toISOString()}`),g||A?R(z,null,J,ie,0,g&&ue||null,{user:U?.user},"delete",!!te):Uc(i,J,w))},"commit")})}),()=>{i.unlock(z,w)},j=>{i.unlock(z,w),$&&xe.default.error?.("Error committing cache update",j)})})}a(Xh,"getFromSource");function aa(z){if(!z||z.user?.role?.permission?.super_user)return!0;if(z.replicateTo)throw new wr.ClientError("Can not specify replication parameters without super user permissions",403);if(z.replicatedConfirmation)throw new wr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(aa,"checkContextPermissions");function ca(z){let m=!1;if(z&&(z-ct>1&&(m=!0),ct=z),!(Xt===yr&&!m)&&(yr=Xt,(0,jl.getWorkerIndex)()===(0,jl.getWorkerCount)()-1))return gs&&clearTimeout(gs),Xt?new Promise(T=>{let O=new Date;O.setMonth(0),O.setDate(1),O.setHours(0),O.setMinutes(0),O.setSeconds(0);let w=Xt/(1+ct),y=m?Date.now():Math.ceil((Date.now()-O.getTime())/w)*w+O.getTime(),D=a(b=>{xe.default.trace?.(`Scheduled next cleanup scan at ${new Date(b)}`),gs=setTimeout(()=>F=F.then(async()=>{if(D(Math.max(b+Xt,Date.now())),i.rootStore.status!=="open"){clearTimeout(gs);return}let U=50,L=new Array(U),P=0,H=Math.pow(ct,8)*(Ql.get(x.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),$=S/Math.pow(Math.max(ct,1),4);xe.default.info?.(`Starting cleanup scan for ${s}, evict threshold ${H}, adjusted eviction ${$}ms`);function j(Q,q,ue,te){let fe=Q+$-Date.now();if(fe<0)return!0;if(ct){let ie=i.lastSize;return ue&$n&&Yf(te,J=>{J.size&&(ie+=J.size)}),xe.default.trace?.(`shouldEvict adjusted ${fe} ${ie}, ${fe*(Q-q)/ie} < ${H}`),fe*(Q-q)/ie<H}return!1}a(j,"shouldEvict");try{let Q=0;for(let q of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:ue,value:te,version:fe,expiresAt:ie,metadataFlags:J}=q,le;te===null&&!g&&fe+aAe<Date.now()?le=Uc(i,q,fe):ie!=null&&j(ie,fe,J,te)&&(le=De.evict(ue,te,fe),Q++),le&&(await L[P],L[P]=le.catch(ye=>{xe.default.error?.("Cleanup error",ye)}),++P>=U&&(P=0)),await pc()}xe.default.info?.(`Finished cleanup scan for ${s}, evicted ${Q} entries`)}catch(Q){xe.default.warn?.(`Error in cleanup scan for ${s}:`,Q)}T(void 0),ct=0}),Math.min(b-Date.now(),2147483647)).unref()},"startNextTimer");D(y)}):void 0}a(ca,"scheduleCleanup");function Tf(){Z=l?.addDeleteRemovalCallback(n,i,(z,m)=>{i.remove(z,m)})}a(Tf,"addDeleteRemoval");function lu(){(0,jl.getWorkerIndex)()===0&&setInterval(async()=>{if(!iu){iu=!0;try{let z=ae.name,m=r[z];if(!m)throw new Error(`expiresAt attribute ${ae} must be indexed`);for(let T of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let O of m.getValues(T)){let w=i.getEntry(O);w?.value?w.value[z]<Date.now()&&De.evict(O,w.value,w.version):i.ifVersion(O,w?.version,()=>m.remove(T,O))}await pc()}}catch(z){xe.default.error?.("Error in evicting old records",z)}finally{iu=!1}}},oAe).unref()}a(lu,"runRecordExpirationEviction");function uu(z){if(z){let m=z.join(","),T=f.get([Symbol.for("residency_by_set"),m]);return T||(f.put([Symbol.for("residency_by_set"),m],T=Math.floor(Math.random()*2147483647)),f.put([Symbol.for("residency_by_id"),T],z),T)}}a(uu,"getResidencyId")}function LP(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 Jj(){}function fAe(e){rQ=e}function pA(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return fA(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return fA(+e);case"Float":return e==="null"?null:fA(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;_Ae.test(e)||(e+="Z");let n=new Date(e);return fA(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,hA.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function fA(e){if(isNaN(e))throw new SyntaxError;return e}function Xj(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function MP(e,t,r){return e?.then?e.then(t,r):t(e)}function Zj(e){return e!=null}function $s(e){try{return JSON.stringify(e)}catch{return e}}function pAe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var hc,Mh,eQ,tQ,Ql,wr,vh,Uh,xe,Jl,jl,hA,_A,iAe,rQ,oAe,aAe,Wj,cAe,zj,lAe,Fn,Ea,uAe,jj,Qj,dAe,axe,_Ae,pc,Gf=be(()=>{B();hc=require("lmdb"),Mh=M(pn()),eQ=require("lodash"),tQ=M(Uf());ga();Am();Ql=M(ce());gN();wr=M(pe()),vh=M(yo()),Uh=M(si());Pe();Ff();xe=M(Ci());Vb();Oc();Jl=require("ordered-binary"),jl=M(tt());ho();hA=M(oe());Ou();$i();xE();Q_();_A=M(require("node:fs"));As();vT();iAe=new Uint8Array(9);iAe[8]=192;oAe=6e4,aAe=864e5;Ql.initSync();Wj=Ql.get(x.STORAGE_PREFETCHWRITES),cAe=1e4,zj=1,lAe=2,Fn=1,Ea=8,uAe=Buffer.allocUnsafeSlow(8192),jj=1978,Qj=100,dAe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},axe=(0,hA.convertToMS)(Ql.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(mA,"makeTable");a(LP,"attributesAsObject");a(Jj,"noop");a(fAe,"setServerUtilities");_Ae=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(pA,"coerceType");a(fA,"rejectNaN");a(Xj,"isDescendantId");pc=a(()=>new Promise(setImmediate),"rest");a(MP,"when");a(Zj,"exists");a($s,"stringify");a(pAe,"hasOtherProcesses")});var rt={};ve(rt,{database:()=>Fu,database_envs:()=>ta,databases:()=>$e,dropDatabase:()=>jb,dropTableMeta:()=>SAe,getDatabases:()=>Je,getDefaultCompression:()=>IS,getTables:()=>hAe,onRemovedDB:()=>mp,onUpdatedTable:()=>ml,readMetaDb:()=>xh,resetDatabases:()=>Cd,table:()=>lt,tables:()=>Zn});function hAe(){return TA||Je(),Zn||{}}function Je(){if(TA)return $e;TA=!0,df=new Map;let e=(0,Qt.getHdbBasePath)()&&(0,Pt.join)((0,Qt.getHdbBasePath)(),yc),t=(0,Qt.get)(x.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Qt.get)(x.STORAGE_PATH)||e&&((0,_s.existsSync)(e)?e:(0,Pt.join)((0,Qt.getHdbBasePath)(),im)),!e)return;if((0,_s.existsSync)(e))for(let n of(0,_s.readdirSync)(e,{withFileTypes:!0})){let s=(0,Pt.basename)(n.name,".mdb");n.isFile()&&(0,Pt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&xh((0,Pt.join)(e,n.name),null,s)}if((0,_s.existsSync)((0,uf.getBaseSchemaPath)())){for(let n of(0,_s.readdirSync)((0,uf.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Pt.join)((0,uf.getBaseSchemaPath)(),n.name),i=(0,Pt.join)((0,uf.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,_s.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Pt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Pt.join)(i,o.name);xh((0,Pt.join)(s,o.name),(0,Pt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,_s.existsSync)(i))for(let c of(0,_s.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Pt.extname)(c.name).toLowerCase()===".mdb"&&xh((0,Pt.join)(i,c.name),(0,Pt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Pt.join)(l.path,(0,Pt.basename)(c+".mdb"));(0,_s.existsSync)(u)&&xh(u,c,n,null,!0)}}for(let n in $e){let s=df.get(n);if(s){let i=$e[n];n.includes("delete")&&Ft.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Ft.trace(`delete table class ${o}`),delete i[o])}else if(delete $e[n],n==="data"){for(let i in Zn)delete Zn[i];delete Zn[AA]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if($e.system)for(let n of r)$e.system[n]&&($e.system[n].replicate=!1);return df=null,$e}function Cd(){TA=!1;for(let[,e]of ta)e.needsDeletion=!0;Je();for(let[e,t]of ta)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),ta.delete(e),delete $e[t.databaseName],Hh.forEach(r=>r(t.databaseName)));return $e}function xh(e,t,r=xP,n,s){let i=new vP.default(e,!1);try{let o=ta.get(e);o?o.needsDeletion=!1:(o=(0,ff.open)(i),ta.set(e,o));let c=new Xl.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(EA.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,_s.existsSync)(n)&&(i.path=n,u=(0,ff.open)(i),u.isLegacy=!0):u=uA(o));let f=oQ(r),d=f[AA],p=new Map;for(let{key:_,value:h}of l.getRange({start:!1})){let[S,g]=_.toString().split("/");g===""?g=h.name:g||(g=S,S=t,h.name||(h.name=g,h.indexed=!h.is_hash_attribute)),d?.add(S);let A=p.get(S);A||p.set(S,A={attributes:[]}),(g==null||h.is_hash_attribute)&&(A.primary=h),g!=null&&A.attributes.push(h),Object.defineProperty(h,"key",{value:_,configurable:!0})}for(let[_,h]of p){let{attributes:S,primary:g}=h;if(!g){for(let W of S)if(W.is_hash_attribute||W.isPrimaryKey){g=W;break}if(!g){Ft.warn(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(S)}`);continue}}let A=f[_],E={},R=[],N,v,k=typeof g.audit=="boolean"?g.audit:(0,Qt.get)(x.LOGGING_AUDITLOG),F=g.trackDeletes,K=g.expiration,re=g.eviction,ae=g.sealed,Z=g.splitSegments,se=g.replicate;if(A)E=A.indices,R=A.attributes,A.schemaVersion++;else{N=g.tableId,N?N>=(l.get(lf)||0)&&(l.putSync(lf,N+1),Ft.info(`Updating next table id (it was out of sync) to ${N+1} for ${_}`)):(g.tableId=N=l.get(lf),N||(N=1),Ft.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(lf,N+1),l.putSync(g.key,g));let W=new Xl.default(!g.is_hash_attribute,g.is_hash_attribute);if(W.compression=g.compression,W.compression){let he=(0,Qt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iQ;W.compression.threshold=he}v=jm(o.openDB(g.key,W),o),o.databaseName=r,v.tableId=N}for(let W of S){W.attribute=W.name;try{if(!W.is_hash_attribute&&(W.indexed||W.attribute&&!W.name)){if(!E[W.name]){let Te=new Xl.default(!W.is_hash_attribute,W.is_hash_attribute);E[W.name]=o.openDB(W.key,Te),E[W.name].indexNulls=W.indexNulls}let he=R.find(Te=>Te.name===W.name);he?R.splice(R.indexOf(he),1,W):R.push(W)}}catch(he){Ft.error("Error trying to update attribute",W,R,E,he)}}if(!A){A=aQ(f,_,mA({primaryStore:v,auditStore:u,audit:k,sealed:ae,splitSegments:Z,replicate:se,expirationMS:K&&K*1e3,evictionMS:re&&re*1e3,trackDeletes:F,tableName:_,tableId:N,primaryKey:g.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:E,attributes:S,schemaDefined:g.schemaDefined,dbisDB:l})),A.schemaVersion=1;for(let W of Bh)W(A)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function oQ(e){let t=$e[e];if(t||(e==="data"?t=$e[e]=Zn:e==="system"?Object.defineProperty($e,"system",{value:t=Object.create(null),configurable:!0}):t=$e[e]=Object.create(null)),df&&!df.has(e)){let r=new Set;t[AA]=r,df.set(e,r)}return t}function aQ(e,t,r){return e[t]=r,r}function Fu({database:e,table:t}){e||(e=xP),Je();let r=oQ(e),n=(0,Pt.join)((0,Qt.getHdbBasePath)(),yc),s=(0,Qt.get)(x.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Qt.get)(x.STORAGE_PATH)||((0,_s.existsSync)(n)?n:(0,Pt.join)((0,Qt.getHdbBasePath)(),im));let o=(0,Pt.join)(n,(i?t:e)+".mdb"),c=ta.get(o);if(!c||c.status==="closed"){let l=new vP.default(o,!1);c=(0,ff.open)(l),ta.set(o,c)}return c.auditStore||(c.auditStore=uA(c)),c}async function jb(e){if(!$e[e])throw new Error("Schema does not exist");let t=$e[e],r;for(let n in t)r=t[n].primaryStore.rootStore,ta.delete(r.path),r.status==="open"&&(await r.close(),await kh.remove(r.path));if(r||(r=Fu({database:e,table:null}),r.status==="open"&&(await r.close(),await kh.remove(r.path))),e==="data"){for(let n in Zn)delete Zn[n];delete Zn[AA]}delete $e[e],Hh.forEach(n=>n(e)),await NR(r)}function lt(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,schemaDefined:p,origin:_}=e;r||(r=xP);let h=Fu({database:r,table:t}),S=$e[r];Ft.trace(`Defining ${t} in ${r}`);let g=S?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let A,E,R;p==null&&(p=!0);let N=new Xl.default(!1);for(let Z of o)Z.attribute&&!Z.name?(Z.name=Z.attribute,Z.indexed=!0):Z.attribute=Z.name,Z.expiresAt&&(Z.indexed=!0);let v,k;if(g){if(A=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...o)}else{let Z=h.auditStore;E=o.find(Te=>Te.isPrimaryKey)||{},A=E.name,E.is_hash_attribute=E.isPrimaryKey=!0,E.schemaDefined=p,E.compression=IS(),d&&(E.trackDeletes=!0),c=E.audit=typeof c=="boolean"?c:(0,Qt.get)(x.LOGGING_AUDITLOG),n&&(E.expiration=n),s&&(E.eviction=s),u??=!1,E.splitSegments=u,typeof l=="boolean"&&(E.sealed=l),typeof f=="boolean"&&(E.replicate=f),_&&(E.origins?E.origins.includes(_)||E.origins.push(_):E.origins=[_]),Ft.trace(`${t} table loading, opening primary store`);let se=new Xl.default(!1,!0);se.compression=E.compression;let W=t+"/";if(R=h.dbisDb=h.openDB(EA.INTERNAL_DBIS_NAME,N),ae(),R.get(W))return k&&k(),Cd(),lt(e);let he=jm(h.openDB(W,se),h);h.databaseName=r,he.tableId=R.get(lf),Ft.trace(`Assigning new table id ${he.tableId} for ${t}`),he.tableId||(he.tableId=1),R.put(lf,he.tableId+1),E.tableId=he.tableId,g=aQ(S,t,mA({primaryStore:he,auditStore:Z,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:A,tableName:t,tableId:he.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:p,dbisDB:R})),g.schemaVersion=1,v=!0,R.put(W,E)}let F=g.indices;R=R||(h.dbisDb=h.openDB(EA.INTERNAL_DBIS_NAME,N)),g.dbisDB=R;let K=[];for(let{key:Z,value:se}of R.getRange({start:!0})){let[W,he]=Z.toString().split("/");if(he===""&&(he=se.name),he){if(W!==t)continue}else continue;let Te=o.find(me=>me.name===he),Ce=!Te?.indexed&&se.indexed&&!se.isPrimaryKey;if((!Te||Ce)&&(ae(),v=!0,Te||R.remove(Z),Ce)){let me=g.indices[W];me&&K.push(me)}}let re=[];try{for(let Z of o||[]){if((Z.relationship||Z.computed)&&(v=!0,Z.relationship))continue;let se=t+"/"+(Z.name||"");Object.defineProperty(Z,"key",{value:se,configurable:!0});let W=R.get(se);if(Z.isPrimaryKey){if(W=W||R.get(se=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||f!==void 0&&f!==g.replicate||(+n||void 0)!==(+W.expiration||void 0)||(+s||void 0)!==(+W.eviction||void 0)){let Te={...W};typeof c=="boolean"&&(c&&g.enableAuditing(c),Te.audit=c),n&&(Te.expiration=+n),s&&(Te.eviction=+s),l!==void 0&&(Te.sealed=l),f!==void 0&&(Te.replicate=f),v=!0,ae(),R.put(se,Te)}continue}W?.attribute&&!W.name&&(W.indexed=!0);let he=!W||W.type!==Z.type||W.indexed!==Z.indexed||W.nullable!==Z.nullable||W.version!==Z.version||JSON.stringify(W.properties)!==JSON.stringify(Z.properties)||JSON.stringify(W.elements)!==JSON.stringify(Z.elements);if(Z.indexed){let Te=new Xl.default(!0,!1),Ce=h.openDB(se,Te);(he||W.indexingPID&&W.indexingPID!==process.pid||W.restartNumber<Fh.workerData?.restartNumber)&&(v=!0,ae(),W=R.get(se),(he||W.indexingPID&&W.indexingPID!==process.pid||W.restartNumber<Fh.workerData?.restartNumber)&&(v=!0,Z.indexNulls===void 0&&(Z.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(Z.lastIndexedKey=W?.lastIndexedKey??void 0,Z.indexingPID=process.pid,Ce.isIndexing=!0,Object.defineProperty(Z,"dbi",{value:Ce}),re.push(Z))),R.put(se,Z)),W?.indexNulls&&Z.indexNulls===void 0&&(Z.indexNulls=!0),Ce.indexNulls=Z.indexNulls,F[Z.name]=Ce}else he&&(v=!0,ae(),R.put(se,Z))}}finally{k&&k()}if(v&&(g.schemaVersion++,g.updatedAttributes()),Ft.trace(`${t} table loading, running index`),re.length>0||K.length>0?g.indexingOperation=gAe(g,re,K):v&&gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,v)for(let Z of Bh)Z(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Ft.trace(`${t} table loaded`),g;function ae(){k||h.transactionSync(()=>({then(Z){k=Z}}))}a(ae,"startTxn")}async function gAe(e,t,r){try{Ft.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let d of t)(0,ff.compareKeys)(d.lastIndexedKey,u)<0&&(u=d.lastIndexedKey),d.lastIndexedKey==null&&d.dbi.clearAsync();let f=0;for(let{key:d,value:p,version:_}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(p){if(f++,s=e.primaryStore.ifVersion(d,_,()=>{for(let h=0;h<l;h++){let S=t[h],g=S.name;try{let A=S.resolve,E=p&&(A?A(p):p[g]),R=(0,nQ.getIndexedValues)(E);if(R)for(let N=0,v=R.length;N<v;N++)S.dbi.put(R[N],d)}catch(A){o[g]||(o[g]=!0,Ft.error(`Error indexing attribute ${g}`,A))}}}),s.then(()=>f--,h=>{f--,Ft.error(h)}),Fh.workerData&&Fh.workerData.restartNumber!==sQ.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=d,e.dbisDB.put(h.key,h);if(i)return}f>mAe?await s:f>EAe&&await new Promise(h=>setImmediate(h))}for(let d of t)delete d.lastIndexedKey,delete d.indexingPID,d.dbi.isIndexing=!1,s=e.dbisDB.put(d.key,d)}await s,await gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Ft.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Ft.error("Error in indexing",n)}}function SAe({table:e,database:t}){let r=Fu({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function ml(e){return Bh.push(e),{remove(){let t=Bh.indexOf(e);t>-1&&Bh.splice(t,1)}}}function mp(e){return Hh.push(e),{remove(){let t=Hh.indexOf(e);t>-1&&Hh.splice(t,1)}}}function IS(){let e=(0,Qt.get)(x.STORAGE_COMPRESSION),t=(0,Qt.get)(x.STORAGE_COMPRESSION_DICTIONARY),r=(0,Qt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iQ,n={startingOffset:32};return t&&(n.dictionary=kh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Qt,EA,ff,Pt,_s,uf,Xl,vP,kh,UP,nQ,gA,SA,Fh,Ft,sQ,xP,AA,iQ,Zn,$e,lf,Bh,Hh,TA,ta,df,mAe,EAe,Pe=be(()=>{Qt=M(ce()),EA=M(vt()),ff=require("lmdb"),Pt=require("path"),_s=require("fs"),uf=M(Et());Gf();Xl=M(s_()),vP=M(i_());B();kh=M(require("fs-extra")),UP=M(yi()),nQ=M(pn()),gA=M(yo()),SA=M(si()),Fh=require("worker_threads"),Ft=M(Y()),sQ=M(tt());ho();Ou();As();xP="data",AA=Symbol("defined-tables"),iQ=((0,Qt.get)(x.STORAGE_PAGESIZE)||4096)-60;(0,Qt.initSync)();Zn=Object.create(null),$e=Object.create(null);(0,UP._assignPackageExport)("databases",$e);(0,UP._assignPackageExport)("tables",Zn);lf=Symbol.for("next-table-id"),Bh=[],Hh=[],ta=new Map;a(hAe,"getTables");a(Je,"getDatabases");a(Cd,"resetDatabases");a(xh,"readMetaDb");a(oQ,"ensureDB");a(aQ,"setTable");a(Fu,"database");a(jb,"dropDatabase");a(lt,"table");mAe=1e3,EAe=10;a(gAe,"runIndexing");a(SAe,"dropTableMeta");a(ml,"onUpdatedTable");a(mp,"onRemovedDB");a(IS,"getDefaultCompression")});var oe=I((gxe,AQ)=>{"use strict";var mc=require("path"),fQ=require("fs-extra"),Un=Y(),cQ=require("fs-extra"),RA=require("os"),TAe=require("net"),AAe=require("recursive-iterator"),Rr=(B(),C(G)),{PACKAGE_ROOT:RAe}=nt(),yAe=nR(),lQ=require("papaparse"),yA=require("moment"),{inspect:bAe}=require("util"),uQ=require("is-number"),Exe=require("lodash"),OAe=require("minimist"),NAe=require("https"),wAe=require("http"),{hdb_errors:bA}=pe(),IAe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,_Q=require("util").promisify(setTimeout),CAe=100,PAe=5,DAe="",LAe=4,dQ={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};AQ.exports={isEmpty:ps,isEmptyOrZeroLength:io,arrayHasEmptyValues:UAe,arrayHasEmptyOrZeroLengthValues:xAe,buildFolderPath:BAe,isBoolean:pQ,errorizeMessage:MAe,stripFileExtension:kAe,autoCast:FAe,autoCastJSON:hQ,autoCastJSONDeep:HP,removeDir:GAe,compareVersions:qAe,isCompatibleDataVersion:$Ae,escapeRawValue:VAe,unescapeValue:KAe,stringifyProps:YAe,timeoutPromise:zAe,isClusterOperation:QAe,getClusterUser:XAe,checkGlobalSchemaTable:JAe,getHomeDir:EQ,getPropsFilePath:WAe,promisifyPapaParse:ZAe,removeBOM:gQ,createEventPromise:eRe,checkProcessRunning:tRe,checkSchemaTableExist:rRe,checkSchemaExists:SQ,checkTableExists:TQ,getStartOfTomorrowInSeconds:nRe,getLimitKey:sRe,isObject:HAe,isNotEmptyAndHasValue:vAe,autoCasterIsNumberCheck:mQ,backtickASTSchemaItems:iRe,isPortTaken:jAe,createForkArgs:oRe,autoCastBoolean:aRe,async_set_timeout:_Q,getTableHashAttribute:cRe,doesSchemaExist:lRe,doesTableExist:uRe,stringifyObj:dRe,ms_to_time:fRe,changeExtension:_Re,getEnvCliRootPath:kP,noBootFile:pRe,httpRequest:hRe,transformReq:mRe,convertToMS:ERe,PACKAGE_ROOT:RAe};function MAe(e){return e instanceof Error?e:new Error(e)}a(MAe,"errorizeMessage");function ps(e){return e==null}a(ps,"isEmpty");function vAe(e){return!ps(e)&&(e||e===0||e===""||pQ(e))}a(vAe,"isNotEmptyAndHasValue");function io(e){return ps(e)||e.length===0||e.size===0}a(io,"isEmptyOrZeroLength");function UAe(e){if(ps(e))return!0;for(let t=0;t<e.length;t++)if(ps(e[t]))return!0;return!1}a(UAe,"arrayHasEmptyValues");function xAe(e){if(io(e))return!0;for(let t=0;t<e.length;t++)if(io(e[t]))return!0;return!1}a(xAe,"arrayHasEmptyOrZeroLengthValues");function BAe(...e){try{return e.join(mc.sep)}catch{console.error(e)}}a(BAe,"buildFolderPath");function pQ(e){return ps(e)?!1:e===!0||e===!1}a(pQ,"isBoolean");function HAe(e){return ps(e)?!1:typeof e=="object"}a(HAe,"isObject");function kAe(e){return io(e)?DAe:e.slice(0,-LAe)}a(kAe,"stripFileExtension");function FAe(e){return ps(e)||e===""||typeof e!="string"?e:dQ[e]!==void 0?dQ[e]:mQ(e)===!0?Number(e):IAe.test(e)?new Date(e):e}a(FAe,"autoCast");function hQ(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(hQ,"autoCastJSON");function HP(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=HP(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=HP(r);n!==r&&(e[t]=n)}return e}else return hQ(e)}a(HP,"autoCastJSONDeep");function mQ(e){if(e.startsWith("0.")&&uQ(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&uQ(e))}a(mQ,"autoCasterIsNumberCheck");async function GAe(e){if(io(e))throw new Error(`Directory path: ${e} does not exist`);try{await cQ.emptyDir(e),await cQ.remove(e)}catch(t){throw Un.error(`Error removing files in ${e} -- ${t}`),t}}a(GAe,"removeDir");function qAe(e,t){if(io(e)){Un.info("Invalid current version sent as parameter.");return}if(io(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 u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(qAe,"compareVersions");function $Ae(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a($Ae,"isCompatibleDataVersion");function VAe(e){if(ps(e))return e;let t=String(e);return t==="."?Rr.UNICODE_PERIOD:t===".."?Rr.UNICODE_PERIOD+Rr.UNICODE_PERIOD:t.replace(Rr.FORWARD_SLASH_REGEX,Rr.UNICODE_FORWARD_SLASH)}a(VAe,"escapeRawValue");function KAe(e){if(ps(e))return e;let t=String(e);return t===Rr.UNICODE_PERIOD?".":t===Rr.UNICODE_PERIOD+Rr.UNICODE_PERIOD?"..":String(e).replace(Rr.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(KAe,"unescapeValue");function YAe(e,t){if(ps(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+RA.EOL}!io(n)&&n[0]===";"?r+=" "+n+s+RA.EOL:io(n)||(r+=n+"="+s+RA.EOL)}catch{Un.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(YAe,"stringifyProps");function EQ(){let e;try{e=RA.homedir()}catch{e=process.env.HOME}return e}a(EQ,"getHomeDir");function WAe(){let e=mc.join(EQ(),Rr.HDB_HOME_DIR_NAME,Rr.BOOT_PROPS_FILE_NAME);return fQ.existsSync(e)||(e=mc.join(__dirname,"../","hdb_boot_properties.file")),e}a(WAe,"getPropsFilePath");function zAe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(zAe,"timeoutPromise");async function jAe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=TAe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(jAe,"isPortTaken");function QAe(e){try{return Rr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Un.error(`Error checking operation against cluster ops ${t}`)}return!1}a(QAe,"isClusterOperation");function JAe(e,t){let r=(Pe(),C(rt)).getDatabases();if(!r[e])return bA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return bA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(JAe,"checkGlobalSchemaTable");function XAe(e,t){if(ps(t)){Un.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ps(e)||io(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(XAe,"getClusterUser");function ZAe(){lQ.parsePromise=function(e,t,r){return new Promise(function(n,s){lQ.parse(e,{header:!0,transformHeader:gQ,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(ZAe,"promisifyPapaParse");function gQ(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(gQ,"removeBOM");function eRe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Un.info(`Got cluster status event response: ${bAe(s)}`);try{i.cancel()}catch{Un.error("Error trying to cancel timeout.")}n(s)})})}a(eRe,"createEventPromise");async function tRe(e){let t=!0,r=0;do await _Q(CAe*r++),(await yAe.findPs(e)).length>0&&(t=!1);while(t&&r<PAe);if(t)throw new Error(`process ${e} was not started`)}a(tRe,"checkProcessRunning");function rRe(e,t){let r=SQ(e);if(r)return r;let n=TQ(e,t);if(n)return n}a(rRe,"checkSchemaTableExist");function SQ(e){let{getDatabases:t}=(Pe(),C(rt));if(!t()[e])return bA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(SQ,"checkSchemaExists");function TQ(e,t){let{getDatabases:r}=(Pe(),C(rt));if(!r()[e][t])return bA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(TQ,"checkTableExists");function nRe(){let e=yA().utc().add(1,"d").startOf("d").unix(),t=yA().utc().unix();return e-t}a(nRe,"getStartOfTomorrowInSeconds");function sRe(){return yA().utc().format("DD-MM-YYYY")}a(sRe,"getLimitKey");function iRe(e){try{let t=new AAe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){Un.error("Got an error back ticking items."),Un.error(t)}}a(iRe,"backtickASTSchemaItems");function oRe(e){return[e]}a(oRe,"createForkArgs");function aRe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(aRe,"autoCastBoolean");function cRe(e,t){let{getDatabases:r}=(Pe(),C(rt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(cRe,"getTableHashAttribute");function lRe(e){let{getDatabases:t}=(Pe(),C(rt));return t()[e]!==void 0}a(lRe,"doesSchemaExist");function uRe(e,t){let{getDatabases:r}=(Pe(),C(rt));return r()[e]?.[t]!==void 0}a(uRe,"doesTableExist");function dRe(e){try{return JSON.stringify(e)}catch{return e}}a(dRe,"stringifyObj");function fRe(e){let t=yA.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(fRe,"ms_to_time");function _Re(e,t){let r=mc.basename(e,mc.extname(e));return mc.join(mc.dirname(e),r+t)}a(_Re,"changeExtension");function kP(){if(process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=OAe(process.argv);if(e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(kP,"getEnvCliRootPath");var BP;function pRe(){if(BP)return BP;let e=kP();if(kP()&&fQ.pathExistsSync(mc.join(e,Rr.HDB_CONFIG_FILE)))return BP=!0,!0}a(pRe,"noBootFile");function hRe(e,t){let r;return e.protocol==="http:"?r=wAe:r=NAe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(hRe,"httpRequest");function mRe(e){if(!e.schema&&!e.database){e.schema=Rr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(mRe,"transformReq");function ERe(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(ERe,"convertToMS")});var ce=I((NQ,wQ)=>{"use strict";var FP=require("fs-extra"),Zl=require("path"),RQ=require("os"),gRe=require("properties-reader"),qh=Y(),Gh=oe(),Me=(B(),C(G)),OA=Rt(),SRe="Error initializing environment manager",NA="BOOT_PROPS_FILE_PATH",yQ=!1,TRe={[Me.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ra={};Object.assign(NQ,wQ.exports={BOOT_PROPS_FILE_PATH:NA,getHdbBasePath:ARe,setHdbBasePath:RRe,get:bQ,initSync:bRe,setProperty:Ye,initTestEnvironment:NRe,setCloneVar:ORe});function ARe(){return ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(ARe,"getHdbBasePath");function RRe(e){ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(RRe,"setHdbBasePath");function bQ(e){let t=OA.getConfigValue(e);return t===void 0?ra[e]:t}a(bQ,"get");function Ye(e,t){TRe[e]&&(ra[e]=t),OA.updateConfigObject(e,t)}a(Ye,"setProperty");function yRe(){let e;try{e=Gh.getPropsFilePath(),FP.accessSync(e,FP.constants.F_OK|FP.constants.R_OK),yQ=!0;let t=gRe(e);return ra[Me.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Me.HDB_SETTINGS_NAMES.INSTALL_USER),ra[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ra[NA]=e,!0}catch{return qh.trace(`Environment manager found no properties file at ${e}`),!1}}a(yRe,"doesPropFileExist");function bRe(e=!1){try{((yQ||yRe()||Gh.noBootFile())&&!OQ||e)&&(OA.initConfig(e),ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=OA.getConfigValue(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){qh.error(SRe),qh.error(t),console.error(t),process.exit(1)}}a(bRe,"initSync");var OQ=!1;function ORe(e){OQ=e}a(ORe,"setCloneVar");function NRe(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=Zl.join(__dirname,"../../","unitTests");ra[NA]=Zl.join(l,"hdb_boot_properties.file"),Ye(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Zl.join(l,"settings.test")),Ye(Me.HDB_SETTINGS_NAMES.INSTALL_USER,RQ.userInfo()?RQ.userInfo().username:void 0),Ye(Me.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ye(Me.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Zl.join(l,"envDir","log")),Ye(Me.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ye(Me.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ye(Me.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ye(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Zl.join(l,"envDir")),Ye(Me.CONFIG_PARAMS.STORAGE_PATH,Zl.join(l,"envDir")),s&&(Ye(Me.CONFIG_PARAMS.HTTP_SECUREPORT,bQ(Me.CONFIG_PARAMS.HTTP_PORT)),Ye(Me.CONFIG_PARAMS.HTTP_PORT,null)),Ye(Me.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ye(Me.CONFIG_PARAMS.HTTP_PORT,9926),Ye(Me.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ye(Me.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Ye(Me.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Gh.isEmpty(i)?!1:i),Ye(Me.CONFIG_PARAMS.HTTP_CORS,Gh.isEmpty(i)?!1:i),Ye(Me.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ye(Me.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Zl.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ye(Me.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Gh.isEmpty(c)?!1:c),o&&(Ye("CORS_ACCESSLIST",o),Ye(Me.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ye(Me.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ye(Me.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ye(Me.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${NA}. Please check your boot props and settings files`;qh.fatal(r),qh.error(t)}}a(NRe,"initTestEnvironment")});var LQ=I((Axe,DQ)=>{"use strict";var IA=ce();IA.initSync();var wA=(B(),C(G)),{httpRequest:wRe}=oe(),PQ=require("path"),IQ=require("fs-extra"),IRe=require("yaml"),{packageDirectory:CRe}=(Gw(),C(Fw)),{encode:PRe}=require("cbor-x"),DRe=["describe_table","describe_all","describe_database","list_users","list_roles","drop_role","add_user","alter_user","drop_user","restart_service","restart","create_database","drop_database","create_table","drop_table","create_attribute","drop_attribute","search_by_id","insert","update","upsert","delete","search_by_value","csv_file_load","csv_url_load","cluster_get_routes","cluster_network","cluster_status","remove_node","add_component","deploy_component","package_component","drop_component","get_components","get_component_file","set_component_file","registration_info","get_fingerprint","set_license","get_job","search_jobs_by_start_date","read_log","read_transaction_log","read_audit_log","delete_transaction_logs_before","purge_stream","delete_records_before","install_node_modules","set_configuration","get_configuration","create_authentication_tokens","refresh_operation_token","system_information","sql","create_csr","sign_certificate","list_certificates","add_certificate","remove_certificate","add_ssh_key","update_ssh_key","delete_ssh_key","list_ssh_keys","set_ssh_known_hosts","get_ssh_known_hosts"],CQ={deploy:"deploy_component",package:"package_component"};DQ.exports={cliOperations:vRe,buildRequest:MRe};var LRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await CRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=PQ.basename(t))},"deploy_component")};function MRe(){let e={};for(let t of process.argv.slice(2))if(DRe.includes(t))e.operation=t;else if(CQ.hasOwnProperty(t))e.operation=CQ[t];else if(t.includes("=")){let[r,...n]=t.split("=");n=n.join("=");try{n=JSON.parse(n)}catch{}e[r]=n}return e}a(MRe,"buildRequest");async function vRe(e){e.target||(e.target=process.env.CLI_TARGET);let t;if(e.target){try{t=new URL(e.target)}catch(r){try{t=new URL(`https://${e.target}:9925`)}catch{throw r}}t={protocol:t.protocol,hostname:t.hostname,port:t.port,username:e.username||t.username||process.env.CLI_TARGET_USERNAME,password:e.password||t.password||process.env.CLI_TARGET_PASSWORD,rejectUnauthorized:e.rejectUnauthorized}}else IQ.existsSync(PQ.join(IA.get(wA.CONFIG_PARAMS.ROOTPATH),wA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),IQ.existsSync(IA.get(wA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await LRe[e.operation]?.(e);try{let r=t??{protocol:"http:",socketPath:IA.get(wA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)};r.method="POST",r.headers={"Content-Type":"application/json"},t?.username&&(r.headers.Authorization=`Basic ${Buffer.from(`${t.username}:${t.password}`).toString("base64")}`),e.cborEncode&&(r.headers["Content-Type"]="application/cbor",e=PRe(e));let n=await wRe(r,e),s;try{s=JSON.parse(n.body)}catch{s={status:n.statusCode+" "+(n.statusMessage||"Unknown"),body:n.body}}e.json?console.log(JSON.stringify(s,null,2)):console.log(IRe.stringify(s).trim())}catch(r){let n="Error: ";if(r?.response?.data?.error)n+=r.response.data.error;else if(r?.response?.data)n+=r?.response?.data;else return console.error(r);console.error(n)}}a(vRe,"cliOperations")});var UQ=I((yxe,vQ)=>{"use strict";var MQ=require("semver/functions/major"),{packageJson:URe}=nt(),GP=process.versions&&process.versions.node?process.versions.node:void 0;vQ.exports=xRe;function xRe(){let e=URe.engines["minimum-node"];if(GP&&MQ(GP)<MQ(e))return{error:`The minimum version of Node.js HarperDB supports is: ${e}, the currently installed Node.js version is: ${GP}. Please install a version of Node.js that is withing the defined range.`}}a(xRe,"checkNodeVersion")});var zP=I((Nxe,nJ)=>{"use strict";var xQ=require("os"),CA=require("https"),BQ=require("http"),Jt=require("fs-extra"),HQ=require("yaml"),{pipeline:kQ}=require("stream/promises"),{createWriteStream:PA,ensureDir:$h,writeFileSync:FQ}=require("fs-extra"),{join:Ri}=require("path"),VQ=require("lodash"),BRe=require("minimist"),na=require("path"),HRe=require("node:crypto"),kRe=require("properties-reader"),Ks=ce(),FRe=Do(),KP=Y(),DA=Rt(),{restart:GRe}=za(),LA=oe(),qRe=da(),$Re=bs(),{main:MA,launch:VRe}=jd(),{install:KQ,updateConfigEnv:KRe,setIgnoreExisting:vA}=CT(),YQ=hC(),cn=(B(),C(G)),{packageJson:YRe}=nt(),WRe=mh(),{sendOperationToNode:VP}=(ts(),C(Po)),{updateConfigCert:zRe}=rs(),{restartWorkers:jRe}=tt(),{databases:QRe}=(Pe(),C(rt)),{SYSTEM_TABLE_NAMES:qP,SYSTEM_SCHEMA_NAME:Oxe,CONFIG_PARAMS:Vh,OPERATIONS_ENUM:Es}=cn,JRe=1e4,XRe="clone-node-config.yaml",WQ=[qP.ROLE_TABLE_NAME,qP.USER_TABLE_NAME,qP.NODE_TABLE_NAME],ZRe={clustering_nodename:!0,clustering_leafserver_streams_path:!0,clustering_tls_certificate:!0,clustering_tls_privatekey:!0,clustering_tls_certificateauthority:!0,logging_file:!0,logging_root:!0,logging_rotation_path:!0,operationsapi_network_domainsocket:!0,operationsapi_tls_certificate:!0,operationsapi_tls_privatekey:!0,operationsapi_tls_certificateauthority:!0,rootpath:!0,storage_path:!0,storage_audit_path:!0,databases:!0,mqtt_network_mtls_certificateauthority:!0,componentsroot:!0,tls_certificate:!0,tls_privatekey:!0,tls_certificateauthority:!0,replication_hostname:!0,replication_url:!0,cloned:!0},Fr={HDB_LEADER_USERNAME:"HDB_LEADER_USERNAME",HDB_LEADER_PASSWORD:"HDB_LEADER_PASSWORD",HDB_LEADER_URL:"HDB_LEADER_URL",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",HDB_CLONE_OVERTOP:"HDB_CLONE_OVERTOP",CLONE_KEYS:"CLONE_KEYS",CLONE_USING_WS:"CLONE_USING_WS",NO_START:"NO_START"},ia=BRe(process.argv),_f=ia[Fr.HDB_LEADER_USERNAME]??process.env[Fr.HDB_LEADER_USERNAME],pf=ia[Fr.HDB_LEADER_PASSWORD]??process.env[Fr.HDB_LEADER_PASSWORD],tu=ia[Fr.HDB_LEADER_URL]??process.env[Fr.HDB_LEADER_URL],sa=ia[Fr.REPLICATION_HOSTNAME]??process.env[Fr.REPLICATION_HOSTNAME],zQ,jQ;sa&&([zQ,jQ]=sa.split(":"));var YP=(ia[Fr.HDB_CLONE_OVERTOP]??process.env[Fr.HDB_CLONE_OVERTOP])==="true",QQ=ia[Vh.CLONED.toUpperCase()]??process.env[Vh.CLONED.toUpperCase()],eye=ia[Fr.CLONE_KEYS]!=="false"&&process.env[Fr.CLONE_KEYS]!=="false",JQ=(ia[Fr.CLONE_USING_WS]??process.env[Fr.CLONE_USING_WS])==="true",XQ=(ia[Fr.NO_START]??process.env[Fr.NO_START])==="true",ms,Ec={},GQ,qQ,eu={},an,Gt,Vs,oo,ru=!1,WP=!1,hs,hf;nJ.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${tu}`),delete process.env.HDB_LEADER_URL,Gt=LA.getEnvCliRootPath(),!Gt)try{let i=Ri(xQ.homedir(),cn.HDB_HOME_DIR_NAME,cn.BOOT_PROPS_FILE_NAME);if(await Jt.pathExists(i)){let o=kRe(i);Gt=na.parse(o.get(cn.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)).dir}}catch{throw new Error("There was an error setting the clone default root path. Please set ROOTPATH using an environment or CLI variable.")}Gt?await Jt.pathExists(Gt)?console.log(`Existing HarperDB install found at ${Gt}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Gt} starting fresh clone`),ru=!0):(console.log("No HarperDB install found, starting fresh clone"),ru=!0),Gt||(Gt=Ri(xQ.homedir(),cn.HDB_ROOT_DIR_NAME),console.log("Using default root path",Gt));let n;try{n=Ri(Gt,XRe),ms=HQ.parseDocument(await Jt.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=Ri(Gt,cn.HDB_CONFIG_FILE);if(await Jt.pathExists(s))try{GQ=HQ.parseDocument(await Jt.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),Ec=DA.flattenConfig(GQ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(sa){let i=new URL(tu);hf=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${jQ||9933}`}if(JQ){await tye();return}if(Ec?.cloned&&QQ!=="false")return console.log("Instance marked as cloned, clone will not run"),Ks.setCloneVar(!1),Ks.initSync(),MA();an=await ZQ({operation:Es.DESCRIBE_ALL}),await tJ(),Ks.setCloneVar(!1),Ks.setHdbBasePath(Gt),Jt.ensureDir(Ks.get(cn.CONFIG_PARAMS.LOGGING_ROOT)),KP.initLogSettings(),await rye(),WP||await nye(),await oye(t,r),sa&&(await cye(),await eJ()),console.info(`
|
|
135
|
+
Successfully cloned node: `+tu),(t||XQ)&&process.exit()},"cloneNode");async function tye(){if(Ec?.cloned&&QQ!=="false")return console.log("Instance marked as cloned, clone will not run"),Ks.setCloneVar(!1),Ks.initSync(),MA();console.log("Cloning using WebSockets");let e=gc("system"),t=Ri(e,"system.mdb"),r=Jt.existsSync(t);ru||!r||YP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Gt,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=HRe.randomBytes(10).toString("base64").slice(0,10),vA(!0),await KQ()):(Ks.setCloneVar(!1),Ks.initSync()),await MA(),await tJ(!0),await zRe(),r||await QRe.system.hdb_user.delete({username:"clone-temp-admin"}),await jRe(),console.log("Adding node to the cluster");let s=await Ed()({operation:Es.ADD_NODE,url:hf});console.log("Add node response: ",s),await eJ(),console.log(`Successfully cloned node: ${tu} using WebSockets`),DA.updateConfigValue(Vh.CLONED,!0),XQ&&process.exit()}a(tye,"cloneUsingWS");async function ZQ(e){return JQ?VP({url:hf},e,{rejectUnauthorized:!1}):JSON.parse((await lye(e)).body)}a(ZQ,"leaderReq");async function eJ(){try{if(eye!==!1){console.log("Cloning JWT keys");let e=na.join(Gt,cn.LICENSE_KEY_DIR_NAME),t=await VP({url:hf},{operation:Es.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});FQ(na.join(e,cn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await VP({url:hf},{operation:Es.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});FQ(na.join(e,cn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r.message)}}catch(e){console.error("Error cloning JWT keys",e)}}a(eJ,"cloneKeys");async function tJ(e=!1){console.info("Cloning configuration"),qQ=await ZQ({operation:Es.GET_CONFIGURATION}),eu=DA.flattenConfig(qQ);let t=ms?.componentConfig?.exclude,r={rootpath:Gt};sa&&(r.replication_hostname=zQ);for(let i in eu)if(!(eu[i]!==null&&typeof eu[i]=="object"&&!(eu[i]instanceof Array)||ZRe[i])){if(i.includes("_package")||i.includes("_port")){if(eu[i]?.includes?.("hdb/components"))continue;if(t){let o=!1;for(let c of t)if(i.includes(c.name)){o=!0;break}if(o)continue}}Ec[i]||(r[i]=eu[i])}for(let i in Ec)i!=="databases"&&typeof Ec[i]=="object"&&!(Ec[i]instanceof Array)||(r[i]=Ec[i]);let n={};if(ms?.databaseConfig?.excludeDatabases&&ms.databaseConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),ms?.clusteringConfig?.excludeDatabases&&ms.clusteringConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),Object.keys(n).length>0){r.replication_databases=[],n.system||r.replication_databases.push("system");for(let i in an)n[i]||r.replication_databases.push(i)}let s=qRe(Object.keys(cn.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),DA.createConfigFile(r,!0)}a(tJ,"cloneConfig");async function rye(){process.env.HDB_FETCH==="true"?(await iye(),process.env.NODE_TLS_REJECT_UNAUTHORIZED&&delete process.env.NODE_TLS_REJECT_UNAUTHORIZED):await sye()}a(rye,"cloneDatabases");async function nye(){if(console.info("Clone node installing HarperDB."),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Gt,!_f)throw new Error("HDB_LEADER_USERNAME is undefined.");if(process.env.HDB_ADMIN_USERNAME=_f,!pf)throw new Error("HDB_LEADER_PASSWORD is undefined.");process.env.HDB_ADMIN_PASSWORD=pf,process.env.OPERATIONSAPI_NETWORK_PORT=Ks.get(Vh.OPERATIONSAPI_NETWORK_PORT),KRe(na.join(Gt,cn.HDB_CONFIG_FILE)),vA(!0),await KQ()}a(nye,"installHDB");function gc(e){return Ks.get(cn.CONFIG_PARAMS.DATABASES)?.[e]?.path||Ks.get(Vh.STORAGE_PATH)||na.join(Gt,cn.DATABASES_DIR_NAME)}a(gc,"getDBPath");async function sye(){let e=gc("system"),t=Ri(e,"system.mdb");if(await $h(e),ru||!await Jt.exists(t)||YP){if(!sa){console.info("Cloning system database"),await $h(e);let r=PA(t,{overwrite:!0}),n={operation:Es.GET_BACKUP,database:"system",tables:WQ},s=await $Q(n,r),i=new Date(s.date);(!hs||i<hs)&&(hs=i),await Jt.utimes(t,Date.now(),i)}ru||(await YQ(Gt),await rJ(),vA(!0))}else WP=!0,console.log("Not cloning system database due to it already existing on clone");Vs=ms?.databaseConfig?.excludeDatabases,Vs=Vs?Vs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in an)await Jt.exists(na.join(gc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Vs[r]=!0);oo=ms?.databaseConfig?.excludeTables,oo=oo?oo.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in an){if(Vs[r]){an[r]="excluded";continue}if(VQ.isEmpty(an[r]))continue;let n=[],s=!1;for(let d in an[r])oo[r+d]?(s=!0,an[r][d]="excluded"):n.push(an[r][d]);if(n.length===0)continue;if(sa){KP.debug("Setting up tables for #{db}");let d=(Pe(),C(rt)).table;for(let p of n){for(let _ of p.attributes)(_.is_hash_attribute||_.is_primary_key)&&(_.isPrimaryKey=!0);d({database:r,table:p.name,attributes:p.attributes})}continue}n=n.map(d=>d.name);let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i={operation:Es.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:Es.GET_BACKUP,database:r});let o=gc(r);await $h(o);let c=Ri(o,r+".mdb"),l=PA(c,{overwrite:!0}),u=await $Q(i,l),f=new Date(u.date);(!hs||f<hs)&&(hs=f),await Jt.utimes(c,Date.now(),f)}}a(sye,"cloneTablesHttp");async function iye(){let e=gc("system"),t=Ri(e,"system.mdb");if(ru||!await Jt.exists(t)||YP){if(!sa){console.info("Cloning system database using fetch");let r={operation:Es.GET_BACKUP,database:"system",tables:WQ},n=await $P(r,!0),s=gc("system");await $h(s);let i=Ri(s,"system.mdb");await kQ(n.body,PA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!hs||o<hs)&&(hs=o),await Jt.utimes(i,Date.now(),new Date(n.headers.get("date")))}ru||(await YQ(Gt),await rJ(),vA(!0))}else WP=!0,console.log("Not cloning system database due to it already existing on clone");if(sa){KP.info("Replication hostname set, not using backup to clone databases, replication will clone");return}Vs=ms?.databaseConfig?.excludeDatabases,Vs=Vs?Vs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in an)await Jt.exists(na.join(gc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Vs[r]=!0);oo=ms?.databaseConfig?.excludeTables,oo=oo?oo.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in an){if(Vs[r]){an[r]="excluded";continue}if(VQ.isEmpty(an[r]))continue;let n=[],s=!1;for(let f in an[r])oo[r+f]?(s=!0,an[r][f]="excluded"):n.push(f);if(n.length===0)return;let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i=await $P({operation:Es.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await $P({operation:Es.GET_BACKUP,database:r},!0));let o=gc(r);await $h(o);let c=new Date(i.headers.get("date")),l=Ri(o,`${c.getTime()}-${r}.mdb`);await kQ(i.body,PA(l,{overwrite:!0}));let u=Ri(o,r+".mdb");await Jt.rename(l,u),(!hs||c<hs)&&(hs=c),await Jt.utimes(u,Date.now(),c)}}a(iye,"cloneTablesFetch");async function $P(e,t=!1){let r=ms?.httpsRejectUnauthorized??!1,n=new CA.Agent({rejectUnauthorized:r});r||(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0");let i={Authorization:"Basic "+Buffer.from(_f+":"+pf).toString("base64"),"Content-Type":"application/json"};t&&(i["Accept-Encoding"]="gzip");let o=await fetch(tu,{method:"POST",headers:i,body:JSON.stringify(e),agent:n,compress:!0});if(o.ok)return o;throw console.error(`HTTP Error Response: ${o.status} ${o.statusText}`),new Error(await o.text())}a($P,"leaderHttpReqFetch");async function oye(e,t=!1){let r=await FRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await VRe(!1):(t&&await aye(),await MA()):(console.info(await GRe({operation:Es.RESTART})),await LA.async_set_timeout(JRe)),e&&await LA.async_set_timeout(2e3)}a(oye,"startHDB");async function aye(){let e=process.argv[3];e&&e[0]!=="-"&&(await Jt.exists(e)||console.error(`The folder ${e} does not exist`),Jt.statSync(e).isDirectory()||console.error(`The path ${e} is not a folder`),e=await Jt.realpath(e),await Jt.exists(na.join(e,cn.HDB_CONFIG_FILE))?process.env.ROOTPATH=e:process.env.RUN_HDB_APP=e)}a(aye,"setAppPath");async function cye(){console.info("Setting up replication"),await $Re.setSchemaDataToGlobalAsync();let t=await Ed()({operation:Es.ADD_NODE,verify_tls:!1,url:hf,start_time:hs,authorization:{username:_f,password:pf}},!0);console.log("Add node response: ",t)}a(cye,"setupReplication");async function lye(e){let t=new CA.Agent({rejectUnauthorized:ms?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(_f+":"+pf).toString("base64"),"Content-Type":"application/json"},s=new URL(tu),i={protocol:s.protocol,host:s.hostname,method:"POST",headers:n};return s.protocol==="https:"&&(i.agent=t),s.port&&(i.port=s.port),await LA.httpRequest(i,e)}a(lye,"leaderHttpReq");async function $Q(e,t){let r=new CA.Agent({rejectUnauthorized:ms?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(_f+":"+pf).toString("base64"),"Content-Type":"application/json"},i=new URL(tu),o={protocol:i.protocol,host:i.hostname,method:"POST",headers:s};return i.protocol==="https:"&&(o.agent=r,BQ=CA),i.port&&(o.port=i.port),new Promise((c,l)=>{let u=BQ.request(o,f=>{f.statusCode!==200&&l("Request to leader node failed with code: "+f.statusCode),f.pipe(t),f.on("end",()=>{t.close(),c(f.headers)})});u.on("error",f=>{l(f)}),u.write(JSON.stringify(e)),u.end()})}a($Q,"leaderHttpStream");async function rJ(){let e=YRe.version;if(e)await WRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(rJ,"insertHdbVersionInfo")});var iJ=I((Ixe,sJ)=>{var uye=CT(),dye=Y();sJ.exports=fye;async function fye(){try{await uye.install()}catch(e){console.error("There was an error during the install."),console.error(e),dye.error(e),process.exit(1)}}a(fye,"install")});var cJ=I((Pxe,aJ)=>{"use strict";var _ye=hS(),pye=Y(),oJ="Registration failed.";async function hye(){let e;try{e=await _ye.register()}catch(t){return pye.error(`Registration error ${t}`),oJ}return e||oJ}a(hye,"register");aJ.exports={register:hye}});var fJ=I((Lxe,dJ)=>{"use strict";var mye=Y(),Eye=(B(),C(G)),gye=require("util"),Sye=require("child_process"),lJ=gye.promisify(Sye.exec),Tye=Do(),Kh=Id(),uJ="Stopping HarperDB.";dJ.exports=Aye;async function Aye(){if(console.log(uJ),mye.notify(uJ),await Kh.isServiceRegistered(Eye.PROCESS_DESCRIPTORS.HDB)){Kh.enterPM2Mode();let r=await Kh.getUniqueServicesList();for(let n in r)await Kh.stop(n)}await Kh.kill();let t=await Tye.getHDBProcessInfo();t.clustering.forEach(r=>{lJ(`kill ${r.pid}`)}),t.core.forEach(r=>{lJ(`kill ${r.pid}`)})}a(Aye,"stop")});var hJ=I((vxe,pJ)=>{"use strict";var QP=require("fs-extra"),JP=require("path"),jP=require("yaml"),Yh=ir(),Sc=(B(),C(G)),_J=St(),XP=Y(),Rye=Rn(),yye=lS(),bye=aS(),Oye=Do(),Wh=ce(),Nye=jd(),wye=oe();Wh.initSync();var Ys={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},xn={LEAF:"leaf server",HUB:"hub server"},UA;pJ.exports=Iye;async function Iye(){let e={harperdb:{status:Ys.STOPPED}};if(!await Nye.isHdbInstalled()){e.harperdb.status=Ys.NOT_INSTALLED,console.log(jP.stringify(e));return}UA=Wh.get(Sc.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await QP.readFile(JP.join(UA,Sc.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Sc.NODE_ERROR_CODES.ENOENT){XP.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Ys.STOPPED,console.log(jP.stringify(e));return}throw n}let r=await Oye.getHDBProcessInfo();for(let n of r.core)if(n.pid===t){e.harperdb.status=Ys.RUNNING,e.harperdb.pid=t;break}if((Wh.get(Sc.CONFIG_PARAMS.REPLICATION_URL)||Wh.get(Sc.CONFIG_PARAMS.REPLICATION_HOSTNAME))&&(e.replication=await Pye()),e.clustering=await Cye(r),e.clustering[xn.HUB].status===Ys.RUNNING&&e.clustering[xn.LEAF].status===Ys.RUNNING){let n=[],s=await yye({});for(let o of s.nodes){let c={};for(let l in o)c[l.replace("_"," ")]=o[l];n.push(c)}e.clustering.network=n;let i=await bye.clusterStatus();e.clustering.replication={"node name":i.node_name,"is enabled":i.is_enabled,connections:[]};for(let o of i.connections){let c={};c["node name"]=o?.node_name,c.status=o?.status,c.ports={clustering:o?.ports?.clustering,"operations api":o?.ports?.operations_api},c["latency ms"]=o?.latency_ms,c.uptime=o?.uptime,c.subscriptions=o?.subscriptions,c["system info"]={"hdb version":o?.system_info?.hdb_version,"node version":o?.system_info?.node_version,platform:o?.system_info?.platform},e.clustering.replication.connections.push(c)}await Yh.closeConnection()}console.log(jP.stringify(e)),process.exit()}a(Iye,"status");async function Cye(e){let t={[xn.HUB]:{},[xn.LEAF]:{}};if(e.clustering.length===0)return t[xn.HUB].status=Ys.STOPPED,t[xn.LEAF].status=Ys.STOPPED,t;let{port:r}=Yh.getServerConfig(Sc.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await Rye.getClusterUser();try{(await Yh.createConnection(r,n,s,!1)).close(),t[xn.HUB].status=Ys.RUNNING}catch{t[xn.HUB].status=Ys.ERRORED}let{port:i}=Yh.getServerConfig(Sc.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await Yh.createConnection(i,n,s,!1)).close(),t[xn.LEAF].status=Ys.RUNNING}catch{t[xn.LEAF].status=Ys.ERRORED}try{t[xn.HUB].pid=Number.parseInt(await QP.readFile(JP.join(UA,"clustering",_J.PID_FILES.HUB),"utf8"))}catch(o){XP.error(o),t[xn.HUB].pid=void 0}try{t[xn.LEAF].pid=Number.parseInt(await QP.readFile(JP.join(UA,"clustering",_J.PID_FILES.LEAF),"utf8"))}catch(o){XP.error(o),t[xn.LEAF].pid=void 0}return t}a(Cye,"getHubLeafStatus");async function Pye(){let e=await wye.httpRequest({method:"POST",protocol:"http:",socketPath:Wh.get(Sc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),headers:{"Content-Type":"application/json"}},{operation:"cluster_status"});e=JSON.parse(e.body);let t={"node name":e.node_name,"is enabled":e.is_enabled,connections:[]};for(let r of e.connections)t.connections.push({"node name":r.name,url:r.url,subscriptions:r.subscriptions,replicates:r.replicates,"database sockets":r.database_sockets.map(n=>({database:n.database,connected:n.connected,latency:n.latency,"catching up from":n.catching_up_from,"thread id":n.thread_id,nodes:n.nodes}))});return t}a(Pye,"getReplicationStatus")});rm();var ZP=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");ZP&&ce().setCloneVar(!0);var zh=require("node:fs"),mJ=require("node:path"),nu=Y(),EJ=LQ(),{packageJson:Dye,PACKAGE_ROOT:gJ}=nt(),Lye=UQ(),eD=(B(),C(G)),{SERVICE_ACTIONS_ENUM:ln}=eD,Mye=`
|
|
136
136
|
Usage: harperdb [command]
|
|
137
137
|
|
|
138
138
|
With no command, harperdb will simply run HarperDB (in the foreground)
|
|
@@ -154,4 +154,4 @@ stop - Stop the harperdb background process
|
|
|
154
154
|
help - Display this output
|
|
155
155
|
upgrade - Upgrade harperdb
|
|
156
156
|
version - Print the version
|
|
157
|
-
`;async function
|
|
157
|
+
`;async function vye(){let e=Lye();if(e)if(e.error){console.error(e.error),nu.error(e.error);return}else e.warn&&(console.warn(e.warn),nu.warn(e.warn));let t;zh.existsSync(mJ.join(gJ,"bin"))||(nu.error(`Missing \`bin\` directory at ${gJ}`),process.exit(0)),process.argv&&process.argv[2]&&!process.argv[2].startsWith("-")&&(t=process.argv[2].toLowerCase());let r=EJ.buildRequest();switch(r.operation&&(t=ln.OPERATION),t){case ln.OPERATION:return nu.trace("calling cli operations with:",r),EJ.cliOperations(r);case ln.START:return ZP?zP()(!0):jd().launch();case ln.INSTALL:return iJ()();case ln.REGISTER:return cJ().register();case ln.STOP:return fJ()().then(()=>{process.exit(0)});case ln.RESTART:return za().restart({});case ln.VERSION:return Dye.version;case ln.UPGRADE:return nu.setLogLevel(eD.LOG_LEVELS.INFO),bC().upgrade(null).then(()=>"Your instance of HarperDB is up to date!");case ln.STATUS:return hJ()();case ln.RENEWCERTS:return rs().renewSelfSigned().then(()=>"Successfully renewed self-signed certificates");case ln.COPYDB:{let n=process.argv[3],s=process.argv[4];return(wS(),C(NS)).copyDb(n,s)}case ln.DEV:process.env.DEV_MODE=!0;case ln.RUN:{let n=process.argv[3];if(n&&n[0]!=="-"){if(!zh.existsSync(n))throw new Error(`The folder ${n} does not exist`);if(!zh.statSync(n).isDirectory())throw new Error(`The path ${n} is not a folder`);n=zh.realpathSync(n),zh.existsSync(mJ.join(n,eD.HDB_CONFIG_FILE))?process.env.ROOTPATH=n:process.env.RUN_HDB_APP=n}}case void 0:return ZP?zP()():jd().main();default:console.warn(`The "${t}" command is not understood.`);case ln.HELP:return Mye}}a(vye,"harperdb");vye().then(e=>{e&&(console.log(e),nu.notify(e))}).catch(e=>{e&&(console.error(e),nu.error(e)),process.exit(1)});
|