harperdb 4.4.0-beta.1 → 4.4.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. package/README.md +1 -1
  2. package/bin/harperdb.js +80 -78
  3. package/bin/lite.js +75 -73
  4. package/launchServiceScripts/launchInstallNATSServer.js +3 -3
  5. package/launchServiceScripts/launchNatsIngestService.js +78 -76
  6. package/launchServiceScripts/launchNatsReplyService.js +78 -76
  7. package/launchServiceScripts/launchUpdateNodes4-0-0.js +78 -76
  8. package/npm-shrinkwrap.json +340 -329
  9. package/package.json +3 -3
  10. package/resources/ResourceInterface.d.ts +1 -1
  11. package/resources/Table.d.ts +2 -0
  12. package/resources/auditStore.d.ts +5 -5
  13. package/resources/crdt.d.ts +1 -1
  14. package/resources/databases.d.ts +3 -0
  15. package/resources/search.d.ts +14 -1
  16. package/resources/tracked.d.ts +1 -1
  17. package/server/jobs/jobProcess.js +78 -76
  18. package/server/threads/threadServer.js +78 -76
  19. package/studio/build-local/asset-manifest.json +54 -0
  20. package/studio/build-local/index.html +1 -0
  21. package/studio/build-local/static/css/main.fee3019a.css +13 -0
  22. package/studio/build-local/static/js/23.3b9f7144.chunk.js +1 -0
  23. package/studio/build-local/static/js/239.183c6cbc.chunk.js +2 -0
  24. package/studio/build-local/static/js/239.183c6cbc.chunk.js.LICENSE.txt +5 -0
  25. package/studio/build-local/static/js/279.7890bce3.chunk.js +1 -0
  26. package/studio/build-local/static/js/311.9e648b13.chunk.js +2 -0
  27. package/studio/build-local/static/js/311.9e648b13.chunk.js.LICENSE.txt +38 -0
  28. package/studio/build-local/static/js/43.73dc432d.chunk.js +2 -0
  29. package/studio/build-local/static/js/43.73dc432d.chunk.js.LICENSE.txt +1 -0
  30. package/studio/build-local/static/js/452.d771b05a.chunk.js +2 -0
  31. package/studio/build-local/static/js/452.d771b05a.chunk.js.LICENSE.txt +13 -0
  32. package/studio/build-local/static/js/545.be2e36f9.chunk.js +1 -0
  33. package/studio/build-local/static/js/759.7c5150cd.chunk.js +2 -0
  34. package/studio/build-local/static/js/759.7c5150cd.chunk.js.LICENSE.txt +8 -0
  35. package/studio/build-local/static/js/805.6aab06e2.chunk.js +1 -0
  36. package/studio/build-local/static/js/806.afb99f70.chunk.js +1 -0
  37. package/studio/build-local/static/js/833.5b133801.chunk.js +1 -0
  38. package/studio/build-local/static/js/851.4c6536d6.chunk.js +1 -0
  39. package/studio/build-local/static/js/860.727e7fc8.chunk.js +1 -0
  40. package/studio/build-local/static/js/browse-csvupload.02fdfbea.chunk.js +1 -0
  41. package/studio/build-local/static/js/browse-datatable.0e20a171.chunk.js +1 -0
  42. package/studio/build-local/static/js/browse-entitymanager.0db076c3.chunk.js +1 -0
  43. package/studio/build-local/static/js/browse-jsonviewer.b690b1bb.chunk.js +1 -0
  44. package/studio/build-local/static/js/custom-functions.04b93135.chunk.js +1 -0
  45. package/studio/build-local/static/js/instance-charts.217c477d.chunk.js +1 -0
  46. package/studio/build-local/static/js/instance-cluster.0ba07710.chunk.js +1 -0
  47. package/studio/build-local/static/js/instance-config.2274de0a.chunk.js +1 -0
  48. package/studio/build-local/static/js/instance-query.fdc5f922.chunk.js +1 -0
  49. package/studio/build-local/static/js/instance-roles.38ef8e77.chunk.js +1 -0
  50. package/studio/build-local/static/js/instance-status.d09551b0.chunk.js +1 -0
  51. package/studio/build-local/static/js/instance-users-datatable.9b5617bc.chunk.js +1 -0
  52. package/studio/build-local/static/js/instance-users-edit.6ea9cc6f.chunk.js +1 -0
  53. package/studio/build-local/static/js/instance-users.876f6070.chunk.js +1 -0
  54. package/studio/build-local/static/js/instance.ad30f892.chunk.js +1 -0
  55. package/studio/build-local/static/js/instances.f4fec0cb.chunk.js +1 -0
  56. package/studio/build-local/static/js/main.e70e768f.js +2 -0
  57. package/studio/build-local/static/js/main.e70e768f.js.LICENSE.txt +39 -0
  58. package/studio/build-local/static/js/offline-app.31ad36fc.chunk.js +1 -0
  59. package/studio/build-local/static/js/online-app.91033fd0.chunk.js +1 -0
  60. package/studio/build-local/static/js/organization-billing.21b2d3c9.chunk.js +1 -0
  61. package/studio/build-local/static/js/organization-users.6f50ca02.chunk.js +1 -0
  62. package/studio/build-local/static/js/organization.89b902c4.chunk.js +1 -0
  63. package/studio/build-local/static/js/organizations.4933fdbc.chunk.js +1 -0
  64. package/studio/build-local/static/js/profile.c05c7042.chunk.js +1 -0
  65. package/studio/build-local/static/js/resetPassword.3478535b.chunk.js +1 -0
  66. package/studio/build-local/static/js/roles-jsonviewer.bf1011d5.chunk.js +1 -0
  67. package/studio/build-local/static/js/signIn.996cf7ee.chunk.js +1 -0
  68. package/studio/build-local/static/js/signUp.c8fce52d.chunk.js +1 -0
  69. package/studio/build-local/static/js/structure-reloader.f65842a1.chunk.js +1 -0
  70. package/studio/build-local/static/js/topnav.0fa4de77.chunk.js +1 -0
  71. package/studio/build-local/static/js/updatePassword.bc881b36.chunk.js +1 -0
  72. package/utility/install/README.md +23 -0
  73. package/utility/scripts/restartHdb.js +78 -76
@@ -1,131 +1,133 @@
1
- "use strict";var QW=Object.create;var yd=Object.defineProperty;var zW=Object.getOwnPropertyDescriptor;var JW=Object.getOwnPropertyNames;var XW=Object.getPrototypeOf,ZW=Object.prototype.hasOwnProperty;var a=(e,t)=>yd(e,"name",{value:t,configurable:!0});var Ce=(e,t)=>()=>(e&&(t=e(e=0)),t);var b=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),tt=(e,t)=>{for(var r in t)yd(e,r,{get:t[r],enumerable:!0})},Hw=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of JW(t))!ZW.call(e,s)&&s!==r&&yd(e,s,{get:()=>t[s],enumerable:!(n=zW(t,s))||n.enumerable});return e};var B=(e,t,r)=>(r=e!=null?QW(XW(e)):{},Hw(t||!e||!e.__esModule?yd(r,"default",{value:e,enumerable:!0}):r,e)),ie=e=>Hw(yd({},"__esModule",{value:!0}),e);var kw=b((Uge,Fw)=>{var ej=require("fast-glob"),{statSync:ng,existsSync:sg,readFileSync:tj,writeFileSync:rj}=require("fs"),{spawnSync:nj,spawn:sj,execFileSync:Mge}=require("child_process"),{isMainThread:ij}=require("worker_threads"),{join:Mo,relative:xw}=require("path"),{PACKAGE_ROOT:Us}=M(),{tmpdir:oj,platform:aj}=require("os");require("source-map-support").install();var cj=["resources","server","dataLayer","components"],Nd="ts-build",ig,lj=__filename.endsWith("tsBuild.js");if(lj){if(ij){let r;try{ng(Mo(Us,Nd)),r=!0}catch{}if(r)for(let n of ej.sync(cj.map(s=>s+"/**/*.ts"),{cwd:Us})){let s=0,i=0;try{s=ng(Mo(Us,n)).mtimeMs-5e3,i=ng(Mo(Us,Nd,n.replace(/.ts$/,".js"))).mtimeMs}catch{}if(s>i){console.warn(`TypeScript ${n} is not compiled`+(i?` (TS source file was modified at ${new Date(s)} and compiled file at ${new Date(i)})`:"")+", consider enabling auto-compilation of TypeScript in your IDE), compiling now."),ig=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),ig=!0;if(ig){let n=Mo(Us,"node_modules/.bin/tsc");aj()==="win32"&&(n+=".cmd");let s=nj(n,{cwd:Us});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=Mo(oj(),"harperdb-tsc.pid"),o;if(sg(i))try{process.kill(+tj(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=sj(n,["--watch"],{cwd:Us,detached:!0,stdio:"ignore"});rj(i,c.pid.toString()),c.unref()}}}}let e=Fw.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(Us)&&!n[0].includes("node_modules")){let i=xw(Us,n[0]),o;i.startsWith(Nd)?o=Mo(Us,xw(Nd,i)):o=Mo(Us,Nd,i);let c=Mo(o,r),l=c+".js";if(sg(l))return l;if(c.includes(".")&&sg(c))return c}return t(r,n,s)}}});var M=b((Hge,eC)=>{"use strict";var es=require("path"),uj=require("fs"),{relative:vge,join:Bge}=es,{existsSync:dj}=uj;function _j(){let e=__dirname;for(;!dj(es.join(e,"package.json"));){let t=es.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(_j,"getHDBPackageRoot");var Uo=_j(),Gw="js",JE=Gw,fj="harperdb-config.yaml",Ej="defaultConfig.yaml",hj="hdb",qw=`harperdb.${JE}`,$w=`customFunctionsServer.${JE}`,mj=`restartHdb.${JE}`,ag="HarperDB",zE="Custom Functions",XE="Clustering Hub",ZE="Clustering Leaf",pj="Clustering Ingest Service",Sj="Clustering Reply Service",Tj="foreground.pid",gj="hdb.pid",Rj="data",Aj={HDB:ag,CLUSTERING_HUB:XE,CLUSTERING_LEAF:ZE,CLUSTERING_INGEST_SERVICE:pj,CLUSTERING_REPLY_SERVICE:Sj,CUSTOM_FUNCTIONS:zE,RESTART_HDB:"Restart HDB",INSTALL:"Install",RUN:"Run",STOP:"Stop",UPGRADE:"Upgrade",REGISTER:"Register",JOB:"Job",CLUSTERING_UPGRADE_4_0_0:"Upgrade-4-0-0"},Oj={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},bj={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},yj={harperdb:ag,"clustering hub":XE,"clustering leaf":ZE,"custom functions":zE,custom_functions:zE,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},Nj={CLUSTERING_HUB_PROC_DESCRIPTOR:XE,CLUSTERING_LEAF_PROC_DESCRIPTOR:ZE},og={HDB:es.join(Uo,"server/harperdb"),CUSTOM_FUNCTIONS:es.join(Uo,"server/customFunctions"),CLUSTERING_HUB:es.join(Uo,"server/nats"),CLUSTERING_LEAF:es.join(Uo,"server/nats")},Ij={HDB:es.join(og.HDB,qw),CUSTOM_FUNCTIONS:es.join(og.CUSTOM_FUNCTIONS,$w)},wj={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:es.join(Uo,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:es.join(Uo,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:es.join(Uo,"launchServiceScripts/launchUpdateNodes4-0-0.js")},Cj={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},Vw="support@harperdb.io",Dj="customer-success@harperdb.io",Yw=1,Pj=4141,Kw="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",Lj="https://www.harperdb.io/product",Mj=`For support, please submit a request at ${Kw} or contact ${Vw}`,Ww=`For license support, please contact ${Dj}`,Uj="None of the specified records were found.",vj="hash attribute not found",Bj=`Your current license only supports ${Yw} role. ${Ww}`,Hj="Your current license only supports 3 connections to a node.",xj="127.0.0.1",Fj=1,kj=/^\.$/,Gj=/^\.\.$/,qj="U+002E",$j=/\//g,Vj="U+002F",Yj=/U\+002F/g,Kj=/^U\+002E$/,Wj=/^U\+002EU\+002E$/,jj="d",Qj=999999,zj="*",Jj="--max-old-space-size=",Xj="system",Zj="__hdb_hash",eQ=".harperdb",tQ=".hdb",rQ="keys",nQ="hdb_boot_properties.file",sQ=".updateConfig.json",iQ="SIGTSTP",oQ=24,aQ=6e4,cQ=448,lQ="blob",uQ="trash",dQ="database",_Q="schema",fQ="transactions",EQ=".count",hQ="id",mQ="PROCESS_NAME",jw={SETTINGS_PATH_KEY:"settings_path"},Qw=require("lodash"),pQ={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"},SQ={HDB_PATH_KEY:"HDB_INTERNAL_PATH",HDB_AUTH_HEADER:"hdb_auth_header",HDB_USER_DATA_KEY:"hdb_user",CHUNK_SIZE:1e3,MAX_CHARACTER_SIZE:250},TQ={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},gQ={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"},RQ={JOB_TABLE_HASH_ATTRIBUTE:"id",NODE_TABLE_HASH_ATTRIBUTE:"name",ATTRIBUTE_TABLE_HASH_ATTRIBUTE:"id",LICENSE_TABLE_HASH_ATTRIBUTE:"license_key",ROLE_TABLE_HASH_ATTRIBUTE:"id",SCHEMA_TABLE_HASH_ATTRIBUTE:"name",TABLE_TABLE_HASH_ATTRIBUTE:"id",USER_TABLE_HASH_ATTRIBUTE:"username",INFO_TABLE_ATTRIBUTE:"info_id"},yn="hdb_internal:",AQ={CREATE_SCHEMA:yn+"create_schema",CREATE_TABLE:yn+"create_table",CREATE_ATTRIBUTE:yn+"create_attribute",ADD_USER:yn+"add_user",ALTER_USER:yn+"alter_user",DROP_USER:yn+"drop_user",HDB_NODES:yn+"hdb_nodes",HDB_USERS:yn+"hdb_users",HDB_WORKERS:yn+"hdb_workers",CATCHUP:yn+"catchup",SCHEMA_CATCHUP:yn+"schema_catchup",WORKER_ROOM:yn+"cluster_workers"},OQ={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"},bQ="060493.ks",yQ=".license",NQ={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},oe={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts"},IQ={CSV:".csv",JSON:".json"},wQ={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},CQ={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Id={};Id[oe.INSERT]=oe.INSERT;Id[oe.UPDATE]=oe.UPDATE;Id[oe.UPSERT]=oe.UPSERT;Id[oe.DELETE]=oe.DELETE;var rt=Object.create(null);rt[oe.DESCRIBE_ALL]=oe.DESCRIBE_ALL;rt[oe.DESCRIBE_TABLE]=oe.DESCRIBE_TABLE;rt[oe.DESCRIBE_SCHEMA]=oe.DESCRIBE_SCHEMA;rt[oe.READ_LOG]=oe.READ_LOG;rt[oe.ADD_NODE]=oe.ADD_NODE;rt[oe.LIST_USERS]=oe.LIST_USERS;rt[oe.LIST_ROLES]=oe.LIST_ROLES;rt[oe.USER_INFO]=oe.USER_INFO;rt[oe.SQL]=oe.SQL;rt[oe.GET_JOB]=oe.GET_JOB;rt[oe.SEARCH_JOBS_BY_START_DATE]=oe.SEARCH_JOBS_BY_START_DATE;rt[oe.DELETE_FILES_BEFORE]=oe.DELETE_FILES_BEFORE;rt[oe.EXPORT_LOCAL]=oe.EXPORT_LOCAL;rt[oe.EXPORT_TO_S3]=oe.EXPORT_TO_S3;rt[oe.CLUSTER_STATUS]=oe.CLUSTER_STATUS;rt[oe.REMOVE_NODE]=oe.REMOVE_NODE;rt[oe.RESTART]=oe.RESTART;rt[oe.CUSTOM_FUNCTIONS_STATUS]=oe.CUSTOM_FUNCTIONS_STATUS;rt[oe.GET_CUSTOM_FUNCTIONS]=oe.GET_CUSTOM_FUNCTIONS;rt[oe.GET_CUSTOM_FUNCTION]=oe.GET_CUSTOM_FUNCTION;rt[oe.SET_CUSTOM_FUNCTION]=oe.SET_CUSTOM_FUNCTION;rt[oe.DROP_CUSTOM_FUNCTION]=oe.DROP_CUSTOM_FUNCTION;rt[oe.ADD_CUSTOM_FUNCTION_PROJECT]=oe.ADD_CUSTOM_FUNCTION_PROJECT;rt[oe.DROP_CUSTOM_FUNCTION_PROJECT]=oe.DROP_CUSTOM_FUNCTION_PROJECT;rt[oe.PACKAGE_CUSTOM_FUNCTION_PROJECT]=oe.PACKAGE_CUSTOM_FUNCTION_PROJECT;rt[oe.DEPLOY_CUSTOM_FUNCTION_PROJECT]=oe.DEPLOY_CUSTOM_FUNCTION_PROJECT;rt[oe.ADD_SSH_KEY]=oe.ADD_SSH_KEY;rt[oe.UPDATE_SSH_KEY]=oe.UPDATE_SSH_KEY;rt[oe.DELETE_SSH_KEY]=oe.DELETE_SSH_KEY;var DQ={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"},PQ={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},zw={HDB_ROOT_KEY:"HDB_ROOT",SERVER_PORT_KEY:"SERVER_PORT",CERT_KEY:"CERTIFICATE",PRIVATE_KEY_KEY:"PRIVATE_KEY",HTTP_SECURE_ENABLED_KEY:"HTTPS_ON",CORS_ENABLED_KEY:"CORS_ON",CORS_WHITELIST_KEY:"CORS_WHITELIST",LOG_LEVEL_KEY:"LOG_LEVEL",LOGGER_KEY:"LOGGER",LOG_PATH_KEY:"LOG_PATH",LOG_ROTATE:"LOG_ROTATE",LOG_ROTATE_MAX_SIZE:"LOG_ROTATE_MAX_SIZE",LOG_ROTATE_RETAIN:"LOG_ROTATE_RETAIN",LOG_ROTATE_COMPRESS:"LOG_ROTATE_COMPRESS",LOG_ROTATE_DATE_FORMAT:"LOG_ROTATE_DATE_FORMAT",LOG_ROTATE_ROTATE_MODULE:"LOG_ROTATE_ROTATE_MODULE",LOG_ROTATE_WORKER_INTERVAL:"LOG_ROTATE_WORKER_INTERVAL",LOG_ROTATE_ROTATE_INTERVAL:"LOG_ROTATE_ROTATE_INTERVAL",LOG_ROTATE_TIMEZONE:"LOG_ROTATE_TIMEZONE",LOG_DAILY_ROTATE_KEY:"LOG_DAILY_ROTATE",LOG_MAX_DAILY_FILES_KEY:"LOG_MAX_DAILY_FILES",PROPS_ENV_KEY:"NODE_ENV",SETTINGS_PATH_KEY:"settings_path",CLUSTERING_PORT_KEY:"CLUSTERING_PORT",CLUSTERING_NODE_NAME_KEY:"NODE_NAME",CLUSTERING_ENABLED_KEY:"CLUSTERING",ALLOW_SELF_SIGNED_SSL_CERTS:"ALLOW_SELF_SIGNED_SSL_CERTS",MAX_HDB_PROCESSES:"MAX_HDB_PROCESSES",INSTALL_USER:"install_user",CLUSTERING_USER_KEY:"CLUSTERING_USER",MAX_CLUSTERING_PROCESSES:"MAX_CLUSTERING_PROCESSES",SERVER_TIMEOUT_KEY:"SERVER_TIMEOUT_MS",SERVER_KEEP_ALIVE_TIMEOUT_KEY:"SERVER_KEEP_ALIVE_TIMEOUT",SERVER_HEADERS_TIMEOUT_KEY:"SERVER_HEADERS_TIMEOUT",DISABLE_TRANSACTION_LOG_KEY:"DISABLE_TRANSACTION_LOG",OPERATION_TOKEN_TIMEOUT_KEY:"OPERATION_TOKEN_TIMEOUT",REFRESH_TOKEN_TIMEOUT_KEY:"REFRESH_TOKEN_TIMEOUT",CUSTOM_FUNCTIONS_ENABLED_KEY:"CUSTOM_FUNCTIONS",CUSTOM_FUNCTIONS_PORT_KEY:"CUSTOM_FUNCTIONS_PORT",CUSTOM_FUNCTIONS_DIRECTORY_KEY:"CUSTOM_FUNCTIONS_DIRECTORY",MAX_CUSTOM_FUNCTION_PROCESSES:"MAX_CUSTOM_FUNCTION_PROCESSES",LOG_TO_FILE:"LOG_TO_FILE",LOG_TO_STDSTREAMS:"LOG_TO_STDSTREAMS",RUN_IN_FOREGROUND:"RUN_IN_FOREGROUND",LOCAL_STUDIO_ON:"LOCAL_STUDIO_ON",STORAGE_WRITE_ASYNC:"STORAGE_WRITE_ASYNC"},LQ=Qw.invert(zw),MQ={CUSTOMFUNCTIONS_ENABLED:"customFunctions_enabled",CUSTOMFUNCTIONS_NETWORK_PORT:"customFunctions_network_port",CUSTOMFUNCTIONS_TLS_CERTIFICATE:"customFunctions_tls_certificate",CUSTOMFUNCTIONS_NETWORK_CORS:"customFunctions_network_cors",CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST:"customFunctions_network_corsAccessList",CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT:"customFunctions_network_headersTimeout",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT:"customFunctions_network_keepAliveTimeout",CUSTOMFUNCTIONS_TLS_PRIVATEKEY:"customFunctions_tls_privateKey",CUSTOMFUNCTIONS_TLS_CERT_AUTH:"customFunctions_tls_certificateAuthority",CUSTOMFUNCTIONS_NETWORK_TIMEOUT:"customFunctions_network_timeout",CUSTOMFUNCTIONS_NODEENV:"customFunctions_nodeEnv",CUSTOMFUNCTIONS_ROOT:"customFunctions_root"},D={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},Jw={settings_path:jw.SETTINGS_PATH_KEY,hdb_root_key:D.ROOTPATH,hdb_root:D.ROOTPATH,rootpath:D.ROOTPATH,server_port_key:D.OPERATIONSAPI_NETWORK_PORT,server_port:D.OPERATIONSAPI_NETWORK_PORT,cert_key:D.TLS_CERTIFICATE,certificate:D.TLS_CERTIFICATE,private_key_key:D.TLS_PRIVATEKEY,private_key:D.TLS_PRIVATEKEY,http_secure_enabled_key:D.OPERATIONSAPI_NETWORK_HTTPS,https_on:D.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:D.OPERATIONSAPI_NETWORK_CORS,cors_on:D.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:D.LOGGING_LEVEL,log_level:D.LOGGING_LEVEL,log_path_key:D.LOGGING_ROOT,log_path:D.LOGGING_ROOT,clustering_node_name_key:D.CLUSTERING_NODENAME,node_name:D.CLUSTERING_NODENAME,clustering_enabled_key:D.CLUSTERING_ENABLED,clustering:D.CLUSTERING_ENABLED,max_http_threads:D.THREADS_COUNT,max_hdb_processes:D.THREADS_COUNT,server_timeout_key:D.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:D.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:D.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:D.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:D.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:D.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:D.LOGGING_AUDITLOG,disable_transaction_log:D.LOGGING_AUDITLOG,operation_token_timeout_key:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:D.HTTP_PORT,custom_functions_port:D.HTTP_PORT,custom_functions_directory_key:D.COMPONENTSROOT,custom_functions_directory:D.COMPONENTSROOT,max_custom_function_processes:D.THREADS_COUNT,logging_console:D.LOGGING_CONSOLE,log_to_file:D.LOGGING_FILE,log_to_stdstreams:D.LOGGING_STDSTREAMS,local_studio_on:D.LOCALSTUDIO_ENABLED,clustering_port:D.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:D.CLUSTERING_USER,clustering_enabled:D.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:D.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:D.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:D.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:D.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:D.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:D.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:D.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:D.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:D.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxconsumemsgs:D.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:D.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,clustering_leafserver_streams_maxmsgs:D.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:D.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:D.CLUSTERING_NODENAME,clustering_tls_certificate:D.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:D.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:D.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:D.CLUSTERING_TLS_INSECURE,clustering_tls_verify:D.CLUSTERING_TLS_VERIFY,clustering_loglevel:D.CLUSTERING_LOGLEVEL,clustering_republishmessages:D.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:D.CLUSTERING_DATABASELEVEL,customfunctions_network_port:D.HTTP_PORT,customfunctions_tls_certificate:D.TLS_CERTIFICATE,customfunctions_network_cors:D.HTTP_CORS,customfunctions_network_corsaccesslist:D.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:D.HTTP_HEADERSTIMEOUT,customfunctions_network_https:D.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:D.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:D.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:D.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:D.HTTP_TIMEOUT,customfunctions_tls:D.TLS,http_threads:D.THREADS_COUNT,threads:D.THREADS_COUNT,threads_count:D.THREADS_COUNT,threads_debug:D.THREADS_DEBUG,threads_debug_startingport:D.THREADS_DEBUG_STARTINGPORT,threads_debug_port:D.THREADS_DEBUG_PORT,threads_debug_host:D.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:D.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:D.THREADS_MAXHEAPMEMORY,http_session_affinity:D.HTTP_SESSIONAFFINITY,http_compressionthreshold:D.HTTP_COMPRESSIONTHRESHOLD,http_cors:D.HTTP_CORS,http_corsaccesslist:D.HTTP_CORSACCESSLIST,http_headerstimeout:D.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:D.HTTP_KEEPALIVETIMEOUT,http_timeout:D.HTTP_TIMEOUT,http_port:D.HTTP_PORT,http_secureport:D.HTTP_SECUREPORT,http_mtls:D.HTTP_MTLS,http_mtls_user:D.HTTP_MTLS_USER,http_mtls_required:D.HTTP_MTLS_REQUIRED,http_maxheadersize:D.HTTP_MAXHEADERSIZE,http_threadrange:D.HTTP_THREADRANGE,customfunctions_processes:D.THREADS_COUNT,customfunctions_root:D.COMPONENTSROOT,localstudio_enabled:D.LOCALSTUDIO_ENABLED,logging_file:D.LOGGING_FILE,logging_level:D.LOGGING_LEVEL,logging_root:D.LOGGING_ROOT,logging_rotation_enabled:D.LOGGING_ROTATION_ENABLED,logging_rotation_compress:D.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:D.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:D.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:D.LOGGING_ROTATION_PATH,logging_stdstreams:D.LOGGING_STDSTREAMS,logging_auditlog:D.LOGGING_AUDITLOG,logging_auditretention:D.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:D.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:D.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:D.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:D.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:D.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:D.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:D.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:D.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:D.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:D.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls:D.OPERATIONSAPI_TLS,operationsapi_tls_certificate:D.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:D.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:D.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:D.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:D.ROOTPATH,operationsapi_sysinfo_network:D.OPERATIONSAPI_SYSINFO_NETWORK,operationsapi_sysinfo_disk:D.OPERATIONSAPI_SYSINFO_DISK,databases:D.DATABASES,storage_path:D.STORAGE_PATH,storage_maxtransactionqueuetime:D.STORAGE_MAXTRANSACTIONQUEUETIME,ignorescripts:D.IGNORE_SCRIPTS,mqtt_network_port:D.MQTT_NETWORK_PORT,mqtt_websocket:D.MQTT_WEBSOCKET,mqtt_network_secureport:D.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:D.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:D.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:D.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:D.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:D.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:D.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:D.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:D.AUTHENTICATION_CACHETTL,authentication_enablesessions:D.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:D.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:D.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:D.COMPONENTSROOT,replication:D.REPLICATION,replication_port:D.REPLICATION_PORT,replication_secureport:D.REPLICATION_SECUREPORT,replication_hostname:D.REPLICATION_HOSTNAME,replication_url:D.REPLICATION_URL,replication_routes:D.REPLICATION_ROUTES,tls:D.TLS,tls_certificate:D.TLS_CERTIFICATE,tls_privatekey:D.TLS_PRIVATEKEY,tls_certificateauthority:D.TLS_CERTIFICATEAUTHORITY,tls_ciphers:D.TLS_CIPHERS};for(let e in D){let t=D[e];Jw[t.toLowerCase()]=t}var UQ={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},vQ={csv_file_load:"csv_file_load",csv_data_load:oe.CSV_DATA_LOAD,csv_url_load:oe.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},BQ={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"},HQ={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},xQ={VERSION_DEFAULT:"2.2.0"},FQ={DEVELOPMENT:8192,DEFAULT:512},kQ={IDENTIFY:"identify",AUTHENTICATE:"authenticate",AUTHENTICATE_OK:"authenticated",AUTHENTICATE_FAIL:"authenticate_fail",CONNECTION:"connection",CONNECT:"connect",CATCHUP_REQUEST:"catchup_request",CATCHUP_RESPONSE:"catchup",CONFIRM_MSG:"confirm_msg",ERROR:"error",DISCONNECT:"disconnect",SCHEMA_UPDATE_REQ:"schema_update_request",SCHEMA_UPDATE_RES:"schema_update_response",RECONNECT_ATTEMPT:"reconnect_attempt",CONNECT_ERROR:"connect_error",MESSAGE:"msg",VERSION_MISMATCH:"version_mismatch",DIRECTION_CHANGE:"direction_change"},GQ={1e3:"SUCCESSFUL_SHUTDOWN",1001:"CLOSE_GOING_AWAY",1002:"CLOSE_PROTOCOL_ERROR",1003:"CLOSE_UNSUPPORTED",1005:"CLOSE_NO_STATUS",1006:"CLOSE_ABNORMAL",1007:"UNSUPPORTED_PAYLOAD",1008:"POLICY_VIOLATION",1009:"CLOSE_TOO_LARGE",1010:"MANDATORY_EXTENSION",1011:"SERVER_ERROR",1012:"SERVICE_RESTART",1013:"SERVER_BUSY",1014:"BAD_GATEWAY",1015:"HANDSHAKE_FAIL",4141:"LICENSE_LIMIT_REACHED"},qQ={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},Xw={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},$Q=Symbol("metadata"),VQ="__clustering__",YQ=Object.values(Xw),KQ=15984864e5,Zw={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},WQ=Qw.invert(Zw),jQ={GET_CLUSTER_STATUS:"GET_CLUSTER_STATUS",CLUSTER_STATUS_RESPONSE:"CLUSTER_STATUS_RESPONSE",ERROR_RESPONSE:"ERROR",ADD_USER:"ADD_USER",ALTER_USER:"ALTER_USER",DROP_USER:"DROP_USER",HDB_OPERATION:"HDB_OPERATION",ADD_NODE:"ADD_NODE",UPDATE_NODE:"UPDATE_NODE",REMOVE_NODE:"REMOVE_NODE",HDB_USERS_MSG:"HDB_USERS_MSG",HDB_WORKERS:"HDB_WORKERS",HDB_TRANSACTION:"HDB_TRANSACTION"},QQ=111,zQ=`\r
2
- `,JQ={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},XQ=["*","%"],ZQ="unauthorized_access",ez="func_val",tz={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},rz={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},nz={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"},sz={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},iz={HTTP:"http"},oz={STOPPED:"stopped",ONLINE:"online"},az="3.x.x",cz={SUCCESS:"success",FAILURE:"failure"},lz={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"};eC.exports={LOCAL_HARPERDB_OPERATIONS:rt,HDB_SUPPORT_ADDRESS:Vw,HDB_SUPPORT_URL:Kw,HDB_PRICING_URL:Lj,SUPPORT_HELP_MSG:Mj,LICENSE_HELP_MSG:Ww,HDB_PROC_NAME:qw,HDB_PROC_DESCRIPTOR:ag,CLUSTERING_LEAF_PROC_DESCRIPTOR:ZE,CLUSTERING_HUB_PROC_DESCRIPTOR:XE,SYSTEM_SCHEMA_NAME:Xj,HASH_FOLDER_NAME:Zj,HDB_HOME_DIR_NAME:eQ,UPDATE_FILE_NAME:sQ,LICENSE_KEY_DIR_NAME:rQ,BOOT_PROPS_FILE_NAME:nQ,JOB_TYPE_ENUM:vQ,JOB_STATUS_ENUM:NQ,SYSTEM_TABLE_NAMES:gQ,SYSTEM_TABLE_HASH_ATTRIBUTES:RQ,OPERATIONS_ENUM:oe,VALID_S3_FILE_TYPES:IQ,S3_BUCKET_AUTH_KEYS:wQ,VALID_SQL_OPS_ENUM:CQ,GEO_CONVERSION_ENUM:PQ,HDB_SETTINGS_NAMES:zw,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:LQ,SERVICE_ACTIONS_ENUM:DQ,CLUSTER_MESSAGE_TYPE_ENUM:BQ,CLUSTER_CONNECTION_DIRECTION_ENUM:HQ,CLUSTER_EVENTS_DEFS_ENUM:kQ,PERIOD_REGEX:kj,DOUBLE_PERIOD_REGEX:Gj,UNICODE_PERIOD:qj,FORWARD_SLASH_REGEX:$j,UNICODE_FORWARD_SLASH:Vj,ESCAPED_FORWARD_SLASH_REGEX:Yj,ESCAPED_PERIOD_REGEX:Kj,ESCAPED_DOUBLE_PERIOD_REGEX:Wj,REG_KEY_FILE_NAME:bQ,RESTART_TIMEOUT_MS:aQ,HDB_FILE_PERMISSIONS:cQ,DATABASES_DIR_NAME:dQ,LEGACY_DATABASES_DIR_NAME:_Q,TRANSACTIONS_DIR_NAME:fQ,LIMIT_COUNT_NAME:EQ,ID_ATTRIBUTE_STRING:hQ,INSERT_MODULE_ENUM:SQ,UPGRADE_JSON_FIELD_NAMES_ENUM:TQ,RESTART_CODE:iQ,RESTART_CODE_NUM:oQ,CLUSTER_OPERATIONS:Id,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:OQ,HDB_INTERNAL_SC_CHANNEL_PREFIX:yn,INTERNAL_SC_CHANNELS:AQ,CLUSTERING_MESSAGE_TYPES:jQ,HDB_FILE_SUFFIX:tQ,BLOB_FOLDER_NAME:lQ,HDB_TRASH_DIR:uQ,ORIGINATOR_SET_VALUE:QQ,LICENSE_VALUES:xQ,RAM_ALLOCATION_ENUM:FQ,TIME_STAMP_NAMES_ENUM:Xw,TIME_STAMP_NAMES:YQ,PERMS_UPDATE_RELEASE_TIMESTAMP:KQ,SEARCH_NOT_FOUND_MESSAGE:Uj,SEARCH_ATTRIBUTE_NOT_FOUND:vj,LICENSE_ROLE_DENIED_RESPONSE:Bj,LICENSE_MAX_CONNS_REACHED:Hj,BASIC_LICENSE_MAX_NON_CU_ROLES:Yw,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:Pj,VALUE_SEARCH_COMPARATORS:Zw,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:WQ,LICENSE_FILE_NAME:yQ,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:GQ,NEW_LINE:zQ,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:Fj,MOMENT_DAYS_TAG:jj,API_TURNOVER_SEC:Qj,LOOPBACK:xj,CODE_EXTENSION:JE,WILDCARD_SEARCH_VALUE:zj,NODE_ERROR_CODES:qQ,JAVASCRIPT_EXTENSION:Gw,PERMS_CRUD_ENUM:JQ,UNAUTHORIZED_PERMISSION_NAME:ZQ,SEARCH_WILDCARDS:XQ,FUNC_VAL:ez,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:tz,JWT_ENUM:rz,CLUSTERING_FLAG:VQ,ITC_EVENT_TYPES:nz,CUSTOM_FUNCTION_PROC_NAME:$w,CUSTOM_FUNCTION_PROC_DESCRIPTOR:zE,SERVICES:sz,THREAD_TYPES:iz,MEM_SETTING_KEY:Jj,HDB_RESTART_SCRIPT:mj,PROCESS_DESCRIPTORS:Aj,SERVICE_SERVERS:Ij,SERVICE_SERVERS_CWD:og,PROCESS_DESCRIPTORS_VALIDATE:yj,LAUNCH_SERVICE_SCRIPTS:wj,LOG_LEVELS:bj,PROCESS_NAME_ENV_PROP:mQ,LOG_NAMES:Oj,PM2_PROCESS_STATUSES:oz,CONFIG_PARAM_MAP:Jw,CONFIG_PARAMS:D,HDB_CONFIG_FILE:fj,HDB_DEFAULT_CONFIG_FILE:Ej,ROLE_TYPES_ENUM:Cj,BOOT_PROP_PARAMS:jw,INSTALL_PROMPTS:pQ,HDB_ROOT_DIR_NAME:hj,CLUSTERING_PROCESSES:Nj,FOREGROUND_PID_FILE:Tj,PACKAGE_ROOT:Uo,PRE_4_0_0_VERSION:az,DATABASES_PARAM_CONFIG:UQ,METADATA_PROPERTY:$Q,AUTH_AUDIT_STATUS:cz,AUTH_AUDIT_TYPES:lz,HDB_PID_FILE:gj,DEFAULT_DATABASE_NAME:Rj,LEGACY_CONFIG_PARAMS:MQ};kw()});var $a=b((Fge,nC)=>{"use strict";var tC=require("minimist");nC.exports=uz;function uz(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=rC(process.env),n=rC(tC(process.argv))):(r=process.env,n=tC(process.argv));let s={};for(let i=0,o=e.length;i<o;i++){let c=e[i];n[c]!==void 0?s[c]=n[c].toString().trim():r[c]!==void 0&&(s[c]=r[c].toString().trim())}return s}a(uz,"assignCMDENVVariables");function rC(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(rC,"objKeysToLowerCase")});var Yi=b(ai=>{"use strict";global.Resource=ai.Resource=void 0;global.tables=ai.tables={};global.databases=ai.databases={};global.getUser=ai.getUser=void 0;global.server=ai.server={};global.contentTypes=ai.contentTypes=null;global.threads=ai.threads=[];global.logger={};ai._assignPackageExport=(e,t)=>{global[e]=ai[e]=t}});var V=b((SC,TC)=>{"use strict";var Ki=require("fs-extra"),{workerData:dz,threadId:_z,isMainThread:fz}=require("worker_threads"),li=require("path"),aC=require("yaml"),cC=require("properties-reader"),Wt=M(),sC=$a(),Ez=require("os"),{PACKAGE_ROOT:dg}=M(),{_assignPackageExport:hz}=Yi(),iC=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),dr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},lC={STDOUT:"stdOut",STDERR:"stdErr"},mz=li.join(dg,"logs"),pz=li.join(dg,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),Sz=1e4,cg,ci,ts,br,eh,wd,th,vo,Cd;Cd===void 0&&uC();Object.assign(SC,{notify:hC,fatal:mC,error:rh,warn:pC,info:_C,debug:EC,trace:fC,setLogLevel:Nz,log_level:br,loggerWithTag:Rz,suppressLogging:Az,initLogSettings:uC,logCustomLevel:bz,closeLogFile:_g,logsAtLevel:Tz,getLogFilePath:()=>th,OUTPUTS:lC,AuthAuditLog:Cz});hz("logger",TC.exports);var lg;function Tz(e){return dr[br]<=dr[e]}a(Tz,"logsAtLevel");function uC(e=!1){try{if(Cd===void 0||e){_g();let t=yz(),r=sC(["ROOTPATH"]);try{Cd=cC(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!Ki.pathExistsSync(li.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:br,config_log_path:wd,to_file:ci,to_stream:ts}=Iz(r.ROOTPATH?li.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):Cd.get("settings_path")),eh=Wt.LOG_NAMES.HDB,th=li.join(wd,eh),fz)try{require("segfault-handler").registerHandler(li.join(wd,"crash.log"))}catch{}}}catch(t){if(Cd=void 0,t.code===Wt.NODE_ERROR_CODES.ENOENT||t.code===Wt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=sC(Object.keys(Wt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Wt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Wt.CONFIG_PARAMS.LOGGING_LEVEL){br=l;continue}if(c===Wt.CONFIG_PARAMS.LOGGING_STDSTREAMS){ts=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(ci=c),c===Wt.CONFIG_PARAMS.LOGGING_CONSOLE&&(cg=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=wz();ci=ci===void 0?s:ci,ci=oC(ci),ts=ts===void 0?i:ts,ts=oC(ts),br=br===void 0?n:br,wd=mz,eh=Wt.LOG_NAMES.INSTALL,th=li.join(wd,eh);return}throw rh("Error initializing log settings"),rh(t),t}process.env.DEV_MODE&&(ts=!0),gz()}a(uC,"initLogSettings");var Bo=!0;function gz(){ci&&(process.stdout.write=function(e){return typeof e=="string"&&Bo&&cg!==!1&&(ug(),e=e.toString(),e[e.length-1]===`
3
- `&&(e=e.slice(0,-1)),Ki.appendFileSync(vo,vs("stdout",[e]))),iC.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&Bo&&cg!==!1&&(ug(),e[e.length-1]===`
4
- `&&(e=e.slice(0,-1)),Ki.appendFileSync(vo,vs("stderr",[e]))),iC.apply(process.stderr,arguments)})}a(gz,"stdioLogging");function Rz(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(hC,"notify"),fatal:n(mC,"fatal"),error:n(rh,"error"),warn:n(pC,"warn"),info:n(_C,"info"),debug:n(EC,"debug"),trace:n(fC,"trace")};function n(s,i){return!t||dr[br]<=dr[i]?function(...o){return s(r,...o)}:null}}a(Rz,"loggerWithTag");function Az(e){try{Bo=!1,e()}finally{Bo=!0}}a(Az,"suppressLogging");var Oz=dz?.name?.replace(/ /g,"-")||"main";function vs(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||Oz+"/"+_z);c<s;c++){let d=t[c];d instanceof Error&&d.stack?n+=d.stack:typeof d=="object"?n+=JSON.stringify(d):n+=d,c<i&&(n+=" ")}return`${r} [${o.join("] [")}]: ${n}
5
- `}a(vs,"createLogRecord");function Dd(e){if(ci){if(dC(e),ts){Bo=!1;try{process.stdout.write(e)}finally{Bo=!0}}}else ts&&process.stdout.write(e)}a(Dd,"logStdOut");function nh(e){if(ci){if(dC(e),ts){Bo=!1;try{process.stderr.write(e)}finally{Bo=!0}}}else ts&&process.stderr.write(e)}a(nh,"logStdErr");function dC(e){ug(),vo?Ki.appendFileSync(vo,e):lg||console.log(e)}a(dC,"logToFile");function _g(){try{Ki.closeSync(vo)}catch{}vo=null}a(_g,"closeLogFile");function ug(){if(!vo){try{vo=Ki.openSync(th,"a")}catch(e){lg||(lg=!0,console.error(e))}setTimeout(()=>{_g()},Sz).unref()}}a(ug,"openLogFile");function _C(...e){dr[br]<=dr.info&&Dd(vs("info",e))}a(_C,"info");function fC(...e){dr[br]<=dr.trace&&Dd(vs("trace",e))}a(fC,"trace");function rh(...e){dr[br]<=dr.error&&nh(vs("error",e))}a(rh,"error");function EC(...e){dr[br]<=dr.debug&&Dd(vs("debug",e))}a(EC,"debug");function hC(...e){dr[br]<=dr.notify&&Dd(vs("notify",e))}a(hC,"notify");function mC(...e){dr[br]<=dr.fatal&&nh(vs("fatal",e))}a(mC,"fatal");function pC(...e){dr[br]<=dr.warn&&nh(vs("warn",e))}a(pC,"warn");function bz(e,t,...r){t===lC.STDERR?nh(vs(e,r)):Dd(vs(e,r))}a(bz,"logCustomLevel");function yz(){let e;try{e=Ez.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=li.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return Ki.existsSync(t)||(t=li.join(dg,"utility/hdb_boot_properties.file")),t}a(yz,"getPropsFilePath");function Nz(e){br=e}a(Nz,"setLogLevel");function oC(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(oC,"autoCastBoolean");function Iz(e){try{if(e.includes("config/settings.js")){let o=cC(e);return{level:o.get(Wt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:li.dirname(o.get(Wt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=aC.parseDocument(Ki.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),n=t.getIn(["logging","root"]),s=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:n,to_file:s,to_stream:i}}catch(t){if(t.code===Wt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(Iz,"getLogConfig");function wz(){try{let e=aC.parseDocument(Ki.readFileSync(pz,"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(wz,"getDefaultConfig");function Cz(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(Cz,"AuthAuditLog")});var fg=b(($ge,gC)=>{"use strict";var Dz=require("util"),Pz=require("path"),Lz=require("child_process"),Mz=Dz.promisify(Lz.execFile),Uz=1e3*1e3*10;gC.exports={findPs:vz};async function vz(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await Mz("ps",["wwxo",`pid,${r}`],{maxBuffer:Uz});for(let s of n.trim().split(`
6
- `).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:Pz.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(vz,"findPs")});var Bt=b((Yge,AC)=>{"use strict";var Bz="__dbis__",Hz="__txns__",xz="__environment_name__",Fz="__dbi_defintion__",kz={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"},Gz=["__createdtime__","__updatedtime__"],qz="\uFFFF",RC={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},$z=Object.values(RC);AC.exports={AUDIT_STORE_NAME:Hz,INTERNAL_DBIS_NAME:Bz,DBI_DEFINITION_NAME:Fz,SEARCH_TYPES:kz,TIMESTAMP_NAMES:Gz,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:xz,TRANSACTIONS_DBI_NAMES_ENUM:RC,TRANSACTIONS_DBIS:$z,OVERFLOW_MARKER:qz}});var Nn=b((Kge,PC)=>{"use strict";var OC=M(),bC=Bt(),yC={CONTINUE:100,OK:200,CREATED:201,BAD_REQUEST:400,UNAUTHORIZED:401,FORBIDDEN:403,NOT_FOUND:404,METHOD_NOT_ALLOWED:405,REQUEST_TIMEOUT:408,CONFLICT:409,TOO_MANY_REQUESTS:429,INTERNAL_SERVER_ERROR:500,NOT_IMPLEMENTED:501,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504,HTTP_VERSION_NOT_SUPPORTED:505,INSUFFICIENT_STORAGE:507,NETWORK_AUTHENTICATION_REQUIRED:511},NC=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),IC={500:NC("There was an error processing your request."),400:"Invalid request"},Vz=IC[yC.INTERNAL_SERVER_ERROR],Yz={OP_NOT_SUPPORTED_FOR_FS:e=>`${e} is not available for this instance because it uses the File System data store.`,MISSING_VALUE:e=>`${e} is missing.`,INVALID_VALUE:e=>`${e} is invalid.`,NOT_FOUND:e=>`${e} not found.`},Kz={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},Wz={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:e=>`There was an error downloading '${e}'.`,INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,INVALID_FILE_EXT_ERR:e=>`Error selecting correct parser - valid file type not found in json - ${e}`,MAX_FILE_SIZE_ERR:(e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:e=>`There was an error downloading '${e}' from AWS.`,WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},jz={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 ${bC.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${bC.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"},Qz={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${OC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${OC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},wC={GENERIC_AUTH_FAIL:"Login failed",USER_INACTIVE:"Cannot complete request: User is inactive",INVALID_TOKEN:"invalid token",NO_ENCRYPTION_KEYS:"unable to generate JWT as there are no encryption keys. please contact your administrator",INVALID_CREDENTIALS:"invalid credentials",PASSWORD_REQUIRED:"password is required",USERNAME_REQUIRED:"username is required",REFRESH_TOKEN_REQUIRED:"refresh_token is required",INVALID_AUTH_OBJECT:"invalid auth_object",INVALID_BODY:"invalid body",TOKEN_EXPIRED:"token expired",REFRESH_TOKEN_SAVE_FAILED:"unable to store refresh_token"},zz={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:e=>`Operation '${e}' is restricted to 'super_user' roles`,OP_NOT_FOUND:e=>`Operation '${e}' not found`,SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:(e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,USER_HAS_NO_PERMS:e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},Jz={ATTR_PERM_MISSING:(e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:(e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:e=>`Invalid attribute '${e}' in 'attribute_permissions'`,INVALID_PERM_KEY:e=>`Invalid table permission key value '${e}'`,INVALID_ATTR_PERM_KEY:e=>`Invalid attribute permission key value '${e}'`,INVALID_ROLE_JSON_KEYS:e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,MISMATCHED_TABLE_ATTR_PERMS:e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:e=>`A role with name '${e}' already exists`,ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:e=>`Your role does not have permission to view database metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:e=>`Value for '${e}' permission must be a boolean`,STRUCTURE_USER_ROLE_TYPE_ERROR:e=>`Value for '${e}' permission must be a boolean or Array`,SU_CU_ROLE_NO_PERMS_ALLOWED:e=>`Roles with '${e}' set to true cannot have other permissions set.`,SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:e=>`Missing table ${e.toUpperCase()} permission`,TABLE_PERM_NOT_BOOLEAN:e=>`Table ${e.toUpperCase()} permission must be a boolean`},Xz={ATTR_NOT_FOUND:(e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,ATTR_EXISTS_ERR:(e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:e=>`Invalid table ${JSON.stringify(e)}`,SCHEMA_NOT_FOUND:e=>`database '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`database '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in '${e}'`,SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},Zz={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},e2={ALTER_USER_DUP_ROLES:e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,ALTER_USER_ROLE_NOT_FOUND:e=>`Update failed. Requested '${e}' role not found.`,DUP_ROLES_FOUND:e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,ROLE_NAME_NOT_FOUND:e=>`${e} role not found`,USER_ALREADY_EXISTS:e=>`User ${e} already exists`,USER_NOT_EXIST:e=>`User ${e} does not exist`},CC={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`},DC={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:e=>`ITC server received invalid event type: ${e}`},t2={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"},r2={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},n2={...wC,...Wz,...Yz,...zz,...Jz,...Xz,...Zz,...e2,...Qz,...CC,...DC,...t2,...r2,...Kz};PC.exports={CHECK_LOGS_WRAPPER:NC,HDB_ERROR_MSGS:n2,DEFAULT_ERROR_MSGS:IC,DEFAULT_ERROR_RESP:Vz,HTTP_STATUS_CODES:yC,LMDB_ERRORS_ENUM:jz,AUTHENTICATION_ERROR_MSGS:wC,VALIDATION_ERROR_MSGS:CC,ITC_ERRORS:DC}});var ce=b((jge,UC)=>{"use strict";var Sl=Nn(),s2=V(),i2=M(),sh=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,LC),this.statusCode=n||Sl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Sl.DEFAULT_ERROR_MSGS[n]?Sl.DEFAULT_ERROR_MSGS[n]:Sl.DEFAULT_ERROR_MSGS[Sl.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&&s2[s](i)}},Eg=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},hg=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function LC(e,t,r,n=i2.LOG_LEVELS.ERROR,s=null,i=!1){if(MC(e))return e;let o=new sh(e,t,r,n,s);return i&&delete o.stack,o}a(LC,"handleHDBError");function MC(e){return e.__proto__.constructor.name===sh.name}a(MC,"isHDBError");UC.exports={isHDBError:MC,handleHDBError:LC,ClientError:Eg,ServerError:hg,hdb_errors:Sl}});var Tt=b((zge,GC)=>{"use strict";var vd=M(),o2=ee(),rn=te(),Bd=require("path"),a2=require("minimist"),vC=require("fs-extra"),BC=require("lodash");rn.initSync();var{CONFIG_PARAMS:Ho,DATABASES_PARAM_CONFIG:Pd,SYSTEM_SCHEMA_NAME:ih}=vd,Ld,Md,Ud;function HC(){if(Ld!==void 0)return Ld;if(rn.getHdbBasePath()!==void 0)return Ld=rn.get(Ho.STORAGE_PATH)||Bd.join(rn.getHdbBasePath(),vd.DATABASES_DIR_NAME),Ld}a(HC,"getBaseSchemaPath");function xC(){if(Md!==void 0)return Md;if(rn.getHdbBasePath()!==void 0)return Md=kC(ih),Md}a(xC,"getSystemSchemaPath");function FC(){if(Ud!==void 0)return Ud;if(rn.getHdbBasePath()!==void 0)return Ud=rn.get(vd.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Bd.join(rn.getHdbBasePath(),vd.TRANSACTIONS_DIR_NAME),Ud}a(FC,"getTransactionAuditStoreBasePath");function c2(e,t){let r=rn.get(Ho.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Bd.join(FC(),e.toString())}a(c2,"getTransactionAuditStorePath");function kC(e,t){e=e.toString(),t=t&&t.toString();let r=rn.get(vd.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Bd.join(HC(),e)}a(kC,"getSchemaPath");function l2(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,a2(process.argv));let n=r[Ho.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!o2.isObject(n))throw o;i=n}for(let o of i){let c=o[ih];if(!c)continue;let l=rn.get(Ho.DATABASES);l=l??{};let d=c?.tables?.[t]?.[Pd.PATH];if(d)return BC.set(l,[ih,Pd.TABLES,t,Pd.PATH],d),rn.setProperty(Ho.DATABASES,l),d;let u=c?.[Pd.PATH];if(u)return BC.set(l,[ih,Pd.PATH],u),rn.setProperty(Ho.DATABASES,l),u}}let s=r[Ho.STORAGE_PATH.toUpperCase()];if(s){if(!vC.pathExistsSync(s))throw new Error(s+" does not exist");let i=Bd.join(s,e);return vC.mkdirsSync(i),rn.setProperty(Ho.STORAGE_PATH,s),i}return xC()}a(l2,"initSystemSchemaPaths");function u2(){Ld=void 0,Md=void 0,Ud=void 0}a(u2,"resetPaths");GC.exports={getBaseSchemaPath:HC,getSystemSchemaPath:xC,getTransactionAuditStorePath:c2,getTransactionAuditStoreBasePath:FC,getSchemaPath:kC,initSystemSchemaPaths:l2,resetPaths:u2}});var nn=b((eRe,KC)=>{"use strict";var d2=Nn().LMDB_ERRORS_ENUM,Xge=require("lmdb"),_2=Bt(),Zge=require("buffer").Buffer,{OVERFLOW_MARKER:qC,MAX_SEARCH_KEY_LENGTH:oh}=_2,$C=["number","string","symbol","boolean","bigint"];function f2(e){if(e=e?.primaryStore||e,!e)throw new Error(d2.ENV_REQUIRED)}a(f2,"validateEnv");function E2(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(E2,"stringifyData");function h2(e){return e instanceof Date?e.valueOf():e}a(h2,"convertKeyValueToWrite");function m2(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if($C.includes(typeof e))return e.length>oh?[e.slice(0,oh)+qC]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if($C.includes(typeof i))i.length>oh?r.push(i.slice(0,oh)+qC):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(m2,"getIndexedValues");var ah=0,VC=0;function YC(){VC=Date.now()-performance.now()}a(YC,"adjustStartTime");YC();var p2=6e4;setInterval(YC,p2).unref();function S2(){let e=performance.now()+VC;return e>ah?(ah=e,e):(ah+=488e-6,ah)}a(S2,"getNextMonotonicTime");KC.exports={validateEnv:f2,stringifyData:E2,convertKeyValueToWrite:h2,getNextMonotonicTime:S2,getIndexedValues:m2}});var WC,In,mg,Tl=Ce(()=>{WC=require("events"),In=class extends WC.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new mg;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)}},mg=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var Va={};tt(Va,{server:()=>nt});var jC,nt,Vr=Ce(()=>{jC=B(Yi()),nt={};(0,jC._assignPackageExport)("server",nt)});var Tg={};tt(Tg,{loadGQLSchema:()=>R2,start:()=>Sg,startOnMainThread:()=>g2});function Sg({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:d,StringValueNode:u}=await import("graphql"),_=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let g of _.definitions)switch(g.kind){case l.OBJECT_TYPE_DEFINITION:let F=function($){if($.kind==="NonNullType"){let _e=F($.type);return _e.nullable=!1,_e}if($.kind==="ListType")return{type:"array",elements:F($.type)};let Q={type:$.name?.value};return Object.defineProperty(Q,"location",{value:$.loc.startToken}),Q};a(F,"getProperty");let S=g.name.value,C=[],y={table:null,database:null,properties:C};E.set(S,y);for(let $ of g.directives){if($.name.value==="table"){for(let Q of $.arguments)y[Q.name.value]=Q.value.value;y.schema&&(y.database=y.schema),y.table||(y.table=S),y.audit&&(y.audit=y.audit!=="false"),y.attributes=y.properties,f.push(y)}if($.name.value==="sealed"&&(y.sealed=!0),$.name.value==="replicate"&&(y.replicate=!0),$.name.value==="export"){y.export=!0;for(let Q of $.arguments)typeof y.export!="object"&&(y.export={}),y.export[Q.name.value]=Q.value.value}}let x=!1,Y={};for(let $ of g.fields){let Z=F($.type);Z.name=$.name.value,C.push(Z),Y[Z.name]=void 0;for(let Q of $.directives){let _e=Q.name.value;if(_e==="primaryKey")x?console.warn("Can not define two attributes as a primary key at",Q.loc):(Z.isPrimaryKey=!0,x=!0);else if(_e==="indexed")Z.indexed=!0;else if(_e==="computed"){for(let K of Q.arguments||[])if(K.name.value==="from"){let se=K.value.value;Z.computed={from:T(se,K,Y)},Z.version==null&&(Z.version=se)}else K.name.value==="version"&&(Z.version=K.value.value);Z.computed=Z.computed||!0}else if(_e==="relationship"){let K={};for(let se of Q.arguments)K[se.name.value]=se.value.value;Z.relationship=K}else if(_e==="createdTime")Z.assignCreatedTime=!0;else if(_e==="updatedTime")Z.assignUpdatedTime=!0;else if(_e==="expiresAt")Z.expiresAt=!0;else if(_e==="allow"){let K=Z.authorizedRoles=[];for(let se of Q.arguments)se.name.value==="role"&&K.push(se.value.value)}else server.knownGraphQLDirectives.includes(_e)&&console.warn(`@${_e} is an unknown directive, at`,Q.loc)}}y.type=S,S==="Query"&&(h=y)}function p(g){let S=E.get(g.type);S?(Object.defineProperty(g,"properties",{value:S.properties}),Object.defineProperty(g,"definition",{value:S})):g.type==="array"?p(g.elements):T2.includes(g.type)||(0,zC.getWorkerIndex)()===0&&console.error(`The type ${g.type} is unknown at line ${g.location.line}, column ${g.location.column}, in ${s}`)}a(p,"connectPropertyType");for(let g of E.values())for(let S of g.properties)p(S);for(let g of f)g.tableClass=e(g),g.export&&(g.export.name===""?i.set((0,pg.dirname)(n),g.tableClass):i.set((0,pg.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function T(g,S,C){return new QC.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${g}; } } } } computed;`,{filename:s,lineOffset:S.loc.startToken.line-1,columnOffset:S.loc.startToken.column}).runInThisContext()(C)}a(T,"createComputedFrom")}}var pg,QC,zC,T2,g2,R2,JC=Ce(()=>{pg=require("path"),QC=require("node:vm");Le();zC=B(st()),T2=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(Sg,"start");g2=Sg,R2=Sg({ensureTable:ft}).handleFile});async function ch(e){let t=(0,eD.pathToFileURL)(e).toString();return A2?(Hd||(Hd=O2(y2)),(await(await Hd).import(t)).namespace):import(t)}async function O2(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Hd=new Compartment({console,Math,Date,fetch:b2,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,ZC.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:yr,tables:wn,databases:Ve})}};let n=await(0,XC.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Hd}function b2(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 y2(){return{Resource:yr,tables:wn}}var XC,ZC,eD,A2,Hd,gg=Ce(()=>{rs();Le();XC=require("fs/promises"),ZC=require("path"),eD=require("url"),A2=!1;a(ch,"secureImport");a(O2,"getCompartment");a(b2,"secureOnlyFetch");a(y2,"getGlobalVars")});var Ag={};tt(Ag,{handleFile:()=>N2});async function N2(e,t,r,n){let s=new Map,i=await ch(r);c(i.default)&&n.set((0,Rg.dirname)(t),i.default),o(i,(0,Rg.dirname)(t));function o(l,d){for(let u in l){let _=l[u];c(_)?n.set(d+"/"+u,_):typeof _=="object"&&o(_,d+"/"+u)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var Rg,tD=Ce(()=>{gg();Rg=require("path");a(N2,"handleFile")});var bg={};tt(bg,{start:()=>I2});function I2({resources:e}){e.set("login",Og),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Og,rD=Ce(()=>{rs();a(I2,"start");Og=class extends yr{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 lD={};tt(lD,{parse:()=>Ng,streamAsJSON:()=>xd,stringify:()=>Ya});function xd(e){return new yg({value:e})}function nD(e){return console.error(e),JSON.stringify(e.toString())}function sD(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Ya(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===aD)return cD(e);if(t.resolution)return t.resolution.then(()=>Ya(e));throw t}}function cD(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+=cD(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Ya(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Ng(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),D2.test(e)?w2.parse(e):JSON.parse(e)):null}var iD,oD,w2,C2,aD,yg,D2,Ig=Ce(()=>{iD=require("stream"),oD=B(require("json-bigint-fixes")),w2=(0,oD.default)({useNativeBigInt:!0}),C2=1e4,aD={};BigInt.prototype.toJSON=function(){throw aD};a(xd,"streamAsJSON");yg=class extends iD.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:()=>({done:!0})},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:()=>({done:!0})}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),nD)}catch(s){yield nD(s)}else yield Ya(t)}else yield Ya(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);sD(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>C2?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 sD(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(nD,"handleError");a(sD,"when");a(Ya,"stringify");a(cD,"jsStringify");D2=/[[,:]\s*-?\d{16,}/;a(Ng,"parse")});var AD=b((mRe,RD)=>{"use strict";var wg=require("recursive-iterator"),P2=require("alasql"),Cg=require("clone"),uD=ee(),{handleHDBError:dD,hdb_errors:L2}=ce(),{HDB_ERROR_MSGS:_D,HTTP_STATUS_CODES:fD}=L2,{getDatabases:M2}=(Le(),ie(lt)),U2=["DISTINCT_ARRAY"],ED=Symbol("validateTables"),Dg=Symbol("validateTable"),hRe=Symbol("getAllColumns"),hD=Symbol("validateAllColumns"),lh=Symbol("findColumn"),mD=Symbol("validateOrderBy"),Fd=Symbol("validateSegment"),Pg=Symbol("validateColumn"),pD=Symbol("setColumnsForTable"),SD=Symbol("checkColumnsForAsterisk"),TD=Symbol("validateGroupBy"),gD=Symbol("hasColumns"),Lg=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[ED](),this[SD](),this[hD]()}[ED](){if(this[gD]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Dg](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Dg](t.table)})}}[gD](){let t=!1,r=new wg(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Dg](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=M2();if(!r[t.databaseid])throw dD(new Error,_D.SCHEMA_NOT_FOUND(t.databaseid),fD.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw dD(new Error,_D.TABLE_NOT_FOUND(t.databaseid,t.tableid),fD.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Cg(s);i.table=Cg(t),this.attributes.push(i)})}[lh](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)}[SD](){let t=new wg(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[pD](r.tableid)}[pD](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new P2.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[hD](){this[Fd](this.statement.columns,!1),this[Fd](this.statement.joins,!1),this[Fd](this.statement.where,!1),this[TD](this.statement.group,!1),this[Fd](this.statement.order,!0)}[Fd](t,r){if(!t)return;let n=new wg(t),s=[];for(let{node:i,path:o}of n)!uD.isEmpty(i)&&!uD.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[mD](i):s.push(this[Pg](i)));return s}[TD](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&U2.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Cg(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[lh](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[lh](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`}[mD](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[Pg](t)}[Pg](t){let r=this[lh](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]}};RD.exports=Lg});var bD=b((SRe,OD)=>{"use strict";var Mg=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")}};OD.exports=Mg});var ND=b((gRe,yD)=>{"use strict";var Ug=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};yD.exports=Ug});var DD={};tt(DD,{HAS_EXPIRATION:()=>_h,HAS_RESIDENCY_ID:()=>qg,HAS_STRUCTURE_UPDATE:()=>fh,LAST_TIMESTAMP_PLACEHOLDER:()=>$d,LOCAL_TIMESTAMP:()=>v2,METADATA:()=>kd,NO_TIMESTAMP:()=>Bg,PENDING_LOCAL_TIME:()=>$g,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Gg,RecordEncoder:()=>kg,TIMESTAMP_ASSIGN_LAST:()=>H2,TIMESTAMP_ASSIGN_NEW:()=>wD,TIMESTAMP_ASSIGN_PREVIOUS:()=>CD,TIMESTAMP_PLACEHOLDER:()=>uh,TIMESTAMP_RECORD_PREVIOUS:()=>Hg,getUpdateRecord:()=>Vg,handleLocalTimeForGets:()=>Eh});function F2(){return qd[0]=qd[0]^64,B2.getFloat64(0)}function Eh(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,d=l?.[kd];return d>=0&&(c.metadataFlags=d,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[kd]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,d=l[kd];return d>=0&&(c.metadataFlags=d,c.localTime=l.localTime,c.value=l.value,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Ka.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<Ka.length;l++){let d=Ka[l].deref();(!d||d.isDone||d.isCommitted)&&Ka.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Vg(e,t,r){return function(n,s,i,o,c=-1,l,d,u="put",_,E){_||l==null?gl=i?.localTime?Hg|CD:Bg:gl=l?i?.localTime?Hg|16384:wD|16384:Bg;let f=d?.expiresAt;if(f>=0&&(c|=_h),Gd=c,xg=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:gl>0},p,T=0;try{let g=i?.residencyId,S=d?.residencyId;S&&(Fg=S,Gd|=qg,T|=Wa),g!==S&&(T|=ja,g||(g=0)),c&_h&&(T|=Yd),d?.originatingOperation&&(T|=Vd),_&&(h.ifVersion=p=i?.version??null);let C=e.put(n,s,h);if(l){let y=d?.user?.username;if(E&&(dh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(T|=fh,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let x=i?.localTime,F=r.get(x);if(F){let Y=Ht(F).previousLocalTime;return r.put(x,Rl(o,t,n,Y,d?.nodeId??server.replication.getThisNodeId(r)??0,y,u,dh,T,S,g,f),{ifVersion:p}),C}}r.put($d,Rl(o,t,n,i?.localTime?1:0,d?.nodeId??server.replication?.getThisNodeId(r)??0,y,u,dh,T,S,g,f,d?.originatingOperation),{append:u!=="invalidate",instructedWrite:!0,ifVersion:p})}return C}catch(g){throw g.message+=" id: "+n+" options: "+h,g}}}var ID,vg,uh,$d,Gg,v2,kd,qd,B2,Bg,wD,H2,CD,Hg,_h,qg,$g,fh,x2,dh,gl,Gd,xg,Fg,kg,Ka,Al=Ce(()=>{ID=require("msgpackr");Wi();vg=B(V()),uh=new Uint8Array([1,1,1,1,4,64,0,0]),$d=new Uint8Array([1,1,1,1,1,0,0,0]),Gg=new Uint8Array([1,1,1,1,3,64,0,0]),v2=Symbol("local-timestamp"),kd=Symbol("metadata"),qd=new Uint8Array(8),B2=new DataView(qd.buffer,0,8),Bg=0,wD=0,H2=1,CD=3,Hg=4,_h=16,qg=32,$g=1,fh=256,gl=0,Gd=-1,xg=-1,Fg=0,kg=class extends ID.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(gl||Gd>=0){let o=0,c=gl;c&&(o+=8,gl=0);let l=Gd,d=xg,u=Fg;l>=0&&(o+=2,Gd=-1,d>=0&&(o+=8,xg=-1),u&&(o+=4,Fg=0));let _=x2=r.call(this,s,i|2048|o);dh=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(uh[4]=c,uh[5]=c>>8,_.set(uh,E),E+=8),l>=0&&(_[E++]=l&31,_[E++]=l>>5,d>=0&&((_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(E,d),E+=8),u&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setUint32(E,u)),_}else return r.call(this,s,i)};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(qd,0,c),c+=8;else for(let E=0;E<8;E++)qd[E]=t[c++];l=F2(),i=t[c]}let d,u;i<32&&(o=i|t[c+1]<<5,c+=2,o&_h&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&qg&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let _=r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c);return{localTime:l,value:_,[kd]:o,expiresAt:d,residencyId:u}}return r?.valueAsBuffer?t:super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(F2,"getTimestamp");a(Eh,"handleLocalTimeForGets");Ka=[];setInterval(()=>{for(let e=0;e<Ka.length;e++){let t=Ka[e].deref();!t||t.isDone||t.isCommitted?Ka.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(vg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):vg.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(Vg,"getUpdateRecord")});var Kd=b((yRe,LD)=>{"use strict";var PD=te(),k2=M(),{RecordEncoder:G2}=(Al(),ie(DD)),bRe=require("fs");PD.initSync();var q2=PD.get(k2.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Yg=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=q2&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:G2})}};LD.exports=Yg});var Wd=b((IRe,MD)=>{"use strict";var Cn=te(),ns=M();Cn.initSync();var hh=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Cn.get(ns.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Cn.get(ns.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Cn.get(ns.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Cn.get(ns.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Cn.get(ns.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Cn.get(ns.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Cn.get(ns.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Cn.get(ns.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Cn.get(ns.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Cn.get(ns.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Cn.get(ns.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Cn.get(ns.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};MD.exports=hh;hh.MAX_DBS=1e4});var Et=b((CRe,$D)=>{"use strict";var Wg=require("lmdb"),Bs=require("fs-extra"),Dn=require("path"),mh=nn(),BD=V(),sn=Nn().LMDB_ERRORS_ENUM,ph=ND(),jg=Kd(),HD=Wd(),xo=Bt(),UD=M(),{table:$2,resetDatabases:V2}=(Le(),ie(lt)),vD=te(),Hs=xo.INTERNAL_DBIS_NAME,xD=xo.DBI_DEFINITION_NAME,Y2="data.mdb",K2="lock.mdb",jd=".mdb",W2="-lock",Kg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ss(t,r),this.key_type=this.dbi[xo.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[xo.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new Wg.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Sh(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(Sh,"pathEnvNameValidation");async function Qg(e,t,r=!0){try{await Bs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(sn.INVALID_BASE_PATH):n}try{let n=Dn.join(e,t+jd);return await Bs.access(n,Bs.constants.R_OK|Bs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Bs.access(Dn.join(e,t,Y2),Bs.constants.R_OK|Bs.constants.F_OK),Dn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(sn.INVALID_ENVIRONMENT)}else throw new Error(sn.INVALID_ENVIRONMENT);throw n}}a(Qg,"validateEnvironmentPath");function Th(e,t){if(mh.validateEnv(e),t===void 0)throw new Error(sn.DBI_NAME_REQUIRED)}a(Th,"validateEnvDBIName");async function j2(e,t,r=!1,n=!1){Sh(e,t);let s=Dn.basename(e);t=t.toString();let i=vD.get(UD.CONFIG_PARAMS.DATABASES);i||vD.setProperty(UD.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Qg(e,t,n),FD(e,t,r)}catch(o){if(o.message===sn.INVALID_ENVIRONMENT){let c=Dn.join(e,t);await Bs.mkdirp(n?c:e);let l=new HD(n?c:c+jd,!1),d=Wg.open(l);d.dbis=Object.create(null);let u=new jg(!1);d.openDB(Hs,u),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=zg(e,t,r);return d[xo.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=d,d}throw o}}a(j2,"createEnvironment");async function Q2(e,t,r,n=!0){Sh(e,t),t=t.toString();let s=Dn.join(e,t);return $2({table:t,database:Dn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(Q2,"copyEnvironment");async function FD(e,t,r=!1){Sh(e,t),t=t.toString();let n=zg(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 Qg(e,t),i=Dn.join(e,t+jd),o=s!=i,c=new HD(s,o),l=Wg.open(c);l.dbis=Object.create(null);let d=GD(l);for(let u=0;u<d.length;u++)ss(l,d[u]);return l[xo.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(FD,"openEnvironment");async function z2(e,t,r=!1){Sh(e,t),t=t.toString();let n=Dn.join(e,t+jd),s=await Qg(e,t);if(global.lmdb_map!==void 0){let i=zg(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await kD(o),delete global.lmdb_map[i]}}await Bs.remove(s),await Bs.remove(s===n?s+W2:Dn.join(Dn.dirname(s),K2))}a(z2,"deleteEnvironment");async function kD(e){mh.validateEnv(e);let t=e[xo.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(kD,"closeEnvironment");function zg(e,t,r=!1){let s=`${Dn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(zg,"getCachedEnvironmentName");function J2(e){mh.validateEnv(e);let t=Object.create(null),r=ss(e,Hs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Hs)try{t[n]=Object.assign(new ph,s)}catch{BD.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(J2,"listDBIDefinitions");function GD(e){mh.validateEnv(e);let t=[],r=ss(e,Hs);for(let{key:n}of r.getRange({start:!1}))n!==Hs&&t.push(n);return t}a(GD,"listDBIs");function X2(e,t){let n=ss(e,Hs).getEntry(t),s=new ph;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{BD.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(X2,"getDBIDefinition");function qD(e,t,r,n=!r){if(Th(e,t),t=t.toString(),t===Hs)throw new Error(sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ss(e,t)}catch(s){if(s.message===sn.DBI_DOES_NOT_EXIST){let i=new jg(r,n===!0),o=e.openDB(t,i),c=new ph(r===!0,n);return o[xD]=c,ss(e,Hs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(qD,"createDBI");function ss(e,t){if(Th(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Hs?r=X2(e,t):r=new ph,r===void 0)throw new Error(sn.DBI_DOES_NOT_EXIST);let n;try{let s=new jg(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[xD]=r,e.dbis[t]=n,n}a(ss,"openDBI");function Z2(e,t){Th(e,t),t=t.toString();let r=ss(e,t),n=r.getStats();return r[xo.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(Z2,"statDBI");async function e4(e,t){try{let r=Dn.join(e,t+jd);return(await Bs.stat(r)).size}catch{throw new Error(sn.INVALID_ENVIRONMENT)}}a(e4,"environmentDataSize");function t4(e,t){if(Th(e,t),t=t.toString(),t===Hs)throw new Error(sn.CANNOT_DROP_INTERNAL_DBIS_NAME);ss(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ss(e,Hs).removeSync(t)}a(t4,"dropDBI");function r4(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ss(e,i)}catch(o){if(o.message===sn.DBI_DOES_NOT_EXIST)qD(e,i,i!==t,i===t),n=!0;else throw o}}n&&V2()}a(r4,"initializeDBIs");$D.exports={openDBI:ss,openEnvironment:FD,createEnvironment:j2,listDBIs:GD,listDBIDefinitions:J2,createDBI:qD,dropDBI:t4,statDBI:Z2,deleteEnvironment:z2,initializeDBIs:r4,TransactionCursor:Kg,environmentDataSize:e4,copyEnvironment:Q2,closeEnvironment:kD}});var YD=b((PRe,VD)=>{"use strict";var Jg=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};VD.exports=Jg});var WD=b((MRe,KD)=>{"use strict";var Xg=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}};KD.exports=Xg});var QD=b((vRe,jD)=>{"use strict";var Zg=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};jD.exports=Zg});var za=b((kRe,XD)=>{"use strict";var n4=Et(),s4=YD(),i4=WD(),o4=QD(),ui=nn(),Qd=Nn().LMDB_ERRORS_ENUM,a4=Bt(),ji=M(),c4=ee(),l4=require("uuid"),HRe=require("lmdb"),{handleHDBError:u4,hdb_errors:d4}=ce(),{OVERFLOW_MARKER:xRe,MAX_SEARCH_KEY_LENGTH:FRe}=a4,zD=te();zD.initSync();var gh=zD.get(ji.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),eR=ji.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Qa=ji.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function _4(e,t,r,n,s=ui.getNextMonotonicTime()){sR(e,t,r,n),tR(e,t,r);let i=new s4,o=[],c=[];for(let l=0;l<n.length;l++){let d=n[l];JD(d,!0,s);let u=f4(e,t,r,d),_=d[t];o.push(u),c.push(_)}return rR(o,c,n,i,s)}a(_4,"insertRecords");function f4(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let u=c([[{}]]);Array.isArray(u)&&(c=u[0][ji.FUNC_VAL],n[o]=c)}let l=ui.getIndexedValues(c),d=e.dbis[o];if(l){gh&&d.prefetch(l.map(u=>({key:u,value:s})),Rh);for(let u=0,_=l.length;u<_;u++)d.put(l[u],s)}}gh&&e.dbis[t].prefetch([s],Rh),e.dbis[t].put(s,n,n[Qa])})}a(f4,"insertRecord");function E4(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(E4,"removeSkippedRecords");function JD(e,t,r){let n=r>0;(n||!Number.isInteger(e[Qa]))&&(e[Qa]=r||(r=ui.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[eR]))&&(e[eR]=r||ui.getNextMonotonicTime()):delete e[eR]}a(JD,"setTimestamps");function tR(e,t,r){r.indexOf(ji.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(ji.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(ji.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(ji.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),n4.initializeDBIs(e,t,r)}a(tR,"initializeTransaction");async function h4(e,t,r,n,s=ui.getNextMonotonicTime()){sR(e,t,r,n),tR(e,t,r);let i=new i4,o=[],c=[],l=[];for(let d=0;d<n.length;d++){let u=n[d],_=u[t],E;try{E=nR(e,t,u,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(d);continue}c.push(E),l.push(_)}return rR(c,l,n,i,s,o)}a(h4,"updateRecords");async function m4(e,t,r,n,s=ui.getNextMonotonicTime()){try{sR(e,t,r,n)}catch(l){throw u4(l,l.message,d4.HTTP_STATUS_CODES.BAD_REQUEST)}tR(e,t,r);let i=new o4,o=[],c=[];for(let l=0;l<n.length;l++){let d=n[l],u;c4.isEmpty(d[t])?(u=l4.v4(),d[t]=u):u=d[t];let _=nR(e,t,d,u,i,!1,s);o.push(_),c.push(u)}return rR(o,c,n,i,s)}a(m4,"upsertRecords");async function rR(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(),E4(r,i),n}a(rR,"finalizeWrite");function nR(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),d=l?.value,u=d;if(!d){if(i)return!1;d={}}if(JD(r,!u,o),Number.isInteger(r[Qa])&&d[Qa]>r[Qa])return!1;u&&s.original_records.push(d);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let p=r[h],T=e.dbis[h];if(T===void 0)continue;let g=d[h];if(typeof p=="function"){let C=p([[d]]);Array.isArray(C)&&(p=C[0][ji.FUNC_VAL],r[h]=p)}if(p===g)continue;let S=ui.getIndexedValues(g);if(S){gh&&T.prefetch(S.map(C=>({key:C,value:n})),Rh);for(let C=0,y=S.length;C<y;C++)T.remove(S[C],n)}if(S=ui.getIndexedValues(p),S){gh&&T.prefetch(S.map(C=>({key:C,value:n})),Rh);for(let C=0,y=S.length;C<y;C++)T.put(S[C],n)}}let f={...d,...r};c.put(n,f,f[Qa])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:nR(e,t,r,n,s,i,o))}a(nR,"updateUpsertRecord");function p4(e,t,r){if(ui.validateEnv(e),t===void 0)throw new Error(Qd.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Qd.WRITE_ATTRIBUTES_REQUIRED):new Error(Qd.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(p4,"validateBasic");function sR(e,t,r,n){if(p4(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Qd.RECORDS_REQUIRED):new Error(Qd.RECORDS_MUST_BE_ARRAY)}a(sR,"validateWrite");function Rh(){}a(Rh,"noop");XD.exports={insertRecords:_4,updateRecords:h4,upsertRecords:m4}});var Qi=b((qRe,S4)=>{S4.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var _i=b(($Re,tP)=>{"use strict";var eP=ee(),ZD=M(),Ol=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,di=require("joi"),Fo={schema_format:{pattern:Ol,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},T4=di.alternatives(di.string().min(1).max(Fo.schema_length.maximum).pattern(Ol).messages({"string.pattern.base":"{:#label} "+Fo.schema_format.message}),di.number(),di.array()).required(),g4=di.alternatives(di.string().min(1).max(Fo.schema_length.maximum).pattern(Ol).messages({"string.pattern.base":"{:#label} "+Fo.schema_format.message}),di.number()),R4=di.alternatives(di.string().min(1).max(Fo.schema_length.maximum).pattern(Ol).messages({"string.pattern.base":"{:#label} "+Fo.schema_format.message}),di.number()).required();function A4(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Fo.schema_length.maximum?`'${e}' maximum of 250 characters`:Ol.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(A4,"checkValidTable");function O4(e,t){return eP.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(O4,"validateSchemaExists");function b4(e,t){let r=t.state.ancestors[0].schema;return eP.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(b4,"validateTableExists");function y4(e,t){return e.toLowerCase()===ZD.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${ZD.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(y4,"validateSchemaName");tP.exports={common_validators:Fo,schema_regex:Ol,hdb_schema_table:T4,validateSchemaExists:O4,validateTableExists:b4,validateSchemaName:y4,checkValidTable:A4,hdb_database:g4,hdb_table:R4}});var dt=b((YRe,rP)=>{"use strict";var on=require("validate.js");on.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||on.validators.type.checks[t](e)?null:` must be a '${t}' value`};on.validators.type.checks={Object:function(e){return on.isObject(e)&&!on.isArray(e)},Array:on.isArray,Integer:on.isInteger,Number:on.isNumber,String:on.isString,Date:on.isDate,Boolean:function(e){return typeof e=="boolean"}};on.validators.hasValidFileExt=function(e,t){return on.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};rP.exports={validateObject:N4,validateObjectAsync:I4,validateBySchema:w4};function N4(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=on(e,t,{format:"flat"});return r?new Error(r):null}a(N4,"validateObject");async function I4(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await on.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(I4,"validateObjectAsync");function w4(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(w4,"validateBySchema")});var Ah=b((WRe,nP)=>{var{common_validators:fi}=_i(),Jd=dt(),zd="is required",rr={database:{presence:!1,format:fi.schema_format,length:fi.schema_length},schema:{presence:!1,format:fi.schema_format,length:fi.schema_length},table:{presence:!0,format:fi.schema_format,length:fi.schema_length},attribute:{presence:!0,format:fi.schema_format,length:fi.schema_length},hash_attribute:{presence:!0,format:fi.schema_format,length:fi.schema_length}};function Xd(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(Xd,"makeAttributesStrings");function C4(e){return e=Xd(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,Jd.validateObject(e,rr)}a(C4,"schema_object");function D4(e){return e=Xd(e),rr.table.presence={message:zd},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,Jd.validateObject(e,rr)}a(D4,"table_object");function P4(e){return e=Xd(e),rr.table.presence={message:zd},rr.attribute.presence=!1,Jd.validateObject(e,rr)}a(P4,"create_table_object");function L4(e){return e=Xd(e),rr.table.presence={message:zd},rr.attribute.presence={message:zd},rr.hash_attribute.presence=!1,Jd.validateObject(e,rr)}a(L4,"attribute_object");function M4(e){return e=Xd(e),rr.table.presence={message:zd},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,Jd.validateObject(e,rr)}a(M4,"describe_table");function U4(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(U4,"validateTableResidence");nP.exports={schema_object:C4,create_table_object:P4,table_object:D4,attribute_object:L4,describe_table:M4,validateTableResidence:U4}});var iP=b((QRe,sP)=>{"use strict";var v4=require("uuid"),iR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||v4.v4(),this.schema_table=`${this.schema}.${this.table}`}};sP.exports=iR});var Oh=b((JRe,oP)=>{"use strict";var B4=iP(),oR=class extends B4{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}};oP.exports=oR});var cP=b((ZRe,aP)=>{"use strict";aP.exports=x4;var H4="inserted";function x4(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===H4?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(x4,"returnObject")});var bh=b((rAe,_P)=>{"use strict";var F4=M(),aR=Et(),k4=za(),{getSystemSchemaPath:G4,getSchemaPath:q4}=Tt(),tAe=Qi(),$4=Ah(),V4=Oh(),Y4=cP(),{handleHDBError:lP,hdb_errors:dP}=ce(),uP=ee(),{HTTP_STATUS_CODES:K4}=dP,W4="inserted";_P.exports=j4;async function j4(e){let t=$4.attribute_object(e);if(t)throw lP(new Error,t.message,dP.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&uP.checkGlobalSchemaTable(e.schema,e.table);if(r)throw lP(new Error,r,K4.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=uP.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 V4(e.schema,e.table,e.attribute,e.id);try{let i=await aR.openEnvironment(q4(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}`);aR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await aR.openEnvironment(G4(),F4.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await k4.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return Y4(W4,c,{records:[s]},l)}catch(i){throw i}}a(j4,"lmdbCreateAttribute")});var lR=b((sAe,EP)=>{var{hdb_table:Q4,hdb_database:fP}=_i(),z4=dt(),cR=require("joi"),J4={undefined:"undefined",null:"null"},X4=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||J4[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"),Z4=cR.object({database:fP,schema:fP,table:Q4,records:cR.array().items(cR.object().custom(X4)).required()});EP.exports=function(e){return z4.validateBySchema(e,Z4)}});var Zd=b((aAe,mP)=>{"use strict";var zi=ee(),hP=V(),oAe=lR(),{getDatabases:eJ}=(Le(),ie(lt)),{ClientError:Ja}=ce();mP.exports=tJ;function tJ(e){if(zi.isEmpty(e))throw new Ja("invalid update parameters defined.");if(zi.isEmptyOrZeroLength(e.schema))throw new Ja("invalid schema specified.");if(zi.isEmptyOrZeroLength(e.table))throw new Ja("invalid table specified.");if(!Array.isArray(e.records))throw new Ja("records must be an array");let t=eJ()[e.schema]?.[e.table];if(zi.isEmpty(t))throw new Ja(`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&&zi.isEmptyOrZeroLength(o[r]))throw hP.error("a valid hash attribute must be provided with update record:",o),new Ja("a valid hash attribute must be provided with update record, check log for more info");if(!zi.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw hP.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Ja(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!zi.isEmpty(o[r])&&o[r]!==""&&n.has(zi.autoCast(o[r]))&&(o.skip=!0),n.add(zi.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(tJ,"insertUpdateValidate")});var e_=b((lAe,pP)=>{"use strict";var rJ=M().OPERATIONS_ENUM,uR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=rJ.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};pP.exports=uR});var t_=b((_Ae,TP)=>{"use strict";var dAe=e_(),yh=M(),dR=ee(),SP=V(),nJ=require("uuid"),{handleHDBError:Nh,hdb_errors:sJ}=ce(),{HDB_ERROR_MSGS:Ih,HTTP_STATUS_CODES:wh}=sJ;TP.exports=iJ;function iJ(e,t,r){for(let s=0;s<t.length;s++)oJ(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];aJ(i,r,e.operation)}}a(iJ,"processRows");function oJ(e){if(Buffer.byteLength(String(e))>yh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Nh(new Error,Ih.ATTR_NAME_LENGTH_ERR(e),wh.BAD_REQUEST,void 0,void 0,!0);if(dR.isEmptyOrZeroLength(e)||dR.isEmpty(e.trim()))throw Nh(new Error,Ih.ATTR_NAME_NULLISH_ERR,wh.BAD_REQUEST,void 0,void 0,!0)}a(oJ,"validateAttribute");function aJ(e,t,r){if(!e.hasOwnProperty(t)||dR.isEmptyOrZeroLength(e[t])){if(r===yh.OPERATIONS_ENUM.INSERT||r===yh.OPERATIONS_ENUM.UPSERT){e[t]=nJ.v4();return}throw SP.error("Update transaction aborted due to record with no hash value:",e),Nh(new Error,Ih.RECORD_MISSING_HASH_ERR,wh.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>yh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw SP.error(e),Nh(new Error,Ih.HASH_VAL_LENGTH_ERR,wh.BAD_REQUEST,void 0,void 0,!0)}a(aJ,"validateHash")});var RP=b((EAe,gP)=>{"use strict";var _R=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};gP.exports=_R});var bP=b((mAe,OP)=>{"use strict";var fR=Et(),cJ=V(),AP=Nn().LMDB_ERRORS_ENUM;OP.exports=lJ;async function lJ(e){try{if(global.lmdb_map!==void 0&&e.operation!==void 0){let t=Object.keys(global.lmdb_map),r;switch(e.operation){case"drop_schema":for(let i=0;i<t.length;i++){let o=t[i];if(o.startsWith(`${e.schema}.`)||o.startsWith(`txn.${e.schema}.`))try{await fR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==AP.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await fR.closeEnvironment(global.lmdb_map[n]),await fR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==AP.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){cJ.error(t)}}a(lJ,"cleanLMDBMap")});var Ji=b((SAe,wP)=>{"use strict";var r_=require("crypto"),uJ=te(),{CONFIG_PARAMS:dJ}=M(),NP="aes-256-cbc",_J=32,fJ=16,ER=64,IP=32,EJ=ER+IP,yP=new Map;wP.exports={encrypt:hJ,decrypt:mJ,createNatsTableStreamName:pJ};function hJ(e){let t=r_.randomBytes(_J),r=r_.randomBytes(fJ),n=r_.createCipheriv(NP,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(hJ,"encrypt");function mJ(e){let t=e.substr(0,ER),r=e.substr(ER,IP),n=e.substr(EJ,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=r_.createDecipheriv(NP,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(mJ,"decrypt");function pJ(e,t){let r=uJ.get(dJ.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=yP.get(r);return n||(n=r_.createHash("md5").update(r).digest("hex"),yP.set(r,n)),n}a(pJ,"createNatsTableStreamName")});var Ei=b((RAe,DP)=>{"use strict";var gAe=Yr(),n_=V(),CP=Ah(),SJ=Ji(),Ch=ee(),{handleHDBError:Dh,hdb_errors:TJ}=ce(),{HDB_ERROR_MSGS:Ph,HTTP_STATUS_CODES:hR}=TJ,gJ=te();gJ.initSync();var{getDatabases:mR}=(Le(),ie(lt)),RJ=require("fs-extra");DP.exports={describeAll:AJ,describeTable:Lh,describeSchema:OJ};async function AJ(e){try{let t=Ch.isEmptyOrZeroLength(e),r,n;t||(r=e.hdb_user.role.permission,n=r.super_user||r.cluster_user);let s=mR(),i={},o={},c=[],l=e?.exact_count;for(let u in s){i[u]=!0,!t&&!n&&(o[u]=e.hdb_user.role.permission[u].describe);let _=s[u];for(let E in _)try{let f;if(t||n)f=await Lh({schema:u,table:E,exact_count:l});else if(r&&r[u].describe&&r[u].tables[E].describe){let h=r[u].tables[E].attribute_permissions;f=await Lh({schema:u,table:E,exact_count:l},h)}f&&c.push(f)}catch(f){n_.error(f)}}let d={};for(let u in c)t||n?(d[c[u].schema]==null&&(d[c[u].schema]={}),d[c[u].schema][c[u].name]=c[u],i[c[u].schema]&&delete i[c[u].schema]):o[c[u].schema]&&(d[c[u].schema]==null&&(d[c[u].schema]={}),d[c[u].schema][c[u].name]=c[u],i[c[u].schema]&&delete i[c[u].schema]);for(let u in i)t||n?d[u]={}:o[u]&&(d[u]={});return d}catch(t){return n_.error("Got an error in describeAll"),n_.error(t),Dh(new Error,Ph.DESCRIBE_ALL_ERR)}}a(AJ,"describeAll");async function Lh(e,t){Ch.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user.role.permission.super_user&&(s=e.hdb_user.role.permission[r].tables[n].attribute_permissions);let i=CP.describe_table(e);if(i)throw i;let c=mR()[r];if(!c)throw Dh(new Error,Ph.SCHEMA_NOT_FOUND(e.schema),hR.NOT_FOUND);let l=c[n];if(!l)throw Dh(new Error,Ph.TABLE_NOT_FOUND(e.schema,e.table),hR.NOT_FOUND);function d(f){u.push({attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(d,"pushAtt");let u=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&d(h)})}else l.attributes?.forEach(f=>d(f));let _;try{_=(await RJ.stat(l.primaryStore.env.path)).size}catch(f){n_.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:u,db_size:_};E.clustering_stream_name=SJ.createNatsTableStreamName(E.schema,E.name);try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let p of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=p[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let p of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=p}catch(f){n_.warn(`unable to stat table dbi due to ${f}`)}return E}a(Lh,"descTable");async function OJ(e){Ch.transformReq(e);let t=CP.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user.role.permission.super_user&&(r=e.hdb_user.role.permission[e.schema]);let n=e.schema.toString(),i=mR()[n];if(!i)throw Dh(new Error,Ph.SCHEMA_NOT_FOUND(e.schema),hR.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Ch.isEmpty(l)||l.describe){let d=await Lh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);d&&(o[d.name]=d)}}return o}a(OJ,"describeSchema")});var is=b((yAe,vP)=>{var bJ=Qi(),{callbackify:LP,promisify:yJ}=require("util"),{getDatabases:MP}=(Le(),ie(lt));vP.exports={setSchemaDataToGlobal:PP,getTableSchema:NJ,getSystemSchema:IJ,setSchemaDataToGlobalAsync:yJ(PP)};var UP=Ei(),OAe=LP(UP.describeAll),bAe=LP(UP.describeTable);function PP(e){global.hdb_schema=MP(),e&&e()}a(PP,"setSchemaDataToGlobal");function NJ(e,t,r){let n=MP()[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(NJ,"getTableSchema");function IJ(){return bJ}a(IJ,"getSystemSchema")});var Kr=b((IAe,FP)=>{"use strict";var Uh=lR(),Nr=ee(),wJ=require("util"),vh=Pn(),CJ=is(),BP=V(),{handleHDBError:Xa,hdb_errors:DJ}=ce(),{HTTP_STATUS_CODES:Za}=DJ,PJ=wJ.promisify(CJ.getTableSchema),LJ="updated",HP="inserted",xP="upserted";FP.exports={insert:UJ,update:vJ,upsert:BJ,validation:MJ,flush:HJ};async function MJ(e){if(Nr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Nr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Nr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await PJ(e.schema,e.table),r=Uh(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Nr.isEmptyOrZeroLength(c[n]))throw BP.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(!Nr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw BP.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Nr.isEmpty(c[n])&&c[n]!==""&&s.has(Nr.autoCast(c[n]))&&(c.skip=!0),s.add(Nr.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(MJ,"validation");async function UJ(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=Uh(e);if(t)throw Xa(new Error,t.message,Za.BAD_REQUEST);Nr.transformReq(e);let r=Nr.checkSchemaTableExist(e.schema,e.table);if(r)throw Xa(new Error,r,Za.BAD_REQUEST);let n=await vh.createRecords(e);return Mh(HP,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(UJ,"insertData");async function vJ(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=Uh(e);if(t)throw Xa(new Error,t.message,Za.BAD_REQUEST);Nr.transformReq(e);let r=Nr.checkSchemaTableExist(e.schema,e.table);if(r)throw Xa(new Error,r,Za.BAD_REQUEST);let n=await vh.updateRecords(e);return Nr.isEmpty(n.existing_rows)?Mh(LJ,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Mh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(vJ,"updateData");async function BJ(e){if(e.operation!=="upsert")throw Xa(new Error,"invalid operation, must be upsert",Za.INTERNAL_SERVER_ERROR);let t=Uh(e);if(t)throw Xa(new Error,t.message,Za.BAD_REQUEST);Nr.transformReq(e);let r=Nr.checkSchemaTableExist(e.schema,e.table);if(r)throw Xa(new Error,r,Za.BAD_REQUEST);let n=await vh.upsertRecords(e);return Mh(xP,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(BJ,"upsertData");function Mh(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===HP?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===xP?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Mh,"returnObject");function HJ(e){return Nr.transformReq(e),vh.flush(e.schema,e.table)}a(HJ,"flush")});var SR=b((CAe,qP)=>{var xJ=dt(),pR=require("joi"),{hdb_table:FJ,hdb_database:kP}=_i(),GP={schema:kP,database:kP,table:FJ},kJ={date:pR.date().iso().required()},GJ={timestamp:pR.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};qP.exports=function(e,t){let r=t==="timestamp"?{...GP,...GJ}:{...GP,...kJ},n=pR.object(r);return xJ.validateBySchema(e,n)}});var YP=b((DAe,VP)=>{var qJ=dt(),TR=require("joi"),{hdb_table:$J,hdb_database:$P}=_i(),VJ=TR.object({schema:$P,database:$P,table:$J,hash_values:TR.array().required(),ids:TR.array()});VP.exports=function(e){return qJ.validateBySchema(e,VJ)}});var OR=b((PAe,KP)=>{"use strict";var gR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},RR=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},AR=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};KP.exports={InsertObject:gR,NoSQLSeachObject:RR,DeleteResponseObject:AR}});var qo=b((MAe,JP)=>{"use strict";var jP=SR(),YJ=YP(),ec=ee(),WP=require("moment"),QP=V(),{promisify:KJ,callbackify:WJ}=require("util"),tc=M(),jJ=is(),bR=KJ(jJ.getTableSchema),yR=Pn(),{DeleteResponseObject:QJ}=OR(),{handleHDBError:ko,hdb_errors:zJ}=ce(),{HDB_ERROR_MSGS:Bh,HTTP_STATUS_CODES:Go}=zJ,JJ="records successfully deleted",XJ=WJ(zP);JP.exports={delete:XJ,deleteRecord:zP,deleteFilesBefore:ZJ,deleteAuditLogsBefore:e3};async function ZJ(e){let t=jP(e,"date");if(t)throw ko(t,t.message,Go.BAD_REQUEST,void 0,void 0,!0);if(ec.transformReq(e),!WP(e.date,WP.ISO_8601).isValid())throw ko(new Error,Bh.INVALID_DATE,Go.BAD_REQUEST,tc.LOG_LEVELS.ERROR,Bh.INVALID_DATE,!0);let n=ec.checkSchemaTableExist(e.schema,e.table);if(n)throw ko(new Error,n,Go.NOT_FOUND,tc.LOG_LEVELS.ERROR,n,!0);let s=await yR.deleteRecordsBefore(e);if(await bR(e.schema,e.table),QP.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(ZJ,"deleteFilesBefore");async function e3(e){let t=jP(e,"timestamp");if(t)throw ko(t,t.message,Go.BAD_REQUEST,void 0,void 0,!0);if(ec.transformReq(e),isNaN(e.timestamp))throw ko(new Error,Bh.INVALID_VALUE("Timestamp"),Go.BAD_REQUEST,tc.LOG_LEVELS.ERROR,Bh.INVALID_VALUE("Timestamp"),!0);let r=ec.checkSchemaTableExist(e.schema,e.table);if(r)throw ko(new Error,r,Go.NOT_FOUND,tc.LOG_LEVELS.ERROR,r,!0);let n=await yR.deleteAuditLogsBefore(e);return await bR(e.schema,e.table),QP.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(e3,"deleteAuditLogsBefore");async function zP(e){e.ids&&(e.hash_values=e.ids);let t=YJ(e);if(t)throw ko(t,t.message,Go.BAD_REQUEST,void 0,void 0,!0);ec.transformReq(e);let r=ec.checkSchemaTableExist(e.schema,e.table);if(r)throw ko(new Error,r,Go.NOT_FOUND,tc.LOG_LEVELS.ERROR,r,!0);try{await bR(e.schema,e.table);let n=await yR.deleteRecords(e);return ec.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${JJ}`),n}catch(n){if(n.message===tc.SEARCH_NOT_FOUND_MESSAGE){let s=new QJ;return s.message=tc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(zP,"deleteRecord")});var Hh=b((vAe,eL)=>{var t3=require("crypto"),XP=9;function r3(e){let t=s3(XP),r=ZP(e+t);return t+r}a(r3,"createHash");function n3(e,t){let r=e?.substr(0,XP),n=r+ZP(t+r);return e===n}a(n3,"validateHash");function s3(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(s3,"generateSalt");function ZP(e){return t3.createHash("md5").update(e).digest("hex")}a(ZP,"md5");eL.exports={hash:r3,validate:n3}});var rL=b((HAe,tL)=>{var NR=dt(),Wr={username:{presence:!0,format:"[\\w\\-\\_]+",exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function i3(e){return Wr.password.presence=!0,Wr.username.presence=!0,Wr.role.presence=!0,Wr.active.presence=!0,NR.validateObject(e,Wr)}a(i3,"addUserValidation");function o3(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,NR.validateObject(e,Wr)}a(o3,"alterUserValidation");function a3(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,NR.validateObject(e,Wr)}a(a3,"dropUserValidation");tL.exports={addUserValidation:i3,alterUserValidation:o3,dropUserValidation:a3}});var _t=b((kAe,sL)=>{"use strict";var{platform:FAe}=require("os"),c3="nats-server.zip",IR="nats-server",l3=process.platform==="win32"?`${IR}.exe`:IR,u3=/^[^\s.,*>]+$/,nL="__request__",d3=a(e=>`${e}.${nL}`,"REQUEST_SUBJECT"),_3={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},f3={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},E3={HUB:"hub.pid",LEAF:"leaf.pid"},h3={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},m3={SUCCESS:"success",ERROR:"error"},p3={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},S3={TXN:"txn",MSGID:"msgid"},bl={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},T3={[bl.ERR]:1,[bl.WRN]:2,[bl.INF]:3,[bl.DBG]:4,[bl.TRC]:5},g3={debug:"-D",trace:"-DVV"};sL.exports={NATS_SERVER_ZIP:c3,NATS_SERVER_NAME:IR,NATS_BINARY_NAME:l3,PID_FILES:E3,NATS_CONFIG_FILES:f3,SERVER_SUFFIX:h3,NATS_TERM_CONSTRAINTS_RX:u3,REQUEST_SUFFIX:nL,UPDATE_REMOTE_RESPONSE_STATUSES:m3,CLUSTER_STATUS_STATUSES:p3,REQUEST_SUBJECT:d3,SUBJECT_PREFIXES:S3,MSG_HEADERS:_3,LOG_LEVELS:bl,LOG_LEVEL_FLAGS:g3,LOG_LEVEL_HIERARCHY:T3}});var wR=b(iL=>{"use strict";var R3={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
1
+ "use strict";var ej=Object.create;var Od=Object.defineProperty;var tj=Object.getOwnPropertyDescriptor;var rj=Object.getOwnPropertyNames;var nj=Object.getPrototypeOf,sj=Object.prototype.hasOwnProperty;var a=(e,t)=>Od(e,"name",{value:t,configurable:!0});var De=(e,t)=>()=>(e&&(t=e(e=0)),t);var b=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),et=(e,t)=>{for(var r in t)Od(e,r,{get:t[r],enumerable:!0})},Hw=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of rj(t))!sj.call(e,s)&&s!==r&&Od(e,s,{get:()=>t[s],enumerable:!(n=tj(t,s))||n.enumerable});return e};var v=(e,t,r)=>(r=e!=null?ej(nj(e)):{},Hw(t||!e||!e.__esModule?Od(r,"default",{value:e,enumerable:!0}):r,e)),oe=e=>Hw(Od({},"__esModule",{value:!0}),e);var Fw=b((Uge,kw)=>{var ij=require("fast-glob"),{statSync:ng,existsSync:sg,readFileSync:oj,writeFileSync:aj}=require("fs"),{spawnSync:cj,spawn:lj,execFileSync:Mge}=require("child_process"),{isMainThread:uj}=require("worker_threads"),{join:xo,relative:xw}=require("path"),{PACKAGE_ROOT:vs}=M(),{tmpdir:dj,platform:_j}=require("os");require("source-map-support").install();var fj=["resources","server","dataLayer","components"],Nd="ts-build",ig,Ej=__filename.endsWith("tsBuild.js");if(Ej){if(uj){let r;try{ng(xo(vs,Nd)),r=!0}catch{}if(r)for(let n of ij.sync(fj.map(s=>s+"/**/*.ts"),{cwd:vs})){let s=0,i=0;try{s=ng(xo(vs,n)).mtimeMs-5e3,i=ng(xo(vs,Nd,n.replace(/.ts$/,".js"))).mtimeMs}catch{}if(s>i){console.warn(`TypeScript ${n} is not compiled`+(i?` (TS source file was modified at ${new Date(s)} and compiled file at ${new Date(i)})`:"")+", consider enabling auto-compilation of TypeScript in your IDE), compiling now."),ig=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),ig=!0;if(ig){let n=xo(vs,"node_modules/.bin/tsc");_j()==="win32"&&(n+=".cmd");let s=cj(n,{cwd:vs});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=xo(dj(),"harperdb-tsc.pid"),o;if(sg(i))try{process.kill(+oj(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=lj(n,["--watch"],{cwd:vs,detached:!0,stdio:"ignore"});aj(i,c.pid.toString()),c.unref()}}}}let e=kw.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(vs)&&!n[0].includes("node_modules")){let i=xw(vs,n[0]),o;i.startsWith(Nd)?o=xo(vs,xw(Nd,i)):o=xo(vs,Nd,i);let c=xo(o,r),l=c+".js";if(sg(l))return l;if(c.includes(".")&&sg(c))return c}return t(r,n,s)}}});var M=b((Hge,eC)=>{"use strict";var ns=require("path"),hj=require("fs"),{relative:vge,join:Bge}=ns,{existsSync:mj}=hj;function pj(){let e=__dirname;for(;!mj(ns.join(e,"package.json"));){let t=ns.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(pj,"getHDBPackageRoot");var ko=pj(),Gw="js",JE=Gw,Sj="harperdb-config.yaml",Tj="defaultConfig.yaml",gj="hdb",qw=`harperdb.${JE}`,$w=`customFunctionsServer.${JE}`,Rj=`restartHdb.${JE}`,ag="HarperDB",zE="Custom Functions",XE="Clustering Hub",ZE="Clustering Leaf",Aj="Clustering Ingest Service",bj="Clustering Reply Service",yj="foreground.pid",Oj="hdb.pid",Nj="data",Ij={HDB:ag,CLUSTERING_HUB:XE,CLUSTERING_LEAF:ZE,CLUSTERING_INGEST_SERVICE:Aj,CLUSTERING_REPLY_SERVICE:bj,CUSTOM_FUNCTIONS:zE,RESTART_HDB:"Restart HDB",INSTALL:"Install",RUN:"Run",STOP:"Stop",UPGRADE:"Upgrade",REGISTER:"Register",JOB:"Job",CLUSTERING_UPGRADE_4_0_0:"Upgrade-4-0-0"},wj={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},Cj={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},Dj={harperdb:ag,"clustering hub":XE,"clustering leaf":ZE,"custom functions":zE,custom_functions:zE,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},Pj={CLUSTERING_HUB_PROC_DESCRIPTOR:XE,CLUSTERING_LEAF_PROC_DESCRIPTOR:ZE},og={HDB:ns.join(ko,"server/harperdb"),CUSTOM_FUNCTIONS:ns.join(ko,"server/customFunctions"),CLUSTERING_HUB:ns.join(ko,"server/nats"),CLUSTERING_LEAF:ns.join(ko,"server/nats")},Lj={HDB:ns.join(og.HDB,qw),CUSTOM_FUNCTIONS:ns.join(og.CUSTOM_FUNCTIONS,$w)},Mj={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:ns.join(ko,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:ns.join(ko,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:ns.join(ko,"launchServiceScripts/launchUpdateNodes4-0-0.js")},Uj={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},Vw="support@harperdb.io",vj="customer-success@harperdb.io",Yw=1,Bj=4141,Kw="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",Hj="https://www.harperdb.io/product",xj=`For support, please submit a request at ${Kw} or contact ${Vw}`,Ww=`For license support, please contact ${vj}`,kj="None of the specified records were found.",Fj="hash attribute not found",Gj=`Your current license only supports ${Yw} role. ${Ww}`,qj="Your current license only supports 3 connections to a node.",$j="127.0.0.1",Vj=1,Yj=/^\.$/,Kj=/^\.\.$/,Wj="U+002E",jj=/\//g,Qj="U+002F",zj=/U\+002F/g,Jj=/^U\+002E$/,Xj=/^U\+002EU\+002E$/,Zj="d",eQ=999999,tQ="*",rQ="--max-old-space-size=",nQ="system",sQ="__hdb_hash",iQ=".harperdb",oQ=".hdb",aQ="keys",cQ="hdb_boot_properties.file",lQ=".updateConfig.json",uQ="SIGTSTP",dQ=24,_Q=6e4,fQ=448,EQ="blob",hQ="database",mQ="schema",pQ="transactions",SQ=".count",TQ="id",gQ="PROCESS_NAME",jw={SETTINGS_PATH_KEY:"settings_path"},Qw=require("lodash"),RQ={TC_AGREEMENT:"TC_AGREEMENT",CLUSTERING_USER:"CLUSTERING_USER",CLUSTERING_PASSWORD:"CLUSTERING_PASSWORD",HDB_ADMIN_USERNAME:"HDB_ADMIN_USERNAME",HDB_ADMIN_PASSWORD:"HDB_ADMIN_PASSWORD",OPERATIONSAPI_ROOT:"OPERATIONSAPI_ROOT",ROOTPATH:"ROOTPATH",CLUSTERING_NODENAME:"CLUSTERING_NODENAME",CLUSTERING_ENABLED:"CLUSTERING_ENABLED",HDB_CONFIG:"HDB_CONFIG",DEFAULTS_MODE:"DEFAULTS_MODE",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},AQ={HDB_PATH_KEY:"HDB_INTERNAL_PATH",HDB_AUTH_HEADER:"hdb_auth_header",HDB_USER_DATA_KEY:"hdb_user",CHUNK_SIZE:1e3,MAX_CHARACTER_SIZE:250},bQ={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},yQ={JOB_TABLE_NAME:"hdb_job",NODE_TABLE_NAME:"hdb_nodes",ATTRIBUTE_TABLE_NAME:"hdb_attribute",LICENSE_TABLE_NAME:"hdb_license",ROLE_TABLE_NAME:"hdb_role",SCHEMA_TABLE_NAME:"hdb_schema",TABLE_TABLE_NAME:"hdb_table",USER_TABLE_NAME:"hdb_user",INFO_TABLE_NAME:"hdb_info"},OQ={JOB_TABLE_HASH_ATTRIBUTE:"id",NODE_TABLE_HASH_ATTRIBUTE:"name",ATTRIBUTE_TABLE_HASH_ATTRIBUTE:"id",LICENSE_TABLE_HASH_ATTRIBUTE:"license_key",ROLE_TABLE_HASH_ATTRIBUTE:"id",SCHEMA_TABLE_HASH_ATTRIBUTE:"name",TABLE_TABLE_HASH_ATTRIBUTE:"id",USER_TABLE_HASH_ATTRIBUTE:"username",INFO_TABLE_ATTRIBUTE:"info_id"},On="hdb_internal:",NQ={CREATE_SCHEMA:On+"create_schema",CREATE_TABLE:On+"create_table",CREATE_ATTRIBUTE:On+"create_attribute",ADD_USER:On+"add_user",ALTER_USER:On+"alter_user",DROP_USER:On+"drop_user",HDB_NODES:On+"hdb_nodes",HDB_USERS:On+"hdb_users",HDB_WORKERS:On+"hdb_workers",CATCHUP:On+"catchup",SCHEMA_CATCHUP:On+"schema_catchup",WORKER_ROOM:On+"cluster_workers"},IQ={ATTR_ATTRIBUTE_KEY:"attribute",ATTR_CREATEDDATE_KEY:"createddate",ATTR_HASH_ATTRIBUTE_KEY:"hash_attribute",ATTR_ID_KEY:"id",ATTR_NAME_KEY:"name",ATTR_PASSWORD_KEY:"password",ATTR_RESIDENCE_KEY:"residence",ATTR_ROLE_KEY:"role",ATTR_SCHEMA_KEY:"schema",ATTR_SCHEMA_TABLE_KEY:"schema_table",ATTR_TABLE_KEY:"table",ATTR_USERNAME_KEY:"username"},wQ="060493.ks",CQ=".license",DQ={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},ae={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts"},PQ={CSV:".csv",JSON:".json"},LQ={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},MQ={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Id={};Id[ae.INSERT]=ae.INSERT;Id[ae.UPDATE]=ae.UPDATE;Id[ae.UPSERT]=ae.UPSERT;Id[ae.DELETE]=ae.DELETE;var tt=Object.create(null);tt[ae.DESCRIBE_ALL]=ae.DESCRIBE_ALL;tt[ae.DESCRIBE_TABLE]=ae.DESCRIBE_TABLE;tt[ae.DESCRIBE_SCHEMA]=ae.DESCRIBE_SCHEMA;tt[ae.READ_LOG]=ae.READ_LOG;tt[ae.ADD_NODE]=ae.ADD_NODE;tt[ae.LIST_USERS]=ae.LIST_USERS;tt[ae.LIST_ROLES]=ae.LIST_ROLES;tt[ae.USER_INFO]=ae.USER_INFO;tt[ae.SQL]=ae.SQL;tt[ae.GET_JOB]=ae.GET_JOB;tt[ae.SEARCH_JOBS_BY_START_DATE]=ae.SEARCH_JOBS_BY_START_DATE;tt[ae.DELETE_FILES_BEFORE]=ae.DELETE_FILES_BEFORE;tt[ae.EXPORT_LOCAL]=ae.EXPORT_LOCAL;tt[ae.EXPORT_TO_S3]=ae.EXPORT_TO_S3;tt[ae.CLUSTER_STATUS]=ae.CLUSTER_STATUS;tt[ae.REMOVE_NODE]=ae.REMOVE_NODE;tt[ae.RESTART]=ae.RESTART;tt[ae.CUSTOM_FUNCTIONS_STATUS]=ae.CUSTOM_FUNCTIONS_STATUS;tt[ae.GET_CUSTOM_FUNCTIONS]=ae.GET_CUSTOM_FUNCTIONS;tt[ae.GET_CUSTOM_FUNCTION]=ae.GET_CUSTOM_FUNCTION;tt[ae.SET_CUSTOM_FUNCTION]=ae.SET_CUSTOM_FUNCTION;tt[ae.DROP_CUSTOM_FUNCTION]=ae.DROP_CUSTOM_FUNCTION;tt[ae.ADD_CUSTOM_FUNCTION_PROJECT]=ae.ADD_CUSTOM_FUNCTION_PROJECT;tt[ae.DROP_CUSTOM_FUNCTION_PROJECT]=ae.DROP_CUSTOM_FUNCTION_PROJECT;tt[ae.PACKAGE_CUSTOM_FUNCTION_PROJECT]=ae.PACKAGE_CUSTOM_FUNCTION_PROJECT;tt[ae.DEPLOY_CUSTOM_FUNCTION_PROJECT]=ae.DEPLOY_CUSTOM_FUNCTION_PROJECT;tt[ae.ADD_SSH_KEY]=ae.ADD_SSH_KEY;tt[ae.UPDATE_SSH_KEY]=ae.UPDATE_SSH_KEY;tt[ae.DELETE_SSH_KEY]=ae.DELETE_SSH_KEY;var UQ={DEV:"dev",RUN:"run",START:"start",INSTALL:"install",REGISTER:"register",STOP:"stop",RESTART:"restart",VERSION:"version",UPGRADE:"upgrade",HELP:"help",STATUS:"status",OPERATION:"operation",RENEWCERTS:"renew-certs",COPYDB:"copy-db"},vQ={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},zw={HDB_ROOT_KEY:"HDB_ROOT",SERVER_PORT_KEY:"SERVER_PORT",CERT_KEY:"CERTIFICATE",PRIVATE_KEY_KEY:"PRIVATE_KEY",HTTP_SECURE_ENABLED_KEY:"HTTPS_ON",CORS_ENABLED_KEY:"CORS_ON",CORS_WHITELIST_KEY:"CORS_WHITELIST",LOG_LEVEL_KEY:"LOG_LEVEL",LOGGER_KEY:"LOGGER",LOG_PATH_KEY:"LOG_PATH",LOG_ROTATE:"LOG_ROTATE",LOG_ROTATE_MAX_SIZE:"LOG_ROTATE_MAX_SIZE",LOG_ROTATE_RETAIN:"LOG_ROTATE_RETAIN",LOG_ROTATE_COMPRESS:"LOG_ROTATE_COMPRESS",LOG_ROTATE_DATE_FORMAT:"LOG_ROTATE_DATE_FORMAT",LOG_ROTATE_ROTATE_MODULE:"LOG_ROTATE_ROTATE_MODULE",LOG_ROTATE_WORKER_INTERVAL:"LOG_ROTATE_WORKER_INTERVAL",LOG_ROTATE_ROTATE_INTERVAL:"LOG_ROTATE_ROTATE_INTERVAL",LOG_ROTATE_TIMEZONE:"LOG_ROTATE_TIMEZONE",LOG_DAILY_ROTATE_KEY:"LOG_DAILY_ROTATE",LOG_MAX_DAILY_FILES_KEY:"LOG_MAX_DAILY_FILES",PROPS_ENV_KEY:"NODE_ENV",SETTINGS_PATH_KEY:"settings_path",CLUSTERING_PORT_KEY:"CLUSTERING_PORT",CLUSTERING_NODE_NAME_KEY:"NODE_NAME",CLUSTERING_ENABLED_KEY:"CLUSTERING",ALLOW_SELF_SIGNED_SSL_CERTS:"ALLOW_SELF_SIGNED_SSL_CERTS",MAX_HDB_PROCESSES:"MAX_HDB_PROCESSES",INSTALL_USER:"install_user",CLUSTERING_USER_KEY:"CLUSTERING_USER",MAX_CLUSTERING_PROCESSES:"MAX_CLUSTERING_PROCESSES",SERVER_TIMEOUT_KEY:"SERVER_TIMEOUT_MS",SERVER_KEEP_ALIVE_TIMEOUT_KEY:"SERVER_KEEP_ALIVE_TIMEOUT",SERVER_HEADERS_TIMEOUT_KEY:"SERVER_HEADERS_TIMEOUT",DISABLE_TRANSACTION_LOG_KEY:"DISABLE_TRANSACTION_LOG",OPERATION_TOKEN_TIMEOUT_KEY:"OPERATION_TOKEN_TIMEOUT",REFRESH_TOKEN_TIMEOUT_KEY:"REFRESH_TOKEN_TIMEOUT",CUSTOM_FUNCTIONS_ENABLED_KEY:"CUSTOM_FUNCTIONS",CUSTOM_FUNCTIONS_PORT_KEY:"CUSTOM_FUNCTIONS_PORT",CUSTOM_FUNCTIONS_DIRECTORY_KEY:"CUSTOM_FUNCTIONS_DIRECTORY",MAX_CUSTOM_FUNCTION_PROCESSES:"MAX_CUSTOM_FUNCTION_PROCESSES",LOG_TO_FILE:"LOG_TO_FILE",LOG_TO_STDSTREAMS:"LOG_TO_STDSTREAMS",RUN_IN_FOREGROUND:"RUN_IN_FOREGROUND",LOCAL_STUDIO_ON:"LOCAL_STUDIO_ON",STORAGE_WRITE_ASYNC:"STORAGE_WRITE_ASYNC"},BQ=Qw.invert(zw),HQ={CUSTOMFUNCTIONS_ENABLED:"customFunctions_enabled",CUSTOMFUNCTIONS_NETWORK_PORT:"customFunctions_network_port",CUSTOMFUNCTIONS_TLS_CERTIFICATE:"customFunctions_tls_certificate",CUSTOMFUNCTIONS_NETWORK_CORS:"customFunctions_network_cors",CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST:"customFunctions_network_corsAccessList",CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT:"customFunctions_network_headersTimeout",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT:"customFunctions_network_keepAliveTimeout",CUSTOMFUNCTIONS_TLS_PRIVATEKEY:"customFunctions_tls_privateKey",CUSTOMFUNCTIONS_TLS_CERT_AUTH:"customFunctions_tls_certificateAuthority",CUSTOMFUNCTIONS_NETWORK_TIMEOUT:"customFunctions_network_timeout",CUSTOMFUNCTIONS_NODEENV:"customFunctions_nodeEnv",CUSTOMFUNCTIONS_ROOT:"customFunctions_root"},P={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},Jw={settings_path:jw.SETTINGS_PATH_KEY,hdb_root_key:P.ROOTPATH,hdb_root:P.ROOTPATH,rootpath:P.ROOTPATH,server_port_key:P.OPERATIONSAPI_NETWORK_PORT,server_port:P.OPERATIONSAPI_NETWORK_PORT,cert_key:P.TLS_CERTIFICATE,certificate:P.TLS_CERTIFICATE,private_key_key:P.TLS_PRIVATEKEY,private_key:P.TLS_PRIVATEKEY,http_secure_enabled_key:P.OPERATIONSAPI_NETWORK_HTTPS,https_on:P.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:P.OPERATIONSAPI_NETWORK_CORS,cors_on:P.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:P.LOGGING_LEVEL,log_level:P.LOGGING_LEVEL,log_path_key:P.LOGGING_ROOT,log_path:P.LOGGING_ROOT,clustering_node_name_key:P.CLUSTERING_NODENAME,node_name:P.CLUSTERING_NODENAME,clustering_enabled_key:P.CLUSTERING_ENABLED,clustering:P.CLUSTERING_ENABLED,max_http_threads:P.THREADS_COUNT,max_hdb_processes:P.THREADS_COUNT,server_timeout_key:P.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:P.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:P.LOGGING_AUDITLOG,disable_transaction_log:P.LOGGING_AUDITLOG,operation_token_timeout_key:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:P.HTTP_PORT,custom_functions_port:P.HTTP_PORT,custom_functions_directory_key:P.COMPONENTSROOT,custom_functions_directory:P.COMPONENTSROOT,max_custom_function_processes:P.THREADS_COUNT,logging_console:P.LOGGING_CONSOLE,log_to_file:P.LOGGING_FILE,log_to_stdstreams:P.LOGGING_STDSTREAMS,local_studio_on:P.LOCALSTUDIO_ENABLED,clustering_port:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:P.CLUSTERING_USER,clustering_enabled:P.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:P.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:P.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:P.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:P.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:P.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:P.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:P.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxconsumemsgs:P.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:P.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,clustering_leafserver_streams_maxmsgs:P.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:P.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:P.CLUSTERING_NODENAME,clustering_tls_certificate:P.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:P.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:P.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:P.CLUSTERING_TLS_INSECURE,clustering_tls_verify:P.CLUSTERING_TLS_VERIFY,clustering_loglevel:P.CLUSTERING_LOGLEVEL,clustering_republishmessages:P.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:P.CLUSTERING_DATABASELEVEL,customfunctions_network_port:P.HTTP_PORT,customfunctions_tls_certificate:P.TLS_CERTIFICATE,customfunctions_network_cors:P.HTTP_CORS,customfunctions_network_corsaccesslist:P.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:P.HTTP_HEADERSTIMEOUT,customfunctions_network_https:P.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:P.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:P.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:P.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:P.HTTP_TIMEOUT,customfunctions_tls:P.TLS,http_threads:P.THREADS_COUNT,threads:P.THREADS_COUNT,threads_count:P.THREADS_COUNT,threads_debug:P.THREADS_DEBUG,threads_debug_startingport:P.THREADS_DEBUG_STARTINGPORT,threads_debug_port:P.THREADS_DEBUG_PORT,threads_debug_host:P.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:P.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:P.THREADS_MAXHEAPMEMORY,http_session_affinity:P.HTTP_SESSIONAFFINITY,http_compressionthreshold:P.HTTP_COMPRESSIONTHRESHOLD,http_cors:P.HTTP_CORS,http_corsaccesslist:P.HTTP_CORSACCESSLIST,http_headerstimeout:P.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:P.HTTP_KEEPALIVETIMEOUT,http_timeout:P.HTTP_TIMEOUT,http_port:P.HTTP_PORT,http_secureport:P.HTTP_SECUREPORT,http_mtls:P.HTTP_MTLS,http_mtls_user:P.HTTP_MTLS_USER,http_mtls_required:P.HTTP_MTLS_REQUIRED,http_maxheadersize:P.HTTP_MAXHEADERSIZE,http_threadrange:P.HTTP_THREADRANGE,customfunctions_processes:P.THREADS_COUNT,customfunctions_root:P.COMPONENTSROOT,localstudio_enabled:P.LOCALSTUDIO_ENABLED,logging_file:P.LOGGING_FILE,logging_level:P.LOGGING_LEVEL,logging_root:P.LOGGING_ROOT,logging_rotation_enabled:P.LOGGING_ROTATION_ENABLED,logging_rotation_compress:P.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:P.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:P.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:P.LOGGING_ROTATION_PATH,logging_stdstreams:P.LOGGING_STDSTREAMS,logging_auditlog:P.LOGGING_AUDITLOG,logging_auditretention:P.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:P.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:P.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:P.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:P.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:P.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:P.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:P.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls:P.OPERATIONSAPI_TLS,operationsapi_tls_certificate:P.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:P.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:P.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:P.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:P.ROOTPATH,operationsapi_sysinfo_network:P.OPERATIONSAPI_SYSINFO_NETWORK,operationsapi_sysinfo_disk:P.OPERATIONSAPI_SYSINFO_DISK,databases:P.DATABASES,storage_path:P.STORAGE_PATH,storage_maxtransactionqueuetime:P.STORAGE_MAXTRANSACTIONQUEUETIME,ignorescripts:P.IGNORE_SCRIPTS,mqtt_network_port:P.MQTT_NETWORK_PORT,mqtt_websocket:P.MQTT_WEBSOCKET,mqtt_network_secureport:P.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:P.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:P.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:P.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:P.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:P.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:P.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:P.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:P.AUTHENTICATION_CACHETTL,authentication_enablesessions:P.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:P.COMPONENTSROOT,replication:P.REPLICATION,replication_port:P.REPLICATION_PORT,replication_secureport:P.REPLICATION_SECUREPORT,replication_hostname:P.REPLICATION_HOSTNAME,replication_url:P.REPLICATION_URL,replication_routes:P.REPLICATION_ROUTES,tls:P.TLS,tls_certificate:P.TLS_CERTIFICATE,tls_privatekey:P.TLS_PRIVATEKEY,tls_certificateauthority:P.TLS_CERTIFICATEAUTHORITY,tls_ciphers:P.TLS_CIPHERS};for(let e in P){let t=P[e];Jw[t.toLowerCase()]=t}var xQ={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},kQ={csv_file_load:"csv_file_load",csv_data_load:ae.CSV_DATA_LOAD,csv_url_load:ae.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},FQ={CLUSTERING_PAYLOAD:"clustering_payload",DELEGATE_THREAD_RESPONSE:"delegate_thread_response",CLUSTERING:"clustering",SCHEMA:"schema",CLUSTER_STATUS:"cluster_status",JOB:"job",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",USER:"user",RESTART:"restart"},GQ={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},qQ={VERSION_DEFAULT:"2.2.0"},$Q={DEVELOPMENT:8192,DEFAULT:512},VQ={IDENTIFY:"identify",AUTHENTICATE:"authenticate",AUTHENTICATE_OK:"authenticated",AUTHENTICATE_FAIL:"authenticate_fail",CONNECTION:"connection",CONNECT:"connect",CATCHUP_REQUEST:"catchup_request",CATCHUP_RESPONSE:"catchup",CONFIRM_MSG:"confirm_msg",ERROR:"error",DISCONNECT:"disconnect",SCHEMA_UPDATE_REQ:"schema_update_request",SCHEMA_UPDATE_RES:"schema_update_response",RECONNECT_ATTEMPT:"reconnect_attempt",CONNECT_ERROR:"connect_error",MESSAGE:"msg",VERSION_MISMATCH:"version_mismatch",DIRECTION_CHANGE:"direction_change"},YQ={1e3:"SUCCESSFUL_SHUTDOWN",1001:"CLOSE_GOING_AWAY",1002:"CLOSE_PROTOCOL_ERROR",1003:"CLOSE_UNSUPPORTED",1005:"CLOSE_NO_STATUS",1006:"CLOSE_ABNORMAL",1007:"UNSUPPORTED_PAYLOAD",1008:"POLICY_VIOLATION",1009:"CLOSE_TOO_LARGE",1010:"MANDATORY_EXTENSION",1011:"SERVER_ERROR",1012:"SERVICE_RESTART",1013:"SERVER_BUSY",1014:"BAD_GATEWAY",1015:"HANDSHAKE_FAIL",4141:"LICENSE_LIMIT_REACHED"},KQ={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},Xw={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},WQ=Symbol("metadata"),jQ="__clustering__",QQ=Object.values(Xw),zQ=15984864e5,Zw={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},JQ=Qw.invert(Zw),XQ={GET_CLUSTER_STATUS:"GET_CLUSTER_STATUS",CLUSTER_STATUS_RESPONSE:"CLUSTER_STATUS_RESPONSE",ERROR_RESPONSE:"ERROR",ADD_USER:"ADD_USER",ALTER_USER:"ALTER_USER",DROP_USER:"DROP_USER",HDB_OPERATION:"HDB_OPERATION",ADD_NODE:"ADD_NODE",UPDATE_NODE:"UPDATE_NODE",REMOVE_NODE:"REMOVE_NODE",HDB_USERS_MSG:"HDB_USERS_MSG",HDB_WORKERS:"HDB_WORKERS",HDB_TRANSACTION:"HDB_TRANSACTION"},ZQ=111,ez=`\r
2
+ `,tz={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},rz=["*","%"],nz="unauthorized_access",sz="func_val",iz={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},oz={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},az={SHUTDOWN:"shutdown",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",SCHEMA:"schema",USER:"user",CLUSTER_STATUS_RESPONSE:"cluster_status_response",CLUSTER_STATUS_REQUEST:"cluster_status_request",METRICS:"metrics",GET_METRICS:"get_metrics",RESTART:"restart",START_JOB:"start_job",NATS_CONSUMER_UPDATE:"nats_consumer_update"},cz={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},lz={HTTP:"http"},uz={STOPPED:"stopped",ONLINE:"online"},dz="3.x.x",_z={SUCCESS:"success",FAILURE:"failure"},fz={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"};eC.exports={LOCAL_HARPERDB_OPERATIONS:tt,HDB_SUPPORT_ADDRESS:Vw,HDB_SUPPORT_URL:Kw,HDB_PRICING_URL:Hj,SUPPORT_HELP_MSG:xj,LICENSE_HELP_MSG:Ww,HDB_PROC_NAME:qw,HDB_PROC_DESCRIPTOR:ag,CLUSTERING_LEAF_PROC_DESCRIPTOR:ZE,CLUSTERING_HUB_PROC_DESCRIPTOR:XE,SYSTEM_SCHEMA_NAME:nQ,HASH_FOLDER_NAME:sQ,HDB_HOME_DIR_NAME:iQ,UPDATE_FILE_NAME:lQ,LICENSE_KEY_DIR_NAME:aQ,BOOT_PROPS_FILE_NAME:cQ,JOB_TYPE_ENUM:kQ,JOB_STATUS_ENUM:DQ,SYSTEM_TABLE_NAMES:yQ,SYSTEM_TABLE_HASH_ATTRIBUTES:OQ,OPERATIONS_ENUM:ae,VALID_S3_FILE_TYPES:PQ,S3_BUCKET_AUTH_KEYS:LQ,VALID_SQL_OPS_ENUM:MQ,GEO_CONVERSION_ENUM:vQ,HDB_SETTINGS_NAMES:zw,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:BQ,SERVICE_ACTIONS_ENUM:UQ,CLUSTER_MESSAGE_TYPE_ENUM:FQ,CLUSTER_CONNECTION_DIRECTION_ENUM:GQ,CLUSTER_EVENTS_DEFS_ENUM:VQ,PERIOD_REGEX:Yj,DOUBLE_PERIOD_REGEX:Kj,UNICODE_PERIOD:Wj,FORWARD_SLASH_REGEX:jj,UNICODE_FORWARD_SLASH:Qj,ESCAPED_FORWARD_SLASH_REGEX:zj,ESCAPED_PERIOD_REGEX:Jj,ESCAPED_DOUBLE_PERIOD_REGEX:Xj,REG_KEY_FILE_NAME:wQ,RESTART_TIMEOUT_MS:_Q,HDB_FILE_PERMISSIONS:fQ,DATABASES_DIR_NAME:hQ,LEGACY_DATABASES_DIR_NAME:mQ,TRANSACTIONS_DIR_NAME:pQ,LIMIT_COUNT_NAME:SQ,ID_ATTRIBUTE_STRING:TQ,INSERT_MODULE_ENUM:AQ,UPGRADE_JSON_FIELD_NAMES_ENUM:bQ,RESTART_CODE:uQ,RESTART_CODE_NUM:dQ,CLUSTER_OPERATIONS:Id,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:IQ,HDB_INTERNAL_SC_CHANNEL_PREFIX:On,INTERNAL_SC_CHANNELS:NQ,CLUSTERING_MESSAGE_TYPES:XQ,HDB_FILE_SUFFIX:oQ,BLOB_FOLDER_NAME:EQ,ORIGINATOR_SET_VALUE:ZQ,LICENSE_VALUES:qQ,RAM_ALLOCATION_ENUM:$Q,TIME_STAMP_NAMES_ENUM:Xw,TIME_STAMP_NAMES:QQ,PERMS_UPDATE_RELEASE_TIMESTAMP:zQ,SEARCH_NOT_FOUND_MESSAGE:kj,SEARCH_ATTRIBUTE_NOT_FOUND:Fj,LICENSE_ROLE_DENIED_RESPONSE:Gj,LICENSE_MAX_CONNS_REACHED:qj,BASIC_LICENSE_MAX_NON_CU_ROLES:Yw,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:Bj,VALUE_SEARCH_COMPARATORS:Zw,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:JQ,LICENSE_FILE_NAME:CQ,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:YQ,NEW_LINE:ez,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:Vj,MOMENT_DAYS_TAG:Zj,API_TURNOVER_SEC:eQ,LOOPBACK:$j,CODE_EXTENSION:JE,WILDCARD_SEARCH_VALUE:tQ,NODE_ERROR_CODES:KQ,JAVASCRIPT_EXTENSION:Gw,PERMS_CRUD_ENUM:tz,UNAUTHORIZED_PERMISSION_NAME:nz,SEARCH_WILDCARDS:rz,FUNC_VAL:sz,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:iz,JWT_ENUM:oz,CLUSTERING_FLAG:jQ,ITC_EVENT_TYPES:az,CUSTOM_FUNCTION_PROC_NAME:$w,CUSTOM_FUNCTION_PROC_DESCRIPTOR:zE,SERVICES:cz,THREAD_TYPES:lz,MEM_SETTING_KEY:rQ,HDB_RESTART_SCRIPT:Rj,PROCESS_DESCRIPTORS:Ij,SERVICE_SERVERS:Lj,SERVICE_SERVERS_CWD:og,PROCESS_DESCRIPTORS_VALIDATE:Dj,LAUNCH_SERVICE_SCRIPTS:Mj,LOG_LEVELS:Cj,PROCESS_NAME_ENV_PROP:gQ,LOG_NAMES:wj,PM2_PROCESS_STATUSES:uz,CONFIG_PARAM_MAP:Jw,CONFIG_PARAMS:P,HDB_CONFIG_FILE:Sj,HDB_DEFAULT_CONFIG_FILE:Tj,ROLE_TYPES_ENUM:Uj,BOOT_PROP_PARAMS:jw,INSTALL_PROMPTS:RQ,HDB_ROOT_DIR_NAME:gj,CLUSTERING_PROCESSES:Pj,FOREGROUND_PID_FILE:yj,PACKAGE_ROOT:ko,PRE_4_0_0_VERSION:dz,DATABASES_PARAM_CONFIG:xQ,METADATA_PROPERTY:WQ,AUTH_AUDIT_STATUS:_z,AUTH_AUDIT_TYPES:fz,HDB_PID_FILE:Oj,DEFAULT_DATABASE_NAME:Nj,LEGACY_CONFIG_PARAMS:HQ};Fw()});var qa=b((kge,nC)=>{"use strict";var tC=require("minimist");nC.exports=Ez;function Ez(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=rC(process.env),n=rC(tC(process.argv))):(r=process.env,n=tC(process.argv));let s={};for(let i=0,o=e.length;i<o;i++){let c=e[i];n[c]!==void 0?s[c]=n[c].toString().trim():r[c]!==void 0&&(s[c]=r[c].toString().trim())}return s}a(Ez,"assignCMDENVVariables");function rC(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(rC,"objKeysToLowerCase")});var Vi=b(oi=>{"use strict";global.Resource=oi.Resource=void 0;global.tables=oi.tables={};global.databases=oi.databases={};global.getUser=oi.getUser=void 0;global.server=oi.server={};global.contentTypes=oi.contentTypes=null;global.threads=oi.threads=[];global.logger={};oi._assignPackageExport=(e,t)=>{global[e]=oi[e]=t}});var V=b((SC,TC)=>{"use strict";var Yi=require("fs-extra"),{workerData:hz,threadId:mz,isMainThread:pz}=require("worker_threads"),ci=require("path"),aC=require("yaml"),cC=require("properties-reader"),Wt=M(),sC=qa(),Sz=require("os"),{PACKAGE_ROOT:dg}=M(),{_assignPackageExport:Tz}=Vi(),iC=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),dr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},lC={STDOUT:"stdOut",STDERR:"stdErr"},gz=ci.join(dg,"logs"),Rz=ci.join(dg,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),Az=1e4,cg,ai,ss,Nr,eh,wd,th,Fo,Cd;Cd===void 0&&uC();Object.assign(SC,{notify:hC,fatal:mC,error:rh,warn:pC,info:_C,debug:EC,trace:fC,setLogLevel:Dz,log_level:Nr,loggerWithTag:Oz,suppressLogging:Nz,initLogSettings:uC,logCustomLevel:wz,closeLogFile:_g,logsAtLevel:bz,getLogFilePath:()=>th,OUTPUTS:lC,AuthAuditLog:Mz});Tz("logger",TC.exports);var lg;function bz(e){return dr[Nr]<=dr[e]}a(bz,"logsAtLevel");function uC(e=!1){try{if(Cd===void 0||e){_g();let t=Cz(),r=sC(["ROOTPATH"]);try{Cd=cC(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!Yi.pathExistsSync(ci.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:Nr,config_log_path:wd,to_file:ai,to_stream:ss}=Pz(r.ROOTPATH?ci.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):Cd.get("settings_path")),eh=Wt.LOG_NAMES.HDB,th=ci.join(wd,eh),pz)try{require("segfault-handler").registerHandler(ci.join(wd,"crash.log"))}catch{}}}catch(t){if(Cd=void 0,t.code===Wt.NODE_ERROR_CODES.ENOENT||t.code===Wt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=sC(Object.keys(Wt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Wt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Wt.CONFIG_PARAMS.LOGGING_LEVEL){Nr=l;continue}if(c===Wt.CONFIG_PARAMS.LOGGING_STDSTREAMS){ss=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(ai=c),c===Wt.CONFIG_PARAMS.LOGGING_CONSOLE&&(cg=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=Lz();ai=ai===void 0?s:ai,ai=oC(ai),ss=ss===void 0?i:ss,ss=oC(ss),Nr=Nr===void 0?n:Nr,wd=gz,eh=Wt.LOG_NAMES.INSTALL,th=ci.join(wd,eh);return}throw rh("Error initializing log settings"),rh(t),t}process.env.DEV_MODE&&(ss=!0),yz()}a(uC,"initLogSettings");var Go=!0;function yz(){ai&&(process.stdout.write=function(e){return typeof e=="string"&&Go&&cg!==!1&&(ug(),e=e.toString(),e[e.length-1]===`
3
+ `&&(e=e.slice(0,-1)),Yi.appendFileSync(Fo,Bs("stdout",[e]))),iC.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&Go&&cg!==!1&&(ug(),e[e.length-1]===`
4
+ `&&(e=e.slice(0,-1)),Yi.appendFileSync(Fo,Bs("stderr",[e]))),iC.apply(process.stderr,arguments)})}a(yz,"stdioLogging");function Oz(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(hC,"notify"),fatal:n(mC,"fatal"),error:n(rh,"error"),warn:n(pC,"warn"),info:n(_C,"info"),debug:n(EC,"debug"),trace:n(fC,"trace")};function n(s,i){return!t||dr[Nr]<=dr[i]?function(...o){return s(r,...o)}:null}}a(Oz,"loggerWithTag");function Nz(e){try{Go=!1,e()}finally{Go=!0}}a(Nz,"suppressLogging");var Iz=hz?.name?.replace(/ /g,"-")||"main";function Bs(e,t){let r=new Date(Date.now()).toISOString(),n="",s=t.length,i=s-1,o=[e],c=0,l;for(typeof t[0]=="object"&&(t[0]?.tagName?(o.push(t[0]?.tagName),c++):t[0]?.serviceName&&(l=t[0]?.serviceName,c++)),o.unshift(l||Iz+"/"+mz);c<s;c++){let d=t[c];if(d instanceof Error&&d.stack)n+=d.stack,Object.keys(d).length>0&&(n+=`
5
+ `+JSON.stringify(d)),d.cause&&(t[c--]=d.cause,d&&(n+=`
6
+ Caused by:`));else if(typeof d=="object")try{n+=JSON.stringify(d)}catch{n+="Object ["+Object.keys(d)+"]"}else n+=d;c<i&&(n+=" ")}return`${r} [${o.join("] [")}]: ${n}
7
+ `}a(Bs,"createLogRecord");function Dd(e){if(ai){if(dC(e),ss){Go=!1;try{process.stdout.write(e)}finally{Go=!0}}}else ss&&process.stdout.write(e)}a(Dd,"logStdOut");function nh(e){if(ai){if(dC(e),ss){Go=!1;try{process.stderr.write(e)}finally{Go=!0}}}else ss&&process.stderr.write(e)}a(nh,"logStdErr");function dC(e){ug(),Fo?Yi.appendFileSync(Fo,e):lg||console.log(e)}a(dC,"logToFile");function _g(){try{Yi.closeSync(Fo)}catch{}Fo=null}a(_g,"closeLogFile");function ug(){if(!Fo){try{Fo=Yi.openSync(th,"a")}catch(e){lg||(lg=!0,console.error(e))}setTimeout(()=>{_g()},Az).unref()}}a(ug,"openLogFile");function _C(...e){dr[Nr]<=dr.info&&Dd(Bs("info",e))}a(_C,"info");function fC(...e){dr[Nr]<=dr.trace&&Dd(Bs("trace",e))}a(fC,"trace");function rh(...e){dr[Nr]<=dr.error&&nh(Bs("error",e))}a(rh,"error");function EC(...e){dr[Nr]<=dr.debug&&Dd(Bs("debug",e))}a(EC,"debug");function hC(...e){dr[Nr]<=dr.notify&&Dd(Bs("notify",e))}a(hC,"notify");function mC(...e){dr[Nr]<=dr.fatal&&nh(Bs("fatal",e))}a(mC,"fatal");function pC(...e){dr[Nr]<=dr.warn&&nh(Bs("warn",e))}a(pC,"warn");function wz(e,t,...r){t===lC.STDERR?nh(Bs(e,r)):Dd(Bs(e,r))}a(wz,"logCustomLevel");function Cz(){let e;try{e=Sz.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=ci.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return Yi.existsSync(t)||(t=ci.join(dg,"utility/hdb_boot_properties.file")),t}a(Cz,"getPropsFilePath");function Dz(e){Nr=e}a(Dz,"setLogLevel");function oC(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(oC,"autoCastBoolean");function Pz(e){try{if(e.includes("config/settings.js")){let o=cC(e);return{level:o.get(Wt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:ci.dirname(o.get(Wt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=aC.parseDocument(Yi.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),n=t.getIn(["logging","root"]),s=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:n,to_file:s,to_stream:i}}catch(t){if(t.code===Wt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(Pz,"getLogConfig");function Lz(){try{let e=aC.parseDocument(Yi.readFileSync(Rz,"utf8")),t=e.getIn(["logging","level"]),r=e.getIn(["logging","file"]),n=e.getIn(["logging","stdStreams"]);return{default_level:t,default_to_file:r,default_to_stream:n}}catch(e){console.error("Error accessing default config file for logging"),console.error(e)}}a(Lz,"getDefaultConfig");function Mz(e,t,r,n,s,i){this.username=e,this.status=t,this.type=r,this.originating_ip=n,this.request_method=s,this.path=i}a(Mz,"AuthAuditLog")});var fg=b(($ge,gC)=>{"use strict";var Uz=require("util"),vz=require("path"),Bz=require("child_process"),Hz=Uz.promisify(Bz.execFile),xz=1e3*1e3*10;gC.exports={findPs:kz};async function kz(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await Hz("ps",["wwxo",`pid,${r}`],{maxBuffer:xz});for(let s of n.trim().split(`
8
+ `).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:vz.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(kz,"findPs")});var Bt=b((Yge,AC)=>{"use strict";var Fz="__dbis__",Gz="__txns__",qz="__environment_name__",$z="__dbi_defintion__",Vz={EQUALS:"equals",STARTS_WITH:"startsWith",_STARTS_WITH:"starts_with",ENDS_WITH:"endsWith",_ENDS_WITH:"ends_with",CONTAINS:"contains",SEARCH_ALL:"searchAll",SEARCH_ALL_TO_MAP:"searchAllToMap",BATCH_SEARCH_BY_HASH:"batchSearchByHash",BATCH_SEARCH_BY_HASH_TO_MAP:"batchSearchByHashToMap",GREATER_THAN:"greaterThan",_GREATER_THAN:"greater_than",GREATER_THAN_EQUAL:"greaterThanEqual",_GREATER_THAN_EQUAL:"greater_than_equal",LESS_THAN:"lessThan",_LESS_THAN:"less_than",LESS_THAN_EQUAL:"lessThanEqual",_LESS_THAN_EQUAL:"less_than_equal",BETWEEN:"between"},Yz=["__createdtime__","__updatedtime__"],Kz="\uFFFF",RC={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},Wz=Object.values(RC);AC.exports={AUDIT_STORE_NAME:Gz,INTERNAL_DBIS_NAME:Fz,DBI_DEFINITION_NAME:$z,SEARCH_TYPES:Vz,TIMESTAMP_NAMES:Yz,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:qz,TRANSACTIONS_DBI_NAMES_ENUM:RC,TRANSACTIONS_DBIS:Wz,OVERFLOW_MARKER:Kz}});var Nn=b((Kge,PC)=>{"use strict";var bC=M(),yC=Bt(),OC={CONTINUE:100,OK:200,CREATED:201,BAD_REQUEST:400,UNAUTHORIZED:401,FORBIDDEN:403,NOT_FOUND:404,METHOD_NOT_ALLOWED:405,REQUEST_TIMEOUT:408,CONFLICT:409,TOO_MANY_REQUESTS:429,INTERNAL_SERVER_ERROR:500,NOT_IMPLEMENTED:501,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504,HTTP_VERSION_NOT_SUPPORTED:505,INSUFFICIENT_STORAGE:507,NETWORK_AUTHENTICATION_REQUIRED:511},NC=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),IC={500:NC("There was an error processing your request."),400:"Invalid request"},jz=IC[OC.INTERNAL_SERVER_ERROR],Qz={OP_NOT_SUPPORTED_FOR_FS:e=>`${e} is not available for this instance because it uses the File System data store.`,MISSING_VALUE:e=>`${e} is missing.`,INVALID_VALUE:e=>`${e} is invalid.`,NOT_FOUND:e=>`${e} not found.`},zz={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},Jz={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:e=>`There was an error downloading '${e}'.`,INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,INVALID_FILE_EXT_ERR:e=>`Error selecting correct parser - valid file type not found in json - ${e}`,MAX_FILE_SIZE_ERR:(e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:e=>`There was an error downloading '${e}' from AWS.`,WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},Xz={BASE_PATH_REQUIRED:"base_path is required",DESTINATION_PATH_REQUIRED:"destination_path is required",ENV_NAME_REQUIRED:"env_name is required",INVALID_BASE_PATH:"invalid base_path",INVALID_DESTINATION_PATH:"invalid destination_path",INVALID_ENVIRONMENT:"invalid environment",ENV_REQUIRED:"env is required",DBI_NAME_REQUIRED:"dbi_name is required",DBI_DOES_NOT_EXIST:"dbi does not exist",HASH_ATTRIBUTE_REQUIRED:"hash_attribute is required",ID_REQUIRED:"id is required",IDS_REQUIRED:"ids is required",IDS_MUST_BE_ITERABLE:"ids must be iterable",FETCH_ATTRIBUTES_REQUIRED:"fetch_attributes is required",FETCH_ATTRIBUTES_MUST_BE_ARRAY:"fetch_attributes must be an array",ATTRIBUTE_REQUIRED:"attribute is required",SEARCH_VALUE_REQUIRED:"search_value is required",SEARCH_VALUE_TOO_LARGE:"search_value is too long",WRITE_ATTRIBUTES_REQUIRED:"write_attributes is required",WRITE_ATTRIBUTES_MUST_BE_ARRAY:"write_attributes must be an array",RECORDS_REQUIRED:"records is required",RECORDS_MUST_BE_ARRAY:"records must be an array",CANNOT_CREATE_INTERNAL_DBIS_NAME:`cannot create a dbi named ${yC.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${yC.INTERNAL_DBIS_NAME}`,START_VALUE_REQUIRED:"start_value is required",END_VALUE_REQUIRED:"end_value is required",CANNOT_COMPARE_STRING_TO_NUMERIC_KEYS:"cannot compare a string to numeric keys",END_VALUE_MUST_BE_GREATER_THAN_START_VALUE:"end_value must be greater than or equal to start_value",UNKNOWN_SEARCH_TYPE:"unknown search type",CANNOT_DROP_TABLE_HASH_ATTRIBUTE:"cannot drop a table's hash attribute"},Zz={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${bC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${bC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},wC={GENERIC_AUTH_FAIL:"Login failed",USER_INACTIVE:"Cannot complete request: User is inactive",INVALID_TOKEN:"invalid token",NO_ENCRYPTION_KEYS:"unable to generate JWT as there are no encryption keys. please contact your administrator",INVALID_CREDENTIALS:"invalid credentials",PASSWORD_REQUIRED:"password is required",USERNAME_REQUIRED:"username is required",REFRESH_TOKEN_REQUIRED:"refresh_token is required",INVALID_AUTH_OBJECT:"invalid auth_object",INVALID_BODY:"invalid body",TOKEN_EXPIRED:"token expired",REFRESH_TOKEN_SAVE_FAILED:"unable to store refresh_token"},e2={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:e=>`Operation '${e}' is restricted to 'super_user' roles`,OP_NOT_FOUND:e=>`Operation '${e}' not found`,SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:(e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,USER_HAS_NO_PERMS:e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},t2={ATTR_PERM_MISSING:(e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:(e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:e=>`Invalid attribute '${e}' in 'attribute_permissions'`,INVALID_PERM_KEY:e=>`Invalid table permission key value '${e}'`,INVALID_ATTR_PERM_KEY:e=>`Invalid attribute permission key value '${e}'`,INVALID_ROLE_JSON_KEYS:e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,MISMATCHED_TABLE_ATTR_PERMS:e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:e=>`A role with name '${e}' already exists`,ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:e=>`Your role does not have permission to view database metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:e=>`Value for '${e}' permission must be a boolean`,STRUCTURE_USER_ROLE_TYPE_ERROR:e=>`Value for '${e}' permission must be a boolean or Array`,SU_CU_ROLE_NO_PERMS_ALLOWED:e=>`Roles with '${e}' set to true cannot have other permissions set.`,SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:e=>`Missing table ${e.toUpperCase()} permission`,TABLE_PERM_NOT_BOOLEAN:e=>`Table ${e.toUpperCase()} permission must be a boolean`},r2={ATTR_NOT_FOUND:(e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,ATTR_EXISTS_ERR:(e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:e=>`Invalid table ${JSON.stringify(e)}`,SCHEMA_NOT_FOUND:e=>`database '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`database '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in '${e}'`,SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},n2={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},s2={ALTER_USER_DUP_ROLES:e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,ALTER_USER_ROLE_NOT_FOUND:e=>`Update failed. Requested '${e}' role not found.`,DUP_ROLES_FOUND:e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,ROLE_NAME_NOT_FOUND:e=>`${e} role not found`,USER_ALREADY_EXISTS:e=>`User ${e} already exists`,USER_NOT_EXIST:e=>`User ${e} does not exist`},CC={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`},DC={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:e=>`ITC server received invalid event type: ${e}`},i2={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},o2={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},a2={...wC,...Jz,...Qz,...e2,...t2,...r2,...n2,...s2,...Zz,...CC,...DC,...i2,...o2,...zz};PC.exports={CHECK_LOGS_WRAPPER:NC,HDB_ERROR_MSGS:a2,DEFAULT_ERROR_MSGS:IC,DEFAULT_ERROR_RESP:jz,HTTP_STATUS_CODES:OC,LMDB_ERRORS_ENUM:Xz,AUTHENTICATION_ERROR_MSGS:wC,VALIDATION_ERROR_MSGS:CC,ITC_ERRORS:DC}});var fe=b((jge,UC)=>{"use strict";var Rl=Nn(),c2=V(),l2=M(),sh=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,LC),this.statusCode=n||Rl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Rl.DEFAULT_ERROR_MSGS[n]?Rl.DEFAULT_ERROR_MSGS[n]:Rl.DEFAULT_ERROR_MSGS[Rl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&c2[s](i)}},Eg=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},hg=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function LC(e,t,r,n=l2.LOG_LEVELS.ERROR,s=null,i=!1){if(MC(e))return e;let o=new sh(e,t,r,n,s);return i&&delete o.stack,o}a(LC,"handleHDBError");function MC(e){return e.__proto__.constructor.name===sh.name}a(MC,"isHDBError");UC.exports={isHDBError:MC,handleHDBError:LC,ClientError:Eg,ServerError:hg,hdb_errors:Rl}});var gt=b((zge,GC)=>{"use strict";var vd=M(),u2=J(),rn=te(),Bd=require("path"),d2=require("minimist"),vC=require("fs-extra"),BC=require("lodash");rn.initSync();var{CONFIG_PARAMS:qo,DATABASES_PARAM_CONFIG:Pd,SYSTEM_SCHEMA_NAME:ih}=vd,Ld,Md,Ud;function HC(){if(Ld!==void 0)return Ld;if(rn.getHdbBasePath()!==void 0)return Ld=rn.get(qo.STORAGE_PATH)||Bd.join(rn.getHdbBasePath(),vd.DATABASES_DIR_NAME),Ld}a(HC,"getBaseSchemaPath");function xC(){if(Md!==void 0)return Md;if(rn.getHdbBasePath()!==void 0)return Md=FC(ih),Md}a(xC,"getSystemSchemaPath");function kC(){if(Ud!==void 0)return Ud;if(rn.getHdbBasePath()!==void 0)return Ud=rn.get(vd.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Bd.join(rn.getHdbBasePath(),vd.TRANSACTIONS_DIR_NAME),Ud}a(kC,"getTransactionAuditStoreBasePath");function _2(e,t){let r=rn.get(qo.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Bd.join(kC(),e.toString())}a(_2,"getTransactionAuditStorePath");function FC(e,t){e=e.toString(),t=t&&t.toString();let r=rn.get(vd.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Bd.join(HC(),e)}a(FC,"getSchemaPath");function f2(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,d2(process.argv));let n=r[qo.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!u2.isObject(n))throw o;i=n}for(let o of i){let c=o[ih];if(!c)continue;let l=rn.get(qo.DATABASES);l=l??{};let d=c?.tables?.[t]?.[Pd.PATH];if(d)return BC.set(l,[ih,Pd.TABLES,t,Pd.PATH],d),rn.setProperty(qo.DATABASES,l),d;let u=c?.[Pd.PATH];if(u)return BC.set(l,[ih,Pd.PATH],u),rn.setProperty(qo.DATABASES,l),u}}let s=r[qo.STORAGE_PATH.toUpperCase()];if(s){if(!vC.pathExistsSync(s))throw new Error(s+" does not exist");let i=Bd.join(s,e);return vC.mkdirsSync(i),rn.setProperty(qo.STORAGE_PATH,s),i}return xC()}a(f2,"initSystemSchemaPaths");function E2(){Ld=void 0,Md=void 0,Ud=void 0}a(E2,"resetPaths");GC.exports={getBaseSchemaPath:HC,getSystemSchemaPath:xC,getTransactionAuditStorePath:_2,getTransactionAuditStoreBasePath:kC,getSchemaPath:FC,initSystemSchemaPaths:f2,resetPaths:E2}});var nn=b((eRe,KC)=>{"use strict";var h2=Nn().LMDB_ERRORS_ENUM,Xge=require("lmdb"),m2=Bt(),Zge=require("buffer").Buffer,{OVERFLOW_MARKER:qC,MAX_SEARCH_KEY_LENGTH:oh}=m2,$C=["number","string","symbol","boolean","bigint"];function p2(e){if(e=e?.primaryStore||e,!e)throw new Error(h2.ENV_REQUIRED)}a(p2,"validateEnv");function S2(e){if(e==null)return null;let t;try{t=typeof e=="object"?JSON.stringify(e):e.toString()}catch{t=e.toString()}return t}a(S2,"stringifyData");function T2(e){return e instanceof Date?e.valueOf():e}a(T2,"convertKeyValueToWrite");function g2(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if($C.includes(typeof e))return e.length>oh?[e.slice(0,oh)+qC]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if($C.includes(typeof i))i.length>oh?r.push(i.slice(0,oh)+qC):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(g2,"getIndexedValues");var ah=0,VC=0;function YC(){VC=Date.now()-performance.now()}a(YC,"adjustStartTime");YC();var R2=6e4;setInterval(YC,R2).unref();function A2(){let e=performance.now()+VC;return e>ah?(ah=e,e):(ah+=488e-6,ah)}a(A2,"getNextMonotonicTime");KC.exports={validateEnv:p2,stringifyData:S2,convertKeyValueToWrite:T2,getNextMonotonicTime:A2,getIndexedValues:g2}});var Hd=b((rRe,WC)=>{"use strict";var b2=M().OPERATIONS_ENUM,mg=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=b2.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};WC.exports=mg});var xd=b((iRe,JC)=>{"use strict";var sRe=Hd(),ch=M(),pg=J(),jC=V(),y2=require("uuid"),{handleHDBError:lh,hdb_errors:O2}=fe(),{HDB_ERROR_MSGS:uh,HTTP_STATUS_CODES:dh}=O2;JC.exports=QC;function QC(e,t,r){for(let s=0;s<t.length;s++)zC(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];N2(i,r,e.operation)}}a(QC,"processRows");QC.validateAttribute=zC;function zC(e){if(Buffer.byteLength(String(e))>ch.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw lh(new Error,uh.ATTR_NAME_LENGTH_ERR(e),dh.BAD_REQUEST,void 0,void 0,!0);if(pg.isEmptyOrZeroLength(e)||pg.isEmpty(e.trim()))throw lh(new Error,uh.ATTR_NAME_NULLISH_ERR,dh.BAD_REQUEST,void 0,void 0,!0)}a(zC,"validateAttribute");function N2(e,t,r){if(!e.hasOwnProperty(t)||pg.isEmptyOrZeroLength(e[t])){if(r===ch.OPERATIONS_ENUM.INSERT||r===ch.OPERATIONS_ENUM.UPSERT){e[t]=y2.v4();return}throw jC.error("Update transaction aborted due to record with no hash value:",e),lh(new Error,uh.RECORD_MISSING_HASH_ERR,dh.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>ch.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw jC.error(e),lh(new Error,uh.HASH_VAL_LENGTH_ERR,dh.BAD_REQUEST,void 0,void 0,!0)}a(N2,"validateHash")});var XC,In,Sg,Al=De(()=>{XC=require("events"),In=class extends XC.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new Sg;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},Sg=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var $a={};et($a,{server:()=>st});var ZC,st,$r=De(()=>{ZC=v(Vi()),st={};(0,ZC._assignPackageExport)("server",st)});var Rg={};et(Rg,{loadGQLSchema:()=>C2,start:()=>gg,startOnMainThread:()=>w2});function gg({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:d,StringValueNode:u}=await import("graphql"),_=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let R of _.definitions)switch(R.kind){case l.OBJECT_TYPE_DEFINITION:let x=function(q){if(q.kind==="NonNullType"){let X=x(q.type);return X.nullable=!1,X}if(q.kind==="ListType")return{type:"array",elements:x(q.type)};let _e={type:q.name?.value};return Object.defineProperty(_e,"location",{value:q.loc.startToken}),_e};a(x,"getProperty");let p=R.name.value,y=[],O={table:null,database:null,properties:y};E.set(p,O);for(let q of R.directives){if(q.name.value==="table"){for(let _e of q.arguments)O[_e.name.value]=_e.value.value;O.schema&&(O.database=O.schema),O.table||(O.table=p),O.audit&&(O.audit=O.audit!=="false"),O.attributes=O.properties,f.push(O)}if(q.name.value==="sealed"&&(O.sealed=!0),q.name.value==="splitSegments"&&(O.splitSegments=!0),q.name.value==="replicate"&&(O.replicate=!0),q.name.value==="export"){O.export=!0;for(let _e of q.arguments)typeof O.export!="object"&&(O.export={}),O.export[_e.name.value]=_e.value.value}}let B=!1,W={};for(let q of R.fields){let z=x(q.type);z.name=q.name.value,y.push(z),W[z.name]=void 0;for(let _e of q.directives){let X=_e.name.value;if(X==="primaryKey")B?console.warn("Can not define two attributes as a primary key at",_e.loc):(z.isPrimaryKey=!0,B=!0);else if(X==="indexed")z.indexed=!0;else if(X==="computed"){for(let ue of _e.arguments||[])if(ue.name.value==="from"){let j=ue.value.value;z.computed={from:S(j,ue,W)},z.version==null&&(z.version=j)}else ue.name.value==="version"&&(z.version=ue.value.value);z.computed=z.computed||!0}else if(X==="relationship"){let ue={};for(let j of _e.arguments)ue[j.name.value]=j.value.value;z.relationship=ue}else if(X==="createdTime")z.assignCreatedTime=!0;else if(X==="updatedTime")z.assignUpdatedTime=!0;else if(X==="expiresAt")z.expiresAt=!0;else if(X==="allow"){let ue=z.authorizedRoles=[];for(let j of _e.arguments)j.name.value==="role"&&ue.push(j.value.value)}else server.knownGraphQLDirectives.includes(X)&&console.warn(`@${X} is an unknown directive, at`,_e.loc)}}O.type=p,p==="Query"&&(h=O)}function T(R){let p=E.get(R.type);p?(Object.defineProperty(R,"properties",{value:p.properties}),Object.defineProperty(R,"definition",{value:p})):R.type==="array"?T(R.elements):I2.includes(R.type)||(0,tD.getWorkerIndex)()===0&&console.error(`The type ${R.type} is unknown at line ${R.location.line}, column ${R.location.column}, in ${s}`)}a(T,"connectPropertyType");for(let R of E.values())for(let p of R.properties)T(p);for(let R of f)R.tableClass=e(R),R.export&&(R.export.name===""?i.set((0,Tg.dirname)(n),R.tableClass):i.set((0,Tg.dirname)(n)+"/"+(R.export.name||R.type),R.tableClass,R.export));function S(R,p,y){return new eD.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${R}; } } } } computed;`,{filename:s,lineOffset:p.loc.startToken.line-1,columnOffset:p.loc.startToken.column}).runInThisContext()(y)}a(S,"createComputedFrom")}}var Tg,eD,tD,I2,w2,C2,rD=De(()=>{Tg=require("path"),eD=require("node:vm");Le();tD=v(it()),I2=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(gg,"start");w2=gg,C2=gg({ensureTable:Et}).handleFile});async function _h(e){let t=(0,iD.pathToFileURL)(e).toString();return D2?(kd||(kd=P2(M2)),(await(await kd).import(t)).namespace):import(t)}async function P2(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),kd=new Compartment({console,Math,Date,fetch:L2,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,sD.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Ir,tables:wn,databases:We})}};let n=await(0,nD.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),kd}function L2(e,t){let r=typeof e=="string"||e.url;if(new URL(r).protocol!="https")throw new Error("Only https is allowed in fetch");return fetch(e,t)}function M2(){return{Resource:Ir,tables:wn}}var nD,sD,iD,D2,kd,Ag=De(()=>{Hs();Le();nD=require("fs/promises"),sD=require("path"),iD=require("url"),D2=!1;a(_h,"secureImport");a(P2,"getCompartment");a(L2,"secureOnlyFetch");a(M2,"getGlobalVars")});var yg={};et(yg,{handleFile:()=>U2});async function U2(e,t,r,n){let s=new Map,i=await _h(r);c(i.default)&&n.set((0,bg.dirname)(t),i.default),o(i,(0,bg.dirname)(t));function o(l,d){for(let u in l){let _=l[u];c(_)?n.set(d+"/"+u,_):typeof _=="object"&&o(_,d+"/"+u)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var bg,oD=De(()=>{Ag();bg=require("path");a(U2,"handleFile")});var Ng={};et(Ng,{start:()=>v2});function v2({resources:e}){e.set("login",Og),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Og,aD=De(()=>{Hs();a(v2,"start");Og=class extends Ir{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var ED={};et(ED,{parse:()=>wg,streamAsJSON:()=>Fd,stringify:()=>Va});function Fd(e){return new Ig({value:e})}function cD(e){return console.error(e),JSON.stringify(e.toString())}function lD(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Va(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===_D)return fD(e);if(t.resolution)return t.resolution.then(()=>Va(e));throw t}}function fD(e){let t=typeof e;if(t==="object"){if(e===null)return"null";e.toJSON&&(e=e.toJSON());let r;if(Array.isArray(e)){r="[";for(let n=0;n<e.length;n++)n>0&&(r+=","),r+=fD(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Va(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function wg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),x2.test(e)?B2.parse(e):JSON.parse(e)):null}var uD,dD,B2,H2,_D,Ig,x2,Cg=De(()=>{uD=require("stream"),dD=v(require("json-bigint-fixes")),B2=(0,dD.default)({useNativeBigInt:!0}),H2=1e4,_D={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw _D};a(Fd,"streamAsJSON");Ig=class extends uD.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:()=>({done:!0})},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:()=>({done:!0})}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),cD)}catch(s){yield cD(s)}else yield Va(t)}else yield Va(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);lD(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>H2?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return lD(this.readIterator(t.childIterator),n=>{if(n)return t.childIterator=null,this.readIterator(t)});do{let n=t.next();if(n.done)return!0;if(r=n.value,r==null)r="null";else{if(r.then)return this.flush(),Promise.resolve(r).then(s=>{if(s&&typeof s.return=="function")return t.childIterator=s,this.readIterator(t);if(this.push(s+""))return this.readIterator(t)});if(typeof r.return=="function")return t.childIterator=r,this.readIterator(t)}}while(this.push(r))}catch(r){return console.error(r),this.push(r.toString()),this.push(null),!0}}_destroy(t,r){for(let n of this.activeIterators)t?n.throw(t):n.return();r()}};a(cD,"handleError");a(lD,"when");a(Va,"stringify");a(fD,"jsStringify");x2=/[[,:]\s*-?\d{16,}/;a(wg,"parse")});var ID=b((RRe,ND)=>{"use strict";var Dg=require("recursive-iterator"),k2=require("alasql"),Pg=require("clone"),hD=J(),{handleHDBError:mD,hdb_errors:F2}=fe(),{HDB_ERROR_MSGS:pD,HTTP_STATUS_CODES:SD}=F2,{getDatabases:G2}=(Le(),oe(lt)),q2=["DISTINCT_ARRAY"],TD=Symbol("validateTables"),Lg=Symbol("validateTable"),gRe=Symbol("getAllColumns"),gD=Symbol("validateAllColumns"),fh=Symbol("findColumn"),RD=Symbol("validateOrderBy"),Gd=Symbol("validateSegment"),Mg=Symbol("validateColumn"),AD=Symbol("setColumnsForTable"),bD=Symbol("checkColumnsForAsterisk"),yD=Symbol("validateGroupBy"),OD=Symbol("hasColumns"),Ug=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[TD](),this[bD](),this[gD]()}[TD](){if(this[OD]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Lg](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Lg](t.table)})}}[OD](){let t=!1,r=new Dg(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Lg](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=G2();if(!r[t.databaseid])throw mD(new Error,pD.SCHEMA_NOT_FOUND(t.databaseid),SD.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw mD(new Error,pD.TABLE_NOT_FOUND(t.databaseid,t.tableid),SD.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Pg(s);i.table=Pg(t),this.attributes.push(i)})}[fh](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[bD](){let t=new Dg(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[AD](r.tableid)}[AD](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new k2.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[gD](){this[Gd](this.statement.columns,!1),this[Gd](this.statement.joins,!1),this[Gd](this.statement.where,!1),this[yD](this.statement.group,!1),this[Gd](this.statement.order,!0)}[Gd](t,r){if(!t)return;let n=new Dg(t),s=[];for(let{node:i,path:o}of n)!hD.isEmpty(i)&&!hD.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[RD](i):s.push(this[Mg](i)));return s}[yD](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&q2.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Pg(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[fh](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[fh](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[RD](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[Mg](t)}[Mg](t){let r=this[fh](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};ND.exports=Ug});var CD=b((bRe,wD)=>{"use strict";var vg=class{static{a(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};wD.exports=vg});var PD=b((ORe,DD)=>{"use strict";var Bg=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};DD.exports=Bg});var vD={};et(vD,{HAS_EXPIRATION:()=>mh,HAS_RESIDENCY_ID:()=>Vg,HAS_STRUCTURE_UPDATE:()=>ph,LAST_TIMESTAMP_PLACEHOLDER:()=>Yd,LOCAL_TIMESTAMP:()=>$2,METADATA:()=>qd,NO_TIMESTAMP:()=>xg,PENDING_LOCAL_TIME:()=>Yg,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>$g,RecordEncoder:()=>qg,TIMESTAMP_ASSIGN_LAST:()=>Y2,TIMESTAMP_ASSIGN_NEW:()=>MD,TIMESTAMP_ASSIGN_PREVIOUS:()=>UD,TIMESTAMP_PLACEHOLDER:()=>Eh,TIMESTAMP_RECORD_PREVIOUS:()=>kg,getUpdateRecord:()=>Kg,handleLocalTimeForGets:()=>Sh});function W2(){return Vd[0]=Vd[0]^64,V2.getFloat64(0)}function Sh(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,d=l?.[qd];return d>=0&&(c.metadataFlags=d,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[qd]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,d=l[qd];return d>=0&&(c.metadataFlags=d,c.localTime=l.localTime,c.value=l.value,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Ya.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<Ya.length;l++){let d=Ya[l].deref();(!d||d.isDone||d.isCommitted)&&Ya.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Kg(e,t,r){return function(n,s,i,o,c=-1,l,d,u="put",_,E){_||l==null?bl=i?.localTime?kg|UD:xg:bl=l?i?.localTime?kg|16384:MD|16384:xg;let f=d?.expiresAt;if(f>=0&&(c|=mh),$d=c,Fg=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:bl>0},T,S=0;try{let R=i?.residencyId,p=d?.residencyId;p&&(Gg=p,$d|=Vg,S|=Ka),R!==p&&(S|=Wa,R||(R=0)),c&mh&&(S|=Wd),d?.originatingOperation&&(S|=Kd),_&&(h.ifVersion=T=i?.version??null);let y=e.put(n,s,h);if(l){let O=d?.user?.username;if(E&&(hh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(S|=ph,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let B=i?.localTime,x=r.get(B);if(x){let W=Ht(x).previousLocalTime;return r.put(B,yl(o,t,n,W,d?.nodeId??server.replication.getThisNodeId(r)??0,O,u,hh,S,p,R,f),{ifVersion:T}),y}}r.put(Yd,yl(o,t,n,i?.localTime?1:0,d?.nodeId??server.replication?.getThisNodeId(r)??0,O,u,hh,S,p,R,f,d?.originatingOperation),{append:u!=="invalidate",instructedWrite:!0,ifVersion:T})}return y}catch(R){throw R.message+=" id: "+n+" options: "+h,R}}}var LD,Hg,Eh,Yd,$g,$2,qd,Vd,V2,xg,MD,Y2,UD,kg,mh,Vg,Yg,ph,K2,hh,bl,$d,Fg,Gg,qg,Ya,Ol=De(()=>{LD=require("msgpackr");Ki();Hg=v(V()),Eh=new Uint8Array([1,1,1,1,4,64,0,0]),Yd=new Uint8Array([1,1,1,1,1,0,0,0]),$g=new Uint8Array([1,1,1,1,3,64,0,0]),$2=Symbol("local-timestamp"),qd=Symbol("metadata"),Vd=new Uint8Array(8),V2=new DataView(Vd.buffer,0,8),xg=0,MD=0,Y2=1,UD=3,kg=4,mh=16,Vg=32,Yg=1,ph=256,bl=0,$d=-1,Fg=-1,Gg=0,qg=class extends LD.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(bl||$d>=0){let o=0,c=bl;c&&(o+=8,bl=0);let l=$d,d=Fg,u=Gg;l>=0&&(o+=2,$d=-1,d>=0&&(o+=8,Fg=-1),u&&(o+=4,Gg=0));let _=K2=r.call(this,s,i|2048|o);hh=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(Eh[4]=c,Eh[5]=c>>8,_.set(Eh,E),E+=8),l>=0&&(_[E++]=l&31,_[E++]=l>>5,d>=0&&((_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(E,d),E+=8),u&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setUint32(E,u)),_}else return r.call(this,s,i)};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(Vd,0,c),c+=8;else for(let E=0;E<8;E++)Vd[E]=t[c++];l=W2(),i=t[c]}let d,u;i<32&&(o=i|t[c+1]<<5,c+=2,o&mh&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&Vg&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let _=r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c);return{localTime:l,value:_,[qd]:o,expiresAt:d,residencyId:u}}return r?.valueAsBuffer?t:super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(W2,"getTimestamp");a(Sh,"handleLocalTimeForGets");Ya=[];setInterval(()=>{for(let e=0;e<Ya.length;e++){let t=Ya[e].deref();!t||t.isDone||t.isCommitted?Ya.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Hg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Hg.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(Kg,"getUpdateRecord")});var jd=b((DRe,HD)=>{"use strict";var BD=te(),j2=M(),{RecordEncoder:Q2}=(Ol(),oe(vD)),CRe=require("fs");BD.initSync();var z2=BD.get(j2.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Wg=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=z2&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:Q2})}};HD.exports=Wg});var Qd=b((LRe,xD)=>{"use strict";var Cn=te(),is=M();Cn.initSync();var Th=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Cn.get(is.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Cn.get(is.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Cn.get(is.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Cn.get(is.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Cn.get(is.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Cn.get(is.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Cn.get(is.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Cn.get(is.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Cn.get(is.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Cn.get(is.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Cn.get(is.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Cn.get(is.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};xD.exports=Th;Th.MAX_DBS=1e4});var ht=b((URe,jD)=>{"use strict";var Qg=require("lmdb"),xs=require("fs-extra"),Dn=require("path"),gh=nn(),GD=V(),sn=Nn().LMDB_ERRORS_ENUM,Rh=PD(),zg=jd(),qD=Qd(),$o=Bt(),kD=M(),{table:J2,resetDatabases:X2}=(Le(),oe(lt)),FD=te(),ks=$o.INTERNAL_DBIS_NAME,$D=$o.DBI_DEFINITION_NAME,Z2="data.mdb",e4="lock.mdb",zd=".mdb",t4="-lock",jg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=os(t,r),this.key_type=this.dbi[$o.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[$o.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new Qg.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Ah(e,t){if(e===void 0)throw new Error(sn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(sn.ENV_NAME_REQUIRED)}a(Ah,"pathEnvNameValidation");async function Jg(e,t,r=!0){try{await xs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(sn.INVALID_BASE_PATH):n}try{let n=Dn.join(e,t+zd);return await xs.access(n,xs.constants.R_OK|xs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await xs.access(Dn.join(e,t,Z2),xs.constants.R_OK|xs.constants.F_OK),Dn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(sn.INVALID_ENVIRONMENT)}else throw new Error(sn.INVALID_ENVIRONMENT);throw n}}a(Jg,"validateEnvironmentPath");function bh(e,t){if(gh.validateEnv(e),t===void 0)throw new Error(sn.DBI_NAME_REQUIRED)}a(bh,"validateEnvDBIName");async function r4(e,t,r=!1,n=!1){Ah(e,t);let s=Dn.basename(e);t=t.toString();let i=FD.get(kD.CONFIG_PARAMS.DATABASES);i||FD.setProperty(kD.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Jg(e,t,n),VD(e,t,r)}catch(o){if(o.message===sn.INVALID_ENVIRONMENT){let c=Dn.join(e,t);await xs.mkdirp(n?c:e);let l=new qD(n?c:c+zd,!1),d=Qg.open(l);d.dbis=Object.create(null);let u=new zg(!1);d.openDB(ks,u),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=Xg(e,t,r);return d[$o.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=d,d}throw o}}a(r4,"createEnvironment");async function n4(e,t,r,n=!0){Ah(e,t),t=t.toString();let s=Dn.join(e,t);return J2({table:t,database:Dn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(n4,"copyEnvironment");async function VD(e,t,r=!1){Ah(e,t),t=t.toString();let n=Xg(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await Jg(e,t),i=Dn.join(e,t+zd),o=s!=i,c=new qD(s,o),l=Qg.open(c);l.dbis=Object.create(null);let d=KD(l);for(let u=0;u<d.length;u++)os(l,d[u]);return l[$o.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(VD,"openEnvironment");async function s4(e,t,r=!1){Ah(e,t),t=t.toString();let n=Dn.join(e,t+zd),s=await Jg(e,t);if(global.lmdb_map!==void 0){let i=Xg(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await YD(o),delete global.lmdb_map[i]}}await xs.remove(s),await xs.remove(s===n?s+t4:Dn.join(Dn.dirname(s),e4))}a(s4,"deleteEnvironment");async function YD(e){gh.validateEnv(e);let t=e[$o.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(YD,"closeEnvironment");function Xg(e,t,r=!1){let s=`${Dn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(Xg,"getCachedEnvironmentName");function i4(e){gh.validateEnv(e);let t=Object.create(null),r=os(e,ks);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==ks)try{t[n]=Object.assign(new Rh,s)}catch{GD.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(i4,"listDBIDefinitions");function KD(e){gh.validateEnv(e);let t=[],r=os(e,ks);for(let{key:n}of r.getRange({start:!1}))n!==ks&&t.push(n);return t}a(KD,"listDBIs");function o4(e,t){let n=os(e,ks).getEntry(t),s=new Rh;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{GD.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(o4,"getDBIDefinition");function WD(e,t,r,n=!r){if(bh(e,t),t=t.toString(),t===ks)throw new Error(sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return os(e,t)}catch(s){if(s.message===sn.DBI_DOES_NOT_EXIST){let i=new zg(r,n===!0),o=e.openDB(t,i),c=new Rh(r===!0,n);return o[$D]=c,os(e,ks).putSync(t,c),e.dbis[t]=o,o}throw s}}a(WD,"createDBI");function os(e,t){if(bh(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==ks?r=o4(e,t):r=new Rh,r===void 0)throw new Error(sn.DBI_DOES_NOT_EXIST);let n;try{let s=new zg(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(sn.DBI_DOES_NOT_EXIST):s}return n[$D]=r,e.dbis[t]=n,n}a(os,"openDBI");function a4(e,t){bh(e,t),t=t.toString();let r=os(e,t),n=r.getStats();return r[$o.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(a4,"statDBI");async function c4(e,t){try{let r=Dn.join(e,t+zd);return(await xs.stat(r)).size}catch{throw new Error(sn.INVALID_ENVIRONMENT)}}a(c4,"environmentDataSize");function l4(e,t){if(bh(e,t),t=t.toString(),t===ks)throw new Error(sn.CANNOT_DROP_INTERNAL_DBIS_NAME);os(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],os(e,ks).removeSync(t)}a(l4,"dropDBI");function u4(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{os(e,i)}catch(o){if(o.message===sn.DBI_DOES_NOT_EXIST)WD(e,i,i!==t,i===t),n=!0;else throw o}}n&&X2()}a(u4,"initializeDBIs");jD.exports={openDBI:os,openEnvironment:VD,createEnvironment:r4,listDBIs:KD,listDBIDefinitions:i4,createDBI:WD,dropDBI:l4,statDBI:a4,deleteEnvironment:s4,initializeDBIs:u4,TransactionCursor:jg,environmentDataSize:c4,copyEnvironment:n4,closeEnvironment:YD}});var zD=b((BRe,QD)=>{"use strict";var Zg=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};QD.exports=Zg});var XD=b((xRe,JD)=>{"use strict";var eR=class{static{a(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};JD.exports=eR});var eP=b((FRe,ZD)=>{"use strict";var tR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};ZD.exports=tR});var Qa=b((YRe,nP)=>{"use strict";var d4=ht(),_4=zD(),f4=XD(),E4=eP(),li=nn(),Jd=Nn().LMDB_ERRORS_ENUM,h4=Bt(),Wi=M(),m4=J(),p4=require("uuid"),qRe=require("lmdb"),{handleHDBError:S4,hdb_errors:T4}=fe(),{OVERFLOW_MARKER:$Re,MAX_SEARCH_KEY_LENGTH:VRe}=h4,tP=te();tP.initSync();var yh=tP.get(Wi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),rR=Wi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,ja=Wi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function g4(e,t,r,n,s=li.getNextMonotonicTime()){oR(e,t,r,n),nR(e,t,r);let i=new _4,o=[],c=[];for(let l=0;l<n.length;l++){let d=n[l];rP(d,!0,s);let u=R4(e,t,r,d),_=d[t];o.push(u),c.push(_)}return sR(o,c,n,i,s)}a(g4,"insertRecords");function R4(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let u=c([[{}]]);Array.isArray(u)&&(c=u[0][Wi.FUNC_VAL],n[o]=c)}let l=li.getIndexedValues(c),d=e.dbis[o];if(l){yh&&d.prefetch(l.map(u=>({key:u,value:s})),Oh);for(let u=0,_=l.length;u<_;u++)d.put(l[u],s)}}yh&&e.dbis[t].prefetch([s],Oh),e.dbis[t].put(s,n,n[ja])})}a(R4,"insertRecord");function A4(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(A4,"removeSkippedRecords");function rP(e,t,r){let n=r>0;(n||!Number.isInteger(e[ja]))&&(e[ja]=r||(r=li.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[rR]))&&(e[rR]=r||li.getNextMonotonicTime()):delete e[rR]}a(rP,"setTimestamps");function nR(e,t,r){r.indexOf(Wi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Wi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Wi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Wi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),d4.initializeDBIs(e,t,r)}a(nR,"initializeTransaction");async function b4(e,t,r,n,s=li.getNextMonotonicTime()){oR(e,t,r,n),nR(e,t,r);let i=new f4,o=[],c=[],l=[];for(let d=0;d<n.length;d++){let u=n[d],_=u[t],E;try{E=iR(e,t,u,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(d);continue}c.push(E),l.push(_)}return sR(c,l,n,i,s,o)}a(b4,"updateRecords");async function y4(e,t,r,n,s=li.getNextMonotonicTime()){try{oR(e,t,r,n)}catch(l){throw S4(l,l.message,T4.HTTP_STATUS_CODES.BAD_REQUEST)}nR(e,t,r);let i=new E4,o=[],c=[];for(let l=0;l<n.length;l++){let d=n[l],u;m4.isEmpty(d[t])?(u=p4.v4(),d[t]=u):u=d[t];let _=iR(e,t,d,u,i,!1,s);o.push(_),c.push(u)}return sR(o,c,n,i,s)}a(y4,"upsertRecords");async function sR(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||li.getNextMonotonicTime(),A4(r,i),n}a(sR,"finalizeWrite");function iR(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),d=l?.value,u=d;if(!d){if(i)return!1;d={}}if(rP(r,!u,o),Number.isInteger(r[ja])&&d[ja]>r[ja])return!1;u&&s.original_records.push(d);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let T=r[h],S=e.dbis[h];if(S===void 0)continue;let R=d[h];if(typeof T=="function"){let y=T([[d]]);Array.isArray(y)&&(T=y[0][Wi.FUNC_VAL],r[h]=T)}if(T===R)continue;let p=li.getIndexedValues(R);if(p){yh&&S.prefetch(p.map(y=>({key:y,value:n})),Oh);for(let y=0,O=p.length;y<O;y++)S.remove(p[y],n)}if(p=li.getIndexedValues(T),p){yh&&S.prefetch(p.map(y=>({key:y,value:n})),Oh);for(let y=0,O=p.length;y<O;y++)S.put(p[y],n)}}let f={...d,...r};c.put(n,f,f[ja])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:iR(e,t,r,n,s,i,o))}a(iR,"updateUpsertRecord");function O4(e,t,r){if(li.validateEnv(e),t===void 0)throw new Error(Jd.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Jd.WRITE_ATTRIBUTES_REQUIRED):new Error(Jd.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(O4,"validateBasic");function oR(e,t,r,n){if(O4(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Jd.RECORDS_REQUIRED):new Error(Jd.RECORDS_MUST_BE_ARRAY)}a(oR,"validateWrite");function Oh(){}a(Oh,"noop");nP.exports={insertRecords:g4,updateRecords:b4,upsertRecords:y4}});var ji=b((WRe,N4)=>{N4.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var di=b((jRe,oP)=>{"use strict";var iP=J(),sP=M(),Nl=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,ui=require("joi"),Vo={schema_format:{pattern:Nl,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},I4=ui.alternatives(ui.string().min(1).max(Vo.schema_length.maximum).pattern(Nl).messages({"string.pattern.base":"{:#label} "+Vo.schema_format.message}),ui.number(),ui.array()).required(),w4=ui.alternatives(ui.string().min(1).max(Vo.schema_length.maximum).pattern(Nl).messages({"string.pattern.base":"{:#label} "+Vo.schema_format.message}),ui.number()),C4=ui.alternatives(ui.string().min(1).max(Vo.schema_length.maximum).pattern(Nl).messages({"string.pattern.base":"{:#label} "+Vo.schema_format.message}),ui.number()).required();function D4(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Vo.schema_length.maximum?`'${e}' maximum of 250 characters`:Nl.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(D4,"checkValidTable");function P4(e,t){return iP.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(P4,"validateSchemaExists");function L4(e,t){let r=t.state.ancestors[0].schema;return iP.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(L4,"validateTableExists");function M4(e,t){return e.toLowerCase()===sP.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${sP.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(M4,"validateSchemaName");oP.exports={common_validators:Vo,schema_regex:Nl,hdb_schema_table:I4,validateSchemaExists:P4,validateTableExists:L4,validateSchemaName:M4,checkValidTable:D4,hdb_database:w4,hdb_table:C4}});var ut=b((zRe,aP)=>{"use strict";var on=require("validate.js");on.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||on.validators.type.checks[t](e)?null:` must be a '${t}' value`};on.validators.type.checks={Object:function(e){return on.isObject(e)&&!on.isArray(e)},Array:on.isArray,Integer:on.isInteger,Number:on.isNumber,String:on.isString,Date:on.isDate,Boolean:function(e){return typeof e=="boolean"}};on.validators.hasValidFileExt=function(e,t){return on.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};aP.exports={validateObject:U4,validateObjectAsync:v4,validateBySchema:B4};function U4(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=on(e,t,{format:"flat"});return r?new Error(r):null}a(U4,"validateObject");async function v4(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await on.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(v4,"validateObjectAsync");function B4(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(B4,"validateBySchema")});var Nh=b((XRe,cP)=>{var{common_validators:_i}=di(),Zd=ut(),Xd="is required",rr={database:{presence:!1,format:_i.schema_format,length:_i.schema_length},schema:{presence:!1,format:_i.schema_format,length:_i.schema_length},table:{presence:!0,format:_i.schema_format,length:_i.schema_length},attribute:{presence:!0,format:_i.schema_format,length:_i.schema_length},hash_attribute:{presence:!0,format:_i.schema_format,length:_i.schema_length}};function e_(e){for(let t in e)e[t]=e[t]===null||e[t]===void 0||typeof e[t]=="object"?e[t]:e[t].toString();return e}a(e_,"makeAttributesStrings");function H4(e){return e=e_(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,Zd.validateObject(e,rr)}a(H4,"schema_object");function x4(e){return e=e_(e),rr.table.presence={message:Xd},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,Zd.validateObject(e,rr)}a(x4,"table_object");function k4(e){return e=e_(e),rr.table.presence={message:Xd},rr.attribute.presence=!1,Zd.validateObject(e,rr)}a(k4,"create_table_object");function F4(e){return e=e_(e),rr.table.presence={message:Xd},rr.attribute.presence={message:Xd},rr.hash_attribute.presence=!1,Zd.validateObject(e,rr)}a(F4,"attribute_object");function G4(e){return e=e_(e),rr.table.presence={message:Xd},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,Zd.validateObject(e,rr)}a(G4,"describe_table");function q4(e){if(e){if(!Array.isArray(e))throw new Error("residence must be a string array");if(e.length===0)throw new Error("residence cannot be an empty array");for(let t=0;t<e.length;t++)if(typeof e[t]!="string")throw new Error(`residence must be a string array, item '${e[t]}' is not a string`)}}a(q4,"validateTableResidence");cP.exports={schema_object:H4,create_table_object:k4,table_object:x4,attribute_object:F4,describe_table:G4,validateTableResidence:q4}});var uP=b((eAe,lP)=>{"use strict";var $4=require("uuid"),aR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||$4.v4(),this.schema_table=`${this.schema}.${this.table}`}};lP.exports=aR});var Ih=b((rAe,dP)=>{"use strict";var V4=uP(),cR=class extends V4{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};dP.exports=cR});var fP=b((sAe,_P)=>{"use strict";_P.exports=K4;var Y4="inserted";function K4(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===Y4?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(K4,"returnObject")});var wh=b((aAe,pP)=>{"use strict";var W4=M(),lR=ht(),j4=Qa(),{getSystemSchemaPath:Q4,getSchemaPath:z4}=gt(),oAe=ji(),J4=Nh(),X4=Ih(),Z4=fP(),{handleHDBError:EP,hdb_errors:mP}=fe(),hP=J(),{HTTP_STATUS_CODES:eJ}=mP,tJ="inserted";pP.exports=rJ;async function rJ(e){let t=J4.attribute_object(e);if(t)throw EP(new Error,t.message,mP.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&hP.checkGlobalSchemaTable(e.schema,e.table);if(r)throw EP(new Error,r,eJ.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=hP.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new X4(e.schema,e.table,e.attribute,e.id);try{let i=await lR.openEnvironment(z4(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);lR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await lR.openEnvironment(Q4(),W4.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await j4.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return Z4(tJ,c,{records:[s]},l)}catch(i){throw i}}a(rJ,"lmdbCreateAttribute")});var dR=b((lAe,TP)=>{var{hdb_table:nJ,hdb_database:SP}=di(),sJ=ut(),uR=require("joi"),iJ={undefined:"undefined",null:"null"},oJ=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||iJ[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),aJ=uR.object({database:SP,schema:SP,table:nJ,records:uR.array().items(uR.object().custom(oJ)).required()});TP.exports=function(e){return sJ.validateBySchema(e,aJ)}});var t_=b((_Ae,RP)=>{"use strict";var Qi=J(),gP=V(),dAe=dR(),{getDatabases:cJ}=(Le(),oe(lt)),{ClientError:za}=fe();RP.exports=lJ;function lJ(e){if(Qi.isEmpty(e))throw new za("invalid update parameters defined.");if(Qi.isEmptyOrZeroLength(e.schema))throw new za("invalid schema specified.");if(Qi.isEmptyOrZeroLength(e.table))throw new za("invalid table specified.");if(!Array.isArray(e.records))throw new za("records must be an array");let t=cJ()[e.schema]?.[e.table];if(Qi.isEmpty(t))throw new za(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&Qi.isEmptyOrZeroLength(o[r]))throw gP.error("a valid hash attribute must be provided with update record:",o),new za("a valid hash attribute must be provided with update record, check log for more info");if(!Qi.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw gP.error(`a valid hash value must be provided with ${e.operation} record:`,o),new za(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!Qi.isEmpty(o[r])&&o[r]!==""&&n.has(Qi.autoCast(o[r]))&&(o.skip=!0),n.add(Qi.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(lJ,"insertUpdateValidate")});var bP=b((EAe,AP)=>{"use strict";var _R=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};AP.exports=_R});var NP=b((mAe,OP)=>{"use strict";var fR=ht(),uJ=V(),yP=Nn().LMDB_ERRORS_ENUM;OP.exports=dJ;async function dJ(e){try{if(global.lmdb_map!==void 0&&e.operation!==void 0){let t=Object.keys(global.lmdb_map),r;switch(e.operation){case"drop_schema":for(let i=0;i<t.length;i++){let o=t[i];if(o.startsWith(`${e.schema}.`)||o.startsWith(`txn.${e.schema}.`))try{await fR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==yP.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await fR.closeEnvironment(global.lmdb_map[n]),await fR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==yP.ENV_REQUIRED)throw i}break;case"drop_attribute":r=global.lmdb_map[`${e.schema}.${e.table}`],r!==void 0&&typeof r.dbis=="object"&&r.dbis[`${e.attribute}`]!==void 0&&delete r.dbis[`${e.attribute}`];break;default:break}}}catch(t){uJ.error(t)}}a(dJ,"cleanLMDBMap")});var zi=b((SAe,DP)=>{"use strict";var r_=require("crypto"),_J=te(),{CONFIG_PARAMS:fJ}=M(),wP="aes-256-cbc",EJ=32,hJ=16,ER=64,CP=32,mJ=ER+CP,IP=new Map;DP.exports={encrypt:pJ,decrypt:SJ,createNatsTableStreamName:TJ};function pJ(e){let t=r_.randomBytes(EJ),r=r_.randomBytes(hJ),n=r_.createCipheriv(wP,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(pJ,"encrypt");function SJ(e){let t=e.substr(0,ER),r=e.substr(ER,CP),n=e.substr(mJ,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=r_.createDecipheriv(wP,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(SJ,"decrypt");function TJ(e,t){let r=_J.get(fJ.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=IP.get(r);return n||(n=r_.createHash("md5").update(r).digest("hex"),IP.set(r,n)),n}a(TJ,"createNatsTableStreamName")});var fi=b((RAe,LP)=>{"use strict";var gAe=Vr(),n_=V(),PP=Nh(),gJ=zi(),Ch=J(),{handleHDBError:Dh,hdb_errors:RJ}=fe(),{HDB_ERROR_MSGS:Ph,HTTP_STATUS_CODES:hR}=RJ,AJ=te();AJ.initSync();var{getDatabases:mR}=(Le(),oe(lt)),bJ=require("fs-extra");LP.exports={describeAll:yJ,describeTable:Lh,describeSchema:OJ};async function yJ(e={}){try{let t=Ch.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=mR(),o={},c={},l=[],d=e?.exact_count;for(let _ in i){o[_]=!0,!t&&!s&&!r&&(c[_]=e.hdb_user?.role?.permission[_]?.describe);let E=i[_];for(let f in E)try{let h;if(t||s||r)h=await Lh({schema:_,table:f,exact_count:d});else if(n&&n[_].describe&&n[_].tables[f].describe){let T=n[_].tables[f].attribute_permissions;h=await Lh({schema:_,table:f,exact_count:d},T)}h&&l.push(h)}catch(h){n_.error(h)}}let u={};for(let _ in l)t||s||r?(u[l[_].schema]==null&&(u[l[_].schema]={}),u[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]):c[l[_].schema]&&(u[l[_].schema]==null&&(u[l[_].schema]={}),u[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]);for(let _ in o)t||s||r?u[_]={}:c[_]&&(u[_]={});return u}catch(t){return n_.error("Got an error in describeAll"),n_.error(t),Dh(new Error,Ph.DESCRIBE_ALL_ERR)}}a(yJ,"describeAll");async function Lh(e,t){Ch.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=PP.describe_table(e);if(i)throw i;let c=mR()[r];if(!c)throw Dh(new Error,Ph.SCHEMA_NOT_FOUND(e.schema),hR.NOT_FOUND);let l=c[n];if(!l)throw Dh(new Error,Ph.TABLE_NOT_FOUND(e.schema,e.table),hR.NOT_FOUND);function d(f){u.push({attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(d,"pushAtt");let u=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&d(h)})}else l.attributes?.forEach(f=>d(f));let _;try{_=(await bJ.stat(l.primaryStore.env.path)).size}catch(f){n_.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:u,db_size:_};E.clustering_stream_name=gJ.createNatsTableStreamName(E.schema,E.name);try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let T of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=T[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let T of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=T}catch(f){n_.warn(`unable to stat table dbi due to ${f}`)}return E}a(Lh,"descTable");async function OJ(e){Ch.transformReq(e);let t=PP.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=mR()[n];if(!i)throw Dh(new Error,Ph.SCHEMA_NOT_FOUND(e.schema),hR.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Ch.isEmpty(l)||l.describe){let d=await Lh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);d&&(o[d.name]=d)}}return o}a(OJ,"describeSchema")});var as=b((OAe,HP)=>{var NJ=ji(),{callbackify:UP,promisify:IJ}=require("util"),{getDatabases:vP}=(Le(),oe(lt));HP.exports={setSchemaDataToGlobal:MP,getTableSchema:wJ,getSystemSchema:CJ,setSchemaDataToGlobalAsync:IJ(MP)};var BP=fi(),bAe=UP(BP.describeAll),yAe=UP(BP.describeTable);function MP(e){global.hdb_schema=vP(),e&&e()}a(MP,"setSchemaDataToGlobal");function wJ(e,t,r){let n=vP()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}a(wJ,"getTableSchema");function CJ(){return NJ}a(CJ,"getSystemSchema")});var Yr=b((IAe,GP)=>{"use strict";var Uh=dR(),wr=J(),DJ=require("util"),vh=Pn(),PJ=as(),xP=V(),{handleHDBError:Ja,hdb_errors:LJ}=fe(),{HTTP_STATUS_CODES:Xa}=LJ,MJ=DJ.promisify(PJ.getTableSchema),UJ="updated",kP="inserted",FP="upserted";GP.exports={insert:BJ,update:HJ,upsert:xJ,validation:vJ,flush:kJ};async function vJ(e){if(wr.isEmpty(e))throw new Error("invalid update parameters defined.");if(wr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(wr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await MJ(e.schema,e.table),r=Uh(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&wr.isEmptyOrZeroLength(c[n]))throw xP.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!wr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw xP.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!wr.isEmpty(c[n])&&c[n]!==""&&s.has(wr.autoCast(c[n]))&&(c.skip=!0),s.add(wr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(vJ,"validation");async function BJ(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=Uh(e);if(t)throw Ja(new Error,t.message,Xa.BAD_REQUEST);wr.transformReq(e);let r=wr.checkSchemaTableExist(e.schema,e.table);if(r)throw Ja(new Error,r,Xa.BAD_REQUEST);let n=await vh.createRecords(e);return Mh(kP,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(BJ,"insertData");async function HJ(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=Uh(e);if(t)throw Ja(new Error,t.message,Xa.BAD_REQUEST);wr.transformReq(e);let r=wr.checkSchemaTableExist(e.schema,e.table);if(r)throw Ja(new Error,r,Xa.BAD_REQUEST);let n=await vh.updateRecords(e);return wr.isEmpty(n.existing_rows)?Mh(UJ,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Mh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(HJ,"updateData");async function xJ(e){if(e.operation!=="upsert")throw Ja(new Error,"invalid operation, must be upsert",Xa.INTERNAL_SERVER_ERROR);let t=Uh(e);if(t)throw Ja(new Error,t.message,Xa.BAD_REQUEST);wr.transformReq(e);let r=wr.checkSchemaTableExist(e.schema,e.table);if(r)throw Ja(new Error,r,Xa.BAD_REQUEST);let n=await vh.upsertRecords(e);return Mh(FP,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(xJ,"upsertData");function Mh(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===kP?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===FP?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Mh,"returnObject");function kJ(e){return wr.transformReq(e),vh.flush(e.schema,e.table)}a(kJ,"flush")});var SR=b((CAe,VP)=>{var FJ=ut(),pR=require("joi"),{hdb_table:GJ,hdb_database:qP}=di(),$P={schema:qP,database:qP,table:GJ},qJ={date:pR.date().iso().required()},$J={timestamp:pR.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};VP.exports=function(e,t){let r=t==="timestamp"?{...$P,...$J}:{...$P,...qJ},n=pR.object(r);return FJ.validateBySchema(e,n)}});var WP=b((DAe,KP)=>{var VJ=ut(),TR=require("joi"),{hdb_table:YJ,hdb_database:YP}=di(),KJ=TR.object({schema:YP,database:YP,table:YJ,hash_values:TR.array().required(),ids:TR.array()});KP.exports=function(e){return VJ.validateBySchema(e,KJ)}});var bR=b((PAe,jP)=>{"use strict";var gR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},RR=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},AR=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};jP.exports={InsertObject:gR,NoSQLSeachObject:RR,DeleteResponseObject:AR}});var Wo=b((MAe,ZP)=>{"use strict";var zP=SR(),WJ=WP(),Za=J(),QP=require("moment"),JP=V(),{promisify:jJ,callbackify:QJ}=require("util"),ec=M(),zJ=as(),yR=jJ(zJ.getTableSchema),OR=Pn(),{DeleteResponseObject:JJ}=bR(),{handleHDBError:Yo,hdb_errors:XJ}=fe(),{HDB_ERROR_MSGS:Bh,HTTP_STATUS_CODES:Ko}=XJ,ZJ="records successfully deleted",e3=QJ(XP);ZP.exports={delete:e3,deleteRecord:XP,deleteFilesBefore:t3,deleteAuditLogsBefore:r3};async function t3(e){let t=zP(e,"date");if(t)throw Yo(t,t.message,Ko.BAD_REQUEST,void 0,void 0,!0);if(Za.transformReq(e),!QP(e.date,QP.ISO_8601).isValid())throw Yo(new Error,Bh.INVALID_DATE,Ko.BAD_REQUEST,ec.LOG_LEVELS.ERROR,Bh.INVALID_DATE,!0);let n=Za.checkSchemaTableExist(e.schema,e.table);if(n)throw Yo(new Error,n,Ko.NOT_FOUND,ec.LOG_LEVELS.ERROR,n,!0);let s=await OR.deleteRecordsBefore(e);if(await yR(e.schema,e.table),JP.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(t3,"deleteFilesBefore");async function r3(e){let t=zP(e,"timestamp");if(t)throw Yo(t,t.message,Ko.BAD_REQUEST,void 0,void 0,!0);if(Za.transformReq(e),isNaN(e.timestamp))throw Yo(new Error,Bh.INVALID_VALUE("Timestamp"),Ko.BAD_REQUEST,ec.LOG_LEVELS.ERROR,Bh.INVALID_VALUE("Timestamp"),!0);let r=Za.checkSchemaTableExist(e.schema,e.table);if(r)throw Yo(new Error,r,Ko.NOT_FOUND,ec.LOG_LEVELS.ERROR,r,!0);let n=await OR.deleteAuditLogsBefore(e);return await yR(e.schema,e.table),JP.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(r3,"deleteAuditLogsBefore");async function XP(e){e.ids&&(e.hash_values=e.ids);let t=WJ(e);if(t)throw Yo(t,t.message,Ko.BAD_REQUEST,void 0,void 0,!0);Za.transformReq(e);let r=Za.checkSchemaTableExist(e.schema,e.table);if(r)throw Yo(new Error,r,Ko.NOT_FOUND,ec.LOG_LEVELS.ERROR,r,!0);try{await yR(e.schema,e.table);let n=await OR.deleteRecords(e);return Za.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${ZJ}`),n}catch(n){if(n.message===ec.SEARCH_NOT_FOUND_MESSAGE){let s=new JJ;return s.message=ec.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(XP,"deleteRecord")});var Hh=b((vAe,rL)=>{var n3=require("crypto"),eL=9;function s3(e){let t=o3(eL),r=tL(e+t);return t+r}a(s3,"createHash");function i3(e,t){let r=e?.substr(0,eL),n=r+tL(t+r);return e===n}a(i3,"validateHash");function o3(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(o3,"generateSalt");function tL(e){return n3.createHash("md5").update(e).digest("hex")}a(tL,"md5");rL.exports={hash:s3,validate:i3}});var sL=b((HAe,nL)=>{var NR=ut(),Kr={username:{presence:!0,format:"[\\w\\-\\_]+",exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function a3(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,NR.validateObject(e,Kr)}a(a3,"addUserValidation");function c3(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,NR.validateObject(e,Kr)}a(c3,"alterUserValidation");function l3(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,NR.validateObject(e,Kr)}a(l3,"dropUserValidation");nL.exports={addUserValidation:a3,alterUserValidation:c3,dropUserValidation:l3}});var dt=b((FAe,oL)=>{"use strict";var{platform:kAe}=require("os"),u3="nats-server.zip",IR="nats-server",d3=process.platform==="win32"?`${IR}.exe`:IR,_3=/^[^\s.,*>]+$/,iL="__request__",f3=a(e=>`${e}.${iL}`,"REQUEST_SUBJECT"),E3={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},h3={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},m3={HUB:"hub.pid",LEAF:"leaf.pid"},p3={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},S3={SUCCESS:"success",ERROR:"error"},T3={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},g3={TXN:"txn",MSGID:"msgid"},Il={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},R3={[Il.ERR]:1,[Il.WRN]:2,[Il.INF]:3,[Il.DBG]:4,[Il.TRC]:5},A3={debug:"-D",trace:"-DVV"};oL.exports={NATS_SERVER_ZIP:u3,NATS_SERVER_NAME:IR,NATS_BINARY_NAME:d3,PID_FILES:m3,NATS_CONFIG_FILES:h3,SERVER_SUFFIX:p3,NATS_TERM_CONSTRAINTS_RX:_3,REQUEST_SUFFIX:iL,UPDATE_REMOTE_RESPONSE_STATUSES:S3,CLUSTER_STATUS_STATUSES:T3,REQUEST_SUBJECT:f3,SUBJECT_PREFIXES:g3,MSG_HEADERS:E3,LOG_LEVELS:Il,LOG_LEVEL_FLAGS:A3,LOG_LEVEL_HIERARCHY:R3}});var wR=b(aL=>{"use strict";var b3={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
7
9
  `),key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
8
- `)},A3="certificate.pem",O3="privateKey.pem",b3="caCertificate.pem",y3="natsCertificate.pem",N3="natsCaCertificate.pem",Ot={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},I3={tls_certificate:Ot.SERVER,tls_certificateAuthority:Ot.CA,customFunctions_tls_certificate:Ot.SERVER,customFunctions_tls_certificateAuthority:Ot.CA,operationsApi_tls_certificate:Ot["OPERATIONS-API"],operationsApi_tls_certificateAuthority:Ot["OPERATIONS-CA"]},w3={[Ot.SERVER]:2,[Ot.DEFAULT]:1},C3={[Ot["OPERATIONS-API"]]:3,[Ot.SERVER]:2,[Ot.DEFAULT]:1},D3={[Ot["OPERATIONS-API"]]:3,[Ot.SERVER]:2,[Ot.DEFAULT]:1},P3={[Ot["OPERATIONS-CA"]]:3,[Ot.CA]:2,[Ot["DEFAULT-CA"]]:1},L3={[Ot["OPERATIONS-CA"]]:3,[Ot.CA]:2,[Ot["DEFAULT-CA"]]:1},M3={[Ot.CA]:2,[Ot["DEFAULT-CA"]]:1};Object.assign(iL,{CERTIFICATE_PEM_NAME:A3,PRIVATEKEY_PEM_NAME:O3,CA_PEM_NAME:b3,CERT_NAME:Ot,CERT_CONFIG_NAME_MAP:I3,CERT_PREFERENCE_APP:w3,CERT_PREFERENCE_OPS:C3,CERT_PREFERENCE_REP:D3,CA_CERT_PREFERENCE_REP:P3,CA_CERT_PREFERENCE_OPS:L3,CA_CERT_PREFERENCE_APP:M3,CERTIFICATE_VALUES:R3,NATS_CERTIFICATE_PEM_NAME:y3,NATS_CA_PEM_NAME:N3})});var DR=b((VAe,dL)=>{"use strict";var lL=require("fs-extra"),pe=require("joi"),U3=require("os"),{boolean:qe,string:Nt,number:xt,array:nc}=pe.types(),{totalmem:oL}=require("os"),rc=require("path"),v3=V(),CR=ee(),$Ae=wR(),aL=M(),B3=dt(),cL="log",H3="components",x3="Invalid logging.rotation.maxSize unit. Available units are G, M or K",F3="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",k3="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",G3="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",q3="rootPath config parameter is undefined",os=pe.alternatives([xt.min(0),Nt]).optional().empty(null),xh=pe.alternatives([nc.items(Nt,{host:Nt.required(),port:os},{hostname:Nt.required(),port:os}).empty(null),nc.items(Nt)]),hi,uL=!1;dL.exports={configValidator:$3,routesValidator:Q3,route_constraints:xh};function $3(e,t=!1){if(uL=t,hi=e.rootPath,CR.isEmpty(hi))throw q3;let r=qe.optional(),n=xt.min(0).max(1e3).empty(null).default(j3),s=Nt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(s_),i=Nt.optional().empty(null),o=Nt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=pe.string().empty(null).default(s_),l=pe.custom(Y3).empty(null).default(s_),d=e.clustering?.enabled,u=pe.object({certificate:i,certificateAuthority:i,privateKey:i}),_;return d===!0?_=pe.object({enabled:r,hubServer:pe.object({cluster:pe.object({name:pe.required().empty(null),network:pe.object({port:os,routes:xh}).required()}).required(),leafNodes:pe.object({network:pe.object({port:os}).required()}).required(),network:pe.object({port:os}).required()}).required(),leafServer:pe.object({network:pe.object({port:os,routes:xh}).required(),streams:pe.object({maxAge:xt.min(120).allow(null).optional(),maxBytes:xt.min(1).allow(null).optional(),maxMsgs:xt.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:pe.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:qe.optional(),databaseLevel:qe.optional(),tls:pe.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:qe.required(),verify:qe.optional()}),user:Nt.optional().empty(null)}).optional():_=pe.object({enabled:r,tls:pe.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:qe.optional()})}).optional(),pe.object({authentication:pe.object({authorizeLocal:qe,cacheTTL:xt.required(),enableSessions:qe}),analytics:pe.object({aggregatePeriod:xt}),replication:pe.object({hostname:pe.alternatives(Nt,xt).optional().empty(null),url:Nt.optional().empty(null),port:xt.optional().empty(null),securePort:xt.optional().empty(null),routes:nc.optional().empty(null),databases:pe.alternatives(Nt,nc),enableRootCAs:qe.optional()}),componentsRoot:s.optional(),clustering:_,localStudio:pe.object({enabled:r}).required(),logging:pe.object({auditAuthEvents:pe.object({logFailed:qe,logSuccessful:qe}),file:qe.required(),level:pe.valid("notify","fatal","error","warn","info","debug","trace"),rotation:pe.object({enabled:qe.optional(),compress:qe.optional(),interval:Nt.custom(W3).optional().empty(null),maxSize:Nt.custom(K3).optional().empty(null),path:Nt.optional().empty(null).default(s_)}).required(),root:s,stdStreams:qe.required(),auditLog:qe.required()}).required(),operationsApi:pe.object({network:pe.object({cors:qe.optional(),corsAccessList:nc.optional(),headersTimeout:xt.min(1).optional(),keepAliveTimeout:xt.min(1).optional(),port:os,domainSocket:pe.optional().empty("hdb/operations-server").default(s_),securePort:os,timeout:xt.min(1).optional()}).optional(),tls:pe.alternatives([pe.array().items(u),u])}).required(),rootPath:Nt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:pe.object({network:pe.object({port:os,securePort:os,mtls:pe.alternatives([qe.optional(),pe.object({user:Nt.optional(),certificateAuthority:i,required:qe.optional()})])}).required(),webSocket:qe.optional(),requireAuthentication:qe.optional()}),http:pe.object({compressionThreshold:xt.optional(),cors:qe.optional(),corsAccessList:nc.optional(),headersTimeout:xt.min(1).optional(),port:os,securePort:os,maxHeaderSize:xt.optional(),mtls:pe.alternatives([qe.optional(),pe.object({user:Nt.optional(),certificateAuthority:i,required:qe.optional()})]),threadRange:pe.alternatives([nc.optional(),Nt.optional()])}).required(),threads:pe.alternatives(n.optional(),pe.object({count:n.optional(),debug:pe.alternatives(qe.optional(),pe.object({startingPort:xt.min(1).optional(),host:Nt.optional(),waitForDebugger:qe.optional()})),maxHeapMemory:xt.min(0).optional()})),storage:pe.object({writeAsync:qe.required(),overlappingSync:qe.optional(),caching:qe.optional(),compression:pe.alternatives([qe.optional(),pe.object({dictionary:Nt.optional(),threshold:xt.optional()})]),compactOnStart:qe.optional(),compactOnStartKeepBackup:qe.optional(),noReadAhead:qe.optional(),path:l,prefetchWrites:qe.optional(),maxFreeSpaceToLoad:xt.optional(),maxFreeSpaceToRetain:xt.optional()}).required(),ignoreScripts:qe.optional(),tls:pe.alternatives([pe.array().items(u),u])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a($3,"configValidator");function V3(e){return uL||lL.existsSync(e)?null:`Specified path ${e} does not exist.`}a(V3,"doesPathExist");function Y3(e,t){pe.assert(e,Nt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=V3(e);if(r)return t.message(r)}a(Y3,"validatePath");function K3(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(x3);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(k3):e}a(K3,"validateRotationMaxSize");function W3(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(F3);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(G3):e}a(W3,"validateRotationInterval");function j3(e,t){let r=t.state.path.join("."),n=U3.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||oL();return i=Math.round(Math.min(i,oL())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),v3.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(j3,"setDefaultThreads");function s_(e,t){let r=t.state.path.join(".");if(!CR.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(CR.isEmpty(hi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return rc.join(hi,H3);case"logging.root":return rc.join(hi,cL);case"clustering.leafServer.streams.path":return rc.join(hi,"clustering","leaf");case"storage.path":let n=rc.join(hi,aL.LEGACY_DATABASES_DIR_NAME);return lL.existsSync(n)?n:rc.join(hi,aL.DATABASES_DIR_NAME);case"logging.rotation.path":return rc.join(hi,cL);case"operationsApi.network.domainSocket":return r==null?null:rc.join(hi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(s_,"setDefaultRoot");function Q3(e){let t=pe.object({routes:xh});return B3.validateBySchema({routes:e},t)}a(Q3,"routesValidator")});var It=b(RL=>{"use strict";var an=M(),_r=ee(),fr=V(),{configValidator:z3,routesValidator:_L}=DR(),jr=require("fs-extra"),EL=require("yaml"),Mn=require("path"),J3=require("is-number"),hL=require("properties-reader"),X3=require("lodash"),{handleHDBError:Z3}=ce(),{HTTP_STATUS_CODES:eX,HDB_ERROR_MSGS:yl}=Nn(),{server:tX}=(Vr(),ie(Va)),{DATABASES_PARAM_CONFIG:i_,CONFIG_PARAMS:Ln,CONFIG_PARAM_MAP:xs}=an,rX="Unable to get config value because config is uninitialized",nX="Config successfully initialized",sX="Error backing up config file",iX="Empty parameter sent to getConfigValue",mL=Mn.join(an.PACKAGE_ROOT,"config","yaml",an.HDB_DEFAULT_CONFIG_FILE),oX=Mn.join(an.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),aX="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",fL={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"},Fh,jt,kh;Object.assign(RL,{createConfigFile:cX,getDefaultConfig:lX,getConfigValue:SL,initConfig:Gh,flattenConfig:Nl,updateConfigValue:TL,updateConfigObject:dX,getConfiguration:EX,setConfiguration:hX,readConfigFile:UR,getClusteringRoutes:mX,initOldConfig:gL,getConfigFromFile:pX,getConfigFilePath:sc,addConfig:SX,deleteConfigFromFile:TX,getConfigObj:gX,resolvePath:PR,getFlatConfigObj:RX});function PR(e){if(e?.startsWith("~/"))return Mn.join(_r.getHomeDir(),e.slice(1));let t=te();return Mn.resolve(t.getHdbBasePath(),e)}a(PR,"resolvePath");function cX(e,t=!1){let r=$o(mL);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=EL.parseDocument(jr.readFileSync(oX,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}Fh=Nl(r.toJSON());let n;for(let c in e){let l=xs[c.toLowerCase()];if(l===Ln.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(d=>({[d]:e[c][d]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let d=l.split("_"),u=LR(l,e[c]);l==="rootPath"&&u?.endsWith("/")&&(u=u.slice(0,-1));try{r.setIn([...d],u)}catch(_){fr.error(_)}}}n&&pL(r,n),MR(r,t);let s=r.toJSON();jt=Nl(s);let i=r.getIn(["rootPath"]),o=Mn.join(i,an.HDB_CONFIG_FILE);jr.createFileSync(o),jr.writeFileSync(o,String(r)),fr.trace(`Config file written to ${o}`)}a(cX,"createConfigFile");function pL(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!_r.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(i_.TABLES))for(let i in n[s][i_.TABLES])for(let o in n[s][i_.TABLES][i]){let c=n[s][i_.TABLES][i][o],l=[Ln.DATABASES,s,i_.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Ln.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){fr.error("Error parsing schemas CLI/env config arguments",n)}}a(pL,"setSchemasConfig");function lX(e){if(Fh===void 0){let r=$o(mL);Fh=Nl(r.toJSON())}let t=xs[e.toLowerCase()];if(t!==void 0)return Fh[t.toLowerCase()]}a(lX,"getDefaultConfig");function SL(e){if(e==null){fr.info(iX);return}if(jt===void 0){fr.trace(rX);return}let t=xs[e.toLowerCase()];if(t!==void 0)return jt[t.toLowerCase()]}a(SL,"getConfigValue");function sc(e=_r.getPropsFilePath()){let t=_r.getEnvCliRootPath();if(t)return PR(Mn.join(t,an.HDB_CONFIG_FILE));let r=hL(e);return PR(r.get(an.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(sc,"getConfigFilePath");function Gh(e=!1){if(jt===void 0||e){let t;if(!_r.noBootFile()){t=_r.getPropsFilePath();try{jr.accessSync(t,jr.constants.F_OK|jr.constants.R_OK)}catch(i){throw fr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=sc(t),n;if(r.includes("config/settings.js"))try{gL(r);return}catch(i){if(i.code!==an.NODE_ERROR_CODES.ENOENT)throw i}try{n=$o(r)}catch(i){if(i.code===an.NODE_ERROR_CODES.ENOENT){fr.trace(`HarperDB config file not found at ${r}.
9
- This can occur during early stages of install where the config file has not yet been created`);return}else throw fr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}uX(n,r),MR(n);let s=n.toJSON();if(tX.config=s,jt=Nl(s),jt.logging_rotation_rotate)for(let i in fL)jt[i]&&fr.error(`Config ${fL[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);fr.trace(nX)}}a(Gh,"initConfig");function uX(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Mn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Mn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(fr.trace("Updating config file with missing config params"),jr.writeFileSync(t,String(e)))}a(uX,"checkForUpdatedConfig");function MR(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw yl.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 yl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=z3(r,t);if(n.error)throw yl.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(MR,"validateConfig");function dX(e,t){jt===void 0&&(jt={});let r=xs[e.toLowerCase()];if(r===void 0){fr.trace(`Unable to update config object because config param '${e}' does not exist`);return}jt[r.toLowerCase()]=t}a(dX,"updateConfigObject");function TL(e,t,r=void 0,n=!1,s=!1,i=!1){jt===void 0&&Gh();let o=SL(xs.hdb_root),c=Mn.join(o,an.HDB_CONFIG_FILE),l=$o(c),d;if(r===void 0&&e.toLowerCase()===Ln.DATABASES)d=t;else if(r===void 0){let E;if(i)E=e;else if(E=xs[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=LR(E,t);l.setIn([...f],h)}else for(let E in r){let f=xs[E.toLowerCase()];if(f===Ln.HTTP_SECUREPORT&&r[E]===jt[Ln.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Ln.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Ln.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Ln.DATABASES){d=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),p=an.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&l.hasIn(p.split("_"))&&(f=p,h=p.split("_"));let T=LR(f,r[E]);f==="rootPath"&&T?.endsWith("/")&&(T=T.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],T)}catch(g){fr.error(g)}}}d&&pL(l,d),MR(l);let u=l.getIn(["rootPath"]),_=Mn.join(u,an.HDB_CONFIG_FILE);n===!0&&_X(c,u),jr.writeFileSync(_,String(l)),s&&(jt=Nl(l.toJSON())),fr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(TL,"updateConfigValue");function _X(e,t){try{let r=Mn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${an.HDB_CONFIG_FILE}.bak`);jr.copySync(e,r),fr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){fr.error(sX),fr.error(r)}}a(_X,"backupConfigFile");var fX=["databases"];function Nl(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}),kh=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])&&!fX.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Ln[l.toUpperCase()]&&xs[l]&&(s[xs[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Nl,"flattenConfig");function LR(e,t){if(e===Ln.CLUSTERING_NODENAME||e===Ln.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(J3(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||_r.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return _r.autoCast(t)}a(LR,"castConfigValue");function EX(){let e=_r.getPropsFilePath(),t=sc(e);return $o(t).toJSON()}a(EX,"getConfiguration");async function hX(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return TL(void 0,void 0,s,!0),aX}catch(i){throw typeof i=="string"||i instanceof String?Z3(i,i,eX.BAD_REQUEST,void 0,void 0,!0):i}}a(hX,"setConfiguration");function UR(){let e=_r.getPropsFilePath();try{jr.accessSync(e,jr.constants.F_OK|jr.constants.R_OK)}catch(n){if(!_r.noBootFile())throw fr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=sc(e);return $o(t).toJSON()}a(UR,"readConfigFile");function $o(e){return EL.parseDocument(jr.readFileSync(e,"utf8"),{simpleKeys:!0})}a($o,"parseYamlDoc");function mX(){let e=UR(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=_r.isEmptyOrZeroLength(t)?[]:t;let r=_L(t);if(r)throw yl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=_r.isEmptyOrZeroLength(n)?[]:n;let s=_L(n);if(s)throw yl.CONFIG_VALIDATION(s.message);if(!_r.isEmptyOrZeroLength(n)&&!_r.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!_r.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw yl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(mX,"getClusteringRoutes");function gL(e){let t=hL(e);jt={};for(let r in xs){let n=t.get(r.toUpperCase());if(_r.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=xs[r].toLowerCase();s===Ln.LOGGING_ROOT?jt[s]=Mn.dirname(n):jt[s]=n}return jt}a(gL,"initOldConfig");function pX(e){let t=UR();return X3.get(t,e.replaceAll("_","."))}a(pX,"getConfigFromFile");async function SX(e,t){let r=$o(sc());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await jr.writeFile(sc(),String(r))}a(SX,"addConfig");function TX(e){let t=sc(_r.getPropsFilePath()),r=$o(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Mn.join(n,an.HDB_CONFIG_FILE);jr.writeFileSync(s,String(r))}a(TX,"deleteConfigFromFile");function gX(){return kh||(Gh(),kh)}a(gX,"getConfigObj");function RX(){return jt||Gh(),jt}a(RX,"getFlatConfigObj")});var OL=b((jAe,AL)=>{"use strict";var qh=M(),$h=class{static{a(this,"BaseLicense")}constructor(t=0,r=qh.RAM_ALLOCATION_ENUM.DEFAULT,n=qh.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},vR=class extends $h{static{a(this,"ExtendedLicense")}constructor(t=0,r=qh.RAM_ALLOCATION_ENUM.DEFAULT,n=qh.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};AL.exports={BaseLicense:$h,ExtendedLicense:vR}});var ic=b((zAe,DL)=>{"use strict";var wl=require("fs-extra"),yL=Hh(),NL=require("crypto"),AX=require("moment"),OX=require("uuid").v4,Qr=V(),HR=require("path"),bX=ee(),Vo=M(),{totalmem:bL}=require("os"),yX=OL().ExtendedLicense,Il="invalid license key format",NX="061183",IX="mofi25",wX="aes-256-cbc",CX=16,DX=32,IL=te(),{resolvePath:wL}=It();IL.initSync();var BR;DL.exports={validateLicense:CL,generateFingerPrint:LX,licenseSearch:kR,getLicense:vX,checkMemoryLimit:BX};function xR(){return HR.join(IL.getHdbBasePath(),Vo.LICENSE_KEY_DIR_NAME,Vo.LICENSE_FILE_NAME)}a(xR,"getLicenseDirPath");function PX(){let e=xR();return wL(HR.join(e,Vo.LICENSE_FILE_NAME))}a(PX,"getLicenseFilePath");function FR(){let e=xR();return wL(HR.join(e,Vo.REG_KEY_FILE_NAME))}a(FR,"getFingerPrintFilePath");async function LX(){let e=FR();try{return await wl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await MX();throw Qr.error(`Error writing fingerprint file to ${e}`),Qr.error(t),new Error("There was an error generating the fingerprint")}}a(LX,"generateFingerPrint");async function MX(){let e=OX(),t=yL.hash(e),r=FR();try{await wl.mkdirp(xR()),await wl.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Qr.error(`Error writing fingerprint file to ${r}`),Qr.error(n),new Error("There was an error generating the fingerprint")}return t}a(MX,"writeFingerprint");function CL(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Vo.RAM_ALLOCATION_ENUM.DEFAULT,version:Vo.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Qr.error("empty license key passed to validate."),r;let n=FR(),s=!1;try{s=wl.statSync(n)}catch(i){Qr.error(i)}if(s){let i;try{i=wl.readFileSync(n,"utf8")}catch{Qr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(IX),c=o[1];c=Buffer.concat([Buffer.from(c)],CX);let l=Buffer.concat([Buffer.from(i)],DX),d=NL.createDecipheriv(wX,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=d.update(o[0],"hex","utf8"),u.trim(),u+=d.final("utf8")}catch{let f=UX(o[0],i);if(f)u=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Il),Qr.error(Il),new Error(Il)}let _;if(isNaN(u))try{_=JSON.parse(u),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(Il),Qr.error(Il),new Error(Il)}else r.exp_date=u;r.exp_date<AX().valueOf()&&(r.valid_date=!1),yL.validate(o[1],`${NX}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Qr.error("Invalid licence"),r}a(CL,"validateLicense");function UX(e,t){try{let r=NL.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Qr.warn("Check old license failed")}}a(UX,"checkOldLicense");function kR(){let e=new yX,t=[];try{t=wl.readFileSync(PX(),"utf-8").split(Vo.NEW_LINE)}catch(r){r.code==="ENOENT"?Qr.debug("no license file found"):Qr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(bX.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=CL(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){Qr.error("There was an error parsing the license string."),Qr.error(s),e.ram_allocation=Vo.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return BR=e,e}a(kR,"licenseSearch");async function vX(){return BR||await kR(),BR}a(vX,"getLicense");function BX(){let e=kR().ram_allocation,t=process.constrainedMemory?.()||bL();if(t=Math.round(Math.min(t,bL())/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(BX,"checkMemoryLimit")});var vn=b((tOe,KL)=>{"use strict";var UL="username is required",vL="nothing to update, must supply active, role or password to update",BL="password cannot be an empty string",HL="If role is specified, it cannot be empty.",xL="active must be true or false";KL.exports={addUser:YX,alterUser:KX,dropUser:jX,getSuperUser:XX,userInfo:QX,listUsers:Yh,listUsersExternal:zX,setUsersToGlobal:Dl,findAndValidateUser:VL,getClusterUser:ZX,USERNAME_REQUIRED:UL,ALTERUSER_NOTHING_TO_UPDATE:vL,EMPTY_PASSWORD:BL,EMPTY_ROLE:HL,ACTIVE_BOOLEAN:xL};var FL=Kr(),HX=qo(),$R=Hh(),kL=rL(),GL=Yr(),VR=Xi(),Un=ee(),qL=require("validate.js"),$e=V(),{promisify:xX}=require("util"),YR=Ji(),PL=M(),LL=_t(),FX=It(),XAe=te(),ZAe=ic(),kX=Qi(),{table:eOe}=(Le(),ie(lt)),{handleHDBError:mi,hdb_errors:GX}=ce(),{HTTP_STATUS_CODES:pi,AUTHENTICATION_ERROR_MSGS:GR,HDB_ERROR_MSGS:Cl}=GX,{UserEventMsg:KR}=Fs(),qR=require("lodash"),{server:WR}=(Vr(),ie(Va)),qX=V();WR.getUser=(e,t)=>VL(e,t,t!=null);var $L={username:!0,active:!0,role:!0,password:!0},ML=new Map,Vh=GL.searchByValue,$X=GL.searchByHash,VX=xX(HX.delete);async function YX(e){let t=qL.cleanAttributes(e,$L),r=kL.addUserValidation(t);if(r)throw mi(new Error,r.message,pi.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await Vh(n),s=s&&Array.from(s)}catch(l){throw $e.error("There was an error searching for a role in add user"),$e.error(l),l}if(!s||s.length<1)throw mi(new Error,Cl.ROLE_NAME_NOT_FOUND(t.role),pi.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw mi(new Error,Cl.DUP_ROLES_FOUND(t.role),pi.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=YR.encrypt(t.password)),t.password=$R.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await FL.insert(i)}catch(l){throw $e.error("There was an error searching for a user."),$e.error(l),l}$e.debug(o);try{await Dl()}catch(l){throw $e.error("Got an error setting users to global"),$e.error(l),l}if(o.skipped_hashes.length===1)throw mi(new Error,Cl.USER_ALREADY_EXISTS(t.username),pi.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],VR.signalUserChange(new KR(process.pid)),`${c.username} successfully added`}a(YX,"addUser");async function KX(e){let t=qL.cleanAttributes(e,$L);if(Un.isEmptyOrZeroLength(t.username))throw new Error(UL);if(Un.isEmptyOrZeroLength(t.password)&&Un.isEmptyOrZeroLength(t.role)&&Un.isEmptyOrZeroLength(t.active))throw new Error(vL);if(!Un.isEmpty(t.password)&&Un.isEmptyOrZeroLength(t.password.trim()))throw new Error(BL);if(!Un.isEmpty(t.active)&&!Un.isBoolean(t.active))throw new Error(xL);let r=WX(t.username);if(!Un.isEmpty(t.password)&&!Un.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=YR.encrypt(t.password)),t.password=$R.hash(t.password)),t.role==="")throw new Error(HL);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await Vh(i)||[])}catch(c){throw $e.error("Got an error searching for a role."),$e.error(c),c}if(!o||o.length===0){let c=Cl.ALTER_USER_ROLE_NOT_FOUND(t.role);throw $e.error(c),mi(new Error,c,pi.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Cl.ALTER_USER_DUP_ROLES(t.role);throw $e.error(c),mi(new Error,c,pi.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await FL.update(n)}catch(i){throw $e.error("Error during update."),$e.error(i),i}try{await Dl()}catch(i){throw $e.error("Got an error setting users to global"),$e.error(i),i}return VR.signalUserChange(new KR(process.pid)),s}a(KX,"alterUser");function WX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(WX,"isClusterUser");async function jX(e){try{let t=kL.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Un.isEmpty(global.hdb_users.get(e.username)))throw mi(new Error,Cl.USER_NOT_EXIST(e.username),pi.NOT_FOUND,void 0,void 0,!0);let n;try{n=await VX(r)}catch(s){throw $e.error("Got an error deleting a user."),$e.error(s),s}$e.debug(n);try{await Dl()}catch(s){throw $e.error("Got an error setting users to global."),$e.error(s),s}return VR.signalUserChange(new KR(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(jX,"dropUser");async function QX(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=qR.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await $X(r)}catch(s){throw $e.error("Got an error searching for a role."),$e.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw $e.error(r),r}return t}a(QX,"userInfo");async function zX(){let e;try{e=await Yh()}catch(t){throw $e.error("Got an error listing users."),$e.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(zX,"listUsersExternal");async function Yh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await Vh(e)}catch(o){throw $e.error("Got an error searching for roles."),$e.error(o),o}let r={};for(let o of t)r[o.id]=qR.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await Vh(n)}catch(o){throw $e.error("Got an error searching for users."),$e.error(o),o}let i=new Map;for(let o of s)o=qR.cloneDeep(o),o.role=r[o.role],JX(o.role),i.set(o.username,o);return i}catch(e){throw $e.error("got an error listing users"),$e.error(e),Un.errorizeMessage(e)}return null}a(Yh,"listUsers");function JX(e){try{if(!e){$e.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(kX)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){$e.error("Got an error trying to set system permissions."),$e.error(t)}}a(JX,"appendSystemTablesToRole");async function Dl(){try{let e=await Yh();global.hdb_users=e}catch(e){throw $e.error(e),e}}a(Dl,"setUsersToGlobal");async function VL(e,t,r=!0){global.hdb_users||await Dl();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw mi(new Error,GR.GENERIC_AUTH_FAIL,pi.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw mi(new Error,GR.USER_INACTIVE,pi.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(ML.get(t)===n.password)return s;if($R.validate(n.password,t))ML.set(t,n.password);else throw mi(new Error,GR.GENERIC_AUTH_FAIL,pi.UNAUTHORIZED,void 0,void 0,!0)}return s}a(VL,"findAndValidateUser");async function XX(){global.hdb_users||await Dl();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(XX,"getSuperUser");async function ZX(){let e=await Yh(),t=FX.getConfigFromFile(PL.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Un.isEmpty(r)&&r?.role?.role===PL.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=YR.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+LL.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+LL.SERVER_SUFFIX.ADMIN,r}a(ZX,"getClusterUser");var YL=[];WR.invalidateUser=function(e){for(let t of YL)try{t(e)}catch(r){qX.error("Error invalidating user",r)}};WR.onInvalidatedUser=function(e){YL.push(e)}});var a_=b((iOe,zL)=>{"use strict";var oc=V(),Bn=M(),eZ=bP(),nOe=is(),sOe=Ei(),tZ=vn(),{validateEvent:WL}=Fs(),o_=Pn(),rZ=require("process"),{resetDatabases:nZ}=(Le(),ie(lt)),sZ={[Bn.ITC_EVENT_TYPES.SCHEMA]:iZ,[Bn.ITC_EVENT_TYPES.USER]:QL};async function iZ(e){let t=WL(e);if(t){oc.error(t);return}oc.trace("ITC schemaHandler received schema event:",e),await eZ(e.message),await oZ(e.message)}a(iZ,"schemaHandler");async function oZ(e){try{o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=nZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){oc.error(t)}}a(oZ,"syncSchemaMetadata");var jL=[];async function QL(e){try{try{o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){oc.warn(r)}let t=WL(e);if(t){oc.error(t);return}oc.trace(`ITC userHandler ${Bn.HDB_ITC_CLIENT_PREFIX}${rZ.pid} received user event:`,e),await tZ.setUsersToGlobal();for(let r of jL)r()}catch(t){oc.error(t)}}a(QL,"userHandler");QL.addListener=function(e){jL.push(e)};zL.exports=sZ});var Fs=b((dOe,XL)=>{"use strict";var aOe=V(),jR=ee(),aZ=M(),{ITC_ERRORS:c_}=Nn(),{parentPort:cOe,threadId:cZ,isMainThread:lZ,workerData:lOe}=require("worker_threads"),{onMessageFromWorkers:uZ,broadcast:uOe,broadcastWithAcknowledgement:dZ}=st();XL.exports={sendItcEvent:_Z,validateEvent:JL,SchemaEventMsg:fZ,UserEventMsg:EZ};var Kh;uZ(async(e,t)=>{Kh=Kh||a_(),JL(e),Kh[e.type]&&await Kh[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function _Z(e){return!lZ&&e.message&&(e.message.originator=cZ),dZ(e)}a(_Z,"sendItcEvent");function JL(e){if(typeof e!="object")return c_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||jR.isEmpty(e.type))return c_.MISSING_TYPE;if(!e.hasOwnProperty("message")||jR.isEmpty(e.message))return c_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||jR.isEmpty(e.message.originator))return c_.MISSING_ORIGIN;if(aZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return c_.INVALID_EVENT(e.type)}a(JL,"validateEvent");function fZ(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(fZ,"SchemaEventMsg");function EZ(e){this.originator=e}a(EZ,"UserEventMsg")});var Xi=b((EOe,rM)=>{"use strict";var ZL=M(),fOe=ee(),Wh=V(),eM=RP(),Pl,{sendItcEvent:tM}=Fs();function hZ(e){try{Wh.info("signalSchemaChange called with message:",e),Pl=Pl||a_();let t=new eM(ZL.ITC_EVENT_TYPES.SCHEMA,e);return Pl.schema(t),tM(t)}catch(t){Wh.error(t)}}a(hZ,"signalSchemaChange");function mZ(e){try{Wh.trace("signalUserChange called with message:",e),Pl=Pl||a_();let t=new eM(ZL.ITC_EVENT_TYPES.USER,e);return Pl.user(t),tM(t)}catch(t){Wh.error(t)}}a(mZ,"signalUserChange");rM.exports={signalSchemaChange:hZ,signalUserChange:mZ}});var jh=b((mOe,sM)=>{"use strict";var nM=ee(),pZ=M(),SZ=V(),TZ=bh(),gZ=Oh(),RZ=Xi(),{SchemaEventMsg:AZ}=Fs(),OZ="already exists in";sM.exports=bZ;async function bZ(e,t,r){if(nM.isEmptyOrZeroLength(r))return r;let n=[];nM.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 yZ(e,t.schema,t.name,i)})),s}a(bZ,"lmdbCheckForNewAttributes");async function yZ(e,t,r,n){let s=new gZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await NZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(OZ))SZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(yZ,"createNewAttribute");async function NZ(e){let t;return t=await TZ(e),RZ.signalSchemaChange(new AZ(process.pid,pZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(NZ,"createAttribute")});var Ll=b((SOe,iM)=>{"use strict";var QR=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};iM.exports=QR});var aM=b((gOe,oM)=>{"use strict";var IZ=Ll(),wZ=M().OPERATIONS_ENUM,zR=class extends IZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(wZ.INSERT,r,n,s,i),this.records=t}};oM.exports=zR});var lM=b((AOe,cM)=>{"use strict";var CZ=Ll(),DZ=M().OPERATIONS_ENUM,JR=class extends CZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(DZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};cM.exports=JR});var dM=b((bOe,uM)=>{"use strict";var PZ=Ll(),LZ=M().OPERATIONS_ENUM,XR=class extends PZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(LZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};uM.exports=XR});var fM=b((NOe,_M)=>{"use strict";var MZ=Ll(),UZ=M().OPERATIONS_ENUM,ZR=class extends MZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(UZ.DELETE,n,s,t,i),this.original_records=r}};_M.exports=ZR});var l_=b((COe,pM)=>{"use strict";var wOe=require("path"),EM=Et(),vZ=aM(),BZ=lM(),HZ=dM(),xZ=fM(),Ml=Bt(),hM=ee(),{CONFIG_PARAMS:FZ}=M(),mM=te();mM.initSync();var Qh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:kZ}=Tt();pM.exports=GZ;async function GZ(e,t){if(mM.get(FZ.LOGGING_AUDITLOG)===!1)return;let r=kZ(e.schema,e.table),n=await EM.openEnvironment(r,e.table,!0),s=qZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){EM.initializeDBIs(n,Ml.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Ml.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Ml.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Ml.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),hM.isEmpty(s.user_name)||n.dbis[Ml.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Ml.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(GZ,"writeTransaction");function qZ(e,t){let r=hM.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===Qh.INSERT)return new vZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.UPDATE)return new BZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.UPSERT)return new HZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.DELETE)return new xZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(qZ,"createTransactionObject")});var eA=b((LOe,SM)=>{"use strict";var $Z=Zd(),POe=e_(),u_=M(),VZ=t_(),YZ=za().insertRecords,KZ=Et(),WZ=V(),jZ=jh(),{getSchemaPath:QZ}=Tt(),zZ=l_();SM.exports=JZ;async function JZ(e){try{let{schema_table:t,attributes:r}=$Z(e);VZ(e,r,t.hash_attribute),e.schema!==u_.SYSTEM_SCHEMA_NAME&&(r.includes(u_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(u_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(u_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(u_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await jZ(e.hdb_auth_header,t,r),s=QZ(e.schema,e.table),i=await KZ.openEnvironment(s,e.table),o=await YZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await zZ(e,o)}catch(c){WZ.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(JZ,"lmdbCreateRecords")});var RM=b((UOe,gM)=>{"use strict";var TM=M(),XZ=eA(),ZZ=e_(),e5=require("fs-extra"),{getSchemaPath:t5}=Tt();gM.exports=r5;async function r5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new ZZ(TM.SYSTEM_SCHEMA_NAME,TM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await XZ(r),await e5.mkdirp(t5(e.schema))}a(r5,"lmdbCreateSchema")});var OM=b((BOe,AM)=>{"use strict";var tA=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};AM.exports=tA});var IM=b((GOe,NM)=>{"use strict";var bM=Et(),rA=nn(),nA=Nn().LMDB_ERRORS_ENUM,n5=Bt(),yM=V(),xOe=ee(),s5=require("lmdb"),i5=OM(),o5=M(),{OVERFLOW_MARKER:FOe,MAX_SEARCH_KEY_LENGTH:kOe}=n5,a5=o5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function c5(e,t,r,n){if(rA.validateEnv(e),t===void 0)throw new Error(nA.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(nA.IDS_REQUIRED):new Error(nA.IDS_MUST_BE_ITERABLE);try{let s=bM.listDBIs(e);bM.initializeDBIs(e,t,s);let i=new i5,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[a5]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,s5.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let T=0;T<s.length;T++){let g=s[T];if(!h.hasOwnProperty(g)||g===t)continue;let S=e.dbis[g],C=h[g];if(C!=null)try{let y=rA.getIndexedValues(C);if(y)for(let x=0,F=y.length;x<F;x++)S.remove(y[x],o)}catch{yM.warn(`cannot delete from attribute: ${g}, ${C}:${o}`)}}});c.push(p),l.push(o),i.original_records.push(h)}catch(h){yM.warn(h),i.skipped.push(o)}let d=[],u=await Promise.all(c);for(let E=0,f=u.length;E<f;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),d.push(E));let _=0;for(let E=0;E<d.length;E++){let f=d[E];i.original_records.splice(f-_,1),_++}return i.txn_time=rA.getNextMonotonicTime(),i}catch(s){throw s}}a(c5,"deleteRecords");NM.exports={deleteRecords:c5}});var d_=b(($Oe,CM)=>{"use strict";var Ul=ee(),l5=IM(),u5=Et(),{getSchemaPath:d5}=Tt(),_5=l_(),f5=V();CM.exports=E5;async function E5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Ul.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Ul.isEmptyOrZeroLength(e.hash_values)&&!Ul.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Ul.isEmpty(l)||e.hash_values.push(l)}}if(Ul.isEmptyOrZeroLength(e.hash_values))return wM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Ul.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=d5(e.schema,e.table),i=await u5.openEnvironment(s,e.table),o=await l5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await _5(e,o)}catch(c){f5.error(`unable to write transaction due to ${c.message}`)}return wM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(E5,"lmdbDeleteRecords");function wM(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(wM,"createDeleteResponse")});var iA=b((KOe,DM)=>{"use strict";var h5=M(),YOe=nn();function sA(e,t){let r=Object.create(null);if(t.length===1&&h5.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(sA,"parseRow");function m5(e,t,r,n){let s=sA(r,e);n.push(s)}a(m5,"searchAll");function p5(e,t,r,n){let s=sA(r,e);n[t]=s}a(p5,"searchAllToMap");function S5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(S5,"iterateDBI");function ac(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(ac,"pushResults");function T5(e,t,r,n,s,i){t.toString().endsWith(e)&&ac(t,r,n,s,i)}a(T5,"endsWith");function g5(e,t,r,n,s,i){t.toString().includes(e)&&ac(t,r,n,s,i)}a(g5,"contains");function R5(e,t,r,n,s,i){t>e&&ac(t,r,n,s,i)}a(R5,"greaterThanCompare");function A5(e,t,r,n,s,i){t>=e&&ac(t,r,n,s,i)}a(A5,"greaterThanEqualCompare");function O5(e,t,r,n,s,i){t<e&&ac(t,r,n,s,i)}a(O5,"lessThanCompare");function b5(e,t,r,n,s,i){t<=e&&ac(t,r,n,s,i)}a(b5,"lessThanEqualCompare");DM.exports={parseRow:sA,searchAll:m5,searchAllToMap:p5,iterateDBI:S5,endsWith:T5,contains:g5,greaterThanCompare:R5,greaterThanEqualCompare:A5,lessThanCompare:O5,lessThanEqualCompare:b5,pushResults:ac}});var vl=b((JOe,HM)=>{"use strict";var Yo=Et(),jOe=V(),Hn=nn(),zh=Bt(),Qt=Nn().LMDB_ERRORS_ENUM,QOe=ee(),y5=M(),Jh=iA(),{parseRow:N5}=Jh,zOe=require("lmdb"),{OVERFLOW_MARKER:PM,MAX_SEARCH_KEY_LENGTH:I5}=zh;function LM(e,t,r,n=!1,s=void 0,i=void 0){return cc(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(LM,"iterateFullIndex");function __(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,d=!1){return cc(e,t,r,(u,_,E,f)=>{let S={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!d,exclusiveStart:i===!0?d:l};return f===r?(S.values=!1,_.getRange(S).map(C=>({value:C}))):_.getRange(S)})}a(__,"iterateRangeBetween");function cc(e,t,r,n){let s=e.database||e,i=Yo.openDBI(s,r);i[zh.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Yo.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(cc,"setupTransaction");function MM(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(PM)){if(!s)if(r)s=Yo.openDBI(e,r);else{let l=Yo.listDBIs(e);for(let d=0,u=l.length;d<u&&(s=Yo.openDBI(e,l[d]),!s[zh.DBI_DEFINITION_NAME].is_hash_attribute);d++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(MM,"getOverflowCheck");function w5(e,t,r,n=!1,s=void 0,i=void 0){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return cc(e,t,t,(o,c,l)=>(Xh(r),r=f_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(d=>N5(d.value,r))))}a(w5,"searchAll");function C5(e,t,r,n=!1,s=void 0,i=void 0){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);Xh(r),r=f_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of LM(e,t,t,n,s,i))o.set(c,Jh.parseRow(l,r));return o}a(C5,"searchAllToMap");function D5(e,t,r=!1,n=void 0,s=void 0){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=LM(e,void 0,t,r,n,s),c=o.transaction,l=MM(c.database,c,void 0,t);for(let{key:d,value:u}of o){let _=l(d,u);i[_]===void 0&&(i[_]=[]),i[_].push(u)}return i}a(D5,"iterateDBI");function P5(e,t){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return Yo.statDBI(e,t).entryCount}a(P5,"countAll");function L5(e,t,r,n,s=!1,i=void 0,o=void 0){return Ko(e,r,n),cc(e,t,r,(c,l,d,u)=>(n=Hn.convertKeyValueToWrite(n),u===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(_=>({key:n,value:_}))))}a(L5,"equals");function M5(e,t,r){return Ko(e,t,r),Yo.openDBI(e,t).getValuesCount(r)}a(M5,"count");function U5(e,t,r,n,s=!1,i=void 0,o=void 0){return Ko(e,r,n),cc(e,null,r,(c,l)=>{n=Hn.convertKeyValueToWrite(n);let d=!0;typeof n=="number"&&(d=!1);let u;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(d===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(d===!0)return u.DONE}),d?u:u.filter(_=>_)})}a(U5,"startsWith");function v5(e,t,r,n,s=!1,i=void 0,o=void 0){return UM(e,t,r,n,s,i,o,!0)}a(v5,"endsWith");function UM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Ko(e,r,n),cc(e,null,r,(l,d,u,_)=>{let E=MM(u,l,_,r);return o=Number.isInteger(o)?o:0,d.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(PM)?d.getValues(f,{transaction:l}).map(p=>{let T=E(f,p);if(c?T.endsWith(n):T.includes(n))return{key:T,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?d[zh.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:d.getValues(f,{transaction:l}).map(p=>({key:f,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(UM,"contains");function B5(e,t,r,n,s=!1,i=void 0,o=void 0){Ko(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),__(e,t,r,n,l,s,i,o,!0,!1)}a(B5,"greaterThan");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){Ko(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),__(e,t,r,n,l,s,i,o,!1,!1)}a(H5,"greaterThanEqual");function x5(e,t,r,n,s=!1,i=void 0,o=void 0){Ko(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),__(e,t,r,l,n,s,i,o,!1,!0)}a(x5,"lessThan");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){Ko(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),__(e,t,r,l,n,s,i,o,!1,!1)}a(F5,"lessThanEqual");function k5(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Hn.validateEnv(e),r===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Qt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Qt.END_VALUE_REQUIRED);if(n=Hn.convertKeyValueToWrite(n),s=Hn.convertKeyValueToWrite(s),n>s)throw new Error(Qt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return __(e,t,r,n,s,i,o,c)}a(k5,"between");function G5(e,t,r,n){Hn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(Xh(r),r=f_(s,r),n===void 0)throw new Error(Qt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=Jh.parseRow(c,r)),o}a(G5,"searchByHash");function q5(e,t,r){Hn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(q5,"checkHashExists");function $5(e,t,r,n,s=[]){return BM(e,t,r,n,s),vM(e,t,r,n,s).map(i=>i[1])}a($5,"batchSearchByHash");function V5(e,t,r,n,s=[]){BM(e,t,r,n,s);let i=new Map;for(let[o,c]of vM(e,t,r,n,s))i.set(o,c);return i}a(V5,"batchSearchByHashToMap");function vM(e,t,r,n,s=[]){return cc(e,t,t,(i,o,c)=>{r=f_(c,r);let l=r.length<3;return n.map(d=>{let u=c.dbis[t].get(d,{transaction:i,lazy:l});if(u)return[d,Jh.parseRow(u,r)];s.push(d)}).filter(d=>d)})}a(vM,"batchHashSearch");function BM(e,t,r,n,s){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(Xh(r),n==null)throw new Error(Qt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Qt.IDS_MUST_BE_ITERABLE)}a(BM,"initializeBatchSearchByHash");function Xh(e){if(!Array.isArray(e))throw e===void 0?new Error(Qt.FETCH_ATTRIBUTES_REQUIRED):new Error(Qt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(Xh,"validateFetchAttributes");function Ko(e,t,r){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.SEARCH_VALUE_REQUIRED);if(r?.length>I5)throw new Error(Qt.SEARCH_VALUE_TOO_LARGE)}a(Ko,"validateComparisonFunctions");function f_(e,t){return t.length===1&&y5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Yo.listDBIs(e)),t}a(f_,"setGetWholeRowAttributes");HM.exports={searchAll:w5,searchAllToMap:C5,count:M5,countAll:P5,equals:L5,startsWith:U5,endsWith:v5,contains:UM,searchByHash:G5,setGetWholeRowAttributes:f_,batchSearchByHash:$5,batchSearchByHashToMap:V5,checkHashExists:q5,iterateDBI:D5,greaterThan:B5,greaterThanEqual:H5,lessThan:x5,lessThanEqual:F5,between:k5}});var Bl=b((ZOe,qM)=>{var xM=require("lodash"),FM=dt(),Be=require("joi"),Y5=ee(),{hdb_schema_table:E_,checkValidTable:kM,hdb_table:GM,hdb_database:Zh}=_i(),{handleHDBError:K5,hdb_errors:W5}=ce(),{getDatabases:j5}=(Le(),ie(lt)),{HTTP_STATUS_CODES:Q5}=W5,z5=Be.object({database:Zh,schema:Zh,table:GM,search_attribute:E_,search_value:Be.any().required(),get_attributes:Be.array().min(1).items(Be.alternatives(E_,Be.object())).optional(),desc:Be.bool(),limit:Be.number().integer().min(1),offset:Be.number().integer().min(0)}),J5=Be.object({database:Zh,schema:Zh,table:GM,operator:Be.string().valid("and","or").default("and").lowercase(),offset:Be.number().integer().min(0),limit:Be.number().integer().min(1),get_attributes:Be.array().min(1).items(Be.alternatives(E_,Be.object())).optional(),sort:Be.object({attribute:Be.alternatives(E_,Be.array().min(1)),descending:Be.bool().optional()}).optional(),conditions:Be.array().min(1).items(Be.alternatives(Be.object({operator:Be.string().valid("and","or").default("and").lowercase(),conditions:Be.array()}),Be.object({search_attribute:Be.alternatives(E_,Be.array().min(1)),search_type:Be.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:Be.when("search_type",{switch:[{is:"equals",then:Be.any()},{is:"between",then:Be.array().items(Be.alternatives([Be.string(),Be.number()])).length(2)}],otherwise:Be.alternatives(Be.string(),Be.number())}).required()}))).required()});qM.exports=function(e,t){let r=null;switch(t){case"value":r=FM.validateBySchema(e,z5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(kM("database",e.schema)),i(kM("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=FM.validateBySchema(e,J5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Y5.checkGlobalSchemaTable(e.schema,e.table);if(s)return K5(new Error,s,Q5.NOT_FOUND);let o=j5()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let _=0,E=u.conditions.length;_<E;_++){let f=u.conditions[_];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let d=xM.filter(c,u=>u!=="*"&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!xM.some(o,_=>_===u||_.attribute===u||_.attribute===u.attribute));if(d&&d.length>0){let u=d.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var oA=b((tbe,$M)=>{"use strict";var X5=Et(),Z5=Bl(),{getSchemaPath:e6}=Tt();$M.exports=t6;function t6(e){let t=Z5(e,"hashes");if(t)throw t;let r=e6(e.schema,e.table);return X5.openEnvironment(r,e.table)}a(t6,"initialize")});var aA=b((nbe,VM)=>{"use strict";var r6=vl(),n6=oA();VM.exports=s6;async function s6(e){let t=await n6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return r6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(s6,"lmdbGetDataByHash")});var Hl=b((ibe,YM)=>{"use strict";var cA=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};YM.exports=cA});var WM=b((cbe,KM)=>{"use strict";var abe=Hl(),i6=vl(),o6=oA();KM.exports=a6;async function a6(e){let t=await o6(e),r=global.hdb_schema[e.schema][e.table];return i6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(a6,"lmdbSearchByHash")});var ks=b((ube,jM)=>{"use strict";var lA=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,d=void 0,u=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=d,this.offset=u}};jM.exports=lA});var em=b((_be,eU)=>{"use strict";var zr=vl(),c6=Et(),l6=ee(),He=Bt(),lc=M(),u6=Qi(),QM=Nn().LMDB_ERRORS_ENUM,{getSchemaPath:d6}=Tt(),Zi=lc.SEARCH_WILDCARDS;async function _6(e,t,r){let n;e.schema===lc.SYSTEM_SCHEMA_NAME?n=u6[e.table]:n=global.hdb_schema[e.schema][e.table];let s=ZM(e,n.hash_attribute,r,t);return JM(e,s,n.hash_attribute,r)}a(_6,"prepSearch");async function JM(e,t,r,n){let s=d6(e.schema,e.table),i=await c6.openEnvironment(s,e.table),o=XM(i,e,t,r),c=o.transaction||i;if([He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,He.SEARCH_TYPES.SEARCH_ALL,He.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(f6(e,r)===!1){let u=e.search_attribute;if(u===r)return n?zM(o,()=>!0):o.map(E=>({[r]:E.key}));let _=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?zM(o,_):o.map(_)}let d=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?zr.batchSearchByHashToMap(c,r,e.get_attributes,d):zr.batchSearchByHash(c,r,e.get_attributes,d)}a(JM,"executeSearch");function XM(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case He.SEARCH_TYPES.EQUALS:s=zr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.CONTAINS:s=zr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.ENDS_WITH:case He.SEARCH_TYPES._ENDS_WITH:s=zr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.STARTS_WITH:case He.SEARCH_TYPES._STARTS_WITH:s=zr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return zr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return zr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case He.SEARCH_TYPES.SEARCH_ALL:return zr.searchAll(e,n,t.get_attributes,o,c,l);case He.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return zr.searchAllToMap(e,n,t.get_attributes,o,c,l);case He.SEARCH_TYPES.BETWEEN:s=zr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case He.SEARCH_TYPES.GREATER_THAN:case He.SEARCH_TYPES._GREATER_THAN:s=zr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.GREATER_THAN_EQUAL:case He.SEARCH_TYPES._GREATER_THAN_EQUAL:s=zr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.LESS_THAN:case He.SEARCH_TYPES._LESS_THAN:s=zr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.LESS_THAN_EQUAL:case He.SEARCH_TYPES._LESS_THAN_EQUAL:s=zr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(XM,"searchByType");function zM(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(zM,"createMapFromIterable");function f6(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(f6,"checkToFetchMore");function ZM(e,t,r,n){if(l6.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),Zi.indexOf(s)>-1)return r===!0?He.SEARCH_TYPES.SEARCH_ALL_TO_MAP:He.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Zi[0])<0&&s.indexOf(Zi[1])<0)return c===!0?r===!0?He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:He.SEARCH_TYPES.EQUALS;if(Zi.indexOf(i)>=0&&Zi.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),He.SEARCH_TYPES.CONTAINS;if(Zi.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),He.SEARCH_TYPES.ENDS_WITH;if(Zi.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),He.SEARCH_TYPES.STARTS_WITH;if(s.includes(Zi[0])||s.includes(Zi[1]))return He.SEARCH_TYPES.EQUALS;throw new Error(QM.UNKNOWN_SEARCH_TYPE)}else switch(n){case lc.VALUE_SEARCH_COMPARATORS.BETWEEN:return He.SEARCH_TYPES.BETWEEN;case lc.VALUE_SEARCH_COMPARATORS.GREATER:return He.SEARCH_TYPES.GREATER_THAN;case lc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return He.SEARCH_TYPES.GREATER_THAN_EQUAL;case lc.VALUE_SEARCH_COMPARATORS.LESS:return He.SEARCH_TYPES.LESS_THAN;case lc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return He.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(QM.UNKNOWN_SEARCH_TYPE)}}a(ZM,"createSearchTypeFromSearchObject");eU.exports={executeSearch:JM,createSearchTypeFromSearchObject:ZM,prepSearch:_6,searchByType:XM}});var rU=b((hbe,tU)=>{"use strict";var Ebe=ks(),E6=Bl(),h6=ee(),m6=M(),p6=em();tU.exports=S6;function S6(e,t){if(!h6.isEmpty(t)&&m6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=E6(e,"value");if(n)throw n;return p6.prepSearch(e,t,!0)}a(S6,"lmdbGetDataByValue")});var h_=b((Sbe,nU)=>{"use strict";var pbe=ks(),T6=Bl(),g6=ee(),R6=M(),A6=em();nU.exports=O6;async function O6(e,t){if(!g6.isEmpty(t)&&R6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=T6(e,"value");if(n)throw n;return A6.prepSearch(e,t,!1)}a(O6,"lmdbSearchByValue")});var iU=b((Rbe,sU)=>{"use strict";var gbe=Bt(),uA=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},dA=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},_A=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};sU.exports={SearchByConditionsObject:uA,SearchCondition:dA,SortAttribute:_A}});var uU=b((ybe,lU)=>{"use strict";var Obe=iU().SearchByConditionsObject,b6=ks(),y6=Bl(),fA=vl(),tm=Bt(),{Resource:bbe}=(rs(),ie(EA)),cU=em(),N6=iA(),I6=require("lodash"),{getSchemaPath:w6}=Tt(),oU=Et(),{handleHDBError:C6,hdb_errors:D6}=ce(),{HTTP_STATUS_CODES:P6}=D6,L6=1e8;lU.exports=M6;async function M6(e){let t=y6(e,"conditions");if(t)throw C6(t,t.message,P6.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=w6(e.schema,e.table),n=await oU.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let d of e.conditions)oU.openDBI(n,d.search_attribute);let i=I6.sortBy(e.conditions,d=>{if(d.estimated_count===void 0){let u=d.search_type;u===tm.SEARCH_TYPES.EQUALS?d.estimated_count=fA.count(n,d.search_attribute,d.search_value):u===tm.SEARCH_TYPES.CONTAINS||u===tm.SEARCH_TYPES.ENDS_WITH?d.estimated_count=1/0:d.estimated_count=L6}return d.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await aU(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let d=n.dbis[s.hash_attribute],u=i.slice(1).map(cU.filterByType),_=u.length,E=fA.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>d.get(f,{transaction:o,lazy:!0})),_>0&&(l=l.filter(f=>{for(let h=0;h<_;h++)if(!u[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>N6.parseRow(f,E))}else{for(let _=1;_<i.length;_++){let E=i[_],f=await aU(o,e,E,s.hash_attribute);c=c.concat(f)}let d=new Set,u=e.offset||0;c=c.filter(_=>d.has(_)?!1:(d.add(_),!0)).slice(u,e.limit&&e.limit+u),l=fA.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(M6,"lmdbSearchByConditions");async function aU(e,t,r,n){let s=new b6(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===tm.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,cU.searchByType(e,s,i,n).map(o=>o.value)}a(aU,"executeConditionSearch")});var xl=b((Ibe,dU)=>{"use strict";var U6=M().OPERATIONS_ENUM,hA=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=U6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};dU.exports=hA});var mA=b((Cbe,TU)=>{"use strict";var hU=ks(),mU=xl(),pU=h_(),SU=d_(),cn=M(),_U=ee(),fU=Et(),{getTransactionAuditStorePath:v6,getSchemaPath:B6}=Tt(),EU=V();TU.exports=H6;async function H6(e){try{if(_U.isEmpty(global.hdb_schema[e.schema])||_U.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await x6(e),await F6(e);let t=B6(e.schema,e.table);try{await fU.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")EU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=v6(e.schema,e.table);await fU.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")EU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(H6,"lmdbDropTable");async function x6(e){let t=new hU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await pU(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 mU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await SU(s)}a(x6,"deleteAttributesFromSystem");async function F6(e){let t=new hU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await pU(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 mU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await SU(s)}catch(i){throw i}}a(F6,"dropTableFromSystem")});var RU=b((Pbe,gU)=>{"use strict";var k6=require("fs-extra"),G6=ks(),q6=Hl(),$6=xl(),V6=mA(),Y6=d_(),K6=aA(),W6=h_(),eo=M(),{getSchemaPath:j6}=Tt(),{handleHDBError:Q6,hdb_errors:z6}=ce(),{HDB_ERROR_MSGS:J6,HTTP_STATUS_CODES:X6}=z6;gU.exports=Z6;async function Z6(e){let t;try{t=await e8(e.schema);let r=new G6(eo.SYSTEM_SCHEMA_NAME,eo.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,eo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[eo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await W6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await V6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new $6(eo.SYSTEM_SCHEMA_NAME,eo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Y6(s);let i=j6(t);await k6.remove(i)}catch(r){throw r}}a(Z6,"lmdbDropSchema");async function e8(e){let t=new q6(eo.SYSTEM_SCHEMA_NAME,eo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[eo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await K6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw Q6(new Error,J6.SCHEMA_NOT_FOUND(e),X6.NOT_FOUND,void 0,void 0,!0);return n}a(e8,"validateDropSchema")});var Fl=b((Mbe,AU)=>{"use strict";var pA=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};AU.exports=pA});var TA=b((Bbe,OU)=>{"use strict";var t8=require("fs-extra"),rm=Et(),{getTransactionAuditStorePath:r8}=Tt(),SA=Bt(),vbe=Fl();OU.exports=n8;async function n8(e){let t;try{let r=r8(e.schema,e.table);await t8.mkdirp(r),t=await rm.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{rm.createDBI(t,SA.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),rm.createDBI(t,SA.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),rm.createDBI(t,SA.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME,!0,!1)}catch(r){throw r.message=`unable to create dbi for ${e.schema}.${e.table} due to: ${r.message}`,r}return t}a(n8,"createTransactionsAuditEnvironment")});var NU=b((Fbe,yU)=>{"use strict";var gA=M(),bU=Et(),s8=za(),{getSystemSchemaPath:i8,getSchemaPath:o8}=Tt(),xbe=Qi(),a8=bh(),RA=Oh(),c8=V(),l8=TA();yU.exports=u8;async function u8(e,t){let r=o8(t.schema,t.table),n=new RA(t.schema,t.table,gA.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new RA(t.schema,t.table,gA.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new RA(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await bU.createEnvironment(r,t.table),e!==void 0){let o=await bU.openEnvironment(i8(),gA.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await s8.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await AA(n),await AA(s),await AA(i)}await l8(t)}catch(o){throw o}}a(u8,"lmdbCreateTable");async function AA(e){try{await a8(e)}catch(t){c8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(AA,"createAttribute")});var wU=b((Gbe,IU)=>{"use strict";var d8=Zd(),_8=t_(),f8=jh(),m_=M(),E8=za().updateRecords,h8=Et(),{getSchemaPath:m8}=Tt(),p8=l_(),S8=V();IU.exports=T8;async function T8(e){try{let{schema_table:t,attributes:r}=d8(e);_8(e,r,t.hash_attribute),e.schema!==m_.SYSTEM_SCHEMA_NAME&&(r.includes(m_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(m_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(m_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(m_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await f8(e.hdb_auth_header,t,r),s=m8(e.schema,e.table),i=await h8.openEnvironment(s,e.table),o=await E8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await p8(e,o)}catch(c){S8.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(T8,"lmdbUpdateRecords")});var DU=b(($be,CU)=>{"use strict";var g8=M().OPERATIONS_ENUM,OA=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=g8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};CU.exports=OA});var LU=b((Kbe,PU)=>{"use strict";var Ybe=DU(),R8=Zd(),A8=t_(),O8=jh(),p_=M(),b8=za().upsertRecords,y8=Et(),{getSchemaPath:N8}=Tt(),I8=l_(),w8=V(),{handleHDBError:C8,hdb_errors:D8}=ce();PU.exports=P8;async function P8(e){let t;try{t=R8(e)}catch(l){throw C8(l,l.message,D8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;A8(e,n,r.hash_attribute),e.schema!==p_.SYSTEM_SCHEMA_NAME&&(n.includes(p_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(p_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(p_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(p_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await O8(e.hdb_auth_header,r,n),i=N8(e.schema,e.table),o=await y8.openEnvironment(i,e.table),c=await b8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await I8(e,c)}catch(l){w8.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(P8,"lmdbUpsertRecords")});var UU=b((jbe,MU)=>{"use strict";var bA=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};MU.exports=bA});var BU=b((zbe,vU)=>{"use strict";var yA=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}};vU.exports=yA});var FU=b((Zbe,xU)=>{"use strict";var NA=Et(),{getTransactionAuditStorePath:L8}=Tt(),Xbe=UU(),S_=Bt(),M8=ee(),HU=BU(),U8=require("util").promisify,v8=U8(setTimeout),B8=1e4,H8=100;xU.exports=x8;async function x8(e){let t=L8(e.schema,e.table),r=await NA.openEnvironment(t,e.table,!0),n=NA.listDBIs(r);NA.initializeDBIs(r,S_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new HU;do s=await F8(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 v8(H8);while(s.transactions_deleted>0);return i}a(x8,"deleteAuditLogsBefore");async function F8(e,t){let r=new HU;try{let n=e.dbis[S_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[S_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];M8.isEmpty(c)||(s=e.dbis[S_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[S_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>B8)break}return await s,r}catch(n){throw n}}a(F8,"deleteTransactions")});var GU=b((tye,kU)=>{"use strict";var IA=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};kU.exports=IA});var $U=b((sye,qU)=>{"use strict";var k8=ks(),G8=xl(),nye=GU(),Si=M(),q8=ee(),wA=Et(),$8=Qi(),V8=h_(),Y8=d_(),{getSchemaPath:K8}=Tt();qU.exports=W8;async function W8(e,t=!0){let r;e.schema===Si.SYSTEM_SCHEMA_NAME?r=$8[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await Q8(e),s=K8(e.schema,e.table),i=await wA.openEnvironment(s,e.table);return t===!0&&await j8(e,i,r.hash_attribute),wA.dropDBI(i,e.attribute),n}a(W8,"lmdbDropAttribute");async function j8(e,t,r){let n=wA.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let d={};for(let u in c)u!==i&&(d[u]=c[u]);s=t.dbis[r].put(o,d,l)}await s}a(j8,"removeAttributeFromAllObjects");async function Q8(e){let t=new k8(Si.SYSTEM_SCHEMA_NAME,Si.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Si.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Si.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Si.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await V8(t)).filter(o=>o[Si.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(q8.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Si.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new G8(Si.SYSTEM_SCHEMA_NAME,Si.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Y8(i)}a(Q8,"dropAttributeFromSystem")});var QU=b((aye,jU)=>{"use strict";var CA=Et(),kl=Bt(),oye=nn(),DA=M(),VU=ee(),{getTransactionAuditStorePath:z8}=Tt(),J8=vl(),nm=Ll(),X8=V();jU.exports=Z8;async function Z8(e){let t=z8(e.schema,e.table),r=await CA.openEnvironment(t,e.table,!0),n=CA.listDBIs(r);CA.initializeDBIs(r,kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case DA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return YU(r,e.search_values);case DA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,t9(r,e.search_values,s);case DA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return e9(r,e.search_values);default:return YU(r)}}a(Z8,"readAuditLog");function YU(e,t=[0,Date.now()]){VU.isEmpty(t[0])&&(t[0]=0),VU.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new nm,s))}a(YU,"searchTransactionsByTimestamp");function e9(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[kl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,WU(e,i))}return Object.fromEntries(r)}a(e9,"searchTransactionsByUsername");function t9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let d=t[c],u=J8.equals(e,kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,kl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,d);for(let{value:_}of u){let E=Number(_);n.has(E)?n.get(E).push(d.toString()):n.set(E,[d.toString()])}}let s=Array.from(n.keys()),i=WU(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],d=l.timestamp,u=n.get(d);KU(l,"records",r,u,o),KU(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(t9,"searchTransactionsByHashValues");function KU(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let d=s.get(l),u=d[d.length-1];if(u.timestamp===i)u[t]=[c];else{let _=new nm(e.operation,e.user_name,i,void 0);_[t]=[c],d.push(_)}}else{let d=new nm(e.operation,e.user_name,i,void 0);d[t]=[c],s.set(l,[d])}}}a(KU,"loopRecords");function WU(e,t){let r=[];try{let n=e.dbis[kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new nm,i);r.push(o)}}catch(i){X8.warn(i)}return r}catch(n){throw n}}a(WU,"batchSearchTransactions")});var JU=b((dye,zU)=>{"use strict";var{getSchemaPath:lye}=Tt(),uye=Et(),{database:r9}=(Le(),ie(lt));zU.exports={writeTransaction:n9};async function n9(e,t,r){return r9({database:e,table:t}).transaction(r)}a(n9,"writeTransaction")});var tv=b((fye,ev)=>{"use strict";var{getSchemaPath:XU}=Tt(),ZU=Et();ev.exports={flush:s9,resetReadTxn:i9};async function s9(e,t){return(await ZU.openEnvironment(XU(e,t),t.toString())).flushed}a(s9,"flush");async function i9(e,t){try{(await ZU.openEnvironment(XU(e,t),t.toString())).resetReadTxn()}catch{}}a(i9,"resetReadTxn")});var iv=b((hye,sv)=>{"use strict";var{Readable:o9}=require("stream"),{getDatabases:a9}=(Le(),ie(lt)),{readSync:c9,openSync:l9,createReadStream:rv}=require("fs"),{open:u9}=require("lmdb"),nv=Kd(),d9=Wd(),{AUDIT_STORE_OPTIONS:_9}=(Wi(),ie(ov)),{INTERNAL_DBIS_NAME:f9,AUDIT_STORE_NAME:E9}=Bt();sv.exports=m9;var PA=32768,h9=100;async function m9(e){let t=e.database||e.schema||"data",r=a9()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let d=r[s[0]];if(!d)throw new Error(`Can not find table ${s[0]}`);let u=d.dbisDB,_=u9({noSync:!0,maxDbs:d9.MAX_DBS}),E,f=_.openDB(f9,new nv(!1)),h=u.useReadTransaction(),p=0,T=a(async function(S,C){C.encoding="binary",C.encoder=void 0;let y=_.openDB(S,C),x=u.openDB(S,C);for(let{key:F,version:Y,value:$}of x.getRange({start:null,transaction:h,versions:x.useVersions}))E=y.put(F,$,Y),p++%h9===0&&(await new Promise(Z=>setTimeout(Z,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:S,value:C}of u.getRange({transaction:h,start:!1}))if(s.some(y=>S.startsWith?.(y+"/"))){f.put(S,C);let[,y]=S.split("/"),x=!y,F=new nv(!x,x);await T(S,F)}e.include_audit&&await T(E9,{..._9}),await E;let g=rv(_.path);return g.headers=l(),g.on("close",()=>{h.done(),_.close()}),g}let o=r[Object.keys(r)[0]].primaryStore,c=l9(o.path);return o.transaction(()=>{let d=Buffer.alloc(PA);c9(c,d,0,PA),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let _=rv(null,{fd:c,start:PA}),E=new o9.from(async function*(){yield d;for await(let f of _)u.openTimer&&(u.openTimer=0),yield f;u.done()}());return E.headers=l(),E});function l(){let d=new Map;return d.set("content-type","application/octet-stream"),d.set("content-disposition",`attachment; filename="${t}"`),d.set("date",n),d}}a(m9,"getBackup")});var lv=b((pye,cv)=>{"use strict";var p9=V(),{handleHDBError:S9}=ce(),T9=bD(),g9=bh(),R9=eA(),A9=RM(),O9=d_(),b9=aA(),y9=WM(),N9=rU(),I9=h_(),w9=uU(),C9=RU(),D9=NU(),P9=wU(),L9=LU(),M9=FU(),U9=mA(),v9=$U(),B9=QU(),H9=JU(),av=tv(),x9=iv(),LA=class extends T9{static{a(this,"LMDBBridge")}async searchByConditions(t){return w9(t)}async getDataByHash(t){return await b9(t)}async searchByHash(t){return await y9(t)}async getDataByValue(t,r){return await N9(t,r)}async searchByValue(t){return await I9(t)}async createSchema(t){return await A9(t)}async dropSchema(t){return await C9(t)}async createTable(t,r){return await D9(t,r)}async dropTable(t){return await U9(t)}async createAttribute(t){return await g9(t)}async createRecords(t){return await R9(t)}async updateRecords(t){return await P9(t)}async upsertRecords(t){try{return await L9(t)}catch(r){throw S9(r,null,null,p9.ERR,r)}}async deleteRecords(t){return await O9(t)}async dropAttribute(t){return await v9(t)}async deleteAuditLogsBefore(t){return await M9(t)}async readAuditLog(t){return await B9(t)}writeTransaction(t,r,n){return H9.writeTransaction(t,r,n)}flush(t,r){return av.flush(t,r)}resetReadTxn(t,r){return av.resetReadTxn(t,r)}getBackup(t){return x9(t)}};cv.exports=LA});function pv(e){UA=e}function q9(){G9=setInterval(function(){for(let e of MA)if(e.stale){let t=e[xe]?.url;fv.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},k9).unref()}var vA,_v,fv,Ev,hv,mv,uv,MA,F9,T_,dv,UA,uc,sm,k9,G9,im=Ce(()=>{vA=B(nn()),_v=B(ce()),fv=B(V());rs();Ev=B(te()),hv=B(M()),mv=B(ee()),uv=100,MA=new Set,F9=(0,mv.convertToMS)(Ev.get(hv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(pv,"replicationConfirmation");uc=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),MA.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(MA.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(T_&&!this.overloadChecked&&performance.now()-dv>F9)throw new _v.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp=t.timestamp||(0,vA.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let _=this.validated;this.validated=this.writes.length;for(let f=_;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=_;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let p=_;p<this.validated;p++){let T=this.writes[p];if(!T)continue;let g=T[f===0?"before":"beforeIntermediate"];if(g){let S=g();h?h.push?h.push(S):h=[h,S]:h=S}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(_){throw this.abort(),_}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(_=>_);let c=a(_=>{_.commit(r,_.entry,n)},"doWrite"),l=a(()=>{let _=this.writes[o++];if(_)if(_.key){n>0&&(_.entry=_.store.getEntry(_.key));let E=_.store.ifVersion(_.key,_.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),d=this.lmdbDb;if(this.writes.length>0&&(d?.retryRisk&&(d.retryRisk*=.99),this.writes.length+(d?.retryRisk||0)<uv>>n?l():s=this.writes[0].store.transaction(()=>{for(let _ of this.writes)_.entry=_.store.getEntry(_.key),c(_);return!0})),s)return T_||(T_=s,dv=performance.now(),T_.then(()=>{T_=null})),s.then(_=>{if(_){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let E=this.writes[0].store.rootStore.databaseName,f=this.writes[this.writes.length-1];UA&&f&&i.push(UA(E,f.store.getEntry(f.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return d&&(d.retryRisk=(d.retryRisk||0)+uv/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let u={txnTime:r};if(this.next){let _=this.next?.commit(t);if(_?.then)return _?.then(E=>({txnTime:r,next:E}));u.next=_}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},sm=class extends uc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,vA.getNextMonotonicTime)())}getReadTxn(){}},k9=3e4;a(q9,"startMonitoringTxns");q9()});function wt(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new uc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[xe]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var Sv,dc=Ce(()=>{Sv=B(Yi());rs();im();a(wt,"transaction");(0,Sv._assignPackageExport)("transaction",wt);wt.commit=function(e){let t=(e[xe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};wt.abort=function(e){let t=(e[xe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var Iv={};tt(Iv,{ResourceBridge:()=>xA});function FA({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 gv(e,t){let r=Ti(e),n=FA(e,r);if(!r)throw new Gs.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user},o;wt(i,()=>new Promise(d=>o=d));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let d=c[l++],u=await r.get({id:d,lazy:s,select:n},i);return u=u&&am(u),t?{value:{key:d,value:u}}:{value:u}}else return o(),{done:!0}},return(d){return o(),{value:d,done:!0}},throw(d){return o(),{done:!0}}}}}}function Ti(e){let t=e.database||e.schema||V9,r=ht()[t];if(!r)throw(0,Gs.handleHDBError)(new Error,$9.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Rv(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*Av(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:d,value:u}=o;if(s?.timestamp===d)s.hash_values.push(l),s.records.push(u);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:d,hash_values:[l],records:[u]}}}s&&(yield s)}var Ov,om,Gs,bv,yv,qs,BA,HA,Nv,$9,V9,Y9,K9,Tv,xA,wv=Ce(()=>{"use strict";Ov=B(lv()),om=B(Bl()),Gs=B(ce());Le();bv=B(Zd()),yv=B(t_()),qs=B(M()),BA=B(Xi()),HA=B(Fs()),Nv=B(ee());dc();cm();({HDB_ERROR_MSGS:$9}=Gs.hdb_errors),V9="data",Y9=1e4,K9=10,xA=class extends Ov.default{static{a(this,"ResourceBridge")}constructor(t){super(t),Tv=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,om.default)(t,"conditions");if(r)throw(0,Gs.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Ti(t);if(!n)throw new Gs.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:FA(t,n),sort:t.sort,allowFullScan:!0})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Gs.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ft({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await Ti(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Ti(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(d=>{if(!d){let{value:u,version:_}=r.primaryStore.getEntry(o);return i(o,u,_)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(d=>setImmediate(d));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Ti(t).dropTable()}createSchema(t){return Gl({database:t.schema,table:null}),BA.signalSchemaChange(new HA.SchemaEventMsg(process.pid,qs.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await kA(t.schema),BA.signalSchemaChange(new HA.SchemaEventMsg(process.pid,qs.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,Tv.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,bv.default)(t);(0,yv.default)(t,n,r.primaryKey);let s,i=ht()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),wt(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],d=[];for(let u of t.records){let _=await i.get(u[i.primaryKey],o);if(t.requires_existing&&!_||t.requires_no_existing&&_){d.push(u[i.primaryKey]);continue}_&&(_=am(_));for(let E in u)if(Object.prototype.hasOwnProperty.call(u,E)){let f=u[E];if(typeof f=="function")try{let h=f([[_]]);Array.isArray(h)&&(f=h[0].func_val,u[E]=f)}catch(h){throw h.message+="Trying to set key "+E+" on object"+JSON.stringify(u),h}}if(_)for(let E in _)Object.prototype.hasOwnProperty.call(u,E)||(u[E]=_[E]);await i.put(u,o),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:d}})}async deleteRecords(t){let r=ht()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),wt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return Rv(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=ht()[t.schema][t.table];if(!r.createdTimeProperty)throw new Gs.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:qs.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],d=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,Nv.async_set_timeout)(K9),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%Y9===0&&await d();return l.length>0&&await d(),s?Rv(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,om.default)(t,"hashes");if(r)throw r;return gv(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of gv(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&qs.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,om.default)(t,"value");if(n)throw n;let s=Ti(t);if(!s)throw new Gs.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===qs.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:FA(t,s)})}async getDataByValue(t,r){let n=new Map,s=Ti(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){Ti({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Ti(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=Ti(t),n={};switch(t.search_type){case qs.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case qs.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of Av(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return Av(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(FA,"getSelect");a(gv,"getRecords");a(Ti,"getTable");a(Rv,"createDeleteResponse");a(Av,"groupRecordsInHistory")});var Pn=b((Lye,Cv)=>{"use strict";var{ResourceBridge:W9}=(wv(),ie(Iv)),j9=te();j9.initSync();var lm;function Q9(){return lm||(lm=new W9,lm)}a(Q9,"getBridge");Cv.exports=Q9()});var Mv=b((Uye,Lv)=>{"use strict";var Dv=require("lodash"),g_=require("mathjs"),z9=require("jsonata"),Pv=ee();Lv.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?Dv.uniqWith(e,Dv.isEqual):e,searchJSON:J9,mad:R_.bind(null,g_.mad),mean:R_.bind(null,g_.mean),mode:R_.bind(null,g_.mode),prod:R_.bind(null,g_.prod),median:R_.bind(null,g_.median)};function R_(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(R_,"aggregateFunction");function J9(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(Pv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Pv.isEmpty(this.__ala__.res[r])){let n=z9(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(J9,"searchJSON")});var vv=b((Bye,Uv)=>{"use strict";var nr=require("moment"),GA="YYYY-MM-DDTHH:mm:ss.SSSZZ";nr.suppressDeprecationWarnings=!0;Uv.exports={current_date:()=>nr().utc().format("YYYY-MM-DD"),current_time:()=>nr().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return nr(e).utc().format("YYYY");case"month":return nr(e).utc().format("MM");case"day":return nr(e).utc().format("DD");case"hour":return nr(e).utc().format("HH");case"minute":return nr(e).utc().format("mm");case"second":return nr(e).utc().format("ss");case"millisecond":return nr(e).utc().format("SSS");default:break}},date:e=>nr(e).utc().format(GA),date_format:(e,t)=>nr(e).utc().format(t),date_add:(e,t,r)=>nr(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>nr(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=nr(e).utc(),s=nr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>nr().utc().valueOf(),get_server_time:()=>nr().format(GA),offset_utc:(e,t)=>nr(e).utc().utcOffset(t).format(GA)}});var Fv=b((Hye,xv)=>{"use strict";var X9=require("@turf/area"),Z9=require("@turf/length"),e7=require("@turf/circle"),t7=require("@turf/difference"),r7=require("@turf/distance"),n7=require("@turf/boolean-contains"),s7=require("@turf/boolean-equal"),i7=require("@turf/boolean-disjoint"),o7=require("@turf/helpers"),Bv=M(),Ge=ee(),to=V();xv.exports={geoArea:a7,geoLength:c7,geoCircle:l7,geoDifference:u7,geoDistance:Hv,geoNear:d7,geoContains:_7,geoEqual:f7,geoCrosses:E7,geoConvert:h7};function a7(e){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return X9.default(e)}catch(t){return to.trace(t,e),NaN}}a(a7,"geoArea");function c7(e,t){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return Z9.default(e,{units:t||"kilometers"})}catch(r){return to.trace(r,e),NaN}}a(c7,"geoLength");function l7(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return e7.default(e,t,{units:r||"kilometers"})}catch(n){return to.trace(n,e,t),NaN}}a(l7,"geoCircle");function u7(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 t7(e,t)}catch(r){return to.trace(r,e,t),NaN}}a(u7,"geoDifference");function Hv(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return r7.default(e,t,{units:r||"kilometers"})}catch(n){return to.trace(n,e,t),NaN}}a(Hv,"geoDistance");function d7(e,t,r,n){if(Ge.isEmpty(e)||Ge.isEmpty(t))return!1;if(Ge.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return Hv(e,t,n)<=r}catch(s){return to.trace(s,e,t),!1}}a(d7,"geoNear");function _7(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 n7.default(e,t)}catch(r){return to.trace(r,e,t),!1}}a(_7,"geoContains");function f7(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 s7.default(e,t)}catch(r){return to.trace(r,e,t),!1}}a(f7,"geoEqual");function E7(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!i7.default(e,t)}catch(r){return to.trace(r,e,t),!1}}a(E7,"geoCrosses");function h7(e,t,r){if(Ge.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Ge.isEmpty(t))throw new Error("geo_type is required");if(Ge.isEmpty(Bv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Bv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ge.autoCastJSON(e)),o7[t](e,r)}a(h7,"geoConvert")});var um=b((Fye,kv)=>{var _c=Mv(),xn=vv(),gi=Fv();kv.exports=e=>{e.aggr.mad=e.aggr.MAD=_c.mad,e.aggr.mean=e.aggr.MEAN=_c.mean,e.aggr.mode=e.aggr.MODE=_c.mode,e.aggr.prod=e.aggr.PROD=_c.prod,e.aggr.median=e.aggr.MEDIAN=_c.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=_c.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=_c.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=xn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=xn.current_time,e.fn.extract=e.fn.EXTRACT=xn.extract,e.fn.date=e.fn.DATE=xn.date,e.fn.date_format=e.fn.DATE_FORMAT=xn.date_format,e.fn.date_add=e.fn.DATE_ADD=xn.date_add,e.fn.date_sub=e.fn.DATE_SUB=xn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=xn.date_diff,e.fn.now=e.fn.NOW=xn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=xn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=xn.get_server_time,e.fn.getdate=e.fn.GETDATE=xn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=xn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=gi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=gi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=gi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=gi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=gi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=gi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=gi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=gi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=gi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=gi.geoNear}});var Vv=b((kye,$v)=>{"use strict";var A_=require("lodash"),ln=require("alasql");ln.options.cache=!1;var m7=um(),Gv=require("clone"),dm=require("recursive-iterator"),Me=V(),Ze=ee(),ql=Pn(),p7=M(),{hdb_errors:S7}=ce(),{getDatabases:qv}=(Le(),ie(lt)),T7="IS NULL",$s="There was a problem performing this search. Please check the logs and try again.";m7(ln);var qA=class{static{a(this,"SQLSearch")}constructor(t,r){if(Ze.isEmpty(t))throw Me.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 Me.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Me.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Me.error(n),new Error($s)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Me.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Me.error(n),new Error($s)}if(Object.keys(this.data).length===0)return Me.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Me.error("Error thrown from processJoins in SQLSearch class method search."),Me.error(n),new Error($s)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Me.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Me.error(n),new Error($s)}try{return t=await this._finalSQL(),t}catch(n){throw Me.error("Error thrown from finalSQL in SQLSearch class method search."),Me.error(n),new Error($s)}}_getColumns(){let t=new dm(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(Gv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=A_.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=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)){Me.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new dm(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Ze.isEmpty(r)&&r.right)if(Ze.isNotEmptyAndHasValue(r.right.value)){let n=Ze.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new ln.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Ze.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new ln.yy.LogicValue({value:i}):n instanceof ln.yy.StringValue&&Ze.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new ln.yy.NumValue({value:i}))});if(t){Me.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new dm(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!Ze.isEmpty(p7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Ze.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Ze.isEmptyOrZeroLength(r.left.columnid)||Ze.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(Ze.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!Ze.isEmpty(r.right.value)||!Ze.isEmpty(r.left.value)?n.add(Ze.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let d=0;d<l.length;d++)if(l[d].value)n.add(l[d].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Ze.isEmptyOrZeroLength(this.all_table_attributes)&&Ze.isEmptyOrZeroLength(this.statement.from)&&Ze.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&A_.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(Ze.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Ze.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(Ze.isEmptyOrZeroLength(this.all_table_attributes)&&!Ze.isEmptyOrZeroLength(this.columns.columns))return t;if(Ze.isEmptyOrZeroLength(this.all_table_attributes)&&Ze.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await ln.promise(r)}catch(r){throw Me.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Me.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(T7)>-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=A_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,d=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!Ze.isEmpty(this.exact_search_values[d])&&!this.exact_search_values[d].ignore&&!Ze.isEmptyOrZeroLength(this.exact_search_values[d].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[d].values);let u=await ql.getDataByHash(c);for(let _ of c.hash_values)u.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(u){throw Me.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Me.error(u),new Error($s)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[d].values).map(async u=>{let _={...c};_.search_value=u;let E=await ql.getDataByValue(_);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(u){throw Me.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Me.error(u),new Error($s)}else if(!Ze.isEmpty(this.comparator_search_values[d])&&!this.comparator_search_values[d].ignore&&!Ze.isEmptyOrZeroLength(this.comparator_search_values[d].comparators))try{let u=this.comparator_search_values[d].comparators;for(let _=0,E=u.length;_<E;_++){let f=u[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await ql.getDataByValue(c,f.operation);if(l)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,T]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,T[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,T[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(u){throw Me.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Me.error(u),new Error($s)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await ql.getDataByValue(c);if(l)for(let[_]of u)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of u)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(u){throw Me.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Me.error(u),new Error($s)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof ln.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new ln.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new ln.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new ln.yy.FuncValue:new ln.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,p=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${p}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${p}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let d="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(d="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let u="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",_=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${d} ${u} ${_}`,h=this._convertColumnsToIndexes(f,s);E=await ln.promise(h,t),t=null}catch(f){throw Me.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Me.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let p=E[f];o.forEach(T=>{p[T.key]!==null&&p[T.key]!==void 0&&T.keys.add(p[T.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),p=A_.difference(h,[...f.keys].map(T=>T.toString()));for(let T=0,g=p.length;T<g;T++){let S=p[T];delete this.data[`${f.schema}_${f.table}`].__merged_data[S]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new dm(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=A_.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw Me.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Me.error(i),new Error($s)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let u in i)o.push(i[u][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await ql.getDataByHash(c),d=s.columns.length;for(let u=0,_=o.length;u<_;u++){let E=o[u],f=l.get(E);for(let h=0;h<d;h++){let p=s.columns[h],T=f[p]===void 0?null:f[p];this.data[n].__merged_data[E].push(T)}}}}catch(r){throw Me.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Me.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();Me.trace(`Final SQL: ${s}`),n=await ln.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Me.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Me.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Me.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 Me.error(S7.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Me.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],d=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(d,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),d=`[${c}]`;n=n.replace(l,d)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await ql.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 Me.error("There was an error when processing this SQL operation. Check your logs"),Me.error(o),new Error($s)}}return Object.values(Object.values(this.data)[0].__merged_data)}};$v.exports=qA});var Yr=b((qye,Yv)=>{"use strict";var g7=AD();Yv.exports={searchByConditions:A7,searchByHash:O7,searchByValue:b7,search:y7};var $A=Pn(),{transformReq:VA}=ee(),R7=Vv();async function A7(e){return VA(e),$A.searchByConditions(e)}a(A7,"searchByConditions");async function O7(e){VA(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of $A.searchByHash(e))r&&t.push(r);return t}a(O7,"searchByHash");async function b7(e){VA(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of $A.searchByValue(e))t.push(r);return t}a(b7,"searchByValue");function y7(e,t){try{let r=new g7(e);r.validate(),new R7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(y7,"search")});var _m=b((Vye,Kv)=>{"use strict";var N7=Pn();Kv.exports={writeTransaction:I7};function I7(e,t,r){return N7.writeTransaction(e,t,r)}a(I7,"writeTransaction")});var zv=b((Wye,Qv)=>{"use strict";var w7=Yr(),C7=is(),Wv=V(),D7=Kr(),Kye=_m(),P7=require("clone"),KA=require("alasql"),L7=um(),jv=require("util"),M7=jv.promisify(C7.getTableSchema),U7=jv.promisify(w7.search),v7=M(),YA=ee();L7(KA);Qv.exports={update:H7};var B7="There was a problem performing this update. Please check the logs and try again.";async function H7({statement:e,hdb_user:t}){let r=await M7(e.table.databaseid,e.table.tableid),n=x7(e.columns);YA.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=P7(s),c=YA.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,d=KA.parse(l).statements[0],u=await U7(d),_=F7(n,u);return k7(o,_,t)}a(H7,"update");function x7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=KA.compile(`SELECT ${r.expression.toString()} AS [${v7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw Wv.error(t),new Error(B7)}}a(x7,"createUpdateRecord");function F7(e,t){return YA.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(F7,"buildUpdateRecords");async function k7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await D7.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){Wv.error(`Error delete new_attributes from update response: ${i}`)}return s}a(k7,"updateRecords")});var Xv=b((Jye,Jv)=>{var G7=require("alasql"),q7=Yr(),$7=V(),V7=Pn(),jA=require("util"),WA=ee(),Y7=M(),K7=is(),Qye=_m(),zye=Kr(),W7="record",j7="successfully deleted",Q7=jA.callbackify(Z7),z7=jA.promisify(q7.search),J7=jA.promisify(K7.getTableSchema);Jv.exports={convertDelete:Q7};function X7(e){return`${e.deleted_hashes.length} ${W7}${e.deleted_hashes.length===1?"":"s"} ${j7}`}a(X7,"generateReturnMessage");async function Z7({statement:e,hdb_user:t}){let r=await J7(e.table.databaseid,e.table.tableid);WA.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=WA.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=G7.parse(o).statements[0],l={operation:Y7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await z7(c);let d=await V7.deleteRecords(l);return WA.isEmptyOrZeroLength(d.message)&&(d.message=X7(d)),delete d.txn_time,d}catch(d){throw $7.error(d),d.hdb_code?d.message:d}}a(Z7,"convertDelete")});var n0=b((Zye,r0)=>{"use strict";var eee=Ei(),{hdb_errors:Zv}=ce(),{getDatabases:e0}=(Le(),ie(lt));r0.exports={checkSchemaExists:t0,checkSchemaTableExists:tee,schema_describe:eee};async function t0(e){if(!e0()[e])return Zv.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(t0,"checkSchemaExists");async function tee(e,t){let r=await t0(e);if(r)return r;if(!e0()[e][t])return Zv.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(tee,"checkSchemaTableExists")});var $l=b((tNe,ree)=>{ree.exports={name:"harperdb",version:"4.4.0-beta.1",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc --no-clean --reporter=lcovonly npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:replication && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test",format:"prettier .","format:fix":"npm run format -- --write",lint:"eslint . --ignore-path .gitignore --ignore-pattern 'studio/' --ignore-pattern 'application-template/'","lint:fix":"npm run lint -- --fix"},dependencies:{"@aws-sdk/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.6.0",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.28.1","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.9.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.1.2",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.0",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.1",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^1.1.0","serve-static":"2.1.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.23.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.5.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^7.18.0","@typescript-eslint/parser":"^7.18.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",eslint:"^8.57.0","eslint-config-prettier":"8.3.0","eslint-plugin-sonarjs":"^2.0.2",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^10.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"3.3.3",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.4.2","why-is-node-still-running":"^1.0.0"},overrides:{alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var I_={};tt(I_,{addAnalyticsListener:()=>N_,recordAction:()=>Tr,recordActionBinary:()=>Fn,setAnalyticsEnabled:()=>nee});function nee(e){_0=e}function Tr(e,t,r,n,s){if(!_0)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=hm.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let d=c;o.values=c=new Float32Array(l*2),c.set(d),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},hm.set(i,o)}fm||see()}function Fn(e,t,r,n,s){Tr(!!e,t,r,n,s)}function N_(e){h0.push(e)}function see(){fm=performance.now(),setTimeout(async()=>{let e=performance.now()-fm;fm=0;let t=[],r={time:Date.now(),period:e,threadId:fc.threadId,metrics:t};for(let[s,i]of hm){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,d=[],u;for(let _ of m0){let E=Math.floor(c*_),f=o[E-1];if(E>l){let h=E-l;if(f===u){let p=d[d.length-1];typeof p=="number"?d[d.length-1]={value:p,count:1+h}:p.count+=h}else d.push(h>1?{value:f,count:h}:f),u=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:d,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await p0()}let n=process.memoryUsage();t.push({metric:"memory",threadId:fc.threadId,byThread:!0,...n});for(let s of h0)s(t);hm=new Map,fc.parentPort?fc.parentPort.postMessage({type:E0,report:r}):g0({report:r})},f0).unref()}async function iee(e,t=6e4){let r=JA(),n=S0(),s=new Promise(p=>{let T=performance.now();setImmediate(()=>{let g=performance.now();g-T>5e3&&(0,O_.warn)("Unusually high event queue latency on the main thread of "+Math.round(g-T)+"ms"),T=performance.now()}),n.primaryStore.prefetch([1],()=>{let g=performance.now();g-T>5e3&&(0,O_.warn)("Unusually high task queue latency on the main thread of "+Math.round(g-T)+"ms"),p(g-T)})}),i;for(let p of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(p.value?.time){i=p.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,d=[],u;for(let{key:p,value:T}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!T)continue;if(o){if(p>o+t)break}else o=p;u=p;let{metrics:g,threadId:S}=T;for(let C of g||[]){let{path:y,method:x,type:F,metric:Y,count:$,total:Z,distribution:Q,threads:_e,...K}=C;$||($=1);let se=Y+(y?"-"+y:"");x!==void 0&&(se+="-"+x),F!==void 0&&(se+="-"+F);let le=c.get(se);if(le){if(le.threads){let ve=le.threads[S];if(ve)le=ve;else{le.threads[S]={...K};continue}}le.count||(le.count=1);let we=le.count;for(let ve in K){let et=K[ve];typeof et=="number"&&(le[ve]=(le[ve]*we+et*$)/(we+$))}le.count+=$,Z>=0&&(le.total+=Z,le.ratio=le.total/le.count)}else le={period:t,...C},delete le.distribution,c.set(se,le),le.byThread&&(le.threads=[],le.threads[S]={...K},d.push(le));if(Q){Q=Q.map(ve=>typeof ve=="number"?{value:ve,count:1}:ve);let we=l.get(se);we?we.push(...Q):l.set(se,Q)}}await p0()}for(let p of d){let{path:T,method:g,type:S,metric:C,count:y,total:x,distribution:F,threads:Y,...$}=p;Y=Y.filter(Z=>Z);for(let Z in $){if(typeof p[Z]!="number")continue;let Q=0;for(let _e of Y){let K=_e[Z];typeof K=="number"&&(Q+=K)}p[Z]=Q}p.count=Y.length,delete p.threads,delete p.byThread}for(let[p,T]of l){let g=c.get(p);T.sort((ve,et)=>ve.value>et.value?1:-1);let S=g.count-1,C=[],y=0,x=0,F;for(let ve of m0){let et=S*ve;for(;y<et;)F=T[x++],y+=F.count,x===1&&y--;let va=T[x>1?x-2:0];F||(F=T[0]),C.push(F.value-(F.value-va.value)*(y-et)/F.count)}let[Y,$,Z,Q,_e,K,se,le,we]=C;Object.assign(g,{p1:Y,p10:$,p25:Z,median:Q,p75:_e,p90:K,p95:se,p99:le,p999:we})}let _;for(let[p,T]of c)T.id=(0,Em.getNextMonotonicTime)(),T.time=u,n.primaryStore.put(T.id,T,{append:!0}).then(g=>{g||n.primaryStore.put(T.id,T)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let p=(0,Em.getNextMonotonicTime)(),T={id:p,metric:"main-thread-utilization",idle:f-s0,active:h-i0,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(p,T,{append:!0}).then(g=>{g||n.primaryStore.put(p,T)})}s0=f,i0=h}async function o0(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function JA(){return a0||(a0=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function S0(){return c0||(c0=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function cee(){T0=!0;let e=(0,y_.get)(zA.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await iee(f0,e),await o0(JA(),oee),await o0(S0(),aee)},Math.min(e/2,2147483647)).unref()}function g0(e,t){let r=e.report;r.threadId=t?.threadId||fc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(l0+=n.mean*n.count);r.totalBytesProcessed=l0,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(u0.get(t))}),u0.set(t,t.performance.eventLoopUtilization())),r.id=(0,Em.getNextMonotonicTime)(),JA().primaryStore.put(r.id,r),T0||cee(),lee&&(R0=dee(r))}async function dee(e){if(await R0,!Wo){let r=(0,b_.dirname)((0,O_.getLogFilePath)());try{Wo=await(0,QA.open)((0,b_.join)(r,"analytics.log"),"r+")}catch{Wo=await(0,QA.open)((0,b_.join)(r,"analytics.log"),"w+")}}let t=(await Wo.stat()).size;if(t>uee){let r=Buffer.alloc(t);await Wo.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Wo.write(r,{position:0}),await Wo.truncate(r.length),t=r.length}await Wo.write(JSON.stringify(e)+`
10
- `,t)}var fc,d0,O_,b_,QA,Em,y_,zA,hm,_0,fm,f0,E0,h0,m0,s0,i0,p0,oee,aee,a0,c0,T0,l0,u0,lee,R0,Wo,uee,Ri=Ce(()=>{fc=require("worker_threads"),d0=B(st());Le();O_=B(V()),b_=require("path"),QA=require("fs/promises"),Em=B(nn()),y_=B(te()),zA=B(M());Vr();(0,y_.initSync)();hm=new Map,_0=(0,y_.get)(zA.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(nee,"setAnalyticsEnabled");a(Tr,"recordAction");nt.recordAnalytics=Tr;a(Fn,"recordActionBinary");fm=0,f0=1e3,E0="analytics-report",h0=[];a(N_,"addAnalyticsListener");m0=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(see,"sendAnalytics");a(iee,"aggregation");s0=0,i0=0,p0=a(()=>new Promise(setImmediate),"rest");a(o0,"cleanup");oee=36e5,aee=31536e6;a(JA,"getRawAnalyticsTable");a(S0,"getAnalyticsTable");(0,d0.setChildListenerByType)(E0,g0);a(cee,"startScheduledTasks");l0=0,u0=new Map,lee=!1;a(g0,"recordAnalytics");uee=1e6;a(dee,"logAnalytics")});var rO=b((ENe,M0)=>{"use strict";var{decode:_ee}=require("msgpackr"),{isMainThread:dNe,parentPort:_Ne,threadId:fNe}=require("worker_threads"),Sm=Ft(),Vl=_t(),eO=M(),Jr=V(),ZA=te(),fee=M(),{onMessageByType:Eee}=st(),y0=Ji(),{recordAction:A0,recordActionBinary:hee}=(Ri(),ie(I_)),{publishToStream:mee}=Sm,{ConsumerEvents:O0}=require("nats"),pee=Yr(),{promisify:See}=require("util"),N0=See(setTimeout),Tm=1e4,gm,pm,Tee,gee,I0,w_=new Map,Yl=new Map;M0.exports={initialize:w0,ingestConsumer:tO,setSubscription:Ree,setIgnoreOrigin:bee,getDatabaseSubscriptions:Oee,updateConsumer:C0};async function w0(){Eee(eO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await C0(n)}),I0=!0,Jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await Sm.getNATSReferences();gm=e,pm=e.info.server_name,Tee=t,gee=r}a(w0,"initialize");async function C0(e){if(e.status==="start"){let{js:t,jsm:r}=await D0(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&&(Jr.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")),Yl.get(e.node_domain_name)==="failed"&&Yl.set(e.node_domain_name,"close")}}a(C0,"updateConsumer");var Rm=new Map;function Ree(e,t,r){let n=Rm.get(e);n||Rm.set(e,n=new Map),n.set(t,r),I0||w0().then(Aee)}a(Ree,"setSubscription");async function Aee(){let e=await pee.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Vl.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions)if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await D0(r),!n))break;let{schema:o,table:c}=i,l=y0.createNatsTableStreamName(o,c);tO(l,n,s,r)}}}a(Aee,"accessConsumers");async function D0(e){let t,r,n=1;for(;!r;)try{t=await gm.jetstream({domain:e}),r=await gm.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Yl.get(e)==="close")break;Yl.set(e,"failed"),n%10===1&&Jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<Tm?n++*100:Tm;await N0(i)}return{js:t,jsm:r}}a(D0,"connectToRemoteJS");function Oee(){return Rm}a(Oee,"getDatabaseSubscriptions");var P0;function bee(e){P0=e}a(bee,"setIgnoreOrigin");var L0=100,b0=new Array(L0),mm=0;async function tO(e,t,r,n){let{connection:s}=await Sm.getNATSReferences();gm=s,pm=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,pm),Jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(d){if(Yl.get(n)==="close")break;o%10===1&&Jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",d.message),d.code==="404"&&(Jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await Sm.createConsumer(r,e,pm,new Date(Date.now()).toISOString()));let u=o++*100<Tm?o++*100:Tm;await N0(u)}let c=!1,l;for(;!c;){if(w_.get(e+n)==="close"||Yl.get(n)==="close"){w_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:ZA.get(eO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),w_.set(e+n,l);let d=!1;(async()=>{for await(let u of await l.status())if(u.type===O0.ConsumerDeleted&&(await l.close(),c=!0),u.type===O0.HeartbeatsMissed){let _=u.data;Jr.trace(`${_} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),_===100&&(Jr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),d=!0)}})();try{for await(let u of l)await b0[mm],b0[mm]=yee(u).catch(_=>{Jr.error(_)}),++mm>=L0&&(mm=0)}catch(u){u.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",u)}}}a(tO,"ingestConsumer");async function yee(e){let t=_ee(e.data);A0(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=ZA.get(eO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Vl.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Vl.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Vl.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!P0),hee(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Vl.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:d,records:u,hash_values:_,__origin:E,expiresAt:f}=t;Jr.trace("processing message:",o,c,d,(u?"records: "+u.map(x=>x?.id):"")+(_?"ids: "+_:""),"with sequence:",e.seq),Jr.trace(`messageProcessor nats msg id: ${e.headers.get(Vl.MSG_HEADERS.NATS_MSG_ID)}`);let h;u||(u=_);let p=new Promise(x=>h=x),{timestamp:T,user:g,node_name:S}=E||{},C=Rm.get(c)?.get(d);if(!C)throw new Error("Missing table for replication message",d);if(o==="define_schema")t.type=o,t.onCommit=h,C.send(t);else if(u.length===1&&!l)C.send({type:XA(o),value:u[0],id:_?.[0],expiresAt:f,timestamp:T,table:d,onCommit:h,user:g,nodeName:S});else{let x=u.map((F,Y)=>({type:XA(o),value:F,expiresAt:f,id:_?.[Y],table:d}));for(;l;)x.push({type:XA(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;C.send({type:"transaction",writes:x,table:d,timestamp:T,onCommit:h,user:g,nodeName:S})}ZA.get(fee.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&mee(e.subject.split(".").slice(0,-1).join("."),y0.createNatsTableStreamName(c,d),e.headers,e.data),await p;let y=Date.now()-T;T&&A0(y,"replication-latency",e.subject,o,"ingest")}catch(o){Jr.error(o)}e.ack()}a(yee,"messageProcessor");function XA(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(XA,"convertOperation")});var Ft=b((RNe,z0)=>{"use strict";var gr=te();gr.initSync();var Nee=require("fs-extra"),Iee=require("semver"),P_=require("path"),{monotonicFactory:wee}=require("ulidx"),v0=wee(),Cee=require("util"),B0=require("child_process"),Dee=Cee.promisify(B0.exec),Pee=B0.spawn,Ir=_t(),je=M(),Am=ee(),Vs=V(),Om=Ji(),Lee=_m(),C_=It(),{broadcast:Mee,onMessageByType:Uee,getWorkerIndex:vee}=st(),{isMainThread:H0}=require("worker_threads"),{Encoder:Bee,decode:oO}=require("msgpackr"),x0=new Bee,{isEmpty:pc}=Am,F0=vn(),mNe=48*36e11;H0&&Uee(je.ITC_EVENT_TYPES.RESTART,()=>{un=void 0,mc=void 0});var{connect:Hee,StorageType:xee,RetentionPolicy:Fee,AckPolicy:aO,DeliverPolicy:cO,DiscardPolicy:kee,NatsConnection:pNe,JetStreamManager:SNe,JetStreamClient:TNe,StringCodec:gNe,JSONCodec:Gee,createInbox:lO,headers:qee,ErrorCode:U0}=require("nats"),{PACKAGE_ROOT:$ee}=M(),Vee=$l(),{recordAction:Yee}=(Ri(),ie(I_)),k0=Gee(),Kee="clustering",Wee=Vee.engines[Ir.NATS_SERVER_NAME],jee=P_.join($ee,"dependencies"),iO=P_.join(jee,`${process.platform}-${process.arch}`,Ir.NATS_BINARY_NAME),nO,sO,D_,Ec,hc;z0.exports={runCommand:G0,checkNATSServerInstalled:Qee,createConnection:uO,getConnection:L_,getJetStreamManager:M_,getJetStream:$0,getNATSReferences:Ai,getServerList:Jee,createLocalStream:dO,listStreams:V0,deleteLocalStream:Xee,getServerConfig:Kl,listRemoteStreams:Zee,viewStream:ete,viewStreamIterator:tte,publishToStream:rte,request:ite,reloadNATS:_O,reloadNATSHub:ote,reloadNATSLeaf:ate,extractServerName:ste,requestErrorHandler:cte,createLocalTableStream:j0,createTableStreams:dte,purgeTableStream:Q0,purgeSchemaTableStreams:_te,getStreamInfo:fte,updateLocalStreams:hte,closeConnection:zee,getJsmServerName:bm,addNatsMsgHeader:Y0,clearClientCache:q0,updateRemoteConsumer:lte,createConsumer:K0,updateConsumerIterator:ute};async function G0(e,t=void 0){let{stdout:r,stderr:n}=await Dee(e,{cwd:t});if(n)throw new Error(n.replace(`
10
+ `)},y3="certificate.pem",O3="privateKey.pem",N3="caCertificate.pem",I3="natsCertificate.pem",w3="natsCaCertificate.pem",yt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},C3={tls_certificate:yt.SERVER,tls_certificateAuthority:yt.CA,customFunctions_tls_certificate:yt.SERVER,customFunctions_tls_certificateAuthority:yt.CA,operationsApi_tls_certificate:yt["OPERATIONS-API"],operationsApi_tls_certificateAuthority:yt["OPERATIONS-CA"]},D3={[yt.SERVER]:2,[yt.DEFAULT]:1},P3={[yt["OPERATIONS-API"]]:3,[yt.SERVER]:2,[yt.DEFAULT]:1},L3={[yt["OPERATIONS-API"]]:3,[yt.SERVER]:2,[yt.DEFAULT]:1},M3={[yt["OPERATIONS-CA"]]:3,[yt.CA]:2,[yt["DEFAULT-CA"]]:1},U3={[yt["OPERATIONS-CA"]]:3,[yt.CA]:2,[yt["DEFAULT-CA"]]:1},v3={[yt.CA]:2,[yt["DEFAULT-CA"]]:1};Object.assign(aL,{CERTIFICATE_PEM_NAME:y3,PRIVATEKEY_PEM_NAME:O3,CA_PEM_NAME:N3,CERT_NAME:yt,CERT_CONFIG_NAME_MAP:C3,CERT_PREFERENCE_APP:D3,CERT_PREFERENCE_OPS:P3,CERT_PREFERENCE_REP:L3,CA_CERT_PREFERENCE_REP:M3,CA_CERT_PREFERENCE_OPS:U3,CA_CERT_PREFERENCE_APP:v3,CERTIFICATE_VALUES:b3,NATS_CERTIFICATE_PEM_NAME:I3,NATS_CA_PEM_NAME:w3})});var DR=b((VAe,fL)=>{"use strict";var dL=require("fs-extra"),pe=require("joi"),B3=require("os"),{boolean:Ve,string:It,number:xt,array:rc}=pe.types(),{totalmem:cL}=require("os"),tc=require("path"),H3=V(),CR=J(),$Ae=wR(),lL=M(),x3=ut(),uL="log",k3="components",F3="Invalid logging.rotation.maxSize unit. Available units are G, M or K",G3="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",q3="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",$3="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",V3="rootPath config parameter is undefined",cs=pe.alternatives([xt.min(0),It]).optional().empty(null),xh=pe.alternatives([rc.items(It,{host:It.required(),port:cs},{hostname:It.required(),port:cs}).empty(null),rc.items(It)]),Ei,_L=!1;fL.exports={configValidator:Y3,routesValidator:J3,route_constraints:xh};function Y3(e,t=!1){if(_L=t,Ei=e.rootPath,CR.isEmpty(Ei))throw V3;let r=Ve.optional(),n=xt.min(0).max(1e3).empty(null).default(z3),s=It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(s_),i=It.optional().empty(null),o=It.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=pe.string().empty(null).default(s_),l=pe.custom(W3).empty(null).default(s_),d=e.clustering?.enabled,u=pe.object({certificate:i,certificateAuthority:i,privateKey:i}),_;return d===!0?_=pe.object({enabled:r,hubServer:pe.object({cluster:pe.object({name:pe.required().empty(null),network:pe.object({port:cs,routes:xh}).required()}).required(),leafNodes:pe.object({network:pe.object({port:cs}).required()}).required(),network:pe.object({port:cs}).required()}).required(),leafServer:pe.object({network:pe.object({port:cs,routes:xh}).required(),streams:pe.object({maxAge:xt.min(120).allow(null).optional(),maxBytes:xt.min(1).allow(null).optional(),maxMsgs:xt.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:pe.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:Ve.optional(),databaseLevel:Ve.optional(),tls:pe.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Ve.required(),verify:Ve.optional()}),user:It.optional().empty(null)}).optional():_=pe.object({enabled:r,tls:pe.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Ve.optional()})}).optional(),pe.object({authentication:pe.object({authorizeLocal:Ve,cacheTTL:xt.required(),enableSessions:Ve}),analytics:pe.object({aggregatePeriod:xt}),replication:pe.object({hostname:pe.alternatives(It,xt).optional().empty(null),url:It.optional().empty(null),port:xt.optional().empty(null),securePort:xt.optional().empty(null),routes:rc.optional().empty(null),databases:pe.alternatives(It,rc),enableRootCAs:Ve.optional()}),componentsRoot:s.optional(),clustering:_,localStudio:pe.object({enabled:r}).required(),logging:pe.object({auditAuthEvents:pe.object({logFailed:Ve,logSuccessful:Ve}),file:Ve.required(),level:pe.valid("notify","fatal","error","warn","info","debug","trace"),rotation:pe.object({enabled:Ve.optional(),compress:Ve.optional(),interval:It.custom(Q3).optional().empty(null),maxSize:It.custom(j3).optional().empty(null),path:It.optional().empty(null).default(s_)}).required(),root:s,stdStreams:Ve.required(),auditLog:Ve.required()}).required(),operationsApi:pe.object({network:pe.object({cors:Ve.optional(),corsAccessList:rc.optional(),headersTimeout:xt.min(1).optional(),keepAliveTimeout:xt.min(1).optional(),port:cs,domainSocket:pe.optional().empty("hdb/operations-server").default(s_),securePort:cs,timeout:xt.min(1).optional()}).optional(),tls:pe.alternatives([pe.array().items(u),u])}).required(),rootPath:It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:pe.object({network:pe.object({port:cs,securePort:cs,mtls:pe.alternatives([Ve.optional(),pe.object({user:It.optional(),certificateAuthority:i,required:Ve.optional()})])}).required(),webSocket:Ve.optional(),requireAuthentication:Ve.optional()}),http:pe.object({compressionThreshold:xt.optional(),cors:Ve.optional(),corsAccessList:rc.optional(),headersTimeout:xt.min(1).optional(),port:cs,securePort:cs,maxHeaderSize:xt.optional(),mtls:pe.alternatives([Ve.optional(),pe.object({user:It.optional(),certificateAuthority:i,required:Ve.optional()})]),threadRange:pe.alternatives([rc.optional(),It.optional()])}).required(),threads:pe.alternatives(n.optional(),pe.object({count:n.optional(),debug:pe.alternatives(Ve.optional(),pe.object({startingPort:xt.min(1).optional(),host:It.optional(),waitForDebugger:Ve.optional()})),maxHeapMemory:xt.min(0).optional()})),storage:pe.object({writeAsync:Ve.required(),overlappingSync:Ve.optional(),caching:Ve.optional(),compression:pe.alternatives([Ve.optional(),pe.object({dictionary:It.optional(),threshold:xt.optional()})]),compactOnStart:Ve.optional(),compactOnStartKeepBackup:Ve.optional(),noReadAhead:Ve.optional(),path:l,prefetchWrites:Ve.optional(),maxFreeSpaceToLoad:xt.optional(),maxFreeSpaceToRetain:xt.optional()}).required(),ignoreScripts:Ve.optional(),tls:pe.alternatives([pe.array().items(u),u])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(Y3,"configValidator");function K3(e){return _L||dL.existsSync(e)?null:`Specified path ${e} does not exist.`}a(K3,"doesPathExist");function W3(e,t){pe.assert(e,It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=K3(e);if(r)return t.message(r)}a(W3,"validatePath");function j3(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(F3);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(q3):e}a(j3,"validateRotationMaxSize");function Q3(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(G3);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message($3):e}a(Q3,"validateRotationInterval");function z3(e,t){let r=t.state.path.join("."),n=B3.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||cL();return i=Math.round(Math.min(i,cL())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),H3.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(z3,"setDefaultThreads");function s_(e,t){let r=t.state.path.join(".");if(!CR.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(CR.isEmpty(Ei))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return tc.join(Ei,k3);case"logging.root":return tc.join(Ei,uL);case"clustering.leafServer.streams.path":return tc.join(Ei,"clustering","leaf");case"storage.path":let n=tc.join(Ei,lL.LEGACY_DATABASES_DIR_NAME);return dL.existsSync(n)?n:tc.join(Ei,lL.DATABASES_DIR_NAME);case"logging.rotation.path":return tc.join(Ei,uL);case"operationsApi.network.domainSocket":return r==null?null:tc.join(Ei,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(s_,"setDefaultRoot");function J3(e){let t=pe.object({routes:xh});return x3.validateBySchema({routes:e},t)}a(J3,"routesValidator")});var wt=b(bL=>{"use strict";var an=M(),_r=J(),fr=V(),{configValidator:X3,routesValidator:EL}=DR(),Wr=require("fs-extra"),mL=require("yaml"),Mn=require("path"),Z3=require("is-number"),pL=require("properties-reader"),eX=require("lodash"),{handleHDBError:tX}=fe(),{HTTP_STATUS_CODES:rX,HDB_ERROR_MSGS:wl}=Nn(),{server:nX}=($r(),oe($a)),{DATABASES_PARAM_CONFIG:i_,CONFIG_PARAMS:Ln,CONFIG_PARAM_MAP:Fs}=an,sX="Unable to get config value because config is uninitialized",iX="Config successfully initialized",oX="Error backing up config file",aX="Empty parameter sent to getConfigValue",SL=Mn.join(an.PACKAGE_ROOT,"config","yaml",an.HDB_DEFAULT_CONFIG_FILE),cX=Mn.join(an.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),lX="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",hL={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},kh,jt,Fh;Object.assign(bL,{createConfigFile:uX,getDefaultConfig:dX,getConfigValue:gL,initConfig:Gh,flattenConfig:Cl,updateConfigValue:RL,updateConfigObject:fX,getConfiguration:mX,setConfiguration:pX,readConfigFile:UR,getClusteringRoutes:SX,initOldConfig:AL,getConfigFromFile:TX,getConfigFilePath:nc,addConfig:gX,deleteConfigFromFile:RX,getConfigObj:AX,resolvePath:PR,getFlatConfigObj:bX});function PR(e){if(e?.startsWith("~/"))return Mn.join(_r.getHomeDir(),e.slice(1));let t=te();return Mn.resolve(t.getHdbBasePath(),e)}a(PR,"resolvePath");function uX(e,t=!1){let r=jo(SL);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=mL.parseDocument(Wr.readFileSync(cX,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}kh=Cl(r.toJSON());let n;for(let c in e){let l=Fs[c.toLowerCase()];if(l===Ln.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(d=>({[d]:e[c][d]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let d=l.split("_"),u=LR(l,e[c]);l==="rootPath"&&u?.endsWith("/")&&(u=u.slice(0,-1));try{r.setIn([...d],u)}catch(_){fr.error(_)}}}n&&TL(r,n),MR(r,t);let s=r.toJSON();jt=Cl(s);let i=r.getIn(["rootPath"]),o=Mn.join(i,an.HDB_CONFIG_FILE);Wr.createFileSync(o),Wr.writeFileSync(o,String(r)),fr.trace(`Config file written to ${o}`)}a(uX,"createConfigFile");function TL(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!_r.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(i_.TABLES))for(let i in n[s][i_.TABLES])for(let o in n[s][i_.TABLES][i]){let c=n[s][i_.TABLES][i][o],l=[Ln.DATABASES,s,i_.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Ln.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){fr.error("Error parsing schemas CLI/env config arguments",n)}}a(TL,"setSchemasConfig");function dX(e){if(kh===void 0){let r=jo(SL);kh=Cl(r.toJSON())}let t=Fs[e.toLowerCase()];if(t!==void 0)return kh[t.toLowerCase()]}a(dX,"getDefaultConfig");function gL(e){if(e==null){fr.info(aX);return}if(jt===void 0){fr.trace(sX);return}let t=Fs[e.toLowerCase()];if(t!==void 0)return jt[t.toLowerCase()]}a(gL,"getConfigValue");function nc(e=_r.getPropsFilePath()){let t=_r.getEnvCliRootPath();if(t)return PR(Mn.join(t,an.HDB_CONFIG_FILE));let r=pL(e);return PR(r.get(an.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(nc,"getConfigFilePath");function Gh(e=!1){if(jt===void 0||e){let t;if(!_r.noBootFile()){t=_r.getPropsFilePath();try{Wr.accessSync(t,Wr.constants.F_OK|Wr.constants.R_OK)}catch(i){throw fr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=nc(t),n;if(r.includes("config/settings.js"))try{AL(r);return}catch(i){if(i.code!==an.NODE_ERROR_CODES.ENOENT)throw i}try{n=jo(r)}catch(i){if(i.code===an.NODE_ERROR_CODES.ENOENT){fr.trace(`HarperDB config file not found at ${r}.
11
+ This can occur during early stages of install where the config file has not yet been created`);return}else throw fr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}_X(n,r),MR(n);let s=n.toJSON();if(nX.config=s,jt=Cl(s),jt.logging_rotation_rotate)for(let i in hL)jt[i]&&fr.error(`Config ${hL[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);fr.trace(iX)}}a(Gh,"initConfig");function _X(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Mn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Mn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(fr.trace("Updating config file with missing config params"),Wr.writeFileSync(t,String(e)))}a(_X,"checkForUpdatedConfig");function MR(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw wl.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw wl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=X3(r,t);if(n.error)throw wl.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(MR,"validateConfig");function fX(e,t){jt===void 0&&(jt={});let r=Fs[e.toLowerCase()];if(r===void 0){fr.trace(`Unable to update config object because config param '${e}' does not exist`);return}jt[r.toLowerCase()]=t}a(fX,"updateConfigObject");function RL(e,t,r=void 0,n=!1,s=!1,i=!1){jt===void 0&&Gh();let o=gL(Fs.hdb_root),c=Mn.join(o,an.HDB_CONFIG_FILE),l=jo(c),d;if(r===void 0&&e.toLowerCase()===Ln.DATABASES)d=t;else if(r===void 0){let E;if(i)E=e;else if(E=Fs[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=LR(E,t);l.setIn([...f],h)}else for(let E in r){let f=Fs[E.toLowerCase()];if(f===Ln.HTTP_SECUREPORT&&r[E]===jt[Ln.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Ln.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Ln.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Ln.DATABASES){d=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),T=an.LEGACY_CONFIG_PARAMS[E.toUpperCase()];T&&T.startsWith("customFunctions")&&l.hasIn(T.split("_"))&&(f=T,h=T.split("_"));let S=LR(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],S)}catch(R){fr.error(R)}}}d&&TL(l,d),MR(l);let u=l.getIn(["rootPath"]),_=Mn.join(u,an.HDB_CONFIG_FILE);n===!0&&EX(c,u),Wr.writeFileSync(_,String(l)),s&&(jt=Cl(l.toJSON())),fr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(RL,"updateConfigValue");function EX(e,t){try{let r=Mn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${an.HDB_CONFIG_FILE}.bak`);Wr.copySync(e,r),fr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){fr.error(oX),fr.error(r)}}a(EX,"backupConfigFile");var hX=["databases"];function Cl(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),Fh=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!hX.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Ln[l.toUpperCase()]&&Fs[l]&&(s[Fs[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Cl,"flattenConfig");function LR(e,t){if(e===Ln.CLUSTERING_NODENAME||e===Ln.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(Z3(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||_r.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return _r.autoCast(t)}a(LR,"castConfigValue");function mX(){let e=_r.getPropsFilePath(),t=nc(e);return jo(t).toJSON()}a(mX,"getConfiguration");async function pX(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return RL(void 0,void 0,s,!0),lX}catch(i){throw typeof i=="string"||i instanceof String?tX(i,i,rX.BAD_REQUEST,void 0,void 0,!0):i}}a(pX,"setConfiguration");function UR(){let e=_r.getPropsFilePath();try{Wr.accessSync(e,Wr.constants.F_OK|Wr.constants.R_OK)}catch(n){if(!_r.noBootFile())throw fr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=nc(e);return jo(t).toJSON()}a(UR,"readConfigFile");function jo(e){return mL.parseDocument(Wr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(jo,"parseYamlDoc");function SX(){let e=UR(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=_r.isEmptyOrZeroLength(t)?[]:t;let r=EL(t);if(r)throw wl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=_r.isEmptyOrZeroLength(n)?[]:n;let s=EL(n);if(s)throw wl.CONFIG_VALIDATION(s.message);if(!_r.isEmptyOrZeroLength(n)&&!_r.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!_r.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw wl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(SX,"getClusteringRoutes");function AL(e){let t=pL(e);jt={};for(let r in Fs){let n=t.get(r.toUpperCase());if(_r.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Fs[r].toLowerCase();s===Ln.LOGGING_ROOT?jt[s]=Mn.dirname(n):jt[s]=n}return jt}a(AL,"initOldConfig");function TX(e){let t=UR();return eX.get(t,e.replaceAll("_","."))}a(TX,"getConfigFromFile");async function gX(e,t){let r=jo(nc());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await Wr.writeFile(nc(),String(r))}a(gX,"addConfig");function RX(e){let t=nc(_r.getPropsFilePath()),r=jo(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Mn.join(n,an.HDB_CONFIG_FILE);Wr.writeFileSync(s,String(r))}a(RX,"deleteConfigFromFile");function AX(){return Fh||(Gh(),Fh)}a(AX,"getConfigObj");function bX(){return jt||Gh(),jt}a(bX,"getFlatConfigObj")});var OL=b((jAe,yL)=>{"use strict";var qh=M(),$h=class{static{a(this,"BaseLicense")}constructor(t=0,r=qh.RAM_ALLOCATION_ENUM.DEFAULT,n=qh.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},vR=class extends $h{static{a(this,"ExtendedLicense")}constructor(t=0,r=qh.RAM_ALLOCATION_ENUM.DEFAULT,n=qh.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};yL.exports={BaseLicense:$h,ExtendedLicense:vR}});var sc=b((zAe,LL)=>{"use strict";var Pl=require("fs-extra"),IL=Hh(),wL=require("crypto"),yX=require("moment"),OX=require("uuid").v4,jr=V(),HR=require("path"),NX=J(),Qo=M(),{totalmem:NL}=require("os"),IX=OL().ExtendedLicense,Dl="invalid license key format",wX="061183",CX="mofi25",DX="aes-256-cbc",PX=16,LX=32,CL=te(),{resolvePath:DL}=wt();CL.initSync();var BR;LL.exports={validateLicense:PL,generateFingerPrint:UX,licenseSearch:FR,getLicense:HX,checkMemoryLimit:xX};function xR(){return HR.join(CL.getHdbBasePath(),Qo.LICENSE_KEY_DIR_NAME,Qo.LICENSE_FILE_NAME)}a(xR,"getLicenseDirPath");function MX(){let e=xR();return DL(HR.join(e,Qo.LICENSE_FILE_NAME))}a(MX,"getLicenseFilePath");function kR(){let e=xR();return DL(HR.join(e,Qo.REG_KEY_FILE_NAME))}a(kR,"getFingerPrintFilePath");async function UX(){let e=kR();try{return await Pl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await vX();throw jr.error(`Error writing fingerprint file to ${e}`),jr.error(t),new Error("There was an error generating the fingerprint")}}a(UX,"generateFingerPrint");async function vX(){let e=OX(),t=IL.hash(e),r=kR();try{await Pl.mkdirp(xR()),await Pl.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw jr.error(`Error writing fingerprint file to ${r}`),jr.error(n),new Error("There was an error generating the fingerprint")}return t}a(vX,"writeFingerprint");function PL(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Qo.RAM_ALLOCATION_ENUM.DEFAULT,version:Qo.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return jr.error("empty license key passed to validate."),r;let n=kR(),s=!1;try{s=Pl.statSync(n)}catch(i){jr.error(i)}if(s){let i;try{i=Pl.readFileSync(n,"utf8")}catch{jr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(CX),c=o[1];c=Buffer.concat([Buffer.from(c)],PX);let l=Buffer.concat([Buffer.from(i)],LX),d=wL.createDecipheriv(DX,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=d.update(o[0],"hex","utf8"),u.trim(),u+=d.final("utf8")}catch{let f=BX(o[0],i);if(f)u=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Dl),jr.error(Dl),new Error(Dl)}let _;if(isNaN(u))try{_=JSON.parse(u),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(Dl),jr.error(Dl),new Error(Dl)}else r.exp_date=u;r.exp_date<yX().valueOf()&&(r.valid_date=!1),IL.validate(o[1],`${wX}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||jr.error("Invalid licence"),r}a(PL,"validateLicense");function BX(e,t){try{let r=wL.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{jr.warn("Check old license failed")}}a(BX,"checkOldLicense");function FR(){let e=new IX,t=[];try{t=Pl.readFileSync(MX(),"utf-8").split(Qo.NEW_LINE)}catch(r){r.code==="ENOENT"?jr.debug("no license file found"):jr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(NX.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=PL(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){jr.error("There was an error parsing the license string."),jr.error(s),e.ram_allocation=Qo.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return BR=e,e}a(FR,"licenseSearch");async function HX(){return BR||await FR(),BR}a(HX,"getLicense");function xX(){let e=FR().ram_allocation,t=process.constrainedMemory?.()||NL();if(t=Math.round(Math.min(t,NL())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(xX,"checkMemoryLimit")});var vn=b((tbe,jL)=>{"use strict";var BL="username is required",HL="nothing to update, must supply active, role or password to update",xL="password cannot be an empty string",kL="If role is specified, it cannot be empty.",FL="active must be true or false";jL.exports={addUser:WX,alterUser:jX,dropUser:zX,getSuperUser:eZ,userInfo:JX,listUsers:Yh,listUsersExternal:XX,setUsersToGlobal:Ml,findAndValidateUser:KL,getClusterUser:tZ,USERNAME_REQUIRED:BL,ALTERUSER_NOTHING_TO_UPDATE:HL,EMPTY_PASSWORD:xL,EMPTY_ROLE:kL,ACTIVE_BOOLEAN:FL};var GL=Yr(),kX=Wo(),$R=Hh(),qL=sL(),$L=Vr(),VR=Ji(),Un=J(),VL=require("validate.js"),Ye=V(),{promisify:FX}=require("util"),YR=zi(),ML=M(),UL=dt(),GX=wt(),XAe=te(),ZAe=sc(),qX=ji(),{table:ebe}=(Le(),oe(lt)),{handleHDBError:hi,hdb_errors:$X}=fe(),{HTTP_STATUS_CODES:mi,AUTHENTICATION_ERROR_MSGS:GR,HDB_ERROR_MSGS:Ll}=$X,{UserEventMsg:KR}=Gs(),qR=require("lodash"),{server:WR}=($r(),oe($a)),VX=V();WR.getUser=(e,t)=>KL(e,t,t!=null);var YL={username:!0,active:!0,role:!0,password:!0},vL=new Map,Vh=$L.searchByValue,YX=$L.searchByHash,KX=FX(kX.delete);async function WX(e){let t=VL.cleanAttributes(e,YL),r=qL.addUserValidation(t);if(r)throw hi(new Error,r.message,mi.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await Vh(n),s=s&&Array.from(s)}catch(l){throw Ye.error("There was an error searching for a role in add user"),Ye.error(l),l}if(!s||s.length<1)throw hi(new Error,Ll.ROLE_NAME_NOT_FOUND(t.role),mi.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw hi(new Error,Ll.DUP_ROLES_FOUND(t.role),mi.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=YR.encrypt(t.password)),t.password=$R.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await GL.insert(i)}catch(l){throw Ye.error("There was an error searching for a user."),Ye.error(l),l}Ye.debug(o);try{await Ml()}catch(l){throw Ye.error("Got an error setting users to global"),Ye.error(l),l}if(o.skipped_hashes.length===1)throw hi(new Error,Ll.USER_ALREADY_EXISTS(t.username),mi.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],VR.signalUserChange(new KR(process.pid)),`${c.username} successfully added`}a(WX,"addUser");async function jX(e){let t=VL.cleanAttributes(e,YL);if(Un.isEmptyOrZeroLength(t.username))throw new Error(BL);if(Un.isEmptyOrZeroLength(t.password)&&Un.isEmptyOrZeroLength(t.role)&&Un.isEmptyOrZeroLength(t.active))throw new Error(HL);if(!Un.isEmpty(t.password)&&Un.isEmptyOrZeroLength(t.password.trim()))throw new Error(xL);if(!Un.isEmpty(t.active)&&!Un.isBoolean(t.active))throw new Error(FL);let r=QX(t.username);if(!Un.isEmpty(t.password)&&!Un.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=YR.encrypt(t.password)),t.password=$R.hash(t.password)),t.role==="")throw new Error(kL);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await Vh(i)||[])}catch(c){throw Ye.error("Got an error searching for a role."),Ye.error(c),c}if(!o||o.length===0){let c=Ll.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ye.error(c),hi(new Error,c,mi.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Ll.ALTER_USER_DUP_ROLES(t.role);throw Ye.error(c),hi(new Error,c,mi.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await GL.update(n)}catch(i){throw Ye.error("Error during update."),Ye.error(i),i}try{await Ml()}catch(i){throw Ye.error("Got an error setting users to global"),Ye.error(i),i}return VR.signalUserChange(new KR(process.pid)),s}a(jX,"alterUser");function QX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(QX,"isClusterUser");async function zX(e){try{let t=qL.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Un.isEmpty(global.hdb_users.get(e.username)))throw hi(new Error,Ll.USER_NOT_EXIST(e.username),mi.NOT_FOUND,void 0,void 0,!0);let n;try{n=await KX(r)}catch(s){throw Ye.error("Got an error deleting a user."),Ye.error(s),s}Ye.debug(n);try{await Ml()}catch(s){throw Ye.error("Got an error setting users to global."),Ye.error(s),s}return VR.signalUserChange(new KR(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(zX,"dropUser");async function JX(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=qR.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await YX(r)}catch(s){throw Ye.error("Got an error searching for a role."),Ye.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Ye.error(r),r}return t}a(JX,"userInfo");async function XX(){let e;try{e=await Yh()}catch(t){throw Ye.error("Got an error listing users."),Ye.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(XX,"listUsersExternal");async function Yh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await Vh(e)}catch(o){throw Ye.error("Got an error searching for roles."),Ye.error(o),o}let r={};for(let o of t)r[o.id]=qR.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await Vh(n)}catch(o){throw Ye.error("Got an error searching for users."),Ye.error(o),o}let i=new Map;for(let o of s)o=qR.cloneDeep(o),o.role=r[o.role],ZX(o.role),i.set(o.username,o);return i}catch(e){throw Ye.error("got an error listing users"),Ye.error(e),Un.errorizeMessage(e)}return null}a(Yh,"listUsers");function ZX(e){try{if(!e){Ye.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(qX)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Ye.error("Got an error trying to set system permissions."),Ye.error(t)}}a(ZX,"appendSystemTablesToRole");async function Ml(){try{let e=await Yh();global.hdb_users=e}catch(e){throw Ye.error(e),e}}a(Ml,"setUsersToGlobal");async function KL(e,t,r=!0){global.hdb_users||await Ml();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw hi(new Error,GR.GENERIC_AUTH_FAIL,mi.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw hi(new Error,GR.USER_INACTIVE,mi.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(vL.get(t)===n.password)return s;if($R.validate(n.password,t))vL.set(t,n.password);else throw hi(new Error,GR.GENERIC_AUTH_FAIL,mi.UNAUTHORIZED,void 0,void 0,!0)}return s}a(KL,"findAndValidateUser");async function eZ(){global.hdb_users||await Ml();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(eZ,"getSuperUser");async function tZ(){let e=await Yh(),t=GX.getConfigFromFile(ML.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Un.isEmpty(r)&&r?.role?.role===ML.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=YR.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+UL.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+UL.SERVER_SUFFIX.ADMIN,r}a(tZ,"getClusterUser");var WL=[];WR.invalidateUser=function(e){for(let t of WL)try{t(e)}catch(r){VX.error("Error invalidating user",r)}};WR.onInvalidatedUser=function(e){WL.push(e)}});var a_=b((ibe,XL)=>{"use strict";var ic=V(),Bn=M(),rZ=NP(),nbe=as(),sbe=fi(),nZ=vn(),{validateEvent:QL}=Gs(),o_=Pn(),sZ=require("process"),{resetDatabases:iZ}=(Le(),oe(lt)),oZ={[Bn.ITC_EVENT_TYPES.SCHEMA]:aZ,[Bn.ITC_EVENT_TYPES.USER]:JL};async function aZ(e){let t=QL(e);if(t){ic.error(t);return}ic.trace("ITC schemaHandler received schema event:",e),await rZ(e.message),await cZ(e.message)}a(aZ,"schemaHandler");async function cZ(e){try{o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=iZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){ic.error(t)}}a(cZ,"syncSchemaMetadata");var zL=[];async function JL(e){try{try{o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),o_.resetReadTxn(Bn.SYSTEM_SCHEMA_NAME,Bn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){ic.warn(r)}let t=QL(e);if(t){ic.error(t);return}ic.trace(`ITC userHandler ${Bn.HDB_ITC_CLIENT_PREFIX}${sZ.pid} received user event:`,e),await nZ.setUsersToGlobal();for(let r of zL)r()}catch(t){ic.error(t)}}a(JL,"userHandler");JL.addListener=function(e){zL.push(e)};XL.exports=oZ});var Gs=b((dbe,eM)=>{"use strict";var abe=V(),jR=J(),lZ=M(),{ITC_ERRORS:c_}=Nn(),{parentPort:cbe,threadId:uZ,isMainThread:dZ,workerData:lbe}=require("worker_threads"),{onMessageFromWorkers:_Z,broadcast:ube,broadcastWithAcknowledgement:fZ}=it();eM.exports={sendItcEvent:EZ,validateEvent:ZL,SchemaEventMsg:hZ,UserEventMsg:mZ};var Kh;_Z(async(e,t)=>{Kh=Kh||a_(),ZL(e),Kh[e.type]&&await Kh[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function EZ(e){return!dZ&&e.message&&(e.message.originator=uZ),fZ(e)}a(EZ,"sendItcEvent");function ZL(e){if(typeof e!="object")return c_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||jR.isEmpty(e.type))return c_.MISSING_TYPE;if(!e.hasOwnProperty("message")||jR.isEmpty(e.message))return c_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||jR.isEmpty(e.message.originator))return c_.MISSING_ORIGIN;if(lZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return c_.INVALID_EVENT(e.type)}a(ZL,"validateEvent");function hZ(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(hZ,"SchemaEventMsg");function mZ(e){this.originator=e}a(mZ,"UserEventMsg")});var Ji=b((Ebe,sM)=>{"use strict";var tM=M(),fbe=J(),Wh=V(),rM=bP(),Ul,{sendItcEvent:nM}=Gs();function pZ(e){try{Wh.info("signalSchemaChange called with message:",e),Ul=Ul||a_();let t=new rM(tM.ITC_EVENT_TYPES.SCHEMA,e);return Ul.schema(t),nM(t)}catch(t){Wh.error(t)}}a(pZ,"signalSchemaChange");function SZ(e){try{Wh.trace("signalUserChange called with message:",e),Ul=Ul||a_();let t=new rM(tM.ITC_EVENT_TYPES.USER,e);return Ul.user(t),nM(t)}catch(t){Wh.error(t)}}a(SZ,"signalUserChange");sM.exports={signalSchemaChange:pZ,signalUserChange:SZ}});var jh=b((mbe,oM)=>{"use strict";var iM=J(),TZ=M(),gZ=V(),RZ=wh(),AZ=Ih(),bZ=Ji(),{SchemaEventMsg:yZ}=Gs(),OZ="already exists in";oM.exports=NZ;async function NZ(e,t,r){if(iM.isEmptyOrZeroLength(r))return r;let n=[];iM.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await IZ(e,t.schema,t.name,i)})),s}a(NZ,"lmdbCheckForNewAttributes");async function IZ(e,t,r,n){let s=new AZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await wZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(OZ))gZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(IZ,"createNewAttribute");async function wZ(e){let t;return t=await RZ(e),bZ.signalSchemaChange(new yZ(process.pid,TZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(wZ,"createAttribute")});var vl=b((Sbe,aM)=>{"use strict";var QR=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};aM.exports=QR});var lM=b((gbe,cM)=>{"use strict";var CZ=vl(),DZ=M().OPERATIONS_ENUM,zR=class extends CZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(DZ.INSERT,r,n,s,i),this.records=t}};cM.exports=zR});var dM=b((Abe,uM)=>{"use strict";var PZ=vl(),LZ=M().OPERATIONS_ENUM,JR=class extends PZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(LZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};uM.exports=JR});var fM=b((ybe,_M)=>{"use strict";var MZ=vl(),UZ=M().OPERATIONS_ENUM,XR=class extends MZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(UZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};_M.exports=XR});var hM=b((Nbe,EM)=>{"use strict";var vZ=vl(),BZ=M().OPERATIONS_ENUM,ZR=class extends vZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(BZ.DELETE,n,s,t,i),this.original_records=r}};EM.exports=ZR});var l_=b((Cbe,TM)=>{"use strict";var wbe=require("path"),mM=ht(),HZ=lM(),xZ=dM(),kZ=fM(),FZ=hM(),Bl=Bt(),pM=J(),{CONFIG_PARAMS:GZ}=M(),SM=te();SM.initSync();var Qh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:qZ}=gt();TM.exports=$Z;async function $Z(e,t){if(SM.get(GZ.LOGGING_AUDITLOG)===!1)return;let r=qZ(e.schema,e.table),n=await mM.openEnvironment(r,e.table,!0),s=VZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){mM.initializeDBIs(n,Bl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Bl.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Bl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Bl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),pM.isEmpty(s.user_name)||n.dbis[Bl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Bl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a($Z,"writeTransaction");function VZ(e,t){let r=pM.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Qh.INSERT)return new HZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.UPDATE)return new xZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.UPSERT)return new kZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.DELETE)return new FZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(VZ,"createTransactionObject")});var eA=b((Lbe,gM)=>{"use strict";var YZ=t_(),Pbe=Hd(),u_=M(),KZ=xd(),WZ=Qa().insertRecords,jZ=ht(),QZ=V(),zZ=jh(),{getSchemaPath:JZ}=gt(),XZ=l_();gM.exports=ZZ;async function ZZ(e){try{let{schema_table:t,attributes:r}=YZ(e);KZ(e,r,t.hash_attribute),e.schema!==u_.SYSTEM_SCHEMA_NAME&&(r.includes(u_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(u_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(u_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(u_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await zZ(e.hdb_auth_header,t,r),s=JZ(e.schema,e.table),i=await jZ.openEnvironment(s,e.table),o=await WZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await XZ(e,o)}catch(c){QZ.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(ZZ,"lmdbCreateRecords")});var bM=b((Ube,AM)=>{"use strict";var RM=M(),e5=eA(),t5=Hd(),r5=require("fs-extra"),{getSchemaPath:n5}=gt();AM.exports=s5;async function s5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new t5(RM.SYSTEM_SCHEMA_NAME,RM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await e5(r),await r5.mkdirp(n5(e.schema))}a(s5,"lmdbCreateSchema")});var OM=b((Bbe,yM)=>{"use strict";var tA=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};yM.exports=tA});var CM=b((Gbe,wM)=>{"use strict";var NM=ht(),rA=nn(),nA=Nn().LMDB_ERRORS_ENUM,i5=Bt(),IM=V(),xbe=J(),o5=require("lmdb"),a5=OM(),c5=M(),{OVERFLOW_MARKER:kbe,MAX_SEARCH_KEY_LENGTH:Fbe}=i5,l5=c5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function u5(e,t,r,n){if(rA.validateEnv(e),t===void 0)throw new Error(nA.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(nA.IDS_REQUIRED):new Error(nA.IDS_MUST_BE_ITERABLE);try{let s=NM.listDBIs(e);NM.initializeDBIs(e,t,s);let i=new a5,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[l5]>n){i.skipped.push(o);continue}let T=e.dbis[t].ifVersion(o,o5.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let R=s[S];if(!h.hasOwnProperty(R)||R===t)continue;let p=e.dbis[R],y=h[R];if(y!=null)try{let O=rA.getIndexedValues(y);if(O)for(let B=0,x=O.length;B<x;B++)p.remove(O[B],o)}catch{IM.warn(`cannot delete from attribute: ${R}, ${y}:${o}`)}}});c.push(T),l.push(o),i.original_records.push(h)}catch(h){IM.warn(h),i.skipped.push(o)}let d=[],u=await Promise.all(c);for(let E=0,f=u.length;E<f;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),d.push(E));let _=0;for(let E=0;E<d.length;E++){let f=d[E];i.original_records.splice(f-_,1),_++}return i.txn_time=rA.getNextMonotonicTime(),i}catch(s){throw s}}a(u5,"deleteRecords");wM.exports={deleteRecords:u5}});var d_=b(($be,PM)=>{"use strict";var Hl=J(),d5=CM(),_5=ht(),{getSchemaPath:f5}=gt(),E5=l_(),h5=V();PM.exports=m5;async function m5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Hl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Hl.isEmptyOrZeroLength(e.hash_values)&&!Hl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Hl.isEmpty(l)||e.hash_values.push(l)}}if(Hl.isEmptyOrZeroLength(e.hash_values))return DM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Hl.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=f5(e.schema,e.table),i=await _5.openEnvironment(s,e.table),o=await d5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await E5(e,o)}catch(c){h5.error(`unable to write transaction due to ${c.message}`)}return DM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(m5,"lmdbDeleteRecords");function DM(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(DM,"createDeleteResponse")});var iA=b((Kbe,LM)=>{"use strict";var p5=M(),Ybe=nn();function sA(e,t){let r=Object.create(null);if(t.length===1&&p5.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(sA,"parseRow");function S5(e,t,r,n){let s=sA(r,e);n.push(s)}a(S5,"searchAll");function T5(e,t,r,n){let s=sA(r,e);n[t]=s}a(T5,"searchAllToMap");function g5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(g5,"iterateDBI");function oc(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(oc,"pushResults");function R5(e,t,r,n,s,i){t.toString().endsWith(e)&&oc(t,r,n,s,i)}a(R5,"endsWith");function A5(e,t,r,n,s,i){t.toString().includes(e)&&oc(t,r,n,s,i)}a(A5,"contains");function b5(e,t,r,n,s,i){t>e&&oc(t,r,n,s,i)}a(b5,"greaterThanCompare");function y5(e,t,r,n,s,i){t>=e&&oc(t,r,n,s,i)}a(y5,"greaterThanEqualCompare");function O5(e,t,r,n,s,i){t<e&&oc(t,r,n,s,i)}a(O5,"lessThanCompare");function N5(e,t,r,n,s,i){t<=e&&oc(t,r,n,s,i)}a(N5,"lessThanEqualCompare");LM.exports={parseRow:sA,searchAll:S5,searchAllToMap:T5,iterateDBI:g5,endsWith:R5,contains:A5,greaterThanCompare:b5,greaterThanEqualCompare:y5,lessThanCompare:O5,lessThanEqualCompare:N5,pushResults:oc}});var xl=b((Jbe,kM)=>{"use strict";var zo=ht(),jbe=V(),Hn=nn(),zh=Bt(),Qt=Nn().LMDB_ERRORS_ENUM,Qbe=J(),I5=M(),Jh=iA(),{parseRow:w5}=Jh,zbe=require("lmdb"),{OVERFLOW_MARKER:MM,MAX_SEARCH_KEY_LENGTH:C5}=zh;function UM(e,t,r,n=!1,s=void 0,i=void 0){return ac(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(UM,"iterateFullIndex");function __(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,d=!1){return ac(e,t,r,(u,_,E,f)=>{let p={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!d,exclusiveStart:i===!0?d:l};return f===r?(p.values=!1,_.getRange(p).map(y=>({value:y}))):_.getRange(p)})}a(__,"iterateRangeBetween");function ac(e,t,r,n){let s=e.database||e,i=zo.openDBI(s,r);i[zh.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&zo.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(ac,"setupTransaction");function vM(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(MM)){if(!s)if(r)s=zo.openDBI(e,r);else{let l=zo.listDBIs(e);for(let d=0,u=l.length;d<u&&(s=zo.openDBI(e,l[d]),!s[zh.DBI_DEFINITION_NAME].is_hash_attribute);d++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(vM,"getOverflowCheck");function D5(e,t,r,n=!1,s=void 0,i=void 0){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return ac(e,t,t,(o,c,l)=>(Xh(r),r=f_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(d=>w5(d.value,r))))}a(D5,"searchAll");function P5(e,t,r,n=!1,s=void 0,i=void 0){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);Xh(r),r=f_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of UM(e,t,t,n,s,i))o.set(c,Jh.parseRow(l,r));return o}a(P5,"searchAllToMap");function L5(e,t,r=!1,n=void 0,s=void 0){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=UM(e,void 0,t,r,n,s),c=o.transaction,l=vM(c.database,c,void 0,t);for(let{key:d,value:u}of o){let _=l(d,u);i[_]===void 0&&(i[_]=[]),i[_].push(u)}return i}a(L5,"iterateDBI");function M5(e,t){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return zo.statDBI(e,t).entryCount}a(M5,"countAll");function U5(e,t,r,n,s=!1,i=void 0,o=void 0){return Jo(e,r,n),ac(e,t,r,(c,l,d,u)=>(n=Hn.convertKeyValueToWrite(n),u===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(_=>({key:n,value:_}))))}a(U5,"equals");function v5(e,t,r){return Jo(e,t,r),zo.openDBI(e,t).getValuesCount(r)}a(v5,"count");function B5(e,t,r,n,s=!1,i=void 0,o=void 0){return Jo(e,r,n),ac(e,null,r,(c,l)=>{n=Hn.convertKeyValueToWrite(n);let d=!0;typeof n=="number"&&(d=!1);let u;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(d===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(d===!0)return u.DONE}),d?u:u.filter(_=>_)})}a(B5,"startsWith");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){return BM(e,t,r,n,s,i,o,!0)}a(H5,"endsWith");function BM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Jo(e,r,n),ac(e,null,r,(l,d,u,_)=>{let E=vM(u,l,_,r);return o=Number.isInteger(o)?o:0,d.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(MM)?d.getValues(f,{transaction:l}).map(T=>{let S=E(f,T);if(c?S.endsWith(n):S.includes(n))return{key:S,value:T}}).filter(T=>T):(c?h.endsWith(n):h.includes(n))?d[zh.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:d.getValues(f,{transaction:l}).map(T=>({key:f,value:T})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(BM,"contains");function x5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),__(e,t,r,n,l,s,i,o,!0,!1)}a(x5,"greaterThan");function k5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),__(e,t,r,n,l,s,i,o,!1,!1)}a(k5,"greaterThanEqual");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),__(e,t,r,l,n,s,i,o,!1,!0)}a(F5,"lessThan");function G5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),__(e,t,r,l,n,s,i,o,!1,!1)}a(G5,"lessThanEqual");function q5(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Hn.validateEnv(e),r===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Qt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Qt.END_VALUE_REQUIRED);if(n=Hn.convertKeyValueToWrite(n),s=Hn.convertKeyValueToWrite(s),n>s)throw new Error(Qt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return __(e,t,r,n,s,i,o,c)}a(q5,"between");function $5(e,t,r,n){Hn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(Xh(r),r=f_(s,r),n===void 0)throw new Error(Qt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=Jh.parseRow(c,r)),o}a($5,"searchByHash");function V5(e,t,r){Hn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(V5,"checkHashExists");function Y5(e,t,r,n,s=[]){return xM(e,t,r,n,s),HM(e,t,r,n,s).map(i=>i[1])}a(Y5,"batchSearchByHash");function K5(e,t,r,n,s=[]){xM(e,t,r,n,s);let i=new Map;for(let[o,c]of HM(e,t,r,n,s))i.set(o,c);return i}a(K5,"batchSearchByHashToMap");function HM(e,t,r,n,s=[]){return ac(e,t,t,(i,o,c)=>{r=f_(c,r);let l=r.length<3;return n.map(d=>{let u=c.dbis[t].get(d,{transaction:i,lazy:l});if(u)return[d,Jh.parseRow(u,r)];s.push(d)}).filter(d=>d)})}a(HM,"batchHashSearch");function xM(e,t,r,n,s){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(Xh(r),n==null)throw new Error(Qt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Qt.IDS_MUST_BE_ITERABLE)}a(xM,"initializeBatchSearchByHash");function Xh(e){if(!Array.isArray(e))throw e===void 0?new Error(Qt.FETCH_ATTRIBUTES_REQUIRED):new Error(Qt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(Xh,"validateFetchAttributes");function Jo(e,t,r){if(Hn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.SEARCH_VALUE_REQUIRED);if(r?.length>C5)throw new Error(Qt.SEARCH_VALUE_TOO_LARGE)}a(Jo,"validateComparisonFunctions");function f_(e,t){return t.length===1&&I5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=zo.listDBIs(e)),t}a(f_,"setGetWholeRowAttributes");kM.exports={searchAll:D5,searchAllToMap:P5,count:v5,countAll:M5,equals:U5,startsWith:B5,endsWith:H5,contains:BM,searchByHash:$5,setGetWholeRowAttributes:f_,batchSearchByHash:Y5,batchSearchByHashToMap:K5,checkHashExists:V5,iterateDBI:L5,greaterThan:x5,greaterThanEqual:k5,lessThan:F5,lessThanEqual:G5,between:q5}});var kl=b((Zbe,VM)=>{var FM=require("lodash"),GM=ut(),Be=require("joi"),W5=J(),{hdb_schema_table:E_,checkValidTable:qM,hdb_table:$M,hdb_database:Zh}=di(),{handleHDBError:j5,hdb_errors:Q5}=fe(),{getDatabases:z5}=(Le(),oe(lt)),{HTTP_STATUS_CODES:J5}=Q5,X5=Be.object({database:Zh,schema:Zh,table:$M,search_attribute:E_,search_value:Be.any().required(),get_attributes:Be.array().min(1).items(Be.alternatives(E_,Be.object())).optional(),desc:Be.bool(),limit:Be.number().integer().min(1),offset:Be.number().integer().min(0)}),Z5=Be.object({database:Zh,schema:Zh,table:$M,operator:Be.string().valid("and","or").default("and").lowercase(),offset:Be.number().integer().min(0),limit:Be.number().integer().min(1),get_attributes:Be.array().min(1).items(Be.alternatives(E_,Be.object())).optional(),sort:Be.object({attribute:Be.alternatives(E_,Be.array().min(1)),descending:Be.bool().optional()}).optional(),conditions:Be.array().min(1).items(Be.alternatives(Be.object({operator:Be.string().valid("and","or").default("and").lowercase(),conditions:Be.array()}),Be.object({search_attribute:Be.alternatives(E_,Be.array().min(1)),search_type:Be.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:Be.when("search_type",{switch:[{is:"equals",then:Be.any()},{is:"between",then:Be.array().items(Be.alternatives([Be.string(),Be.number()])).length(2)}],otherwise:Be.alternatives(Be.string(),Be.number())}).required()}))).required()});VM.exports=function(e,t){let r=null;switch(t){case"value":r=GM.validateBySchema(e,X5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(qM("database",e.schema)),i(qM("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(o=>typeof o=="string"||typeof o=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=GM.validateBySchema(e,Z5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=W5.checkGlobalSchemaTable(e.schema,e.table);if(s)return j5(new Error,s,J5.NOT_FOUND);let o=z5()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let _=0,E=u.conditions.length;_<E;_++){let f=u.conditions[_];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let d=FM.filter(c,u=>u!=="*"&&!u.startsWith?.("$")&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!FM.some(o,_=>_===u||_.attribute===u||_.attribute===u.attribute));if(d&&d.length>0){let u=d.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var oA=b((tye,YM)=>{"use strict";var e6=ht(),t6=kl(),{getSchemaPath:r6}=gt();YM.exports=n6;function n6(e){let t=t6(e,"hashes");if(t)throw t;let r=r6(e.schema,e.table);return e6.openEnvironment(r,e.table)}a(n6,"initialize")});var aA=b((nye,KM)=>{"use strict";var s6=xl(),i6=oA();KM.exports=o6;async function o6(e){let t=await i6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return s6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(o6,"lmdbGetDataByHash")});var Fl=b((iye,WM)=>{"use strict";var cA=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};WM.exports=cA});var QM=b((cye,jM)=>{"use strict";var aye=Fl(),a6=xl(),c6=oA();jM.exports=l6;async function l6(e){let t=await c6(e),r=global.hdb_schema[e.schema][e.table];return a6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(l6,"lmdbSearchByHash")});var qs=b((uye,zM)=>{"use strict";var lA=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,d=void 0,u=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=d,this.offset=u}};zM.exports=lA});var em=b((_ye,rU)=>{"use strict";var Qr=xl(),u6=ht(),d6=J(),He=Bt(),cc=M(),_6=ji(),JM=Nn().LMDB_ERRORS_ENUM,{getSchemaPath:f6}=gt(),Xi=cc.SEARCH_WILDCARDS;async function E6(e,t,r){let n;e.schema===cc.SYSTEM_SCHEMA_NAME?n=_6[e.table]:n=global.hdb_schema[e.schema][e.table];let s=tU(e,n.hash_attribute,r,t);return ZM(e,s,n.hash_attribute,r)}a(E6,"prepSearch");async function ZM(e,t,r,n){let s=f6(e.schema,e.table),i=await u6.openEnvironment(s,e.table),o=eU(i,e,t,r),c=o.transaction||i;if([He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,He.SEARCH_TYPES.SEARCH_ALL,He.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(h6(e,r)===!1){let u=e.search_attribute;if(u===r)return n?XM(o,()=>!0):o.map(E=>({[r]:E.key}));let _=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?XM(o,_):o.map(_)}let d=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?Qr.batchSearchByHashToMap(c,r,e.get_attributes,d):Qr.batchSearchByHash(c,r,e.get_attributes,d)}a(ZM,"executeSearch");function eU(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case He.SEARCH_TYPES.EQUALS:s=Qr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.CONTAINS:s=Qr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.ENDS_WITH:case He.SEARCH_TYPES._ENDS_WITH:s=Qr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.STARTS_WITH:case He.SEARCH_TYPES._STARTS_WITH:s=Qr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Qr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Qr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case He.SEARCH_TYPES.SEARCH_ALL:return Qr.searchAll(e,n,t.get_attributes,o,c,l);case He.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Qr.searchAllToMap(e,n,t.get_attributes,o,c,l);case He.SEARCH_TYPES.BETWEEN:s=Qr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case He.SEARCH_TYPES.GREATER_THAN:case He.SEARCH_TYPES._GREATER_THAN:s=Qr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.GREATER_THAN_EQUAL:case He.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Qr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.LESS_THAN:case He.SEARCH_TYPES._LESS_THAN:s=Qr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case He.SEARCH_TYPES.LESS_THAN_EQUAL:case He.SEARCH_TYPES._LESS_THAN_EQUAL:s=Qr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(eU,"searchByType");function XM(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(XM,"createMapFromIterable");function h6(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}a(h6,"checkToFetchMore");function tU(e,t,r,n){if(d6.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),Xi.indexOf(s)>-1)return r===!0?He.SEARCH_TYPES.SEARCH_ALL_TO_MAP:He.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Xi[0])<0&&s.indexOf(Xi[1])<0)return c===!0?r===!0?He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:He.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:He.SEARCH_TYPES.EQUALS;if(Xi.indexOf(i)>=0&&Xi.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),He.SEARCH_TYPES.CONTAINS;if(Xi.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),He.SEARCH_TYPES.ENDS_WITH;if(Xi.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),He.SEARCH_TYPES.STARTS_WITH;if(s.includes(Xi[0])||s.includes(Xi[1]))return He.SEARCH_TYPES.EQUALS;throw new Error(JM.UNKNOWN_SEARCH_TYPE)}else switch(n){case cc.VALUE_SEARCH_COMPARATORS.BETWEEN:return He.SEARCH_TYPES.BETWEEN;case cc.VALUE_SEARCH_COMPARATORS.GREATER:return He.SEARCH_TYPES.GREATER_THAN;case cc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return He.SEARCH_TYPES.GREATER_THAN_EQUAL;case cc.VALUE_SEARCH_COMPARATORS.LESS:return He.SEARCH_TYPES.LESS_THAN;case cc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return He.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(JM.UNKNOWN_SEARCH_TYPE)}}a(tU,"createSearchTypeFromSearchObject");rU.exports={executeSearch:ZM,createSearchTypeFromSearchObject:tU,prepSearch:E6,searchByType:eU}});var sU=b((hye,nU)=>{"use strict";var Eye=qs(),m6=kl(),p6=J(),S6=M(),T6=em();nU.exports=g6;function g6(e,t){if(!p6.isEmpty(t)&&S6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=m6(e,"value");if(n)throw n;return T6.prepSearch(e,t,!0)}a(g6,"lmdbGetDataByValue")});var h_=b((Sye,iU)=>{"use strict";var pye=qs(),R6=kl(),A6=J(),b6=M(),y6=em();iU.exports=O6;async function O6(e,t){if(!A6.isEmpty(t)&&b6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R6(e,"value");if(n)throw n;return y6.prepSearch(e,t,!1)}a(O6,"lmdbSearchByValue")});var aU=b((Rye,oU)=>{"use strict";var gye=Bt(),uA=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},dA=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},_A=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};oU.exports={SearchByConditionsObject:uA,SearchCondition:dA,SortAttribute:_A}});var _U=b((Oye,dU)=>{"use strict";var bye=aU().SearchByConditionsObject,N6=qs(),I6=kl(),fA=xl(),tm=Bt(),{Resource:yye}=(Hs(),oe(EA)),uU=em(),w6=iA(),C6=require("lodash"),{getSchemaPath:D6}=gt(),cU=ht(),{handleHDBError:P6,hdb_errors:L6}=fe(),{HTTP_STATUS_CODES:M6}=L6,U6=1e8;dU.exports=v6;async function v6(e){let t=I6(e,"conditions");if(t)throw P6(t,t.message,M6.BAD_REQUEST,void 0,void 0,!0);e.operator=e.operator?e.operator.toLowerCase():void 0,e.offset=Number.isInteger(e.offset)?e.offset:0;let r=D6(e.schema,e.table),n=await cU.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let d of e.conditions)cU.openDBI(n,d.search_attribute);let i=C6.sortBy(e.conditions,d=>{if(d.estimated_count===void 0){let u=d.search_type;u===tm.SEARCH_TYPES.EQUALS?d.estimated_count=fA.count(n,d.search_attribute,d.search_value):u===tm.SEARCH_TYPES.CONTAINS||u===tm.SEARCH_TYPES.ENDS_WITH?d.estimated_count=1/0:d.estimated_count=U6}return d.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await lU(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let d=n.dbis[s.hash_attribute],u=i.slice(1).map(uU.filterByType),_=u.length,E=fA.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>d.get(f,{transaction:o,lazy:!0})),_>0&&(l=l.filter(f=>{for(let h=0;h<_;h++)if(!u[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>w6.parseRow(f,E))}else{for(let _=1;_<i.length;_++){let E=i[_],f=await lU(o,e,E,s.hash_attribute);c=c.concat(f)}let d=new Set,u=e.offset||0;c=c.filter(_=>d.has(_)?!1:(d.add(_),!0)).slice(u,e.limit&&e.limit+u),l=fA.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(v6,"lmdbSearchByConditions");async function lU(e,t,r,n){let s=new N6(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===tm.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,uU.searchByType(e,s,i,n).map(o=>o.value)}a(lU,"executeConditionSearch")});var Gl=b((Iye,fU)=>{"use strict";var B6=M().OPERATIONS_ENUM,hA=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=B6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};fU.exports=hA});var mA=b((Cye,RU)=>{"use strict";var pU=qs(),SU=Gl(),TU=h_(),gU=d_(),cn=M(),EU=J(),hU=ht(),{getTransactionAuditStorePath:H6,getSchemaPath:x6}=gt(),mU=V();RU.exports=k6;async function k6(e){try{if(EU.isEmpty(global.hdb_schema[e.schema])||EU.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await F6(e),await G6(e);let t=x6(e.schema,e.table);try{await hU.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")mU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=H6(e.schema,e.table);await hU.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")mU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(k6,"lmdbDropTable");async function F6(e){let t=new pU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await TU(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new SU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await gU(s)}a(F6,"deleteAttributesFromSystem");async function G6(e){let t=new pU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await TU(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new SU(cn.SYSTEM_SCHEMA_NAME,cn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await gU(s)}catch(i){throw i}}a(G6,"dropTableFromSystem")});var bU=b((Pye,AU)=>{"use strict";var q6=require("fs-extra"),$6=qs(),V6=Fl(),Y6=Gl(),K6=mA(),W6=d_(),j6=aA(),Q6=h_(),Zi=M(),{getSchemaPath:z6}=gt(),{handleHDBError:J6,hdb_errors:X6}=fe(),{HDB_ERROR_MSGS:Z6,HTTP_STATUS_CODES:e8}=X6;AU.exports=t8;async function t8(e){let t;try{t=await r8(e.schema);let r=new $6(Zi.SYSTEM_SCHEMA_NAME,Zi.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Zi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Zi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Q6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await K6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Y6(Zi.SYSTEM_SCHEMA_NAME,Zi.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await W6(s);let i=z6(t);await q6.remove(i)}catch(r){throw r}}a(t8,"lmdbDropSchema");async function r8(e){let t=new V6(Zi.SYSTEM_SCHEMA_NAME,Zi.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Zi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await j6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw J6(new Error,Z6.SCHEMA_NOT_FOUND(e),e8.NOT_FOUND,void 0,void 0,!0);return n}a(r8,"validateDropSchema")});var ql=b((Mye,yU)=>{"use strict";var pA=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};yU.exports=pA});var TA=b((Bye,OU)=>{"use strict";var n8=require("fs-extra"),rm=ht(),{getTransactionAuditStorePath:s8}=gt(),SA=Bt(),vye=ql();OU.exports=i8;async function i8(e){let t;try{let r=s8(e.schema,e.table);await n8.mkdirp(r),t=await rm.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{rm.createDBI(t,SA.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),rm.createDBI(t,SA.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),rm.createDBI(t,SA.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME,!0,!1)}catch(r){throw r.message=`unable to create dbi for ${e.schema}.${e.table} due to: ${r.message}`,r}return t}a(i8,"createTransactionsAuditEnvironment")});var wU=b((kye,IU)=>{"use strict";var gA=M(),NU=ht(),o8=Qa(),{getSystemSchemaPath:a8,getSchemaPath:c8}=gt(),xye=ji(),l8=wh(),RA=Ih(),u8=V(),d8=TA();IU.exports=_8;async function _8(e,t){let r=c8(t.schema,t.table),n=new RA(t.schema,t.table,gA.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new RA(t.schema,t.table,gA.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new RA(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await NU.createEnvironment(r,t.table),e!==void 0){let o=await NU.openEnvironment(a8(),gA.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await o8.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await AA(n),await AA(s),await AA(i)}await d8(t)}catch(o){throw o}}a(_8,"lmdbCreateTable");async function AA(e){try{await l8(e)}catch(t){u8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(AA,"createAttribute")});var DU=b((Gye,CU)=>{"use strict";var f8=t_(),E8=xd(),h8=jh(),m_=M(),m8=Qa().updateRecords,p8=ht(),{getSchemaPath:S8}=gt(),T8=l_(),g8=V();CU.exports=R8;async function R8(e){try{let{schema_table:t,attributes:r}=f8(e);E8(e,r,t.hash_attribute),e.schema!==m_.SYSTEM_SCHEMA_NAME&&(r.includes(m_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(m_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(m_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(m_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await h8(e.hdb_auth_header,t,r),s=S8(e.schema,e.table),i=await p8.openEnvironment(s,e.table),o=await m8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await T8(e,o)}catch(c){g8.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(R8,"lmdbUpdateRecords")});var LU=b(($ye,PU)=>{"use strict";var A8=M().OPERATIONS_ENUM,bA=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=A8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};PU.exports=bA});var UU=b((Kye,MU)=>{"use strict";var Yye=LU(),b8=t_(),y8=xd(),O8=jh(),p_=M(),N8=Qa().upsertRecords,I8=ht(),{getSchemaPath:w8}=gt(),C8=l_(),D8=V(),{handleHDBError:P8,hdb_errors:L8}=fe();MU.exports=M8;async function M8(e){let t;try{t=b8(e)}catch(l){throw P8(l,l.message,L8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;y8(e,n,r.hash_attribute),e.schema!==p_.SYSTEM_SCHEMA_NAME&&(n.includes(p_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(p_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(p_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(p_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await O8(e.hdb_auth_header,r,n),i=w8(e.schema,e.table),o=await I8.openEnvironment(i,e.table),c=await N8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await C8(e,c)}catch(l){D8.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(M8,"lmdbUpsertRecords")});var BU=b((jye,vU)=>{"use strict";var yA=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};vU.exports=yA});var xU=b((zye,HU)=>{"use strict";var OA=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};HU.exports=OA});var GU=b((Zye,FU)=>{"use strict";var NA=ht(),{getTransactionAuditStorePath:U8}=gt(),Xye=BU(),S_=Bt(),v8=J(),kU=xU(),B8=require("util").promisify,H8=B8(setTimeout),x8=1e4,k8=100;FU.exports=F8;async function F8(e){let t=U8(e.schema,e.table),r=await NA.openEnvironment(t,e.table,!0),n=NA.listDBIs(r);NA.initializeDBIs(r,S_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new kU;do s=await G8(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=s.start_timestamp),s.end_timestamp!==void 0&&(i.end_timestamp=s.end_timestamp),i.transactions_deleted+=s.transactions_deleted,await H8(k8);while(s.transactions_deleted>0);return i}a(F8,"deleteAuditLogsBefore");async function G8(e,t){let r=new kU;try{let n=e.dbis[S_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[S_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];v8.isEmpty(c)||(s=e.dbis[S_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[S_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>x8)break}return await s,r}catch(n){throw n}}a(G8,"deleteTransactions")});var $U=b((tOe,qU)=>{"use strict";var IA=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};qU.exports=IA});var YU=b((sOe,VU)=>{"use strict";var q8=qs(),$8=Gl(),nOe=$U(),pi=M(),V8=J(),wA=ht(),Y8=ji(),K8=h_(),W8=d_(),{getSchemaPath:j8}=gt();VU.exports=Q8;async function Q8(e,t=!0){let r;e.schema===pi.SYSTEM_SCHEMA_NAME?r=Y8[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await J8(e),s=j8(e.schema,e.table),i=await wA.openEnvironment(s,e.table);return t===!0&&await z8(e,i,r.hash_attribute),wA.dropDBI(i,e.attribute),n}a(Q8,"lmdbDropAttribute");async function z8(e,t,r){let n=wA.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let d={};for(let u in c)u!==i&&(d[u]=c[u]);s=t.dbis[r].put(o,d,l)}await s}a(z8,"removeAttributeFromAllObjects");async function J8(e){let t=new q8(pi.SYSTEM_SCHEMA_NAME,pi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await K8(t)).filter(o=>o[pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(V8.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new $8(pi.SYSTEM_SCHEMA_NAME,pi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return W8(i)}a(J8,"dropAttributeFromSystem")});var JU=b((aOe,zU)=>{"use strict";var CA=ht(),$l=Bt(),oOe=nn(),DA=M(),KU=J(),{getTransactionAuditStorePath:X8}=gt(),Z8=xl(),nm=vl(),e9=V();zU.exports=t9;async function t9(e){let t=X8(e.schema,e.table),r=await CA.openEnvironment(t,e.table,!0),n=CA.listDBIs(r);CA.initializeDBIs(r,$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case DA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return WU(r,e.search_values);case DA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,n9(r,e.search_values,s);case DA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return r9(r,e.search_values);default:return WU(r)}}a(t9,"readAuditLog");function WU(e,t=[0,Date.now()]){KU.isEmpty(t[0])&&(t[0]=0),KU.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new nm,s))}a(WU,"searchTransactionsByTimestamp");function r9(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,QU(e,i))}return Object.fromEntries(r)}a(r9,"searchTransactionsByUsername");function n9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let d=t[c],u=Z8.equals(e,$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,$l.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,d);for(let{value:_}of u){let E=Number(_);n.has(E)?n.get(E).push(d.toString()):n.set(E,[d.toString()])}}let s=Array.from(n.keys()),i=QU(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],d=l.timestamp,u=n.get(d);jU(l,"records",r,u,o),jU(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(n9,"searchTransactionsByHashValues");function jU(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let d=s.get(l),u=d[d.length-1];if(u.timestamp===i)u[t]=[c];else{let _=new nm(e.operation,e.user_name,i,void 0);_[t]=[c],d.push(_)}}else{let d=new nm(e.operation,e.user_name,i,void 0);d[t]=[c],s.set(l,[d])}}}a(jU,"loopRecords");function QU(e,t){let r=[];try{let n=e.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new nm,i);r.push(o)}}catch(i){e9.warn(i)}return r}catch(n){throw n}}a(QU,"batchSearchTransactions")});var ZU=b((dOe,XU)=>{"use strict";var{getSchemaPath:lOe}=gt(),uOe=ht(),{database:s9}=(Le(),oe(lt));XU.exports={writeTransaction:i9};async function i9(e,t,r){return s9({database:e,table:t}).transaction(r)}a(i9,"writeTransaction")});var nv=b((fOe,rv)=>{"use strict";var{getSchemaPath:ev}=gt(),tv=ht();rv.exports={flush:o9,resetReadTxn:a9};async function o9(e,t){return(await tv.openEnvironment(ev(e,t),t.toString())).flushed}a(o9,"flush");async function a9(e,t){try{(await tv.openEnvironment(ev(e,t),t.toString())).resetReadTxn()}catch{}}a(a9,"resetReadTxn")});var av=b((hOe,ov)=>{"use strict";var{Readable:c9}=require("stream"),{getDatabases:l9}=(Le(),oe(lt)),{readSync:u9,openSync:d9,createReadStream:sv}=require("fs"),{open:_9}=require("lmdb"),iv=jd(),f9=Qd(),{AUDIT_STORE_OPTIONS:E9}=(Ki(),oe(cv)),{INTERNAL_DBIS_NAME:h9,AUDIT_STORE_NAME:m9}=Bt();ov.exports=S9;var PA=32768,p9=100;async function S9(e){let t=e.database||e.schema||"data",r=l9()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let d=r[s[0]];if(!d)throw new Error(`Can not find table ${s[0]}`);let u=d.dbisDB,_=_9({noSync:!0,maxDbs:f9.MAX_DBS}),E,f=_.openDB(h9,new iv(!1)),h=u.useReadTransaction(),T=0,S=a(async function(p,y){y.encoding="binary",y.encoder=void 0;let O=_.openDB(p,y),B=u.openDB(p,y);for(let{key:x,version:W,value:q}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=O.put(x,q,W),T++%p9===0&&(await new Promise(z=>setTimeout(z,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:p,value:y}of u.getRange({transaction:h,start:!1}))if(s.some(O=>p.startsWith?.(O+"/"))){f.put(p,y);let[,O]=p.split("/"),B=!O,x=new iv(!B,B);await S(p,x)}e.include_audit&&await S(m9,{...E9}),await E;let R=sv(_.path);return R.headers=l(),R.on("close",()=>{h.done(),_.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=d9(o.path);return o.transaction(()=>{let d=Buffer.alloc(PA);u9(c,d,0,PA),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let _=sv(null,{fd:c,start:PA}),E=new c9.from(async function*(){yield d;for await(let f of _)u.openTimer&&(u.openTimer=0),yield f;u.done()}());return E.headers=l(),E});function l(){let d=new Map;return d.set("content-type","application/octet-stream"),d.set("content-disposition",`attachment; filename="${t}"`),d.set("date",n),d}}a(S9,"getBackup")});var dv=b((pOe,uv)=>{"use strict";var T9=V(),{handleHDBError:g9}=fe(),R9=CD(),A9=wh(),b9=eA(),y9=bM(),O9=d_(),N9=aA(),I9=QM(),w9=sU(),C9=h_(),D9=_U(),P9=bU(),L9=wU(),M9=DU(),U9=UU(),v9=GU(),B9=mA(),H9=YU(),x9=JU(),k9=ZU(),lv=nv(),F9=av(),LA=class extends R9{static{a(this,"LMDBBridge")}async searchByConditions(t){return D9(t)}async getDataByHash(t){return await N9(t)}async searchByHash(t){return await I9(t)}async getDataByValue(t,r){return await w9(t,r)}async searchByValue(t){return await C9(t)}async createSchema(t){return await y9(t)}async dropSchema(t){return await P9(t)}async createTable(t,r){return await L9(t,r)}async dropTable(t){return await B9(t)}async createAttribute(t){return await A9(t)}async createRecords(t){return await b9(t)}async updateRecords(t){return await M9(t)}async upsertRecords(t){try{return await U9(t)}catch(r){throw g9(r,null,null,T9.ERR,r)}}async deleteRecords(t){return await O9(t)}async dropAttribute(t){return await H9(t)}async deleteAuditLogsBefore(t){return await v9(t)}async readAuditLog(t){return await x9(t)}writeTransaction(t,r,n){return k9.writeTransaction(t,r,n)}flush(t,r){return lv.flush(t,r)}resetReadTxn(t,r){return lv.resetReadTxn(t,r)}getBackup(t){return F9(t)}};uv.exports=LA});function Tv(e){UA=e}function V9(){$9=setInterval(function(){for(let e of MA)if(e.stale){let t=e[xe]?.url;hv.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},q9).unref()}var vA,Ev,hv,mv,pv,Sv,_v,MA,G9,T_,fv,UA,lc,sm,q9,$9,im=De(()=>{vA=v(nn()),Ev=v(fe()),hv=v(V());Hs();mv=v(te()),pv=v(M()),Sv=v(J()),_v=100,MA=new Set,G9=(0,Sv.convertToMS)(mv.get(pv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(Tv,"replicationConfirmation");lc=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),MA.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(MA.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(T_&&!this.overloadChecked&&performance.now()-fv>G9)throw new Ev.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp=t.timestamp||(0,vA.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let _=this.validated;this.validated=this.writes.length;for(let f=_;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=_;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let T=_;T<this.validated;T++){let S=this.writes[T];if(!S)continue;let R=S[f===0?"before":"beforeIntermediate"];if(R){let p=R();h?h.push?h.push(p):h=[h,p]:h=p}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(_){throw this.abort(),_}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(_=>_);let c=a(_=>{_.commit(r,_.entry,n)},"doWrite"),l=a(()=>{let _=this.writes[o++];if(_)if(_.key){n>0&&(_.entry=_.store.getEntry(_.key));let E=_.store.ifVersion(_.key,_.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),d=this.lmdbDb;if(this.writes.length>0&&(d?.retryRisk&&(d.retryRisk*=.99),this.writes.length+(d?.retryRisk||0)<_v>>n?l():s=this.writes[0].store.transaction(()=>{for(let _ of this.writes)_.entry=_.store.getEntry(_.key),c(_);return!0})),s)return T_||(T_=s,fv=performance.now(),T_.then(()=>{T_=null})),s.then(_=>{if(_){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let E=this.writes[0].store.rootStore.databaseName,f=this.writes[this.writes.length-1];UA&&f&&i.push(UA(E,f.store.getEntry(f.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return d&&(d.retryRisk=(d.retryRisk||0)+_v/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let u={txnTime:r};if(this.next){let _=this.next?.commit(t);if(_?.then)return _?.then(E=>({txnTime:r,next:E}));u.next=_}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},sm=class extends lc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,vA.getNextMonotonicTime)())}getReadTxn(){}},q9=3e4;a(V9,"startMonitoringTxns");V9()});function Ct(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new lc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[xe]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var gv,uc=De(()=>{gv=v(Vi());Hs();im();a(Ct,"transaction");(0,gv._assignPackageExport)("transaction",Ct);Ct.commit=function(e){let t=(e[xe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ct.abort=function(e){let t=(e[xe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var wv={};et(wv,{ResourceBridge:()=>xA});function kA({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function Av(e,t){let r=Si(e),n=kA(e,r);if(!r)throw new $s.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache},o;Ct(i,()=>new Promise(d=>o=d));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let d=c[l++],u;try{u=await r.get({id:d,lazy:s,select:n},i),u=u&&am(u)}catch(_){u={message:_.toString()}}return t?{value:{key:d,value:u}}:{value:u}}else return o(),{done:!0}},return(d){return o(),{value:d,done:!0}},throw(d){return o(),{done:!0}}}}}}function Si(e){let t=e.database||e.schema||K9,r=mt()[t];if(!r)throw(0,$s.handleHDBError)(new Error,Y9.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function bv(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*yv(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:d,value:u}=o;if(s?.timestamp===d)s.hash_values.push(l),s.records.push(u);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:d,hash_values:[l],records:[u]}}}s&&(yield s)}var Ov,om,$s,Nv,Vs,BA,HA,Iv,Y9,K9,W9,j9,Rv,xA,Cv=De(()=>{"use strict";Ov=v(dv()),om=v(kl()),$s=v(fe());Le();Nv=v(t_()),Vs=v(M()),BA=v(Ji()),HA=v(Gs()),Iv=v(J());uc();cm();({HDB_ERROR_MSGS:Y9}=$s.hdb_errors),K9="data",W9=1e4,j9=10,xA=class extends Ov.default{static{a(this,"ResourceBridge")}constructor(t){super(t),Rv=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,om.default)(t,"conditions");if(r)throw(0,$s.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Si(t);if(!n)throw new $s.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:kA(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new $s.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}Et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await Si(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Si(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(d=>{if(!d){let{value:u,version:_}=r.primaryStore.getEntry(o);return i(o,u,_)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(d=>setImmediate(d));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Si(t).dropTable()}createSchema(t){return Vl({database:t.schema,table:null}),BA.signalSchemaChange(new HA.SchemaEventMsg(process.pid,Vs.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await FA(t.schema),BA.signalSchemaChange(new HA.SchemaEventMsg(process.pid,Vs.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,Rv.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,Nv.default)(t),s,i=mt()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Ct(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],d=[];for(let u of t.records){let _=u[i.primaryKey],E=_!=null&&await i.get(_,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){d.push(u[i.primaryKey]);continue}E&&(E=am(E));for(let f in u)if(Object.prototype.hasOwnProperty.call(u,f)){let h=u[f];if(typeof h=="function")try{let T=h([[E]]);Array.isArray(T)&&(h=T[0].func_val,u[f]=h)}catch(T){throw T.message+="Trying to set key "+f+" on object"+JSON.stringify(u),T}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(u,f)||(u[f]=E[f]);await(_==null?i.create(u,o):i.put(u,o)),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:d}})}async deleteRecords(t){let r=mt()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Ct(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return bv(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=mt()[t.schema][t.table];if(!r.createdTimeProperty)throw new $s.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:Vs.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],d=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,Iv.async_set_timeout)(j9),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%W9===0&&await d();return l.length>0&&await d(),s?bv(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,om.default)(t,"hashes");if(r)throw r;return Av(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of Av(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Vs.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,om.default)(t,"value");if(n)throw n;let s=Si(t);if(!s)throw new $s.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===Vs.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:kA(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async getDataByValue(t,r){let n=new Map,s=Si(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){Si({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Si(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=Si(t),n={};switch(t.search_type){case Vs.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Vs.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of yv(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return yv(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(kA,"getSelect");a(Av,"getRecords");a(Si,"getTable");a(bv,"createDeleteResponse");a(yv,"groupRecordsInHistory")});var Pn=b((LOe,Dv)=>{"use strict";var{ResourceBridge:Q9}=(Cv(),oe(wv)),z9=te();z9.initSync();var lm;function J9(){return lm||(lm=new Q9,lm)}a(J9,"getBridge");Dv.exports=J9()});var Uv=b((UOe,Mv)=>{"use strict";var Pv=require("lodash"),g_=require("mathjs"),X9=require("jsonata"),Lv=J();Mv.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?Pv.uniqWith(e,Pv.isEqual):e,searchJSON:Z9,mad:R_.bind(null,g_.mad),mean:R_.bind(null,g_.mean),mode:R_.bind(null,g_.mode),prod:R_.bind(null,g_.prod),median:R_.bind(null,g_.median)};function R_(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(R_,"aggregateFunction");function Z9(e,t){if(typeof e!="string"||e.length===0)throw new Error("search json expression must be a non-empty string");let r="__"+e+"__";if(Lv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Lv.isEmpty(this.__ala__.res[r])){let n=X9(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(Z9,"searchJSON")});var Bv=b((BOe,vv)=>{"use strict";var nr=require("moment"),GA="YYYY-MM-DDTHH:mm:ss.SSSZZ";nr.suppressDeprecationWarnings=!0;vv.exports={current_date:()=>nr().utc().format("YYYY-MM-DD"),current_time:()=>nr().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return nr(e).utc().format("YYYY");case"month":return nr(e).utc().format("MM");case"day":return nr(e).utc().format("DD");case"hour":return nr(e).utc().format("HH");case"minute":return nr(e).utc().format("mm");case"second":return nr(e).utc().format("ss");case"millisecond":return nr(e).utc().format("SSS");default:break}},date:e=>nr(e).utc().format(GA),date_format:(e,t)=>nr(e).utc().format(t),date_add:(e,t,r)=>nr(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>nr(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=nr(e).utc(),s=nr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>nr().utc().valueOf(),get_server_time:()=>nr().format(GA),offset_utc:(e,t)=>nr(e).utc().utcOffset(t).format(GA)}});var Fv=b((HOe,kv)=>{"use strict";var e7=require("@turf/area"),t7=require("@turf/length"),r7=require("@turf/circle"),n7=require("@turf/difference"),s7=require("@turf/distance"),i7=require("@turf/boolean-contains"),o7=require("@turf/boolean-equal"),a7=require("@turf/boolean-disjoint"),c7=require("@turf/helpers"),Hv=M(),qe=J(),eo=V();kv.exports={geoArea:l7,geoLength:u7,geoCircle:d7,geoDifference:_7,geoDistance:xv,geoNear:f7,geoContains:E7,geoEqual:h7,geoCrosses:m7,geoConvert:p7};function l7(e){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return e7.default(e)}catch(t){return eo.trace(t,e),NaN}}a(l7,"geoArea");function u7(e,t){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return t7.default(e,{units:t||"kilometers"})}catch(r){return eo.trace(r,e),NaN}}a(u7,"geoLength");function d7(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return r7.default(e,t,{units:r||"kilometers"})}catch(n){return eo.trace(n,e,t),NaN}}a(d7,"geoCircle");function _7(e,t){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return n7(e,t)}catch(r){return eo.trace(r,e,t),NaN}}a(_7,"geoDifference");function xv(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return s7.default(e,t,{units:r||"kilometers"})}catch(n){return eo.trace(n,e,t),NaN}}a(xv,"geoDistance");function f7(e,t,r,n){if(qe.isEmpty(e)||qe.isEmpty(t))return!1;if(qe.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return xv(e,t,n)<=r}catch(s){return eo.trace(s,e,t),!1}}a(f7,"geoNear");function E7(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return i7.default(e,t)}catch(r){return eo.trace(r,e,t),!1}}a(E7,"geoContains");function h7(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return o7.default(e,t)}catch(r){return eo.trace(r,e,t),!1}}a(h7,"geoEqual");function m7(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return!a7.default(e,t)}catch(r){return eo.trace(r,e,t),!1}}a(m7,"geoCrosses");function p7(e,t,r){if(qe.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(qe.isEmpty(t))throw new Error("geo_type is required");if(qe.isEmpty(Hv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Hv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=qe.autoCastJSON(e)),c7[t](e,r)}a(p7,"geoConvert")});var um=b((kOe,Gv)=>{var dc=Uv(),xn=Bv(),Ti=Fv();Gv.exports=e=>{e.aggr.mad=e.aggr.MAD=dc.mad,e.aggr.mean=e.aggr.MEAN=dc.mean,e.aggr.mode=e.aggr.MODE=dc.mode,e.aggr.prod=e.aggr.PROD=dc.prod,e.aggr.median=e.aggr.MEDIAN=dc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=dc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=dc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=xn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=xn.current_time,e.fn.extract=e.fn.EXTRACT=xn.extract,e.fn.date=e.fn.DATE=xn.date,e.fn.date_format=e.fn.DATE_FORMAT=xn.date_format,e.fn.date_add=e.fn.DATE_ADD=xn.date_add,e.fn.date_sub=e.fn.DATE_SUB=xn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=xn.date_diff,e.fn.now=e.fn.NOW=xn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=xn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=xn.get_server_time,e.fn.getdate=e.fn.GETDATE=xn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=xn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ti.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ti.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ti.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ti.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ti.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ti.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ti.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ti.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ti.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ti.geoNear}});var Yv=b((FOe,Vv)=>{"use strict";var A_=require("lodash"),ln=require("alasql");ln.options.cache=!1;var S7=um(),qv=require("clone"),dm=require("recursive-iterator"),Ue=V(),Ze=J(),Yl=Pn(),T7=M(),{hdb_errors:g7}=fe(),{getDatabases:$v}=(Le(),oe(lt)),R7="IS NULL",Ys="There was a problem performing this search. Please check the logs and try again.";S7(ln);var qA=class{static{a(this,"SQLSearch")}constructor(t,r){if(Ze.isEmpty(t))throw Ue.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),Ze.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Ze.isEmptyOrZeroLength(n))return Ue.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Ue.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Ue.error(n),new Error(Ys)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Ue.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Ue.error(n),new Error(Ys)}if(Object.keys(this.data).length===0)return Ue.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Ue.error("Error thrown from processJoins in SQLSearch class method search."),Ue.error(n),new Error(Ys)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Ue.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Ue.error(n),new Error(Ys)}try{return t=await this._finalSQL(),t}catch(n){throw Ue.error("Error thrown from finalSQL in SQLSearch class method search."),Ue.error(n),new Error(Ys)}}_getColumns(){let t=new dm(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(qv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=A_.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=$v()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Ze.isEmpty(this.statement.where)){Ue.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new dm(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Ze.isEmpty(r)&&r.right)if(Ze.isNotEmptyAndHasValue(r.right.value)){let n=Ze.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new ln.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Ze.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new ln.yy.LogicValue({value:i}):n instanceof ln.yy.StringValue&&Ze.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new ln.yy.NumValue({value:i}))});if(t){Ue.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new dm(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!Ze.isEmpty(T7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Ze.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Ze.isEmptyOrZeroLength(r.left.columnid)||Ze.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(Ze.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!Ze.isEmpty(r.right.value)||!Ze.isEmpty(r.left.value)?n.add(Ze.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let d=0;d<l.length;d++)if(l[d].value)n.add(l[d].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Ze.isEmptyOrZeroLength(this.all_table_attributes)&&Ze.isEmptyOrZeroLength(this.statement.from)&&Ze.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&A_.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(Ze.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Ze.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(Ze.isEmptyOrZeroLength(this.all_table_attributes)&&!Ze.isEmptyOrZeroLength(this.columns.columns))return t;if(Ze.isEmptyOrZeroLength(this.all_table_attributes)&&Ze.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await ln.promise(r)}catch(r){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Ue.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(qv(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(Ze.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(R7)>-1&&this.tables.forEach(s=>{let i={columnid:$v()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=A_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,d=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!Ze.isEmpty(this.exact_search_values[d])&&!this.exact_search_values[d].ignore&&!Ze.isEmptyOrZeroLength(this.exact_search_values[d].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[d].values);let u=await Yl.getDataByHash(c);for(let _ of c.hash_values)u.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(u){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(u),new Error(Ys)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[d].values).map(async u=>{let _={...c};_.search_value=u;let E=await Yl.getDataByValue(_);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(u){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(u),new Error(Ys)}else if(!Ze.isEmpty(this.comparator_search_values[d])&&!this.comparator_search_values[d].ignore&&!Ze.isEmptyOrZeroLength(this.comparator_search_values[d].comparators))try{let u=this.comparator_search_values[d].comparators;for(let _=0,E=u.length;_<E;_++){let f=u[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await Yl.getDataByValue(c,f.operation);if(l)for(let[T]of h)this.data[i].__merged_data[T]||(this.data[i].__merged_data[T]=[...n[i]],this._setMergedHashAttribute(i,T));else for(let[T,S]of h)this.data[i].__merged_data[T]?this._updateMergedAttribute(i,T,s.attribute,S[s.attribute]):(this.data[i].__merged_data[T]=[...n[i]],this._updateMergedAttribute(i,T,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,T))}}catch(u){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(u),new Error(Ys)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await Yl.getDataByValue(c);if(l)for(let[_]of u)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of u)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(u){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(u),new Error(Ys)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof ln.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new ln.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new ln.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new ln.yy.FuncValue:new ln.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,T=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${T}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${T}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let d="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(d="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let u="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",_=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${d} ${u} ${_}`,h=this._convertColumnsToIndexes(f,s);E=await ln.promise(h,t),t=null}catch(f){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let T=E[f];o.forEach(S=>{T[S.key]!==null&&T[S.key]!==void 0&&S.keys.add(T[S.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),T=A_.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,R=T.length;S<R;S++){let p=T[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[p]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new dm(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=A_.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw Ue.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Ue.error(i),new Error(Ys)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let u in i)o.push(i[u][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await Yl.getDataByHash(c),d=s.columns.length;for(let u=0,_=o.length;u<_;u++){let E=o[u],f=l.get(E);for(let h=0;h<d;h++){let T=s.columns[h],S=f[T]===void 0?null:f[T];this.data[n].__merged_data[E].push(S)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();Ue.trace(`Final SQL: ${s}`),n=await ln.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ue.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ue.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return Ue.error(g7.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],d=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(d,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),d=`[${c}]`;n=n.replace(l,d)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Yl.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Ue.error("There was an error when processing this SQL operation. Check your logs"),Ue.error(o),new Error(Ys)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Vv.exports=qA});var Vr=b((qOe,Kv)=>{"use strict";var A7=ID();Kv.exports={searchByConditions:y7,searchByHash:O7,searchByValue:N7,search:I7};var $A=Pn(),{transformReq:VA}=J(),b7=Yv();async function y7(e){return VA(e),$A.searchByConditions(e)}a(y7,"searchByConditions");async function O7(e){VA(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of $A.searchByHash(e))r&&t.push(r);return t}a(O7,"searchByHash");async function N7(e){VA(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of $A.searchByValue(e))t.push(r);return t}a(N7,"searchByValue");function I7(e,t){try{let r=new A7(e);r.validate(),new b7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(I7,"search")});var _m=b((VOe,Wv)=>{"use strict";var w7=Pn();Wv.exports={writeTransaction:C7};function C7(e,t,r){return w7.writeTransaction(e,t,r)}a(C7,"writeTransaction")});var Jv=b((WOe,zv)=>{"use strict";var D7=Vr(),P7=as(),jv=V(),L7=Yr(),KOe=_m(),M7=require("clone"),KA=require("alasql"),U7=um(),Qv=require("util"),v7=Qv.promisify(P7.getTableSchema),B7=Qv.promisify(D7.search),H7=M(),YA=J();U7(KA);zv.exports={update:k7};var x7="There was a problem performing this update. Please check the logs and try again.";async function k7({statement:e,hdb_user:t}){let r=await v7(e.table.databaseid,e.table.tableid),n=F7(e.columns);YA.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=M7(s),c=YA.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,d=KA.parse(l).statements[0],u=await B7(d),_=G7(n,u);return q7(o,_,t)}a(k7,"update");function F7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=KA.compile(`SELECT ${r.expression.toString()} AS [${H7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw jv.error(t),new Error(x7)}}a(F7,"createUpdateRecord");function G7(e,t){return YA.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(G7,"buildUpdateRecords");async function q7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await L7.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){jv.error(`Error delete new_attributes from update response: ${i}`)}return s}a(q7,"updateRecords")});var Zv=b((JOe,Xv)=>{var $7=require("alasql"),V7=Vr(),Y7=V(),K7=Pn(),jA=require("util"),WA=J(),W7=M(),j7=as(),QOe=_m(),zOe=Yr(),Q7="record",z7="successfully deleted",J7=jA.callbackify(tee),X7=jA.promisify(V7.search),Z7=jA.promisify(j7.getTableSchema);Xv.exports={convertDelete:J7};function eee(e){return`${e.deleted_hashes.length} ${Q7}${e.deleted_hashes.length===1?"":"s"} ${z7}`}a(eee,"generateReturnMessage");async function tee({statement:e,hdb_user:t}){let r=await Z7(e.table.databaseid,e.table.tableid);WA.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=WA.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=$7.parse(o).statements[0],l={operation:W7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await X7(c);let d=await K7.deleteRecords(l);return WA.isEmptyOrZeroLength(d.message)&&(d.message=eee(d)),delete d.txn_time,d}catch(d){throw Y7.error(d),d.hdb_code?d.message:d}}a(tee,"convertDelete")});var s0=b((ZOe,n0)=>{"use strict";var ree=fi(),{hdb_errors:e0}=fe(),{getDatabases:t0}=(Le(),oe(lt));n0.exports={checkSchemaExists:r0,checkSchemaTableExists:nee,schema_describe:ree};async function r0(e){if(!t0()[e])return e0.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(r0,"checkSchemaExists");async function nee(e,t){let r=await r0(e);if(r)return r;if(!t0()[e][t])return e0.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(nee,"checkSchemaTableExists")});var Kl=b((tNe,see)=>{see.exports={name:"harperdb",version:"4.4.0-beta.2",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc --no-clean --reporter=lcovonly npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:replication && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test",format:"prettier .","format:fix":"npm run format -- --write",lint:"eslint .","lint:fix":"npm run lint -- --fix"},dependencies:{"@aws-sdk/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.6.0",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.28.1","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.9.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.1.3",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.0",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.2",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^1.1.0","serve-static":"2.1.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.23.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.5.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^7.18.0","@typescript-eslint/parser":"^7.18.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",eslint:"^8.57.0","eslint-config-prettier":"8.3.0","eslint-plugin-sonarjs":"^2.0.2",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^10.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"3.3.3",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.4.2","why-is-node-still-running":"^1.0.0"},overrides:{alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var I_={};et(I_,{addAnalyticsListener:()=>N_,recordAction:()=>gr,recordActionBinary:()=>kn,setAnalyticsEnabled:()=>iee});function iee(e){f0=e}function gr(e,t,r,n,s){if(!f0)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=hm.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let d=c;o.values=c=new Float32Array(l*2),c.set(d),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},hm.set(i,o)}fm||oee()}function kn(e,t,r,n,s){gr(!!e,t,r,n,s)}function N_(e){m0.push(e)}function oee(){fm=performance.now(),setTimeout(async()=>{let e=performance.now()-fm;fm=0;let t=[],r={time:Date.now(),period:e,threadId:_c.threadId,metrics:t};for(let[s,i]of hm){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,d=[],u;for(let _ of p0){let E=Math.floor(c*_),f=o[E-1];if(E>l){let h=E-l;if(f===u){let T=d[d.length-1];typeof T=="number"?d[d.length-1]={value:T,count:1+h}:T.count+=h}else d.push(h>1?{value:f,count:h}:f),u=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:d,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await S0()}let n=process.memoryUsage();t.push({metric:"memory",threadId:_c.threadId,byThread:!0,...n});for(let s of m0)s(t);hm=new Map,_c.parentPort?_c.parentPort.postMessage({type:h0,report:r}):R0({report:r})},E0).unref()}async function aee(e,t=6e4){let r=JA(),n=T0(),s=new Promise(T=>{let S=performance.now();setImmediate(()=>{let R=performance.now();R-S>5e3&&(0,b_.warn)("Unusually high event queue latency on the main thread of "+Math.round(R-S)+"ms"),S=performance.now()}),n.primaryStore.prefetch([1],()=>{let R=performance.now();R-S>5e3&&(0,b_.warn)("Unusually high task queue latency on the main thread of "+Math.round(R-S)+"ms"),T(R-S)})}),i;for(let T of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(T.value?.time){i=T.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,d=[],u;for(let{key:T,value:S}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!S)continue;if(o){if(T>o+t)break}else o=T;u=T;let{metrics:R,threadId:p}=S;for(let y of R||[]){let{path:O,method:B,type:x,metric:W,count:q,total:z,distribution:_e,threads:X,...ue}=y;q||(q=1);let j=W+(O?"-"+O:"");B!==void 0&&(j+="-"+B),x!==void 0&&(j+="-"+x);let ie=c.get(j);if(ie){if(ie.threads){let Ie=ie.threads[p];if(Ie)ie=Ie;else{ie.threads[p]={...ue};continue}}ie.count||(ie.count=1);let ye=ie.count;for(let Ie in ue){let Me=ue[Ie];typeof Me=="number"&&(ie[Ie]=(ie[Ie]*ye+Me*q)/(ye+q))}ie.count+=q,z>=0&&(ie.total+=z,ie.ratio=ie.total/ie.count)}else ie={period:t,...y},delete ie.distribution,c.set(j,ie),ie.byThread&&(ie.threads=[],ie.threads[p]={...ue},d.push(ie));if(_e){_e=_e.map(Ie=>typeof Ie=="number"?{value:Ie,count:1}:Ie);let ye=l.get(j);ye?ye.push(..._e):l.set(j,_e)}}await S0()}for(let T of d){let{path:S,method:R,type:p,metric:y,count:O,total:B,distribution:x,threads:W,...q}=T;W=W.filter(z=>z);for(let z in q){if(typeof T[z]!="number")continue;let _e=0;for(let X of W){let ue=X[z];typeof ue=="number"&&(_e+=ue)}T[z]=_e}T.count=W.length,delete T.threads,delete T.byThread}for(let[T,S]of l){let R=c.get(T);S.sort((Ie,Me)=>Ie.value>Me.value?1:-1);let p=R.count-1,y=[],O=0,B=0,x;for(let Ie of p0){let Me=p*Ie;for(;O<Me;)x=S[B++],O+=x.count,B===1&&O--;let tn=S[B>1?B-2:0];x||(x=S[0]),y.push(x.value-(x.value-tn.value)*(O-Me)/x.count)}let[W,q,z,_e,X,ue,j,ie,ye]=y;Object.assign(R,{p1:W,p10:q,p25:z,median:_e,p75:X,p90:ue,p95:j,p99:ie,p999:ye})}let _;for(let[T,S]of c)S.id=(0,Em.getNextMonotonicTime)(),S.time=u,n.primaryStore.put(S.id,S,{append:!0}).then(R=>{R||n.primaryStore.put(S.id,S)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let T=(0,Em.getNextMonotonicTime)(),S={id:T,metric:"main-thread-utilization",idle:f-i0,active:h-o0,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(T,S,{append:!0}).then(R=>{R||n.primaryStore.put(T,S)})}i0=f,o0=h}async function a0(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function JA(){return c0||(c0=Et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function T0(){return l0||(l0=Et({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function uee(){g0=!0;let e=(0,O_.get)(zA.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await aee(E0,e),await a0(JA(),cee),await a0(T0(),lee)},Math.min(e/2,2147483647)).unref()}function R0(e,t){let r=e.report;r.threadId=t?.threadId||_c.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(u0+=n.mean*n.count);r.totalBytesProcessed=u0,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(d0.get(t))}),d0.set(t,t.performance.eventLoopUtilization())),r.id=(0,Em.getNextMonotonicTime)(),JA().primaryStore.put(r.id,r),g0||uee(),dee&&(A0=fee(r))}async function fee(e){if(await A0,!Xo){let r=(0,y_.dirname)((0,b_.getLogFilePath)());try{Xo=await(0,QA.open)((0,y_.join)(r,"analytics.log"),"r+")}catch{Xo=await(0,QA.open)((0,y_.join)(r,"analytics.log"),"w+")}}let t=(await Xo.stat()).size;if(t>_ee){let r=Buffer.alloc(t);await Xo.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Xo.write(r,{position:0}),await Xo.truncate(r.length),t=r.length}await Xo.write(JSON.stringify(e)+`
12
+ `,t)}var _c,_0,b_,y_,QA,Em,O_,zA,hm,f0,fm,E0,h0,m0,p0,i0,o0,S0,cee,lee,c0,l0,g0,u0,d0,dee,A0,Xo,_ee,gi=De(()=>{_c=require("worker_threads"),_0=v(it());Le();b_=v(V()),y_=require("path"),QA=require("fs/promises"),Em=v(nn()),O_=v(te()),zA=v(M());$r();(0,O_.initSync)();hm=new Map,f0=(0,O_.get)(zA.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(iee,"setAnalyticsEnabled");a(gr,"recordAction");st.recordAnalytics=gr;a(kn,"recordActionBinary");fm=0,E0=1e3,h0="analytics-report",m0=[];a(N_,"addAnalyticsListener");p0=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(oee,"sendAnalytics");a(aee,"aggregation");i0=0,o0=0,S0=a(()=>new Promise(setImmediate),"rest");a(a0,"cleanup");cee=36e5,lee=31536e6;a(JA,"getRawAnalyticsTable");a(T0,"getAnalyticsTable");(0,_0.setChildListenerByType)(h0,R0);a(uee,"startScheduledTasks");u0=0,d0=new Map,dee=!1;a(R0,"recordAnalytics");_ee=1e6;a(fee,"logAnalytics")});var rb=b((ENe,U0)=>{"use strict";var{decode:Eee}=require("msgpackr"),{isMainThread:dNe,parentPort:_Ne,threadId:fNe}=require("worker_threads"),Sm=kt(),Wl=dt(),eb=M(),zr=V(),ZA=te(),hee=M(),{onMessageByType:mee}=it(),N0=zi(),{recordAction:b0,recordActionBinary:pee}=(gi(),oe(I_)),{publishToStream:See}=Sm,{ConsumerEvents:y0}=require("nats"),Tee=Vr(),{promisify:gee}=require("util"),I0=gee(setTimeout),Tm=1e4,gm,pm,Ree,Aee,w0,w_=new Map,jl=new Map;U0.exports={initialize:C0,ingestConsumer:tb,setSubscription:bee,setIgnoreOrigin:Nee,getDatabaseSubscriptions:Oee,updateConsumer:D0};async function C0(){mee(eb.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await D0(n)}),w0=!0,zr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await Sm.getNATSReferences();gm=e,pm=e.info.server_name,Ree=t,Aee=r}a(C0,"initialize");async function D0(e){if(e.status==="start"){let{js:t,jsm:r}=await P0(e.node_domain_name);tb(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=w_.get(e.stream_name+e.node_domain_name);t&&(zr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),w_.set(e.stream_name+e.node_domain_name,"close")),jl.get(e.node_domain_name)==="failed"&&jl.set(e.node_domain_name,"close")}}a(D0,"updateConsumer");var Rm=new Map;function bee(e,t,r){let n=Rm.get(e);n||Rm.set(e,n=new Map),n.set(t,r),w0||C0().then(yee)}a(bee,"setSubscription");async function yee(){let e=await Tee.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Wl.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await P0(r),!n))break;let{schema:o,table:c}=i,l=N0.createNatsTableStreamName(o,c);tb(l,n,s,r)}}}a(yee,"accessConsumers");async function P0(e){let t,r,n=1;for(;!r;)try{t=await gm.jetstream({domain:e}),r=await gm.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(jl.get(e)==="close")break;jl.set(e,"failed"),n%10===1&&zr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<Tm?n++*100:Tm;await I0(i)}return{js:t,jsm:r}}a(P0,"connectToRemoteJS");function Oee(){return Rm}a(Oee,"getDatabaseSubscriptions");var L0;function Nee(e){L0=e}a(Nee,"setIgnoreOrigin");var M0=100,O0=new Array(M0),mm=0;async function tb(e,t,r,n){let{connection:s}=await Sm.getNATSReferences();gm=s,pm=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,pm),zr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(d){if(jl.get(n)==="close")break;o%10===1&&zr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",d.message),d.code==="404"&&(zr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await Sm.createConsumer(r,e,pm,new Date(Date.now()).toISOString()));let u=o++*100<Tm?o++*100:Tm;await I0(u)}let c=!1,l;for(;!c;){if(w_.get(e+n)==="close"||jl.get(n)==="close"){w_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:ZA.get(eb.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),w_.set(e+n,l);let d=!1;(async()=>{for await(let u of await l.status())if(u.type===y0.ConsumerDeleted&&(await l.close(),c=!0),u.type===y0.HeartbeatsMissed){let _=u.data;zr.trace(`${_} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),_===100&&(zr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),d=!0)}})();try{for await(let u of l)await O0[mm],O0[mm]=Iee(u).catch(_=>{zr.error(_)}),++mm>=M0&&(mm=0)}catch(u){u.message==="consumer deleted"?(zr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):zr.error("Error consuming clustering ingest, restarting consumer",u)}}}a(tb,"ingestConsumer");async function Iee(e){let t=Eee(e.data);b0(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),zr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=ZA.get(eb.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Wl.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Wl.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Wl.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!L0),pee(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Wl.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:d,records:u,hash_values:_,__origin:E,expiresAt:f}=t;zr.trace("processing message:",o,c,d,(u?"records: "+u.map(B=>B?.id):"")+(_?"ids: "+_:""),"with sequence:",e.seq),zr.trace(`messageProcessor nats msg id: ${e.headers.get(Wl.MSG_HEADERS.NATS_MSG_ID)}`);let h;u||(u=_);let T=new Promise(B=>h=B),{timestamp:S,user:R,node_name:p}=E||{},y=Rm.get(c)?.get(d);if(!y)throw new Error(`Missing table for replication message: ${d}`);if(o==="define_schema")t.type=o,t.onCommit=h,y.send(t);else if(u.length===1&&!l)y.send({type:XA(o),value:u[0],id:_?.[0],expiresAt:f,timestamp:S,table:d,onCommit:h,user:R,nodeName:p});else{let B=u.map((x,W)=>({type:XA(o),value:x,expiresAt:f,id:_?.[W],table:d}));for(;l;)B.push({type:XA(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;y.send({type:"transaction",writes:B,table:d,timestamp:S,onCommit:h,user:R,nodeName:p})}ZA.get(hee.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&See(e.subject.split(".").slice(0,-1).join("."),N0.createNatsTableStreamName(c,d),e.headers,e.data),await T;let O=Date.now()-S;S&&b0(O,"replication-latency",e.subject,o,"ingest")}catch(o){zr.error(o)}e.ack()}a(Iee,"messageProcessor");function XA(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(XA,"convertOperation")});var kt=b((RNe,J0)=>{"use strict";var Rr=te();Rr.initSync();var wee=require("fs-extra"),Cee=require("semver"),P_=require("path"),{monotonicFactory:Dee}=require("ulidx"),B0=Dee(),Pee=require("util"),H0=require("child_process"),Lee=Pee.promisify(H0.exec),Mee=H0.spawn,Cr=dt(),Qe=M(),Am=J(),Ks=V(),bm=zi(),Uee=_m(),C_=wt(),{broadcast:vee,onMessageByType:Bee,getWorkerIndex:Hee}=it(),{isMainThread:x0}=require("worker_threads"),{Encoder:xee,decode:ob}=require("msgpackr"),k0=new xee,{isEmpty:mc}=Am,F0=vn(),mNe=48*36e11;x0&&Bee(Qe.ITC_EVENT_TYPES.RESTART,()=>{un=void 0,hc=void 0});var{connect:kee,StorageType:Fee,RetentionPolicy:Gee,AckPolicy:ab,DeliverPolicy:cb,DiscardPolicy:qee,NatsConnection:pNe,JetStreamManager:SNe,JetStreamClient:TNe,StringCodec:gNe,JSONCodec:$ee,createInbox:lb,headers:Vee,ErrorCode:v0}=require("nats"),{PACKAGE_ROOT:Yee}=M(),Kee=Kl(),{recordAction:Wee}=(gi(),oe(I_)),G0=$ee(),jee="clustering",Qee=Kee.engines[Cr.NATS_SERVER_NAME],zee=P_.join(Yee,"dependencies"),ib=P_.join(zee,`${process.platform}-${process.arch}`,Cr.NATS_BINARY_NAME),nb,sb,D_,fc,Ec;J0.exports={runCommand:q0,checkNATSServerInstalled:Jee,createConnection:ub,getConnection:L_,getJetStreamManager:M_,getJetStream:V0,getNATSReferences:Ri,getServerList:Zee,createLocalStream:db,listStreams:Y0,deleteLocalStream:ete,getServerConfig:Ql,listRemoteStreams:tte,viewStream:rte,viewStreamIterator:nte,publishToStream:ste,request:ate,reloadNATS:_b,reloadNATSHub:cte,reloadNATSLeaf:lte,extractServerName:ote,requestErrorHandler:ute,createLocalTableStream:Q0,createTableStreams:fte,purgeTableStream:z0,purgeSchemaTableStreams:Ete,getStreamInfo:hte,updateLocalStreams:pte,closeConnection:Xee,getJsmServerName:ym,addNatsMsgHeader:K0,clearClientCache:$0,updateRemoteConsumer:dte,createConsumer:W0,updateConsumerIterator:_te};async function q0(e,t=void 0){let{stdout:r,stderr:n}=await Lee(e,{cwd:t});if(n)throw new Error(n.replace(`
11
13
  `,""));return r.replace(`
12
- `,"")}a(G0,"runCommand");async function Qee(){try{await Nee.access(iO)}catch{return!1}let e=await G0(`${iO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Iee.eq(t,Wee)}a(Qee,"checkNATSServerInstalled");async function uO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await F0.getClusterUser();if(pc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Vs.trace("create nats connection called");let i=await Hee({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:gr.get(je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:gr.get(je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:gr.get(je.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Vs.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Vs.error("Error with Nats client connection, connection closed",o),q0()}),i}a(uO,"createConnection");function q0(){un=void 0,Ec=void 0,hc=void 0,mc=void 0}a(q0,"clearClientCache");async function zee(){un&&(await un.drain(),un=void 0,Ec=void 0,hc=void 0,mc=void 0)}a(zee,"closeConnection");var un,mc;async function L_(){return mc||(mc=uO(gr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),un=await mc),un||mc}a(L_,"getConnection");async function M_(){if(Ec)return Ec;pc(un)&&await L_();let{domain:e}=Kl(je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(pc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ec=await un.jetstreamManager({domain:e,timeout:6e4}),Ec}a(M_,"getJetStreamManager");async function $0(){if(hc)return hc;pc(un)&&await L_();let{domain:e}=Kl(je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(pc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return hc=un.jetstream({domain:e,timeout:6e4}),hc}a($0,"getJetStream");async function Ai(){let e=un||await L_(),t=Ec||await M_(),r=hc||await $0();return{connection:e,jsm:t,js:r}}a(Ai,"getNATSReferences");async function Jee(e){let t=gr.get(je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await F0.getClusterUser(),s=await uO(t,r,n),i=lO(),o=s.subscribe(i),c=[],l,d=(async()=>{for await(let u of o){let _=k0.decode(u.data);_.response_time=Date.now()-l,c.push(_)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Am.async_set_timeout(e),await o.drain(),await s.close(),await d,c}a(Jee,"getServerList");async function dO(e,t){let{jsm:r}=await Ai(),n=gr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=gr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=gr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:xee.File,retention:Fee.Limits,subjects:t,discard:kee.Old,max_msgs:s,max_bytes:i,max_age:n})}a(dO,"createLocalStream");async function V0(){let{jsm:e}=await Ai(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(V0,"listStreams");async function Xee(e){let{jsm:t}=await Ai();await t.streams.delete(e)}a(Xee,"deleteLocalStream");async function Zee(e){let{connection:t}=await Ai(),r=[],n=lO(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(k0.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(Zee,"listRemoteStreams");async function ete(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ai(),i=v0(),o={durable_name:i,ack_policy:aO.Explicit};t&&(o.deliver_policy=cO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let d=[];for await(let u of l){let _=oO(u.data),E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:_};if(u.headers&&(E.origin=u.headers.get(Ir.MSG_HEADERS.ORIGIN)),d.push(E),u.ack(),u.info.pending===0)break}return await c.delete(),d}a(ete,"viewStream");async function*tte(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ai(),i=v0(),o={durable_name:i,ack_policy:aO.Explicit};t&&(o.deliver_policy=cO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let d of l){let u=oO(d.data);u[0]||(u=[u]);for(let _ of u){let E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:_};d.headers&&(E.origin=d.headers.get(Ir.MSG_HEADERS.ORIGIN)),yield E}if(d.ack(),d.info.pending===0)break}await c.delete()}a(tte,"viewStreamIterator");async function rte(e,t,r,n){Vs.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Y0(n,r);let{js:s}=await Ai(),i=await bm(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:x0.encode(n);try{Vs.trace(`publishToStream publishing to subject: ${o}`),Yee(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 W0(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){Vs.trace(`publishToStream creating stream: ${t}`);let u=o.split(".");u[2]="*",await dO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(rte,"publishToStream");function Y0(e,t){t===void 0&&(t=qee());let r=gr.get(je.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Ir.MSG_HEADERS.ORIGIN)&&r&&t.append(Ir.MSG_HEADERS.ORIGIN,r),t}a(Y0,"addNatsMsgHeader");function Kl(e){e=e.toLowerCase();let t=P_.join(gr.get(je.CONFIG_PARAMS.ROOTPATH),Kee);if(e===je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return pc(sO)&&(sO={port:C_.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:C_.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Ir.SERVER_SUFFIX.HUB,config_file:Ir.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:P_.join(t,Ir.PID_FILES.HUB),hdb_nats_path:t}),sO;if(e===je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return pc(nO)&&(nO={port:C_.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:C_.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Ir.SERVER_SUFFIX.LEAF,config_file:Ir.NATS_CONFIG_FILES.LEAF_SERVER,domain:C_.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Ir.SERVER_SUFFIX.LEAF,pid_file_path:P_.join(t,Ir.PID_FILES.LEAF),hdb_nats_path:t}),nO;Vs.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Kl,"getServerConfig");async function K0(e,t,r,n){try{await e.consumers.add(t,{ack_policy:aO.Explicit,durable_name:r,deliver_policy:cO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(K0,"createConsumer");async function nte(e,t,r){await e.consumers.delete(t,r)}a(nte,"removeConsumer");function ste(e){return e.split(".")[1]}a(ste,"extractServerName");async function ite(e,t,r=6e4,n=lO()){if(!Am.isObject(t))throw new Error("data param must be an object");let s=x0.encode(t),{connection:i}=await Ai(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return oO(c.data)}a(ite,"request");function _O(e){return new Promise(async(t,r)=>{let n=Pee(iO,["--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 ote(){let{pid_file_path:e}=Kl(je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await _O(e)}a(ote,"reloadNATSHub");async function ate(){let{pid_file_path:e}=Kl(je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await _O(e)}a(ate,"reloadNATSLeaf");function cte(e,t,r){let n;switch(e.code){case U0.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case U0.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(cte,"requestErrorHandler");async function lte(e,t){let r=t+Ir.SERVER_SUFFIX.LEAF,{connection:n}=await Ai(),{jsm:s}=await pte(r),{schema:i,table:o}=e,c=Om.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await W0(async()=>{if(e.subscribe===!0)await K0(s,c,n.info.server_name,l);else try{await nte(s,c,n.info.server_name)}catch(d){Vs.trace(d)}})}a(lte,"updateRemoteConsumer");async function ute(e,t,r,n){let s=Om.createNatsTableStreamName(e,t),i=r+Ir.SERVER_SUFFIX.LEAF,o={type:je.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!H0&&vee()<gr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=rO();await c(o)}await Mee(o),n==="stop"&&await Am.async_set_timeout(1e3)}a(ute,"updateConsumerIterator");function W0(e){return Lee.writeTransaction(je.SYSTEM_SCHEMA_NAME,je.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(W0,"exclusiveLock");async function j0(e,t){let r=Om.createNatsTableStreamName(e,t),n=await bm(),s=Ete(e,t,n);await dO(r,[s])}a(j0,"createLocalTableStream");async function dte(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await j0(n,s)}}a(dte,"createTableStreams");async function Q0(e,t,r=void 0){if(gr.get(je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Om.createNatsTableStreamName(e,t),{domain:s}=Kl(je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await L_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")Vs.warn(n);else throw n}}a(Q0,"purgeTableStream");async function _te(e,t){if(gr.get(je.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await Q0(e,t[r])}a(_te,"purgeSchemaTableStreams");async function fte(e){return(await M_()).streams.info(e)}a(fte,"getStreamInfo");function Ete(e,t,r){return`${Ir.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(Ete,"createSubjectName");async function bm(){if(D_)return D_;if(D_=(await M_())?.nc?.info?.server_name,D_===void 0)throw new Error("Unable to get jetstream manager server name");return D_}a(bm,"getJsmServerName");async function hte(){let e=await M_(),t=await bm(),r=await V0();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=mte(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let d=i.split(".");d[d.length-1]=t;let u=d.join(".");Vs.trace(`Updating stream subject name from: ${i} to: ${u}`),s.subjects[0]=u,await e.streams.update(s.name,s)}}a(hte,"updateLocalStreams");function mte(e){let{config:t}=e,r=!1,n=gr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=gr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=gr.get(je.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(mte,"updateStreamLimits");async function pte(e){let t,r;try{t=await un.jetstream({domain:e}),r=await un.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw Vs.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(pte,"connectToRemoteJS")});var Wl=b(Nm=>{var ym=V();for(let e of["trace","debug","info","warn","error","fatal","notify"])ym.logsAtLevel(e)&&(Nm[e]=ym[e]);Nm.loggerWithTag=e=>ym.loggerWithTag(e,!0);Nm.setLogLevel=ym.setLogLevel});function fO(e){let t=e.get(Im),r=t?(0,jl.unpack)(t):null;r||(r={remoteNameToId:{}});let n=ut(),s=!1;r.nodeName=ut();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let d=i[l];d===0?c=l:d>o&&(o=d)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:v_(e)??1,nodes:[]})})}i[n]=0,e.putSync(Im,(0,jl.pack)(r))}return r}function U_(e){return fO(e).remoteNameToId}function X0(e,t,r){let n=fO(r),s=n.remoteNameToId,i=new Map,o=!1;for(let c in t){let l=t[c],d=s[c];if(d==null){let u=0;for(let _ in s){let E=s[_];E>u&&(u=E)}d=u+1,s[c]=d,o=!0}i.set(l,d)}return o&&r.putSync(Im,(0,jl.pack)(n)),i}function wm(e,t){let r=fO(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Im,(0,jl.pack)(r))}return J0.info?.("The remote node name map",e,n,s),s}var J0,jl,Im,EO=Ce(()=>{J0=B(Wl());as();jl=require("msgpackr"),Im=Symbol.for("remote-ids");a(fO,"getIdMappingRecord");a(U_,"exportIdMapping");a(X0,"remoteToLocalNodeId");a(wm,"getIdOfRemoteNode")});var jo,hO=Ce(()=>{jo=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 tB={};tt(tB,{Resources:()=>Cm,keyArrayToString:()=>Ql,resetResources:()=>Ste,resources:()=>Qo});function Ste(){return Qo=new Cm}function Ql(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var Z0,eB,Cm,Qo,B_=Ce(()=>{dc();hO();Z0=B(V()),eB=B(ce()),Cm=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new eB.ServerError(`Conflicting paths for ${t}`);Z0.default.error(c),i.Resource=new jo(c)}super.set(t,i);for(let[c,l]of this){let d=2;for(;(d=c.indexOf("/",d))>-1;){let u=this.get(c.slice(0,d));u&&(u.hasSubPaths=!0),d+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(!l&&c.indexOf(".")>-1){let d=c.split(".");l=this.get(d[0])}if(l&&(!r||l.exportTypes?.[r]!==!1)){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),s&&(!r||s.exportTypes?.[r]!==!1)?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(!r||s.exportTypes?.[r]!==!1)&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return wt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(Ste,"resetResources");a(Ql,"keyArrayToString")});function SO(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=nB,Tte(e.primaryStore,e.auditStore)):(c=rB,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{sB(rB[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let d=l[o];d||(d=l[o]=new Map,d.envs=l,d.tableId=o,d.store=e.primaryStore),t=Ql(t);let u=new pO(r);u.startTime=n;let _=d.get(t);return _?_.push(u):(d.set(t,_=[u]),_.tables=d,_.key=t),u.subscriptions=_,u}function sB(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),iB(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ht(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Ql(c),d=0;do{let u=o.get(l);if(u){for(let E of u)if(!(d>0&&!(E.includeDescendants&&!(E.onlyChildren&&d>1)))){if(E.startTime>=n){(0,mO.info)("omitting",c,E.startTime,n);continue}try{let f;E.supportsTransactions&&E.txnInProgress!==i.version&&(f=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,f)}catch(f){console.error(f),(0,mO.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_>-1?l=l.slice(0,_):l=null,d++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function Tte(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=nB[s];if(!l)return;let d=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{sB(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",d)&&d()})}}function iB(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function oB(e){return e.nextTransaction||(SO({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),iB(e)),e.nextTransaction}var mO,rB,nB,pO,TO=Ce(()=>{mO=B(V());Tl();B_();Wi();rB=Object.create(null),nB=Object.create(null);a(SO,"addSubscription");pO=class extends In{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(sB,"notifyFromTransactionData");a(Tte,"listenToCommits");a(iB,"nextTransaction");a(oB,"whenNextTransaction")});var uB={};tt(uB,{commits_awaiting_replication:()=>Xl,getHDBNodeTable:()=>wr,iterateRoutes:()=>x_,shouldReplicateToNode:()=>H_,subscribeToNodeUpdates:()=>Zl});function wr(){return aB||(aB=ft({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"replicates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Zl(e){wr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==ut()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r)),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function H_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&wr().primaryStore.get(ut())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function gte(){Zl(e=>{zo({},(t,r)=>{let n=e.name,s=cB.get(n);if(s||cB.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=new Float64Array(i.getUserSharedBuffer(["replicated",r,n],new ArrayBuffer(8),{callback:()=>{let c=o[0],l=o.lastTime;for(let{txnTime:d,onConfirm:u}of Xl.get(r)||[])d>l&&d<=c&&u();o.lastTime=c}}));o.lastTime=0,s.set(r,o)}})})}function*x_(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=zl.default.get(Jl.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!zl.default.get(Jl.CONFIG_PARAMS.REPLICATION_PORT)&&zl.default.get(Jl.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||zl.default.get(Jl.CONFIG_PARAMS.REPLICATION_PORT)||zl.default.get(Jl.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){lB.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{url:r,subscription:t.subscriptions,routes:t.routes}}}var lB,zl,Jl,aB,cB,Xl,eu=Ce(()=>{Le();as();im();lB=require("worker_threads"),zl=B(te()),Jl=B(M());server.nodes=[];a(wr,"getHDBNodeTable");a(Zl,"subscribeToNodeUpdates");a(H_,"shouldReplicateToNode");cB=new Map;pv((e,t,r)=>{Xl||(Xl=new Map,gte());let n=Xl.get(e);return n||Xl.set(e,n=[]),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:()=>{++i===r&&s()}})})});a(gte,"startSubscriptionToReplications");a(x_,"iterateRoutes")});var EB={};tt(EB,{connectedToNode:()=>Sc,disconnectedFromNode:()=>nu,ensureNode:()=>no,requestClusterStatus:()=>fB,startOnMainThread:()=>RO});async function RO(e){let t=0,r=ht();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){Dm.set(i,v_(l.auditStore));break}}}Oi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes.search([]))i.push(o);for(let o of x_(e))try{let c=!o.subscriptions;if(c){let d=ut();wr().primaryStore.get(d)===void 0&&await no(d,{name:d,url:e.url??Jo(),replicates:!0})}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(d=>d.url===o.url))continue;s(o)}catch(c){console.error(c)}Zl(s)});let n;function s(i,o=i?.name){let c=ut()&&o===ut()||Jo()&&i?.url===Jo();if(c){let _=!!i?.replicates;if(n!==void 0&&n!==_)for(let E of wr().search([]))E.replicates&&E.name!==o&&s(E,E.name);n=_}if(Ct.trace("Setting up node replication for",i),!i){for(let[_,E]of ro){let f;for(let[h,{worker:p,nodes:T}]of E){let g=T[0];if(g&&g.name==o){f=!0;for(let[S,{worker:C}]of E)E.delete(S),C?.postMessage({type:"unsubscribe-from-node",node:o,database:S,url:_});break}}if(f){ro.get(_).iterator.remove(),ro.delete(_);return}}return}if(c)return;if(!i.url){Ct.info(`Node ${i.name} is missing url`);return}let l=ro.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(Ct.info(`Added node ${i.name} at ${i.url} for process ${ut()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[_,E]of tu)if(i.url===E.url){tu.delete(_);break}tu.set(i.name,i)}let d=ht();if(l||(l=new Map,ro.set(i.url,l)),l.iterator=zo(e,(_,E,f)=>{f?u(E,!0):u(E,!1)}),i.subscriptions)for(let _ of i.subscriptions){let E=_.database||_.schema;d[E]||(Ct.warn(`Database ${E} not found for node ${i.name}, making a subscription anyway`),u(E,!1))}function u(_,E){Ct.trace("Setting up replication for database",_,"on node",i.name);let f=l.get(_),h,p=[{replicateByDefault:E,...i}];Dm.has(_)&&(p.push({replicateByDefault:E,name:ut(),start_time:Dm.get(_),end_time:Date.now(),replicates:!0}),Dm.delete(_));let T=H_(i,_),g=Oi.workers.filter(S=>S.name==="http");if(f?(h=f.worker,f.nodes=p):T&&(t=t%g.length,h=g[t++],l.set(_,{worker:h,nodes:p,url:i.url}),h?.on("exit",()=>{l.get(_)?.worker===h&&(l.delete(_),u(_,E))})),T)setTimeout(()=>{let S={type:"subscribe-to-node",database:_,nodes:p};h?h.postMessage(S):ru(S)},Rte);else{wr().primaryStore.get(ut())?.replicates||(n=!1);let S={type:"unsubscribe-from-node",database:_,url:i.url};h?h.postMessage(S):Lm(S)}}a(u,"onDatabase")}a(s,"onNodeUpdate"),nu=a(function(i){try{Ct.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(tu.keys()),c=o.sort(),l=c.indexOf(i.name||bi(i.url));if(l===-1){Ct.warn("Disconnected node not found in node map",i.name,o);return}let d=ro.get(i.url),u=d?.get(i.database);if(!u){Ct.warn("Disconnected node not found in replication map",i.database,d);return}if(u.connected=!1,i.finished)return;let _=u.nodes[0];if(!(_.replicates===!0||_.replicates?.sends||_.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let f=c[E],h=tu.get(f);d=ro.get(h.url);let p=d?.get(i.database);if(!p){E=(E+1)%c.length;continue}let{worker:T,nodes:g}=p,S=!1;for(let C of u.nodes){if(g.some(y=>y.name===C.name)){Ct.info(`Disconnected node is already failing over to ${f} for ${i.database}`);continue}g.push(C),S=!0}if(!S){Ct.info(`Disconnected node ${i.name} has no nodes to fail over to ${f}`);return}u.redirectingTo=p,Ct.info(`Failing over ${i.database} from ${i.name} to ${f}`),T?T.postMessage({type:"subscribe-to-node",database:i.database,nodes:g}):ru({database:i.database,nodes:g});return}Ct.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){Ct.error("Error failing over node",o)}},"disconnectedFromNode"),Sc=a(function(i){let o=ro.get(i.url),c=o?.get(i.database);if(!c){Ct.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.catchingUpFrom=i.lastSendTime,c.redirectingTo){let{worker:l,nodes:d}=c.redirectingTo,u=d.find(_=>_.name===i.name);c.redirectingTo=null,u&&(d.splice(d.indexOf(u),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:d}):ru({database:i.database,nodes:d}))}},"connectedToNode"),(0,Oi.onMessageByType)("disconnected-from-node",nu),(0,Oi.onMessageByType)("connected-to-node",Sc),(0,Oi.onMessageByType)("request-cluster-status",fB)}function fB(e,t){let r=[];for(let[n,s]of tu)try{let i=ro.get(s.url);Ct.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:d,connected:u,nodes:_,latency:E,catchingUpFrom:f}]of i)o.push({database:l,connected:u,latency:E,catchingUpFrom:f?new Date(f).toISOString():"up-to-date",threadId:d?.threadId,nodes:_.map(h=>h.name)});let c=(0,gO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){Ct.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function no(e,t){let r=wr();e=e??bi(t.url),t.name=e;let n=r.primaryStore.get(e);if(Ct.info(`Ensuring node ${e} at ${t.url}, existing record:`,n),!n)await r.put(t);else{t.replicates&&!dB.default.get(_B.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,gO.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let d of o)if((c.database??c.schema)===(d.database??d.schema)&&c.table===d.table){d.publish=c.publish,d.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}Ct.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Oi,Pm,Ct,gO,dB,_B,Rte,ro,nu,Sc,tu,Dm,F_=Ce(()=>{Le();Oi=B(st());as();Pm=require("worker_threads");eu();Ct=B(V()),gO=require("lodash"),dB=B(te()),_B=B(M()),Rte=200,ro=new Map,tu=new Map,Dm=new Map;a(RO,"startOnMainThread");a(fB,"requestClusterStatus");Pm.parentPort&&(nu=a(e=>{Pm.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Sc=a(e=>{Pm.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Oi.onMessageByType)("subscribe-to-node",e=>{ru(e)}),(0,Oi.onMessageByType)("unsubscribe-from-node",e=>{Lm(e)}));a(no,"ensureNode")});var Ks=b(FB=>{"use strict";var Dr=require("path"),cs=require("fs-extra"),su=require("node-forge"),gB=require("net"),{generateKeyPair:OO,X509Certificate:Zo,createPrivateKey:RB}=require("crypto"),Ate=require("util");OO=Ate.promisify(OO);var Dt=su.pki,so=require("joi"),{v4:Ote}=require("uuid"),{validateBySchema:AB}=dt(),gt=V(),ls=te(),Ys=M(),{CONFIG_PARAMS:gc}=Ys,yi=wR(),{ClientError:k_}=ce(),Rc=require("node:tls"),{relative:OB,join:bB}=require("node:path"),{CERT_PREFERENCE_APP:QNe,CERTIFICATE_VALUES:bte}=yi,yte=$a(),bO=It(),hB=parseInt(process.version.slice(1))<20,{table:Nte,getDatabases:Ite,databases:AO}=(Le(),ie(lt));Object.assign(FB,{generateKeys:PB,updateConfigCert:MB,createCsr:vte,signCertificate:Bte,setCertTable:iu,loadCertificates:CB,reviewSelfSignedCert:CO,createTLSSelector:BB,listCertificates:HB,addCertificate:qte,removeCertificate:Vte,createNatsCerts:Fte,generateCertsKeys:xte,getReplicationCert:q_,getReplicationCertAuth:Ute,renewSelfSigned:kte,hostnamesFromCert:xB});var{urlToNodeName:yB,getThisNodeUrl:wte,getThisNodeName:Um,clearThisNodeName:Cte}=(as(),ie(ta)),{readFileSync:Dte,watchFile:Pte,statSync:NB}=require("node:fs"),zNe=te(),{getTicketKeys:Lte,onMessageFromWorkers:Mte}=st(),Xo=V(),{isMainThread:IB}=require("worker_threads"),{TLSSocket:wB,createSecureContext:JNe}=require("node:tls"),NO=3650,G_=["127.0.0.1","localhost","::1"],IO=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Mte(async e=>{e.type===Ys.ITC_EVENT_TYPES.RESTART&&(ls.initSync(!0),await CO())});var Cr;function ea(){return Cr||(Cr=Ite().system.hdb_certificate,Cr||(Cr=Nte({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__"}]}))),Cr}a(ea,"getCertTable");async function q_(){let e=BB("operations-api"),t={secureContexts:null,setSecureContext:s=>{}};await e.initialize(t);let r=t.secureContexts.get(Um());if(!r)return;let n=new Zo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(q_,"getReplicationCert");async function Ute(){ea();let e=(await q_()).options.cert,r=new Zo(e).issuer.match(/CN=(.*)/)?.[1];return Cr.get(r)}a(Ute,"getReplicationCertAuth");var mB,Ac=new Map;function CB(){if(mB)return;mB=!0;let e=[{configKey:gc.TLS},{configKey:gc.OPERATIONSAPI_TLS}];ea();let t=Dr.dirname(bO.getConfigFilePath()),r;for(let{configKey:n}of e){let s=bO.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&OB(bB(t,"keys"),o);c&&pB(o,l=>{Ac.set(c,l)},"private key");for(let l of[!1,!0]){let d=i[l?"certificateAuthority":"certificate"];if(d&&IB){let u;pB(d,_=>{if(bte.cert===_)return;let E=i.hostname??i.hostnames??i.host??i.hosts;E&&!Array.isArray(E)&&(E=[E]);let f=UB(d),h=new Zo(f),p;try{p=DO(h)}catch(C){gt.error("error extracting common name from certificate",C);return}if(p==null){gt.error("error extracting common name from certificate");return}let T=Cr.primaryStore.get(p),g=NB(d).mtimeMs,S=!T||T.is_self_signed?1:T.file_timestamp??T.__updatedtime__;if(T&&g<=S){g<S&&gt.info(`Certificate ${p} at ${d} is older (${new Date(g)}) than the certificate in the database (${S>1?new Date(S):"only self signed certificate available"})`);return}r=Cr.put({name:p,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:f,private_key_name:c,is_authority:l,hostnames:E,file_timestamp:g,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(CB,"loadCertificates");function pB(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&IB&&gt.warn(`Reloading ${r}:`,e),n=c,t(UB(e)))}catch(c){gt.error(`Error loading ${r}:`,e,c)}},"loadFile");cs.existsSync(e)?s(NB(e)):gt.error(`${r} file not found:`,e),Pte(e,{persistent:!1},s)}a(pB,"loadAndWatch");function SB(){let e=wte();if(e==null){let t=G_[0];return gt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return yB(e)}a(SB,"getHost");function Mm(){let e=Um();if(e==null){let t=G_[0];return gt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Mm,"getCommonName");async function vte(){let e=await q_(),t=Dt.certificateFromPem(e.options.cert),r=Dt.privateKeyFromPem(e.options.key);gt.info("Creating CSR with cert named:",e.name);let n=Dt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Mm()},...IO];gt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:DB()}];return gt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),su.pki.certificationRequestToPem(n)}a(vte,"createCsr");function DB(){let e=G_.includes(Mm())?G_:[...G_,Mm()];return e.includes(SB())||e.push(SB()),[{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=>gB.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(DB,"certExtensions");async function Bte(e){let t={},r=Dr.join(ls.getHdbBasePath(),Ys.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;ea();for await(let u of Cr.search([]))if(u.is_authority&&!u.details.issuer.includes("HarperDB-Certificate-Authority")){if(Ac.has(u.private_key_name)){n=Ac.get(u.private_key_name),s=u;break}else if(u.private_key_name&&await cs.exists(Dr.join(r,u.private_key_name))){n=cs.readFile(Dr.join(r,u.private_key_name)),s=u;break}}if(!n){let u=await yO();s=u.ca,n=u.private_key}n=Dt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=Dt.certificateFromPem(s.certificate);gt.info("Signing CSR with cert named",s.name);let o=Dt.certificationRequestFromPem(e.csr);try{o.verify()}catch(u){return gt.error(u),new Error("Error verifying CSR: "+u.message)}let c=su.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()+NO),gt.info("sign cert setting validity:",c.validity),gt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),gt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let d=o.getAttribute({name:"extensionRequest"}).extensions;gt.info("sign cert adding extensions from CSR:",d),c.setExtensions(d),c.publicKey=o.publicKey,c.sign(n,su.md.sha256.create()),t.certificate=Dt.certificateToPem(c)}else gt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Bte,"signCertificate");async function Hte(e,t){await iu({name:Um(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await iu({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:Dt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Hte,"createCertificateTable");async function iu(e){let t=new Zo(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},ea(),await Cr.patch(e)}a(iu,"setCertTable");async function PB(){let e=await OO("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:Dt.publicKeyFromPem(e.publicKey),private_key:Dt.privateKeyFromPem(e.privateKey)}}a(PB,"generateKeys");async function wO(e,t,r){let n=Dt.createCertificate();if(!t){let o=await q_();t=Dt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+NO);let i=[{name:"commonName",value:Mm()},...IO];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(DB()),n.sign(e,su.md.sha256.create()),Dt.certificateToPem(n)}a(wO,"generateCertificates");async function yO(){let e=await HB(),t;for(let r of e){if(!r.is_authority)continue;let n=Ac.get(r.private_key_name);if(r.private_key_name&&n&&new Zo(r.certificate).checkPrivateKey(RB(n))){gt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;gt.trace("No CA found with matching private key")}a(yO,"getCertAuthority");async function LB(e,t){let r=Dt.createCertificate();r.publicKey=t,r.serialNumber=Math.random().toString().slice(2,10),r.validity.notBefore=new Date;let n=new Date;r.validity.notAfter=n,r.validity.notAfter.setDate(n.getDate()+NO);let s=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ls.get(gc.REPLICATION_HOSTNAME)??yB(ls.get(gc.REPLICATION_URL))??Ote().split("-")[0]}`},...IO];r.setSubject(s),r.setIssuer(s),r.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),r.sign(e,su.md.sha256.create());let i=Dr.join(ls.getHdbBasePath(),Ys.LICENSE_KEY_DIR_NAME),o=Dr.join(i,yi.PRIVATEKEY_PEM_NAME);return await cs.writeFile(o,Dt.privateKeyToPem(e)),r}a(LB,"generateCertAuthority");async function xte(){let{private_key:e,public_key:t}=await PB(),r=await LB(e,t),n=await wO(e,t,r);await Hte(n,r),MB()}a(xte,"generateCertsKeys");async function Fte(){let e=await wO(Dt.privateKeyFromPem(yi.CERTIFICATE_VALUES.key),void 0,Dt.certificateFromPem(yi.CERTIFICATE_VALUES.cert)),t=Dr.join(ls.getHdbBasePath(),Ys.LICENSE_KEY_DIR_NAME),r=Dr.join(t,yi.NATS_CERTIFICATE_PEM_NAME);await cs.exists(r)||await cs.writeFile(r,e);let n=Dr.join(t,yi.NATS_CA_PEM_NAME);await cs.exists(n)||await cs.writeFile(n,yi.CERTIFICATE_VALUES.cert)}a(Fte,"createNatsCerts");async function kte(){ea();for await(let e of Cr.search([{attribute:"is_self_signed",value:!0}]))await Cr.delete(e.name);await CO()}a(kte,"renewSelfSigned");async function CO(){Cte(),await CB(),ea();let e,t=ls.get(gc.TLS_PRIVATEKEY),r=a(async()=>e||(e=Dt.privateKeyFromPem(await cs.readFile(t)),e),"getPrivateKey"),n,s=await yO();if(!s){n=!0,gt.info("No self signed Cert Authority found, generating new self signed CA"),await r();let o=await LB(e,Dt.setRsaPublicKey(e.n,e.e));await iu({name:o.subject.getField("CN").value,uses:["https","wss"],certificate:Dt.certificateToPem(o),private_key_name:OB(bB(ls.get(gc.ROOTPATH),"keys"),t),is_authority:!0,is_self_signed:!0})}if(!await q_()){let o=Um();gt.info(`A suitable replication certificate was not found, creating new self singed cert named: ${o}`),s=s??await yO();let c=Dt.certificateFromPem(s.ca.certificate),l=c.publicKey,d=await wO(Dt.privateKeyFromPem(s.private_key),l,c);await iu({name:o,uses:["https","operations","wss"],certificate:d,is_authority:!1,private_key_name:s.ca.private_key_name,is_self_signed:!0})}}a(CO,"reviewSelfSignedCert");function MB(){let e=yte(Object.keys(Ys.CONFIG_PARAM_MAP),!0),t=Dr.join(ls.getHdbBasePath(),Ys.LICENSE_KEY_DIR_NAME),r=Dr.join(t,yi.PRIVATEKEY_PEM_NAME),n=Dr.join(t,yi.NATS_CERTIFICATE_PEM_NAME),s=Dr.join(t,yi.NATS_CA_PEM_NAME),i=Ys.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),bO.updateConfigValue(void 0,void 0,o,!1,!0)}a(MB,"updateConfigCert");function UB(e){return e.startsWith("-----BEGIN")?e:Dte(e,"utf8")}a(UB,"readPEM");var TB=Rc.createSecureContext;Rc.createSecureContext=function(e){if(!e.cert||!e.key)return TB(e);let t={...e};delete t.key,delete t.cert;let r=TB(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var vB=Rc.Server;Rc.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),vB.call(this,e,t)};Rc.Server.prototype=vB.prototype;var Gte=wB.prototype._init;wB.prototype._init=function(e,t){Gte.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 Tc=new Map;function BB(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function d(){try{r.clear(),Tc.clear();let u=0;for await(let _ of AO.system.hdb_certificate.search([])){if(e!=="operations-api"&&_.uses?.includes?.("operations"))continue;let E=_.certificate,f=new Zo(E);_.is_authority&&(f.asString=E,Tc.set(f.subject,E))}for await(let _ of AO.system.hdb_certificate.search([]))try{if(_.is_authority||!(e==="operations-api")&&_.uses?.includes?.("operations"))continue;let f=_.is_self_signed?1:2,h=Ac.get(_.private_key_name);!h&&_.private_key_name&&(h=await cs.readFile(Dr.join(ls.get(gc.ROOTPATH),Ys.LICENSE_KEY_DIR_NAME,_.private_key_name)));let p=_.certificate,T=new Zo(p);if(Tc.has(T.issuer)&&(p+=`
13
- `+Tc.get(T.issuer)),!h||!p)throw new Error("Missing private key or certificate for secure server");let g={ciphers:_.ciphers,ticketKeys:Lte(),availableCAs:Tc,ca:t&&Array.from(Tc.values()),cert:p,key:h,key_file:_.private_key_name,is_self_signed:_.is_self_signed};o&&(g.sessionIdContext=o.sessionIdContext);let S=Rc.createSecureContext(g);S.name=_.name,S.options=g,S.quality=f,S.certificateAuthorities=Array.from(Tc),S.certStart=p.toString().slice(0,100);let C=_.hostnames??xB(T);Array.isArray(C)||(C=[C]);let y;for(let x of C)if(x){x[0]==="*"&&(s=!0,x=x.slice(1)),gB.isIP(x)&&(y=!0);let F=r.get(x)?.quality??0;f>F&&r.set(x,S)}else Xo.error("No hostname found for certificate at",Rc.certificate);f>u&&(i.defaultContext=n=S,u=f,o&&(o.defaultContext=S,Xo.trace("Applying default TLS",S.name,"for",o.ports,"cert named",_.name)))}catch(E){Xo.error("Error applying TLS for",_.name,E)}o?.secureContextsListeners.forEach(_=>_()),c(n)}catch(u){l(u)}}a(d,"updateTLS"),AO.system.hdb_certificate.subscribe({listener:d,omitCurrent:!0}),d()})),i;function i(o,c){Xo.info("TLS requested for",o,this.isReplicationConnection);let l=o;for(;;){let u=r.get(l);if(u)return Xo.debug("Found certificate for",o,u.certStart),u.replicationContext&&(this.isReplicationConnection||hB)&&(u=u.replicationContext),c(null,u);if(s&&l){let _=l.indexOf(".",1);_<0?l="":l=l.slice(_)}else break}o?Xo.debug("No certificate found to match",o,"using the default certificate"):Xo.debug("No SNI, using the default certificate");let d=n;d?d.replicationContext&&(this.isReplicationConnection||hB)&&(d=d.replicationContext):Xo.info("No default certificate found"),c(null,d)}a(i,"SNICallback")}a(BB,"createTLSSelector");async function HB(){ea();let e=[];for await(let t of Cr.search([]))e.push(t);return e}a(HB,"listCertificates");async function qte(e){let t=AB(e,so.object({name:so.string().required(),certificate:so.string().required(),is_authority:so.boolean().required(),private_key:so.string(),hosts:so.array(),uses:so.array()}));if(t)throw new k_(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new Zo(n),c=!1,l=!1,d;for(let[f,h]of Ac)!s&&!c&&o.checkPrivateKey(RB(h))&&(c=!0,d=f),s&&s===h&&(l=!0,d=f);if(!i&&!s&&!c)throw new k_("A suitable private key was not found for this certificate");let u;if(!r){try{u=DO(o)}catch(f){gt.error(f)}if(u==null)throw new k_("Error extracting certificate common name, please provide a name parameter")}let _=$te(r??u);s&&!c&&!l&&(await cs.writeFile(Dr.join(ls.getHdbBasePath(),Ys.LICENSE_KEY_DIR_NAME,_+".pem"),s),Ac.set(_,s));let E={name:r??u,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&d||i&&s)&&(E.private_key_name=d??_+".pem"),await iu(E),"Successfully added certificate: "+_}a(qte,"addCertificate");function $te(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a($te,"sanitizeName");async function Vte(e){let t=AB(e,so.object({name:so.string().required()}));if(t)throw new k_(t.message);let{name:r}=e;ea();let n=await Cr.get(r);if(!n)throw new k_(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Cr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(gt.info("Removing private key named",s),await cs.remove(Dr.join(ls.getHdbBasePath(),Ys.LICENSE_KEY_DIR_NAME,s)))}return await Cr.delete(r),"Successfully removed "+r}a(Vte,"removeCertificate");function DO(e){return e.subject.match(/CN=(.*)/)?.[1]}a(DO,"extractCommonName");function xB(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):[DO(e)]}a(xB,"hostnamesFromCert")});async function BO(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=ut(),i;if(e.includes("wss://")){if(!LO){let l=(0,eH.createTLSSelector)("operations-api"),d={secureContexts:null};await l.initialize(d),LO=d.secureContexts}if(i=LO.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,rH.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,ALPNProtocols:["http/1.1","harperdb-replication"],rejectUnauthorized:n!==!1,secureContext:void 0};return n!==!1&&i&&(c.secureContext=tH.createSecureContext({...i.options,ca:Array.from(na)})),new XB.WebSocket(e,"harperdb-replication-v1",c)}function km(e,t,r){let n=t.port||t.securePort,s=vO.pid%1e3+"-"+ZB.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),d=t.database,u=t.databaseSubscriptions||Oc,_,E,f=!1,h=t.subscription;h?.then&&h.then(re=>h=re);let p=t.tables||d&&ht()[d];if(!r){de.error?.("No authorization provided"),ye(1008,"Unauthorized");return}let T=new Map,g=[],S=r.name;S&&t.connection&&(t.connection.nodeName=S);let C,y,x,F,Y,$,Z=1e3,Q,_e=0,K=0;if(t.url){let re=a(()=>{Y?e.terminate():(Y=performance.now(),e.ping())},"send_ping");x=setInterval(re,zB).unref(),re()}else se();function se(){clearTimeout(F),F=setTimeout(()=>{de.warn?.(`Timeout waiting for ping from ${S}, terminating connection and reconnecting`),e.terminate()},zB*2).unref()}a(se,"resetPingTimer"),d&&hl(d);let le,we,ve=[],et=[],va,Ba=[],bn=[],Rd=[],Ad=150,YE=0,zT=0,At,Ha,Zn,Ms,KE;e.on("message",re=>{_e=performance.now();try{let ge=re.dataView=new au(re.buffer,re.byteOffset,re.byteLength);if(re[0]>127){let m=(0,ct.decode)(re),[R,O,A]=m;switch(R){case GB:{if(O){if(S){if(S!==O){de.error?.(s,`Node name mismatch, expecting to connect to ${S}, but peer reported name as ${O}, disconnecting`),e.send((0,ct.encode)([ou])),ye(1008,"Node name mismatch");return}}else if(S=O,t.connection?.tentativeNode){let P=t.connection.tentativeNode;P.name=S,t.connection.tentativeNode=null,no(S,P)}if(t.connection&&(t.connection.nodeName=S),de.debug?.(s,"received node name:",S,"db:",d),!d)try{hl(d=m[2]),d==="system"&&(le=zo(t,(P,H)=>{oi(H)&&Fa(H)}),e.on("close",()=>{le?.remove()}))}catch(P){de.warn?.(s,"Error setting database",P),e.send((0,ct.encode)([ou])),ye(1008,P.message);return}WE()}break}case jB:{de.debug?.(s,"Received table definitions for",O.map(P=>P.table));for(let P of O){let H=m[2];P.database=H;let k;oi(H)&&(H==="system"?Ve[H]?.[P.table]||(k=MO(P,Ve[H]?.[P.table])):k=MO(P,Ve[H]?.[P.table]),_||(_=k?.auditStore),p||(p=ht()?.[H]))}break}case ou:ye();break;case YB:try{let P=r?.replicates||r?.subscribers||r?.name;server.operation(O,{user:r},!P).then(H=>{Array.isArray(H)&&(H={results:H}),H.requestId=O.requestId,e.send((0,ct.encode)([Bm,H]))},H=>{e.send((0,ct.encode)([Bm,{requestId:O.requestId,error:H instanceof Error?H.toString():H}]))})}catch(P){e.send((0,ct.encode)([Bm,{requestId:O.requestId,error:P instanceof Error?P.toString():P}]))}break;case Bm:let{resolve:I,reject:w}=T.get(O.requestId);O.error?w(new Error(O.error)):I(O),T.delete(O.requestId);break;case PO:let N=m[3];p||(d?de.error?.(s,"No tables found for",d):de.error?.(s,"Database name never received"));let v=p[N];v=MO({table:N,database:d,attributes:O.attributes,schemaDefined:O.schemaDefined},v),ve[A]={name:N,decoder:new ct.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:O.typedStructs,structures:O.structures}),getEntry(P){return v.primaryStore.getEntry(P)},rootStore:v.primaryStore.rootStore};break;case qB:KE=_?X0(S,O,_):new Map,va=m[2],de.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${va}`);break;case $B:let U=A;Rd[U]=O;break;case WB:let L=["replicated",d,S];E||(E=new Float64Array(_.getUserSharedBuffer(L,new ArrayBuffer(8)))),E[0]=O,de.trace?.(s,"received and broadcasting committed update",O),E.buffer.notify();break;case KB:C=O,h.send({type:"end_txn",localTime:C,remoteNodeIds:g});break;case VB:{let P=O,H;try{let k=m[3],ue=et[A]||(et[A]=p[m[4]]);if(!ue)return de.warn?.("Unknown table id trying to handle record request",A);let X=ue.primaryStore.getBinaryFast(Symbol.for("structures")),Ne=X.length;if(Ne!==zT){zT=Ne;let he=(0,ct.decode)(X);e.send((0,ct.encode)([PO,{typedStructs:he.typed,structures:he.named},A,ue.tableName]))}let fe=ue.primaryStore.getBinaryFast(k);if(fe){let he=ue.primaryStore.decoder.decode(fe,{valueAsBuffer:!0});H=(0,ct.encode)([vm,P,{value:he.value,expiresAt:he.expiresAt,version:he.version,residencyId:he.residencyId,nodeId:he.nodeId,user:he.user}])}else H=(0,ct.encode)([vm,P])}catch(k){H=(0,ct.encode)([vm,P,{error:k.message}])}e.send(H);break}case vm:{let{resolve:P,reject:H,tableId:k,key:ue}=T.get(m[1]),X=m[2];if(X?.error)H(new Error(X.error));else if(X){let Ne=ve[k].decoder.decode(X.value);X.value=Ne,X.key=ue,P(X)}else P();T.delete(m[1]);break}case kB:{Ms=O;let P,H,k=!1;if(h){if(d!==h.databaseName&&!h.then){de.error?.("Subscription request for wrong database",d,h.databaseName);return}}else h=u.get(d);if(de.debug?.(s,"received subscription request for",d,"at",Ms),!h){let me;h=new Promise(Oe=>{de.debug?.("Waiting for subscription to database "+d),me=Oe}),h.ready=me,Oc.set(d,h)}if(r.name)H=wr().subscribe(r.name),H.then(async me=>{P=me;for await(let Oe of P){let Ke=Oe.value;if(!(Ke?.replicates===!0||Ke?.replicates?.receives||Ke?.subscriptions?.some(Xe=>(Xe.database||Xe.schema)===d&&Xe.publish!==!1))){k=!0,e.send((0,ct.encode)([ou])),ye(1008,`Unauthorized database subscription to ${d}`);return}}},me=>{de.error?.(s,"Error subscribing to HDB nodes",me)});else if(!(r?.permissions?.super_user||r.replicates)){e.send((0,ct.encode)([ou])),ye(1008,`Unauthorized database subscription to ${d}`);return}if(Zn&&(de.debug?.(s,"stopping previous subscription",d),Zn.emit("close")),Ms.length===0)return;let ue,X=Ms[0],Ne=a(me=>{if(me&&(X.replicateByDefault?!X.tables.includes(me.tableName):X.tables.includes(me.tableName)))return ue=me,{table:me}},"tableToTableEntry"),fe={txnTime:0},he,ne,z=1/0,Re,ke=a((me,Oe)=>{if(z=Oe,me.type==="end_txn"){fe.txnTime&&(o[i]!==66&&de.error?.("Invalid encoding of message"),ka(9),ka(Fm),Od(Re=Oe),Kt()),i=c,fe.txnTime=0;return}let Ke=me.nodeId,Xe=me.tableId,We=ne[Xe];if(!We&&(We=ne[Xe]=Ne(h.tableById[Xe]),!We))return de.debug?.("Not subscribed to table",Xe);let at=We.table,Sr=at.primaryStore,qr=Sr.encoder;if(me.extendedType&fh||!qr.typedStructs){let Lo=me.getValue(Sr,!0);JSON.stringify(Lo)}let $r=he[Ke];if(!($r&&$r.startTime<Oe&&(!$r.endTime||$r.endTime>Oe)))return $_&&de.trace?.(s,"skipping replication update",me.recordId,"to:",S,"from:",Ke,"subscribed:",he),vw();$_&&de.trace?.(s,"sending replication update",me.recordId,"to:",S,"from:",Ke,"subscribed:",he);let JT=me.version;fe.txnTime!==JT&&(fe.txnTime&&($_&&de.trace?.(s,"new txn time, sending queued txn",fe.txnTime),o[i]!==66&&de.error?.("Invalid encoding of message"),Kt()),fe.txnTime=JT,i=c,Od(JT));let qa=me.residencyId,XT=xa(qa,at),jE;if(XT&&!XT.includes(S)){let Lo=xa(me.previousResidencyId,at);if(Lo&&!Lo.includes(S)&&(me.type==="put"||me.type==="patch")||at.getResidencyById)return vw();let bd=me.recordId;de.trace?.(s,"sending invalidation",bd,S,"from",Ke);let tg=0;qa&&(tg|=Wa),me.previousResidencyId&&(tg|=ja);let rg,QE=null;for(let Bw in at.indices){if(!QE){if(rg=me.getValue(Sr,!0),!rg)break;QE={}}QE[Bw]=rg[Bw]}jE=Rl(me.version,Xe,bd,null,Ke,me.user,me.type==="put"||me.type==="patch"?"invalidate":me.type,qr.encode(QE),tg,qa,me.previousResidencyId,me.expiresAt)}function vw(){de.trace?.(s,"skipping audit record",me.recordId),$||($=setTimeout(()=>{$=null,(Re||0)+QB/2<z&&($_&&de.trace?.(s,"sending skipped sequence update",z),e.send((0,ct.encode)([KB,z])))},QB).unref())}a(vw,"skipAuditRecord");let ZT=qr.typedStructs,eg=qr.structures;if((ZT?.length!=We.typed_length||eg?.length!=We.structure_length)&&(We.typed_length=ZT?.length,We.structure_length=eg.length,de.debug?.(s,"send table struct",We.typed_length,We.structure_length),We.sentName||(We.sentName=!0),e.send((0,ct.encode)([PO,{typedStructs:ZT,structures:eg,attributes:at.attributes,schemaDefined:at.schemaDefined},Xe,We.table.tableName]))),qa&&!bn[qa]&&(e.send((0,ct.encode)([$B,XT,qa])),bn[qa]=!0),jE)ka(jE.length),Ga(jE);else{let Lo=me.encoded,bd=Lo[0]===66?8:0;ka(Lo.length-bd),Ga(Lo,bd)}},"sendAuditRecord"),Kt=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");Zn=new UO.EventEmitter,Zn.once("close",()=>{k=!0,P?.end()});for(let{startTime:me}of Ms)me<z&&(z=me);(H||Promise.resolve()).then(async()=>{h=await h,_=h.auditStore,ne=h.tableById.map(Ne),he=[];for(let{name:Oe,startTime:Ke,endTime:Xe}of Ms){let We=wm(Oe,_);de.debug?.("subscription to",Oe,"using local id",We,"starting",Ke),he[We]={startTime:Ke,endTime:Xe}}Fa(d),le||(le=bc(Oe=>{Oe.databaseName===d&&Fa(d)}),we=V_(Oe=>{Oe===d&&(e.send((0,ct.encode)([ou])),ye())}),e.on("close",()=>{le?.remove(),we?.remove()})),e.send((0,ct.encode)([qB,U_(h.auditStore),Ms.map(({name:Oe})=>Oe)]));let me=!0;do{isFinite(z)||(de.warn?.("Invalid sequence id "+z),ye(1008,"Invalid sequence id"+z));let Oe;if(me&&!k&&(me=!1,!(HO(_)<=z)&&server.nodes[0]?.name===S)){de.info?.("Replicating all tables to",S);let We=z,at=Gm(_);for(let Sr in p){let qr=p[Sr];for(let $r of qr.primaryStore.getRange({snapshot:!1})){if(k)return;$r.localTime>=z&&(de.trace?.(s,"Copying record from",d,Sr,$r.key,$r.localTime),We=Math.max($r.localTime,We),Oe=!0,ke({recordId:$r.key,tableId:qr.tableId,type:"put",getValue(){return $r.value},encoded:qr.primaryStore.getBinary($r.key),version:$r.version,residencyId:$r.residencyId,nodeId:at},$r.localTime))}}z=We}for(let{key:Xe,value:We}of _.getRange({start:z||1,exclusiveStart:!0,snapshot:!1})){if(k)return;K=Xe;let at=Ht(We);ke(at,Xe),e._socket.writableNeedDrain&&await new Promise(Sr=>e._socket.once("drain",Sr)),Zn.startTime=Xe,Oe=!0}Oe&&ke({type:"end_txn"},z);let Ke=Hm.get(ue);Ke||Hm.set(ue,Ke=[]),Ke.push(Xe=>{}),K=0,await oB(_)}while(!k)}).catch(me=>{de.error?.(s,"Error handling subscription to node",me),ye(1008,"Error handling subscription to node")});break}}return}ge.position=8;let ot=!0,Te,G;do{let m=ge.readInt();if(m===9&&ge.getUint8(ge.position)==Fm){ge.position++,C=G=ge.readFloat64(),de.trace?.("received remote sequence update",C,d);break}let R=ge.position,O=Ht(re.subarray(R,R+m)),A=ve[O.tableId];A||de.error?.(`No table found with an id of ${O.tableId}`);let I;O.residencyId&&(I=Rd[O.residencyId],de.trace?.(s,"received residency list",I,O.type,O.recordId)),Te={table:A.name,id:O.recordId,type:O.type,nodeId:KE.get(O.nodeId),residencyList:I,timestamp:O.version,value:O.getValue(A),user:O.user,beginTxn:ot,expiresAt:O.expiresAt},ot=!1,$_&&de.trace?.(s,"received replication message",O.type,"id",Te.id,"version",O.version,"nodeId",Te.nodeId,"name",Te.value?.name),h.send(Te),ge.position=R+m}while(ge.position<re.byteLength);YE++,Tr(re.byteLength,"bytes-received",S+"."+d+"."+Te.table,"replication","ingest"),YE>Ad&&!At&&(At=!0,e.pause()),h.send({type:"end_txn",localTime:C,remoteNodeIds:g,onCommit(){if(Te){let m=Date.now()-Te.timestamp;Tr(m,"replication-latency",S+"."+d+"."+Te.table,Te.type,"ingest")}YE--,At&&(At=!1,e.resume()),!y&&G&&(de.trace?.(s,"queuing confirmation of a commit at",G),setTimeout(()=>{e.send((0,ct.encode)([WB,y])),de.trace?.(s,"sent confirmation of a commit at",y),y=null},Yte)),y=G}})}catch(ge){de.error?.(s,"Error handling incoming replication message",ge)}}),e.on("ping",se),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-Y,Sc({name:S,database:d,url:t.url,lastSendTime:K,latency:t.connection.latency})),Y=null}),e.on("close",(re,ge)=>{clearInterval(x),clearTimeout(F),Zn&&Zn.emit("close"),Ha&&Ha.end();for(let[ot,{reject:Te}]of T)Te(new Error("Connection closed"));de.debug?.(s,"closed",re,ge?.toString())});function Uw(){}a(Uw,"recordRemoteNodeSequence");function ye(re,ge){e.isFinished=!0,e.close(re,ge)}a(ye,"close");function WE(){if(f||(f=!0,t.connection?.on("subscriptions-updated",WE)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let re=new Map;try{for(let Te of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let G of Te.value.nodes||[])G.seqId>(re.get(G.id)??0)&&re.set(G.id,G.seqId)}catch(Te){if(!Te.message.includes("Can not re"))throw Te}let ge=t.connection?.nodeSubscriptions?.[0];g=[];let ot=t.connection?.nodeSubscriptions.map((Te,G)=>{let m=[],{replicateByDefault:R}=Te;if(Te.subscriptions){for(let w of Te.subscriptions)if(w.subscribe&&(w.schema||w.database)===d){let N=w.table;p?.[N]?.replicate!==!1&&m.push(N)}R=!1}else for(let w in p)(R?p[w].replicate===!1:p[w].replicate)&&m.push(w);let O=_&&wm(Te.name,_),A=h?.dbisDB?.get([Symbol.for("seq"),O])??1,I=Math.max(A?.seqId??1,(typeof Te.start_time=="string"?new Date(Te.start_time).getTime():Te.start_time)??1);if(de.debug?.("Starting time recorded in db",Te.name,O,d,A?.seqId,"start time:",I),ge!==Te){I>5e3&&(I-=5e3);let w=_&&wm(ge.name,_),N=h?.dbisDB?.get([Symbol.for("seq"),w])??1;for(let v of N?.nodes||[])v.name===Te.name&&(I=v.seqId,de.debug?.("Using sequence id from proxy node",ge.name,I))}return g.push(O),re.get(O)>I&&(I=re.get(O),de.debug?.("Updating start time from more recent txn recorded",ge.name,I)),{name:Te.name,replicateByDefault:R,tables:m,startTime:I,endTime:Te.end_time}});if(ot)if(de.debug?.(s,"sending subscription request",ot,h?.dbisDB?.path),clearTimeout(Q),ot.length>0)e.send((0,ct.encode)([kB,ot]));else{let Te=a(()=>{let G=performance.now();Q=setTimeout(()=>{_e<=G?ye(1008,"No nodes to subscribe to"):Te()},Z)},"schedule_close");Te()}}a(WE,"sendSubscriptionRequestUpdate");function xa(re,ge){if(!re)return;let ot=Ba[re];return ot||(ot=ge.getResidencyRecord(re),Ba[re]=ot),ot}a(xa,"getResidence");function oi(re){return!(ra&&ra!="*"&&!ra[re]&&!ra.includes?.(re)&&!ra.some?.(ge=>ge.name===re))}a(oi,"checkDatabaseAccess");function hl(re){if(h=h||u.get(re),!oi(re))throw new Error(`Access to database "${re}" is not permitted`);h||de.warn?.(`No database named "${re}" was declared and registered`),_=h?.auditStore,p||(p=ht()?.[re]);let ge=ut();if(ge===S)throw ge?new Error("Should not connect to self",ge):new Error("Node name not defined");return ml(ge,re),!0}a(hl,"setDatabase");function ml(re,ge){let ot=ht()?.[ge],Te=[];for(let G in ot){let m=ot[G];Te.push({table:G,schemaDefined:m.schemaDefined,attributes:m.attributes.map(R=>({name:R.name,type:R.type,isPrimaryKey:R.isPrimaryKey}))})}de.trace?.("Sending database info for node",re,"database name",ge),e.send((0,ct.encode)([GB,re,ge,Te]))}a(ml,"sendNodeDBName");function Fa(re){let ge=ht()?.[re],ot=[];for(let Te in ge){if(Ms&&!Ms.some(m=>m.replicateByDefault?!m.tables.includes(Te):m.tables.includes(Te)))continue;let G=ge[Te];ot.push({table:Te,schemaDefined:G.schemaDefined,attributes:G.attributes.map(m=>({name:m.name,type:m.type,isPrimaryKey:m.isPrimaryKey}))})}e.send((0,ct.encode)([jB,ot,re]))}a(Fa,"sendDBSchema");let Gr=1,pl=[];return{end(){Ha&&Ha.end(),Zn&&Zn.emit("close")},getRecord(re){let ge=Gr++;return new Promise((ot,Te)=>{let G=[VB,ge,re.table.tableId,re.id];pl[re.table.tableId]||(G.push(re.table.tableName),pl[re.table.tableId]=!0),e.send((0,ct.encode)(G)),T.set(ge,{tableId:re.table.tableId,key:re.id,resolve(m){let{table:R,entry:O}=re;ot(m),m&&R._recordRelocate(O,m)},reject:Te})})},sendOperation(re){let ge=Gr++;return re.requestId=ge,e.send((0,ct.encode)([YB,re])),new Promise((ot,Te)=>{T.set(ge,{resolve:ot,reject:Te})})}};function ka(re){Po(5),re<128?o[c++]=re:re<16384?(l.setUint16(c,re|32768),c+=2):re<1056964608?(l.setUint32(c,re|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,re),c+=5)}function Ga(re,ge=0,ot=re.length){let Te=ot-ge;Po(Te),re.copy(o,c,ge,ot),c+=Te}function Od(re){Po(8),l.setFloat64(c,re),c+=8}function Po(re){if(re+16>o.length-c){let ge=Buffer.allocUnsafeSlow(c+re-i+65536>>10<<11);o.copy(ge,0,i,c),c=c-i,i=0,o=ge,l=new DataView(o.buffer,0,o.length)}}}function MO(e,t){let r=e.database??"data";if(r!=="data"&&!Ve[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),ft({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var ct,XB,ZB,de,UO,eH,tH,vO,rH,kB,GB,qB,ou,$B,PO,VB,vm,YB,Bm,KB,WB,jB,Hm,Oc,$_,QB,Yte,zB,LO,JB,xm,nH=Ce(()=>{Le();Wi();EO();TO();as();Al();ct=require("msgpackr"),XB=require("ws"),ZB=require("worker_threads"),de=B(Wl());F_();UO=require("events"),eH=B(Ks()),tH=B(require("node:tls"));eu();vO=B(require("node:process")),rH=require("node:net");Ri();kB=129,GB=140,qB=141,ou=142,$B=130,PO=132,VB=133,vm=134,YB=136,Bm=137,KB=143,WB=144,jB=145,Hm=new Map,Oc=new Map,$_=!0,QB=300,Yte=2,zB=3e4;a(BO,"createWebSocket");JB=1e3,xm=class extends UO.EventEmitter{constructor(r,n,s){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=bi(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=JB;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;nodeName;async connect(){this.session||this.resetSession();let r=[];this.socket=await BO(this.url,{serverName:this.nodeName});let n;de.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${vO.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),de.info?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=JB,Sc({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=km(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&&(nu({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(km,"replicateOverWS");a(MO,"ensureTableIfChanged")});var ta={};tt(ta,{clearThisNodeName:()=>Xte,disableReplication:()=>jte,enabled_databases:()=>ra,forEachReplicatedDatabase:()=>zo,getThisNodeId:()=>Gm,getThisNodeName:()=>ut,getThisNodeUrl:()=>Jo,hostnameToUrl:()=>Vm,lastTimeInAuditStore:()=>v_,monitorNodeCAs:()=>_H,replicateOperation:()=>ere,replication_certificate_authorities:()=>na,sendOperationToNode:()=>W_,servers:()=>dH,setReplicator:()=>EH,start:()=>Wte,startOnMainThread:()=>RO,subscribeToNode:()=>ru,unsubscribeFromNode:()=>Lm,urlToNodeName:()=>bi});function Wte(e){if(e.port||(e.port=us.default.get(yc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=us.default.get(yc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!ut())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of x_(e))t.set(bi(n.url),n);Qte(e),e={subProtocol:"harperdb-replication-v1",mtls:!0,isOperationsServer:!0,...e};let r=nt.ws(async(n,s,i)=>{await i,n._socket.unref(),km(n,e,s?.user),n.on("error",o=>{o.code!=="ECONNREFUSED"&&Rr.error("Error in connection to "+this.url,o.message)})},e);e.runFirst=!0,nt.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&Rr.error(`Incoming client connection from ${n.ip} did not have valid certificate `,n._nodeRequest.socket.authorizationError);let i=wr().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));c?n.user=c:Rr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(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:Rr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(dH.push(n),n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(na);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.replicationContext=K_.createSecureContext(l)}catch(c){Rr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),_H(s)}}function _H(e){let t=0;Zl(r=>{if(r?.ca){if(na.add(r.ca),na.size!==t)t=na.size,e?.();else if(us.default.get(yc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1)for(let n of K_.rootCertificates)na.add(n)}})}function jte(e=!0){uH=e}function Qte(e){uH||(ht(),ra=e.databases,zo(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Oc;for(let[s,i]of Y_){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];EH(r,s,e),Hm.get(s)?.forEach(i=>i(s))}}))}function EH(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 fH extends yr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Oc,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(Rr.trace("Setting up replicator subscription to database",e,o&&Object.keys(o)),!o?.auditStore)return this.subscription=o=new In,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,d=new Set;do{let u;for(let E of c){let f=zte(E,fH.subscription,e);f?.isConnected&&!d.has(f)&&(!u||f.latency<u.latency)&&(u=f)}if(!u)throw l||new cH.ServerError("No connection to any other nodes are available",502);let _={requestId:Kte++,table:t,entry:i,id:i.key};d.add(u);try{return await u.getRecord(_)}catch(E){if(u.isConnected)throw E;Rr.warn("Error in load from node",$m,E),l||(l=E)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function hH(e,t,r){let n=Y_.get(e);n||Y_.set(e,n=new Map);let s=n.get(r);if(s)return s;if(t)return n.set(r,s=new xm(e,t,r)),s.connect(),s.once("finished",()=>n.delete(r)),s}function zte(e,t,r){let n=sH.get(e)?.get(r);if(n)return n;let s=wr().primaryStore.get(e);return s?.url&&(n=hH(s.url,t,r),sH.set(e,Y_.get(s.url))),n}async function W_(e,t,r){r||(r={}),r.serverName=e.name;let n=await BO(e.url,r),s=km(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{Rr.error("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function ru(e){try{lH.isMainThread&&Rr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Oc.get(e.database);if(!t){let n;t=new Promise(s=>{Rr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Oc.set(e.database,t)}let r=hH(e.nodes[0].url,t,e.database);e.nodes[0].name===void 0&&(r.tentativeNode=e.nodes[0]),r.subscribe(e.nodes.filter(n=>H_(n,e.database)),e.replicateByDefault)}catch(t){Rr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Lm({url:e,database:t}){let r=Y_.get(e);if(r){let n=r.get(t);n&&(n.unsubscribe(),r.delete(t))}}function Jte(){if(xO!==void 0)return xO;let e=us.default.get(yc.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||us.default.get(yc.CONFIG_PARAMS.TLS_CERTIFICATE);if(e)return xO=new oH.X509Certificate((0,aH.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function ut(){return $m||($m=us.default.get("replication_hostname")??bi(us.default.get("replication_url"))??Jte()??iH("operationsapi_network_secureport")??iH("operationsapi_network_port")??"127.0.0.1")}function Xte(){$m=void 0}function iH(e){let t=us.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function qm(e){let t=us.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Gm(e){return U_(e)?.[ut()]}function Jo(){let e=us.default.get("replication_url");return e||Vm(ut())}function Vm(e){let t=qm("replication_port");if(t)return`ws://${e}:${t}`;if(t=qm("replication_secureport"),t)return`wss://${e}:${t}`;if(t=qm("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=qm("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function bi(e){if(e)return new URL(e).hostname}function zo(e,t){for(let n of Object.getOwnPropertyNames(Ve))r(n);return V_(n=>{r(n)}),bc((n,s)=>{r(n.databaseName)});function r(n){let s=Ve[n];Rr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):Zte(n)&&t(s,n,!1)}a(r,"forDatabase")}function Zte(e){let t=Ve[e];for(let r in t)if(t[r].replicate)return!0}function v_(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function ere(e){let t={message:""};if(e.replicated){e.replicated=!1,Rr.trace?.("Replicating operation",e,"to nodes",nt.nodes.map(n=>n.name));let r=await Promise.allSettled(nt.nodes.map(n=>W_(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=nt.nodes[s]?.name,i})}return t}var us,Rr,oH,aH,yc,K_,cH,lH,uH,Kte,dH,na,ra,Y_,sH,xO,$m,as=Ce(()=>{Le();rs();Tl();nH();Vr();us=B(te()),Rr=B(V()),oH=require("crypto"),aH=require("fs");F_();eu();yc=B(M());EO();K_=B(require("node:tls")),cH=B(ce()),lH=require("worker_threads"),Kte=1,dH=[],na=us.default.get(yc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)===!0?new Set(K_.rootCertificates):new Set;a(Wte,"start");a(_H,"monitorNodeCAs");a(jte,"disableReplication");a(Qte,"assignReplicationSource");a(EH,"setReplicator");Y_=new Map;a(hH,"getConnection");sH=new Map;a(zte,"getConnectionByName");a(W_,"sendOperationToNode");a(ru,"subscribeToNode");a(Lm,"unsubscribeFromNode");a(Jte,"getCommonNameFromCert");a(ut,"getThisNodeName");a(Xte,"clearThisNodeName");Object.defineProperty(nt,"hostname",{get(){return ut()}});a(iH,"getHostFromListeningPort");a(qm,"getPortFromListeningPort");a(Gm,"getThisNodeId");nt.replication={getThisNodeId:Gm,exportIdMapping:U_};a(Jo,"getThisNodeUrl");a(Vm,"hostnameToUrl");a(bi,"urlToNodeName");a(zo,"forEachReplicatedDatabase");a(Zte,"hasExplicitlyReplicatedTable");a(v_,"lastTimeInAuditStore");a(ere,"replicateOperation")});var j_=b((NIe,gH)=>{"use strict";var cu=Ah(),lu=n0(),tre=V(),rre=require("uuid").v4,yIe=require("clone"),Km=Xi(),uu=M(),nre=require("util"),sa=Pn(),{handleHDBError:dn,hdb_errors:sre}=ce(),{HDB_ERROR_MSGS:Ym,HTTP_STATUS_CODES:_n}=sre,{SchemaEventMsg:Wm}=Fs(),mH=Ft(),{getDatabases:ire}=(Le(),ie(lt)),{transformReq:du}=ee(),{replicateOperation:pH}=(as(),ie(ta));gH.exports={createSchema:ore,createSchemaStructure:SH,createTable:are,createTableStructure:TH,createAttribute:_re,dropSchema:cre,dropTable:lre,dropAttribute:ure,getBackup:fre};async function ore(e){let t=await SH(e);return Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema)),t}a(ore,"createSchema");async function SH(e){let t=cu.schema_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);if(du(e),!await lu.checkSchemaExists(e.schema))throw dn(new Error,Ym.SCHEMA_EXISTS_ERR(e.schema),_n.BAD_REQUEST,uu.LOG_LEVELS.ERROR,Ym.SCHEMA_EXISTS_ERR(e.schema),!0);return await sa.createSchema(e),`database '${e.schema}' successfully created`}a(SH,"createSchemaStructure");async function are(e){return du(e),e.hash_attribute=e.primary_key??e.hash_attribute,await TH(e)}a(are,"createTable");async function TH(e){let t=cu.create_table_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);if(cu.validateTableResidence(e.residence),!await lu.checkSchemaTableExists(e.schema,e.table))throw dn(new Error,Ym.TABLE_EXISTS_ERR(e.schema,e.table),_n.BAD_REQUEST,uu.LOG_LEVELS.ERROR,Ym.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:rre(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await sa.createTable(n,e);else throw dn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",_n.BAD_REQUEST);else await sa.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(TH,"createTableStructure");async function cre(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=cu.schema_object(e),n=t??r;if(n)throw dn(n,n.message,_n.BAD_REQUEST,void 0,void 0,!0);du(e);let s=await lu.checkSchemaExists(e.schema);if(s)throw dn(new Error,s,_n.NOT_FOUND,uu.LOG_LEVELS.ERROR,s,!0);let i=await lu.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await sa.dropSchema(e),Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema)),await mH.purgeSchemaTableStreams(e.schema,o);let c=await pH(e);return c.message=`successfully deleted '${e.schema}'`,c}a(cre,"dropSchema");async function lre(e){let t=cu.table_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);du(e);let r=await lu.checkSchemaTableExists(e.schema,e.table);if(r)throw dn(new Error,r,_n.NOT_FOUND,uu.LOG_LEVELS.ERROR,r,!0);await sa.dropTable(e),await mH.purgeTableStream(e.schema,e.table);let n=await pH(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(lre,"dropTable");async function ure(e){let t=cu.attribute_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);du(e);let r=await lu.checkSchemaTableExists(e.schema,e.table);if(r)throw dn(new Error,r,_n.NOT_FOUND,uu.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw dn(new Error,"You cannot drop a hash attribute",_n.BAD_REQUEST,void 0,void 0,!0);if(uu.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw dn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,_n.BAD_REQUEST,void 0,void 0,!0);try{return await sa.dropAttribute(e),dre(e),Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw tre.error(`Got an error deleting attribute ${nre.inspect(e)}.`),n}}a(ure,"dropAttribute");function dre(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(dre,"dropAttributeFromGlobal");async function _re(e){du(e);let t=ire()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw dn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,_n.BAD_REQUEST,void 0,void 0,!0);return await sa.createAttribute(e),Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(_re,"createAttribute");function fre(e){return sa.getBackup(e)}a(fre,"getBackup")});var AH=b((wIe,RH)=>{"use strict";var{OPERATIONS_ENUM:Ere}=M(),FO=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Ere.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};RH.exports=FO});var kO=b((PIe,IH)=>{"use strict";var hre=Pn(),DIe=AH(),jm=ee(),Qm=M(),mre=te(),{handleHDBError:OH,hdb_errors:pre}=ce(),{HDB_ERROR_MSGS:bH,HTTP_STATUS_CODES:yH}=pre,Sre=Object.values(Qm.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),NH="To use this operation audit log must be enabled in harperdb-config.yaml";IH.exports=Tre;async function Tre(e){if(jm.isEmpty(e.schema))throw new Error(bH.SCHEMA_REQUIRED_ERR);if(jm.isEmpty(e.table))throw new Error(bH.TABLE_REQUIRED_ERR);if(!mre.get(Qm.CONFIG_PARAMS.LOGGING_AUDITLOG))throw OH(new Error,NH,yH.BAD_REQUEST,Qm.LOG_LEVELS.ERROR,NH,!0);let t=jm.checkSchemaTableExist(e.schema,e.table);if(t)throw OH(new Error,t,yH.NOT_FOUND,Qm.LOG_LEVELS.ERROR,t,!0);if(!jm.isEmpty(e.search_type)&&Sre.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await hre.readAuditLog(e)}a(Tre,"readAuditLog")});var CH=b((MIe,wH)=>{"use strict";var{OPERATIONS_ENUM:gre}=M(),GO=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=gre.GET_BACKUP,this.schema=t,this.table=r}};wH.exports=GO});var LH=b((HIe,PH)=>{"use strict";var Rre=Pn(),vIe=CH(),qO=ee(),Are=M(),BIe=te(),{handleHDBError:Ore,hdb_errors:bre}=ce(),{HDB_ERROR_MSGS:DH,HTTP_STATUS_CODES:yre}=bre;PH.exports=Nre;async function Nre(e){if(qO.isEmpty(e.schema))throw new Error(DH.SCHEMA_REQUIRED_ERR);if(qO.isEmpty(e.table))throw new Error(DH.TABLE_REQUIRED_ERR);let t=qO.checkSchemaTableExist(e.schema,e.table);if(t)throw Ore(new Error,t,yre.NOT_FOUND,Are.LOG_LEVELS.ERROR,t,!0);return await Rre.getBackup(read_audit_log_object)}a(Nre,"getBackup")});var xH=b((FIe,HH)=>{var ia=require("validate.js"),UH=dt(),_u=M(),{handleHDBError:Ire,hdb_errors:wre}=ce(),{HDB_ERROR_MSGS:zt,HTTP_STATUS_CODES:Cre}=wre,$O=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Dre={STRUCTURE_USER:"structure_user"},MH=Object.values(_u.ROLE_TYPES_ENUM),Pre="attribute_permissions",Lre="attribute_name",{PERMS_CRUD_ENUM:fu}=_u,Mre=[Pre,...Object.values(fu)],vH=[fu.READ,fu.INSERT,fu.UPDATE],Ure=[Lre,...vH];function vre(e){let t=$O();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,BH(e,t)}a(vre,"addRoleValidation");function Bre(e){let t=$O();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,BH(e,t)}a(Bre,"alterRoleValidation");function Hre(e){let t=$O();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,UH.validateObject(e,t)}a(Hre,"dropRoleValidation");var xre=["operation","role","id","permission","hdb_user","hdb_auth_header"];function BH(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)xre.includes(n[o])||s.push(n[o]);s.length>0&&sr(zt.INVALID_ROLE_JSON_KEYS(s),r);let i=UH.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{sr(o,r)}),e.permission){let o=Fre(e);o&&sr(o,r),MH.forEach(c=>{e.permission[c]&&!ia.isBoolean(e.permission[c])&&sr(zt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(MH.indexOf(o)<0){if(o===Dre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let d=0,u=l.length;d<u;d++){let _=l[d];global.hdb_schema[_]||sr(zt.SCHEMA_NOT_FOUND(_),r)}continue}sr(zt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){sr(zt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let d=c.tables[l];if(!l||!global.hdb_schema[o][l]){sr(zt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(d).forEach(u=>{Mre.includes(u)||sr(zt.INVALID_PERM_KEY(u),r,o,l)}),Object.values(fu).forEach(u=>{ia.isDefined(d[u])?ia.isBoolean(d[u])||sr(zt.TABLE_PERM_NOT_BOOLEAN(u),r,o,l):sr(zt.TABLE_PERM_MISSING(u),r,o,l)}),ia.isDefined(d.attribute_permissions)){if(!ia.isArray(d.attribute_permissions)){sr(zt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}}else{sr(zt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}if(d.attribute_permissions){let u=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),_={read:!1,insert:!1,update:!1};for(let E in d.attribute_permissions){let f=d.attribute_permissions[E];if(Object.keys(f).forEach(p=>{!Ure.includes(p)&&p!==fu.DELETE&&sr(zt.INVALID_ATTR_PERM_KEY(p),r,o,l)}),!ia.isDefined(f.attribute_name)){sr(zt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!u.includes(h)){sr(zt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}vH.forEach(p=>{ia.isDefined(f[p])?ia.isBoolean(f[p])||sr(zt.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,l):sr(zt.ATTR_PERM_MISSING(p,h),r,o,l)}),!_.read&&f.read===!0&&(_.read=!0),!_.insert&&f.insert===!0&&(_.insert=!0),!_.update&&f.update===!0&&(_.update=!0)}if(d.read===!1&&_.read===!0||d.insert===!1&&_.insert===!0||d.update===!1&&_.update===!0){let E=`${o}.${l}`;sr(zt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return kre(r)}a(BH,"customValidate");HH.exports={addRoleValidation:vre,alterRoleValidation:Bre,dropRoleValidation:Hre};function Fre(e){let{operation:t,permission:r}=e;if(t===_u.OPERATIONS_ENUM.ADD_ROLE||t===_u.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return zt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?_u.ROLE_TYPES_ENUM.SUPER_USER:_u.ROLE_TYPES_ENUM.CLUSTER_USER;return zt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Fre,"validateNoSUPerms");function kre(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:zt.ROLE_PERMS_ERROR,...e};return Ire(new Error,n,Cre.BAD_REQUEST)}else return null}a(kre,"generateRolePermResponse");function sr(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(sr,"addPermError")});var Jm=b((qIe,qH)=>{"use strict";var FH=Kr(),kH=Yr(),Gre=qo(),YO=xH(),KO=Xi(),GIe=require("uuid").v4,qre=require("util"),zm=M(),$re=ee(),WO=kH.searchByValue,Vre=kH.searchByHash,Yre=qre.promisify(Gre.delete),Kre=ks(),Wre=Hl(),{hdb_errors:jre,handleHDBError:Nc}=ce(),{HDB_ERROR_MSGS:GH,HTTP_STATUS_CODES:Q_}=jre,{UserEventMsg:jO}=Fs();qH.exports={addRole:Qre,alterRole:zre,dropRole:Jre,listRoles:Xre};function VO(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(VO,"scrubRoleDetails");async function Qre(e){let t=YO.addRoleValidation(e);if(t)throw t;e=VO(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 WO(r)||[])}catch(i){throw Nc(i)}if(n&&n.length>0)throw Nc(new Error,GH.ROLE_ALREADY_EXISTS(e.role),Q_.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await FH.insert(s),KO.signalUserChange(new jO(process.pid)),e=VO(e),e}a(Qre,"addRole");async function zre(e){let t=YO.alterRoleValidation(e);if(t)throw t;e=VO(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await FH.update(r)}catch(s){throw Nc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Nc(new Error,"Invalid role id",Q_.BAD_REQUEST,void 0,void 0,!0);return await KO.signalUserChange(new jO(process.pid)),e}a(zre,"alterRole");async function Jre(e){let t=YO.dropRoleValidation(e);if(t)throw Nc(new Error,t,Q_.BAD_REQUEST,void 0,void 0,!0);let r=new Wre(zm.SYSTEM_SCHEMA_NAME,zm.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Vre(r));if(n.length===0)throw Nc(new Error,GH.ROLE_NOT_FOUND,Q_.NOT_FOUND,void 0,void 0,!0);let s=new Kre(zm.SYSTEM_SCHEMA_NAME,zm.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await WO(s)),o=!1;if($re.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Nc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,Q_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Yre(c),KO.signalUserChange(new jO(process.pid)),`${n[0].role} successfully deleted`}a(Jre,"dropRole");async function Xre(){return WO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Xre,"listRoles")});var KH=b((VIe,YH)=>{"use strict";var Zre=te(),oa=require("joi"),ene=dt(),$H=require("moment"),tne=require("fs-extra"),QO=require("path"),rne=require("lodash"),z_=M(),{LOG_LEVELS:Ic}=M(),nne="YYYY-MM-DD hh:mm:ss",sne=QO.resolve(__dirname,"../logs");YH.exports=function(e){return ene.validateBySchema(e,ine)};var ine=oa.object({from:oa.custom(VH),until:oa.custom(VH),level:oa.valid(Ic.NOTIFY,Ic.FATAL,Ic.ERROR,Ic.WARN,Ic.INFO,Ic.DEBUG,Ic.TRACE),order:oa.valid("asc","desc"),limit:oa.number().min(1),start:oa.number().min(0),log_name:oa.custom(one)});function VH(e,t){if($H(e,$H.ISO_8601).format(nne)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(VH,"validateDatetime");function one(e,t){if(rne.invert(z_.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Zre.get(z_.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?z_.LOG_NAMES.HDB:e,i=s===z_.LOG_NAMES.INSTALL?QO.join(sne,z_.LOG_NAMES.INSTALL):QO.join(n,s);return tne.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(one,"validateReadLogPath")});var JO=b((KIe,jH)=>{"use strict";var Xm=M(),ane=V(),cne=te(),lne=KH(),zO=require("path"),WH=require("fs-extra"),{once:une}=require("events"),{handleHDBError:dne,hdb_errors:_ne}=ce(),{PACKAGE_ROOT:fne}=M(),Ene=zO.join(fne,"logs"),hne=1e3,mne=200;jH.exports=pne;async function pne(e){let t=lne(e);if(t)throw dne(t,t.message,_ne.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=cne.get(Xm.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Xm.LOG_NAMES.HDB:e.log_name,s=n===Xm.LOG_NAMES.INSTALL?zO.join(Ene,Xm.LOG_NAMES.INSTALL):zO.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,d=e.until!==void 0,u=d?new Date(e.until):void 0,_=e.limit===void 0?hne:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+_,p=0;E==="desc"&&!l&&!u&&(p=Math.max(WH.statSync(s).size-(h+5)*mne,0));let T=WH.createReadStream(s,{start:p});T.on("error",F=>{ane.error(F)});let g=0,S=[],C="",y;T.on("data",F=>{let Y=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;F=C+F;let $=0,Z;for(;(Z=Y.exec(F))&&!T.destroyed;){y&&(y.message=F.slice($,Z.index),x(y));let[Q,_e,K]=Z,se=K.split("] ["),le=se[0],we=se[1];se.splice(0,2),y={timestamp:_e,thread:le,level:we,tags:se,message:""},$=Z.index+Q.length}C=F.slice($)}),T.on("end",F=>{T.destroyed||y&&(y.message=C.trim(),x(y))}),T.resume();function x(F){let Y,$,Z;switch(!0){case(i&&c&&d):Y=new Date(F.timestamp),$=new Date(l),Z=new Date(u),F.level===o&&Y>=$&&Y<=Z&&g<f?g++:F.level===o&&Y>=$&&Y<=Z&&(aa(F,E,S),g++,g===h&&T.destroy());break;case(i&&c):Y=new Date(F.timestamp),$=new Date(l),F.level===o&&Y>=$&&g<f?g++:F.level===o&&Y>=$&&(aa(F,E,S),g++,g===h&&T.destroy());break;case(i&&d):Y=new Date(F.timestamp),Z=new Date(u),F.level===o&&Y<=Z&&g<f?g++:F.level===o&&Y<=Z&&(aa(F,E,S),g++,g===h&&T.destroy());break;case(c&&d):Y=new Date(F.timestamp),$=new Date(l),Z=new Date(u),Y>=$&&Y<=Z&&g<f?g++:Y>=$&&Y<=Z&&(aa(F,E,S),g++,g===h&&T.destroy());break;case i:F.level===o&&g<f?g++:F.level===o&&(aa(F,E,S),g++,g===h&&T.destroy());break;case c:Y=new Date(F.timestamp),$=new Date(l),Y>=$&&g<f?g++:Y>=$&&g>=f&&(aa(F,E,S),g++,g===h&&T.destroy());break;case d:Y=new Date(F.timestamp),Z=new Date(u),Y<=Z&&g<f?g++:Y<=Z&&g>=f&&(aa(F,E,S),g++,g===h&&T.destroy());break;default:g<f?g++:(aa(F,E,S),g++,g===h&&T.destroy())}}return a(x,"onLogMessage"),await une(T,"close"),S}a(pne,"readLog");function aa(e,t,r){t==="desc"?Sne(e,r):t==="asc"?Tne(e,r):r.push(e)}a(aa,"pushLineToResult");function Sne(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(Sne,"insertDescending");function Tne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(Tne,"insertAscending")});var Zm=b((XIe,XH)=>{"use strict";var XO=require("joi"),{string:Eu,boolean:QH,date:gne}=XO.types(),Rne=dt(),{validateSchemaExists:jIe,validateTableExists:QIe,validateSchemaName:zIe}=_i(),Ane=M(),One=_t(),zH=te();zH.initSync();var JIe=Eu.invalid(zH.get(Ane.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(One.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),JH={operation:Eu.valid("add_node","update_node","set_node_replication"),node_name:Eu.optional(),subscriptions:XO.array().items({table:Eu.optional(),schema:Eu.optional(),database:Eu.optional(),subscribe:QH.required(),publish:QH.required().custom(yne),start_time:gne.iso()})};function bne(e){return Rne.validateBySchema(e,XO.object(JH))}a(bne,"addUpdateNodeValidator");function yne(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(yne,"checkForFalsy");XH.exports={addUpdateNodeValidator:bne,validation_schema:JH}});var ex=b((ewe,ZH)=>{var Nne=dt(),Ine={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};ZH.exports=function(e){return Nne.validateObject(e,Ine)}});var J_=b((twe,tx)=>{"use strict";var wne=M().OPERATIONS_ENUM,ZO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=wne.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};tx.exports=ZO});var nx=b((nwe,rx)=>{"use strict";var Cne={OPERATION:"operation",REFRESH:"refresh"},eb=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},tb=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};rx.exports={JWTTokens:eb,TOKEN_TYPE_ENUM:Cne,JWTRSAKeys:tb}});var ef=b((iwe,ax)=>{"use strict";var Z_=require("jsonwebtoken"),rb=require("fs-extra"),nb=ee(),ds=M(),{handleHDBError:fn,hdb_errors:Dne}=ce(),{HTTP_STATUS_CODES:En,AUTHENTICATION_ERROR_MSGS:hn}=Dne,X_=V(),sx=Hh(),ob=vn(),Pne=Kr().update,Lne=J_(),Mne=Xi(),{UserEventMsg:Une}=Fs(),ca=te();ca.initSync();var sb=require("path"),{JWTTokens:vne,JWTRSAKeys:Bne,TOKEN_TYPE_ENUM:ep}=nx(),Hne=ca.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?ca.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",xne=ca.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?ca.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",tp="RS256",ib;ax.exports={createTokens:Fne,validateOperationToken:Gne,refreshOperationToken:kne,validateRefreshToken:ox};async function Fne(e){if(nb.isEmpty(e)||typeof e!="object")throw fn(new Error,hn.INVALID_AUTH_OBJECT,En.BAD_REQUEST,void 0,void 0,!0);if(nb.isEmpty(e.username))throw fn(new Error,hn.USERNAME_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);if(nb.isEmpty(e.password))throw fn(new Error,hn.PASSWORD_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await ob.findAndValidateUser(e.username,e.password),!t)throw fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw X_.error(E),fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}let r=await rp(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await ix(i,r.private_key,r.passphrase),c=await Z_.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:xne,algorithm:tp,subject:ep.REFRESH}),l=sx.hash(c),d=new Lne(ds.SYSTEM_SCHEMA_NAME,ds.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),u,_;try{u=await Pne(d)}catch(E){X_.error(E),_=E}if(_!==void 0||u.skipped_hashes.length>0)throw fn(new Error,hn.REFRESH_TOKEN_SAVE_FAILED,En.INTERNAL_SERVER_ERROR);return Mne.signalUserChange(new Une(process.pid)),new vne(o,c)}a(Fne,"createTokens");async function ix(e,t,r){return await Z_.sign(e,{key:t,passphrase:r},{expiresIn:Hne,algorithm:tp,subject:ep.OPERATION})}a(ix,"signOperationToken");async function rp(){if(ib===void 0)try{let e=sb.join(ca.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PASSPHRASE_NAME),t=sb.join(ca.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=sb.join(ca.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await rb.readFile(e)).toString(),s=(await rb.readFile(t)).toString(),i=(await rb.readFile(r)).toString();ib=new Bne(i,s,n)}catch(e){throw X_.error(e),fn(new Error,hn.NO_ENCRYPTION_KEYS,En.INTERNAL_SERVER_ERROR)}return ib}a(rp,"getJWTRSAKeys");async function kne(e){if(!e)throw fn(new Error,hn.INVALID_BODY,En.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw fn(new Error,hn.REFRESH_TOKEN_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);await ox(e.refresh_token);let t=await rp(),r=await Z_.decode(e.refresh_token);return{operation_token:await ix({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(kne,"refreshOperationToken");async function Gne(e){try{let t=await rp(),r=await Z_.verify(e,t.public_key,{algorithms:tp,subject:ep.OPERATION});return await ob.findAndValidateUser(r.username,void 0,!1)}catch(t){throw X_.warn(t),t.name&&t.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}}a(Gne,"validateOperationToken");async function ox(e){let t;try{let r=await rp(),n=await Z_.verify(e,r.public_key,{algorithms:tp,subject:ep.REFRESH});t=await ob.findAndValidateUser(n.username,void 0,!1)}catch(r){throw X_.warn(r),r.name&&r.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}if(!sx.validate(t.refresh_token,e))throw fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED);return t}a(ox,"validateRefreshToken")});var ab=b((cwe,ux)=>{"use strict";var qne=ex(),hu=require("passport"),$ne=require("passport-local").Strategy,Vne=require("passport-http").BasicStrategy,Yne=require("util"),Kne=vn(),lx=Yne.callbackify(Kne.findAndValidateUser),awe=Nn(),Wne=M(),cx=ef();hu.use(new $ne(function(e,t,r){lx(e,t,r)}));hu.use(new Vne(function(e,t,r){lx(e,t,r)}));hu.serializeUser(function(e,t){t(null,e)});hu.deserializeUser(function(e,t){t(null,e)});function jne(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":hu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Wne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?cx.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):cx.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:hu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(jne,"authorize");function Qne(e,t){let r=qne(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(Qne,"checkPermissions");ux.exports={authorize:jne,checkPermissions:Qne}});var la=b((uwe,dx)=>{"use strict";var cb=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},lb=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};dx.exports={Node:cb,NodeSubscription:lb}});var fx=b((_we,_x)=>{"use strict";var zne=M().OPERATIONS_ENUM,ub=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=zne.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};_x.exports=ub});var tf=b((Ewe,Ex)=>{"use strict";var db=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},_b=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)}};Ex.exports={RemotePayloadObject:db,RemotePayloadSubscription:_b}});var mx=b((mwe,hx)=>{"use strict";var fb=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}};hx.exports=fb});var Sx=b((Awe,px)=>{"use strict";var Jne=mx(),Swe=Bt(),Twe=Et(),Xne=V(),{getSchemaPath:gwe,getTransactionAuditStorePath:Rwe}=Tt(),{getDatabases:Zne}=(Le(),ie(lt));px.exports=ese;async function ese(e){let t=new Jne;try{let r=Zne()[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){Xne.warn(`unable to stat table dbi due to ${r}`)}return t}a(ese,"lmdbGetTableSize")});var gx=b((bwe,Tx)=>{"use strict";var Eb=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}};Tx.exports=Eb});var pu=b((Dwe,bx)=>{"use strict";var tse=require("fs-extra"),rse=require("path"),Xr=require("systeminformation"),ua=V(),Rx=Ft(),Nwe=_t(),mu=M(),nse=Sx(),sse=Ei(),{getThreadInfo:Ax}=st(),rf=te();rf.initSync();var ise=gx(),{openEnvironment:Iwe}=Et(),{getSchemaPath:wwe}=Tt(),{database:Cwe,databases:hb}=(Le(),ie(lt)),np;bx.exports={getHDBProcessInfo:Tb,getNetworkInfo:Rb,getDiskInfo:gb,getMemoryInfo:Sb,getCPUInfo:pb,getTimeInfo:mb,getSystemInformation:Ab,systemInformation:ose,getTableSize:Ob,getMetrics:bb};function mb(){return Xr.time()}a(mb,"getTimeInfo");async function pb(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:d,...u}=await Xr.cpu();u.cpu_speed=await Xr.cpuCurrentSpeed();let{raw_currentload:_,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:p,raw_currentload_user:T,cpus:g,...S}=await Xr.currentLoad();return S.cpus=[],g.forEach(C=>{let{raw_load:y,raw_load_idle:x,raw_load_irq:F,raw_load_nice:Y,raw_load_system:$,raw_load_user:Z,...Q}=C;S.cpus.push(Q)}),u.current_load=S,u}catch(e){return ua.error(`error in getCPUInfo: ${e}`),{}}}a(pb,"getCPUInfo");async function Sb(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Xr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return ua.error(`error in getMemoryInfo: ${e}`),{}}}a(Sb,"getMemoryInfo");async function Tb(){let e={core:[],clustering:[]};try{let t=await Xr.processes(),r;try{r=Number.parseInt(await tse.readFile(rse.join(rf.get(mu.CONFIG_PARAMS.ROOTPATH),mu.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===mu.NODE_ERROR_CODES.ENOENT)ua.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 ua.error(`error in getHDBProcessInfo: ${t}`),e}}a(Tb,"getHDBProcessInfo");async function gb(){let e={};try{if(!rf.get(mu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Xr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...d}=await Xr.fsStats();return e.read_write=d,e.size=await Xr.fsSize(),e}catch(t){return ua.error(`error in getDiskInfo: ${t}`),e}}a(gb,"getDiskInfo");async function Rb(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return rf.get(mu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Xr.networkInterfaceDefault(),e.latency=await Xr.inetChecksite("google.com"),(await Xr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:d,ieee8021xState:u,carrier_changes:_,...E}=n;e.interfaces.push(E)}),(await Xr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return ua.error(`error in getNetworkInfo: ${t}`),e}}a(Rb,"getNetworkInfo");async function Ab(){if(np!==void 0)return np;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Xr.osInfo();e=c;let l=await Xr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,np=e,np}catch(t){return ua.error(`error in getSystemInformation: ${t}`),e}}a(Ab,"getSystemInformation");async function Ob(){let e=[],t=await sse.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await nse(n));return e}a(Ob,"getTableSize");async function bb(){let e={};for(let t in hb){let r=e[t]={},n=r.tables={};for(let s in hb[t])try{let i=hb[t][s];r.readers||(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[d,u,_]=l.trim().split(" ");return{pid:d,thread:u,txnid:_}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){ua.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(bb,"getMetrics");async function Ox(){if(rf.get(mu.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await Rx.getNATSReferences(),t=await Rx.listStreams(),r=[];for(let n of t){let s=[],i=await e.consumers.list(n.config.name);for await(let c of i)s.push({name:c.name,created:c.created,num_ack_pending:c.num_ack_pending,num_redelivered:c.num_redelivered,num_waiting:c.num_waiting,num_pending:c.num_pending});let o={stream_name:n.config.name,database:n.config.subjects[0].split(".")[1],table:n.config.subjects[0].split(".")[2],state:n.state,consumers:s};r.push(o)}return r}}a(Ox,"getNatsStreamInfo");async function ose(e){let t=new ise;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await Ab(),t.time=mb(),t.cpu=await pb(),t.memory=await Sb(),t.disk=await gb(),t.network=await Rb(),t.harperdb_processes=await Tb(),t.table_size=await Ob(),t.metrics=await bb(),t.threads=await Ax(),t.replication=await Ox(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await Ab();break;case"time":t.time=mb();break;case"cpu":t.cpu=await pb();break;case"memory":t.memory=await Sb();break;case"disk":t.disk=await gb();break;case"network":t.network=await Rb();break;case"harperdb_processes":t.harperdb_processes=await Tb();break;case"table_size":t.table_size=await Ob();break;case"database_metrics":case"metrics":t.metrics=await bb();break;case"threads":t.threads=await Ax();break;case"replication":t.replication=await Ox();break;default:break}return t}a(ose,"systemInformation")});var wc=b((Lwe,yx)=>{"use strict";yx.exports={version:ase,printVersion:cse};var sp=$l();function ase(){if(sp)return sp.version}a(ase,"version");function cse(){sp&&console.log(`HarperDB Version ${sp.version}`)}a(cse,"printVersion")});var _s=b((Bwe,Cx)=>{"use strict";var lse=Kr(),yb=ee(),use=require("util"),Cc=M(),Nx=te();Nx.initSync();var dse=ab(),Ix=Yr(),{Node:Uwe,NodeSubscription:vwe}=la(),_se=Hl(),fse=fx(),{RemotePayloadObject:Ese,RemotePayloadSubscription:hse}=tf(),{handleHDBError:mse,hdb_errors:pse}=ce(),{HTTP_STATUS_CODES:Sse,HDB_ERROR_MSGS:Tse}=pse,gse=ks(),Rse=pu(),Ase=wc(),{getDatabases:Ose}=(Le(),ie(lt)),bse=use.promisify(dse.authorize),yse=Ix.searchByHash,Nse=Ix.searchByValue;Cx.exports={authHeaderToUser:Ise,isEmpty:wse,getNodeRecord:Cse,upsertNodeRecord:Dse,buildNodePayloads:Pse,checkClusteringEnabled:Lse,getAllNodeRecords:Mse,getSystemInfo:Use,reverseSubscription:wx};async function Ise(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await bse(t,null),e}a(Ise,"authHeaderToUser");function wse(e){return e==null}a(wse,"isEmpty");async function Cse(e){let t=new _se(Cc.SYSTEM_SCHEMA_NAME,Cc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return yse(t)}a(Cse,"getNodeRecord");async function Dse(e){let t=new fse(Cc.SYSTEM_SCHEMA_NAME,Cc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return lse.upsert(t)}a(Dse,"upsertNodeRecord");function wx(e){if(yb.isEmpty(e.subscribe)||yb.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(wx,"reverseSubscription");function Pse(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:d}=c,u=yb.getTableHashAttribute(l,d),{subscribe:_,publish:E}=wx(c),f=Ose()[l]?.[d],h=new hse(l,d,u,E,_,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new Ese(r,t,s,n)}a(Pse,"buildNodePayloads");function Lse(){if(!Nx.get(Cc.CONFIG_PARAMS.CLUSTERING_ENABLED))throw mse(new Error,Tse.CLUSTERING_NOT_ENABLED,Sse.BAD_REQUEST,void 0,void 0,!0)}a(Lse,"checkClusteringEnabled");async function Mse(){let e=new gse(Cc.SYSTEM_SCHEMA_NAME,Cc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Nse(e))}a(Mse,"getAllNodeRecords");async function Use(){let e=await Rse.getSystemInformation();return{hdb_version:Ase.version(),node_version:e.node_version,platform:e.platform}}a(Use,"getSystemInfo")});var Nb=b((xwe,Hx)=>{"use strict";var ip=Ft(),Dx=ee(),Px=_t(),Lx=M(),op=V(),Mx=j_(),vse=Fl(),{RemotePayloadObject:Bse}=tf(),{handleHDBError:Ux,hdb_errors:Hse}=ce(),{HTTP_STATUS_CODES:vx}=Hse,{NodeSubscription:Bx}=la();Hx.exports=xse;async function xse(e,t){let r;try{r=await ip.request(`${t}.${Px.REQUEST_SUFFIX}`,new Bse(Lx.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),op.trace("Response from remote describe all request:",r)}catch(o){op.error(`addNode received error from describe all request to remote node: ${o}`);let c=ip.requestErrorHandler(o,"add_node",t);throw Ux(new Error,c,vx.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===Px.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw Ux(new Error,o,vx.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===Lx.SYSTEM_SCHEMA_NAME){await ip.createLocalTableStream(l,c);let h=new Bx(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let d=Dx.doesSchemaExist(l),u=n[l]!==void 0,_=c?Dx.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!d&&!u||!_&&!E){s.push(o);continue}if(!d&&u&&(op.trace(`addNode creating schema: ${l}`),await Mx.createSchema({operation:"create_schema",schema:l})),!_&&E){op.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new vse(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await Mx.createTable(h)}await ip.createLocalTableStream(l,c);let f=new Bx(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(xse,"reviewSubscriptions")});var Dc={};tt(Dc,{addNodeBack:()=>$se,removeNodeBack:()=>Vse,setNode:()=>qse});async function qse(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=bi(t)):t=Vm(r);let n=(0,Fx.validateBySchema)(e,Gse);if(n)throw(0,Ni.handleHDBError)(n,n.message,kse.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Ni.ClientError("url or hostname is required for remove_node operation");let _=r,E=wr(),f=await E.get(_);if(!f)throw new Ni.ClientError(_+" does not exist");try{await W_({url:f.url},{operation:nf.OPERATIONS_ENUM.REMOVE_NODE_BACK,name:f?.subscriptions?.length>0?ut():_},void 0)}catch(h){Es.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,h)}return await E.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Ni.ClientError("url required for this operation");let s=Jo();if(s==null)throw new Ni.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){if(e.operation==="add_node"&&!e.authorization)throw new Ni.ClientError("authorization parameter is required");i=await(0,hs.getReplicationCert)();let _=await(0,hs.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,hs.createCsr)(),Es.info("Sending CSR to target node:",t)):(c=_?.certificate,Es.info("Sending CA named",_?.name,"to target node",t))}let l={operation:nf.OPERATIONS_ENUM.ADD_NODE_BACK,hostname:(0,kx.get)(nf.CONFIG_PARAMS.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c};if(e.subscriptions&&(l.subscriptions=e.subscriptions.map(xx)),e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=xx(e);l.subscribe=_.subscribe,l.publish=_.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let d;try{d=await W_({url:t},l,e)}catch(_){throw _.message=`Error returned from ${t}: `+_.message,_}if(o&&(!d?.certificate||!d?.certificate?.includes?.("BEGIN CERTIFICATE")))throw new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(d)}`);o&&(Es.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,hs.setCertTable)({name:Fse.certificateFromPem(d.signingCA).issuer.getField("CN").value,certificate:d.signingCA,is_authority:!0}),d.certificate&&await(0,hs.setCertTable)({name:ut(),uses:["https","operations","wss"],certificate:d.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=d.signingCA);let u={url:t,ca:d.usingCA};if(e.hostname&&(u.name=e.hostname),e.subscriptions?u.subscriptions=e.subscriptions:u.replicates=!0,e.start_time&&(u.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),u.replicates){let _={url:s,ca:c,replicates:!0};e.start_time&&(_.start_time=e.start_time),await no(ut(),_)}return await no(d.nodeName,u),e.operation==="update_node"?`Successfully updated '${t}'`:`Successfully added '${t}' to cluster`}async function $se(e){Es.trace("addNodeBack received request:",e);let t=await(0,hs.signCertificate)(e),r;e.csr?(r=t.signingCA,Es.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,Es.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:n.replicates=!0,e.start_time&&(n.start_time=e.start_time);let s=await(0,hs.getReplicationCertAuth)();if(n.replicates){let i={url:Jo(),ca:s?.certificate,replicates:!0};e.start_time&&(i.start_time=e.start_time),await no(ut(),i)}return await no(e.hostname,n),t.nodeName=ut(),t.usingCA=s?.certificate,Es.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Vse(e){Es.trace("removeNodeBack received request:",e),await wr().delete(e.name)}function xx(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var hs,Fx,Su,kx,nf,Es,Ni,Fse,kse,Gse,Pc=Ce(()=>{hs=B(Ks()),Fx=B(dt()),Su=B(require("joi")),kx=B(te()),nf=B(M());F_();eu();as();Es=B(V()),Ni=B(ce()),{pki:Fse}=require("node-forge"),{HTTP_STATUS_CODES:kse}=Ni.hdb_errors,Gse=Su.default.object({hostname:Su.default.string(),verify_tls:Su.default.boolean(),replicates:Su.default.boolean(),subscriptions:Su.default.array()});a(qse,"setNode");a($se,"addNodeBack");a(Vse,"removeNodeBack");a(xx,"reverseSubscription")});var dp=b((Kwe,qx)=>{"use strict";var{handleHDBError:ap,hdb_errors:Yse}=ce(),{HTTP_STATUS_CODES:cp}=Yse,{addUpdateNodeValidator:Kse}=Zm(),lp=V(),up=M(),Gx=_t(),Wse=ee(),sf=Ft(),of=_s(),Ib=te(),jse=Nb(),{Node:Qse,NodeSubscription:zse}=la(),{broadcast:Jse}=st(),{setNode:Xse}=(Pc(),ie(Dc)),Vwe=te(),Ywe=M(),Zse="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",eie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",tie=Ib.get(up.CONFIG_PARAMS.CLUSTERING_NODENAME);qx.exports=rie;async function rie(e,t=!1){if(lp.trace("addNode called with:",e),Ib.get(up.CONFIG_PARAMS.REPLICATION_URL)||Ib.get(up.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Xse(e);of.checkClusteringEnabled();let r=Kse(e);if(r)throw ap(r,r.message,cp.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let _=await of.getNodeRecord(n);if(!Wse.isEmptyOrZeroLength(_))throw ap(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,cp.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await jse(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Zse,o;let c=of.buildNodePayloads(s,tie,up.OPERATIONS_ENUM.ADD_NODE,await of.getSystemInfo()),l=[];for(let _=0,E=s.length;_<E;_++){let f=s[_];s[_].start_time===void 0&&delete s[_].start_time,l.push(new zse(f.schema,f.table,f.publish,f.subscribe))}lp.trace("addNode sending remote payload:",c);let d;try{d=await sf.request(`${n}.${Gx.REQUEST_SUFFIX}`,c)}catch(_){lp.error(`addNode received error from request: ${_}`);for(let f=0,h=s.length;f<h;f++){let p=s[f];p.publish=!1,p.subscribe=!1,await sf.updateRemoteConsumer(p,n)}let E=sf.requestErrorHandler(_,"add_node",n);throw ap(new Error,E,cp.INTERNAL_SERVER_ERROR,"error",E)}if(d.status===Gx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let _=`Error returned from remote node ${n}: ${d.message}`;throw ap(new Error,_,cp.INTERNAL_SERVER_ERROR,"error",_)}lp.trace(d);for(let _=0,E=s.length;_<E;_++){let f=s[_];await sf.updateRemoteConsumer(f,n),f.subscribe===!0&&await sf.updateConsumerIterator(f.schema,f.table,n,"start")}let u=new Qse(n,l,d.system_info);return await of.upsertNodeRecord(u),Jse({type:"nats_update"}),i.length>0?o.message=eie:o.message=`Successfully added '${n}' to manifest`,o}a(rie,"addNode")});var Pb=b((Qwe,Vx)=>{"use strict";var{handleHDBError:wb,hdb_errors:nie}=ce(),{HTTP_STATUS_CODES:Cb}=nie,{addUpdateNodeValidator:sie}=Zm(),af=V(),_p=M(),$x=_t(),jwe=ee(),cf=Ft(),lf=_s(),Db=te(),{cloneDeep:iie}=require("lodash"),oie=Nb(),{Node:aie,NodeSubscription:cie}=la(),{broadcast:lie}=st(),{setNode:uie}=(Pc(),ie(Dc)),die="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",_ie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",fie=Db.get(_p.CONFIG_PARAMS.CLUSTERING_NODENAME);Vx.exports=Eie;async function Eie(e){if(af.trace("updateNode called with:",e),Db.get(_p.CONFIG_PARAMS.REPLICATION_URL)??Db.get(_p.CONFIG_PARAMS.REPLICATION_HOSTNAME))return uie(e);lf.checkClusteringEnabled();let t=sie(e);if(t)throw wb(t,t.message,Cb.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await lf.getNodeRecord(r);s.length>0&&(n=iie(s));let{added:i,skipped:o}=await oie(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=die,c;let l=lf.buildNodePayloads(i,fie,_p.OPERATIONS_ENUM.UPDATE_NODE,await lf.getSystemInfo());for(let u=0,_=i.length;u<_;u++){let E=i[u];af.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[u].start_time===void 0&&delete i[u].start_time}af.trace("updateNode sending remote payload:",l);let d;try{d=await cf.request(`${r}.${$x.REQUEST_SUFFIX}`,l)}catch(u){af.error(`updateNode received error from request: ${u}`);let _=cf.requestErrorHandler(u,"update_node",r);throw wb(new Error,_,Cb.INTERNAL_SERVER_ERROR,"error",_)}if(d.status===$x.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${d.message}`;throw wb(new Error,u,Cb.INTERNAL_SERVER_ERROR,"error",u)}af.trace(d);for(let u=0,_=i.length;u<_;u++){let E=i[u];await cf.updateRemoteConsumer(E,r),E.subscribe===!0?await cf.updateConsumerIterator(E.schema,E.table,r,"start"):await cf.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new aie(r,[],d.system_info)]),await hie(n[0],i,d.system_info),o.length>0?c.message=_ie:c.message=`Successfully updated '${r}'`,c}a(Eie,"updateNode");async function hie(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,d=e.subscriptions.length;l<d;l++){let u=n.subscriptions[l];if(u.schema===o.schema&&u.table===o.table){u.publish=o.publish,u.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new cie(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await lf.upsertNodeRecord(n),lie({type:"nats_update"})}a(hie,"updateNodeTable")});var Qx=b((Jwe,jx)=>{"use strict";var Wx=require("joi"),{string:Yx}=Wx.types(),mie=dt(),Kx=M(),pie=te(),Sie=_t();jx.exports=Tie;function Tie(e){let t=Yx.invalid(pie.get(Kx.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Sie.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=Wx.object({operation:Yx.valid(Kx.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return mie.validateBySchema(e,r)}a(Tie,"removeNodeValidator")});var fp=b((Zwe,eF)=>{"use strict";var{handleHDBError:zx,hdb_errors:gie}=ce(),{HTTP_STATUS_CODES:Jx}=gie,Rie=Qx(),uf=V(),Xx=_s(),Aie=ee(),Tu=M(),Zx=_t(),Lb=Ft(),Mb=te(),{RemotePayloadObject:Oie}=tf(),{NodeSubscription:bie}=la(),yie=xl(),Nie=qo(),{broadcast:Iie}=st(),{setNode:wie}=(Pc(),ie(Dc)),Cie=Mb.get(Tu.CONFIG_PARAMS.CLUSTERING_NODENAME);eF.exports=Die;async function Die(e){if(uf.trace("removeNode called with:",e),Mb.get(Tu.CONFIG_PARAMS.REPLICATION_URL)??Mb.get(Tu.CONFIG_PARAMS.REPLICATION_HOSTNAME))return wie(e);Xx.checkClusteringEnabled();let t=Rie(e);if(t)throw zx(t,t.message,Jx.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await Xx.getNodeRecord(r);if(Aie.isEmptyOrZeroLength(n))throw zx(new Error,`Node '${r}' was not found.`,Jx.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Oie(Tu.OPERATIONS_ENUM.REMOVE_NODE,Cie,[]),i,o=!1;for(let l=0,d=n.subscriptions.length;l<d;l++){let u=n.subscriptions[l];u.subscribe===!0&&await Lb.updateConsumerIterator(u.schema,u.table,r,"stop");try{await Lb.updateRemoteConsumer(new bie(u.schema,u.table,!1,!1),r)}catch(_){uf.error(_)}}try{i=await Lb.request(`${r}.${Zx.REQUEST_SUFFIX}`,s),uf.trace("Remove node reply from remote node:",r,i)}catch(l){uf.error("removeNode received error from request:",l),o=!0}let c=new yie(Tu.SYSTEM_SCHEMA_NAME,Tu.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Nie.deleteRecord(c),Iie({type:"nats_update"}),i?.status===Zx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(uf.error("Error returned from remote node:",r,i?.message),`Successfully removed '${r}' from local manifest, however there was an error reaching remote node. Check the logs for more details.`):`Successfully removed '${r}' from manifest`}a(Die,"removeNode")});var nF=b((tCe,rF)=>{"use strict";var tF=require("joi"),{string:Pie,array:Lie}=tF.types(),Mie=dt(),Uie=Zm();rF.exports=vie;function vie(e){let t=tF.object({operation:Pie.valid("configure_cluster").required(),connections:Lie.items(Uie.validation_schema).required()});return Mie.validateBySchema(e,t)}a(vie,"configureClusterValidator")});var Ub=b((nCe,cF)=>{"use strict";var sF=M(),Ep=V(),Bie=ee(),Hie=te(),xie=fp(),Fie=dp(),kie=_s(),Gie=nF(),{handleHDBError:iF,hdb_errors:qie}=ce(),{HTTP_STATUS_CODES:oF}=qie,$ie="Configure cluster complete.",Vie="Failed to configure the cluster. Check the logs for more details.",Yie="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";cF.exports=Kie;async function Kie(e){Ep.trace("configure cluster called with:",e);let t=Gie(e);if(t)throw iF(t,t.message,oF.BAD_REQUEST,void 0,void 0,!0);let r=await kie.getAllNodeRecords(),n=[];if(Hie.get(sF.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let u=0,_=r.length;u<_;u++){let E=await aF(xie,{operation:sF.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[u].name},r[u].name);n.push(E)}Ep.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let u=0;u<i;u++){let _=e.connections[u],E=await aF(Fie,_,_.node_name);s.push(E)}Ep.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,d=n.concat(s);for(let u=0,_=d.length;u<_;u++){let E=d[u];E.status==="rejected"&&(Ep.error(E.node_name,E?.error?.message,E?.error?.stack),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,response:E?.result})}if(Bie.isEmptyOrZeroLength(o))return{message:$ie,connections:c};if(l)return{message:Yie,failed_nodes:o,connections:c};throw iF(new Error,Vie,oF.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Kie,"configureCluster");async function aF(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(aF,"functionWrapper")});var _F=b((iCe,dF)=>{"use strict";var df=require("joi"),Wie=dt(),{validateSchemaExists:lF,validateTableExists:jie,validateSchemaName:uF}=_i(),Qie=df.object({operation:df.string().valid("purge_stream"),schema:df.string().custom(lF).custom(uF).optional(),database:df.string().custom(lF).custom(uF).optional(),table:df.string().custom(jie).required()});function zie(e){return Wie.validateBySchema(e,Qie)}a(zie,"purgeStreamValidator");dF.exports=zie});var vb=b((aCe,fF)=>{"use strict";var{handleHDBError:Jie,hdb_errors:Xie}=ce(),{HTTP_STATUS_CODES:Zie}=Xie,eoe=_F(),toe=Ft(),roe=_s();fF.exports=noe;async function noe(e){e.schema=e.schema??e.database;let t=eoe(e);if(t)throw Jie(t,t.message,Zie.BAD_REQUEST,void 0,void 0,!0);roe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await toe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(noe,"purgeStream")});var xb=b((lCe,gF)=>{"use strict";var Hb=_s(),soe=Ft(),hp=te(),gu=M(),Lc=_t(),ioe=ee(),Bb=V(),{RemotePayloadObject:ooe}=tf(),{ErrorCode:EF}=require("nats"),{parentPort:hF}=require("worker_threads"),{onMessageByType:aoe}=st(),{getThisNodeName:coe}=(as(),ie(ta)),{requestClusterStatus:loe}=(F_(),ie(EB)),mF=hp.get(gu.CONFIG_PARAMS.CLUSTERING_ENABLED),pF=hp.get(gu.CONFIG_PARAMS.CLUSTERING_NODENAME);gF.exports={clusterStatus:uoe,buildNodeStatus:TF};var SF;aoe("cluster-status",async e=>{SF(e)});async function uoe(){if(hp.get(gu.CONFIG_PARAMS.REPLICATION_URL)||hp.get(gu.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;return hF?(hF.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{SF=s})):n=loe(),n.node_name=coe(),n.is_enabled=!0,n}let e={node_name:pF,is_enabled:mF,connections:[]};if(!mF)return e;let t=await Hb.getAllNodeRecords();if(ioe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(TF(t[n],e.connections));return await Promise.allSettled(r),e}a(uoe,"clusterStatus");async function TF(e,t){let r=e.name,n=new ooe(gu.OPERATIONS_ENUM.CLUSTER_STATUS,pF,void 0,await Hb.getSystemInfo()),s,i,o=Lc.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await soe.request(Lc.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Lc.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Lc.CLUSTER_STATUS_STATUSES.CLOSED,Bb.error(`Error getting node status from ${r} `,s))}catch(l){Bb.warn(`Error getting node status from ${r}`,l),l.code===EF.NoResponders?o=Lc.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===EF.Timeout?o=Lc.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Lc.CLUSTER_STATUS_STATUSES.CLOSED}let c=new doe(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!==gu.PRE_4_0_0_VERSION&&await Hb.upsertNodeRecord(l)}catch(l){Bb.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(TF,"buildNodeStatus");function doe(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(doe,"NodeStatusObject")});var kb=b((dCe,RF)=>{"use strict";var{handleHDBError:_oe,hdb_errors:foe}=ce(),{HTTP_STATUS_CODES:Eoe}=foe,hoe=Ft(),moe=_s(),Fb=ee(),mp=require("joi"),poe=dt(),Soe=2e3,Toe=mp.object({timeout:mp.number().min(1),connected_nodes:mp.boolean(),routes:mp.boolean()});RF.exports=goe;async function goe(e){moe.checkClusteringEnabled();let t=poe.validateBySchema(e,Toe);if(t)throw _oe(t,t.message,Eoe.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||Fb.autoCastBoolean(n),o=s===void 0||Fb.autoCastBoolean(s),c={nodes:[]},l=await hoe.getServerList(r??Soe),d={};if(i)for(let u=0,_=l.length;u<_;u++){let E=l[u].statsz;E&&(d[l[u].server.name]=E.routes)}for(let u=0,_=l.length;u<_;u++){if(l[u].statsz)continue;let E=l[u].server,f=l[u].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[u].response_time};i&&(h.connected_nodes=[],d[E.name]&&d[E.name].forEach(p=>{h.connected_nodes.includes(p.name.slice(0,-4))||h.connected_nodes.push(p.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(p=>({host:p.split(":")[0],port:Fb.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(goe,"clusterNetwork")});var yF=b((fCe,bF)=>{"use strict";var Gb=require("joi"),AF=dt(),{route_constraints:OF}=DR();bF.exports={setRoutesValidator:Roe,deleteRoutesValidator:Aoe};function Roe(e){let t=Gb.object({server:Gb.valid("hub","leaf"),routes:OF.required()});return AF.validateBySchema(e,t)}a(Roe,"setRoutesValidator");function Aoe(e){let t=Gb.object({routes:OF.required()});return AF.validateBySchema(e,t)}a(Aoe,"deleteRoutesValidator")});var pp=b((hCe,LF)=>{"use strict";var io=It(),qb=ee(),ms=M(),Ru=te(),NF=yF(),{handleHDBError:IF,hdb_errors:Ooe}=ce(),{HTTP_STATUS_CODES:wF}=Ooe,CF="cluster routes successfully set",DF="cluster routes successfully deleted";LF.exports={setRoutes:yoe,getRoutes:Noe,deleteRoutes:Ioe};function boe(e){let t=io.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=qb.autoCast(l.port);let d=r.some(_=>_.host===l.host&&_.port===l.port),u=n.some(_=>_.host===l.host&&_.port===l.port);d||u?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?io.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):io.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:CF,set:i,skipped:s}}a(boe,"setRoutesNats");function yoe(e){let t=NF.setRoutesValidator(e);if(t)throw IF(t,t.message,wF.BAD_REQUEST,void 0,void 0,!0);if(Ru.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return boe(e);let r=[],n=[],s=Ru.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{PF(s,i)?n.push(i):(s.push(i),r.push(i))}),io.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:CF,set:r,skipped:n}}a(yoe,"setRoutes");function PF(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(PF,"existsInArray");function Noe(){if(Ru.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=io.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Ru.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Noe,"getRoutes");function Ioe(e){let t=NF.deleteRoutesValidator(e);if(t)throw IF(t,t.message,wF.BAD_REQUEST,void 0,void 0,!0);if(Ru.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return woe(e);let r=[],n=[],s=Ru.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{PF(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),io.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:DF,deleted:r,skipped:n}}a(Ioe,"deleteRoutes");function woe(e){let t=io.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,d=e.routes.length;l<d;l++){let u=e.routes[l],_=!1;for(let E=0,f=r.length;E<f;E++){let h=r[E];if(u.host===h.host&&u.port===h.port){r.splice(E,1),_=!0,o=!0,s.push(u);break}}if(!_){let E=!0;for(let f=0,h=n.length;f<h;f++){let p=n[f];if(u.host===p.host&&u.port===p.port){n.splice(f,1),c=!0,E=!1,s.push(u);break}}E&&i.push(u)}}return o&&(r=qb.isEmptyOrZeroLength(r)?null:r,io.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=qb.isEmptyOrZeroLength(n)?null:n,io.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:DF,deleted:s,skipped:i}}a(woe,"deleteRoutesNats")});var UF=b((pCe,MF)=>{"use strict";var _f=require("alasql"),Mc=require("recursive-iterator"),Ws=V(),Coe=ee(),ff=M(),$b=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,Poe(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>ff.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!ff.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,o=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][ff.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Doe(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(d=>({attribute_name:d.attribute}));let l=this.affected_attributes.get(i).get(o).filter(d=>!ff.SEARCH_WILDCARDS.includes(d));c.forEach(({attribute_name:d})=>{let u=new _f.yy.Column({columnid:d});s.tableid&&(u.tableid=s.tableid),this.ast.columns.push(u),l.includes(d)||l.push(d)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function Doe(e){return e.filter(t=>t[ff.PERMS_CRUD_ENUM.READ])}a(Doe,"filterReadRestrictedAttrs");function Poe(e,t,r,n,s){Loe(e,t,r,n,s)}a(Poe,"interpretAST");function Ef(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),s.set(o,i)}}a(Ef,"addSchemaTableToMap");function Loe(e,t,r,n,s){if(!e){Ws.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof _f.yy.Insert?Boe(e,t,r):e instanceof _f.yy.Select?Moe(e,t,r,n,s):e instanceof _f.yy.Update?Uoe(e,t,r):e instanceof _f.yy.Delete?voe(e,t,r):Ws.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(Loe,"getRecordAttributesAST");function Moe(e,t,r,n,s){if(!e){Ws.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Coe.isEmptyOrZeroLength(i)){Ws.error("No schema specified");return}e.from.forEach(c=>{Ef(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Ef(c.table,t,r,n,s)});let o=new Mc(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,d=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(d).has(l))if(r.has(l))l=r.get(l);else{Ws.info(`table specified as ${l} not found.`);return}t.get(d).get(l).indexOf(c.columnid)<0&&t.get(d).get(l).push(c.columnid)}if(e.where){let c=new Mc(e.where),l=e.from[0].tableid;for(let{node:d}of c)if(d&&d.columnid){let u=d.tableid?d.tableid:l;if(!t.get(i).has(u))if(r.has(u))u=r.get(u);else{Ws.info(`table specified as ${u} not found.`);continue}t.get(i).get(u).indexOf(d.columnid)<0&&t.get(i).get(u).push(d.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Mc(c.on);for(let{node:d}of l)if(d&&d.columnid){let u=d.tableid,_=s.get(u);if(!t.get(_).has(u))if(r.has(u))u=r.get(u);else{Ws.info(`table specified as ${u} not found.`);continue}t.get(_).get(u).indexOf(d.columnid)<0&&t.get(_).get(u).push(d.columnid)}}),e.order){let c=new Mc(e.order);for(let{node:l}of c)if(l&&l.columnid){let d=l.tableid,u=n.has(d)?n.get(d):i;if(d||(d=e.from[0].tableid),!t.get(u).has(d))if(r.has(d))d=r.get(d);else{Ws.info(`table specified as ${d} not found.`);return}t.get(u).get(d).indexOf(l.columnid)<0&&t.get(u).get(d).push(l.columnid)}}}a(Moe,"getSelectAttributes");function Uoe(e,t,r){if(!e){Ws.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Mc(e.columns),s=e.table.databaseid;Ef(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(Uoe,"getUpdateAttributes");function voe(e,t,r){if(!e){Ws.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Mc(e.where),s=e.table.databaseid;Ef(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(voe,"getDeleteAttributes");function Boe(e,t,r){if(!e){Ws.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Mc(e.columns),s=e.into.databaseid;Ef(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.into.tableid,s,i.columnid,t,r)}a(Boe,"getInsertAttributes");function Vb(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(Vb,"pushAttribute");MF.exports=$b});var Wb=b((TCe,xF)=>{var Sp=ic(),vF=require("chalk"),kn=V(),BF=require("prompt"),{promisify:Hoe}=require("util"),Yb=M(),xoe=require("fs-extra"),Foe=require("path"),koe=ee(),Goe=wc(),HF=te();HF.initSync();var qoe=require("moment"),$oe=Hoe(BF.get),Voe=Foe.join(HF.getHdbBasePath(),Yb.LICENSE_KEY_DIR_NAME,Yb.LICENSE_FILE_NAME,Yb.LICENSE_FILE_NAME);xF.exports={getFingerprint:Koe,setLicense:Yoe,parseLicense:Kb,register:Woe,getRegistrationInfo:Qoe};async function Yoe(e){if(e&&e.key&&e.company){try{kn.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Kb(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw kn.error(r),kn.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(Yoe,"setLicense");async function Koe(){let e={};try{e=await Sp.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw kn.error(r),kn.error(t),new Error(r)}return e}a(Koe,"getFingerprint");async function Kb(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");kn.info("Validating license input...");let r=Sp.validateLicense(e,t);if(kn.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(kn.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(kn.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{kn.info("writing license to disk"),await xoe.writeFile(Voe,JSON.stringify({license_key:e,company:t}))}catch(n){throw kn.error("Failed to write License"),n}return"Registration successful."}a(Kb,"parseLicense");async function Woe(){let e=await joe();return Kb(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Woe,"register");async function joe(){let e=await Sp.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:vF.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:vF.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{BF.start()}catch(n){kn.error(n)}let r;try{r=await $oe(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(joe,"promptForRegistration");async function Qoe(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Sp.getLicense()}catch(r){throw kn.error(`There was an error when searching licenses due to: ${r.message}`),r}if(koe.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=Goe.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=qoe.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(Qoe,"getRegistrationInfo")});var kF=b((RCe,FF)=>{"use strict";var zoe=_t(),jb=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,d,u,_,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+zoe.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:d,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:_,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};FF.exports=jb});var $F=b((OCe,qF)=>{"use strict";var GF=_t(),Qb=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,d,u,_){this.port=t,_===null&&(_=void 0),this.server_name=r+GF.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+GF.SERVER_SUFFIX.LEAF},this.tls={cert_file:d,key_file:u,ca_file:_,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:_,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:_,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};qF.exports=Qb});var YF=b((yCe,VF)=>{"use strict";var zb=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};VF.exports=zb});var WF=b((ICe,KF)=>{"use strict";var Joe=_t(),Jb=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+Joe.SERVER_SUFFIX.ADMIN,this.password=r}};KF.exports=Jb});var Ap=b((CCe,zF)=>{"use strict";var Au=require("path"),Ou=require("fs-extra"),Xoe=kF(),Zoe=$F(),eae=YF(),tae=WF(),Xb=vn(),yu=ee(),mn=It(),gp=M(),hf=_t(),{CONFIG_PARAMS:Jt}=gp,Nu=V(),mf=te(),jF=Ji(),Zb=Ft(),rae=Ks(),bu="clustering",nae=1e4,QF=50;zF.exports={generateNatsConfig:iae,removeNatsConfig:oae,getHubConfigPath:sae};function sae(){let e=mf.get(Jt.ROOTPATH);return Au.join(e,bu,hf.NATS_CONFIG_FILES.HUB_SERVER)}a(sae,"getHubConfigPath");async function iae(e=!1,t=void 0){mf.initSync();let r=mn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),n=mn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),s=mn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await Ou.exists(s)&&!await Ou.exists(!r)&&await rae.createNatsCerts();let i=mf.get(Jt.ROOTPATH),o=Au.join(i,bu,hf.PID_FILES.HUB),c=Au.join(i,bu,hf.PID_FILES.LEAF),l=mn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),d=Au.join(i,bu,hf.NATS_CONFIG_FILES.HUB_SERVER),u=Au.join(i,bu,hf.NATS_CONFIG_FILES.LEAF_SERVER),_=mn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),E=mn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),f=mn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Zb.checkNATSServerInstalled()||Rp("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await Xb.listUsers(),T=mn.getConfigFromFile(Jt.CLUSTERING_USER),g=await Xb.getClusterUser();(yu.isEmpty(g)||g.active!==!0)&&Rp(`Invalid cluster user '${T}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Tp(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Tp(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Tp(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Tp(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let S=[],C=[];for(let[Q,_e]of p.entries())_e.role.role===gp.ROLE_TYPES_ENUM.CLUSTER_USER&&_e.active&&(S.push(new tae(_e.username,jF.decrypt(_e.hash))),C.push(new eae(_e.username,jF.decrypt(_e.hash))));let y=[],{hub_routes:x}=mn.getClusteringRoutes();if(!yu.isEmptyOrZeroLength(x))for(let Q of x)y.push(`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@${Q.host}:${Q.port}`);let F=new Xoe(mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,o,s,n,r,_,E,h,mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),y,S,C);r==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=yu.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===gp.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Ou.writeJson(d,F),Nu.trace(`Hub server config written to ${d}`));let Y=`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,$=`tls://${g.uri_encoded_name}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,Z=new Zoe(mn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,c,l,[Y],[$],S,C,s,n,r,_);r==null&&delete Z.tls.ca_file,(t===void 0||t===gp.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Ou.writeJson(u,Z),Nu.trace(`Leaf server config written to ${u}`))}a(iae,"generateNatsConfig");async function Tp(e){let t=mf.get(e);return yu.isEmpty(t)&&Rp(`port undefined for '${e}'`),await yu.isPortTaken(t)&&Rp(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(Tp,"isPortAvailable");function Rp(e){let t=`Error generating clustering config: ${e}`;Nu.error(t),console.error(t),process.exit(1)}a(Rp,"generateNatsConfigError");async function oae(e){let{port:t,config_file:r}=Zb.getServerConfig(e),{username:n,decrypt_hash:s}=await Xb.getClusterUser(),i=0,o=2e3;for(;i<QF;){try{let u=await Zb.createConnection(t,n,s,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){Nu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=QF)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let d=o*(i*2);d>3e4&&Nu.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await yu.async_set_timeout(d)}let c="0".repeat(nae),l=Au.join(mf.get(Jt.ROOTPATH),bu,r);await Ou.writeFile(l,c),await Ou.remove(l),Nu.notify(e,"started.")}a(oae,"removeNatsConfig")});var rk=b((PCe,tk)=>{"use strict";var Gn=te(),aae=ic(),Fe=M(),pf=_t(),oo=require("path"),{PACKAGE_ROOT:bp}=M(),JF=te(),Op=ee(),Iu="/dev/null",cae=oo.join(bp,"launchServiceScripts"),XF=oo.join(bp,"utility/scripts"),lae=oo.join(XF,Fe.HDB_RESTART_SCRIPT),ZF=oo.resolve(bp,"dependencies",`${process.platform}-${process.arch}`,pf.NATS_BINARY_NAME);function ek(){let t=aae.licenseSearch().ram_allocation||Fe.RAM_ALLOCATION_ENUM.DEFAULT,r=Fe.MEM_SETTING_KEY+t,n={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Op.noBootFile()&&(n[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Op.getEnvCliRootPath()),{name:Fe.PROCESS_DESCRIPTORS.HDB,script:Fe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:bp}}a(ek,"generateMainServerConfig");var uae=9930;function dae(){Gn.initSync(!0);let e=Gn.get(Fe.CONFIG_PARAMS.ROOTPATH),t=oo.join(e,"clustering",pf.NATS_CONFIG_FILES.HUB_SERVER),r=oo.join(Gn.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=JF.get(Fe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=pf.LOG_LEVEL_FLAGS[Gn.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==uae?"-"+n:""),script:ZF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Gn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Iu,i.error_file=Iu),i}a(dae,"generateNatsHubServerConfig");var _ae=9940;function fae(){Gn.initSync(!0);let e=Gn.get(Fe.CONFIG_PARAMS.ROOTPATH),t=oo.join(e,"clustering",pf.NATS_CONFIG_FILES.LEAF_SERVER),r=oo.join(Gn.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=JF.get(Fe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=pf.LOG_LEVEL_FLAGS[Gn.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==_ae?"-"+n:""),script:ZF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Gn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Iu,i.error_file=Iu),i}a(fae,"generateNatsLeafServerConfig");function Eae(){Gn.initSync();let e=oo.join(Gn.get(Fe.CONFIG_PARAMS.LOGGING_ROOT),Fe.LOG_NAMES.HDB),t={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Fe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:cae,autorestart:!1};return Gn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Iu,t.error_file=Iu),t}a(Eae,"generateClusteringUpgradeV4ServiceConfig");function hae(){let e={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.RESTART_HDB};return Op.noBootFile()&&(e[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Op.getEnvCliRootPath()),{...{name:Fe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:XF},script:lae}}a(hae,"generateRestart");function mae(){return{apps:[ek()]}}a(mae,"generateAllServiceConfigs");tk.exports={generateAllServiceConfigs:mae,generateMainServerConfig:ek,generateRestart:hae,generateNatsHubServerConfig:dae,generateNatsLeafServerConfig:fae,generateClusteringUpgradeV4ServiceConfig:Eae}});var Tf=b((UCe,hk)=>{"use strict";var it=M(),pae=ee(),co=Ap(),yp=Ft(),ao=_t(),da=rk(),Np=te(),Uc=V(),Sae=_s(),{startWorker:nk,onMessageFromWorkers:Tae}=st(),gae=pu(),MCe=require("util"),Rae=require("child_process"),Aae=require("fs"),{execFile:Oae}=Rae,Qe;hk.exports={enterPM2Mode:bae,start:_a,stop:ey,reload:ik,restart:ok,list:ty,describe:ck,connect:lo,kill:Cae,startAllServices:Dae,startService:ry,getUniqueServicesList:lk,restartAllServices:Pae,isServiceRegistered:uk,reloadStopStart:dk,restartHdb:ak,deleteProcess:Iae,startClusteringProcesses:fk,startClusteringThreads:Ek,isHdbRestartRunning:wae,isClusteringRunning:Mae,stopClustering:Lae,reloadClustering:Uae};var Sf=!1;Tae(e=>{e.type==="restart"&&Np.initSync(!0)});function bae(){Sf=!0}a(bae,"enterPM2Mode");function lo(){return Qe||(Qe=require("pm2")),new Promise((e,t)=>{Qe.connect((r,n)=>{r&&t(r),e(n)})})}a(lo,"connect");var pn,yae=10,sk;function _a(e,t=!1){if(Sf)return Nae(e);let r=Oae(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=pn.indexOf(r);o>-1&&pn.splice(o,1),!sk&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<yae&&(Aae.existsSync(co.getHubConfigPath())?_a(e):(await co.generateNatsConfig(!0),_a(e),await new Promise(c=>setTimeout(c,3e3)),await co.removeNatsConfig(it.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await co.removeNatsConfig(it.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Np.get(it.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,d=0,u;for(;l=c.exec(i);){if(l.index&&ao.LOG_LEVEL_HIERARCHY[o]>=ao.LOG_LEVEL_HIERARCHY[u||"info"]){let f=u===ao.LOG_LEVELS.ERR||u===ao.LOG_LEVELS.WRN?Uc.OUTPUTS.STDERR:Uc.OUTPUTS.STDOUT;Uc.logCustomLevel(u||"info",f,n,i.slice(d,l.index).trim())}let[_,E]=l;d=l.index+_.length,u=ao.LOG_LEVELS[E]}if(ao.LOG_LEVEL_HIERARCHY[o]>=ao.LOG_LEVEL_HIERARCHY[u||"info"]){let _=u===ao.LOG_LEVELS.ERR||u===ao.LOG_LEVELS.WRN?Uc.OUTPUTS.STDERR:Uc.OUTPUTS.STDOUT;Uc.logCustomLevel(u||"info",_,n,i.slice(d).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),pn=[],!pn&&!t){let i=a(()=>{sk=!0,pn&&(pn.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}pn.push(r)}a(_a,"start");function Nae(e){return new Promise(async(t,r)=>{try{await lo()}catch(n){r(n)}Qe.start(e,(n,s)=>{n&&(Qe.disconnect(),r(n)),Qe.disconnect(),t(s)})})}a(Nae,"startWithPM2");function ey(e){if(!Sf){for(let t of pn||[])t.name===e&&(pn.splice(pn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await lo()}catch(n){r(n)}Qe.stop(e,async(n,s)=>{n&&(Qe.disconnect(),r(n)),Qe.delete(e,(i,o)=>{i&&(Qe.disconnect(),r(n)),Qe.disconnect(),t(o)})})})}a(ey,"stop");function ik(e){return new Promise(async(t,r)=>{try{await lo()}catch(n){r(n)}Qe.reload(e,(n,s)=>{n&&(Qe.disconnect(),r(n)),Qe.disconnect(),t(s)})})}a(ik,"reload");function ok(e){if(!Sf)for(let t of pn||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await lo()}catch(n){r(n)}Qe.restart(e,(n,s)=>{Qe.disconnect(),t(s)})})}a(ok,"restart");function Iae(e){return new Promise(async(t,r)=>{try{await lo()}catch(n){r(n)}Qe.delete(e,(n,s)=>{n&&(Qe.disconnect(),r(n)),Qe.disconnect(),t(s)})})}a(Iae,"deleteProcess");async function ak(){await _a(da.generateRestart())}a(ak,"restartHdb");async function wae(){let e=await ty();for(let t in e)if(e[t].name===it.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(wae,"isHdbRestartRunning");function ty(){return new Promise(async(e,t)=>{try{await lo()}catch(r){t(r)}Qe.list((r,n)=>{r&&(Qe.disconnect(),t(r)),Qe.disconnect(),e(n)})})}a(ty,"list");function ck(e){return new Promise(async(t,r)=>{try{await lo()}catch(n){r(n)}Qe.describe(e,(n,s)=>{n&&(Qe.disconnect(),r(n)),Qe.disconnect(),t(s)})})}a(ck,"describe");function Cae(){if(!Sf){for(let e of pn||[])e.kill();pn=[];return}return new Promise(async(e,t)=>{try{await lo()}catch(r){t(r)}Qe.killDaemon((r,n)=>{r&&(Qe.disconnect(),t(r)),Qe.disconnect(),e(n)})})}a(Cae,"kill");async function Dae(){try{await fk(),await Ek(),await _a(da.generateAllServiceConfigs())}catch(e){throw Qe?.disconnect(),e}}a(Dae,"startAllServices");async function ry(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case it.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=da.generateMainServerConfig();break;case it.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=da.generateNatsIngestServiceConfig();break;case it.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=da.generateNatsReplyServiceConfig();break;case it.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=da.generateNatsHubServerConfig(),await _a(r,t),await co.removeNatsConfig(e);return;case it.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=da.generateNatsLeafServerConfig(),await _a(r,t),await co.removeNatsConfig(e);return;case it.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=da.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await _a(r)}catch(r){throw Qe?.disconnect(),r}}a(ry,"startService");async function lk(){try{let e=await ty(),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 Qe?.disconnect(),e}}a(lk,"getUniqueServicesList");async function Pae(e=[]){try{let t=!1,r=await lk();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===it.PROCESS_DESCRIPTORS.HDB?t=!0:await ok(o))}t&&await dk(it.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Qe?.disconnect(),t}}a(Pae,"restartAllServices");async function uk(e){if(pn?.find(r=>r.name===e))return!0;let t=await gae.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(uk,"isServiceRegistered");async function dk(e){let t=Np.get(it.CONFIG_PARAMS.THREADS_COUNT)??Np.get(it.CONFIG_PARAMS.THREADS),r=await ck(e),n=pae.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await ey(e),await ry(e)):e===it.PROCESS_DESCRIPTORS.HDB?await ak():await ik(e)}a(dk,"reloadStopStart");var _k;async function fk(e=!1){for(let t in it.CLUSTERING_PROCESSES){let r=it.CLUSTERING_PROCESSES[t];await ry(r,e)}}a(fk,"startClusteringProcesses");async function Ek(){_k=nk(it.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:it.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await yp.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await yp.updateLocalStreams();let e=await Sae.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===it.PRE_4_0_0_VERSION){Uc.info("Starting clustering upgrade 4.0.0 process"),nk(it.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(Ek,"startClusteringThreads");async function Lae(){for(let e in it.CLUSTERING_PROCESSES)if(e!==it.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===it.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await _k.terminate();else{let t=it.CLUSTERING_PROCESSES[e];await ey(t)}}a(Lae,"stopClustering");async function Mae(){for(let e in it.CLUSTERING_PROCESSES){let t=it.CLUSTERING_PROCESSES[e];if(await uk(t)===!1)return!1}return!0}a(Mae,"isClusteringRunning");async function Uae(){await co.generateNatsConfig(!0),await yp.reloadNATSHub(),await yp.reloadNATSLeaf(),await co.removeNatsConfig(it.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await co.removeNatsConfig(it.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Uae,"reloadClustering")});var iy={};tt(iy,{compactOnStart:()=>vae,copyDb:()=>Rk});async function vae(){gf.notify("Running compact on start"),console.log("Running compact on start");let e=(0,ny.get)(fa.CONFIG_PARAMS.ROOTPATH),t=new Map,r=ht();try{for(let n in r){if(n==="system")continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Ip.join)(e,"backup",n+".mdb"),o=(0,Ip.join)(e,fa.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await mk(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await Rk(n,o),console.log("Backing up",n,"to",i),await(0,vc.move)(s,i,{overwrite:!0})}wu();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,vc.move)(i,s,{overwrite:!0}),await(0,vc.remove)((0,Ip.join)(e,fa.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));wu()}catch(n){gf.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,sy.updateConfigValue)(fa.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,vc.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw wu(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await mk(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
14
+ `,"")}a(q0,"runCommand");async function Jee(){try{await wee.access(ib)}catch{return!1}let e=await q0(`${ib} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Cee.eq(t,Qee)}a(Jee,"checkNATSServerInstalled");async function ub(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await F0.getClusterUser();if(mc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Ks.trace("create nats connection called");let i=await kee({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Ks.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Ks.error("Error with Nats client connection, connection closed",o),$0()}),i}a(ub,"createConnection");function $0(){un=void 0,fc=void 0,Ec=void 0,hc=void 0}a($0,"clearClientCache");async function Xee(){un&&(await un.drain(),un=void 0,fc=void 0,Ec=void 0,hc=void 0)}a(Xee,"closeConnection");var un,hc;async function L_(){return hc||(hc=ub(Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),un=await hc),un||hc}a(L_,"getConnection");async function M_(){if(fc)return fc;mc(un)&&await L_();let{domain:e}=Ql(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(mc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return fc=await un.jetstreamManager({domain:e,timeout:6e4}),fc}a(M_,"getJetStreamManager");async function V0(){if(Ec)return Ec;mc(un)&&await L_();let{domain:e}=Ql(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(mc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ec=un.jetstream({domain:e,timeout:6e4}),Ec}a(V0,"getJetStream");async function Ri(){let e=un||await L_(),t=fc||await M_(),r=Ec||await V0();return{connection:e,jsm:t,js:r}}a(Ri,"getNATSReferences");async function Zee(e){let t=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await F0.getClusterUser(),s=await ub(t,r,n),i=lb(),o=s.subscribe(i),c=[],l,d=(async()=>{for await(let u of o){let _=G0.decode(u.data);_.response_time=Date.now()-l,c.push(_)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Am.async_set_timeout(e),await o.drain(),await s.close(),await d,c}a(Zee,"getServerList");async function db(e,t){let{jsm:r}=await Ri(),n=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Fee.File,retention:Gee.Limits,subjects:t,discard:qee.Old,max_msgs:s,max_bytes:i,max_age:n})}a(db,"createLocalStream");async function Y0(){let{jsm:e}=await Ri(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Y0,"listStreams");async function ete(e){let{jsm:t}=await Ri();await t.streams.delete(e)}a(ete,"deleteLocalStream");async function tte(e){let{connection:t}=await Ri(),r=[],n=lb(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(G0.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(tte,"listRemoteStreams");async function rte(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ri(),i=B0(),o={durable_name:i,ack_policy:ab.Explicit};t&&(o.deliver_policy=cb.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let d=[];for await(let u of l){let _=ob(u.data),E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:_};if(u.headers&&(E.origin=u.headers.get(Cr.MSG_HEADERS.ORIGIN)),d.push(E),u.ack(),u.info.pending===0)break}return await c.delete(),d}a(rte,"viewStream");async function*nte(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ri(),i=B0(),o={durable_name:i,ack_policy:ab.Explicit};t&&(o.deliver_policy=cb.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let d of l){let u=ob(d.data);u[0]||(u=[u]);for(let _ of u){let E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:_};d.headers&&(E.origin=d.headers.get(Cr.MSG_HEADERS.ORIGIN)),yield E}if(d.ack(),d.info.pending===0)break}await c.delete()}a(nte,"viewStreamIterator");async function ste(e,t,r,n){Ks.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=K0(n,r);let{js:s}=await Ri(),i=await ym(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:k0.encode(n);try{Ks.trace(`publishToStream publishing to subject: ${o}`),Wee(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return j0(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){Ks.trace(`publishToStream creating stream: ${t}`);let u=o.split(".");u[2]="*",await db(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(ste,"publishToStream");function K0(e,t){t===void 0&&(t=Vee());let r=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Cr.MSG_HEADERS.ORIGIN)&&r&&t.append(Cr.MSG_HEADERS.ORIGIN,r),t}a(K0,"addNatsMsgHeader");function Ql(e){e=e.toLowerCase();let t=P_.join(Rr.get(Qe.CONFIG_PARAMS.ROOTPATH),jee);if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return mc(sb)&&(sb={port:C_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:C_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Cr.SERVER_SUFFIX.HUB,config_file:Cr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:P_.join(t,Cr.PID_FILES.HUB),hdb_nats_path:t}),sb;if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return mc(nb)&&(nb={port:C_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:C_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Cr.SERVER_SUFFIX.LEAF,config_file:Cr.NATS_CONFIG_FILES.LEAF_SERVER,domain:C_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Cr.SERVER_SUFFIX.LEAF,pid_file_path:P_.join(t,Cr.PID_FILES.LEAF),hdb_nats_path:t}),nb;Ks.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Ql,"getServerConfig");async function W0(e,t,r,n){try{await e.consumers.add(t,{ack_policy:ab.Explicit,durable_name:r,deliver_policy:cb.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(W0,"createConsumer");async function ite(e,t,r){await e.consumers.delete(t,r)}a(ite,"removeConsumer");function ote(e){return e.split(".")[1]}a(ote,"extractServerName");async function ate(e,t,r=6e4,n=lb()){if(!Am.isObject(t))throw new Error("data param must be an object");let s=k0.encode(t),{connection:i}=await Ri(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return ob(c.data)}a(ate,"request");function _b(e){return new Promise(async(t,r)=>{let n=Mee(ib,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(_b,"reloadNATS");async function cte(){let{pid_file_path:e}=Ql(Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await _b(e)}a(cte,"reloadNATSHub");async function lte(){let{pid_file_path:e}=Ql(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await _b(e)}a(lte,"reloadNATSLeaf");function ute(e,t,r){let n;switch(e.code){case v0.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case v0.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(ute,"requestErrorHandler");async function dte(e,t){let r=t+Cr.SERVER_SUFFIX.LEAF,{connection:n}=await Ri(),{jsm:s}=await Tte(r),{schema:i,table:o}=e,c=bm.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await j0(async()=>{if(e.subscribe===!0)await W0(s,c,n.info.server_name,l);else try{await ite(s,c,n.info.server_name)}catch(d){Ks.trace(d)}})}a(dte,"updateRemoteConsumer");async function _te(e,t,r,n){let s=bm.createNatsTableStreamName(e,t),i=r+Cr.SERVER_SUFFIX.LEAF,o={type:Qe.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!x0&&Hee()<Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=rb();await c(o)}await vee(o),n==="stop"&&await Am.async_set_timeout(1e3)}a(_te,"updateConsumerIterator");function j0(e){return Uee.writeTransaction(Qe.SYSTEM_SCHEMA_NAME,Qe.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(j0,"exclusiveLock");async function Q0(e,t){let r=bm.createNatsTableStreamName(e,t),n=await ym(),s=mte(e,t,n);await db(r,[s])}a(Q0,"createLocalTableStream");async function fte(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await Q0(n,s)}}a(fte,"createTableStreams");async function z0(e,t,r=void 0){if(Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=bm.createNatsTableStreamName(e,t),{domain:s}=Ql(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await L_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")Ks.warn(n);else throw n}}a(z0,"purgeTableStream");async function Ete(e,t){if(Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await z0(e,t[r])}a(Ete,"purgeSchemaTableStreams");async function hte(e){return(await M_()).streams.info(e)}a(hte,"getStreamInfo");function mte(e,t,r){return`${Cr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(mte,"createSubjectName");async function ym(){if(D_)return D_;if(D_=(await M_())?.nc?.info?.server_name,D_===void 0)throw new Error("Unable to get jetstream manager server name");return D_}a(ym,"getJsmServerName");async function pte(){let e=await M_(),t=await ym(),r=await Y0();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=Ste(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let d=i.split(".");d[d.length-1]=t;let u=d.join(".");Ks.trace(`Updating stream subject name from: ${i} to: ${u}`),s.subjects[0]=u,await e.streams.update(s.name,s)}}a(pte,"updateLocalStreams");function Ste(e){let{config:t}=e,r=!1,n=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Rr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(Ste,"updateStreamLimits");async function Tte(e){let t,r;try{t=await un.jetstream({domain:e}),r=await un.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw Ks.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Tte,"connectToRemoteJS")});var zl=b(Nm=>{var Om=V();for(let e of["trace","debug","info","warn","error","fatal","notify"])Om.logsAtLevel(e)&&(Nm[e]=Om[e]);Nm.loggerWithTag=e=>Om.loggerWithTag(e,!0);Nm.setLogLevel=Om.setLogLevel});function fb(e){let t=e.get(Im),r=t?(0,Jl.unpack)(t):null;r||(r={remoteNameToId:{}});let n=at(),s=!1;r.nodeName=at();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let d=i[l];d===0?c=l:d>o&&(o=d)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:v_(e)??1,nodes:[]})})}i[n]=0,e.putSync(Im,(0,Jl.pack)(r))}return r}function U_(e){return fb(e).remoteNameToId}function Z0(e,t,r){let n=fb(r),s=n.remoteNameToId,i=new Map,o=!1;for(let c in t){let l=t[c],d=s[c];if(d==null){let u=0;for(let _ in s){let E=s[_];E>u&&(u=E)}d=u+1,s[c]=d,o=!0}i.set(l,d)}return o&&r.putSync(Im,(0,Jl.pack)(n)),i}function wm(e,t){let r=fb(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Im,(0,Jl.pack)(r))}return X0.info?.("The remote node name map",e,n,s),s}var X0,Jl,Im,Eb=De(()=>{X0=v(zl());ls();Jl=require("msgpackr"),Im=Symbol.for("remote-ids");a(fb,"getIdMappingRecord");a(U_,"exportIdMapping");a(Z0,"remoteToLocalNodeId");a(wm,"getIdOfRemoteNode")});var Zo,hb=De(()=>{Zo=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var rB={};et(rB,{Resources:()=>Cm,keyArrayToString:()=>Xl,resetResources:()=>gte,resources:()=>ea});function gte(){return ea=new Cm}function Xl(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var eB,tB,Cm,ea,B_=De(()=>{uc();hb();eB=v(V()),tB=v(fe()),Cm=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new tB.ServerError(`Conflicting paths for ${t}`);eB.default.error(c),i.Resource=new Zo(c)}super.set(t,i);for(let[c,l]of this){let d=2;for(;(d=c.indexOf("/",d))>-1;){let u=this.get(c.slice(0,d));u&&(u.hasSubPaths=!0),d+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(!l&&c.indexOf(".")>-1){let d=c.split(".");l=this.get(d[0])}if(l&&(!r||l.exportTypes?.[r]!==!1)){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),s&&(!r||s.exportTypes?.[r]!==!1)?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(!r||s.exportTypes?.[r]!==!1)&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Ct(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(gte,"resetResources");a(Xl,"keyArrayToString")});function Sb(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=sB,Rte(e.primaryStore,e.auditStore)):(c=nB,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{iB(nB[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let d=l[o];d||(d=l[o]=new Map,d.envs=l,d.tableId=o,d.store=e.primaryStore),t=Xl(t);let u=new pb(r);u.startTime=n;let _=d.get(t);return _?_.push(u):(d.set(t,_=[u]),_.tables=d,_.key=t),u.subscriptions=_,u}function iB(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),oB(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ht(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Xl(c),d=0;do{let u=o.get(l);if(u){for(let E of u)if(!(d>0&&!(E.includeDescendants&&!(E.onlyChildren&&d>1)))){if(E.startTime>=n){(0,mb.info)("omitting",c,E.startTime,n);continue}try{let f;E.supportsTransactions&&E.txnInProgress!==i.version&&(f=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,f)}catch(f){console.error(f),(0,mb.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_>-1?l=l.slice(0,_):l=null,d++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function Rte(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=sB[s];if(!l)return;let d=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{iB(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",d)&&d()})}}function oB(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function aB(e){return e.nextTransaction||(Sb({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),oB(e)),e.nextTransaction}var mb,nB,sB,pb,Tb=De(()=>{mb=v(V());Al();B_();Ki();nB=Object.create(null),sB=Object.create(null);a(Sb,"addSubscription");pb=class extends In{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(iB,"notifyFromTransactionData");a(Rte,"listenToCommits");a(oB,"nextTransaction");a(aB,"whenNextTransaction")});var dB={};et(dB,{commits_awaiting_replication:()=>tu,getHDBNodeTable:()=>Er,iterateRoutes:()=>x_,shouldReplicateToNode:()=>H_,subscribeToNodeUpdates:()=>ru});function Er(){return cB||(cB=Et({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function ru(e){Er().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==at()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r)),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function H_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&Er().primaryStore.get(at())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function Ate(){ru(e=>{ta({},(t,r)=>{let n=e.name,s=lB.get(n);if(s||lB.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=new Float64Array(i.getUserSharedBuffer(["replicated",r,n],new ArrayBuffer(8),{callback:()=>{let c=o[0],l=o.lastTime;for(let{txnTime:d,onConfirm:u}of tu.get(r)||[])d>l&&d<=c&&u();o.lastTime=c}}));o.lastTime=0,s.set(r,o)}})})}function*x_(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=Zl.default.get(eu.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!Zl.default.get(eu.CONFIG_PARAMS.REPLICATION_PORT)&&Zl.default.get(eu.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||Zl.default.get(eu.CONFIG_PARAMS.REPLICATION_PORT)||Zl.default.get(eu.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){uB.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{url:r,subscription:t.subscriptions,routes:t.routes}}}var uB,Zl,eu,cB,lB,tu,nu=De(()=>{Le();ls();im();uB=require("worker_threads"),Zl=v(te()),eu=v(M());server.nodes=[];a(Er,"getHDBNodeTable");a(ru,"subscribeToNodeUpdates");a(H_,"shouldReplicateToNode");lB=new Map;Tv((e,t,r)=>{tu||(tu=new Map,Ate());let n=tu.get(e);return n||tu.set(e,n=[]),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:()=>{++i===r&&s()}})})});a(Ate,"startSubscriptionToReplications");a(x_,"iterateRoutes")});var mB={};et(mB,{connectedToNode:()=>pc,disconnectedFromNode:()=>ou,ensureNode:()=>ro,requestClusterStatus:()=>hB,startOnMainThread:()=>Rb});async function Rb(e){let t=0,r=mt();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){Dm.set(i,v_(l.auditStore));break}}}Ai.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes.search([]))i.push(o);for(let o of x_(e))try{let c=!o.subscriptions;if(c){let d=at();Er().primaryStore.get(d)===void 0&&await ro(d,{name:d,url:e.url??ra(),replicates:!0})}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(d=>d.url===o.url))continue;s(o)}catch(c){console.error(c)}ru(s)});let n;function s(i,o=i?.name){let c=at()&&o===at()||ra()&&i?.url===ra();if(c){let _=!!i?.replicates;if(n!==void 0&&n!==_)for(let E of Er().search([]))E.replicates&&E.name!==o&&s(E,E.name);n=_}if(_t.trace("Setting up node replication for",i),!i){for(let[_,E]of to){let f;for(let[h,{worker:T,nodes:S}]of E){let R=S[0];if(R&&R.name==o){f=!0;for(let[p,{worker:y}]of E)E.delete(p),_t.warn("Node was deleted, unsubscribing from node",o,p,_),y?.postMessage({type:"unsubscribe-from-node",node:o,database:p,url:_});break}}if(f){to.get(_).iterator.remove(),to.delete(_);return}}return}if(c)return;if(!i.url){_t.info(`Node ${i.name} is missing url`);return}let l=to.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(_t.info(`Added node ${i.name} at ${i.url} for process ${at()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[_,E]of su)if(i.url===E.url){su.delete(_);break}su.set(i.name,i)}let d=mt();if(l||(l=new Map,to.set(i.url,l)),l.iterator=ta(e,(_,E,f)=>{f?u(E,!0):u(E,!1)}),i.subscriptions)for(let _ of i.subscriptions){let E=_.database||_.schema;d[E]||(_t.warn(`Database ${E} not found for node ${i.name}, making a subscription anyway`),u(E,!1))}function u(_,E){_t.trace("Setting up replication for database",_,"on node",i.name);let f=l.get(_),h,T=[{replicateByDefault:E,...i}];Dm.has(_)&&(T.push({replicateByDefault:E,name:at(),start_time:Dm.get(_),end_time:Date.now(),replicates:!0}),Dm.delete(_));let S=H_(i,_),R=Ai.workers.filter(p=>p.name==="http");if(f?(h=f.worker,f.nodes=T):S&&(t=t%R.length,h=R[t++],l.set(_,{worker:h,nodes:T,url:i.url}),h?.on("exit",()=>{l.get(_)?.worker===h&&(l.delete(_),u(_,E))})),S)setTimeout(()=>{let p={type:"subscribe-to-node",database:_,nodes:T};h?h.postMessage(p):iu(p)},bte);else{_t.info("Node no longer should be used, unsubscribing from node",i.replicates,!!d[_],Er().primaryStore.get(at())?.replicates),Er().primaryStore.get(at())?.replicates||(n=!1);let p={type:"unsubscribe-from-node",database:_,url:i.url,name:i.name};h?h.postMessage(p):Lm(p)}}a(u,"onDatabase")}a(s,"onNodeUpdate"),ou=a(function(i){try{_t.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(su.keys()),c=o.sort(),l=c.indexOf(i.name||bi(i.url));if(l===-1){_t.warn("Disconnected node not found in node map",i.name,o);return}let d=to.get(i.url),u=d?.get(i.database);if(!u){_t.warn("Disconnected node not found in replication map",i.database,d);return}if(u.connected=!1,i.finished)return;let _=u.nodes[0];if(!(_.replicates===!0||_.replicates?.sends||_.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let f=c[E],h=su.get(f);d=to.get(h.url);let T=d?.get(i.database);if(!T){E=(E+1)%c.length;continue}let{worker:S,nodes:R}=T,p=!1;for(let y of u.nodes){if(R.some(O=>O.name===y.name)){_t.info(`Disconnected node is already failing over to ${f} for ${i.database}`);continue}R.push(y),p=!0}if(!p){_t.info(`Disconnected node ${i.name} has no nodes to fail over to ${f}`);return}u.redirectingTo=T,_t.info(`Failing over ${i.database} from ${i.name} to ${f}`),S?S.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):iu({database:i.database,nodes:R});return}_t.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){_t.error("Error failing over node",o)}},"disconnectedFromNode"),pc=a(function(i){let o=to.get(i.url),c=o?.get(i.database);if(!c){_t.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.catchingUpFrom=i.lastSendTime,c.redirectingTo){let{worker:l,nodes:d}=c.redirectingTo,u=d.find(_=>_.name===i.name);c.redirectingTo=null,u&&(d.splice(d.indexOf(u),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:d}):iu({database:i.database,nodes:d}))}},"connectedToNode"),(0,Ai.onMessageByType)("disconnected-from-node",ou),(0,Ai.onMessageByType)("connected-to-node",pc),(0,Ai.onMessageByType)("request-cluster-status",hB)}function hB(e,t){let r=[];for(let[n,s]of su)try{let i=to.get(s.url);_t.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:d,connected:u,nodes:_,latency:E,catchingUpFrom:f}]of i)o.push({database:l,connected:u,latency:E,catching_up_from:f?new Date(f).toISOString():"up-to-date",thread_id:d?.threadId,nodes:_.map(h=>h.name)});let c=(0,gb.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){_t.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function ro(e,t){let r=Er();e=e??bi(t.url),t.name=e;try{if(t.ca){let s=new EB.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){_t.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(_t.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!_B.default.get(fB.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,gb.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let d of o)if((c.database??c.schema)===(d.database??d.schema)&&c.table===d.table){d.publish=c.publish,d.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}_t.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Ai,Pm,_t,gb,_B,fB,EB,bte,to,ou,pc,su,Dm,k_=De(()=>{Le();Ai=v(it());ls();Pm=require("worker_threads");nu();_t=v(V()),gb=require("lodash"),_B=v(te()),fB=v(M()),EB=require("crypto"),bte=200,to=new Map,su=new Map,Dm=new Map;a(Rb,"startOnMainThread");a(hB,"requestClusterStatus");Pm.parentPort&&(ou=a(e=>{Pm.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),pc=a(e=>{Pm.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Ai.onMessageByType)("subscribe-to-node",e=>{iu(e)}),(0,Ai.onMessageByType)("unsubscribe-from-node",e=>{Lm(e)}));a(ro,"ensureNode")});var js=b(GB=>{"use strict";var Pr=require("path"),us=require("fs-extra"),au=require("node-forge"),AB=require("net"),{generateKeyPair:bb,X509Certificate:io,createPrivateKey:bB}=require("crypto"),yte=require("util");bb=yte.promisify(bb);var Dt=au.pki,so=require("joi"),{v4:Ote}=require("uuid"),{validateBySchema:yB}=ut(),Rt=V(),ds=te(),Ws=M(),{CONFIG_PARAMS:Tc}=Ws,yi=wR(),{ClientError:F_}=fe(),gc=require("node:tls"),{relative:OB,join:NB}=require("node:path"),{CERT_PREFERENCE_APP:QNe,CERTIFICATE_VALUES:pB}=yi,Nte=qa(),yb=wt(),SB=parseInt(process.version.slice(1))<20,{table:Ite,getDatabases:wte,databases:Ab}=(Le(),oe(lt));Object.assign(GB,{generateKeys:MB,updateConfigCert:vB,createCsr:Bte,signCertificate:Hte,setCertTable:cu,loadCertificates:PB,reviewSelfSignedCert:Db,createTLSSelector:xB,listCertificates:kB,addCertificate:$te,removeCertificate:Yte,createNatsCerts:Fte,generateCertsKeys:kte,getReplicationCert:q_,getReplicationCertAuth:vte,renewSelfSigned:Gte,hostnamesFromCert:FB});var{urlToNodeName:IB,getThisNodeUrl:Cte,getThisNodeName:Um,clearThisNodeName:Dte}=(ls(),oe(sa)),{readFileSync:Pte,watchFile:Lte,statSync:wB}=require("node:fs"),zNe=te(),{getTicketKeys:Mte,onMessageFromWorkers:Ute}=it(),no=V(),{isMainThread:CB}=require("worker_threads"),{TLSSocket:DB,createSecureContext:JNe}=require("node:tls"),Ib=3650,G_=["127.0.0.1","localhost","::1"],wb=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Ute(async e=>{e.type===Ws.ITC_EVENT_TYPES.RESTART&&(ds.initSync(!0),await Db())});var Dr;function na(){return Dr||(Dr=wte().system.hdb_certificate,Dr||(Dr=Ite({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),Dr}a(na,"getCertTable");async function q_(){let e=xB("operations-api"),t={secureContexts:null,setSecureContext:s=>{}};await e.initialize(t);let r=t.secureContexts.get(Um());if(!r)return;let n=new io(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(q_,"getReplicationCert");async function vte(){na();let e=(await q_()).options.cert,r=new io(e).issuer.match(/CN=(.*)/)?.[1];return Dr.get(r)}a(vte,"getReplicationCertAuth");var TB,Rc=new Map;function PB(){if(TB)return;TB=!0;let e=[{configKey:Tc.TLS},{configKey:Tc.OPERATIONSAPI_TLS}];na();let t=Pr.dirname(yb.getConfigFilePath()),r;for(let{configKey:n}of e){let s=yb.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&OB(NB(t,"keys"),o);c&&gB(o,l=>{Rc.set(c,l)},"private key");for(let l of[!1,!0]){let d=i[l?"certificateAuthority":"certificate"];if(d&&CB){let u;gB(d,_=>{if(pB.cert===_)return;let E=i.hostname??i.hostnames??i.host??i.hosts;E&&!Array.isArray(E)&&(E=[E]);let f=BB(d),h=new io(f),T;try{T=Pb(h)}catch(y){Rt.error("error extracting common name from certificate",y);return}if(T==null){Rt.error("error extracting common name from certificate");return}if(h.checkIssued(new io(pB.cert)))return;let S=Dr.primaryStore.get(T),R=wB(d).mtimeMs,p=!S||S.is_self_signed?1:S.file_timestamp??S.__updatedtime__;if(S&&R<=p){R<p&&Rt.info(`Certificate ${T} at ${d} is older (${new Date(R)}) than the certificate in the database (${p>1?new Date(p):"only self signed certificate available"})`);return}r=Dr.put({name:T,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:f,private_key_name:c,is_authority:l,hostnames:E,file_timestamp:R,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(PB,"loadCertificates");function gB(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&CB&&Rt.warn(`Reloading ${r}:`,e),n=c,t(BB(e)))}catch(c){Rt.error(`Error loading ${r}:`,e,c)}},"loadFile");us.existsSync(e)?s(wB(e)):Rt.error(`${r} file not found:`,e),Lte(e,{persistent:!1},s)}a(gB,"loadAndWatch");function Ob(){let e=Cte();if(e==null){let t=G_[0];return Rt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return IB(e)}a(Ob,"getHost");function Mm(){let e=Um();if(e==null){let t=G_[0];return Rt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Mm,"getCommonName");async function Bte(){let e=await q_(),t=Dt.certificateFromPem(e.options.cert),r=Dt.privateKeyFromPem(e.options.key);Rt.info("Creating CSR with cert named:",e.name);let n=Dt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Mm()},...wb];Rt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:LB()}];return Rt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),au.pki.certificationRequestToPem(n)}a(Bte,"createCsr");function LB(){let e=G_.includes(Mm())?G_:[...G_,Mm()];return e.includes(Ob())||e.push(Ob()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>AB.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(LB,"certExtensions");async function Hte(e){let t={},r=Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;na();for await(let u of Dr.search([]))if(u.is_authority&&!u.details.issuer.includes("HarperDB-Certificate-Authority")){if(Rc.has(u.private_key_name)){n=Rc.get(u.private_key_name),s=u;break}else if(u.private_key_name&&await us.exists(Pr.join(r,u.private_key_name))){n=us.readFile(Pr.join(r,u.private_key_name)),s=u;break}}if(!n){let u=await Nb();s=u.ca,n=u.private_key}n=Dt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=Dt.certificateFromPem(s.certificate);Rt.info("Signing CSR with cert named",s.name);let o=Dt.certificationRequestFromPem(e.csr);try{o.verify()}catch(u){return Rt.error(u),new Error("Error verifying CSR: "+u.message)}let c=au.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+Ib),Rt.info("sign cert setting validity:",c.validity),Rt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),Rt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let d=o.getAttribute({name:"extensionRequest"}).extensions;Rt.info("sign cert adding extensions from CSR:",d),c.setExtensions(d),c.publicKey=o.publicKey,c.sign(n,au.md.sha256.create()),t.certificate=Dt.certificateToPem(c)}else Rt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Hte,"signCertificate");async function xte(e,t){await cu({name:Um(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await cu({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:Dt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(xte,"createCertificateTable");async function cu(e){let t=new io(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},na(),await Dr.patch(e)}a(cu,"setCertTable");async function MB(){let e=await bb("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:Dt.publicKeyFromPem(e.publicKey),private_key:Dt.privateKeyFromPem(e.privateKey)}}a(MB,"generateKeys");async function Cb(e,t,r){let n=Dt.createCertificate();if(!t){let o=await q_();t=Dt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Ib);let i=[{name:"commonName",value:Mm()},...wb];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(LB()),n.sign(e,au.md.sha256.create()),Dt.certificateToPem(n)}a(Cb,"generateCertificates");async function Nb(){let e=await kB(),t;for(let r of e){if(!r.is_authority)continue;let n=Rc.get(r.private_key_name);if(r.private_key_name&&n&&new io(r.certificate).checkPrivateKey(bB(n))){Rt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;Rt.trace("No CA found with matching private key")}a(Nb,"getCertAuthority");async function UB(e,t){let r=Dt.createCertificate();r.publicKey=t,r.serialNumber=Math.random().toString().slice(2,10),r.validity.notBefore=new Date;let n=new Date;r.validity.notAfter=n,r.validity.notAfter.setDate(n.getDate()+Ib);let s=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ds.get(Tc.REPLICATION_HOSTNAME)??IB(ds.get(Tc.REPLICATION_URL))??Ote().split("-")[0]}`},...wb];r.setSubject(s),r.setIssuer(s),r.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),r.sign(e,au.md.sha256.create());let i=Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME),o=Pr.join(i,yi.PRIVATEKEY_PEM_NAME);return await us.writeFile(o,Dt.privateKeyToPem(e)),r}a(UB,"generateCertAuthority");async function kte(){let{private_key:e,public_key:t}=await MB(),r=await UB(e,t),n=await Cb(e,t,r);await xte(n,r),vB()}a(kte,"generateCertsKeys");async function Fte(){let e=await Cb(Dt.privateKeyFromPem(yi.CERTIFICATE_VALUES.key),void 0,Dt.certificateFromPem(yi.CERTIFICATE_VALUES.cert)),t=Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME),r=Pr.join(t,yi.NATS_CERTIFICATE_PEM_NAME);await us.exists(r)||await us.writeFile(r,e);let n=Pr.join(t,yi.NATS_CA_PEM_NAME);await us.exists(n)||await us.writeFile(n,yi.CERTIFICATE_VALUES.cert)}a(Fte,"createNatsCerts");async function Gte(){na();for await(let e of Dr.search([{attribute:"is_self_signed",value:!0}]))await Dr.delete(e.name);await Db()}a(Gte,"renewSelfSigned");async function Db(){Dte(),await PB(),na();let e,t=ds.get(Tc.TLS_PRIVATEKEY),r=a(async()=>e||(e=Dt.privateKeyFromPem(await us.readFile(t)),e),"getPrivateKey"),n=await Nb();if(!n){Rt.info("No self signed Cert Authority found, generating new self signed CA"),await r();let i=await UB(e,Dt.setRsaPublicKey(e.n,e.e));await cu({name:i.subject.getField("CN").value,uses:["https","wss"],certificate:Dt.certificateToPem(i),private_key_name:OB(NB(ds.get(Tc.ROOTPATH),"keys"),t),is_authority:!0,is_self_signed:!0})}if(!await q_()){let i=Um();Rt.info(`A suitable replication certificate was not found, creating new self singed cert named: ${i}`),n=n??await Nb();let o=Dt.certificateFromPem(n.ca.certificate),c=o.publicKey,l=await Cb(Dt.privateKeyFromPem(n.private_key),c,o);await cu({name:i,uses:["https","operations","wss"],certificate:l,is_authority:!1,private_key_name:n.ca.private_key_name,is_self_signed:!0})}}a(Db,"reviewSelfSignedCert");function vB(){let e=Nte(Object.keys(Ws.CONFIG_PARAM_MAP),!0),t=Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME),r=Pr.join(t,yi.PRIVATEKEY_PEM_NAME),n=Pr.join(t,yi.NATS_CERTIFICATE_PEM_NAME),s=Pr.join(t,yi.NATS_CA_PEM_NAME),i=Ws.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),yb.updateConfigValue(void 0,void 0,o,!1,!0)}a(vB,"updateConfigCert");function BB(e){return e.startsWith("-----BEGIN")?e:Pte(e,"utf8")}a(BB,"readPEM");var RB=gc.createSecureContext;gc.createSecureContext=function(e){if(!e.cert||!e.key)return RB(e);let t={...e};delete t.key,delete t.cert;let r=RB(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var HB=gc.Server;gc.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),HB.call(this,e,t)};gc.Server.prototype=HB.prototype;var qte=DB.prototype._init;DB.prototype._init=function(e,t){qte.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o.context||o,this.certCbDone()})}};var Sc=new Map;function xB(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function d(){try{r.clear(),Sc.clear();let u=0;for await(let _ of Ab.system.hdb_certificate.search([])){if(e!=="operations-api"&&_.uses?.includes?.("operations"))continue;let E=_.certificate,f=new io(E);_.is_authority&&(f.asString=E,Sc.set(f.subject,E))}for await(let _ of Ab.system.hdb_certificate.search([]))try{if(_.is_authority)continue;if(!(e==="operations-api")&&_.uses?.includes?.("operations")){no.trace("Skipping cert",_.name,"for",e,o.ports||"client","because it is for operations");continue}let f=_.is_self_signed?1:2,h=Rc.get(_.private_key_name);!h&&_.private_key_name&&(h=await us.readFile(Pr.join(ds.get(Tc.ROOTPATH),Ws.LICENSE_KEY_DIR_NAME,_.private_key_name)));let T=_.certificate,S=new io(T);if(Sc.has(S.issuer)&&(T+=`
15
+ `+Sc.get(S.issuer)),!h||!T)throw new Error("Missing private key or certificate for secure server");let R={ciphers:_.ciphers,ticketKeys:Mte(),availableCAs:Sc,ca:t&&Array.from(Sc.values()),cert:T,key:h,key_file:_.private_key_name,is_self_signed:_.is_self_signed};o&&(R.sessionIdContext=o.sessionIdContext);let p=gc.createSecureContext(R);p.name=_.name,p.options=R,p.quality=f,p.certificateAuthorities=Array.from(Sc),p.certStart=T.toString().slice(0,100);let y=_.hostnames??FB(S);Array.isArray(y)||(y=[y]);let O;for(let B of y)if(B){B[0]==="*"&&(s=!0,B=B.slice(1)),B===Ob()&&(f+=2),AB.isIP(B)&&(O=!0);let x=r.get(B)?.quality??0;f>x&&r.set(B,p)}else no.error("No hostname found for certificate at",gc.certificate);no.trace("Adding TLS",p.name,"for",o.ports||"client","cert named",_.name,"hostnames",y,"quality",f,"best quality",u),f>u&&(i.defaultContext=n=p,u=f,o&&(o.defaultContext=p))}catch(E){no.error("Error applying TLS for",_.name,E)}o?.secureContextsListeners.forEach(_=>_()),c(n)}catch(u){l(u)}}a(d,"updateTLS"),Ab.system.hdb_certificate.subscribe({listener:d,omitCurrent:!0}),d()})),i;function i(o,c){no.info("TLS requested for",o||"(no SNI)",this.isReplicationConnection);let l=o;for(;;){let u=r.get(l);if(u)return no.debug("Found certificate for",o,u.certStart),u.replicationContext&&(this.isReplicationConnection||SB)&&(u=u.replicationContext),c(null,u);if(s&&l){let _=l.indexOf(".",1);_<0?l="":l=l.slice(_)}else break}o?no.debug("No certificate found to match",o,"using the default certificate"):no.debug("No SNI, using the default certificate",n.name);let d=n;d?d.replicationContext&&(this.isReplicationConnection||SB)&&(d=d.replicationContext):no.info("No default certificate found"),c(null,d)}a(i,"SNICallback")}a(xB,"createTLSSelector");async function kB(){na();let e=[];for await(let t of Dr.search([]))e.push(t);return e}a(kB,"listCertificates");async function $te(e){let t=yB(e,so.object({name:so.string().required(),certificate:so.string().required(),is_authority:so.boolean().required(),private_key:so.string(),hosts:so.array(),uses:so.array()}));if(t)throw new F_(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new io(n),c=!1,l=!1,d;for(let[f,h]of Rc)!s&&!c&&o.checkPrivateKey(bB(h))&&(c=!0,d=f),s&&s===h&&(l=!0,d=f);if(!i&&!s&&!c)throw new F_("A suitable private key was not found for this certificate");let u;if(!r){try{u=Pb(o)}catch(f){Rt.error(f)}if(u==null)throw new F_("Error extracting certificate common name, please provide a name parameter")}let _=Vte(r??u);s&&!c&&!l&&(await us.writeFile(Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME,_+".pem"),s),Rc.set(_,s));let E={name:r??u,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&d||i&&s)&&(E.private_key_name=d??_+".pem"),await cu(E),"Successfully added certificate: "+_}a($te,"addCertificate");function Vte(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(Vte,"sanitizeName");async function Yte(e){let t=yB(e,so.object({name:so.string().required()}));if(t)throw new F_(t.message);let{name:r}=e;na();let n=await Dr.get(r);if(!n)throw new F_(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Dr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(Rt.info("Removing private key named",s),await us.remove(Pr.join(ds.getHdbBasePath(),Ws.LICENSE_KEY_DIR_NAME,s)))}return await Dr.delete(r),"Successfully removed "+r}a(Yte,"removeCertificate");function Pb(e){return e.subject.match(/CN=(.*)/)?.[1]}a(Pb,"extractCommonName");function FB(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[Pb(e)]}a(FB,"hostnamesFromCert")});async function Hb(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=at(),i;if(e.includes("wss://")){if(!Mb){let l=(0,rH.createTLSSelector)("operations-api"),d={secureContexts:null};await l.initialize(d),Mb=d.secureContexts}if(i=Mb.get(s),i&&Ee.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,sH.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,ALPNProtocols:["http/1.1","harperdb-replication"],rejectUnauthorized:n!==!1,secureContext:void 0};return n!==!1&&i&&(c.secureContext=nH.createSecureContext({...i.options,ca:Array.from(oa)})),new eH.WebSocket(e,"harperdb-replication-v1",c)}function Fm(e,t,r){let n=t.port||t.securePort,s=Bb.pid%1e3+"-"+tH.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),d=t.database,u=t.databaseSubscriptions||Ac,_,E,f=!1,h=t.subscription;h?.then&&h.then(se=>h=se);let T=t.tables||d&&mt()[d];if(!r){Ee.error?.("No authorization provided"),rs(1008,"Unauthorized");return}let S=new Map,R=[],p=r.name;p&&t.connection&&(t.connection.nodeName=p);let y,O,B,x,W,q,z=1e3,_e,X=0,ue=0;if(t.url){let se=a(()=>{W?e.terminate():(W=performance.now(),e.ping())},"send_ping");B=setInterval(se,XB).unref(),se()}else j();function j(){clearTimeout(x),x=setTimeout(()=>{Ee.warn?.(`Timeout waiting for ping from ${p}, terminating connection and reconnecting`),e.terminate()},XB*2).unref()}a(j,"resetPingTimer"),d&&$i(d);let ie,ye,Ie=[],Me=[],tn,gd=[],ka=[],yn=[],YE=150,Fa=0,zT=0,Rd,bt,es,ts,KE;e.on("message",se=>{X=performance.now();try{let Se=se.dataView=new uu(se.buffer,se.byteOffset,se.byteLength);if(se[0]>127){let k=(0,ct.decode)(se),[m,g,D]=k;switch(m){case $B:{if(g){if(p){if(p!==g){Ee.error?.(s,`Node name mismatch, expecting to connect to ${p}, but peer reported name as ${g}, disconnecting`),e.send((0,ct.encode)([lu])),rs(1008,"Node name mismatch");return}}else if(p=g,t.connection?.tentativeNode){let C=t.connection.tentativeNode;C.name=p,t.connection.tentativeNode=null,ro(p,C)}if(t.connection&&(t.connection.nodeName=p),Ee.debug?.(s,"received node name:",p,"db:",d),!d)try{$i(d=k[2]),d==="system"&&(ie=ta(t,(C,L)=>{Mo(L)&&Uo(L)}),e.on("close",()=>{ie?.remove()}))}catch(C){Ee.warn?.(s,"Error setting database",C),e.send((0,ct.encode)([lu])),rs(1008,C.message);return}Ge()}break}case zB:{Ee.debug?.(s,"Received table definitions for",g.map(C=>C.table));for(let C of g){let L=k[2];C.database=L;let F;Mo(L)&&(L==="system"?We[L]?.[C.table]||(F=Ub(C,We[L]?.[C.table])):F=Ub(C,We[L]?.[C.table]),_||(_=F?.auditStore),T||(T=mt()?.[L]))}break}case lu:rs();break;case WB:try{let C=r?.replicates||r?.subscribers||r?.name;server.operation(g,{user:r},!C).then(L=>{Array.isArray(L)&&(L={results:L}),L.requestId=g.requestId,e.send((0,ct.encode)([Bm,L]))},L=>{e.send((0,ct.encode)([Bm,{requestId:g.requestId,error:L instanceof Error?L.toString():L}]))})}catch(C){e.send((0,ct.encode)([Bm,{requestId:g.requestId,error:C instanceof Error?C.toString():C}]))}break;case Bm:let{resolve:A,reject:I}=S.get(g.requestId);g.error?I(new Error(g.error)):A(g),S.delete(g.requestId);break;case Lb:let w=k[3];T||(d?Ee.error?.(s,"No tables found for",d):Ee.error?.(s,"Database name never received"));let N=T[w];N=Ub({table:w,database:d,attributes:g.attributes,schemaDefined:g.schemaDefined},N),Ie[D]={name:w,decoder:new ct.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:g.typedStructs,structures:g.structures}),getEntry(C){return N.primaryStore.getEntry(C)},rootStore:N.primaryStore.rootStore};break;case VB:KE=_?Z0(p,g,_):new Map,tn=k[2],Ee.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${tn}`);break;case YB:let H=D;yn[H]=g;break;case QB:let U=["replicated",d,p];E||(E=new Float64Array(_.getUserSharedBuffer(U,new ArrayBuffer(8)))),E[0]=g,Ee.trace?.(s,"received and broadcasting committed update",g),E.buffer.notify();break;case jB:y=g,h.send({type:"end_txn",localTime:y,remoteNodeIds:R});break;case KB:{let C=g,L;try{let F=k[3],G=Me[D]||(Me[D]=T[k[4]]);if(!G)return Ee.warn?.("Unknown table id trying to handle record request",D);let ce=G.primaryStore.getBinaryFast(Symbol.for("structures")),re=ce.length;if(re!==zT){zT=re;let de=(0,ct.decode)(ce);e.send((0,ct.encode)([Lb,{typedStructs:de.typed,structures:de.named},D,G.tableName]))}let Te=G.primaryStore.getBinaryFast(F);if(Te){let de=G.primaryStore.decoder.decode(Te,{valueAsBuffer:!0});L=(0,ct.encode)([vm,C,{value:de.value,expiresAt:de.expiresAt,version:de.version,residencyId:de.residencyId,nodeId:de.nodeId,user:de.user}])}else L=(0,ct.encode)([vm,C])}catch(F){L=(0,ct.encode)([vm,C,{error:F.message}])}e.send(L);break}case vm:{let{resolve:C,reject:L,tableId:F,key:G}=S.get(k[1]),ce=k[2];if(ce?.error)L(new Error(ce.error));else if(ce){let re=Ie[F].decoder.decode(ce.value);ce.value=re,ce.key=G,C(ce)}else C();S.delete(k[1]);break}case qB:{ts=g;let C,L,F=!1;if(h){if(d!==h.databaseName&&!h.then){Ee.error?.("Subscription request for wrong database",d,h.databaseName);return}}else h=u.get(d);if(Ee.debug?.(s,"received subscription request for",d,"at",ts),!h){let ne;h=new Promise(we=>{Ee.debug?.("Waiting for subscription to database "+d),ne=we}),h.ready=ne,Ac.set(d,h)}if(r.name)L=Er().subscribe(r.name),L.then(async ne=>{C=ne;for await(let we of C){let nt=we.value;if(!(nt?.replicates===!0||nt?.replicates?.receives||nt?.subscriptions?.some(Xe=>(Xe.database||Xe.schema)===d&&Xe.publish!==!1))){F=!0,e.send((0,ct.encode)([lu])),rs(1008,`Unauthorized database subscription to ${d}`);return}}},ne=>{Ee.error?.(s,"Error subscribing to HDB nodes",ne)});else if(!(r?.permissions?.super_user||r.replicates)){e.send((0,ct.encode)([lu])),rs(1008,`Unauthorized database subscription to ${d}`);return}if(es&&(Ee.debug?.(s,"stopping previous subscription",d),es.emit("close")),ts.length===0)return;let G,ce=ts[0],re=a(ne=>{if(ne&&(ce.replicateByDefault?!ce.tables.includes(ne.tableName):ce.tables.includes(ne.tableName)))return G=ne,{table:ne}},"tableToTableEntry"),Te={txnTime:0},de,Oe,Z=1/0,ee,ge=a((ne,we)=>{if(Z=we,ne.type==="end_txn"){Te.txnTime&&(o[i]!==66&&Ee.error?.("Invalid encoding of message"),vo(9),vo(km),Bo(ee=we),Ke()),i=c,Te.txnTime=0;return}let nt=ne.nodeId,Xe=ne.tableId,$e=Oe[Xe];if(!$e&&($e=Oe[Xe]=re(h.tableById[Xe]),!$e))return Ee.debug?.("Not subscribed to table",Xe);let Kt=$e.table,Or=Kt.primaryStore,ii=Or.encoder;if(ne.extendedType&ph||!ii.typedStructs){let Ho=ne.getValue(Or,!0);JSON.stringify(Ho)}let qr=de[nt];if(!(qr&&qr.startTime<we&&(!qr.endTime||qr.endTime>we)))return $_&&Ee.trace?.(s,"skipping replication update",ne.recordId,"to:",p,"from:",nt,"subscribed:",de),vw();$_&&Ee.trace?.(s,"sending replication update",ne.recordId,"to:",p,"from:",nt,"subscribed:",de);let JT=ne.version;Te.txnTime!==JT&&(Te.txnTime&&($_&&Ee.trace?.(s,"new txn time, sending queued txn",Te.txnTime),o[i]!==66&&Ee.error?.("Invalid encoding of message"),Ke()),Te.txnTime=JT,i=c,Bo(JT));let Ga=ne.residencyId,XT=WE(Ga,Kt),jE;if(XT&&!XT.includes(p)){let Ho=WE(ne.previousResidencyId,Kt);if(Ho&&!Ho.includes(p)&&(ne.type==="put"||ne.type==="patch")||Kt.getResidencyById)return vw();let yd=ne.recordId;Ee.trace?.(s,"sending invalidation",yd,p,"from",nt);let tg=0;Ga&&(tg|=Ka),ne.previousResidencyId&&(tg|=Wa);let rg,QE=null;for(let Bw in Kt.indices){if(!QE){if(rg=ne.getValue(Or,!0),!rg)break;QE={}}QE[Bw]=rg[Bw]}jE=yl(ne.version,Xe,yd,null,nt,ne.user,ne.type==="put"||ne.type==="patch"?"invalidate":ne.type,ii.encode(QE),tg,Ga,ne.previousResidencyId,ne.expiresAt)}function vw(){Ee.trace?.(s,"skipping audit record",ne.recordId),q||(q=setTimeout(()=>{q=null,(ee||0)+JB/2<Z&&($_&&Ee.trace?.(s,"sending skipped sequence update",Z),e.send((0,ct.encode)([jB,Z])))},JB).unref())}a(vw,"skipAuditRecord");let ZT=ii.typedStructs,eg=ii.structures;if((ZT?.length!=$e.typed_length||eg?.length!=$e.structure_length)&&($e.typed_length=ZT?.length,$e.structure_length=eg.length,Ee.debug?.(s,"send table struct",$e.typed_length,$e.structure_length),$e.sentName||($e.sentName=!0),e.send((0,ct.encode)([Lb,{typedStructs:ZT,structures:eg,attributes:Kt.attributes,schemaDefined:Kt.schemaDefined},Xe,$e.table.tableName]))),Ga&&!ka[Ga]&&(e.send((0,ct.encode)([YB,XT,Ga])),ka[Ga]=!0),jE)vo(jE.length),bd(jE);else{let Ho=ne.encoded,yd=Ho[0]===66?8:0;vo(Ho.length-yd),bd(Ho,yd)}},"sendAuditRecord"),Ke=a(()=>{c-i>8?(e.send(o.subarray(i,c)),Ee.debug?.(s,"Sent message, size:",c-i)):Ee.debug?.(s,"skipping empty transaction")},"sendQueuedData");es=new vb.EventEmitter,es.once("close",()=>{F=!0,C?.end()});for(let{startTime:ne}of ts)ne<Z&&(Z=ne);(L||Promise.resolve()).then(async()=>{h=await h,_=h.auditStore,Oe=h.tableById.map(re),de=[];for(let{name:we,startTime:nt,endTime:Xe}of ts){let $e=wm(we,_);Ee.debug?.("subscription to",we,"using local id",$e,"starting",nt),de[$e]={startTime:nt,endTime:Xe}}Uo(d),ie||(ie=bc(we=>{we.databaseName===d&&Uo(d)}),ye=V_(we=>{we===d&&(e.send((0,ct.encode)([lu])),rs())}),e.on("close",()=>{ie?.remove(),ye?.remove()})),e.send((0,ct.encode)([VB,U_(h.auditStore),ts.map(({name:we})=>we)]));let ne=!0;do{isFinite(Z)||(Ee.warn?.("Invalid sequence id "+Z),rs(1008,"Invalid sequence id"+Z));let we;if(ne&&!F&&(ne=!1,!(xb(_)<=Z)&&server.nodes[0]?.name===p)){Ee.info?.("Replicating all tables to",p);let $e=Z,Kt=Gm(_);for(let Or in T){let ii=T[Or];for(let qr of ii.primaryStore.getRange({snapshot:!1})){if(F)return;qr.localTime>=Z&&(Ee.trace?.(s,"Copying record from",d,Or,qr.key,qr.localTime),$e=Math.max(qr.localTime,$e),we=!0,ge({recordId:qr.key,tableId:ii.tableId,type:"put",getValue(){return qr.value},encoded:ii.primaryStore.getBinary(qr.key),version:qr.version,residencyId:qr.residencyId,nodeId:Kt},qr.localTime))}}Z=$e}for(let{key:Xe,value:$e}of _.getRange({start:Z||1,exclusiveStart:!0,snapshot:!1})){if(F)return;ue=Xe;let Kt=Ht($e);ge(Kt,Xe),e._socket.writableNeedDrain&&await new Promise(Or=>e._socket.once("drain",Or)),es.startTime=Xe,we=!0}we&&ge({type:"end_txn"},Z);let nt=Hm.get(G);nt||Hm.set(G,nt=[]),nt.push(Xe=>{}),ue=0,await aB(_)}while(!F)}).catch(ne=>{Ee.error?.(s,"Error handling subscription to node",ne),rs(1008,"Error handling subscription to node")});break}}return}Se.position=8;let rt=!0,Re,ft;do{let k=Se.readInt();if(k===9&&Se.getUint8(Se.position)==km){Se.position++,y=ft=Se.readFloat64(),Ee.trace?.("received remote sequence update",y,d);break}let m=Se.position,g=Ht(se,m,m+k),D=Ie[g.tableId];D||Ee.error?.(`No table found with an id of ${g.tableId}`);let A;g.residencyId&&(A=yn[g.residencyId],Ee.trace?.(s,"received residency list",A,g.type,g.recordId)),Re={table:D.name,id:g.recordId,type:g.type,nodeId:KE.get(g.nodeId),residencyList:A,timestamp:g.version,value:g.getValue(D),user:g.user,beginTxn:rt,expiresAt:g.expiresAt},rt=!1,$_&&Ee.trace?.(s,"received replication message",g.type,"id",Re.id,"version",g.version,"nodeId",Re.nodeId,"value",Re.value),h.send(Re),Se.position=m+k}while(Se.position<se.byteLength);Fa++,gr(se.byteLength,"bytes-received",p+"."+d+"."+Re.table,"replication","ingest"),Fa>YE&&!Rd&&(Rd=!0,e.pause()),h.send({type:"end_txn",localTime:y,remoteNodeIds:R,onCommit(){if(Re){let k=Date.now()-Re.timestamp;gr(k,"replication-latency",p+"."+d+"."+Re.table,Re.type,"ingest")}Fa--,Rd&&(Rd=!1,e.resume()),!O&&ft&&(Ee.trace?.(s,"queuing confirmation of a commit at",ft),setTimeout(()=>{e.send((0,ct.encode)([QB,O])),Ee.trace?.(s,"sent confirmation of a commit at",O),O=null},Kte)),O=ft}})}catch(Se){Ee.error?.(s,"Error handling incoming replication message",Se)}}),e.on("ping",j),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-W,pc({name:p,database:d,url:t.url,lastSendTime:ue,latency:t.connection.latency})),W=null}),e.on("close",(se,Se)=>{clearInterval(B),clearTimeout(x),es&&es.emit("close"),bt&&bt.end();for(let[rt,{reject:Re}]of S)Re(new Error(`Connection closed ${Se?.toString()} ${se}`));Ee.debug?.(s,"closed",se,Se?.toString())});function Uw(){}a(Uw,"recordRemoteNodeSequence");function rs(se,Se){e.isFinished=!0,e.close(se,Se)}a(rs,"close");function Ge(){if(f||(f=!0,t.connection?.on("subscriptions-updated",Ge)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let se=new Map;try{for(let Re of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let ft of Re.value.nodes||[])ft.seqId>(se.get(ft.id)??0)&&se.set(ft.id,ft.seqId)}catch(Re){if(!Re.message.includes("Can not re"))throw Re}let Se=t.connection?.nodeSubscriptions?.[0];R=[];let rt=t.connection?.nodeSubscriptions.map((Re,ft)=>{let k=[],{replicateByDefault:m}=Re;if(Re.subscriptions){for(let I of Re.subscriptions)if(I.subscribe&&(I.schema||I.database)===d){let w=I.table;T?.[w]?.replicate!==!1&&k.push(w)}m=!1}else for(let I in T)(m?T[I].replicate===!1:T[I].replicate)&&k.push(I);let g=_&&wm(Re.name,_),D=h?.dbisDB?.get([Symbol.for("seq"),g])??1,A=Math.max(D?.seqId??1,(typeof Re.start_time=="string"?new Date(Re.start_time).getTime():Re.start_time)??1);if(Ee.debug?.("Starting time recorded in db",Re.name,g,d,D?.seqId,"start time:",A),Se!==Re){A>5e3&&(A-=5e3);let I=_&&wm(Se.name,_),w=h?.dbisDB?.get([Symbol.for("seq"),I])??1;for(let N of w?.nodes||[])N.name===Re.name&&(A=N.seqId,Ee.debug?.("Using sequence id from proxy node",Se.name,A))}return R.push(g),se.get(g)>A&&(A=se.get(g),Ee.debug?.("Updating start time from more recent txn recorded",Se.name,A)),{name:Re.name,replicateByDefault:m,tables:k,startTime:A,endTime:Re.end_time}});if(rt)if(Ee.debug?.(s,"sending subscription request",rt,h?.dbisDB?.path),clearTimeout(_e),rt.length>0)e.send((0,ct.encode)([qB,rt]));else{let Re=a(()=>{let ft=performance.now();_e=setTimeout(()=>{X<=ft?rs(1008,"No nodes to subscribe to"):Re()},z)},"schedule_close");Re()}}a(Ge,"sendSubscriptionRequestUpdate");function WE(se,Se){if(!se)return;let rt=gd[se];return rt||(rt=Se.getResidencyRecord(se),gd[se]=rt),rt}a(WE,"getResidence");function Mo(se){return!(ia&&ia!="*"&&!ia[se]&&!ia.includes?.(se)&&!ia.some?.(Se=>Se.name===se))}a(Mo,"checkDatabaseAccess");function $i(se){if(h=h||u.get(se),!Mo(se))throw new Error(`Access to database "${se}" is not permitted`);h||Ee.warn?.(`No database named "${se}" was declared and registered`),_=h?.auditStore,T||(T=mt()?.[se]);let Se=at();if(Se===p)throw Se?new Error("Should not connect to self",Se):new Error("Node name not defined");return Ad(Se,se),!0}a($i,"setDatabase");function Ad(se,Se){let rt=mt()?.[Se],Re=[];for(let ft in rt){let k=rt[ft];Re.push({table:ft,schemaDefined:k.schemaDefined,attributes:k.attributes.map(m=>({name:m.name,type:m.type,isPrimaryKey:m.isPrimaryKey}))})}Ee.trace?.("Sending database info for node",se,"database name",Se),e.send((0,ct.encode)([$B,se,Se,Re]))}a(Ad,"sendNodeDBName");function Uo(se){let Se=mt()?.[se],rt=[];for(let Re in Se){if(ts&&!ts.some(k=>k.replicateByDefault?!k.tables.includes(Re):k.tables.includes(Re)))continue;let ft=Se[Re];rt.push({table:Re,schemaDefined:ft.schemaDefined,attributes:ft.attributes.map(k=>({name:k.name,type:k.type,isPrimaryKey:k.isPrimaryKey}))})}e.send((0,ct.encode)([zB,rt,se]))}a(Uo,"sendDBSchema");let Tl=1,Gr=[];return{end(){bt&&bt.end(),es&&es.emit("close")},getRecord(se){let Se=Tl++;return new Promise((rt,Re)=>{let ft=[KB,Se,se.table.tableId,se.id];Gr[se.table.tableId]||(ft.push(se.table.tableName),Gr[se.table.tableId]=!0),e.send((0,ct.encode)(ft)),S.set(Se,{tableId:se.table.tableId,key:se.id,resolve(k){let{table:m,entry:g}=se;rt(k),k&&m._recordRelocate(g,k)},reject:Re})})},sendOperation(se){let Se=Tl++;return se.requestId=Se,e.send((0,ct.encode)([WB,se])),new Promise((rt,Re)=>{S.set(Se,{resolve:rt,reject:Re})})}};function vo(se){gl(5),se<128?o[c++]=se:se<16384?(l.setUint16(c,se|32768),c+=2):se<1056964608?(l.setUint32(c,se|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,se),c+=5)}function bd(se,Se=0,rt=se.length){let Re=rt-Se;gl(Re),se.copy(o,c,Se,rt),c+=Re}function Bo(se){gl(8),l.setFloat64(c,se),c+=8}function gl(se){if(se+16>o.length-c){let Se=Buffer.allocUnsafeSlow(c+se-i+65536>>10<<11);o.copy(Se,0,i,c),c=c-i,i=0,o=Se,l=new DataView(o.buffer,0,o.length)}}}function Ub(e,t){let r=e.database??"data";if(r!=="data"&&!We[r]){Ee.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(Ee.debug?.("(Re)creating",e),Et({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var ct,eH,tH,Ee,vb,rH,nH,Bb,sH,qB,$B,VB,lu,YB,Lb,KB,vm,WB,Bm,jB,QB,zB,Hm,Ac,$_,JB,Kte,XB,Mb,ZB,xm,iH=De(()=>{Le();Ki();Eb();Tb();ls();Ol();ct=require("msgpackr"),eH=require("ws"),tH=require("worker_threads"),Ee=v(zl());k_();vb=require("events"),rH=v(js()),nH=v(require("node:tls"));nu();Bb=v(require("node:process")),sH=require("node:net");gi();qB=129,$B=140,VB=141,lu=142,YB=130,Lb=132,KB=133,vm=134,WB=136,Bm=137,jB=143,QB=144,zB=145,Hm=new Map,Ac=new Map,$_=!0,JB=300,Kte=2,XB=3e4;a(Hb,"createWebSocket");ZB=1e3,xm=class extends vb.EventEmitter{constructor(r,n,s){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=bi(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=ZB;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;nodeName;async connect(){this.session||this.resetSession();let r=[];this.socket=await Hb(this.url,{serverName:this.nodeName});let n;Ee.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${Bb.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),Ee.info?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=ZB,pc({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=Fm(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(Ee.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?Ee.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):Ee.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(ou({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();Ee.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(Fm,"replicateOverWS");a(Ub,"ensureTableIfChanged")});var sa={};et(sa,{clearThisNodeName:()=>Zte,disableReplication:()=>Qte,enabled_databases:()=>ia,forEachReplicatedDatabase:()=>ta,getThisNodeId:()=>Gm,getThisNodeName:()=>at,getThisNodeUrl:()=>ra,hostnameToUrl:()=>Vm,lastTimeInAuditStore:()=>v_,monitorNodeCAs:()=>EH,replicateOperation:()=>tre,replication_certificate_authorities:()=>oa,sendOperationToNode:()=>W_,servers:()=>fH,setReplicator:()=>mH,start:()=>jte,startOnMainThread:()=>Rb,subscribeToNode:()=>iu,unsubscribeFromNode:()=>Lm,urlToNodeName:()=>bi});function jte(e){if(e.port||(e.port=_s.default.get(yc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=_s.default.get(yc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!at())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of x_(e))t.set(bi(n.url),n);zte(e),e={subProtocol:"harperdb-replication-v1",mtls:!0,isOperationsServer:!0,...e};let r=st.ws(async(n,s,i)=>{await i,n._socket.unref(),Fm(n,e,s?.user),n.on("error",o=>{o.code!=="ECONNREFUSED"&&hr.error("Error in connection to "+this.url,o.message)})},e);e.runFirst=!0,st.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&hr.error(`Incoming client connection from ${n.ip} did not have valid certificate `,n._nodeRequest.socket.authorizationError);let i=Er().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));c?n.user=c:hr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:hr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(fH.push(n),n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(oa);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.replicationContext=K_.createSecureContext(l)}catch(c){hr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),EH(s)}}function EH(e){let t=0;ru(r=>{if(r?.ca){if(oa.add(r.ca),oa.size!==t)t=oa.size,e?.();else if(_s.default.get(yc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1)for(let n of K_.rootCertificates)oa.add(n)}})}function Qte(e=!0){_H=e}function zte(e){_H||(mt(),ia=e.databases,ta(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Ac;for(let[s,i]of Y_){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];mH(r,s,e),Hm.get(s)?.forEach(i=>i(s))}}))}function mH(e,t,r){if(!t)return console.error(`Attempt to replicate non-existent table ${t.name} from database ${e}`);if(t.replicate===!1||t.sources?.some(s=>s.isReplicator))return;let n;t.sourcedFrom(class hH extends Ir{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Ac,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(hr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new In,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,d=new Set;do{let u;for(let E of c){let f=Jte(E,hH.subscription,e);f?.isConnected&&!d.has(f)&&(!u||f.latency<u.latency)&&(u=f)}if(!u)throw l||new uH.ServerError("No connection to any other nodes are available",502);let _={requestId:Wte++,table:t,entry:i,id:i.key};d.add(u);try{return await u.getRecord(_)}catch(E){if(u.isConnected)throw E;hr.warn("Error in load from node",$m,E),l||(l=E)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function pH(e,t,r){let n=Y_.get(e);n||Y_.set(e,n=new Map);let s=n.get(r);if(s)return s;if(t)return n.set(r,s=new xm(e,t,r)),s.connect(),s.once("finished",()=>n.delete(r)),s}function Jte(e,t,r){let n=oH.get(e)?.get(r);if(n)return n;let s=Er().primaryStore.get(e);return s?.url&&(n=pH(s.url,t,r),oH.set(e,Y_.get(s.url))),n}async function W_(e,t,r){r||(r={}),r.serverName=e.name;let n=await Hb(e.url,r),s=Fm(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{hr.error("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function iu(e){try{dH.isMainThread&&hr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Ac.get(e.database);if(!t){let n;t=new Promise(s=>{hr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Ac.set(e.database,t)}let r=pH(e.nodes[0].url,t,e.database);e.nodes[0].name===void 0&&(r.tentativeNode=e.nodes[0]),r.subscribe(e.nodes.filter(n=>H_(n,e.database)),e.replicateByDefault)}catch(t){hr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Lm({name:e,url:t,database:r}){hr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(Er().primaryStore.getRange({})));let n=Y_.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Xte(){if(kb!==void 0)return kb;let e=_s.default.get(yc.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||_s.default.get(yc.CONFIG_PARAMS.TLS_CERTIFICATE);if(e)return kb=new cH.X509Certificate((0,lH.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function at(){return $m||($m=_s.default.get("replication_hostname")??bi(_s.default.get("replication_url"))??Xte()??aH("operationsapi_network_secureport")??aH("operationsapi_network_port")??"127.0.0.1")}function Zte(){$m=void 0}function aH(e){let t=_s.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function qm(e){let t=_s.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Gm(e){return U_(e)?.[at()]}function ra(){let e=_s.default.get("replication_url");return e||Vm(at())}function Vm(e){let t=qm("replication_port");if(t)return`ws://${e}:${t}`;if(t=qm("replication_secureport"),t)return`wss://${e}:${t}`;if(t=qm("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=qm("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function bi(e){if(e)return new URL(e).hostname}function ta(e,t){for(let n of Object.getOwnPropertyNames(We))r(n);return V_(n=>{r(n)}),bc((n,s)=>{r(n.databaseName)});function r(n){let s=We[n];hr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):ere(n)&&t(s,n,!1)}a(r,"forDatabase")}function ere(e){let t=We[e];for(let r in t)if(t[r].replicate)return!0}function v_(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function tre(e){let t={message:""};if(e.replicated){e.replicated=!1,hr.trace?.("Replicating operation",e,"to nodes",st.nodes.map(n=>n.name));let r=await Promise.allSettled(st.nodes.map(n=>W_(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=st.nodes[s]?.name,i})}return t}var _s,hr,cH,lH,yc,K_,uH,dH,_H,Wte,fH,oa,ia,Y_,oH,kb,$m,ls=De(()=>{Le();Hs();Al();iH();$r();_s=v(te()),hr=v(V()),cH=require("crypto"),lH=require("fs");k_();nu();yc=v(M());Eb();K_=v(require("node:tls")),uH=v(fe()),dH=require("worker_threads"),Wte=1,fH=[],oa=_s.default.get(yc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)===!0?new Set(K_.rootCertificates):new Set;a(jte,"start");a(EH,"monitorNodeCAs");a(Qte,"disableReplication");a(zte,"assignReplicationSource");a(mH,"setReplicator");Y_=new Map;a(pH,"getConnection");oH=new Map;a(Jte,"getConnectionByName");a(W_,"sendOperationToNode");a(iu,"subscribeToNode");a(Lm,"unsubscribeFromNode");a(Xte,"getCommonNameFromCert");a(at,"getThisNodeName");a(Zte,"clearThisNodeName");Object.defineProperty(st,"hostname",{get(){return at()}});a(aH,"getHostFromListeningPort");a(qm,"getPortFromListeningPort");a(Gm,"getThisNodeId");st.replication={getThisNodeId:Gm,exportIdMapping:U_};a(ra,"getThisNodeUrl");a(Vm,"hostnameToUrl");a(bi,"urlToNodeName");a(ta,"forEachReplicatedDatabase");a(ere,"hasExplicitlyReplicatedTable");a(v_,"lastTimeInAuditStore");a(tre,"replicateOperation")});var j_=b((NIe,AH)=>{"use strict";var du=Nh(),_u=s0(),rre=V(),nre=require("uuid").v4,OIe=require("clone"),Km=Ji(),fu=M(),sre=require("util"),aa=Pn(),{handleHDBError:dn,hdb_errors:ire}=fe(),{HDB_ERROR_MSGS:Ym,HTTP_STATUS_CODES:_n}=ire,{SchemaEventMsg:Wm}=Gs(),SH=kt(),{getDatabases:ore}=(Le(),oe(lt)),{transformReq:Eu}=J(),{replicateOperation:TH}=(ls(),oe(sa));AH.exports={createSchema:are,createSchemaStructure:gH,createTable:cre,createTableStructure:RH,createAttribute:fre,dropSchema:lre,dropTable:ure,dropAttribute:dre,getBackup:Ere};async function are(e){let t=await gH(e);return Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema)),t}a(are,"createSchema");async function gH(e){let t=du.schema_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);if(Eu(e),!await _u.checkSchemaExists(e.schema))throw dn(new Error,Ym.SCHEMA_EXISTS_ERR(e.schema),_n.BAD_REQUEST,fu.LOG_LEVELS.ERROR,Ym.SCHEMA_EXISTS_ERR(e.schema),!0);return await aa.createSchema(e),`database '${e.schema}' successfully created`}a(gH,"createSchemaStructure");async function cre(e){return Eu(e),e.hash_attribute=e.primary_key??e.hash_attribute,await RH(e)}a(cre,"createTable");async function RH(e){let t=du.create_table_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);if(du.validateTableResidence(e.residence),!await _u.checkSchemaTableExists(e.schema,e.table))throw dn(new Error,Ym.TABLE_EXISTS_ERR(e.schema,e.table),_n.BAD_REQUEST,fu.LOG_LEVELS.ERROR,Ym.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:nre(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await aa.createTable(n,e);else throw dn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",_n.BAD_REQUEST);else await aa.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(RH,"createTableStructure");async function lre(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=du.schema_object(e),n=t??r;if(n)throw dn(n,n.message,_n.BAD_REQUEST,void 0,void 0,!0);Eu(e);let s=await _u.checkSchemaExists(e.schema);if(s)throw dn(new Error,s,_n.NOT_FOUND,fu.LOG_LEVELS.ERROR,s,!0);let i=await _u.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await aa.dropSchema(e),Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema)),await SH.purgeSchemaTableStreams(e.schema,o);let c=await TH(e);return c.message=`successfully deleted '${e.schema}'`,c}a(lre,"dropSchema");async function ure(e){let t=du.table_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);Eu(e);let r=await _u.checkSchemaTableExists(e.schema,e.table);if(r)throw dn(new Error,r,_n.NOT_FOUND,fu.LOG_LEVELS.ERROR,r,!0);await aa.dropTable(e),await SH.purgeTableStream(e.schema,e.table);let n=await TH(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(ure,"dropTable");async function dre(e){let t=du.attribute_object(e);if(t)throw dn(t,t.message,_n.BAD_REQUEST,void 0,void 0,!0);Eu(e);let r=await _u.checkSchemaTableExists(e.schema,e.table);if(r)throw dn(new Error,r,_n.NOT_FOUND,fu.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw dn(new Error,"You cannot drop a hash attribute",_n.BAD_REQUEST,void 0,void 0,!0);if(fu.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw dn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,_n.BAD_REQUEST,void 0,void 0,!0);try{return await aa.dropAttribute(e),_re(e),Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw rre.error(`Got an error deleting attribute ${sre.inspect(e)}.`),n}}a(dre,"dropAttribute");function _re(e){let t=Object.values(global.hdb_schema[e.schema][e.table].attributes);for(let r=0;r<t.length;r++)t[r].attribute===e.attribute&&global.hdb_schema[e.schema][e.table].attributes.splice(r,1)}a(_re,"dropAttributeFromGlobal");async function fre(e){Eu(e);let t=ore()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw dn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,_n.BAD_REQUEST,void 0,void 0,!0);return await aa.createAttribute(e),Km.signalSchemaChange(new Wm(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(fre,"createAttribute");function Ere(e){return aa.getBackup(e)}a(Ere,"getBackup")});var yH=b((wIe,bH)=>{"use strict";var{OPERATIONS_ENUM:hre}=M(),Fb=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=hre.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};bH.exports=Fb});var Gb=b((PIe,CH)=>{"use strict";var mre=Pn(),DIe=yH(),jm=J(),Qm=M(),pre=te(),{handleHDBError:OH,hdb_errors:Sre}=fe(),{HDB_ERROR_MSGS:NH,HTTP_STATUS_CODES:IH}=Sre,Tre=Object.values(Qm.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),wH="To use this operation audit log must be enabled in harperdb-config.yaml";CH.exports=gre;async function gre(e){if(jm.isEmpty(e.schema))throw new Error(NH.SCHEMA_REQUIRED_ERR);if(jm.isEmpty(e.table))throw new Error(NH.TABLE_REQUIRED_ERR);if(!pre.get(Qm.CONFIG_PARAMS.LOGGING_AUDITLOG))throw OH(new Error,wH,IH.BAD_REQUEST,Qm.LOG_LEVELS.ERROR,wH,!0);let t=jm.checkSchemaTableExist(e.schema,e.table);if(t)throw OH(new Error,t,IH.NOT_FOUND,Qm.LOG_LEVELS.ERROR,t,!0);if(!jm.isEmpty(e.search_type)&&Tre.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await mre.readAuditLog(e)}a(gre,"readAuditLog")});var PH=b((MIe,DH)=>{"use strict";var{OPERATIONS_ENUM:Rre}=M(),qb=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Rre.GET_BACKUP,this.schema=t,this.table=r}};DH.exports=qb});var UH=b((HIe,MH)=>{"use strict";var Are=Pn(),vIe=PH(),$b=J(),bre=M(),BIe=te(),{handleHDBError:yre,hdb_errors:Ore}=fe(),{HDB_ERROR_MSGS:LH,HTTP_STATUS_CODES:Nre}=Ore;MH.exports=Ire;async function Ire(e){if($b.isEmpty(e.schema))throw new Error(LH.SCHEMA_REQUIRED_ERR);if($b.isEmpty(e.table))throw new Error(LH.TABLE_REQUIRED_ERR);let t=$b.checkSchemaTableExist(e.schema,e.table);if(t)throw yre(new Error,t,Nre.NOT_FOUND,bre.LOG_LEVELS.ERROR,t,!0);return await Are.getBackup(read_audit_log_object)}a(Ire,"getBackup")});var FH=b((kIe,kH)=>{var ca=require("validate.js"),BH=ut(),hu=M(),{handleHDBError:wre,hdb_errors:Cre}=fe(),{HDB_ERROR_MSGS:zt,HTTP_STATUS_CODES:Dre}=Cre,Vb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Pre={STRUCTURE_USER:"structure_user"},vH=Object.values(hu.ROLE_TYPES_ENUM),Lre="attribute_permissions",Mre="attribute_name",{PERMS_CRUD_ENUM:mu}=hu,Ure=[Lre,...Object.values(mu)],HH=[mu.READ,mu.INSERT,mu.UPDATE],vre=[Mre,...HH];function Bre(e){let t=Vb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,xH(e,t)}a(Bre,"addRoleValidation");function Hre(e){let t=Vb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,xH(e,t)}a(Hre,"alterRoleValidation");function xre(e){let t=Vb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,BH.validateObject(e,t)}a(xre,"dropRoleValidation");var kre=["operation","role","id","permission","hdb_user","hdb_auth_header"];function xH(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)kre.includes(n[o])||s.push(n[o]);s.length>0&&sr(zt.INVALID_ROLE_JSON_KEYS(s),r);let i=BH.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{sr(o,r)}),e.permission){let o=Fre(e);o&&sr(o,r),vH.forEach(c=>{e.permission[c]&&!ca.isBoolean(e.permission[c])&&sr(zt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(vH.indexOf(o)<0){if(o===Pre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let d=0,u=l.length;d<u;d++){let _=l[d];global.hdb_schema[_]||sr(zt.SCHEMA_NOT_FOUND(_),r)}continue}sr(zt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){sr(zt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let d=c.tables[l];if(!l||!global.hdb_schema[o][l]){sr(zt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(d).forEach(u=>{Ure.includes(u)||sr(zt.INVALID_PERM_KEY(u),r,o,l)}),Object.values(mu).forEach(u=>{ca.isDefined(d[u])?ca.isBoolean(d[u])||sr(zt.TABLE_PERM_NOT_BOOLEAN(u),r,o,l):sr(zt.TABLE_PERM_MISSING(u),r,o,l)}),ca.isDefined(d.attribute_permissions)){if(!ca.isArray(d.attribute_permissions)){sr(zt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}}else{sr(zt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}if(d.attribute_permissions){let u=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),_={read:!1,insert:!1,update:!1};for(let E in d.attribute_permissions){let f=d.attribute_permissions[E];if(Object.keys(f).forEach(T=>{!vre.includes(T)&&T!==mu.DELETE&&sr(zt.INVALID_ATTR_PERM_KEY(T),r,o,l)}),!ca.isDefined(f.attribute_name)){sr(zt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!u.includes(h)){sr(zt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}HH.forEach(T=>{ca.isDefined(f[T])?ca.isBoolean(f[T])||sr(zt.ATTR_PERM_NOT_BOOLEAN(T,h),r,o,l):sr(zt.ATTR_PERM_MISSING(T,h),r,o,l)}),!_.read&&f.read===!0&&(_.read=!0),!_.insert&&f.insert===!0&&(_.insert=!0),!_.update&&f.update===!0&&(_.update=!0)}if(d.read===!1&&_.read===!0||d.insert===!1&&_.insert===!0||d.update===!1&&_.update===!0){let E=`${o}.${l}`;sr(zt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return Gre(r)}a(xH,"customValidate");kH.exports={addRoleValidation:Bre,alterRoleValidation:Hre,dropRoleValidation:xre};function Fre(e){let{operation:t,permission:r}=e;if(t===hu.OPERATIONS_ENUM.ADD_ROLE||t===hu.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return zt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?hu.ROLE_TYPES_ENUM.SUPER_USER:hu.ROLE_TYPES_ENUM.CLUSTER_USER;return zt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Fre,"validateNoSUPerms");function Gre(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:zt.ROLE_PERMS_ERROR,...e};return wre(new Error,n,Dre.BAD_REQUEST)}else return null}a(Gre,"generateRolePermResponse");function sr(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(sr,"addPermError")});var Jm=b((qIe,VH)=>{"use strict";var GH=Yr(),qH=Vr(),qre=Wo(),Kb=FH(),Wb=Ji(),GIe=require("uuid").v4,$re=require("util"),zm=M(),Vre=J(),jb=qH.searchByValue,Yre=qH.searchByHash,Kre=$re.promisify(qre.delete),Wre=qs(),jre=Fl(),{hdb_errors:Qre,handleHDBError:Oc}=fe(),{HDB_ERROR_MSGS:$H,HTTP_STATUS_CODES:Q_}=Qre,{UserEventMsg:Qb}=Gs();VH.exports={addRole:zre,alterRole:Jre,dropRole:Xre,listRoles:Zre};function Yb(e){try{e.hdb_auth_header&&delete e.hdb_auth_header,e.HDB_INTERNAL_PATH&&delete e.HDB_INTERNAL_PATH,e.operation&&delete e.operation,e.hdb_user&&delete e.hdb_user}catch{}return e}a(Yb,"scrubRoleDetails");async function zre(e){let t=Kb.addRoleValidation(e);if(t)throw t;e=Yb(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await jb(r)||[])}catch(i){throw Oc(i)}if(n&&n.length>0)throw Oc(new Error,$H.ROLE_ALREADY_EXISTS(e.role),Q_.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await GH.insert(s),Wb.signalUserChange(new Qb(process.pid)),e=Yb(e),e}a(zre,"addRole");async function Jre(e){let t=Kb.alterRoleValidation(e);if(t)throw t;e=Yb(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await GH.update(r)}catch(s){throw Oc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Oc(new Error,"Invalid role id",Q_.BAD_REQUEST,void 0,void 0,!0);return await Wb.signalUserChange(new Qb(process.pid)),e}a(Jre,"alterRole");async function Xre(e){let t=Kb.dropRoleValidation(e);if(t)throw Oc(new Error,t,Q_.BAD_REQUEST,void 0,void 0,!0);let r=new jre(zm.SYSTEM_SCHEMA_NAME,zm.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Yre(r));if(n.length===0)throw Oc(new Error,$H.ROLE_NOT_FOUND,Q_.NOT_FOUND,void 0,void 0,!0);let s=new Wre(zm.SYSTEM_SCHEMA_NAME,zm.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await jb(s)),o=!1;if(Vre.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Oc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,Q_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Kre(c),Wb.signalUserChange(new Qb(process.pid)),`${n[0].role} successfully deleted`}a(Xre,"dropRole");async function Zre(){return jb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Zre,"listRoles")});var jH=b((VIe,WH)=>{"use strict";var ene=te(),la=require("joi"),tne=ut(),YH=require("moment"),rne=require("fs-extra"),zb=require("path"),nne=require("lodash"),z_=M(),{LOG_LEVELS:Nc}=M(),sne="YYYY-MM-DD hh:mm:ss",ine=zb.resolve(__dirname,"../logs");WH.exports=function(e){return tne.validateBySchema(e,one)};var one=la.object({from:la.custom(KH),until:la.custom(KH),level:la.valid(Nc.NOTIFY,Nc.FATAL,Nc.ERROR,Nc.WARN,Nc.INFO,Nc.DEBUG,Nc.TRACE),order:la.valid("asc","desc"),limit:la.number().min(1),start:la.number().min(0),log_name:la.custom(ane)});function KH(e,t){if(YH(e,YH.ISO_8601).format(sne)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(KH,"validateDatetime");function ane(e,t){if(nne.invert(z_.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=ene.get(z_.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?z_.LOG_NAMES.HDB:e,i=s===z_.LOG_NAMES.INSTALL?zb.join(ine,z_.LOG_NAMES.INSTALL):zb.join(n,s);return rne.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(ane,"validateReadLogPath")});var Xb=b((KIe,zH)=>{"use strict";var Xm=M(),cne=V(),lne=te(),une=jH(),Jb=require("path"),QH=require("fs-extra"),{once:dne}=require("events"),{handleHDBError:_ne,hdb_errors:fne}=fe(),{PACKAGE_ROOT:Ene}=M(),hne=Jb.join(Ene,"logs"),mne=1e3,pne=200;zH.exports=Sne;async function Sne(e){let t=une(e);if(t)throw _ne(t,t.message,fne.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=lne.get(Xm.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Xm.LOG_NAMES.HDB:e.log_name,s=n===Xm.LOG_NAMES.INSTALL?Jb.join(hne,Xm.LOG_NAMES.INSTALL):Jb.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,d=e.until!==void 0,u=d?new Date(e.until):void 0,_=e.limit===void 0?mne:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+_,T=0;E==="desc"&&!l&&!u&&(T=Math.max(QH.statSync(s).size-(h+5)*pne,0));let S=QH.createReadStream(s,{start:T});S.on("error",x=>{cne.error(x)});let R=0,p=[],y="",O;S.on("data",x=>{let W=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;x=y+x;let q=0,z;for(;(z=W.exec(x))&&!S.destroyed;){O&&(O.message=x.slice(q,z.index),B(O));let[_e,X,ue]=z,j=ue.split("] ["),ie=j[0],ye=j[1];j.splice(0,2),O={timestamp:X,thread:ie,level:ye,tags:j,message:""},q=z.index+_e.length}y=x.slice(q)}),S.on("end",x=>{S.destroyed||O&&(O.message=y.trim(),B(O))}),S.resume();function B(x){let W,q,z;switch(!0){case(i&&c&&d):W=new Date(x.timestamp),q=new Date(l),z=new Date(u),x.level===o&&W>=q&&W<=z&&R<f?R++:x.level===o&&W>=q&&W<=z&&(ua(x,E,p),R++,R===h&&S.destroy());break;case(i&&c):W=new Date(x.timestamp),q=new Date(l),x.level===o&&W>=q&&R<f?R++:x.level===o&&W>=q&&(ua(x,E,p),R++,R===h&&S.destroy());break;case(i&&d):W=new Date(x.timestamp),z=new Date(u),x.level===o&&W<=z&&R<f?R++:x.level===o&&W<=z&&(ua(x,E,p),R++,R===h&&S.destroy());break;case(c&&d):W=new Date(x.timestamp),q=new Date(l),z=new Date(u),W>=q&&W<=z&&R<f?R++:W>=q&&W<=z&&(ua(x,E,p),R++,R===h&&S.destroy());break;case i:x.level===o&&R<f?R++:x.level===o&&(ua(x,E,p),R++,R===h&&S.destroy());break;case c:W=new Date(x.timestamp),q=new Date(l),W>=q&&R<f?R++:W>=q&&R>=f&&(ua(x,E,p),R++,R===h&&S.destroy());break;case d:W=new Date(x.timestamp),z=new Date(u),W<=z&&R<f?R++:W<=z&&R>=f&&(ua(x,E,p),R++,R===h&&S.destroy());break;default:R<f?R++:(ua(x,E,p),R++,R===h&&S.destroy())}}return a(B,"onLogMessage"),await dne(S,"close"),p}a(Sne,"readLog");function ua(e,t,r){t==="desc"?Tne(e,r):t==="asc"?gne(e,r):r.push(e)}a(ua,"pushLineToResult");function Tne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(Tne,"insertDescending");function gne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(gne,"insertAscending")});var Zm=b((XIe,ex)=>{"use strict";var Zb=require("joi"),{string:pu,boolean:JH,date:Rne}=Zb.types(),Ane=ut(),{validateSchemaExists:jIe,validateTableExists:QIe,validateSchemaName:zIe}=di(),bne=M(),yne=dt(),XH=te();XH.initSync();var JIe=pu.invalid(XH.get(bne.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(yne.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),ZH={operation:pu.valid("add_node","update_node","set_node_replication"),node_name:pu.optional(),subscriptions:Zb.array().items({table:pu.optional(),schema:pu.optional(),database:pu.optional(),subscribe:JH.required(),publish:JH.required().custom(Nne),start_time:Rne.iso()})};function One(e){return Ane.validateBySchema(e,Zb.object(ZH))}a(One,"addUpdateNodeValidator");function Nne(e,t){if(t.state.ancestors[2].operation==="add_node"&&e===!1&&t.state.ancestors[0].subscribe===!1)return t.message(`'subscriptions[${t.state.path[1]}]' subscribe and/or publish must be set to true when adding a node`)}a(Nne,"checkForFalsy");ex.exports={addUpdateNodeValidator:One,validation_schema:ZH}});var rx=b((ewe,tx)=>{var Ine=ut(),wne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};tx.exports=function(e){return Ine.validateObject(e,wne)}});var J_=b((twe,nx)=>{"use strict";var Cne=M().OPERATIONS_ENUM,ey=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Cne.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};nx.exports=ey});var ix=b((nwe,sx)=>{"use strict";var Dne={OPERATION:"operation",REFRESH:"refresh"},ty=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},ry=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};sx.exports={JWTTokens:ty,TOKEN_TYPE_ENUM:Dne,JWTRSAKeys:ry}});var ef=b((iwe,lx)=>{"use strict";var Z_=require("jsonwebtoken"),ny=require("fs-extra"),sy=J(),Es=M(),{handleHDBError:fn,hdb_errors:Pne}=fe(),{HTTP_STATUS_CODES:En,AUTHENTICATION_ERROR_MSGS:hn}=Pne,X_=V(),ox=Hh(),ay=vn(),Lne=Yr().update,Mne=J_(),Une=Ji(),{UserEventMsg:vne}=Gs(),da=te();da.initSync();var iy=require("path"),{JWTTokens:Bne,JWTRSAKeys:Hne,TOKEN_TYPE_ENUM:ep}=ix(),xne=da.get(Es.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?da.get(Es.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",kne=da.get(Es.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?da.get(Es.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",tp="RS256",oy;lx.exports={createTokens:Fne,validateOperationToken:qne,refreshOperationToken:Gne,validateRefreshToken:cx};async function Fne(e){if(sy.isEmpty(e)||typeof e!="object")throw fn(new Error,hn.INVALID_AUTH_OBJECT,En.BAD_REQUEST,void 0,void 0,!0);if(sy.isEmpty(e.username))throw fn(new Error,hn.USERNAME_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);if(sy.isEmpty(e.password))throw fn(new Error,hn.PASSWORD_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await ay.findAndValidateUser(e.username,e.password),!t)throw fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw X_.error(E),fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}let r=await rp(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await ax(i,r.private_key,r.passphrase),c=await Z_.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:kne,algorithm:tp,subject:ep.REFRESH}),l=ox.hash(c),d=new Mne(Es.SYSTEM_SCHEMA_NAME,Es.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),u,_;try{u=await Lne(d)}catch(E){X_.error(E),_=E}if(_!==void 0||u.skipped_hashes.length>0)throw fn(new Error,hn.REFRESH_TOKEN_SAVE_FAILED,En.INTERNAL_SERVER_ERROR);return Une.signalUserChange(new vne(process.pid)),new Bne(o,c)}a(Fne,"createTokens");async function ax(e,t,r){return await Z_.sign(e,{key:t,passphrase:r},{expiresIn:xne,algorithm:tp,subject:ep.OPERATION})}a(ax,"signOperationToken");async function rp(){if(oy===void 0)try{let e=iy.join(da.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,Es.JWT_ENUM.JWT_PASSPHRASE_NAME),t=iy.join(da.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,Es.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=iy.join(da.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,Es.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await ny.readFile(e)).toString(),s=(await ny.readFile(t)).toString(),i=(await ny.readFile(r)).toString();oy=new Hne(i,s,n)}catch(e){throw X_.error(e),fn(new Error,hn.NO_ENCRYPTION_KEYS,En.INTERNAL_SERVER_ERROR)}return oy}a(rp,"getJWTRSAKeys");async function Gne(e){if(!e)throw fn(new Error,hn.INVALID_BODY,En.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw fn(new Error,hn.REFRESH_TOKEN_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);await cx(e.refresh_token);let t=await rp(),r=await Z_.decode(e.refresh_token);return{operation_token:await ax({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(Gne,"refreshOperationToken");async function qne(e){try{let t=await rp(),r=await Z_.verify(e,t.public_key,{algorithms:tp,subject:ep.OPERATION});return await ay.findAndValidateUser(r.username,void 0,!1)}catch(t){throw X_.warn(t),t.name&&t.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}}a(qne,"validateOperationToken");async function cx(e){let t;try{let r=await rp(),n=await Z_.verify(e,r.public_key,{algorithms:tp,subject:ep.REFRESH});t=await ay.findAndValidateUser(n.username,void 0,!1)}catch(r){throw X_.warn(r),r.name&&r.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}if(!ox.validate(t.refresh_token,e))throw fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED);return t}a(cx,"validateRefreshToken")});var cy=b((cwe,_x)=>{"use strict";var $ne=rx(),Su=require("passport"),Vne=require("passport-local").Strategy,Yne=require("passport-http").BasicStrategy,Kne=require("util"),Wne=vn(),dx=Kne.callbackify(Wne.findAndValidateUser),awe=Nn(),jne=M(),ux=ef();Su.use(new Vne(function(e,t,r){dx(e,t,r)}));Su.use(new Yne(function(e,t,r){dx(e,t,r)}));Su.serializeUser(function(e,t){t(null,e)});Su.deserializeUser(function(e,t){t(null,e)});function Qne(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":Su.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===jne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?ux.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):ux.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Su.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Qne,"authorize");function zne(e,t){let r=$ne(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(zne,"checkPermissions");_x.exports={authorize:Qne,checkPermissions:zne}});var _a=b((uwe,fx)=>{"use strict";var ly=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},uy=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};fx.exports={Node:ly,NodeSubscription:uy}});var hx=b((_we,Ex)=>{"use strict";var Jne=M().OPERATIONS_ENUM,dy=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Jne.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Ex.exports=dy});var tf=b((Ewe,mx)=>{"use strict";var _y=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},fy=class{static{a(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,o,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=o,c!==void 0&&(this.attributes=c)}};mx.exports={RemotePayloadObject:_y,RemotePayloadSubscription:fy}});var Sx=b((mwe,px)=>{"use strict";var Ey=class{static{a(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=n,this.record_count=s,this.transaction_log_size=i,this.transaction_log_record_count=o}};px.exports=Ey});var gx=b((Awe,Tx)=>{"use strict";var Xne=Sx(),Swe=Bt(),Twe=ht(),Zne=V(),{getSchemaPath:gwe,getTransactionAuditStorePath:Rwe}=gt(),{getDatabases:ese}=(Le(),oe(lt));Tx.exports=tse;async function tse(e){let t=new Xne;try{let r=ese()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){Zne.warn(`unable to stat table dbi due to ${r}`)}return t}a(tse,"lmdbGetTableSize")});var Ax=b((ywe,Rx)=>{"use strict";var hy=class{static{a(this,"SystemInformationObject")}constructor(t,r,n,s,i,o,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=o,this.harperdb_processes=c}};Rx.exports=hy});var gu=b((Dwe,Nx)=>{"use strict";var rse=require("fs-extra"),nse=require("path"),Jr=require("systeminformation"),fa=V(),bx=kt(),Nwe=dt(),Tu=M(),sse=gx(),ise=fi(),{getThreadInfo:yx}=it(),rf=te();rf.initSync();var ose=Ax(),{openEnvironment:Iwe}=ht(),{getSchemaPath:wwe}=gt(),{database:Cwe,databases:my}=(Le(),oe(lt)),np;Nx.exports={getHDBProcessInfo:gy,getNetworkInfo:Ay,getDiskInfo:Ry,getMemoryInfo:Ty,getCPUInfo:Sy,getTimeInfo:py,getSystemInformation:by,systemInformation:ase,getTableSize:yy,getMetrics:Oy};function py(){return Jr.time()}a(py,"getTimeInfo");async function Sy(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:d,...u}=await Jr.cpu();u.cpu_speed=await Jr.cpuCurrentSpeed();let{raw_currentload:_,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:T,raw_currentload_user:S,cpus:R,...p}=await Jr.currentLoad();return p.cpus=[],R.forEach(y=>{let{raw_load:O,raw_load_idle:B,raw_load_irq:x,raw_load_nice:W,raw_load_system:q,raw_load_user:z,..._e}=y;p.cpus.push(_e)}),u.current_load=p,u}catch(e){return fa.error(`error in getCPUInfo: ${e}`),{}}}a(Sy,"getCPUInfo");async function Ty(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Jr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return fa.error(`error in getMemoryInfo: ${e}`),{}}}a(Ty,"getMemoryInfo");async function gy(){let e={core:[],clustering:[]};try{let t=await Jr.processes(),r;try{r=Number.parseInt(await rse.readFile(nse.join(rf.get(Tu.CONFIG_PARAMS.ROOTPATH),Tu.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Tu.NODE_ERROR_CODES.ENOENT)fa.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return fa.error(`error in getHDBProcessInfo: ${t}`),e}}a(gy,"getHDBProcessInfo");async function Ry(){let e={};try{if(!rf.get(Tu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Jr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...d}=await Jr.fsStats();return e.read_write=d,e.size=await Jr.fsSize(),e}catch(t){return fa.error(`error in getDiskInfo: ${t}`),e}}a(Ry,"getDiskInfo");async function Ay(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return rf.get(Tu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Jr.networkInterfaceDefault(),e.latency=await Jr.inetChecksite("google.com"),(await Jr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:d,ieee8021xState:u,carrier_changes:_,...E}=n;e.interfaces.push(E)}),(await Jr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return fa.error(`error in getNetworkInfo: ${t}`),e}}a(Ay,"getNetworkInfo");async function by(){if(np!==void 0)return np;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Jr.osInfo();e=c;let l=await Jr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,np=e,np}catch(t){return fa.error(`error in getSystemInformation: ${t}`),e}}a(by,"getSystemInformation");async function yy(){let e=[],t=await ise.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await sse(n));return e}a(yy,"getTableSize");async function Oy(){let e={};for(let t in my){let r=e[t]={},n=r.tables={};for(let s in my[t])try{let i=my[t][s];r.readers||(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[d,u,_]=l.trim().split(" ");return{pid:d,thread:u,txnid:_}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){fa.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(Oy,"getMetrics");async function Ox(){if(rf.get(Tu.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await bx.getNATSReferences(),t=await bx.listStreams(),r=[];for(let n of t){let s=[],i=await e.consumers.list(n.config.name);for await(let c of i)s.push({name:c.name,created:c.created,num_ack_pending:c.num_ack_pending,num_redelivered:c.num_redelivered,num_waiting:c.num_waiting,num_pending:c.num_pending});let o={stream_name:n.config.name,database:n.config.subjects[0].split(".")[1],table:n.config.subjects[0].split(".")[2],state:n.state,consumers:s};r.push(o)}return r}}a(Ox,"getNatsStreamInfo");async function ase(e){let t=new ose;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await by(),t.time=py(),t.cpu=await Sy(),t.memory=await Ty(),t.disk=await Ry(),t.network=await Ay(),t.harperdb_processes=await gy(),t.table_size=await yy(),t.metrics=await Oy(),t.threads=await yx(),t.replication=await Ox(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await by();break;case"time":t.time=py();break;case"cpu":t.cpu=await Sy();break;case"memory":t.memory=await Ty();break;case"disk":t.disk=await Ry();break;case"network":t.network=await Ay();break;case"harperdb_processes":t.harperdb_processes=await gy();break;case"table_size":t.table_size=await yy();break;case"database_metrics":case"metrics":t.metrics=await Oy();break;case"threads":t.threads=await yx();break;case"replication":t.replication=await Ox();break;default:break}return t}a(ase,"systemInformation")});var Ic=b((Lwe,Ix)=>{"use strict";Ix.exports={version:cse,printVersion:lse};var sp=Kl();function cse(){if(sp)return sp.version}a(cse,"version");function lse(){sp&&console.log(`HarperDB Version ${sp.version}`)}a(lse,"printVersion")});var hs=b((Bwe,Px)=>{"use strict";var use=Yr(),Ny=J(),dse=require("util"),wc=M(),wx=te();wx.initSync();var _se=cy(),Cx=Vr(),{Node:Uwe,NodeSubscription:vwe}=_a(),fse=Fl(),Ese=hx(),{RemotePayloadObject:hse,RemotePayloadSubscription:mse}=tf(),{handleHDBError:pse,hdb_errors:Sse}=fe(),{HTTP_STATUS_CODES:Tse,HDB_ERROR_MSGS:gse}=Sse,Rse=qs(),Ase=gu(),bse=Ic(),{getDatabases:yse}=(Le(),oe(lt)),Ose=dse.promisify(_se.authorize),Nse=Cx.searchByHash,Ise=Cx.searchByValue;Px.exports={authHeaderToUser:wse,isEmpty:Cse,getNodeRecord:Dse,upsertNodeRecord:Pse,buildNodePayloads:Lse,checkClusteringEnabled:Mse,getAllNodeRecords:Use,getSystemInfo:vse,reverseSubscription:Dx};async function wse(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Ose(t,null),e}a(wse,"authHeaderToUser");function Cse(e){return e==null}a(Cse,"isEmpty");async function Dse(e){let t=new fse(wc.SYSTEM_SCHEMA_NAME,wc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Nse(t)}a(Dse,"getNodeRecord");async function Pse(e){let t=new Ese(wc.SYSTEM_SCHEMA_NAME,wc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return use.upsert(t)}a(Pse,"upsertNodeRecord");function Dx(e){if(Ny.isEmpty(e.subscribe)||Ny.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:n}=e,s={schema:t,table:r,hash_attribute:n};return e.subscribe===!0&&e.publish===!1?(s.subscribe=!1,s.publish=!0):e.subscribe===!1&&e.publish===!0?(s.subscribe=!0,s.publish=!1):(s.subscribe=e.subscribe,s.publish=e.publish),s}a(Dx,"reverseSubscription");function Lse(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:d}=c,u=Ny.getTableHashAttribute(l,d),{subscribe:_,publish:E}=Dx(c),f=yse()[l]?.[d],h=new mse(l,d,u,E,_,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new hse(r,t,s,n)}a(Lse,"buildNodePayloads");function Mse(){if(!wx.get(wc.CONFIG_PARAMS.CLUSTERING_ENABLED))throw pse(new Error,gse.CLUSTERING_NOT_ENABLED,Tse.BAD_REQUEST,void 0,void 0,!0)}a(Mse,"checkClusteringEnabled");async function Use(){let e=new Rse(wc.SYSTEM_SCHEMA_NAME,wc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Ise(e))}a(Use,"getAllNodeRecords");async function vse(){let e=await Ase.getSystemInformation();return{hdb_version:bse.version(),node_version:e.node_version,platform:e.platform}}a(vse,"getSystemInfo")});var Iy=b((xwe,kx)=>{"use strict";var ip=kt(),Lx=J(),Mx=dt(),Ux=M(),op=V(),vx=j_(),Bse=ql(),{RemotePayloadObject:Hse}=tf(),{handleHDBError:Bx,hdb_errors:xse}=fe(),{HTTP_STATUS_CODES:Hx}=xse,{NodeSubscription:xx}=_a();kx.exports=kse;async function kse(e,t){let r;try{r=await ip.request(`${t}.${Mx.REQUEST_SUFFIX}`,new Hse(Ux.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),op.trace("Response from remote describe all request:",r)}catch(o){op.error(`addNode received error from describe all request to remote node: ${o}`);let c=ip.requestErrorHandler(o,"add_node",t);throw Bx(new Error,c,Hx.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===Mx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw Bx(new Error,o,Hx.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,l=o.database??o.schema??"data";if(l===Ux.SYSTEM_SCHEMA_NAME){await ip.createLocalTableStream(l,c);let h=new xx(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let d=Lx.doesSchemaExist(l),u=n[l]!==void 0,_=c?Lx.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!d&&!u||!_&&!E){s.push(o);continue}if(!d&&u&&(op.trace(`addNode creating schema: ${l}`),await vx.createSchema({operation:"create_schema",schema:l})),!_&&E){op.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Bse(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await vx.createTable(h)}await ip.createLocalTableStream(l,c);let f=new xx(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(kse,"reviewSubscriptions")});var Cc={};et(Cc,{addNodeBack:()=>Vse,removeNodeBack:()=>Yse,setNode:()=>$se});async function $se(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=bi(t)):t=Vm(r);let n=(0,Gx.validateBySchema)(e,qse);if(n)throw(0,Oi.handleHDBError)(n,n.message,Gse.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Oi.ClientError("url or hostname is required for remove_node operation");let _=r,E=Er(),f=await E.get(_);if(!f)throw new Oi.ClientError(_+" does not exist");try{await W_({url:f.url},{operation:nf.OPERATIONS_ENUM.REMOVE_NODE_BACK,name:f?.subscriptions?.length>0?at():_},void 0)}catch(h){ms.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,h)}return await E.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Oi.ClientError("url required for this operation");let s=ra();if(s==null)throw new Oi.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){if(e.operation==="add_node"&&!e.authorization)throw new Oi.ClientError("authorization parameter is required");i=await(0,ps.getReplicationCert)();let _=await(0,ps.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ps.createCsr)(),ms.info("Sending CSR to target node:",t)):(c=_?.certificate,ms.info("Sending CA named",_?.name,"to target node",t))}let l={operation:nf.OPERATIONS_ENUM.ADD_NODE_BACK,hostname:(0,qx.get)(nf.CONFIG_PARAMS.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c};if(e.subscriptions?l.subscriptions=e.subscriptions.map(Fx):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=Fx(e);l.subscribe=_.subscribe,l.publish=_.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let d;try{d=await W_({url:t},l,e)}catch(_){throw _.message=`Error returned from ${t}: `+_.message,_}if(o&&(!d?.certificate||!d?.certificate?.includes?.("BEGIN CERTIFICATE")))throw new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(d)}`);o&&(ms.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,ps.setCertTable)({name:Fse.certificateFromPem(d.signingCA).issuer.getField("CN").value,certificate:d.signingCA,is_authority:!0}),d.certificate&&await(0,ps.setCertTable)({name:at(),uses:["https","operations","wss"],certificate:d.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=d.signingCA);let u={url:t,ca:d.usingCA};if(e.hostname&&(u.name=e.hostname),e.subscriptions?u.subscriptions=e.subscriptions:u.replicates=!0,e.start_time&&(u.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),u.replicates){let _={url:s,ca:c,replicates:!0,subscriptions:null};e.start_time&&(_.start_time=e.start_time),await ro(at(),_)}return await ro(d.nodeName,u),e.operation==="update_node"?`Successfully updated '${t}'`:`Successfully added '${t}' to cluster`}async function Vse(e){ms.trace("addNodeBack received request:",e);let t=await(0,ps.signCertificate)(e),r;e.csr?(r=t.signingCA,ms.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,ms.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time);let s=await(0,ps.getReplicationCertAuth)();if(n.replicates){let i={url:ra(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),await ro(at(),i)}return await ro(e.hostname,n),t.nodeName=at(),t.usingCA=s?.certificate,ms.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Yse(e){ms.trace("removeNodeBack received request:",e),await Er().delete(e.name)}function Fx(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var ps,Gx,Ru,qx,nf,ms,Oi,Fse,Gse,qse,Dc=De(()=>{ps=v(js()),Gx=v(ut()),Ru=v(require("joi")),qx=v(te()),nf=v(M());k_();nu();ls();ms=v(V()),Oi=v(fe()),{pki:Fse}=require("node-forge"),{HTTP_STATUS_CODES:Gse}=Oi.hdb_errors,qse=Ru.default.object({hostname:Ru.default.string(),verify_tls:Ru.default.boolean(),replicates:Ru.default.boolean(),subscriptions:Ru.default.array()});a($se,"setNode");a(Vse,"addNodeBack");a(Yse,"removeNodeBack");a(Fx,"reverseSubscription")});var dp=b((Kwe,Vx)=>{"use strict";var{handleHDBError:ap,hdb_errors:Kse}=fe(),{HTTP_STATUS_CODES:cp}=Kse,{addUpdateNodeValidator:Wse}=Zm(),lp=V(),up=M(),$x=dt(),jse=J(),sf=kt(),of=hs(),wy=te(),Qse=Iy(),{Node:zse,NodeSubscription:Jse}=_a(),{broadcast:Xse}=it(),{setNode:Zse}=(Dc(),oe(Cc)),Vwe=te(),Ywe=M(),eie="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",tie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",rie=wy.get(up.CONFIG_PARAMS.CLUSTERING_NODENAME);Vx.exports=nie;async function nie(e,t=!1){if(lp.trace("addNode called with:",e),wy.get(up.CONFIG_PARAMS.REPLICATION_URL)||wy.get(up.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Zse(e);of.checkClusteringEnabled();let r=Wse(e);if(r)throw ap(r,r.message,cp.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let _=await of.getNodeRecord(n);if(!jse.isEmptyOrZeroLength(_))throw ap(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,cp.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Qse(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=eie,o;let c=of.buildNodePayloads(s,rie,up.OPERATIONS_ENUM.ADD_NODE,await of.getSystemInfo()),l=[];for(let _=0,E=s.length;_<E;_++){let f=s[_];s[_].start_time===void 0&&delete s[_].start_time,l.push(new Jse(f.schema,f.table,f.publish,f.subscribe))}lp.trace("addNode sending remote payload:",c);let d;try{d=await sf.request(`${n}.${$x.REQUEST_SUFFIX}`,c)}catch(_){lp.error(`addNode received error from request: ${_}`);for(let f=0,h=s.length;f<h;f++){let T=s[f];T.publish=!1,T.subscribe=!1,await sf.updateRemoteConsumer(T,n)}let E=sf.requestErrorHandler(_,"add_node",n);throw ap(new Error,E,cp.INTERNAL_SERVER_ERROR,"error",E)}if(d.status===$x.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let _=`Error returned from remote node ${n}: ${d.message}`;throw ap(new Error,_,cp.INTERNAL_SERVER_ERROR,"error",_)}lp.trace(d);for(let _=0,E=s.length;_<E;_++){let f=s[_];await sf.updateRemoteConsumer(f,n),f.subscribe===!0&&await sf.updateConsumerIterator(f.schema,f.table,n,"start")}let u=new zse(n,l,d.system_info);return await of.upsertNodeRecord(u),Xse({type:"nats_update"}),i.length>0?o.message=tie:o.message=`Successfully added '${n}' to manifest`,o}a(nie,"addNode")});var Ly=b((Qwe,Kx)=>{"use strict";var{handleHDBError:Cy,hdb_errors:sie}=fe(),{HTTP_STATUS_CODES:Dy}=sie,{addUpdateNodeValidator:iie}=Zm(),af=V(),_p=M(),Yx=dt(),jwe=J(),cf=kt(),lf=hs(),Py=te(),{cloneDeep:oie}=require("lodash"),aie=Iy(),{Node:cie,NodeSubscription:lie}=_a(),{broadcast:uie}=it(),{setNode:die}=(Dc(),oe(Cc)),_ie="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",fie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Eie=Py.get(_p.CONFIG_PARAMS.CLUSTERING_NODENAME);Kx.exports=hie;async function hie(e){if(af.trace("updateNode called with:",e),Py.get(_p.CONFIG_PARAMS.REPLICATION_URL)??Py.get(_p.CONFIG_PARAMS.REPLICATION_HOSTNAME))return die(e);lf.checkClusteringEnabled();let t=iie(e);if(t)throw Cy(t,t.message,Dy.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await lf.getNodeRecord(r);s.length>0&&(n=oie(s));let{added:i,skipped:o}=await aie(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=_ie,c;let l=lf.buildNodePayloads(i,Eie,_p.OPERATIONS_ENUM.UPDATE_NODE,await lf.getSystemInfo());for(let u=0,_=i.length;u<_;u++){let E=i[u];af.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[u].start_time===void 0&&delete i[u].start_time}af.trace("updateNode sending remote payload:",l);let d;try{d=await cf.request(`${r}.${Yx.REQUEST_SUFFIX}`,l)}catch(u){af.error(`updateNode received error from request: ${u}`);let _=cf.requestErrorHandler(u,"update_node",r);throw Cy(new Error,_,Dy.INTERNAL_SERVER_ERROR,"error",_)}if(d.status===Yx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${d.message}`;throw Cy(new Error,u,Dy.INTERNAL_SERVER_ERROR,"error",u)}af.trace(d);for(let u=0,_=i.length;u<_;u++){let E=i[u];await cf.updateRemoteConsumer(E,r),E.subscribe===!0?await cf.updateConsumerIterator(E.schema,E.table,r,"start"):await cf.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new cie(r,[],d.system_info)]),await mie(n[0],i,d.system_info),o.length>0?c.message=fie:c.message=`Successfully updated '${r}'`,c}a(hie,"updateNode");async function mie(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,d=e.subscriptions.length;l<d;l++){let u=n.subscriptions[l];if(u.schema===o.schema&&u.table===o.table){u.publish=o.publish,u.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new lie(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await lf.upsertNodeRecord(n),uie({type:"nats_update"})}a(mie,"updateNodeTable")});var Jx=b((Jwe,zx)=>{"use strict";var Qx=require("joi"),{string:Wx}=Qx.types(),pie=ut(),jx=M(),Sie=te(),Tie=dt();zx.exports=gie;function gie(e){let t=Wx.invalid(Sie.get(jx.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Tie.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),r=Qx.object({operation:Wx.valid(jx.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return pie.validateBySchema(e,r)}a(gie,"removeNodeValidator")});var fp=b((Zwe,rk)=>{"use strict";var{handleHDBError:Xx,hdb_errors:Rie}=fe(),{HTTP_STATUS_CODES:Zx}=Rie,Aie=Jx(),uf=V(),ek=hs(),bie=J(),Au=M(),tk=dt(),My=kt(),Uy=te(),{RemotePayloadObject:yie}=tf(),{NodeSubscription:Oie}=_a(),Nie=Gl(),Iie=Wo(),{broadcast:wie}=it(),{setNode:Cie}=(Dc(),oe(Cc)),Die=Uy.get(Au.CONFIG_PARAMS.CLUSTERING_NODENAME);rk.exports=Pie;async function Pie(e){if(uf.trace("removeNode called with:",e),Uy.get(Au.CONFIG_PARAMS.REPLICATION_URL)??Uy.get(Au.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Cie(e);ek.checkClusteringEnabled();let t=Aie(e);if(t)throw Xx(t,t.message,Zx.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await ek.getNodeRecord(r);if(bie.isEmptyOrZeroLength(n))throw Xx(new Error,`Node '${r}' was not found.`,Zx.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new yie(Au.OPERATIONS_ENUM.REMOVE_NODE,Die,[]),i,o=!1;for(let l=0,d=n.subscriptions.length;l<d;l++){let u=n.subscriptions[l];u.subscribe===!0&&await My.updateConsumerIterator(u.schema,u.table,r,"stop");try{await My.updateRemoteConsumer(new Oie(u.schema,u.table,!1,!1),r)}catch(_){uf.error(_)}}try{i=await My.request(`${r}.${tk.REQUEST_SUFFIX}`,s),uf.trace("Remove node reply from remote node:",r,i)}catch(l){uf.error("removeNode received error from request:",l),o=!0}let c=new Nie(Au.SYSTEM_SCHEMA_NAME,Au.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Iie.deleteRecord(c),wie({type:"nats_update"}),i?.status===tk.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(uf.error("Error returned from remote node:",r,i?.message),`Successfully removed '${r}' from local manifest, however there was an error reaching remote node. Check the logs for more details.`):`Successfully removed '${r}' from manifest`}a(Pie,"removeNode")});var ik=b((tCe,sk)=>{"use strict";var nk=require("joi"),{string:Lie,array:Mie}=nk.types(),Uie=ut(),vie=Zm();sk.exports=Bie;function Bie(e){let t=nk.object({operation:Lie.valid("configure_cluster").required(),connections:Mie.items(vie.validation_schema).required()});return Uie.validateBySchema(e,t)}a(Bie,"configureClusterValidator")});var vy=b((nCe,uk)=>{"use strict";var ok=M(),Ep=V(),Hie=J(),xie=te(),kie=fp(),Fie=dp(),Gie=hs(),qie=ik(),{handleHDBError:ak,hdb_errors:$ie}=fe(),{HTTP_STATUS_CODES:ck}=$ie,Vie="Configure cluster complete.",Yie="Failed to configure the cluster. Check the logs for more details.",Kie="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";uk.exports=Wie;async function Wie(e){Ep.trace("configure cluster called with:",e);let t=qie(e);if(t)throw ak(t,t.message,ck.BAD_REQUEST,void 0,void 0,!0);let r=await Gie.getAllNodeRecords(),n=[];if(xie.get(ok.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let u=0,_=r.length;u<_;u++){let E=await lk(kie,{operation:ok.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[u].name},r[u].name);n.push(E)}Ep.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let u=0;u<i;u++){let _=e.connections[u],E=await lk(Fie,_,_.node_name);s.push(E)}Ep.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,d=n.concat(s);for(let u=0,_=d.length;u<_;u++){let E=d[u];E.status==="rejected"&&(Ep.error(E.node_name,E?.error?.message,E?.error?.stack),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,response:E?.result})}if(Hie.isEmptyOrZeroLength(o))return{message:Vie,connections:c};if(l)return{message:Kie,failed_nodes:o,connections:c};throw ak(new Error,Yie,ck.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Wie,"configureCluster");async function lk(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(lk,"functionWrapper")});var Ek=b((iCe,fk)=>{"use strict";var df=require("joi"),jie=ut(),{validateSchemaExists:dk,validateTableExists:Qie,validateSchemaName:_k}=di(),zie=df.object({operation:df.string().valid("purge_stream"),schema:df.string().custom(dk).custom(_k).optional(),database:df.string().custom(dk).custom(_k).optional(),table:df.string().custom(Qie).required()});function Jie(e){return jie.validateBySchema(e,zie)}a(Jie,"purgeStreamValidator");fk.exports=Jie});var By=b((aCe,hk)=>{"use strict";var{handleHDBError:Xie,hdb_errors:Zie}=fe(),{HTTP_STATUS_CODES:eoe}=Zie,toe=Ek(),roe=kt(),noe=hs();hk.exports=soe;async function soe(e){e.schema=e.schema??e.database;let t=toe(e);if(t)throw Xie(t,t.message,eoe.BAD_REQUEST,void 0,void 0,!0);noe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await roe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(soe,"purgeStream")});var ky=b((lCe,Ak)=>{"use strict";var xy=hs(),ioe=kt(),hp=te(),bu=M(),Pc=dt(),ooe=J(),Hy=V(),{RemotePayloadObject:aoe}=tf(),{ErrorCode:mk}=require("nats"),{parentPort:pk}=require("worker_threads"),{onMessageByType:coe}=it(),{getThisNodeName:loe}=(ls(),oe(sa)),{requestClusterStatus:uoe}=(k_(),oe(mB)),Sk=hp.get(bu.CONFIG_PARAMS.CLUSTERING_ENABLED),Tk=hp.get(bu.CONFIG_PARAMS.CLUSTERING_NODENAME);Ak.exports={clusterStatus:doe,buildNodeStatus:Rk};var gk;coe("cluster-status",async e=>{gk(e)});async function doe(){if(hp.get(bu.CONFIG_PARAMS.REPLICATION_URL)||hp.get(bu.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;return pk?(pk.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{gk=s})):n=uoe(),n.node_name=loe(),n.is_enabled=!0,n}let e={node_name:Tk,is_enabled:Sk,connections:[]};if(!Sk)return e;let t=await xy.getAllNodeRecords();if(ooe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Rk(t[n],e.connections));return await Promise.allSettled(r),e}a(doe,"clusterStatus");async function Rk(e,t){let r=e.name,n=new aoe(bu.OPERATIONS_ENUM.CLUSTER_STATUS,Tk,void 0,await xy.getSystemInfo()),s,i,o=Pc.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await ioe.request(Pc.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Pc.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Pc.CLUSTER_STATUS_STATUSES.CLOSED,Hy.error(`Error getting node status from ${r} `,s))}catch(l){Hy.warn(`Error getting node status from ${r}`,l),l.code===mk.NoResponders?o=Pc.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===mk.Timeout?o=Pc.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Pc.CLUSTER_STATUS_STATUSES.CLOSED}let c=new _oe(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==bu.PRE_4_0_0_VERSION&&await xy.upsertNodeRecord(l)}catch(l){Hy.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Rk,"buildNodeStatus");function _oe(e,t,r,n,s,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=o,this.system_info=c}a(_oe,"NodeStatusObject")});var Gy=b((dCe,bk)=>{"use strict";var{handleHDBError:foe,hdb_errors:Eoe}=fe(),{HTTP_STATUS_CODES:hoe}=Eoe,moe=kt(),poe=hs(),Fy=J(),mp=require("joi"),Soe=ut(),Toe=2e3,goe=mp.object({timeout:mp.number().min(1),connected_nodes:mp.boolean(),routes:mp.boolean()});bk.exports=Roe;async function Roe(e){poe.checkClusteringEnabled();let t=Soe.validateBySchema(e,goe);if(t)throw foe(t,t.message,hoe.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||Fy.autoCastBoolean(n),o=s===void 0||Fy.autoCastBoolean(s),c={nodes:[]},l=await moe.getServerList(r??Toe),d={};if(i)for(let u=0,_=l.length;u<_;u++){let E=l[u].statsz;E&&(d[l[u].server.name]=E.routes)}for(let u=0,_=l.length;u<_;u++){if(l[u].statsz)continue;let E=l[u].server,f=l[u].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[u].response_time};i&&(h.connected_nodes=[],d[E.name]&&d[E.name].forEach(T=>{h.connected_nodes.includes(T.name.slice(0,-4))||h.connected_nodes.push(T.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(T=>({host:T.split(":")[0],port:Fy.autoCast(T.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(Roe,"clusterNetwork")});var Ik=b((fCe,Nk)=>{"use strict";var qy=require("joi"),yk=ut(),{route_constraints:Ok}=DR();Nk.exports={setRoutesValidator:Aoe,deleteRoutesValidator:boe};function Aoe(e){let t=qy.object({server:qy.valid("hub","leaf"),routes:Ok.required()});return yk.validateBySchema(e,t)}a(Aoe,"setRoutesValidator");function boe(e){let t=qy.object({routes:Ok.required()});return yk.validateBySchema(e,t)}a(boe,"deleteRoutesValidator")});var pp=b((hCe,Uk)=>{"use strict";var oo=wt(),$y=J(),Ss=M(),yu=te(),wk=Ik(),{handleHDBError:Ck,hdb_errors:yoe}=fe(),{HTTP_STATUS_CODES:Dk}=yoe,Pk="cluster routes successfully set",Lk="cluster routes successfully deleted";Uk.exports={setRoutes:Noe,getRoutes:Ioe,deleteRoutes:woe};function Ooe(e){let t=oo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=$y.autoCast(l.port);let d=r.some(_=>_.host===l.host&&_.port===l.port),u=n.some(_=>_.host===l.host&&_.port===l.port);d||u?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?oo.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):oo.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:Pk,set:i,skipped:s}}a(Ooe,"setRoutesNats");function Noe(e){let t=wk.setRoutesValidator(e);if(t)throw Ck(t,t.message,Dk.BAD_REQUEST,void 0,void 0,!0);if(yu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ooe(e);let r=[],n=[],s=yu.get(Ss.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Mk(s,i)?n.push(i):(s.push(i),r.push(i))}),oo.updateConfigValue(Ss.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:Pk,set:r,skipped:n}}a(Noe,"setRoutes");function Mk(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(Mk,"existsInArray");function Ioe(){if(yu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=oo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return yu.get(Ss.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Ioe,"getRoutes");function woe(e){let t=wk.deleteRoutesValidator(e);if(t)throw Ck(t,t.message,Dk.BAD_REQUEST,void 0,void 0,!0);if(yu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED))return Coe(e);let r=[],n=[],s=yu.get(Ss.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Mk(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),oo.updateConfigValue(Ss.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Lk,deleted:r,skipped:n}}a(woe,"deleteRoutes");function Coe(e){let t=oo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,d=e.routes.length;l<d;l++){let u=e.routes[l],_=!1;for(let E=0,f=r.length;E<f;E++){let h=r[E];if(u.host===h.host&&u.port===h.port){r.splice(E,1),_=!0,o=!0,s.push(u);break}}if(!_){let E=!0;for(let f=0,h=n.length;f<h;f++){let T=n[f];if(u.host===T.host&&u.port===T.port){n.splice(f,1),c=!0,E=!1,s.push(u);break}}E&&i.push(u)}}return o&&(r=$y.isEmptyOrZeroLength(r)?null:r,oo.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=$y.isEmptyOrZeroLength(n)?null:n,oo.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Lk,deleted:s,skipped:i}}a(Coe,"deleteRoutesNats")});var Bk=b((pCe,vk)=>{"use strict";var _f=require("alasql"),Lc=require("recursive-iterator"),Qs=V(),Doe=J(),ff=M(),Vy=class{static{a(this,"sql_statement_bucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,Loe(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>ff.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!ff.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,o=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][ff.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Poe(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(d=>({attribute_name:d.attribute}));let l=this.affected_attributes.get(i).get(o).filter(d=>!ff.SEARCH_WILDCARDS.includes(d));c.forEach(({attribute_name:d})=>{let u=new _f.yy.Column({columnid:d});s.tableid&&(u.tableid=s.tableid),this.ast.columns.push(u),l.includes(d)||l.push(d)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function Poe(e){return e.filter(t=>t[ff.PERMS_CRUD_ENUM.READ])}a(Poe,"filterReadRestrictedAttrs");function Loe(e,t,r,n,s){Moe(e,t,r,n,s)}a(Loe,"interpretAST");function Ef(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),s.set(o,i)}}a(Ef,"addSchemaTableToMap");function Moe(e,t,r,n,s){if(!e){Qs.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof _f.yy.Insert?Hoe(e,t,r):e instanceof _f.yy.Select?Uoe(e,t,r,n,s):e instanceof _f.yy.Update?voe(e,t,r):e instanceof _f.yy.Delete?Boe(e,t,r):Qs.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(Moe,"getRecordAttributesAST");function Uoe(e,t,r,n,s){if(!e){Qs.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Doe.isEmptyOrZeroLength(i)){Qs.error("No schema specified");return}e.from.forEach(c=>{Ef(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Ef(c.table,t,r,n,s)});let o=new Lc(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,d=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(d).has(l))if(r.has(l))l=r.get(l);else{Qs.info(`table specified as ${l} not found.`);return}t.get(d).get(l).indexOf(c.columnid)<0&&t.get(d).get(l).push(c.columnid)}if(e.where){let c=new Lc(e.where),l=e.from[0].tableid;for(let{node:d}of c)if(d&&d.columnid){let u=d.tableid?d.tableid:l;if(!t.get(i).has(u))if(r.has(u))u=r.get(u);else{Qs.info(`table specified as ${u} not found.`);continue}t.get(i).get(u).indexOf(d.columnid)<0&&t.get(i).get(u).push(d.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Lc(c.on);for(let{node:d}of l)if(d&&d.columnid){let u=d.tableid,_=s.get(u);if(!t.get(_).has(u))if(r.has(u))u=r.get(u);else{Qs.info(`table specified as ${u} not found.`);continue}t.get(_).get(u).indexOf(d.columnid)<0&&t.get(_).get(u).push(d.columnid)}}),e.order){let c=new Lc(e.order);for(let{node:l}of c)if(l&&l.columnid){let d=l.tableid,u=n.has(d)?n.get(d):i;if(d||(d=e.from[0].tableid),!t.get(u).has(d))if(r.has(d))d=r.get(d);else{Qs.info(`table specified as ${d} not found.`);return}t.get(u).get(d).indexOf(l.columnid)<0&&t.get(u).get(d).push(l.columnid)}}}a(Uoe,"getSelectAttributes");function voe(e,t,r){if(!e){Qs.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Lc(e.columns),s=e.table.databaseid;Ef(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Yy(e.table.tableid,s,i.columnid,t,r)}a(voe,"getUpdateAttributes");function Boe(e,t,r){if(!e){Qs.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Lc(e.where),s=e.table.databaseid;Ef(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Yy(e.table.tableid,s,i.columnid,t,r)}a(Boe,"getDeleteAttributes");function Hoe(e,t,r){if(!e){Qs.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Lc(e.columns),s=e.into.databaseid;Ef(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&Yy(e.into.tableid,s,i.columnid,t,r)}a(Hoe,"getInsertAttributes");function Yy(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}a(Yy,"pushAttribute");vk.exports=Vy});var jy=b((TCe,Fk)=>{var Sp=sc(),Hk=require("chalk"),Fn=V(),xk=require("prompt"),{promisify:xoe}=require("util"),Ky=M(),koe=require("fs-extra"),Foe=require("path"),Goe=J(),qoe=Ic(),kk=te();kk.initSync();var $oe=require("moment"),Voe=xoe(xk.get),Yoe=Foe.join(kk.getHdbBasePath(),Ky.LICENSE_KEY_DIR_NAME,Ky.LICENSE_FILE_NAME,Ky.LICENSE_FILE_NAME);Fk.exports={getFingerprint:Woe,setLicense:Koe,parseLicense:Wy,register:joe,getRegistrationInfo:zoe};async function Koe(e){if(e&&e.key&&e.company){try{Fn.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Wy(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Fn.error(r),Fn.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(Koe,"setLicense");async function Woe(){let e={};try{e=await Sp.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Fn.error(r),Fn.error(t),new Error(r)}return e}a(Woe,"getFingerprint");async function Wy(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Fn.info("Validating license input...");let r=Sp.validateLicense(e,t);if(Fn.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Fn.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Fn.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Fn.info("writing license to disk"),await koe.writeFile(Yoe,JSON.stringify({license_key:e,company:t}))}catch(n){throw Fn.error("Failed to write License"),n}return"Registration successful."}a(Wy,"parseLicense");async function joe(){let e=await Qoe();return Wy(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(joe,"register");async function Qoe(){let e=await Sp.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Hk.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Hk.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{xk.start()}catch(n){Fn.error(n)}let r;try{r=await Voe(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(Qoe,"promptForRegistration");async function zoe(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Sp.getLicense()}catch(r){throw Fn.error(`There was an error when searching licenses due to: ${r.message}`),r}if(Goe.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=qoe.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=$oe.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(zoe,"getRegistrationInfo")});var qk=b((RCe,Gk)=>{"use strict";var Joe=dt(),Qy=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,d,u,_,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+Joe.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:d,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:_,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};Gk.exports=Qy});var Yk=b((bCe,Vk)=>{"use strict";var $k=dt(),zy=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,d,u,_){this.port=t,_===null&&(_=void 0),this.server_name=r+$k.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+$k.SERVER_SUFFIX.LEAF},this.tls={cert_file:d,key_file:u,ca_file:_,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:_,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:_,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};Vk.exports=zy});var Wk=b((OCe,Kk)=>{"use strict";var Jy=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};Kk.exports=Jy});var Qk=b((ICe,jk)=>{"use strict";var Xoe=dt(),Xy=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+Xoe.SERVER_SUFFIX.ADMIN,this.password=r}};jk.exports=Xy});var Ap=b((CCe,Xk)=>{"use strict";var Mc=require("path"),Uc=require("fs-extra"),Zoe=qk(),eae=Yk(),tae=Wk(),rae=Qk(),Zy=vn(),Nu=J(),mn=wt(),gp=M(),hf=dt(),{CONFIG_PARAMS:Jt}=gp,Iu=V(),mf=te(),zk=zi(),eO=kt(),nae=js(),Ou="clustering",sae=1e4,Jk=50;Xk.exports={generateNatsConfig:oae,removeNatsConfig:aae,getHubConfigPath:iae};function iae(){let e=mf.get(Jt.ROOTPATH);return Mc.join(e,Ou,hf.NATS_CONFIG_FILES.HUB_SERVER)}a(iae,"getHubConfigPath");async function oae(e=!1,t=void 0){let r=mf.get(Jt.ROOTPATH);Uc.ensureDirSync(Mc.join(r,"clustering","leaf")),mf.initSync();let n=mn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),s=mn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),i=mn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await Uc.exists(i)&&!await Uc.exists(!n)&&await nae.createNatsCerts();let o=Mc.join(r,Ou,hf.PID_FILES.HUB),c=Mc.join(r,Ou,hf.PID_FILES.LEAF),l=mn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),d=Mc.join(r,Ou,hf.NATS_CONFIG_FILES.HUB_SERVER),u=Mc.join(r,Ou,hf.NATS_CONFIG_FILES.LEAF_SERVER),_=mn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),E=mn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),f=mn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await eO.checkNATSServerInstalled()||Rp("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let T=await Zy.listUsers(),S=mn.getConfigFromFile(Jt.CLUSTERING_USER),R=await Zy.getClusterUser();(Nu.isEmpty(R)||R.active!==!0)&&Rp(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Tp(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Tp(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Tp(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Tp(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let p=[],y=[];for(let[_e,X]of T.entries())X.role?.role===gp.ROLE_TYPES_ENUM.CLUSTER_USER&&X.active&&(p.push(new rae(X.username,zk.decrypt(X.hash))),y.push(new tae(X.username,zk.decrypt(X.hash))));let O=[],{hub_routes:B}=mn.getClusteringRoutes();if(!Nu.isEmptyOrZeroLength(B))for(let _e of B)O.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${_e.host}:${_e.port}`);let x=new Zoe(mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,o,i,s,n,_,E,h,mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),mn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),O,p,y);n==null&&(delete x.tls.ca_file,delete x.leafnodes.tls.ca_file),t=Nu.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===gp.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Uc.writeJson(d,x),Iu.trace(`Hub server config written to ${d}`));let W=`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,q=`tls://${R.uri_encoded_name}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,z=new eae(mn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,c,l,[W],[q],p,y,i,s,n,_);n==null&&delete z.tls.ca_file,(t===void 0||t===gp.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Uc.writeJson(u,z),Iu.trace(`Leaf server config written to ${u}`))}a(oae,"generateNatsConfig");async function Tp(e){let t=mf.get(e);return Nu.isEmpty(t)&&Rp(`port undefined for '${e}'`),await Nu.isPortTaken(t)&&Rp(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(Tp,"isPortAvailable");function Rp(e){let t=`Error generating clustering config: ${e}`;Iu.error(t),console.error(t),process.exit(1)}a(Rp,"generateNatsConfigError");async function aae(e){let{port:t,config_file:r}=eO.getServerConfig(e),{username:n,decrypt_hash:s}=await Zy.getClusterUser(),i=0,o=2e3;for(;i<Jk;){try{let u=await eO.createConnection(t,n,s,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){Iu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=Jk)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let d=o*(i*2);d>3e4&&Iu.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Nu.async_set_timeout(d)}let c="0".repeat(sae),l=Mc.join(mf.get(Jt.ROOTPATH),Ou,r);await Uc.writeFile(l,c),await Uc.remove(l),Iu.notify(e,"started.")}a(aae,"removeNatsConfig")});var sF=b((PCe,nF)=>{"use strict";var Gn=te(),cae=sc(),ke=M(),pf=dt(),ao=require("path"),{PACKAGE_ROOT:yp}=M(),Zk=te(),bp=J(),wu="/dev/null",lae=ao.join(yp,"launchServiceScripts"),eF=ao.join(yp,"utility/scripts"),uae=ao.join(eF,ke.HDB_RESTART_SCRIPT),tF=ao.resolve(yp,"dependencies",`${process.platform}-${process.arch}`,pf.NATS_BINARY_NAME);function rF(){let t=cae.licenseSearch().ram_allocation||ke.RAM_ALLOCATION_ENUM.DEFAULT,r=ke.MEM_SETTING_KEY+t,n={[ke.PROCESS_NAME_ENV_PROP]:ke.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return bp.noBootFile()&&(n[ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=bp.getEnvCliRootPath()),{name:ke.PROCESS_DESCRIPTORS.HDB,script:ke.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:yp}}a(rF,"generateMainServerConfig");var dae=9930;function _ae(){Gn.initSync(!0);let e=Gn.get(ke.CONFIG_PARAMS.ROOTPATH),t=ao.join(e,"clustering",pf.NATS_CONFIG_FILES.HUB_SERVER),r=ao.join(Gn.get(ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),ke.LOG_NAMES.HDB),n=Zk.get(ke.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=pf.LOG_LEVEL_FLAGS[Gn.get(ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:ke.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==dae?"-"+n:""),script:tF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[ke.PROCESS_NAME_ENV_PROP]:ke.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Gn.get(ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wu,i.error_file=wu),i}a(_ae,"generateNatsHubServerConfig");var fae=9940;function Eae(){Gn.initSync(!0);let e=Gn.get(ke.CONFIG_PARAMS.ROOTPATH),t=ao.join(e,"clustering",pf.NATS_CONFIG_FILES.LEAF_SERVER),r=ao.join(Gn.get(ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),ke.LOG_NAMES.HDB),n=Zk.get(ke.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=pf.LOG_LEVEL_FLAGS[Gn.get(ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:ke.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==fae?"-"+n:""),script:tF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[ke.PROCESS_NAME_ENV_PROP]:ke.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Gn.get(ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=wu,i.error_file=wu),i}a(Eae,"generateNatsLeafServerConfig");function hae(){Gn.initSync();let e=ao.join(Gn.get(ke.CONFIG_PARAMS.LOGGING_ROOT),ke.LOG_NAMES.HDB),t={name:ke.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:ke.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[ke.PROCESS_NAME_ENV_PROP]:ke.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:lae,autorestart:!1};return Gn.get(ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=wu,t.error_file=wu),t}a(hae,"generateClusteringUpgradeV4ServiceConfig");function mae(){let e={[ke.PROCESS_NAME_ENV_PROP]:ke.PROCESS_DESCRIPTORS.RESTART_HDB};return bp.noBootFile()&&(e[ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=bp.getEnvCliRootPath()),{...{name:ke.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:eF},script:uae}}a(mae,"generateRestart");function pae(){return{apps:[rF()]}}a(pae,"generateAllServiceConfigs");nF.exports={generateAllServiceConfigs:pae,generateMainServerConfig:rF,generateRestart:mae,generateNatsHubServerConfig:_ae,generateNatsLeafServerConfig:Eae,generateClusteringUpgradeV4ServiceConfig:hae}});var Tf=b((UCe,pF)=>{"use strict";var ot=M(),Sae=J(),lo=Ap(),Op=kt(),co=dt(),Ea=sF(),Np=te(),vc=V(),Tae=hs(),{startWorker:iF,onMessageFromWorkers:gae}=it(),Rae=gu(),MCe=require("util"),Aae=require("child_process"),bae=require("fs"),{execFile:yae}=Aae,ze;pF.exports={enterPM2Mode:Oae,start:ha,stop:tO,reload:aF,restart:cF,list:rO,describe:uF,connect:uo,kill:Dae,startAllServices:Pae,startService:nO,getUniqueServicesList:dF,restartAllServices:Lae,isServiceRegistered:_F,reloadStopStart:fF,restartHdb:lF,deleteProcess:wae,startClusteringProcesses:hF,startClusteringThreads:mF,isHdbRestartRunning:Cae,isClusteringRunning:Uae,stopClustering:Mae,reloadClustering:vae};var Sf=!1;gae(e=>{e.type==="restart"&&Np.initSync(!0)});function Oae(){Sf=!0}a(Oae,"enterPM2Mode");function uo(){return ze||(ze=require("pm2")),new Promise((e,t)=>{ze.connect((r,n)=>{r&&t(r),e(n)})})}a(uo,"connect");var pn,Nae=10,oF;function ha(e,t=!1){if(Sf)return Iae(e);let r=yae(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=pn.indexOf(r);o>-1&&pn.splice(o,1),!oF&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Nae&&(bae.existsSync(lo.getHubConfigPath())?ha(e):(await lo.generateNatsConfig(!0),ha(e),await new Promise(c=>setTimeout(c,3e3)),await lo.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await lo.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Np.get(ot.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,d=0,u;for(;l=c.exec(i);){if(l.index&&co.LOG_LEVEL_HIERARCHY[o]>=co.LOG_LEVEL_HIERARCHY[u||"info"]){let f=u===co.LOG_LEVELS.ERR||u===co.LOG_LEVELS.WRN?vc.OUTPUTS.STDERR:vc.OUTPUTS.STDOUT;vc.logCustomLevel(u||"info",f,n,i.slice(d,l.index).trim())}let[_,E]=l;d=l.index+_.length,u=co.LOG_LEVELS[E]}if(co.LOG_LEVEL_HIERARCHY[o]>=co.LOG_LEVEL_HIERARCHY[u||"info"]){let _=u===co.LOG_LEVELS.ERR||u===co.LOG_LEVELS.WRN?vc.OUTPUTS.STDERR:vc.OUTPUTS.STDOUT;vc.logCustomLevel(u||"info",_,n,i.slice(d).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),pn=[],!pn&&!t){let i=a(()=>{oF=!0,pn&&(pn.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}pn.push(r)}a(ha,"start");function Iae(e){return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.start(e,(n,s)=>{n&&(ze.disconnect(),r(n)),ze.disconnect(),t(s)})})}a(Iae,"startWithPM2");function tO(e){if(!Sf){for(let t of pn||[])t.name===e&&(pn.splice(pn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.stop(e,async(n,s)=>{n&&(ze.disconnect(),r(n)),ze.delete(e,(i,o)=>{i&&(ze.disconnect(),r(n)),ze.disconnect(),t(o)})})})}a(tO,"stop");function aF(e){return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.reload(e,(n,s)=>{n&&(ze.disconnect(),r(n)),ze.disconnect(),t(s)})})}a(aF,"reload");function cF(e){if(!Sf)for(let t of pn||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.restart(e,(n,s)=>{ze.disconnect(),t(s)})})}a(cF,"restart");function wae(e){return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.delete(e,(n,s)=>{n&&(ze.disconnect(),r(n)),ze.disconnect(),t(s)})})}a(wae,"deleteProcess");async function lF(){await ha(Ea.generateRestart())}a(lF,"restartHdb");async function Cae(){let e=await rO();for(let t in e)if(e[t].name===ot.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Cae,"isHdbRestartRunning");function rO(){return new Promise(async(e,t)=>{try{await uo()}catch(r){t(r)}ze.list((r,n)=>{r&&(ze.disconnect(),t(r)),ze.disconnect(),e(n)})})}a(rO,"list");function uF(e){return new Promise(async(t,r)=>{try{await uo()}catch(n){r(n)}ze.describe(e,(n,s)=>{n&&(ze.disconnect(),r(n)),ze.disconnect(),t(s)})})}a(uF,"describe");function Dae(){if(!Sf){for(let e of pn||[])e.kill();pn=[];return}return new Promise(async(e,t)=>{try{await uo()}catch(r){t(r)}ze.killDaemon((r,n)=>{r&&(ze.disconnect(),t(r)),ze.disconnect(),e(n)})})}a(Dae,"kill");async function Pae(){try{await hF(),await mF(),await ha(Ea.generateAllServiceConfigs())}catch(e){throw ze?.disconnect(),e}}a(Pae,"startAllServices");async function nO(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case ot.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ea.generateMainServerConfig();break;case ot.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ea.generateNatsIngestServiceConfig();break;case ot.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ea.generateNatsReplyServiceConfig();break;case ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ea.generateNatsHubServerConfig(),await ha(r,t),await lo.removeNatsConfig(e);return;case ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ea.generateNatsLeafServerConfig(),await ha(r,t),await lo.removeNatsConfig(e);return;case ot.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ea.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await ha(r)}catch(r){throw ze?.disconnect(),r}}a(nO,"startService");async function dF(){try{let e=await rO(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw ze?.disconnect(),e}}a(dF,"getUniqueServicesList");async function Lae(e=[]){try{let t=!1,r=await dF();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===ot.PROCESS_DESCRIPTORS.HDB?t=!0:await cF(o))}t&&await fF(ot.PROCESS_DESCRIPTORS.HDB)}catch(t){throw ze?.disconnect(),t}}a(Lae,"restartAllServices");async function _F(e){if(pn?.find(r=>r.name===e))return!0;let t=await Rae.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(_F,"isServiceRegistered");async function fF(e){let t=Np.get(ot.CONFIG_PARAMS.THREADS_COUNT)??Np.get(ot.CONFIG_PARAMS.THREADS),r=await uF(e),n=Sae.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await tO(e),await nO(e)):e===ot.PROCESS_DESCRIPTORS.HDB?await lF():await aF(e)}a(fF,"reloadStopStart");var EF;async function hF(e=!1){for(let t in ot.CLUSTERING_PROCESSES){let r=ot.CLUSTERING_PROCESSES[t];await nO(r,e)}}a(hF,"startClusteringProcesses");async function mF(){EF=iF(ot.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:ot.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await Op.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await Op.updateLocalStreams();let e=await Tae.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===ot.PRE_4_0_0_VERSION){vc.info("Starting clustering upgrade 4.0.0 process"),iF(ot.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(mF,"startClusteringThreads");async function Mae(){for(let e in ot.CLUSTERING_PROCESSES)if(e!==ot.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===ot.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await EF.terminate();else{let t=ot.CLUSTERING_PROCESSES[e];await tO(t)}}a(Mae,"stopClustering");async function Uae(){for(let e in ot.CLUSTERING_PROCESSES){let t=ot.CLUSTERING_PROCESSES[e];if(await _F(t)===!1)return!1}return!0}a(Uae,"isClusteringRunning");async function vae(){await lo.generateNatsConfig(!0),await Op.reloadNATSHub(),await Op.reloadNATSLeaf(),await lo.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await lo.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(vae,"reloadClustering")});var oO={};et(oO,{compactOnStart:()=>Bae,copyDb:()=>bF});async function Bae(){gf.notify("Running compact on start"),console.log("Running compact on start");let e=(0,sO.get)(ma.CONFIG_PARAMS.ROOTPATH),t=new Map,r=mt();try{for(let n in r){if(n==="system")continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Ip.join)(e,"backup",n+".mdb"),o=(0,Ip.join)(e,ma.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await SF(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await bF(n,o),console.log("Backing up",n,"to",i),await(0,Bc.move)(s,i,{overwrite:!0})}Cu();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,Bc.move)(i,s,{overwrite:!0}),await(0,Bc.remove)((0,Ip.join)(e,ma.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));Cu()}catch(n){gf.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,iO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,Bc.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Cu(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await SF(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
14
16
  Total record count before compaction: ${i}, total after: ${c}.
15
- Database backup has not been removed and can be found here: ${s}`;gf.error(l),console.error(l)}(0,ny.get)(fa.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,vc.remove)(s))}(0,sy.updateConfigValue)(fa.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1)}async function mk(e){let t=await(0,gk.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function Rk(e,t){console.log("copyDb start");let r=ht()[e],n;for(let _ in r){n=r[_].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,pk.open)(new Sk.default(t)),c=o.openDB(wp.INTERNAL_DBIS_NAME),l,d=0,u=s.useReadTransaction();try{for(let{key:f,value:h}of s.getRange({transaction:u})){let p=h.is_hash_attribute||h.isPrimaryKey,T,g;if(p&&(T=h.compression,g=Cp(),g?h.compression=g:delete h.compression,T?.dictionary?.toString()===g?.dictionary?.toString()&&(T=null,g=null)),c.put(f,h),!(p||h.indexed))continue;let S=new Tk.default(!p,p);S.encoding="binary",S.compression=T;let C=n.openDB(f,S);C.decoder=null,S.compression=g;let y=o.openDB(f,S);y.encoder=null,console.log("copying",f,"from",e,"to",t),await E(C,y,p,u)}let _=n.openDB(wp.AUDIT_STORE_NAME,Rf);console.log("copying audit log"),E(i,_,!1,u);async function E(f,h,p,T){let g=0,S=0;for(let{key:C,value:y,version:x}of f.getRange({start:null,versions:p,transaction:T}))l=h.put(C,y,x),g++,T.openTimer&&(T.openTimer=0),S+=(C?.length||10)+y.length,d++>5e3&&(await l,console.log("copied",g,"entries",S,"bytes"),d=0);console.log("finish copying, copied",g,"entries",S,"bytes")}a(E,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{u.done(),o.close()}}var pk,Ip,vc,ny,Sk,Tk,wp,fa,gk,sy,gf,oy=Ce(()=>{Le();pk=require("lmdb"),Ip=require("path"),vc=require("fs-extra"),ny=B(te()),Sk=B(Wd()),Tk=B(Kd()),wp=B(Bt()),fa=B(M());Wi();gk=B(Ei()),sy=B(It()),gf=B(V());a(vae,"compactOnStart");a(mk,"getTotalDBRecordCount");a(Rk,"copyDb")});var Pu=b((qCe,wk)=>{"use strict";var Bae=require("minimist"),{isMainThread:cy,parentPort:Of,threadId:FCe}=require("worker_threads"),Pt=M(),{PROCESS_DESCRIPTORS_VALIDATE:Cu}=Pt,Ii=V(),ly=ee(),Pp=Ap(),Dp=Ft(),kCe=_t(),yk=It(),wi=Tf(),Ak=pu(),{compactOnStart:Hae}=(oy(),ie(iy)),xae=$a(),{restartWorkers:Lp,onMessageByType:Fae}=st(),{handleHDBError:kae,hdb_errors:Gae}=ce(),{HTTP_STATUS_CODES:qae}=Gae,bf=te(),{sendOperationToNode:Ok,getThisNodeName:$ae,monitorNodeCAs:Vae}=(as(),ie(ta)),{getHDBNodeTable:GCe}=(eu(),ie(uB));bf.initSync();var Af=`Restarting HarperDB. This may take up to ${Pt.RESTART_TIMEOUT_MS/1e3} seconds.`,Yae="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",bk="Clustering is not enabled so cannot be restarted",Kae="Invalid service",Du,ps;wk.exports={restart:Nk,restartService:uy};cy&&Fae(Pt.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await uy({service:e.workerType}):Nk({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function Nk(e){ps=Object.keys(e).length===0,Du=await wi.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR);let t=Bae(process.argv);if(t.service){await uy(t);return}if(ps&&!Du){console.error(Yae);return}if(ps&&console.log(Af),Du){wi.enterPM2Mode(),Ii.notify(Af);let r=xae(Object.keys(Pt.CONFIG_PARAM_MAP),!0);return ly.isEmptyOrZeroLength(Object.keys(r))||yk.updateConfigValue(void 0,void 0,r,!0,!0),Wae(),Af}return cy?(Ii.notify(Af),bf.get(Pt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Hae(),setTimeout(()=>{Lp()},50)):Of.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART}),Af}a(Nk,"restart");async function uy(e){let{service:t}=e;if(Pt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw kae(new Error,Kae,qae.BAD_REQUEST,void 0,void 0,!0);if(Du=await wi.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR),!cy){e.replicated&&Vae(),Of.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART,workerType:t}),Of.ref(),await new Promise(s=>{Of.on("message",i=>{i.type==="restart-complete"&&(s(),Of.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===$ae())continue;let{job_id:i}=await Ok(s,e);n.push(await new Promise((o,c)=>{let d=2400,u=setInterval(async()=>{if(d--<=0){clearInterval(u);let f=new Error("Timed out waiting for restart job to complete");f.replicated=n,c(f)}let E=(await Ok(s,{operation:"get_job",id:i})).results[0];if(E.status==="COMPLETE"&&(clearInterval(u),o({node:s.name,message:E.message})),E.status==="ERROR"){clearInterval(u);let f=new Error(E.message);f.replicated=n,c(f)}},250)}))}return{replicated:n}}return}let r;switch(t){case Cu.clustering:if(!bf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=bk;break}ps&&console.log("Restarting clustering"),Ii.notify("Restarting clustering"),await Ik();break;case Cu.clustering_config:case Cu["clustering config"]:if(!bf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=bk;break}ps&&console.log("Restarting clustering_config"),Ii.notify("Restarting clustering_config"),await wi.reloadClustering();break;case"custom_functions":case"custom functions":case Cu.harperdb:case Cu.http_workers:case Cu.http:if(ps&&!Du){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}ps&&console.log("Restarting http_workers"),Ii.notify("Restarting http_workers"),ps?await wi.restart(Pt.HDB_PROC_DESCRIPTOR):await Lp("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Ii.error(r),ps&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(uy,"restartService");async function Wae(){await Ik(),await wi.restart(Pt.HDB_PROC_DESCRIPTOR),await ly.async_set_timeout(2e3),bf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await ay(),ps&&(await Dp.closeConnection(),process.exit(0))}a(Wae,"restartPM2Mode");async function Ik(){if(!yk.getConfigFromFile(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await Ak.getHDBProcessInfo()).clustering.length===0)Ii.trace("Clustering not running, restart will start clustering services"),await Pp.generateNatsConfig(!0),await wi.startClusteringProcesses(),await wi.startClusteringThreads(),await ay(),ps&&await Dp.closeConnection();else{await Pp.generateNatsConfig(!0),Du?(Ii.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await wi.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await wi.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await Ak.getHDBProcessInfo()).clustering.forEach(s=>{Ii.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await ly.async_set_timeout(3e3),await ay(),await Dp.updateLocalStreams(),ps&&await Dp.closeConnection(),Ii.trace("Restart clustering restarting ingest and reply service threads");let t=Lp(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=Lp(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(Ik,"restartClustering");async function ay(){await Pp.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Pp.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(ay,"removeNatsConfig")});var Fk=b((YCe,xk)=>{"use strict";var VCe=require("lodash"),Sn=M(),{handleHDBError:Ck,hdb_errors:jae}=ce(),{HDB_ERROR_MSGS:Qae,HTTP_STATUS_CODES:zae}=jae,dy=V();xk.exports={getRolePermissions:Xae};var Bc=Object.create(null),Jae=a(e=>({key:e,perms:{}}),"perms_template_obj"),Mk=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),Uk=a((e=!1,t=!1,r=!1,n=!1)=>({[Sn.PERMS_CRUD_ENUM.READ]:e,[Sn.PERMS_CRUD_ENUM.INSERT]:t,[Sn.PERMS_CRUD_ENUM.UPDATE]:r,[Sn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),_y=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...Uk(t,r,n,s)}),"table_perms_template"),Dk=a((e,t=Uk())=>({attribute_name:e,describe:Hk(t),[yf]:t[yf],[fy]:t[fy],[Ey]:t[Ey]}),"attr_perms_template"),Pk=a((e,t=!1)=>({attribute_name:e,describe:t,[yf]:t}),"timestamp_attr_perms_template"),{READ:yf,INSERT:fy,UPDATE:Ey}=Sn.PERMS_CRUD_ENUM,vk=Object.values(Sn.PERMS_CRUD_ENUM),Bk=[yf,fy,Ey];function Xae(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[Sn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Bc[t]&&Bc[t].key===n)return Bc[t].perms;let s=Zae(e,r);return Bc[t]?Bc[t].key=n:Bc[t]=Jae(n),Bc[t].perms=s,s}catch(r){if(!e[Sn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Sn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Sn.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw dy.error(n),dy.debug(r),Ck(new Error,Qae.OUTDATED_PERMS_TRANSLATION_ERROR,zae.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
16
- ${r.stack}`;throw dy.error(n),Ck(new Error)}}}a(Xae,"getRolePermissions");function Zae(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Sn.SYSTEM_SCHEMA_NAME]=n[Sn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=ece(t[i]);return}r[i]=Mk(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],d=tce(c,l);r[i].describe||vk.forEach(u=>{d[u]&&(r[i].describe=!0)}),r[i].tables[o]=d}else r[i].tables[o]=_y()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=_y()})}),r}a(Zae,"translateRolePermissions");function ece(e){let t=Mk(!0);return Object.keys(e).forEach(r=>{t.tables[r]=_y(!0,!0,!0,!0,!0)}),t}a(ece,"createStructureUserPermissions");function tce(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((d,u)=>{let{attribute_name:_}=u,E=u;return Sn.TIME_STAMP_NAMES.includes(_)&&(E=Pk(_,u[yf])),d[_]=E,d},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=Dk(o);return t.attributes.forEach(({attribute:d})=>{if(i[d]){let u=i[d];u.describe=Hk(u),s.attribute_permissions.push(u),c||rce(u,l)}else if(d!==o){let u;Sn.TIME_STAMP_NAMES.includes(d)?u=Pk(d):u=Dk(d),s.attribute_permissions.push(u)}}),c||s.attribute_permissions.push(l),s.describe=Lk(s),s}else return e.describe=Lk(e),e}a(tce,"getTableAttrPerms");function Lk(e){return vk.filter(t=>e[t]).length>0}a(Lk,"getSchemaTableDescribePerm");function Hk(e){return Bk.filter(t=>e[t]).length>0}a(Hk,"getAttributeDescribePerm");function rce(e,t){Bk.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(rce,"checkForHashPerms")});var kk={};tt(kk,{Headers:()=>uo,appendHeader:()=>hy,mergeHeaders:()=>my});function hy(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 my(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new uo(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 uo,Nf=Ce(()=>{uo=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(hy,"appendHeader");a(my,"mergeHeaders")});var If={};tt(If,{authentication:()=>Wk,bypassAuth:()=>lce,login:()=>dce,logout:()=>_ce,start:()=>uce});function lce(){Kk=!0}async function Wk(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?oce?ice:[]:sce?nce:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new uo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Mp&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Mp&&o.push("Access-Control-Allow-Credentials","true")}}let l,d;if(Mp){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let p of h)if(p.startsWith(f)){let T=p.indexOf(";");l=p.slice(f.length,T===-1?p.length:T),d=await Gk.get(l);break}e.session=d||(d={})}let u=a((f,h,p)=>{let T=new Lu.AuthAuditLog(f,h,Ar.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);T.auth_strategy=p,l&&(T.session_id=l),r.referer&&(T.referer=r.referer),r.origin&&(T.origin=r.origin),h===Ar.AUTH_AUDIT_STATUS.SUCCESS?py.notify(T):py.error(T)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&py.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await nt.getUser(f,null,null),u(f,Ar.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,Lu.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=Hc.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),p=n.slice(f+1),T,g;try{switch(h){case"Basic":let S=atob(p),C=S.indexOf(":");T=S.slice(0,C),g=S.slice(C+1),_=T||g?await nt.getUser(T,g,e):null;break;case"Bearer":try{_=await(0,Up.validateOperationToken)(p)}catch(y){if(y.message==="invalid token")try{return await(0,Up.validateRefreshToken)(p),c({status:-1})}catch{throw y}}break}}catch(S){return cce&&(Hc.get(p)||(Hc.set(p,p),u(T,Ar.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:xc({error:S.message},e)})}Hc.set(n,_),ace&&u(_.username,Ar.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=_}else d?.user?e.user=await nt.getUser(d.user,null,e):(Kk&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,$k.getSuperUser)());Mp&&(e.session.update=function(f){if(!l){l=(0,Vk.v4)();let p=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",p):E?.headers?.set&&E.headers.set("Set-Cookie",p)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,Gk.put(f)},e.login=async function(f,h){e.user=await nt.getUser(f,h,e),e.session.update({user:e.user.username})},(_&&!d||d?.user?.username!==_?.username)&&r["user-agent"]?.startsWith("Mozilla")&&e.session.update({user:e.user.username}));let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Qo.loginPath?(E.status=302,E.headers.set("Location",Qo.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let d=o.length;if(d>0){let u=l.headers;u||(l.headers=u=new uo);for(let _=0;_<d;){let E=o[_++];u.set(E,o[_++])}}return o=null,l}a(c,"applyResponseHeaders")}function uce({server:e,port:t}){e.http(Wk,{port:t||"all"}),qk||(qk=!0,setInterval(()=>{Hc=new Map},Ss.get(Ar.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),Yk.user.addListener(()=>{Hc=new Map}))}async function dce(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 _ce(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var $k,Up,Vk,Ss,Ar,Lu,Yk,py,nce,sce,ice,oce,Gk,Mp,Kk,ace,cce,Hc,qk,vp=Ce(()=>{$k=B(vn());Vr();B_();Up=B(ef());Le();Vk=require("uuid"),Ss=B(te()),Ar=B(M()),Lu=B(V()),Yk=B(a_());Nf();Mu();py=(0,Lu.loggerWithTag)("auth-event");Ss.initSync();nce=Ss.get(Ar.CONFIG_PARAMS.HTTP_CORSACCESSLIST),sce=Ss.get(Ar.CONFIG_PARAMS.HTTP_CORS),ice=Ss.get(Ar.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),oce=Ss.get(Ar.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),Gk=ft({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Mp=Ss.get(Ar.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,Kk=process.env.AUTHENTICATION_AUTHORIZELOCAL??Ss.get(Ar.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,ace=Ss.get(Ar.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,cce=Ss.get(Ar.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Hc=new Map;nt.onInvalidatedUser(()=>{Hc=new Map});a(lce,"bypassAuth");a(Wk,"authentication");a(uce,"start");a(dce,"login");a(_ce,"logout")});var eG=b((eDe,Zk)=>{"use strict";var be=require("joi"),jk=require("fs-extra"),Qk=require("path"),qn=dt(),zk=te(),Jk=M(),Xk=V(),{hdb_errors:fce}=ce(),{HDB_ERROR_MSGS:Pr}=fce,_o=/^[a-zA-Z0-9-_]+$/,Ece=/^[a-zA-Z0-9-_]+$/;Zk.exports={getDropCustomFunctionValidator:mce,setCustomFunctionValidator:pce,addComponentValidator:Rce,dropCustomFunctionProjectValidator:Ace,packageComponentValidator:Oce,deployComponentValidator:bce,setComponentFileValidator:Sce,getComponentFileValidator:gce,dropComponentFileValidator:Tce,addSSHKeyValidator:yce,updateSSHKeyValidator:Nce,deleteSSHKeyValidator:Ice,setSSHKnownHostsValidator:wce};function Bp(e,t,r){try{let n=zk.get(Jk.CONFIG_PARAMS.COMPONENTSROOT),s=Qk.join(n,t);return jk.existsSync(s)?e?t:r.message(Pr.PROJECT_EXISTS):e?r.message(Pr.NO_PROJECT):t}catch(n){return Xk.error(n),r.message(Pr.VALIDATION_ERR)}}a(Bp,"checkProjectExists");function wf(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(wf,"checkFilePath");function hce(e,t,r,n){try{let s=zk.get(Jk.CONFIG_PARAMS.COMPONENTSROOT),i=Qk.join(s,e,t,r+".js");return jk.existsSync(i)?r:n.message(Pr.NO_FILE)}catch(s){return Xk.error(s),n.message(Pr.VALIDATION_ERR)}}a(hce,"checkFileExists");function mce(e){let t=be.object({project:be.string().pattern(_o).custom(Bp.bind(null,!0)).required().messages({"string.pattern.base":Pr.BAD_PROJECT_NAME}),type:be.string().valid("helpers","routes").required(),file:be.string().pattern(_o).custom(hce.bind(null,e.project,e.type)).custom(wf).required().messages({"string.pattern.base":Pr.BAD_FILE_NAME})});return qn.validateBySchema(e,t)}a(mce,"getDropCustomFunctionValidator");function pce(e){let t=be.object({project:be.string().pattern(_o).custom(Bp.bind(null,!0)).required().messages({"string.pattern.base":Pr.BAD_PROJECT_NAME}),type:be.string().valid("helpers","routes").required(),file:be.string().custom(wf).required(),function_content:be.string().required()});return qn.validateBySchema(e,t)}a(pce,"setCustomFunctionValidator");function Sce(e){let t=be.object({project:be.string().pattern(_o).required().messages({"string.pattern.base":Pr.BAD_PROJECT_NAME}),file:be.string().custom(wf).required(),payload:be.string().allow("").optional(),encoding:be.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return qn.validateBySchema(e,t)}a(Sce,"setComponentFileValidator");function Tce(e){let t=be.object({project:be.string().pattern(_o).required().messages({"string.pattern.base":Pr.BAD_PROJECT_NAME}),file:be.string().custom(wf).optional()});return qn.validateBySchema(e,t)}a(Tce,"dropComponentFileValidator");function gce(e){let t=be.object({project:be.string().required(),file:be.string().custom(wf).required(),encoding:be.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return qn.validateBySchema(e,t)}a(gce,"getComponentFileValidator");function Rce(e){let t=be.object({project:be.string().pattern(_o).custom(Bp.bind(null,!1)).required().messages({"string.pattern.base":Pr.BAD_PROJECT_NAME})});return qn.validateBySchema(e,t)}a(Rce,"addComponentValidator");function Ace(e){let t=be.object({project:be.string().pattern(_o).custom(Bp.bind(null,!0)).required().messages({"string.pattern.base":Pr.BAD_PROJECT_NAME})});return qn.validateBySchema(e,t)}a(Ace,"dropCustomFunctionProjectValidator");function Oce(e){let t=be.object({project:be.string().pattern(_o).required().messages({"string.pattern.base":Pr.BAD_PROJECT_NAME}),skip_node_modules:be.boolean()});return qn.validateBySchema(e,t)}a(Oce,"packageComponentValidator");function bce(e){let t=be.object({project:be.string().pattern(_o).required().messages({"string.pattern.base":Pr.BAD_PROJECT_NAME}),payload:be.string().optional().messages({"string.pattern.base":Pr.BAD_PACKAGE}),package:be.string().optional(),restart:be.boolean().optional()});return qn.validateBySchema(e,t)}a(bce,"deployComponentValidator");function yce(e){let t=be.object({name:be.string().pattern(Ece).required().messages({"string.pattern.base":Pr.BAD_SSH_KEY_NAME}),key:be.string().required(),host:be.string().required(),hostname:be.string().required(),known_hosts:be.string().optional()});return qn.validateBySchema(e,t)}a(yce,"addSSHKeyValidator");function Nce(e){let t=be.object({name:be.string().required(),key:be.string().required()});return qn.validateBySchema(e,t)}a(Nce,"updateSSHKeyValidator");function Ice(e){let t=be.object({name:be.string().required()});return qn.validateBySchema(e,t)}a(Ice,"deleteSSHKeyValidator");function wce(e){let t=be.object({known_hosts:be.string().required()});return qn.validateBySchema(e,t)}a(wce,"setSSHKnownHostsValidator")});var Gp=b((rDe,oG)=>{"use strict";var Hp=require("joi"),Fc=require("path"),Fp=require("fs-extra"),{exec:Cce}=require("child_process"),Dce=require("util"),tG=Dce.promisify(Cce),Bu=M(),{handleHDBError:Uu,hdb_errors:Pce}=ce(),{HTTP_STATUS_CODES:vu}=Pce,xu=te(),Lce=dt(),Hu=V();xu.initSync();var Sy=xu.get(Bu.CONFIG_PARAMS.COMPONENTSROOT),rG="npm install --omit=dev --json",Mce=`${rG} --dry-run`,Uce=xu.get(Bu.CONFIG_PARAMS.ROOTPATH),xp=Fc.join(Uce,"ssh");oG.exports={installModules:xce,auditModules:Fce,installAllRootModules:vce,uninstallRootModule:Bce,linkHarperdb:Hce};async function vce(e=!1){await kp();let t=!1,r=process.env;Fp.pathExistsSync(xp)&&Fp.readdirSync(xp).forEach(n=>{n.includes(".key")&&!t&&(r={GIT_SSH_COMMAND:"ssh -F "+Fc.join(xp,"config")+" -o UserKnownHostsFile="+Fc.join(xp,"known_hosts"),...process.env},t=!0)}),await Cf(e?"npm install --ignore-scripts":"npm install",xu.get(Bu.CONFIG_PARAMS.ROOTPATH),r)}a(vce,"installAllRootModules");async function Bce(e){await Cf(`npm uninstall ${e}`,xu.get(Bu.CONFIG_PARAMS.ROOTPATH))}a(Bce,"uninstallRootModule");async function Hce(){await kp(),await Cf(`npm link ${Bu.PACKAGE_ROOT}`,xu.get(Bu.CONFIG_PARAMS.ROOTPATH))}a(Hce,"linkHarperdb");async function Cf(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await tG(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
17
- `,""))}return s&&!s.includes("Debugger listening")&&Hu.error("Error running NPM command:",e,s),Hu.trace(n,s),n?.replace(`
18
- `,"")}a(Cf,"runCommand");async function xce(e){Hu.info(`starting installModules for request: ${e}`);let t=iG(e);if(t)throw Uu(t,t.message,vu.BAD_REQUEST);let{projects:r,dry_run:n}=e,s=n===!0?Mce:rG;await kp(),await sG(r);let i={};for(let o=0,c=r.length;o<c;o++){let l=r[o];i[l]={npm_output:null,npm_error:null};let d=Fc.join(Sy,l),u,_=null;try{let{stdout:E,stderr:f}=await tG(s,{cwd:d});u=E?E.replace(`
19
- `,""):null,_=f?f.replace(`
20
- `,""):null}catch(E){E.stderr?i[l].npm_error=nG(E.stderr):i[l].npm_error=E.message;continue}try{i[l].npm_output=JSON.parse(u)}catch{i[l].npm_output=u}try{i[l].npm_error=JSON.parse(_)}catch{i[l].npm_error=_}}return Hu.info(`finished installModules with response ${i}`),i}a(xce,"installModules");function nG(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
21
- `);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(nG,"parseNPMStdErr");async function Fce(e){Hu.info(`starting auditModules for request: ${e}`);let t=iG(e);if(t)throw Uu(t,t.message,vu.BAD_REQUEST);let{projects:r}=e;await kp(),await sG(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=Fc.join(Sy,o);n[o]={npm_output:null,npm_error:null};try{let l=await Cf("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=nG(l.stderr)}}return Hu.info(`finished auditModules with response ${n}`),n}a(Fce,"auditModules");async function kp(){try{return await Cf("npm -v"),!0}catch{throw Uu(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",vu.BAD_REQUEST,void 0,void 0,!0)}}a(kp,"checkNPMInstalled");async function sG(e){if(!Array.isArray(e)||e.length===0)throw Uu(new Error,"projects argument must be an array with at least 1 element",vu.BAD_REQUEST,void 0,void 0,!0);let t=[],r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n],o=Fc.join(Sy,i.toString());if(!await Fp.pathExists(o)){t.push(i);continue}let l=Fc.join(o,"package.json");await Fp.pathExists(l)||r.push(i)}if(t.length>0)throw Uu(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,vu.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw Uu(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,vu.BAD_REQUEST,void 0,void 0,!0)}a(sG,"checkProjectPaths");function iG(e){let t=Hp.object({projects:Hp.array().min(1).items(Hp.string()).required(),dry_run:Hp.boolean().default(!1)});return Lce.validateBySchema(e,t)}a(iG,"modulesValidator")});var gy=b((sDe,dG)=>{"use strict";var Fu=require("fs-extra"),Ty=require("path"),qp=V(),aG=ee(),$p=M(),uG=te(),kce=It();dG.exports=Gce;async function Gce(){let e=qce(),t=uG.get($p.CONFIG_PARAMS.ROOTPATH),r=Ty.join(t,"package.json"),n={dependencies:{harperdb:"file:"+$p.PACKAGE_ROOT}},s=Ty.join(t,"node_modules");Fu.ensureDirSync(s);let i,o=!0,c=!1;try{i=Fu.readJsonSync(r)}catch(l){if(aG.isEmptyOrZeroLength(e))return;if(l.code!==$p.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!aG.isEmptyOrZeroLength(e)){for(let{name:l,package:d}of e){let u=cG(d);n.dependencies[l]=u+d}if(!o){qp.notify("Installing components"),await lG(r,n,null);return}for(let{name:l,package:d}of e){let u=i.dependencies[l],_=cG(d);if(u===void 0||u!==_+d){c=!0;break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(qp.notify("Removing component",l),c=!0);c&&(qp.notify("Updating components."),await lG(r,n,i))}a(Gce,"installComponents");function qce(){let e=kce.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(qce,"getComponentsConfig");function cG(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Ty.extname(e)||Fu.existsSync(e)?"file:":"github:"}a(cG,"getPkgPrefix");async function lG(e,t,r){qp.trace("npm installing components package.json",t),Fu.writeFileSync(e,JSON.stringify(t,null," "));try{await Gp().installAllRootModules(uG.get($p.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Fu.writeFileSync(e,JSON.stringify(r,null," ")):Fu.unlinkSync(e),n}}a(lG,"installPackages")});var Oy=b(hG=>{"use strict";var Ae=require("fs-extra"),Ry=require("fast-glob"),Ie=require("path"),fG=require("tar-fs"),$ce=require("gunzip-maybe"),oDe=require("uuid").v4,Ay=require("normalize-path"),Tn=eG(),kt=V(),mt=M(),Xt=te(),Df=It(),Vce=ee(),{PACKAGE_ROOT:Yce}=M(),{handleHDBError:Gt,hdb_errors:Kce}=ce(),{basename:Wce}=require("path"),jce=gy(),EG=te(),Qce=M(),{Readable:zce}=require("stream"),{isMainThread:Jce}=require("worker_threads"),{HDB_ERROR_MSGS:kc,HTTP_STATUS_CODES:qt}=Kce,Xce=st(),{replicateOperation:js}=(as(),ie(ta)),Zce=Ie.join(Yce,"application-template"),_G=Ie.join(Xt.get(mt.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp"),ele=Xt.get(mt.CONFIG_PARAMS.ROOTPATH),Ea=Ie.join(ele,"ssh"),fo=Ie.join(Ea,"known_hosts");function tle(){kt.trace("getting custom api status");let e={};try{e={port:Xt.get(mt.CONFIG_PARAMS.HTTP_PORT),directory:Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Gt(new Error,kc.FUNCTION_STATUS,qt.INTERNAL_SERVER_ERROR,kt.ERR,t)}return e}a(tle,"customFunctionsStatus");function rle(){kt.trace("getting custom api endpoints");let e={},t=Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT);try{Ry.sync(Ay(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:Ry.sync(Ay(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:Ry.sync(Ay(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Gt(new Error,kc.GET_FUNCTIONS,qt.INTERNAL_SERVER_ERROR,kt.ERR,r)}return e}a(rle,"getCustomFunctions");function nle(e){e.project&&(e.project=Ie.parse(e.project).name),e.file&&(e.file=Ie.parse(e.file).name);let t=Tn.getDropCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);kt.trace("getting custom api endpoint file content");let r=Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=Ie.join(r,n,s,i+".js");try{return Ae.readFileSync(o,{encoding:"utf8"})}catch(c){throw Gt(new Error,kc.GET_FUNCTION,qt.INTERNAL_SERVER_ERROR,kt.ERR,c)}}a(nle,"getCustomFunction");async function sle(e){e.project&&(e.project=Ie.parse(e.project).name),e.file&&(e.file=Ie.parse(e.file).name);let t=Tn.setCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);kt.trace("setting custom function file content");let r=Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Ae.outputFileSync(Ie.join(r,n,s,i+".js"),o);let c=await js(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Gt(new Error,kc.SET_FUNCTION,qt.INTERNAL_SERVER_ERROR,kt.ERR,c)}}a(sle,"setCustomFunction");async function ile(e){e.project&&(e.project=Ie.parse(e.project).name),e.file&&(e.file=Ie.parse(e.file).name);let t=Tn.getDropCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);kt.trace("dropping custom function file");let r=Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Ae.unlinkSync(Ie.join(r,n,s,i+".js"));let o=await js(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Gt(new Error,kc.DROP_FUNCTION,qt.INTERNAL_SERVER_ERROR,kt.ERR,o)}}a(ile,"dropCustomFunction");async function ole(e){e.project&&(e.project=Ie.parse(e.project).name);let t=Tn.addComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);kt.trace("adding component");let r=Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=Ie.join(r,n);Ae.mkdirSync(s,{recursive:!0}),Ae.copySync(Zce,s);let i=await js(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Gt(new Error,kc.ADD_FUNCTION,qt.INTERNAL_SERVER_ERROR,kt.ERR,s)}}a(ole,"addComponent");async function ale(e){e.project&&(e.project=Ie.parse(e.project).name);let t=Tn.dropCustomFunctionProjectValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);kt.trace("dropping custom function project");let r=Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Xt.get(mt.CONFIG_PARAMS.APPS);if(!Vce.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 Df.updateConfigValue(mt.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=Ie.join(r,n);Ae.rmSync(i,{recursive:!0});let o=await js(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Gt(new Error,kc.DROP_FUNCTION_PROJECT,qt.INTERNAL_SERVER_ERROR,kt.ERR,i)}}a(ale,"dropCustomFunctionProject");async function cle(e){e.project&&(e.project=Ie.parse(e.project).name);let t=Tn.packageComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;kt.trace("packaging component",n);let s;try{s=await Ae.realpath(Ie.join(r,n))}catch(l){if(l.code!==mt.NODE_ERROR_CODES.ENOENT)throw l;try{s=await Ae.realpath(Ie.join(Xt.get(mt.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(d){if(d.code===mt.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}await Ae.ensureDir(_G);let i=Ie.join(_G,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:l=>l.includes(Ie.join(s,"node_modules"))}),fG.pack(s,o).pipe(Ae.createWriteStream(i,{overwrite:!0})),await new Promise(l=>setTimeout(l,2e3));let c=Ae.readFileSync(i,{encoding:"base64"});return await Ae.remove(i),{project:n,payload:c}}a(cle,"packageComponent");async function lle(e){e.project&&(e.project=Ie.parse(e.project).name);let t=Tn.deployComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i}=e;if(kt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let o;if(s){o=Ie.join(r,n),i="file:"+o,await Ae.emptyDir(o);let f=zce.from(Buffer.from(s,"base64"));await new Promise((p,T)=>{f.pipe($ce()).pipe(fG.extract(o,{finish:p})).on("error",T)});let h=await Ae.readdir(o);h.length===1&&h[0]==="package"&&(await Ae.copy(Ie.join(o,"package"),o),await Ae.remove(Ie.join(o,"package")))}if(await Df.addConfig(n,{package:i}),!s){await jce();let f=EG.get(Qce.CONFIG_PARAMS.ROOTPATH);o=Ie.join(f,"node_modules",n)}if(Jce)return;let c=new Map;c.isWorker=!0;let l=(Lf(),ie(Pf)),d;l.setErrorReporter(f=>d=f);let u=Wce(o),_=l.component_errors.get(u);try{await l.loadComponent(o,c)}finally{l.component_errors.set(u,_)}if(d)throw d;kt.info("Installed component");let E=await js(e);return e.restart===!0?(Xce.restartWorkers("http"),E.message=`Successfully deployed: ${n}, restarting HarperDB`):E.message=`Successfully deployed: ${n}`,E}a(lle,"deployComponent");async function ule(){let e=Df.getConfiguration(),t=[];for(let o in e)if(e[o]?.package){if(e[o].package.startsWith("file:"))continue;t.push({...e[o],name:o})}let r=a(async(o,c)=>{try{let l=await Ae.readdir(o,{withFileTypes:!0});for(let d of l){let u=d.name;if(u.startsWith(".")||u==="node_modules")continue;let _=Ie.join(o,u);if(d.isDirectory()||d.isSymbolicLink()){let E={name:u,entries:[]};c.entries.push(E),await r(_,E)}else{let E=await Ae.stat(_),f={name:Ie.basename(u),mtime:E.mtime,size:E.size};c.entries.push(f)}}return c}catch(l){return kt.warn("Error loading package",l),{error:l.toString(),entries:[]}}},"walk_dir"),n=await r(Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),{name:Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT).split(Ie.sep).slice(-1).pop(),entries:t});for(let o of n.entries)if(o.package){let c=await r(Ie.join(Xt.get(mt.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(Lf(),ie(Pf)).component_errors;for(let o of t){let c=i.get(o.name);c?o.error=i.get(o.name):c===void 0&&(o.error="The component has not been loaded yet (may need a restart)")}return n}a(ule,"getComponents");async function dle(e){let t=Tn.getComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let n=Df.getConfigObj()[e.project]||e.project==="harperdb"?Ie.join(EG.get(mt.CONFIG_PARAMS.ROOTPATH),"node_modules"):Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Ae.stat(Ie.join(n,e.project,e.file));return{message:await Ae.readFile(Ie.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===mt.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${Ie.join(e.project,e.file)}'`):i}}a(dle,"getComponentFile");async function _le(e){let t=Tn.setComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=Ie.join(Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Ae.ensureFile(n),await Ae.outputFile(n,e.payload,r)):await Ae.ensureDir(n);let s=await js(e);return s.message="Successfully set component: "+e.file,s}a(_le,"setComponentFile");async function fle(e){let t=Tn.dropComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=e.file?Ie.join(e.project,e.file):e.project,n=Ie.join(Xt.get(mt.CONFIG_PARAMS.COMPONENTSROOT),r);await Ae.pathExists(n)&&await Ae.remove(n),Df.deleteConfigFromFile([e.project]);let s=await js(e);return s.message="Successfully dropped: "+r,s}a(fle,"dropComponent");async function Ele(e){let t=Tn.addSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;kt.trace("adding ssh key",r);let c=Ie.join(Ea,r+".key"),l=Ie.join(Ea,"config");if(await Ae.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Ae.outputFile(c,n),await Ae.chmod(c,"0600");let d=`#${r}
17
+ Database backup has not been removed and can be found here: ${s}`;gf.error(l),console.error(l)}(0,sO.get)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Bc.remove)(s))}(0,iO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1)}async function SF(e){let t=await(0,AF.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function bF(e,t){console.log("copyDb start");let r=mt()[e],n;for(let _ in r){n=r[_].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,TF.open)(new gF.default(t)),c=o.openDB(wp.INTERNAL_DBIS_NAME),l,d=0,u=s.useReadTransaction();try{for(let{key:f,value:h}of s.getRange({transaction:u})){let T=h.is_hash_attribute||h.isPrimaryKey,S,R;if(T&&(S=h.compression,R=Cp(),R?h.compression=R:delete h.compression,S?.dictionary?.toString()===R?.dictionary?.toString()&&(S=null,R=null)),c.put(f,h),!(T||h.indexed))continue;let p=new RF.default(!T,T);p.encoding="binary",p.compression=S;let y=n.openDB(f,p);y.decoder=null,p.compression=R;let O=o.openDB(f,p);O.encoder=null,console.log("copying",f,"from",e,"to",t),await E(y,O,T,u)}let _=n.openDB(wp.AUDIT_STORE_NAME,Rf);console.log("copying audit log"),E(i,_,!1,u);async function E(f,h,T,S){let R=0,p=0;for(let{key:y,value:O,version:B}of f.getRange({start:null,versions:T,transaction:S}))l=h.put(y,O,B),R++,S.openTimer&&(S.openTimer=0),p+=(y?.length||10)+O.length,d++>5e3&&(await l,console.log("copied",R,"entries",p,"bytes"),d=0);console.log("finish copying, copied",R,"entries",p,"bytes")}a(E,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{u.done(),o.close()}}var TF,Ip,Bc,sO,gF,RF,wp,ma,AF,iO,gf,aO=De(()=>{Le();TF=require("lmdb"),Ip=require("path"),Bc=require("fs-extra"),sO=v(te()),gF=v(Qd()),RF=v(jd()),wp=v(Bt()),ma=v(M());Ki();AF=v(fi()),iO=v(wt()),gf=v(V());a(Bae,"compactOnStart");a(SF,"getTotalDBRecordCount");a(bF,"copyDb")});var Lu=b((qCe,DF)=>{"use strict";var Hae=require("minimist"),{isMainThread:lO,parentPort:bf,threadId:kCe}=require("worker_threads"),Pt=M(),{PROCESS_DESCRIPTORS_VALIDATE:Du}=Pt,Ni=V(),uO=J(),Pp=Ap(),Dp=kt(),FCe=dt(),IF=wt(),Ii=Tf(),yF=gu(),{compactOnStart:xae}=(aO(),oe(oO)),kae=qa(),{restartWorkers:Lp,onMessageByType:Fae}=it(),{handleHDBError:Gae,hdb_errors:qae}=fe(),{HTTP_STATUS_CODES:$ae}=qae,yf=te(),{sendOperationToNode:OF,getThisNodeName:Vae,monitorNodeCAs:Yae}=(ls(),oe(sa)),{getHDBNodeTable:GCe}=(nu(),oe(dB));yf.initSync();var Af=`Restarting HarperDB. This may take up to ${Pt.RESTART_TIMEOUT_MS/1e3} seconds.`,Kae="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",NF="Clustering is not enabled so cannot be restarted",Wae="Invalid service",Pu,Ts;DF.exports={restart:wF,restartService:dO};lO&&Fae(Pt.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await dO({service:e.workerType}):wF({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function wF(e){Ts=Object.keys(e).length===0,Pu=await Ii.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR);let t=Hae(process.argv);if(t.service){await dO(t);return}if(Ts&&!Pu){console.error(Kae);return}if(Ts&&console.log(Af),Pu){Ii.enterPM2Mode(),Ni.notify(Af);let r=kae(Object.keys(Pt.CONFIG_PARAM_MAP),!0);return uO.isEmptyOrZeroLength(Object.keys(r))||IF.updateConfigValue(void 0,void 0,r,!0,!0),jae(),Af}return lO?(Ni.notify(Af),yf.get(Pt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await xae(),setTimeout(()=>{Lp()},50)):bf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART}),Af}a(wF,"restart");async function dO(e){let{service:t}=e;if(Pt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw Gae(new Error,Wae,$ae.BAD_REQUEST,void 0,void 0,!0);if(Pu=await Ii.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR),!lO){e.replicated&&Yae(),bf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART,workerType:t}),bf.ref(),await new Promise(s=>{bf.on("message",i=>{i.type==="restart-complete"&&(s(),bf.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===Vae())continue;let{job_id:i}=await OF(s,e);n.push(await new Promise((o,c)=>{let d=2400,u=setInterval(async()=>{if(d--<=0){clearInterval(u);let f=new Error("Timed out waiting for restart job to complete");f.replicated=n,c(f)}let E=(await OF(s,{operation:"get_job",id:i})).results[0];if(E.status==="COMPLETE"&&(clearInterval(u),o({node:s.name,message:E.message})),E.status==="ERROR"){clearInterval(u);let f=new Error(E.message);f.replicated=n,c(f)}},250)}))}return{replicated:n}}return}let r;switch(t){case Du.clustering:if(!yf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=NF;break}Ts&&console.log("Restarting clustering"),Ni.notify("Restarting clustering"),await CF();break;case Du.clustering_config:case Du["clustering config"]:if(!yf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=NF;break}Ts&&console.log("Restarting clustering_config"),Ni.notify("Restarting clustering_config"),await Ii.reloadClustering();break;case"custom_functions":case"custom functions":case Du.harperdb:case Du.http_workers:case Du.http:if(Ts&&!Pu){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Ts&&console.log("Restarting http_workers"),Ni.notify("Restarting http_workers"),Ts?await Ii.restart(Pt.HDB_PROC_DESCRIPTOR):await Lp("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Ni.error(r),Ts&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(dO,"restartService");async function jae(){await CF(),await Ii.restart(Pt.HDB_PROC_DESCRIPTOR),await uO.async_set_timeout(2e3),yf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await cO(),Ts&&(await Dp.closeConnection(),process.exit(0))}a(jae,"restartPM2Mode");async function CF(){if(!IF.getConfigFromFile(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await yF.getHDBProcessInfo()).clustering.length===0)Ni.trace("Clustering not running, restart will start clustering services"),await Pp.generateNatsConfig(!0),await Ii.startClusteringProcesses(),await Ii.startClusteringThreads(),await cO(),Ts&&await Dp.closeConnection();else{await Pp.generateNatsConfig(!0),Pu?(Ni.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await Ii.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Ii.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await yF.getHDBProcessInfo()).clustering.forEach(s=>{Ni.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await uO.async_set_timeout(3e3),await cO(),await Dp.updateLocalStreams(),Ts&&await Dp.closeConnection(),Ni.trace("Restart clustering restarting ingest and reply service threads");let t=Lp(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=Lp(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(CF,"restartClustering");async function cO(){await Pp.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Pp.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(cO,"removeNatsConfig")});var GF=b((YCe,FF)=>{"use strict";var VCe=require("lodash"),Sn=M(),{handleHDBError:PF,hdb_errors:Qae}=fe(),{HDB_ERROR_MSGS:zae,HTTP_STATUS_CODES:Jae}=Qae,_O=V();FF.exports={getRolePermissions:Zae};var Hc=Object.create(null),Xae=a(e=>({key:e,perms:{}}),"perms_template_obj"),vF=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),BF=a((e=!1,t=!1,r=!1,n=!1)=>({[Sn.PERMS_CRUD_ENUM.READ]:e,[Sn.PERMS_CRUD_ENUM.INSERT]:t,[Sn.PERMS_CRUD_ENUM.UPDATE]:r,[Sn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),fO=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...BF(t,r,n,s)}),"table_perms_template"),LF=a((e,t=BF())=>({attribute_name:e,describe:kF(t),[Of]:t[Of],[EO]:t[EO],[hO]:t[hO]}),"attr_perms_template"),MF=a((e,t=!1)=>({attribute_name:e,describe:t,[Of]:t}),"timestamp_attr_perms_template"),{READ:Of,INSERT:EO,UPDATE:hO}=Sn.PERMS_CRUD_ENUM,HF=Object.values(Sn.PERMS_CRUD_ENUM),xF=[Of,EO,hO];function Zae(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[Sn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Hc[t]&&Hc[t].key===n)return Hc[t].perms;let s=ece(e,r);return Hc[t]?Hc[t].key=n:Hc[t]=Xae(n),Hc[t].perms=s,s}catch(r){if(!e[Sn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Sn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Sn.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw _O.error(n),_O.debug(r),PF(new Error,zae.OUTDATED_PERMS_TRANSLATION_ERROR,Jae.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
18
+ ${r.stack}`;throw _O.error(n),PF(new Error)}}}a(Zae,"getRolePermissions");function ece(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Sn.SYSTEM_SCHEMA_NAME]=n[Sn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=tce(t[i]);return}r[i]=vF(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],d=rce(c,l);r[i].describe||HF.forEach(u=>{d[u]&&(r[i].describe=!0)}),r[i].tables[o]=d}else r[i].tables[o]=fO()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=fO()})}),r}a(ece,"translateRolePermissions");function tce(e){let t=vF(!0);return Object.keys(e).forEach(r=>{t.tables[r]=fO(!0,!0,!0,!0,!0)}),t}a(tce,"createStructureUserPermissions");function rce(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((d,u)=>{let{attribute_name:_}=u,E=u;return Sn.TIME_STAMP_NAMES.includes(_)&&(E=MF(_,u[Of])),d[_]=E,d},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=LF(o);return t.attributes.forEach(({attribute:d})=>{if(i[d]){let u=i[d];u.describe=kF(u),s.attribute_permissions.push(u),c||nce(u,l)}else if(d!==o){let u;Sn.TIME_STAMP_NAMES.includes(d)?u=MF(d):u=LF(d),s.attribute_permissions.push(u)}}),c||s.attribute_permissions.push(l),s.describe=UF(s),s}else return e.describe=UF(e),e}a(rce,"getTableAttrPerms");function UF(e){return HF.filter(t=>e[t]).length>0}a(UF,"getSchemaTableDescribePerm");function kF(e){return xF.filter(t=>e[t]).length>0}a(kF,"getAttributeDescribePerm");function nce(e,t){xF.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(nce,"checkForHashPerms")});var qF={};et(qF,{Headers:()=>_o,appendHeader:()=>mO,mergeHeaders:()=>pO});function mO(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function pO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new _o(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var _o,Nf=De(()=>{_o=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(mO,"appendHeader");a(pO,"mergeHeaders")});var If={};et(If,{authentication:()=>QF,bypassAuth:()=>uce,login:()=>_ce,logout:()=>fce,start:()=>dce});function uce(){jF=!0}async function QF(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?ace?oce:[]:ice?sce:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new _o([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Mp&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Mp&&o.push("Access-Control-Allow-Credentials","true")}}let l,d;if(Mp){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let T of h)if(T.startsWith(f)){let S=T.indexOf(";");l=T.slice(f.length,S===-1?T.length:S),d=await $F.get(l);break}e.session=d||(d={})}let u=a((f,h,T)=>{let S=new Mu.AuthAuditLog(f,h,Ar.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);S.auth_strategy=T,l&&(S.session_id=l),r.referer&&(S.referer=r.referer),r.origin&&(S.origin=r.origin),h===Ar.AUTH_AUDIT_STATUS.SUCCESS?SO.notify(S):SO.error(S)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&SO.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await st.getUser(f,null,null),u(f,Ar.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,Mu.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=xc.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),T=n.slice(f+1),S,R;try{switch(h){case"Basic":let p=atob(T),y=p.indexOf(":");S=p.slice(0,y),R=p.slice(y+1),_=S||R?await st.getUser(S,R,e):null;break;case"Bearer":try{_=await(0,Up.validateOperationToken)(T)}catch(O){if(O.message==="invalid token")try{return await(0,Up.validateRefreshToken)(T),c({status:-1})}catch{throw O}}break}}catch(p){return lce&&(xc.get(T)||(xc.set(T,T),u(S,Ar.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:kc({error:p.message},e)})}xc.set(n,_),cce&&u(_.username,Ar.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=_}else d?.user?e.user=await st.getUser(d.user,null,e):(jF&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,YF.getSuperUser)());Mp&&(e.session.update=function(f){if(!l){l=(0,KF.v4)();let T=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",T):E?.headers?.set&&E.headers.set("Set-Cookie",T)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,$F.put(f)},e.login=async function(f,h){e.user=await st.getUser(f,h,e),e.session.update({user:e.user.username})});let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&ea.loginPath?(E.status=302,E.headers.set("Location",ea.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let d=o.length;if(d>0){let u=l.headers;u||(l.headers=u=new _o);for(let _=0;_<d;){let E=o[_++];u.set(E,o[_++])}}return o=null,l}a(c,"applyResponseHeaders")}function dce({server:e,port:t}){e.http(QF,{port:t||"all"}),VF||(VF=!0,setInterval(()=>{xc=new Map},gs.get(Ar.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),WF.user.addListener(()=>{xc=new Map}))}async function _ce(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password),"Login successful"}async function fce(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var YF,Up,KF,gs,Ar,Mu,WF,SO,sce,ice,oce,ace,$F,Mp,jF,cce,lce,xc,VF,vp=De(()=>{YF=v(vn());$r();B_();Up=v(ef());Le();KF=require("uuid"),gs=v(te()),Ar=v(M()),Mu=v(V()),WF=v(a_());Nf();Uu();SO=(0,Mu.loggerWithTag)("auth-event");gs.initSync();sce=gs.get(Ar.CONFIG_PARAMS.HTTP_CORSACCESSLIST),ice=gs.get(Ar.CONFIG_PARAMS.HTTP_CORS),oce=gs.get(Ar.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),ace=gs.get(Ar.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),$F=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Mp=gs.get(Ar.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,jF=process.env.AUTHENTICATION_AUTHORIZELOCAL??gs.get(Ar.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,cce=gs.get(Ar.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,lce=gs.get(Ar.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,xc=new Map;st.onInvalidatedUser(()=>{xc=new Map});a(uce,"bypassAuth");a(QF,"authentication");a(dce,"start");a(_ce,"login");a(fce,"logout")});var rG=b((eDe,tG)=>{"use strict";var be=require("joi"),zF=require("fs-extra"),JF=require("path"),qn=ut(),XF=te(),ZF=M(),eG=V(),{hdb_errors:Ece}=fe(),{HDB_ERROR_MSGS:Lr}=Ece,fo=/^[a-zA-Z0-9-_]+$/,hce=/^[a-zA-Z0-9-_]+$/;tG.exports={getDropCustomFunctionValidator:pce,setCustomFunctionValidator:Sce,addComponentValidator:Ace,dropCustomFunctionProjectValidator:bce,packageComponentValidator:yce,deployComponentValidator:Oce,setComponentFileValidator:Tce,getComponentFileValidator:Rce,dropComponentFileValidator:gce,addSSHKeyValidator:Nce,updateSSHKeyValidator:Ice,deleteSSHKeyValidator:wce,setSSHKnownHostsValidator:Cce};function Bp(e,t,r){try{let n=XF.get(ZF.CONFIG_PARAMS.COMPONENTSROOT),s=JF.join(n,t);return zF.existsSync(s)?e?t:r.message(Lr.PROJECT_EXISTS):e?r.message(Lr.NO_PROJECT):t}catch(n){return eG.error(n),r.message(Lr.VALIDATION_ERR)}}a(Bp,"checkProjectExists");function wf(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(wf,"checkFilePath");function mce(e,t,r,n){try{let s=XF.get(ZF.CONFIG_PARAMS.COMPONENTSROOT),i=JF.join(s,e,t,r+".js");return zF.existsSync(i)?r:n.message(Lr.NO_FILE)}catch(s){return eG.error(s),n.message(Lr.VALIDATION_ERR)}}a(mce,"checkFileExists");function pce(e){let t=be.object({project:be.string().pattern(fo).custom(Bp.bind(null,!0)).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),type:be.string().valid("helpers","routes").required(),file:be.string().pattern(fo).custom(mce.bind(null,e.project,e.type)).custom(wf).required().messages({"string.pattern.base":Lr.BAD_FILE_NAME})});return qn.validateBySchema(e,t)}a(pce,"getDropCustomFunctionValidator");function Sce(e){let t=be.object({project:be.string().pattern(fo).custom(Bp.bind(null,!0)).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),type:be.string().valid("helpers","routes").required(),file:be.string().custom(wf).required(),function_content:be.string().required()});return qn.validateBySchema(e,t)}a(Sce,"setCustomFunctionValidator");function Tce(e){let t=be.object({project:be.string().pattern(fo).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),file:be.string().custom(wf).required(),payload:be.string().allow("").optional(),encoding:be.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return qn.validateBySchema(e,t)}a(Tce,"setComponentFileValidator");function gce(e){let t=be.object({project:be.string().pattern(fo).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),file:be.string().custom(wf).optional()});return qn.validateBySchema(e,t)}a(gce,"dropComponentFileValidator");function Rce(e){let t=be.object({project:be.string().required(),file:be.string().custom(wf).required(),encoding:be.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return qn.validateBySchema(e,t)}a(Rce,"getComponentFileValidator");function Ace(e){let t=be.object({project:be.string().pattern(fo).custom(Bp.bind(null,!1)).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME})});return qn.validateBySchema(e,t)}a(Ace,"addComponentValidator");function bce(e){let t=be.object({project:be.string().pattern(fo).custom(Bp.bind(null,!0)).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME})});return qn.validateBySchema(e,t)}a(bce,"dropCustomFunctionProjectValidator");function yce(e){let t=be.object({project:be.string().pattern(fo).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),skip_node_modules:be.boolean()});return qn.validateBySchema(e,t)}a(yce,"packageComponentValidator");function Oce(e){let t=be.object({project:be.string().pattern(fo).required().messages({"string.pattern.base":Lr.BAD_PROJECT_NAME}),payload:be.string().optional().messages({"string.pattern.base":Lr.BAD_PACKAGE}),package:be.string().optional(),restart:be.boolean().optional()});return qn.validateBySchema(e,t)}a(Oce,"deployComponentValidator");function Nce(e){let t=be.object({name:be.string().pattern(hce).required().messages({"string.pattern.base":Lr.BAD_SSH_KEY_NAME}),key:be.string().required(),host:be.string().required(),hostname:be.string().required(),known_hosts:be.string().optional()});return qn.validateBySchema(e,t)}a(Nce,"addSSHKeyValidator");function Ice(e){let t=be.object({name:be.string().required(),key:be.string().required()});return qn.validateBySchema(e,t)}a(Ice,"updateSSHKeyValidator");function wce(e){let t=be.object({name:be.string().required()});return qn.validateBySchema(e,t)}a(wce,"deleteSSHKeyValidator");function Cce(e){let t=be.object({known_hosts:be.string().required()});return qn.validateBySchema(e,t)}a(Cce,"setSSHKnownHostsValidator")});var Gp=b((rDe,cG)=>{"use strict";var Hp=require("joi"),Fc=require("path"),kp=require("fs-extra"),{exec:Dce}=require("child_process"),Pce=require("util"),nG=Pce.promisify(Dce),Hu=M(),{handleHDBError:vu,hdb_errors:Lce}=fe(),{HTTP_STATUS_CODES:Bu}=Lce,ku=te(),Mce=ut(),xu=V();ku.initSync();var TO=ku.get(Hu.CONFIG_PARAMS.COMPONENTSROOT),sG="npm install --omit=dev --json",Uce=`${sG} --dry-run`,vce=ku.get(Hu.CONFIG_PARAMS.ROOTPATH),xp=Fc.join(vce,"ssh");cG.exports={installModules:kce,auditModules:Fce,installAllRootModules:Bce,uninstallRootModule:Hce,linkHarperdb:xce};async function Bce(e=!1){await Fp();let t=!1,r=process.env;kp.pathExistsSync(xp)&&kp.readdirSync(xp).forEach(n=>{n.includes(".key")&&!t&&(r={GIT_SSH_COMMAND:"ssh -F "+Fc.join(xp,"config")+" -o UserKnownHostsFile="+Fc.join(xp,"known_hosts"),...process.env},t=!0)}),await Cf(e?"npm install --ignore-scripts":"npm install",ku.get(Hu.CONFIG_PARAMS.ROOTPATH),r)}a(Bce,"installAllRootModules");async function Hce(e){await Cf(`npm uninstall ${e}`,ku.get(Hu.CONFIG_PARAMS.ROOTPATH))}a(Hce,"uninstallRootModule");async function xce(){await Fp(),await Cf(`npm link ${Hu.PACKAGE_ROOT}`,ku.get(Hu.CONFIG_PARAMS.ROOTPATH))}a(xce,"linkHarperdb");async function Cf(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await nG(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
19
+ `,""))}return s&&!s.includes("Debugger listening")&&xu.error("Error running NPM command:",e,s),xu.trace(n,s),n?.replace(`
20
+ `,"")}a(Cf,"runCommand");async function kce(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";xu.warn(t,e);let r=aG(e);if(r)throw vu(r,r.message,Bu.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?Uce:sG;await Fp(),await oG(n);let o={};for(let c=0,l=n.length;c<l;c++){let d=n[c];o[d]={npm_output:null,npm_error:null};let u=Fc.join(TO,d),_,E=null;try{let{stdout:f,stderr:h}=await nG(i,{cwd:u});_=f?f.replace(`
21
+ `,""):null,E=h?h.replace(`
22
+ `,""):null}catch(f){f.stderr?o[d].npm_error=iG(f.stderr):o[d].npm_error=f.message;continue}try{o[d].npm_output=JSON.parse(_)}catch{o[d].npm_output=_}try{o[d].npm_error=JSON.parse(E)}catch{o[d].npm_error=E}}return xu.info(`finished installModules with response ${o}`),o.warning=t,o}a(kce,"installModules");function iG(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
23
+ `);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(iG,"parseNPMStdErr");async function Fce(e){xu.info(`starting auditModules for request: ${e}`);let t=aG(e);if(t)throw vu(t,t.message,Bu.BAD_REQUEST);let{projects:r}=e;await Fp(),await oG(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=Fc.join(TO,o);n[o]={npm_output:null,npm_error:null};try{let l=await Cf("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=iG(l.stderr)}}return xu.info(`finished auditModules with response ${n}`),n}a(Fce,"auditModules");async function Fp(){try{return await Cf("npm -v"),!0}catch{throw vu(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Bu.BAD_REQUEST,void 0,void 0,!0)}}a(Fp,"checkNPMInstalled");async function oG(e){if(!Array.isArray(e)||e.length===0)throw vu(new Error,"projects argument must be an array with at least 1 element",Bu.BAD_REQUEST,void 0,void 0,!0);let t=[],r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n],o=Fc.join(TO,i.toString());if(!await kp.pathExists(o)){t.push(i);continue}let l=Fc.join(o,"package.json");await kp.pathExists(l)||r.push(i)}if(t.length>0)throw vu(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Bu.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw vu(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Bu.BAD_REQUEST,void 0,void 0,!0)}a(oG,"checkProjectPaths");function aG(e){let t=Hp.object({projects:Hp.array().min(1).items(Hp.string()).required(),dry_run:Hp.boolean().default(!1)});return Mce.validateBySchema(e,t)}a(aG,"modulesValidator")});var RO=b((sDe,fG)=>{"use strict";var pa=require("fs-extra"),gO=require("path"),Df=V(),lG=J(),qp=M(),_G=te(),Gce=wt();fG.exports=qce;async function qce(){let e=$ce(),t=_G.get(qp.CONFIG_PARAMS.ROOTPATH),r=gO.join(t,"package.json"),n={dependencies:{harperdb:"file:"+qp.PACKAGE_ROOT}},s=gO.join(t,"node_modules");pa.ensureDirSync(s);let i,o=!0,c=!1;try{i=pa.readJsonSync(r)}catch(l){if(lG.isEmptyOrZeroLength(e))return;if(l.code!==qp.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!lG.isEmptyOrZeroLength(e)){for(let{name:l,package:d}of e){let u=uG(d);n.dependencies[l]=u+d}if(!o){Df.notify("Installing components"),await dG(r,n,null);return}for(let{name:l,package:d}of e){let u=i.dependencies[l],_=uG(d);if(u===void 0||u!==_+d){c=!0;break}if(d.startsWith("file:"))try{if(pa.statSync(new URL(d+"/package.json")).mtimeMs>pa.statSync(r).mtimeMs){c=!0;break}}catch(E){Df.info(`Error checking ${d}/package.json modification time`,E);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Df.notify("Removing component",l),c=!0);c&&(Df.notify("Updating components."),await dG(r,n,i))}a(qce,"installComponents");function $ce(){let e=Gce.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a($ce,"getComponentsConfig");function uG(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":gO.extname(e)||pa.existsSync(e)?"file:":"github:"}a(uG,"getPkgPrefix");async function dG(e,t,r){Df.trace("npm installing components package.json",t),pa.writeFileSync(e,JSON.stringify(t,null," "));try{await Gp().installAllRootModules(_G.get(qp.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?pa.writeFileSync(e,JSON.stringify(r,null," ")):pa.unlinkSync(e),n}}a(dG,"installPackages")});var yO=b(pG=>{"use strict";var Ae=require("fs-extra"),AO=require("fast-glob"),Ce=require("path"),hG=require("tar-fs"),Vce=require("gunzip-maybe"),oDe=require("uuid").v4,bO=require("normalize-path"),Tn=rG(),Ft=V(),pt=M(),Xt=te(),Pf=wt(),Yce=J(),{PACKAGE_ROOT:Kce}=M(),{handleHDBError:Gt,hdb_errors:Wce}=fe(),{basename:jce}=require("path"),Qce=RO(),mG=te(),zce=M(),{Readable:Jce}=require("stream"),{isMainThread:Xce}=require("worker_threads"),{HDB_ERROR_MSGS:Gc,HTTP_STATUS_CODES:qt}=Wce,Zce=it(),{replicateOperation:zs}=(ls(),oe(sa)),ele=Ce.join(Kce,"application-template"),EG=Ce.join(Xt.get(pt.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp"),tle=Xt.get(pt.CONFIG_PARAMS.ROOTPATH),Sa=Ce.join(tle,"ssh"),Eo=Ce.join(Sa,"known_hosts");function rle(){Ft.trace("getting custom api status");let e={};try{e={port:Xt.get(pt.CONFIG_PARAMS.HTTP_PORT),directory:Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Gt(new Error,Gc.FUNCTION_STATUS,qt.INTERNAL_SERVER_ERROR,Ft.ERR,t)}return e}a(rle,"customFunctionsStatus");function nle(){Ft.trace("getting custom api endpoints");let e={},t=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT);try{AO.sync(bO(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:AO.sync(bO(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:AO.sync(bO(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Gt(new Error,Gc.GET_FUNCTIONS,qt.INTERNAL_SERVER_ERROR,Ft.ERR,r)}return e}a(nle,"getCustomFunctions");function sle(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Tn.getDropCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("getting custom api endpoint file content");let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=Ce.join(r,n,s,i+".js");try{return Ae.readFileSync(o,{encoding:"utf8"})}catch(c){throw Gt(new Error,Gc.GET_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,c)}}a(sle,"getCustomFunction");async function ile(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Tn.setCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("setting custom function file content");let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Ae.outputFileSync(Ce.join(r,n,s,i+".js"),o);let c=await zs(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Gt(new Error,Gc.SET_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,c)}}a(ile,"setCustomFunction");async function ole(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Tn.getDropCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("dropping custom function file");let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Ae.unlinkSync(Ce.join(r,n,s,i+".js"));let o=await zs(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Gt(new Error,Gc.DROP_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,o)}}a(ole,"dropCustomFunction");async function ale(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Tn.addComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("adding component");let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=Ce.join(r,n);Ae.mkdirSync(s,{recursive:!0}),Ae.copySync(ele,s);let i=await zs(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Gt(new Error,Gc.ADD_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,s)}}a(ale,"addComponent");async function cle(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Tn.dropCustomFunctionProjectValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("dropping custom function project");let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Xt.get(pt.CONFIG_PARAMS.APPS);if(!Yce.isEmptyOrZeroLength(s)){let i=!1;for(let[o,c]of s.entries())if(c.name===n){s.splice(o,1),i=!0;break}if(i)return Pf.updateConfigValue(pt.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=Ce.join(r,n);Ae.rmSync(i,{recursive:!0});let o=await zs(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Gt(new Error,Gc.DROP_FUNCTION_PROJECT,qt.INTERNAL_SERVER_ERROR,Ft.ERR,i)}}a(cle,"dropCustomFunctionProject");async function lle(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Tn.packageComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ft.trace("packaging component",n);let s;try{s=await Ae.realpath(Ce.join(r,n))}catch(l){if(l.code!==pt.NODE_ERROR_CODES.ENOENT)throw l;try{s=await Ae.realpath(Ce.join(Xt.get(pt.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(d){if(d.code===pt.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}await Ae.ensureDir(EG);let i=Ce.join(EG,`${n}.tar`),o={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(o={ignore:l=>l.includes(Ce.join(s,"node_modules"))}),hG.pack(s,o).pipe(Ae.createWriteStream(i,{overwrite:!0})),await new Promise(l=>setTimeout(l,2e3));let c=Ae.readFileSync(i,{encoding:"base64"});return await Ae.remove(i),{project:n,payload:c}}a(lle,"packageComponent");async function ule(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Tn.deployComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i}=e;if(Ft.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let o;if(s){o=Ce.join(r,n),i="file:"+o,await Ae.emptyDir(o);let h=Jce.from(Buffer.from(s,"base64"));await new Promise((S,R)=>{h.pipe(Vce()).pipe(hG.extract(o,{finish:S})).on("error",R)});let T=await Ae.readdir(o);T.length===1&&T[0]==="package"&&(await Ae.copy(Ce.join(o,"package"),o),await Ae.remove(Ce.join(o,"package")))}await Pf.addConfig(n,{package:i}),await Qce();let c=mG.get(zce.CONFIG_PARAMS.ROOTPATH);if(o=Ce.join(c,"node_modules",n),Xce)return;let l=new Map;l.isWorker=!0;let d=(Mf(),oe(Lf)),u;d.setErrorReporter(h=>u=h);let _=jce(o),E=d.component_errors.get(_);try{await d.loadComponent(o,l)}finally{d.component_errors.set(_,E)}if(u)throw u;Ft.info("Installed component");let f=await zs(e);return e.restart===!0?(Zce.restartWorkers("http"),f.message=`Successfully deployed: ${n}, restarting HarperDB`):f.message=`Successfully deployed: ${n}`,f}a(ule,"deployComponent");async function dle(){let e=Pf.getConfiguration(),t=[];for(let o in e)if(e[o]?.package){if(e[o].package.startsWith("file:"))continue;t.push({...e[o],name:o})}let r=a(async(o,c)=>{try{let l=await Ae.readdir(o,{withFileTypes:!0});for(let d of l){let u=d.name;if(u.startsWith(".")||u==="node_modules")continue;let _=Ce.join(o,u);if(d.isDirectory()||d.isSymbolicLink()){let E={name:u,entries:[]};c.entries.push(E),await r(_,E)}else{let E=await Ae.stat(_),f={name:Ce.basename(u),mtime:E.mtime,size:E.size};c.entries.push(f)}}return c}catch(l){return Ft.warn("Error loading package",l),{error:l.toString(),entries:[]}}},"walk_dir"),n=await r(Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),{name:Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT).split(Ce.sep).slice(-1).pop(),entries:t});for(let o of n.entries)if(o.package){let c=await r(Ce.join(Xt.get(pt.CONFIG_PARAMS.ROOTPATH),"node_modules",o.name),{name:o.name,entries:[]});Object.assign(o,c)}let i=(Mf(),oe(Lf)).component_errors;for(let o of t){let c=i.get(o.name);c?o.error=i.get(o.name):c===void 0&&(o.error="The component has not been loaded yet (may need a restart)")}return n}a(dle,"getComponents");async function _le(e){let t=Tn.getComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let n=Pf.getConfigObj()[e.project]||e.project==="harperdb"?Ce.join(mG.get(pt.CONFIG_PARAMS.ROOTPATH),"node_modules"):Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Ae.stat(Ce.join(n,e.project,e.file));return{message:await Ae.readFile(Ce.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===pt.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${Ce.join(e.project,e.file)}'`):i}}a(_le,"getComponentFile");async function fle(e){let t=Tn.setComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=Ce.join(Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Ae.ensureFile(n),await Ae.outputFile(n,e.payload,r)):await Ae.ensureDir(n);let s=await zs(e);return s.message="Successfully set component: "+e.file,s}a(fle,"setComponentFile");async function Ele(e){let t=Tn.dropComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=e.file?Ce.join(e.project,e.file):e.project,n=Ce.join(Xt.get(pt.CONFIG_PARAMS.COMPONENTSROOT),r);await Ae.pathExists(n)&&await Ae.remove(n),Pf.deleteConfigFromFile([e.project]);let s=await zs(e);return s.message="Successfully dropped: "+r,s}a(Ele,"dropComponent");async function hle(e){let t=Tn.addSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Ft.trace("adding ssh key",r);let c=Ce.join(Sa,r+".key"),l=Ce.join(Sa,"config");if(await Ae.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Ae.outputFile(c,n),await Ae.chmod(c,"0600");let d=`#${r}
22
24
  Host ${s}
23
25
  HostName ${i}
24
26
  User git
25
27
  IdentityFile ${c}
26
28
  IdentitiesOnly yes`;await Ae.pathExists(l)?await Ae.appendFile(l,`
27
- `+d):await Ae.outputFile(l,d);let u="";if(await Ae.pathExists(fo)||(await Ae.writeFile(fo,""),await Ae.chmod(fo,"0600")),i=="github.com"&&!(await Ae.readFile(fo,"utf8")).includes("github.com"))try{let p=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let T of p)Ae.appendFile(fo,"github.com "+T+`
28
- `)}catch{u=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Ae.appendFile(fo,o);let _=await js(e);return _.message=`Added ssh key: ${r}${u}`,_}a(Ele,"addSSHKey");async function hle(e){let t=Tn.updateSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r,key:n}=e;kt.trace("updating ssh key",r);let s=Ie.join(Ea,r+".key");if(!await Ae.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Ae.outputFile(s,n);let i=await js(e);return i.message=`Updated ssh key: ${r}`,i}a(hle,"updateSSHKey");async function mle(e){let t=Tn.deleteSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r}=e;kt.trace("deleting ssh key",r);let n=Ie.join(Ea,r+".key"),s=Ie.join(Ea,"config");if(!await Ae.pathExists(n))throw new Error("Key does not exist");let i=await Ae.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Ae.outputFile(s,i),Ae.removeSync(n);let c=await js(e);return c.message=`Deleted ssh key: ${r}`,c}a(mle,"deleteSSHKey");async function ple(e){let t=[];return await Ae.pathExists(Ea)&&(await Ae.readdir(Ea)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(ple,"listSSHKeys");async function Sle(e){let t=Tn.setSSHKnownHostsValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{known_hosts:r}=e;await Ae.outputFile(fo,r);let n=await js(e);return n.message="Known hosts successfully set",n}a(Sle,"setSSHKnownHosts");async function Tle(e){return await Ae.pathExists(fo)?{known_hosts:await Ae.readFile(fo,"utf8")}:{known_hosts:null}}a(Tle,"getSSHKnownHosts");Object.assign(hG,{customFunctionsStatus:tle,getCustomFunctions:rle,getCustomFunction:nle,setCustomFunction:sle,dropCustomFunction:ile,addComponent:ole,dropCustomFunctionProject:ale,packageComponent:cle,deployComponent:lle,getComponents:ule,getComponentFile:dle,setComponentFile:_le,dropComponent:fle,addSSHKey:Ele,updateSSHKey:hle,deleteSSHKey:mle,listSSHKeys:ple,setSSHKnownHosts:Sle,getSSHKnownHosts:Tle})});var by=b((lDe,pG)=>{"use strict";var Ts=require("joi"),mG=dt();pG.exports={readTransactionLogValidator:gle,deleteTransactionLogsBeforeValidator:Rle};function gle(e){let t=Ts.object({schema:Ts.string(),database:Ts.string(),table:Ts.string().required(),from:Ts.date().timestamp(),to:Ts.date().timestamp(),limit:Ts.number().min(1)});return mG.validateBySchema(e,t)}a(gle,"readTransactionLogValidator");function Rle(e){let t=Ts.object({schema:Ts.string(),database:Ts.string(),table:Ts.string().required(),timestamp:Ts.date().timestamp().required()});return mG.validateBySchema(e,t)}a(Rle,"deleteTransactionLogsBeforeValidator")});var Kp=b((dDe,OG)=>{"use strict";var yy=M(),Mf=Ft(),SG=ee(),TG=te(),gG=Ji(),RG=V(),{handleHDBError:Vp,hdb_errors:Ale}=ce(),{HTTP_STATUS_CODES:Yp}=Ale,{readTransactionLogValidator:Ole,deleteTransactionLogsBeforeValidator:ble}=by(),AG=Pn(),yle="Logs successfully deleted from transaction log.",Nle="All logs successfully deleted from transaction log.";OG.exports={readTransactionLog:Ile,deleteTransactionLogsBefore:Cle};async function Ile(e){let t=Ole(e);if(t)throw Vp(t,t.message,Yp.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=SG.checkSchemaTableExist(e.database,e.table);if(r)throw Vp(new Error,r,Yp.NOT_FOUND,void 0,void 0,!0);return TG.get(yy.CONFIG_PARAMS.CLUSTERING_ENABLED)?await wle(e):(RG.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)),AG.readAuditLog(e))}a(Ile,"readTransactionLog");async function*wle(e){let t=gG.createNatsTableStreamName(e.database,e.table),r=await Mf.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===yy.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(wle,"readTransactionLogNats");async function Cle(e){let t=ble(e);if(t)throw Vp(t,t.message,Yp.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!TG.get(yy.CONFIG_PARAMS.CLUSTERING_ENABLED))return RG.info("Delete transaction logs called for Plexus"),AG.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=SG.checkSchemaTableExist(r,n);if(i)throw Vp(new Error,i,Yp.NOT_FOUND,void 0,void 0,!0);let o=gG.createNatsTableStreamName(r,n),{jsm:c}=await Mf.getNATSReferences(),l=await Mf.getStreamInfo(o),d=new Date(l.state.first_ts).getTime();if(s<=d)return`No transactions exist before: ${s}`;let u=yle,_,E=new Date(l.state.last_ts).getTime();return s>E?(_=l.state.last_seq+1,u=Nle):_=(await Mf.viewStream(o,parseInt(s),1))[0].nats_sequence,await Mf.purgeTableStream(r,n,{seq:_}),u}a(Cle,"deleteTransactionLogsBefore")});var yG=b((fDe,bG)=>{"use strict";var Ny=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}};bG.exports=Ny});var IG=b((hDe,NG)=>{"use strict";var Iy=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};NG.exports=Iy});var Cy=b((pDe,CG)=>{"use strict";var wG=yG(),Dle=IG(),{HDB_ERROR_MSGS:Ple}=Nn(),wy=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=Ple.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 wG(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new Dle(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 wG(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}};CG.exports=wy});var zp=b((RDe,KG)=>{"use strict";var Dy=Kr(),Wp=Yr(),Rs=j_(),Bf=Ei(),Py=qo(),Lle=kO(),Mle=LH(),Hf=vn(),jp=Jm(),Er=V(),Ule=JO(),vle=dp(),Ble=Pb(),Hle=fp(),xle=Ub(),Fle=vb(),kle=xb(),Gle=kb(),Ly=pp(),Eo=ee(),qle=UF(),My=Wb(),LG=Pu(),gs=M(),MG=Fk(),$le=pu(),UG=ef(),vG=(vp(),ie(If)),BG=It(),ir=Oy(),Vle=require("alasql"),HG=Kp(),xG=Gp(),xf=Ks(),FG=(Pc(),ie(Dc)),kG=Cy(),{handleHDBError:gn,hdb_errors:GG}=ce(),{addNodeBack:TDe,removeNodeBack:gDe}=(Pc(),ie(Dc)),{HDB_ERROR_MSGS:Lr,HTTP_STATUS_CODES:Uf}=GG,W=new Map,qG="delete",ha="insert",ho="read",Gc="update",vf="describe",DG=Bf.describeSchema.name,PG=Bf.describeTable.name,$G={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},Yle="catchup",Kle="handleGetJob",Wle="handleGetJobsByStartDate",Qp={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},jle=[Rs.createTable.name,Rs.createAttribute.name,Rs.dropTable.name,Rs.dropAttribute.name],VG={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},J=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};W.set(Dy.insert.name,new J(!1,[ha]));W.set(Dy.update.name,new J(!1,[Gc]));W.set(Dy.upsert.name,new J(!1,[ha,Gc]));W.set(Wp.searchByConditions.name,new J(!1,[ho]));W.set(Wp.searchByHash.name,new J(!1,[ho]));W.set(Wp.searchByValue.name,new J(!1,[ho]));W.set(Wp.search.name,new J(!1,[ho]));W.set(Rs.createSchema.name,new J(!0,[]));W.set(Rs.createTable.name,new J(!0,[]));W.set(Rs.createAttribute.name,new J(!1,[ha]));W.set(Rs.dropSchema.name,new J(!0,[]));W.set(Rs.dropTable.name,new J(!0,[]));W.set(Rs.dropAttribute.name,new J(!0,[]));W.set(Bf.describeSchema.name,new J(!1,[ho]));W.set(Bf.describeTable.name,new J(!1,[ho]));W.set(Py.deleteRecord.name,new J(!1,[qG]));W.set(Hf.addUser.name,new J(!0,[]));W.set(Hf.alterUser.name,new J(!0,[]));W.set(Hf.dropUser.name,new J(!0,[]));W.set(Hf.listUsersExternal.name,new J(!0,[]));W.set(jp.listRoles.name,new J(!0,[]));W.set(jp.addRole.name,new J(!0,[]));W.set(jp.alterRole.name,new J(!0,[]));W.set(jp.dropRole.name,new J(!0,[]));W.set(Ule.name,new J(!0,[]));W.set(vle.name,new J(!0,[]));W.set(Ble.name,new J(!0,[]));W.set(Hle.name,new J(!0,[]));W.set(xle.name,new J(!0,[]));W.set(Fle.name,new J(!0,[]));W.set(Ly.setRoutes.name,new J(!0,[]));W.set(Ly.getRoutes.name,new J(!0,[]));W.set(Ly.deleteRoutes.name,new J(!0,[]));W.set(BG.setConfiguration.name,new J(!0,[]));W.set(kle.clusterStatus.name,new J(!0,[]));W.set(Gle.name,new J(!0,[]));W.set(My.getFingerprint.name,new J(!0,[]));W.set(My.setLicense.name,new J(!0,[]));W.set(Py.deleteFilesBefore.name,new J(!0,[]));W.set(Py.deleteAuditLogsBefore.name,new J(!0,[]));W.set(LG.restart.name,new J(!0,[]));W.set(LG.restartService.name,new J(!0,[]));W.set(Lle.name,new J(!0,[]));W.set(Mle.name,new J(!0,[ho]));W.set($le.systemInformation.name,new J(!0,[]));W.set(BG.getConfiguration.name,new J(!0,[]));W.set(HG.readTransactionLog.name,new J(!0,[]));W.set(HG.deleteTransactionLogsBefore.name,new J(!0,[]));W.set(xG.installModules.name,new J(!0,[]));W.set(xG.auditModules.name,new J(!0,[]));W.set(xf.createCsr.name,new J(!0,[]));W.set(xf.signCertificate.name,new J(!0,[]));W.set(xf.listCertificates.name,new J(!0,[]));W.set(xf.addCertificate.name,new J(!0,[]));W.set(xf.removeCertificate.name,new J(!0,[]));W.set(FG.addNodeBack.name,new J(!0,[]));W.set(FG.removeNodeBack.name,new J(!0,[]));W.set(UG.createTokens.name,new J(!1,[]));W.set(UG.refreshOperationToken.name,new J(!1,[]));W.set(vG.login.name,new J(!1,[]));W.set(vG.logout.name,new J(!1,[]));W.set(ir.customFunctionsStatus.name,new J(!0,[]));W.set(ir.getCustomFunctions.name,new J(!0,[]));W.set(ir.getComponents.name,new J(!0,[]));W.set(ir.getComponentFile.name,new J(!0,[]));W.set(ir.setComponentFile.name,new J(!0,[]));W.set(ir.dropComponent.name,new J(!0,[]));W.set(ir.getCustomFunction.name,new J(!0,[]));W.set(ir.setCustomFunction.name,new J(!0,[]));W.set(ir.dropCustomFunction.name,new J(!0,[]));W.set(ir.addComponent.name,new J(!0,[]));W.set(ir.dropCustomFunctionProject.name,new J(!0,[]));W.set(ir.packageComponent.name,new J(!0,[]));W.set(ir.deployComponent.name,new J(!0,[]));W.set(ir.addSSHKey.name,new J(!0,[]));W.set(ir.updateSSHKey.name,new J(!0,[]));W.set(ir.deleteSSHKey.name,new J(!0,[]));W.set(ir.listSSHKeys.name,new J(!0,[]));W.set(ir.setSSHKnownHosts.name,new J(!0,[]));W.set(ir.getSSHKnownHosts.name,new J(!0,[]));W.set(My.getRegistrationInfo.name,new J(!1,[]));W.set(Hf.userInfo.name,new J(!1,[]));W.set(Bf.describeAll.name,new J(!1,[]));W.set(Kle,new J(!1,[]));W.set(Wle,new J(!0,[]));W.set(Yle,new J(!0,[]));W.set(Qp.CSV_DATA_LOAD,new J(!1,[ha,Gc]));W.set(Qp.CSV_URL_LOAD,new J(!1,[ha,Gc]));W.set(Qp.CSV_FILE_LOAD,new J(!1,[ha,Gc]));W.set(Qp.IMPORT_FROM_S3,new J(!1,[ha,Gc]));W.set(VG.EXPORT_TO_S3,new J(!0,[]));W.set(VG.EXPORT_LOCAL,new J(!0,[]));W.set(gs.VALID_SQL_OPS_ENUM.DELETE,new J(!1,[qG]));W.set(gs.VALID_SQL_OPS_ENUM.SELECT,new J(!1,[ho]));W.set(gs.VALID_SQL_OPS_ENUM.INSERT,new J(!1,[ha]));W.set(gs.VALID_SQL_OPS_ENUM.UPDATE,new J(!1,[Gc]));KG.exports={verifyPerms:zle,verifyPermsAst:Qle,verifyBulkLoadAttributePerms:Xle};function Qle(e,t,r){if(Eo.isEmptyOrZeroLength(e))throw Er.info("verify_perms_ast has an empty user parameter"),gn(new Error);if(Eo.isEmptyOrZeroLength(t))throw Er.info("verify_perms_ast has an empty user parameter"),gn(new Error);if(Eo.isEmptyOrZeroLength(r))throw Er.info("verify_perms_ast has a null operation parameter"),gn(new Error);try{let n=new kG,s=new qle(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Er.info("No schemas defined in verifyPermsAst(), will not continue."),gn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&$G[r])throw gn(new Error,Lr.DROP_SYSTEM,Uf.FORBIDDEN);if(c&&!l)return null;let d=MG.getRolePermissions(t.role);t.role.permission=d,!c&&e instanceof Vle.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(d));for(let _=0;_<i.length;_++){let E=s.getTablesBySchemaName(i[_]);E&&o.set(i[_],E)}let u=YG(t,r,o,n);return u||(o.forEach((_,E)=>{for(let f=0;f<_.length;f++){let h=s.getAttributesBySchemaTableName(E,_[f]),p=vy(t.role.permission,E,_[f]);Uy(h,p,r,_[f],E,n)}}),n.getPermsResponse())}catch(n){throw gn(n)}}a(Qle,"verifyPermsAst");function zle(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Er.info("null required parameter in verifyPerms"),gn(new Error,Lr.DEFAULT_INVALID_REQUEST,Uf.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 kG;if(Eo.isEmptyOrZeroLength(e.hdb_user.role)||Eo.isEmptyOrZeroLength(e.hdb_user.role.permission))return Er.info(`User ${e.hdb_user.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(Lr.USER_HAS_NO_PERMS(e.hdb_user.username));let l=!!e.hdb_user.role.permission.super_user,d=e.hdb_user.role.permission.structure_user,u=o.has(gs.SYSTEM_SCHEMA_NAME)||s===gs.SYSTEM_SCHEMA_NAME;if(u&&$G[r])throw gn(new Error,Lr.DROP_SYSTEM,Uf.FORBIDDEN);if(l&&!u||d===!0&&(r===Rs.createSchema.name||r===Rs.dropSchema.name))return null;if(jle.indexOf(r)>=0&&(d===!0||Array.isArray(d)))return d===!0||d.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let _=MG.getRolePermissions(e.hdb_user.role);if(e.hdb_user.role.permission=_,r===DG||r===PG){if(s===gs.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Lr.SCHEMA_PERM_ERROR(s));if(!_.super_user){if(r===DG&&(!_[s]||!_[s][vf]))return c.handleInvalidItem(Lr.SCHEMA_NOT_FOUND(s));if(r===PG&&(!_[s]||!_[s].tables[i]||!_[s].tables[i][vf]))return c.handleInvalidItem(Lr.TABLE_NOT_FOUND(s,i))}}let E=YG(e.hdb_user,r,o,c,n);if(E)return E;if(W.get(r)&&W.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&gs.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let p=[],T=_[s].tables[i];T[gs.PERMS_CRUD_ENUM.READ]&&(T.attribute_permissions.length>0?T.attribute_permissions.filter(S=>S[gs.PERMS_CRUD_ENUM.READ]).forEach(S=>{p.push(S.attribute_name)}):p=global.hdb_schema[s][i].attributes.map(g=>g.attribute),e.get_attributes=p)}let f=Jle(e),h=vy(e.hdb_user.role.permission,s,i);return Uy(f,h,r,i,s,c,n),c.getPermsResponse()}a(zle,"verifyPerms");function YG(e,t,r,n,s){if(Eo.arrayHasEmptyValues([e,t,r]))throw Er.info("hasPermissions has an invalid parameter"),gn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||W.get(t).requires_su))return null;if(!W.get(t))throw Er.info(`operation ${t} not found.`),gn(new Error,Lr.OP_NOT_FOUND(t),Uf.BAD_REQUEST);if(W.get(t)&&W.get(t).requires_su)return Er.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Lr.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][vf]===!1){n.addInvalidItem(Lr.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(Lr.SCHEMA_NOT_FOUND(l));continue}let d=r.get(l);for(let u of d){let _=o[l].tables[u];if(!_||_[vf]===!1)n.addInvalidItem(Lr.TABLE_NOT_FOUND(l,u));else try{let E=[],f=W.get(t).perms;!Eo.isEmpty(s)&&f.includes(s)&&(f=[s]);for(let h=0;h<f.length;h++){let p=f[h],T=_[p];(T==null||T===!1)&&(Er.info(`Required ${p} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),E.push(p))}E.length>0&&n.addUnauthorizedTable(l,u,E)}catch(E){let f=Lr.UNKNOWN_OP_AUTH_ERROR(t,l,u);throw Er.error(f),Er.error(E),gn(GG.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(YG,"hasPermissions");function Uy(e,t,r,n,s,i,o){if(!e||!t)throw Er.info("no attributes specified in checkAttributePerms."),gn(new Error);let c=W.get(r).perms;if(!c||c==="")throw Er.info(`no permissions found for ${r} in checkAttributePerms().`),gn(new Error);if(Eo.isEmptyOrZeroLength(t))return Er.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let u of e){let _=t.get(u);if(_){if(_[vf]===!1){i.addInvalidItem(Lr.ATTR_NOT_FOUND(s,n,u),s,n);continue}if(c)for(let E of c){if(gs.TIME_STAMP_NAMES.includes(_.attribute_name)&&E!==ho)throw gn(new Error,Lr.SYSTEM_TIMESTAMP_PERMS_ERR,Uf.FORBIDDEN);_[E]===!1&&(l[_.attribute_name]?l[_.attribute_name].push(E):l[_.attribute_name]=[E])}}else i.addInvalidItem(Lr.ATTR_NOT_FOUND(s,n,u),s,n)}let d=Object.keys(l);d.length>0&&i.addUnauthorizedAttributes(d,s,n,l)}a(Uy,"checkAttributePerms");function Jle(e){let t=new Set;try{if(e.action)return t;if(e.operation===gs.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){Er.info(r)}return t}a(Jle,"getRecordAttributes");function vy(e,t,r){let n=new Map;if(Eo.isEmpty(e))return Er.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{Er.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(vy,"getAttributePermissions");function Xle(e,t,r,n,s,i,o){let c=new Set(i),l=vy(e,n,s);Uy(c,l,t,s,n,o,r)}a(Xle,"verifyBulkLoadAttributePerms")});var Xp=b((ODe,JG)=>{"use strict";JG.exports={evaluateSQL:due,processAST:zG,convertSQLToAST:QG,checkASTPermissions:jG};var Zle=Kr(),WG=require("util"),eue=WG.callbackify(Zle.insert),tue=Yr().search,rue=zv().update,nue=WG.callbackify(rue),sue=Xv().convertDelete,ma=require("alasql"),iue=zp(),Jp=V(),oue=um(),aue=ee(),Ff=M(),{hdb_errors:cue,handleHDBError:By}=ce(),{HTTP_STATUS_CODES:Hy}=cue;oue(ma);var lue=403,uue="There was a problem performing this insert. Please check the logs and try again.",xy=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function due(e,t){let r=e.parsed_sql_object;if(!r){r=QG(e.sql);let n,s=r.ast.statements[0];if(s instanceof ma.yy.Insert?n=s.into.databaseid:s instanceof ma.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof ma.yy.Update||s instanceof ma.yy.Delete?n=s.table.databaseid:Jp.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof ma.yy.Select)&&aue.isEmptyOrZeroLength(n))return t("No schema specified",null)}zG(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(due,"evaluateSQL");function jG(e,t){let r;try{r=iue.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(jG,"checkASTPermissions");function QG(e){let t=new xy;if(!e)throw By(new Error,"The 'sql' parameter is missing from the request body",Hy.BAD_REQUEST);try{let r=e.trim(),n=ma.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
29
- `);throw n[1]?By(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,Hy.BAD_REQUEST):By(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",Hy.BAD_REQUEST)}return t}a(QG,"convertSQLToAST");function zG(e,t,r){try{let n=_ue;if(!e.bypass_auth&&!t.permissions_checked){let i=jG(e,t);if(i&&i.length>0)return r(lue,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case Ff.VALID_SQL_OPS_ENUM.SELECT:n=tue,s=t.ast.statements[0];break;case Ff.VALID_SQL_OPS_ENUM.INSERT:n=fue;break;case Ff.VALID_SQL_OPS_ENUM.UPDATE:n=nue;break;case Ff.VALID_SQL_OPS_ENUM.DELETE:n=sue;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(zG,"processAST");function _ue(e,t){Jp.info(e),t("unknown sql statement")}a(_ue,"nullFunction");function fue({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=Eue(i,e.values)}catch(o){return r(o)}eue(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){Jp.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(fue,"convertInsert");function Eue(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]]=ma.compile(`SELECT ${s.toString()} AS [${Ff.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw Jp.error(r),new Error(uue)}}a(Eue,"createDataObjects")});var Fy=b((yDe,ZG)=>{"use strict";var{S3:hue,GetObjectCommand:mue}=require("@aws-sdk/client-s3");ZG.exports={getFileStreamFromS3:pue,getS3AuthObj:XG};async function pue(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await XG(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new mue(r))).Body}a(pue,"getFileStreamFromS3");function XG(e,t,r){return new hue({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(XG,"getS3AuthObj")});var Zp=b((IDe,cq)=>{"use strict";var Gy=Yr(),Sue=Xp(),Tue=Fy(),{AsyncParser:gue,Transform:Rue}=require("json2csv"),Gf=require("stream"),$n=ee(),ky=require("fs-extra"),Aue=require("path"),As=V(),{promisify:rq}=require("util"),kf=ee(),{handleHDBError:or,hdb_errors:Oue}=ce(),{HDB_ERROR_MSGS:Rn,HTTP_STATUS_CODES:ar}=Oue,{streamAsJSON:bue}=(Ig(),ie(lD)),{Upload:yue}=require("@aws-sdk/lib-storage"),eq=["search_by_value","search_by_hash","sql","search_by_conditions"],tq=["json","csv"],nq="json",sq="csv",Nue="Successfully exported JSON locally.",Iue="Successfully exported CSV locally.",wue=1e3,Cue=Gy.searchByHash,Due=Gy.searchByValue,Pue=rq(Sue.evaluateSQL),Lue=rq(Gf.finished);cq.exports={export_to_s3:Bue,export_local:Mue,toCsvStream:iq};async function Mue(e){As.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=oq(e);if(!$n.isEmpty(t))throw As.error(t),or(new Error,t,ar.BAD_REQUEST,void 0,void 0,!0);if($n.isEmpty(e.path))throw As.error(Rn.MISSING_VALUE("path")),or(new Error,Rn.MISSING_VALUE("path"),ar.BAD_REQUEST,void 0,void 0,!0);let r=($n.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Aue.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=$n.buildFolderPath(e.path,r);await Uue(e.path);let s=await aq(e);return await vue(n,e.format,s)}a(Mue,"export_local");async function Uue(e){if(As.trace("in confirmPath"),$n.isEmptyOrZeroLength(e))throw or(new Error,`Invalid path: ${e}`,ar.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await ky.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,As.error(n),or(new Error,n,ar.BAD_REQUEST,void 0,void 0,!0)}if(!t.isDirectory()){let r=`path '${e}' is not a directory, please supply a valid folder path`;throw As.error(r),or(new Error,r,ar.BAD_REQUEST,void 0,void 0,!0)}return!0}a(Uue,"confirmPath");async function vue(e,t,r){if(As.trace("in saveToLocal"),kf.isEmptyOrZeroLength(e))throw or(new Error,Rn.INVALID_VALUE("file_path"),ar.BAD_REQUEST,void 0,void 0,!0);if(kf.isEmptyOrZeroLength(t))throw or(new Error,Rn.INVALID_VALUE("Source format"),ar.BAD_REQUEST,void 0,void 0,!0);if(kf.isEmpty(r))throw or(new Error,Rn.NOT_FOUND("Data"),ar.BAD_REQUEST,void 0,void 0,!0);if(t===nq){let n=ky.createWriteStream(e);return bue(r).pipe(n),await Lue(n),{message:Nue,path:e}}else if(t===sq){let n=ky.createWriteStream(e),s=Gf.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(u=>({label:u,value:u})));let c={objectMode:!0};return await new gue(i,c).fromInput(s).toOutput(n).promise(!1),{message:Iue,path:e}}throw or(new Error,Rn.INVALID_VALUE("format"),ar.BAD_REQUEST)}a(vue,"saveToLocal");async function Bue(e){if(!e.s3||Object.keys(e.s3).length===0)throw or(new Error,Rn.MISSING_VALUE("S3 object"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw or(new Error,Rn.MISSING_VALUE("aws_access_key_id"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw or(new Error,Rn.MISSING_VALUE("aws_secret_access_key"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.bucket))throw or(new Error,Rn.MISSING_VALUE("bucket"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.key))throw or(new Error,Rn.MISSING_VALUE("key"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.region))throw or(new Error,Rn.MISSING_VALUE("region"),ar.BAD_REQUEST);let t=oq(e);if(!$n.isEmpty(t))throw or(new Error,t,ar.BAD_REQUEST);As.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await aq(e)}catch(l){throw As.error(l),l}let n,s=await Tue.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new Gf.PassThrough;if(e.format===sq){i=e.s3.key+".csv";let l=iq(r,r.getColumns?.());l.on("error",d=>{throw d}),l.pipe(o)}else if(e.format===nq){i=e.s3.key+".json";let l=new Gf.Readable;l.pipe(o),l.on("error",_=>{throw _}),l.push("[");let d=r.length,u="";for(let[_,E]of r.entries()){let f=_===d-1?JSON.stringify(E):JSON.stringify(E)+",";u+=f,_!==0&&_%wue===0&&(l.push(u),u="")}u.length!==0&&l.push(u),l.push("]"),l.push(null)}else throw or(new Error,Rn.INVALID_VALUE("format"),ar.BAD_REQUEST);return new yue({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(Bue,"export_to_s3");function iq(e,t){let r=Gf.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 Rue(n,s);return r.pipe(i)}a(iq,"toCsvStream");function oq(e){if(As.trace("in exportCoreValidation"),$n.isEmpty(e.format))return"format missing";if(tq.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${tq.join(", ")}`;let t=e.search_operation.operation;if($n.isEmpty(t))return"search_operation.operation missing";if(eq.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${eq.join(", ")}`}a(oq,"exportCoreValidation");async function aq(e){As.trace("in getRecords");let t,r;if(kf.isEmpty(e.search_operation)||kf.isEmptyOrZeroLength(e.search_operation.operation))throw or(new Error,Rn.INVALID_VALUE("Search operation"),ar.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=Due;break;case"search_by_hash":t=Cue;break;case"search_by_conditions":t=Gy.searchByConditions;break;case"sql":t=Pue;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,As.error(r),or(new Error,r,ar.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(aq,"getRecords")});var Sq={};tt(Sq,{contentTypes:()=>Yy,findBestSerializer:()=>rS,getDeserializer:()=>$c,registerContentHandlers:()=>Ky,serialize:()=>Vf,serializeMessage:()=>xc});function Hue(e){try{return e?.[0]===123?Vy(e):e}catch{return e}}function Ky(e){e.register(Fue,{serializers:[{regex:/^application\/json$/,serializer:xd},{regex:/^application\/cbor$/,serializer:function(t){return new qc.EncoderStream($f).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?tS.Readable.from((0,Ci.encodeIter)(t,$f)):(0,Ci.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,eS.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Ci.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,qc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function rS(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[d,...u]=l.split(/\s*;\s*/),_=1,E={q:1};for(let h of u){let p=h.indexOf("=");E[h.substring(0,p)]=h.substring(p+1)}_=+E.q;let f=Or.get(d);if(f){let h=(f.q||1)*_;h>s&&(n=f,i=f.type||d,s=h,o=E)}}if(!n){if(r)throw new _q.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(Or.keys()).join(", "),406);n=Or.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Vf(e,t,r){let n=uq&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=rS(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}),hq.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>uq?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,mo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function xc(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return qf(e);let r=t.serialize;if(r)return r(e);let n=rS(t);return r=t.serialize=n.serializer.serialize,r(e)}function kue(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 $c(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=Or.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=Or.get(e)?.deserialize||dq(e,n);return o=>kue(o).then(i)}return e&&Or.get(e)?.deserialize||dq(e,n)}function dq(e,t){if(e.startsWith("text/")){let r=t?.match(/charset=(.+)/)?.[1]||"utf-8";return n=>({contentType:e,data:n.toString(r)})}else return e==="application/octet-stream"?r=>r:r=>{if(!e)try{if(r?.[0]===123)return Vy(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function Gue(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}var eS,Ci,qc,mo,_q,tS,fq,qy,$y,Eq,hq,mq,qf,Vy,$f,Or,Yy,lq,pq,xue,Fue,uq,Mu=Ce(()=>{Ig();eS=B(Zp()),Ci=require("msgpackr"),qc=require("cbor-x"),mo=require("zlib"),_q=B(ce()),tS=require("stream");Vr();fq=B(Yi()),qy=B(te()),$y=B(M()),Eq=B(require("yaml")),hq=B(Wl()),mq=qy.default.get($y.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,qf=mq?Ya:JSON.stringify,Vy=mq?Ng:JSON.parse,$f={useRecords:!1,useToJSON:!0},Or=new Map,Yy=Or;nt.contentTypes=Yy;(0,fq._assignPackageExport)("contentTypes",Yy);Or.set("application/json",{serializeStream:xd,serialize:qf,deserialize(e){return Vy(e)},q:.8});lq=new qc.Encoder($f);Or.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new qc.EncoderStream($f).end(e)},serialize:lq.encode,deserialize:lq.decode,q:1});Or.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?tS.Readable.from((0,Ci.encodeIter)(e,$f)):(0,Ci.pack)(e)},serialize:Ci.pack,deserialize:Ci.unpack,q:.9});Or.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,eS.toCsvStream)(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),(0,eS.toCsvStream)(e,e?.getColumns?.())},q:.1});Or.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});Or.set("text/yaml",{serialize(e){return Eq.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Or.set("text/event-stream",{serializeStream:function(e){return tS.Readable.from(Gue(e,this.serialize))},serialize:function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
30
- `),e.data){let r=e.data;typeof r=="object"&&(r=qf(r)),t+="data: "+r+`
29
+ `+d):await Ae.outputFile(l,d);let u="";if(await Ae.pathExists(Eo)||(await Ae.writeFile(Eo,""),await Ae.chmod(Eo,"0600")),i=="github.com"&&!(await Ae.readFile(Eo,"utf8")).includes("github.com"))try{let T=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let S of T)Ae.appendFile(Eo,"github.com "+S+`
30
+ `)}catch{u=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Ae.appendFile(Eo,o);let _=await zs(e);return _.message=`Added ssh key: ${r}${u}`,_}a(hle,"addSSHKey");async function mle(e){let t=Tn.updateSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r,key:n}=e;Ft.trace("updating ssh key",r);let s=Ce.join(Sa,r+".key");if(!await Ae.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Ae.outputFile(s,n);let i=await zs(e);return i.message=`Updated ssh key: ${r}`,i}a(mle,"updateSSHKey");async function ple(e){let t=Tn.deleteSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r}=e;Ft.trace("deleting ssh key",r);let n=Ce.join(Sa,r+".key"),s=Ce.join(Sa,"config");if(!await Ae.pathExists(n))throw new Error("Key does not exist");let i=await Ae.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Ae.outputFile(s,i),Ae.removeSync(n);let c=await zs(e);return c.message=`Deleted ssh key: ${r}`,c}a(ple,"deleteSSHKey");async function Sle(e){let t=[];return await Ae.pathExists(Sa)&&(await Ae.readdir(Sa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(Sle,"listSSHKeys");async function Tle(e){let t=Tn.setSSHKnownHostsValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{known_hosts:r}=e;await Ae.outputFile(Eo,r);let n=await zs(e);return n.message="Known hosts successfully set",n}a(Tle,"setSSHKnownHosts");async function gle(e){return await Ae.pathExists(Eo)?{known_hosts:await Ae.readFile(Eo,"utf8")}:{known_hosts:null}}a(gle,"getSSHKnownHosts");Object.assign(pG,{customFunctionsStatus:rle,getCustomFunctions:nle,getCustomFunction:sle,setCustomFunction:ile,dropCustomFunction:ole,addComponent:ale,dropCustomFunctionProject:cle,packageComponent:lle,deployComponent:ule,getComponents:dle,getComponentFile:_le,setComponentFile:fle,dropComponent:Ele,addSSHKey:hle,updateSSHKey:mle,deleteSSHKey:ple,listSSHKeys:Sle,setSSHKnownHosts:Tle,getSSHKnownHosts:gle})});var OO=b((lDe,TG)=>{"use strict";var Rs=require("joi"),SG=ut();TG.exports={readTransactionLogValidator:Rle,deleteTransactionLogsBeforeValidator:Ale};function Rle(e){let t=Rs.object({schema:Rs.string(),database:Rs.string(),table:Rs.string().required(),from:Rs.date().timestamp(),to:Rs.date().timestamp(),limit:Rs.number().min(1)});return SG.validateBySchema(e,t)}a(Rle,"readTransactionLogValidator");function Ale(e){let t=Rs.object({schema:Rs.string(),database:Rs.string(),table:Rs.string().required(),timestamp:Rs.date().timestamp().required()});return SG.validateBySchema(e,t)}a(Ale,"deleteTransactionLogsBeforeValidator")});var Yp=b((dDe,OG)=>{"use strict";var NO=M(),Uf=kt(),gG=J(),RG=te(),AG=zi(),bG=V(),{handleHDBError:$p,hdb_errors:ble}=fe(),{HTTP_STATUS_CODES:Vp}=ble,{readTransactionLogValidator:yle,deleteTransactionLogsBeforeValidator:Ole}=OO(),yG=Pn(),Nle="Logs successfully deleted from transaction log.",Ile="All logs successfully deleted from transaction log.";OG.exports={readTransactionLog:wle,deleteTransactionLogsBefore:Dle};async function wle(e){let t=yle(e);if(t)throw $p(t,t.message,Vp.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=gG.checkSchemaTableExist(e.database,e.table);if(r)throw $p(new Error,r,Vp.NOT_FOUND,void 0,void 0,!0);return RG.get(NO.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Cle(e):(bG.info("Reading HarperDB logs used by Plexus"),(e.from||e.to)&&(e.search_type="timestamp",e.search_values=[e.from??0],e.to&&(e.search_values[1]=e.to)),yG.readAuditLog(e))}a(wle,"readTransactionLog");async function*Cle(e){let t=AG.createNatsTableStreamName(e.database,e.table),r=await Uf.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===NO.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Cle,"readTransactionLogNats");async function Dle(e){let t=Ole(e);if(t)throw $p(t,t.message,Vp.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!RG.get(NO.CONFIG_PARAMS.CLUSTERING_ENABLED))return bG.info("Delete transaction logs called for Plexus"),yG.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=gG.checkSchemaTableExist(r,n);if(i)throw $p(new Error,i,Vp.NOT_FOUND,void 0,void 0,!0);let o=AG.createNatsTableStreamName(r,n),{jsm:c}=await Uf.getNATSReferences(),l=await Uf.getStreamInfo(o),d=new Date(l.state.first_ts).getTime();if(s<=d)return`No transactions exist before: ${s}`;let u=Nle,_,E=new Date(l.state.last_ts).getTime();return s>E?(_=l.state.last_seq+1,u=Ile):_=(await Uf.viewStream(o,parseInt(s),1))[0].nats_sequence,await Uf.purgeTableStream(r,n,{seq:_}),u}a(Dle,"deleteTransactionLogsBefore")});var IG=b((fDe,NG)=>{"use strict";var IO=class{static{a(this,"PermissionTableResponseObject")}constructor(t,r,n=[],s=[]){this.schema=t,this.table=r,this.required_table_permissions=n,this.required_attribute_permissions=s}};NG.exports=IO});var CG=b((hDe,wG)=>{"use strict";var wO=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};wG.exports=wO});var DO=b((pDe,PG)=>{"use strict";var DG=IG(),Ple=CG(),{HDB_ERROR_MSGS:Lle}=Nn(),CO=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=Lle.OP_AUTH_PERMS_ERROR,this.unauthorized_access={},this.invalid_schema_items=[]}handleUnauthorizedItem(t){return this.invalid_schema_items=[],this.unauthorized_access=[t],this}handleInvalidItem(t){return this.invalid_schema_items=[t],this.unauthorized_access=[],this}addInvalidItem(t,r,n){if(r&&n){let s=`${r}_${n}`;if(this.unauthorized_access[s])return}this.invalid_schema_items.push(t)}addUnauthorizedTable(t,r,n){let s=new DG(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new Ple(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new DG(r,n,[],i);this.unauthorized_access[o]=c}}getPermsResponse(){let t=Object.values(this.unauthorized_access);return t.length>0||this.invalid_schema_items.length>0?(this.unauthorized_access=t,this):null}};PG.exports=CO});var Qp=b((RDe,jG)=>{"use strict";var PO=Yr(),Kp=Vr(),bs=j_(),Hf=fi(),LO=Wo(),Mle=Gb(),Ule=UH(),xf=vn(),Wp=Jm(),mr=V(),vle=Xb(),Ble=dp(),Hle=Ly(),xle=fp(),kle=vy(),Fle=By(),Gle=ky(),qle=Gy(),MO=pp(),ho=J(),$le=Bk(),UO=jy(),UG=Lu(),As=M(),vG=GF(),Vle=gu(),BG=ef(),HG=(vp(),oe(If)),xG=wt(),ir=yO(),Yle=require("alasql"),kG=Yp(),FG=Gp(),kf=js(),GG=(Dc(),oe(Cc)),qG=DO(),{handleHDBError:gn,hdb_errors:$G}=fe(),{addNodeBack:TDe,removeNodeBack:gDe}=(Dc(),oe(Cc)),{HDB_ERROR_MSGS:Mr,HTTP_STATUS_CODES:vf}=$G,Y=new Map,VG="delete",Ta="insert",mo="read",qc="update",Bf="describe",LG=Hf.describeSchema.name,MG=Hf.describeTable.name,YG={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},Kle="catchup",Wle="handleGetJob",jle="handleGetJobsByStartDate",jp={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},Qle=[bs.createTable.name,bs.createAttribute.name,bs.dropTable.name,bs.dropAttribute.name],KG={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},Q=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};Y.set(PO.insert.name,new Q(!1,[Ta]));Y.set(PO.update.name,new Q(!1,[qc]));Y.set(PO.upsert.name,new Q(!1,[Ta,qc]));Y.set(Kp.searchByConditions.name,new Q(!1,[mo]));Y.set(Kp.searchByHash.name,new Q(!1,[mo]));Y.set(Kp.searchByValue.name,new Q(!1,[mo]));Y.set(Kp.search.name,new Q(!1,[mo]));Y.set(bs.createSchema.name,new Q(!0,[]));Y.set(bs.createTable.name,new Q(!0,[]));Y.set(bs.createAttribute.name,new Q(!1,[Ta]));Y.set(bs.dropSchema.name,new Q(!0,[]));Y.set(bs.dropTable.name,new Q(!0,[]));Y.set(bs.dropAttribute.name,new Q(!0,[]));Y.set(Hf.describeSchema.name,new Q(!1,[mo]));Y.set(Hf.describeTable.name,new Q(!1,[mo]));Y.set(LO.deleteRecord.name,new Q(!1,[VG]));Y.set(xf.addUser.name,new Q(!0,[]));Y.set(xf.alterUser.name,new Q(!0,[]));Y.set(xf.dropUser.name,new Q(!0,[]));Y.set(xf.listUsersExternal.name,new Q(!0,[]));Y.set(Wp.listRoles.name,new Q(!0,[]));Y.set(Wp.addRole.name,new Q(!0,[]));Y.set(Wp.alterRole.name,new Q(!0,[]));Y.set(Wp.dropRole.name,new Q(!0,[]));Y.set(vle.name,new Q(!0,[]));Y.set(Ble.name,new Q(!0,[]));Y.set(Hle.name,new Q(!0,[]));Y.set(xle.name,new Q(!0,[]));Y.set(kle.name,new Q(!0,[]));Y.set(Fle.name,new Q(!0,[]));Y.set(MO.setRoutes.name,new Q(!0,[]));Y.set(MO.getRoutes.name,new Q(!0,[]));Y.set(MO.deleteRoutes.name,new Q(!0,[]));Y.set(xG.setConfiguration.name,new Q(!0,[]));Y.set(Gle.clusterStatus.name,new Q(!0,[]));Y.set(qle.name,new Q(!0,[]));Y.set(UO.getFingerprint.name,new Q(!0,[]));Y.set(UO.setLicense.name,new Q(!0,[]));Y.set(LO.deleteFilesBefore.name,new Q(!0,[]));Y.set(LO.deleteAuditLogsBefore.name,new Q(!0,[]));Y.set(UG.restart.name,new Q(!0,[]));Y.set(UG.restartService.name,new Q(!0,[]));Y.set(Mle.name,new Q(!0,[]));Y.set(Ule.name,new Q(!0,[mo]));Y.set(Vle.systemInformation.name,new Q(!0,[]));Y.set(xG.getConfiguration.name,new Q(!0,[]));Y.set(kG.readTransactionLog.name,new Q(!0,[]));Y.set(kG.deleteTransactionLogsBefore.name,new Q(!0,[]));Y.set(FG.installModules.name,new Q(!0,[]));Y.set(FG.auditModules.name,new Q(!0,[]));Y.set(kf.createCsr.name,new Q(!0,[]));Y.set(kf.signCertificate.name,new Q(!0,[]));Y.set(kf.listCertificates.name,new Q(!0,[]));Y.set(kf.addCertificate.name,new Q(!0,[]));Y.set(kf.removeCertificate.name,new Q(!0,[]));Y.set(GG.addNodeBack.name,new Q(!0,[]));Y.set(GG.removeNodeBack.name,new Q(!0,[]));Y.set(BG.createTokens.name,new Q(!1,[]));Y.set(BG.refreshOperationToken.name,new Q(!1,[]));Y.set(HG.login.name,new Q(!1,[]));Y.set(HG.logout.name,new Q(!1,[]));Y.set(ir.customFunctionsStatus.name,new Q(!0,[]));Y.set(ir.getCustomFunctions.name,new Q(!0,[]));Y.set(ir.getComponents.name,new Q(!0,[]));Y.set(ir.getComponentFile.name,new Q(!0,[]));Y.set(ir.setComponentFile.name,new Q(!0,[]));Y.set(ir.dropComponent.name,new Q(!0,[]));Y.set(ir.getCustomFunction.name,new Q(!0,[]));Y.set(ir.setCustomFunction.name,new Q(!0,[]));Y.set(ir.dropCustomFunction.name,new Q(!0,[]));Y.set(ir.addComponent.name,new Q(!0,[]));Y.set(ir.dropCustomFunctionProject.name,new Q(!0,[]));Y.set(ir.packageComponent.name,new Q(!0,[]));Y.set(ir.deployComponent.name,new Q(!0,[]));Y.set(ir.addSSHKey.name,new Q(!0,[]));Y.set(ir.updateSSHKey.name,new Q(!0,[]));Y.set(ir.deleteSSHKey.name,new Q(!0,[]));Y.set(ir.listSSHKeys.name,new Q(!0,[]));Y.set(ir.setSSHKnownHosts.name,new Q(!0,[]));Y.set(ir.getSSHKnownHosts.name,new Q(!0,[]));Y.set(UO.getRegistrationInfo.name,new Q(!1,[]));Y.set(xf.userInfo.name,new Q(!1,[]));Y.set(Hf.describeAll.name,new Q(!1,[]));Y.set(Wle,new Q(!1,[]));Y.set(jle,new Q(!0,[]));Y.set(Kle,new Q(!0,[]));Y.set(jp.CSV_DATA_LOAD,new Q(!1,[Ta,qc]));Y.set(jp.CSV_URL_LOAD,new Q(!1,[Ta,qc]));Y.set(jp.CSV_FILE_LOAD,new Q(!1,[Ta,qc]));Y.set(jp.IMPORT_FROM_S3,new Q(!1,[Ta,qc]));Y.set(KG.EXPORT_TO_S3,new Q(!0,[]));Y.set(KG.EXPORT_LOCAL,new Q(!0,[]));Y.set(As.VALID_SQL_OPS_ENUM.DELETE,new Q(!1,[VG]));Y.set(As.VALID_SQL_OPS_ENUM.SELECT,new Q(!1,[mo]));Y.set(As.VALID_SQL_OPS_ENUM.INSERT,new Q(!1,[Ta]));Y.set(As.VALID_SQL_OPS_ENUM.UPDATE,new Q(!1,[qc]));jG.exports={verifyPerms:Jle,verifyPermsAst:zle,verifyBulkLoadAttributePerms:Zle};function zle(e,t,r){if(ho.isEmptyOrZeroLength(e))throw mr.info("verify_perms_ast has an empty user parameter"),gn(new Error);if(ho.isEmptyOrZeroLength(t))throw mr.info("verify_perms_ast has an empty user parameter"),gn(new Error);if(ho.isEmptyOrZeroLength(r))throw mr.info("verify_perms_ast has a null operation parameter"),gn(new Error);try{let n=new qG,s=new $le(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw mr.info("No schemas defined in verifyPermsAst(), will not continue."),gn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&YG[r])throw gn(new Error,Mr.DROP_SYSTEM,vf.FORBIDDEN);if(c&&!l)return null;let d=vG.getRolePermissions(t.role);t.role.permission=d,!c&&e instanceof Yle.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(d));for(let _=0;_<i.length;_++){let E=s.getTablesBySchemaName(i[_]);E&&o.set(i[_],E)}let u=WG(t,r,o,n);return u||(o.forEach((_,E)=>{for(let f=0;f<_.length;f++){let h=s.getAttributesBySchemaTableName(E,_[f]),T=BO(t.role.permission,E,_[f]);vO(h,T,r,_[f],E,n)}}),n.getPermsResponse())}catch(n){throw gn(n)}}a(zle,"verifyPermsAst");function Jle(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw mr.info("null required parameter in verifyPerms"),gn(new Error,Mr.DEFAULT_INVALID_REQUEST,vf.BAD_REQUEST);let r;t instanceof Function?r=t.name:r=t;let n=e.action,s=e.schema??e.database,i=e.table,o=new Map;s&&i&&o.set(s,[i]);let c=new qG;if(ho.isEmptyOrZeroLength(e.hdb_user?.role)||ho.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return mr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(Mr.USER_HAS_NO_PERMS(e.hdb_user?.username));let l=!!e.hdb_user?.role?.permission?.super_user,d=e.hdb_user?.role?.permission?.structure_user,u=o.has(As.SYSTEM_SCHEMA_NAME)||s===As.SYSTEM_SCHEMA_NAME;if(u&&YG[r])throw gn(new Error,Mr.DROP_SYSTEM,vf.FORBIDDEN);if(l&&!u||d===!0&&(r===bs.createSchema.name||r===bs.dropSchema.name))return null;if(Qle.indexOf(r)>=0&&(d===!0||Array.isArray(d)))return d===!0||d.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let _=vG.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=_),r===LG||r===MG){if(s===As.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Mr.SCHEMA_PERM_ERROR(s));if(!_.super_user){if(r===LG&&(!_[s]||!_[s][Bf]))return c.handleInvalidItem(Mr.SCHEMA_NOT_FOUND(s));if(r===MG&&(!_[s]||!_[s].tables[i]||!_[s].tables[i][Bf]))return c.handleInvalidItem(Mr.TABLE_NOT_FOUND(s,i))}}let E=WG(e.hdb_user,r,o,c,n);if(E)return E;if(Y.get(r)&&Y.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&As.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let T=[],S=_[s].tables[i];S[As.PERMS_CRUD_ENUM.READ]&&(S.attribute_permissions.length>0?S.attribute_permissions.filter(p=>p[As.PERMS_CRUD_ENUM.READ]).forEach(p=>{T.push(p.attribute_name)}):T=global.hdb_schema[s][i].attributes.map(R=>R.attribute),e.get_attributes=T)}let f=Xle(e),h=BO(e.hdb_user?.role?.permission,s,i);return vO(f,h,r,i,s,c,n),c.getPermsResponse()}a(Jle,"verifyPerms");function WG(e,t,r,n,s){if(ho.arrayHasEmptyValues([e,t,r]))throw mr.info("hasPermissions has an invalid parameter"),gn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||Y.get(t).requires_su))return null;if(!Y.get(t))throw mr.info(`operation ${t} not found.`),gn(new Error,Mr.OP_NOT_FOUND(t),vf.BAD_REQUEST);if(Y.get(t)&&Y.get(t).requires_su)return mr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Mr.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Bf]===!1){n.addInvalidItem(Mr.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(Mr.SCHEMA_NOT_FOUND(l));continue}let d=r.get(l);for(let u of d){let _=o[l].tables[u];if(!_||_[Bf]===!1)n.addInvalidItem(Mr.TABLE_NOT_FOUND(l,u));else try{let E=[],f=Y.get(t).perms;!ho.isEmpty(s)&&f.includes(s)&&(f=[s]);for(let h=0;h<f.length;h++){let T=f[h],S=_[T];(S==null||S===!1)&&(mr.info(`Required ${T} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),E.push(T))}E.length>0&&n.addUnauthorizedTable(l,u,E)}catch(E){let f=Mr.UNKNOWN_OP_AUTH_ERROR(t,l,u);throw mr.error(f),mr.error(E),gn($G.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(WG,"hasPermissions");function vO(e,t,r,n,s,i,o){if(!e||!t)throw mr.info("no attributes specified in checkAttributePerms."),gn(new Error);let c=Y.get(r).perms;if(!c||c==="")throw mr.info(`no permissions found for ${r} in checkAttributePerms().`),gn(new Error);if(ho.isEmptyOrZeroLength(t))return mr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let u of e){let _=t.get(u);if(_){if(_[Bf]===!1){i.addInvalidItem(Mr.ATTR_NOT_FOUND(s,n,u),s,n);continue}if(c)for(let E of c){if(As.TIME_STAMP_NAMES.includes(_.attribute_name)&&E!==mo)throw gn(new Error,Mr.SYSTEM_TIMESTAMP_PERMS_ERR,vf.FORBIDDEN);_[E]===!1&&(l[_.attribute_name]?l[_.attribute_name].push(E):l[_.attribute_name]=[E])}}else i.addInvalidItem(Mr.ATTR_NOT_FOUND(s,n,u),s,n)}let d=Object.keys(l);d.length>0&&i.addUnauthorizedAttributes(d,s,n,l)}a(vO,"checkAttributePerms");function Xle(e){let t=new Set;try{if(e.action)return t;if(e.operation===As.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){mr.info(r)}return t}a(Xle,"getRecordAttributes");function BO(e,t,r){let n=new Map;if(ho.isEmpty(e))return mr.info("no hdb_user specified in getAttributePermissions"),n;if(e.super_user||!t||!r)return n;try{e[t].tables[r].attribute_permissions.forEach(s=>{n.has(s.attribute_name)||n.set(s.attribute_name,s)})}catch{mr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(BO,"getAttributePermissions");function Zle(e,t,r,n,s,i,o){let c=new Set(i),l=BO(e,n,s);vO(c,l,t,s,n,o,r)}a(Zle,"verifyBulkLoadAttributePerms")});var Jp=b((bDe,ZG)=>{"use strict";ZG.exports={evaluateSQL:_ue,processAST:XG,convertSQLToAST:JG,checkASTPermissions:zG};var eue=Yr(),QG=require("util"),tue=QG.callbackify(eue.insert),rue=Vr().search,nue=Jv().update,sue=QG.callbackify(nue),iue=Zv().convertDelete,ga=require("alasql"),oue=Qp(),zp=V(),aue=um(),cue=J(),Ff=M(),{hdb_errors:lue,handleHDBError:HO}=fe(),{HTTP_STATUS_CODES:xO}=lue;aue(ga);var uue=403,due="There was a problem performing this insert. Please check the logs and try again.",kO=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function _ue(e,t){let r=e.parsed_sql_object;if(!r){r=JG(e.sql);let n,s=r.ast.statements[0];if(s instanceof ga.yy.Insert?n=s.into.databaseid:s instanceof ga.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof ga.yy.Update||s instanceof ga.yy.Delete?n=s.table.databaseid:zp.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof ga.yy.Select)&&cue.isEmptyOrZeroLength(n))return t("No schema specified",null)}XG(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(_ue,"evaluateSQL");function zG(e,t){let r;try{r=oue.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(zG,"checkASTPermissions");function JG(e){let t=new kO;if(!e)throw HO(new Error,"The 'sql' parameter is missing from the request body",xO.BAD_REQUEST);try{let r=e.trim(),n=ga.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
31
+ `);throw n[1]?HO(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,xO.BAD_REQUEST):HO(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",xO.BAD_REQUEST)}return t}a(JG,"convertSQLToAST");function XG(e,t,r){try{let n=fue;if(!e.bypass_auth&&!t.permissions_checked){let i=zG(e,t);if(i&&i.length>0)return r(uue,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case Ff.VALID_SQL_OPS_ENUM.SELECT:n=rue,s=t.ast.statements[0];break;case Ff.VALID_SQL_OPS_ENUM.INSERT:n=Eue;break;case Ff.VALID_SQL_OPS_ENUM.UPDATE:n=sue;break;case Ff.VALID_SQL_OPS_ENUM.DELETE:n=iue;break;default:throw new Error(`unsupported SQL type ${t.variant} in SQL: ${e}`)}n(s,(i,o)=>{if(i){r(i);return}r(null,o)})}catch(n){return r(n)}}a(XG,"processAST");function fue(e,t){zp.info(e),t("unknown sql statement")}a(fue,"nullFunction");function Eue({statement:e,hdb_user:t},r){let n=e.into,s={schema:n.databaseid,table:n.tableid,operation:"insert",hdb_user:t},i=e.columns.map(o=>o.columnid);try{s.records=hue(i,e.values)}catch(o){return r(o)}tue(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){zp.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(Eue,"convertInsert");function hue(e,t){try{return t.map(r=>{if(e.length!==r.length)throw"number of values do not match number of columns in insert";let n={};return r.forEach((s,i)=>{if(s.columnid)throw"cannot use a column in insert value";"value"in s?n[e[i]]=s.value:n[e[i]]=ga.compile(`SELECT ${s.toString()} AS [${Ff.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw zp.error(r),new Error(due)}}a(hue,"createDataObjects")});var FO=b((ODe,tq)=>{"use strict";var{S3:mue,GetObjectCommand:pue}=require("@aws-sdk/client-s3");tq.exports={getFileStreamFromS3:Sue,getS3AuthObj:eq};async function Sue(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await eq(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new pue(r))).Body}a(Sue,"getFileStreamFromS3");function eq(e,t,r){return new mue({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(eq,"getS3AuthObj")});var Xp=b((IDe,uq)=>{"use strict";var qO=Vr(),Tue=Jp(),gue=FO(),{AsyncParser:Rue,Transform:Aue}=require("json2csv"),qf=require("stream"),$n=J(),GO=require("fs-extra"),bue=require("path"),ys=V(),{promisify:sq}=require("util"),Gf=J(),{handleHDBError:or,hdb_errors:yue}=fe(),{HDB_ERROR_MSGS:Rn,HTTP_STATUS_CODES:ar}=yue,{streamAsJSON:Oue}=(Cg(),oe(ED)),{Upload:Nue}=require("@aws-sdk/lib-storage"),rq=["search_by_value","search_by_hash","sql","search_by_conditions"],nq=["json","csv"],iq="json",oq="csv",Iue="Successfully exported JSON locally.",wue="Successfully exported CSV locally.",Cue=1e3,Due=qO.searchByHash,Pue=qO.searchByValue,Lue=sq(Tue.evaluateSQL),Mue=sq(qf.finished);uq.exports={export_to_s3:Hue,export_local:Uue,toCsvStream:aq};async function Uue(e){ys.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=cq(e);if(!$n.isEmpty(t))throw ys.error(t),or(new Error,t,ar.BAD_REQUEST,void 0,void 0,!0);if($n.isEmpty(e.path))throw ys.error(Rn.MISSING_VALUE("path")),or(new Error,Rn.MISSING_VALUE("path"),ar.BAD_REQUEST,void 0,void 0,!0);let r=($n.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(bue.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=$n.buildFolderPath(e.path,r);await vue(e.path);let s=await lq(e);return await Bue(n,e.format,s)}a(Uue,"export_local");async function vue(e){if(ys.trace("in confirmPath"),$n.isEmptyOrZeroLength(e))throw or(new Error,`Invalid path: ${e}`,ar.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await GO.stat(e)}catch(r){let n;throw r.code==="ENOENT"?n=`path '${e}' does not exist`:r.code==="EACCES"?n=`access to path '${e}' is denied`:n=r.message,ys.error(n),or(new Error,n,ar.BAD_REQUEST,void 0,void 0,!0)}if(!t.isDirectory()){let r=`path '${e}' is not a directory, please supply a valid folder path`;throw ys.error(r),or(new Error,r,ar.BAD_REQUEST,void 0,void 0,!0)}return!0}a(vue,"confirmPath");async function Bue(e,t,r){if(ys.trace("in saveToLocal"),Gf.isEmptyOrZeroLength(e))throw or(new Error,Rn.INVALID_VALUE("file_path"),ar.BAD_REQUEST,void 0,void 0,!0);if(Gf.isEmptyOrZeroLength(t))throw or(new Error,Rn.INVALID_VALUE("Source format"),ar.BAD_REQUEST,void 0,void 0,!0);if(Gf.isEmpty(r))throw or(new Error,Rn.NOT_FOUND("Data"),ar.BAD_REQUEST,void 0,void 0,!0);if(t===iq){let n=GO.createWriteStream(e);return Oue(r).pipe(n),await Mue(n),{message:Iue,path:e}}else if(t===oq){let n=GO.createWriteStream(e),s=qf.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(u=>({label:u,value:u})));let c={objectMode:!0};return await new Rue(i,c).fromInput(s).toOutput(n).promise(!1),{message:wue,path:e}}throw or(new Error,Rn.INVALID_VALUE("format"),ar.BAD_REQUEST)}a(Bue,"saveToLocal");async function Hue(e){if(!e.s3||Object.keys(e.s3).length===0)throw or(new Error,Rn.MISSING_VALUE("S3 object"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw or(new Error,Rn.MISSING_VALUE("aws_access_key_id"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw or(new Error,Rn.MISSING_VALUE("aws_secret_access_key"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.bucket))throw or(new Error,Rn.MISSING_VALUE("bucket"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.key))throw or(new Error,Rn.MISSING_VALUE("key"),ar.BAD_REQUEST);if($n.isEmptyOrZeroLength(e.s3.region))throw or(new Error,Rn.MISSING_VALUE("region"),ar.BAD_REQUEST);let t=cq(e);if(!$n.isEmpty(t))throw or(new Error,t,ar.BAD_REQUEST);ys.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await lq(e)}catch(l){throw ys.error(l),l}let n,s=await gue.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new qf.PassThrough;if(e.format===oq){i=e.s3.key+".csv";let l=aq(r,r.getColumns?.());l.on("error",d=>{throw d}),l.pipe(o)}else if(e.format===iq){i=e.s3.key+".json";let l=new qf.Readable;l.pipe(o),l.on("error",_=>{throw _}),l.push("[");let d=r.length,u="";for(let[_,E]of r.entries()){let f=_===d-1?JSON.stringify(E):JSON.stringify(E)+",";u+=f,_!==0&&_%Cue===0&&(l.push(u),u="")}u.length!==0&&l.push(u),l.push("]"),l.push(null)}else throw or(new Error,Rn.INVALID_VALUE("format"),ar.BAD_REQUEST);return new Nue({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(Hue,"export_to_s3");function aq(e,t){let r=qf.Readable.from(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator]?e:[e]),n={};t&&(n.fields=t.map(o=>({label:o,value:o})));let s={objectMode:!0},i=new Aue(n,s);return r.pipe(i)}a(aq,"toCsvStream");function cq(e){if(ys.trace("in exportCoreValidation"),$n.isEmpty(e.format))return"format missing";if(nq.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${nq.join(", ")}`;let t=e.search_operation.operation;if($n.isEmpty(t))return"search_operation.operation missing";if(rq.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${rq.join(", ")}`}a(cq,"exportCoreValidation");async function lq(e){ys.trace("in getRecords");let t,r;if(Gf.isEmpty(e.search_operation)||Gf.isEmptyOrZeroLength(e.search_operation.operation))throw or(new Error,Rn.INVALID_VALUE("Search operation"),ar.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=Pue;break;case"search_by_hash":t=Due;break;case"search_by_conditions":t=qO.searchByConditions;break;case"sql":t=Lue;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,ys.error(r),or(new Error,r,ar.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(lq,"getRecords")});var gq={};et(gq,{contentTypes:()=>KO,findBestSerializer:()=>tS,getDeserializer:()=>Vc,registerContentHandlers:()=>WO,serialize:()=>Yf,serializeMessage:()=>kc});function xue(e){try{return e?.[0]===123?YO(e):e}catch{return e}}function WO(e){e.register(Fue,{serializers:[{regex:/^application\/json$/,serializer:Fd},{regex:/^application\/cbor$/,serializer:function(t){return new $c.EncoderStream(Vf).end(t)}},{regex:/^application\/(x-)?msgpack$/,serializer:function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?eS.Readable.from((0,wi.encodeIter)(t,Vf)):(0,wi.pack)(t)}},{regex:/^text\/csv$/,serializer:function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,Zp.toCsvStream)(t)}}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,wi.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,$c.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function tS(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[d,...u]=l.split(/\s*;\s*/),_=1,E={q:1};for(let h of u){let T=h.indexOf("=");E[h.substring(0,T)]=h.substring(T+1)}_=+E.q;let f=br.get(d);if(f){let h=(f.q||1)*_;h>s&&(n=f,i=f.type||d,s=h,o=E)}}if(!n){if(r)throw new Eq.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(br.keys()).join(", "),406);n=br.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Yf(e,t,r){let n=_q&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=tS(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&e&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){if(e.mapError){let c=e.getColumns;e=e.mapError(l=>(l.toJSON=()=>({error:l.name,message:l.message,...l.partialObject}),pq.default.warn?.(`Error serializing error ${t?.url||t}: ${l}`),l)),e.getColumns=c}let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,po.createBrotliCompress)({params:{[po.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?po.constants.BROTLI_MODE_TEXT:po.constants.BROTLI_MODE_GENERIC,[po.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>_q?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,po.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function kc(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return $f(e);let r=t.serialize;if(r)return r(e);let n=tS(t);return r=t.serialize=n.serializer.serialize,r(e)}function Gue(e){return new Promise((t,r)=>{let n=[];e.on("data",s=>n.push(s)),e.on("end",()=>t(Buffer.concat(n))),e.on("error",r)})}function Vc(e,t){e||(e="");let r=e.indexOf(";"),n;r>-1&&(n=e.slice(r+1),e=e.slice(0,r));let s=br.get(e);if(t){if(s?.deserializeStream)return s.deserializeStream;let i=br.get(e)?.deserialize||fq(e,n);return o=>Gue(o).then(i)}return e&&br.get(e)?.deserialize||fq(e,n)}function fq(e,t){if(e.startsWith("text/")){let r=t?.match(/charset=(.+)/)?.[1]||"utf-8";return n=>({contentType:e,data:n.toString(r)})}else return e==="application/octet-stream"?r=>r:r=>{if(!e)try{if(r?.[0]===123)return YO(r)}catch{}return{contentType:e||"application/octet-stream",data:r}}}function que(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}var Zp,wi,$c,po,Eq,eS,hq,$O,VO,mq,pq,Sq,$f,YO,Vf,br,KO,dq,Tq,kue,Fue,_q,Uu=De(()=>{Cg();Zp=v(Xp()),wi=require("msgpackr"),$c=require("cbor-x"),po=require("zlib"),Eq=v(fe()),eS=require("stream");$r();hq=v(Vi()),$O=v(te()),VO=v(M()),mq=v(require("yaml")),pq=v(zl()),Sq=$O.default.get(VO.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,$f=Sq?Va:JSON.stringify,YO=Sq?wg:JSON.parse,Vf={useRecords:!1,useToJSON:!0},br=new Map,KO=br;st.contentTypes=KO;(0,hq._assignPackageExport)("contentTypes",KO);br.set("application/json",{serializeStream:Fd,serialize:$f,deserialize(e){return YO(e)},q:.8});dq=new $c.Encoder(Vf);br.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new $c.EncoderStream(Vf).end(e)},serialize:dq.encode,deserialize:dq.decode,q:1});br.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?eS.Readable.from((0,wi.encodeIter)(e,Vf)):(0,wi.pack)(e)},serialize:wi.pack,deserialize:wi.unpack,q:.9});br.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,Zp.toCsvStream)(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),(0,Zp.toCsvStream)(e,e?.getColumns?.())},q:.1});br.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});br.set("text/yaml",{serialize(e){return mq.stringify(e,{aliasDuplicateObjects:!1})},q:.7});br.set("text/event-stream",{serializeStream:function(e){return eS.Readable.from(que(e,this.serialize))},serialize:function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
32
+ `),e.data){let r=e.data;typeof r=="object"&&(r=$f(r)),t+="data: "+r+`
31
33
  `}return e.id&&(t+="id: "+e.id+`
32
34
  `),e.retry&&(t+="retry: "+e.retry+`
33
35
  `),t+`
34
- `}else return typeof e=="object"?`data: ${qf(e)}
36
+ `}else return typeof e=="object"?`data: ${$f(e)}
35
37
 
36
38
  `:`data: ${e}
37
39
 
38
- `},compressible:!1,q:.8});Or.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()}});pq={type:"application/json",serializeStream:xd,serialize:qf,deserialize:Hue,q:.5};Or.set("*/*",pq);Or.set("",pq);a(Hue,"tryJSONParse");a(Ky,"registerContentHandlers");xue=require("fastify-plugin"),Fue=xue(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=rS(n.raw);s.type(c),s.serializer(function(l){let d;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let u=l.getColumns;l=l.mapError(_=>(_.toJSON=()=>({error:_.name,message:_.message,..._.partialObject}),_)),l.getColumns=u}d=o.serializeStream}else d=o.serialize;return d(l,{headers:{set:(u,_)=>{s.header(u,_)}}})})}),r()},{name:"content-type-negotiation"});a(rS,"findBestSerializer");uq=qy.default.get($y.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(Vf,"serialize");a(xc,"serializeMessage");a(kue,"streamToBuffer");a($c,"getDeserializer");a(dq,"deserializerUnknownType");a(Gue,"transformIterable")});function Qy(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let _=d(l);for(let f=1;f<e.length;f++){let h=e[f],p=d(h);_=_.concat(p)}let E=new Set;return _.filter(f=>{let h=f.key??f;return E.has(h)?!1:(E.add(h),!0)})}else{let _=d(l),E=u(e.slice(1),!0,l.estimated_count);return E.length>0?o(_,E):_}function d(_){return _.conditions?Qy(_.conditions,_.operator,r,n,s,i,o,c):qu(_,n,_.descending||s.reverse===!0,r,s.allowFullScan,c)}a(d,"executeCondition");function u(_,E,f){return _.map((h,p)=>{if(h.conditions){let S=h.operator==="or",C=u(h.conditions,!S,f);return S?(y,x)=>C.some(F=>F(y,x)):(y,x)=>C.every(F=>F(y,x))}let T=(h.attribute||h[0])===r.primaryKey,g=Wf(h,r,i,c,T,f);return E&&p<_.length-1&&f&&(f=zue(r.primaryStore,h.estimated_count,f)),g}).filter(Boolean)}a(u,"mapConditionsToFilters")}function qu(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(Array.isArray(o)){let S=o[0],C=Pi(n.attributes,S);if(C.relationship){if(o.length<2)throw new Vn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let y=C.definition?.tableClass||C.elements?.definition?.tableClass,x=new Map,F=qu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,y,s,x);if(C.relationship.to){i[o[0]]=x;let Y=!!Pi(y.attributes,C.relationship.to)?.elements;F=Kue(F,C,y.primaryStore,Y,x)}if(C.relationship.from){let Y=a($=>qu({attribute:C.relationship.from,value:$},t,r,n,s,x),"searchEntry");C.elements?(i[o[0]]=x,F=Wue(F,C,y.primaryStore,x,Y)):F=F.flatMap(Y)}return F}else if(o.length===1)o=o[0];else throw new Vn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let d,u,_,E;c instanceof Date&&(c=c.getTime());let f;switch(zy[l]||l){case"lt":d=!0,u=c;break;case"le":d=!0,u=c,_=!0;break;case"gt":d=c,E=!0;break;case"ge":d=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],d=c,u=c.slice(0),u[u.length-1]=Di.MAXIMUM_KEY;break;case"starts_with":d=c.toString(),u=c+"\uFFFF";break;case"between":d=c[0],d instanceof Date&&(d=d.getTime()),u=c[1],u instanceof Date&&(u=u.getTime()),_=!0;break;case"equals":case void 0:d=c,u=c,_=!0;break;case"ne":if(c===null){d=c,E=!0;break}case"sort":case"contains":case"ends_with":d=!0,f=!0;break;default:throw new Vn.ClientError(`Unknown query comparator "${l}"`)}let h,p=o===n.primaryKey||o==null;if(typeof d=="string"&&d.length>Os.MAX_SEARCH_KEY_LENGTH&&(d=d.slice(0,Os.MAX_SEARCH_KEY_LENGTH)+Os.OVERFLOW_MARKER,E=!1,h=Wf(e,n,null,i,p)),typeof u=="string"&&u.length>Os.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Os.MAX_SEARCH_KEY_LENGTH)+Os.OVERFLOW_MARKER,_=!0,h=h??Wf(e,n,null,i,p)),r){let S=d;d=u,u=S,S=!E,E=!_,_=S}let T=p?n.primaryStore:n.indices[o];if(!T||T.isIndexing||f||c===null&&!T.indexNulls){if(s===!1&&!T)throw new Vn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&f)throw new Vn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(T?.isIndexing)throw new Vn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&!T.indexNulls)throw new Vn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??Wf(e,n,null,i,p),!h)throw new Vn.ClientError(`Unknown search operator ${e.comparator}`)}let g={start:d,end:u,inclusiveEnd:_,exclusiveStart:E,values:!0,versions:p,transaction:t,reverse:r};if(p){let S=T.getRange(g).map(h?function({key:C,value:y}){return this?.isSync?y&&h(y)?C:pa.SKIP:new Promise((x,F)=>setImmediate(()=>{try{x(y&&h(y)?C:pa.SKIP)}catch(Y){F(Y)}}))}:C=>C.value==null&&!(C.metadataFlags&(Li|Ta))?pa.SKIP:C);return S.hasEntries=!0,S}else return T?T.getRange(g).map(h?function({key:S,value:C}){let y;return typeof S=="string"&&S.length>Os.MAX_SEARCH_KEY_LENGTH?y=n.primaryStore.get(C):y={[o]:S},this.isSync?h(y)?C:pa.SKIP:new Promise((x,F)=>setImmediate(()=>{try{x(h(y)?C:pa.SKIP)}catch(Y){F(Y)}}))}:({value:S})=>S):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:S,value:C}){return this.isSync?C&&h(C)?S:pa.SKIP:new Promise((y,x)=>setImmediate(()=>{try{y(C&&h(C)?S:pa.SKIP)}catch(F){x(F)}}))})}function Pi(e,t){if(Array.isArray(t))if(t.length>1){let r=Pi(e,t[0]),n=(r?.definition?.tableClass||r?.elements.definition?.tableClass)?.attributes;return n?Pi(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 Kue(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;s.hasMappings=!0;let o;return{next(){if(!i){let l=t.relationship.to,d=a((u,_)=>{let E=u;Array.isArray(u)&&(E=Qs(u),o=!0);let f=s.get(E);f?f.push(_):s.set(E,f=[_]),u!==E&&(f.key=u)},"add_entry");for(let u of e){let _=u.value??r.get(u.key??u),E=_?.[l];if(E!=null&&!s.filters?.some(f=>!f(_)))if(n)for(let f=0;f<E.length;f++)d(E[f],u);else d(E,u)}return i=(o?s:s.keys())[Symbol.iterator](),this.next()}let c=i.next();return c.done?c:{value:o?c.value[1].key||c.value[0]:c.value}},return(){if(i?.return)return i.return()}}}})}function Wue(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let d=Qs(l.value);if(!c.has(d))return c.add(d),l}if(!i){let d=new Map;n.fromRecord=u=>u[t.relationship.from]?.filter?.(_=>d.has(Qs(_)));for(let u of e){if(n.filters){let _=r.get(u);if(n.filters.some(E=>!E(_)))continue}d.set(Qs(u),u)}return i=d.values()[Symbol.iterator](),this.next()}do{let d=i.next();return d.done?d:(o=s(d.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function Wf(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let u=c[0],_=Pi(t.attributes,u),E=_.definition?.tableClass||_.elements.definition?.tableClass,f=n?.[u],h=Wf({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},E,r,f?.[u]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(f){f.filters||(f.filters=[]),f.filters.push(h);return}let p=t.propertyResolvers?.[u],T,g=a((S,C)=>{let y,x;if(p){if(p.from&&h.idFilter){if(!T)if(h.idFilter.idSet?.size===1){for(let Y of h.idFilter.idSet)e={attribute:p.from,value:Y};T=d(p.from,h.idFilter,!0,!0)}else T=d(p.from,h.idFilter,!1,!0);let F=T(S);return T.idFilter&&(g.idFilter=T.idFilter),F}x=p(S,r,C),y=x?.value}else y=S[u];return y?Array.isArray(y)?y.some(h):h(y,x):!1},"recordFilter");return g}}switch(l instanceof Date&&(l=l.getTime()),zy[o]||o){case Os.SEARCH_TYPES.EQUALS:case void 0:return d(c,u=>u===l,!0);case"contains":return d(c,u=>u?.toString().includes(l));case"ends_with":return d(c,u=>u?.toString().endsWith(l));case"starts_with":return d(c,u=>typeof u=="string"&&u.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],d(c,u=>{if(!Array.isArray(u))return!1;for(let _=0,E=l.length;_<E;_++)if(u[_]!==l[_])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),d(c,u=>(0,Di.compareKeys)(u,l[0])>=0&&(0,Di.compareKeys)(u,l[1])<=0,!0);case"gt":return d(c,u=>(0,Di.compareKeys)(u,l)>0);case"ge":return d(c,u=>(0,Di.compareKeys)(u,l)>=0);case"lt":return d(c,u=>(0,Di.compareKeys)(u,l)<0);case"le":return d(c,u=>(0,Di.compareKeys)(u,l)<=0);case"ne":return d(c,u=>(0,Di.compareKeys)(u,l)!==0);case"sort":return()=>!0;default:throw new Vn.ClientError(`Unknown query comparator "${o}"`)}function d(u,_,E,f){let h;E=E&&!s&&t?.indices[u]&&i>3,E&&(e.estimated_count==null&&sS(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let p=0,T=3;function g(S){let C=S[u],y;if(typeof C!="object"||!C||f?y=_(C):Array.isArray(C)?y=C.some(_):C instanceof Date&&(y=_(C.getTime())),E&&(T++,!y&&!g.idFilter&&++p/T*(i-T)>h)){let x=qu(e,r.transaction.getReadTxn(),!1,t).map(Qs),F=new Set(x);g.idFilter=Y=>F.has(Qs(Y)),g.idFilter.idSet=F}return y}return a(g,"recordFilter"),s&&(g.idFilter=_),g}a(d,"attributeComparator")}function sS(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/po(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=zy[n]||n,n===Os.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=Pi(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=sS(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*po(e.indices[i.relationship.from])/(po(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=po(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=Vue*po(e.primaryStore)+1:n==="between"?r.estimated_count=$ue*po(e.primaryStore)+1:n==="sort"?r.estimated_count=po(e.primaryStore)+1:r.estimated_count=que*po(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function iS(e){if(e)if(Sa=e,ku.lastIndex=0,jue.test(e))try{let t=Yf(new Gu,"");if(An!==Sa.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${An} in '${Sa}'`,t}else return new URLSearchParams(e)}function Yf(e,t){let r=ku,n,s,i,o,c,l=decodeURIComponent,d;for(;n=r.exec(Sa);){An=r.lastIndex;let[,u,_]=n;if(o){if(u)throw new SyntaxError(`expected operator, but encountered '${u}'`);o=!1,c=!1}else c=!0;let E;switch(_){case"=":if(s){if(u.length<=2)i=u;else throw new SyntaxError(`invalid FIQL operator ${u}`);l=Wy}else{if(l=decodeURIComponent,i="equals",!u)throw new SyntaxError("attribute must be specified before equality comparator");s=Kf(u)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=Yue[_],l=jy[i]?Wy:decodeURIComponent,!u)throw new SyntaxError(`attribute must be specified before comparator ${_}`);s=Kf(u);break;case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${_[0]?"'"+_[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${_?"'"+_+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s,value:l(u)};i==="eq"&&Tq(h,u),nS(e,d),e.conditions.push(h)}_==="&"&&(d="and"),_==="|"&&(d="or"),s=void 0;break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(Kf(u)),s=void 0;break;case"(":ku.lastIndex=An;let f=Yf(u?[]:new Gu,")");switch(u){case"":nS(e,d),e.conditions.push(f);break;case"limit":switch(f.length){case 1:e.limit=+f[0];break;case 2:e.offset=+f[0],e.limit=f[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(f[0])&&f.length===1&&!f[0].name?(e.select=f[0],e.select.asArray=!0):f.length===1?e.select=f[0]:f.length===2&&f[1]===""?e.select=f.slice(0,1):e.select=f;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=gq(f);break;default:throw new SyntaxError(`unknown query function call ${u}`)}Sa[An]===","?r.lastIndex=++An:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!u)throw new SyntaxError("property sets must have a defined parent property name");ku.lastIndex=An,E=Yf([],"}"),E.name=u,e.push(E),Sa[An]===","?r.lastIndex=++An:o=!0;break;case"[":ku.lastIndex=An,u?(E=Yf(new Gu,"]"),E.name=u):E=Yf(e.conditions?new Gu:[],"]"),e.conditions?(nS(e,d),e.conditions.push(E),s=null):e.push(E),Sa[An]===","?r.lastIndex=++An:o=!0;break;case")":case"]":case"}":if(t===_[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(u)};i==="eq"&&Tq(h,u),nS(e,d),e.conditions.push(h)}else if(u)throw new SyntaxError("no attribute or comparison specified")}else(u||e.length>0&&c)&&e.push(Kf(u));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${_[0]}'`):new SyntaxError(`unexpected token '${_[0]}'`);default:throw new SyntaxError(`unexpected operator '${_}'`)}if(t!==")"&&(r=s?Que:ku,r.lastIndex=An),An===Sa.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function nS(e,t){if(e.conditions.length>0)if(e.operator){if(e.operator!==t)throw new SyntaxError("Can not mix operators within a condition grouping")}else e.operator=t}function Kf(e){return e.indexOf(".")>-1?e.split(".").map(Kf):decodeURIComponent(e)}function Wy(e){if(e==="null")return null;if(e.indexOf("/")>-1){let t=e.split("/"),r=new $u(t.length);for(let n=0,s=t.length;n<s;n++)r[n]=Wy(t[n]);return r}if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new Vn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function Tq(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Vn.ClientError("wildcard can only be used at the end of a string")}function gq(e){let t=Rq(e[0]);return e.length>1&&(t.next=gq(e.slice(1))),t}function Rq(e){if(Array.isArray(e)){let t=Rq(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 Qs(e){return Array.isArray(e)?e.join("\0"):e}function po(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function zue(e,t,r){return t*r/po(e)}var Vn,Os,Di,pa,que,$ue,Vue,Yue,jy,zy,jue,ku,Que,An,Sa,Gu,Vc,jf=Ce(()=>{Vn=B(ce()),Os=B(Bt()),Di=require("ordered-binary"),pa=require("lmdb");Qf();rs();que=.3,$ue=.1,Vue=.05,Yue={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},jy={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(Qy,"executeConditions");a(qu,"searchByIndex");a(Pi,"findAttribute");a(Kue,"joinTo");a(Wue,"joinFrom");zy={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(Wf,"filterByType");a(sS,"estimateCondition");jue=/[()[\]|!<>.]|(=\w*=)/,ku=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,Que=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(iS,"parseQuery");a(Yf,"parseBlock");a(nS,"assignOperator");a(Kf,"decodeProperty");a(Wy,"typedDecoding");a(Tq,"wildcardDecoding");a(gq,"toSortObject");a(Rq,"toSortEntry");Gu=class{static{a(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}};a(Qs,"flattenKey");a(po,"estimatedEntryCount");a(zue,"intersectionEstimate");Vc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});function Nq(e){let t={openapi:Jue,info:{title:"HarperDB HTTP REST interface",version:(0,yq.version)()},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let d={},u=[];if(o)for(let{type:C,name:y,elements:x,relationship:F,definition:Y}of o){if(F)C==="array"?d[y]={type:"array",items:{$ref:ga+x.type}}:d[y]={$ref:ga+C};else{let $=Y??x?.definition;if($){if(!t.components.schemas[$.type]){let Z={};$.properties.forEach(Q=>{Z[Q.name]=new eN(Jy[Q.type],Q.type)}),t.components.schemas[$.type]=new bq(Z)}C==="array"?d[y]={type:"array",items:{$ref:ga+$.type}}:d[y]={$ref:ga+$.type}}else C==="array"?x.type==="Any"||x.type=="ID"?d[y]={type:"array",items:{format:x.type}}:d[y]={type:"array",items:new eN(Jy[x.type],x.type)}:C==="Any"||C=="ID"?d[y]={format:C}:d[y]=new eN(Jy[C],C)}u.push(new tN(y,"query",d[y]))}let _=Object.keys(d),E=new tN(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new tN("property","path",{enum:_});f.required=!0,t.components.schemas[i]=new bq(d);let h=l.post!==Resource.prototype.post||l.update,p=typeof l.put=="function",T=typeof l.get=="function",g=typeof l.delete=="function",S="/"+s+"/";h&&(t.paths[S]={},t.paths[S].post=new Xue(i,r,"create a new record auto-assigning a primary key")),T&&(t.paths[S]||(t.paths[S]={}),t.paths[S].get=new Xy(u,r,{200:new Zy({$ref:ga+i})},"search for records by the specified property name and value pairs")),g&&(t.paths[S]||(t.paths[S]={}),t.paths[S].delete=new Oq(u,r,"delete all the records that match the provided query",{204:new Aq})),S="/"+s+"/{"+c+"}",T&&(t.paths[S]={},t.paths[S].get=new Xy([E],r,{200:new Zy({$ref:ga+i})},"retrieve a record by its primary key")),p&&(t.paths[S]||(t.paths[S]={}),t.paths[S].put=new Zue([E],r,i,"create or update the record with the URL path that maps to the record's primary key")),g&&(t.paths[S]||(t.paths[S]={}),t.paths[S].delete=new Oq([E],r,"delete a record with the given primary key",{204:new Aq})),T&&f.schema.enum.length>0&&(S="/"+s+"/{"+c+"}.{property}",t.paths[S]={},t.paths[S].get=new Xy([E,f],r,{200:new Zy({enum:_})},"used to retrieve the specified property of the specified record"))}return t}function Xue(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:ga+e}}}},this.security=t,this.responses={200:{description:rN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function Xy(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function Zy(e){this.description=rN,this.content={"application/json":{schema:e}}}function Aq(){this.description="successfully processed request, no content returned to client"}function Zue(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:ga+r}}}},this.responses={200:{description:rN}}}function Oq(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function bq(e){this.type="object",this.properties=e}function eN(e,t){this.type=e,this.format=t}function tN(e,t,r){this.name=e,this.in=t,this.schema=r}var yq,Jue,Jy,ga,rN,Iq=Ce(()=>{yq=B(wc()),Jue="3.0.3",Jy={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},ga="#/components/schemas/",rN="successful operation";a(Nq,"generateJsonApi");a(Xue,"Post");a(Xy,"Get");a(Zy,"Response200");a(Aq,"Response204");a(Zue,"Put");a(Oq,"Delete");a(bq,"ResourceSchema");a(eN,"Type");a(tN,"Parameter")});var aS={};tt(aS,{start:()=>rde});async function tde(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&iS(e);let i=new uo;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==wq){let T=oS.getMatch(o,n?"sse":"rest");if(!T)return t(e);e.handlerPath=T.path,c=new Vc(T.relativeURL),c.async=!0,l=T.Resource}let d=r["cache-control"];if(d){let T=Pq(d);for(let g of T)switch(g.name){case"max-age":e.expiresAt=g.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}let u=r["x-replicate-to"];if(u){let T=Pq(u).map(g=>(g.next?.name==="confirm"&&g.next.value>=0&&(e.replicatedConfirmation=+g.next.value),g.name));e.replicateTo=T.length===1&&+T[0]>=0?+T[0]:T[0]==="*"?void 0:T}let _=await wt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=$c(r["content-type"],!0)(e.body,e.headers)}catch(T){throw new Vu.ClientError(T,400)}if(e.authorize=!0,o===wq&&s==="GET"){if(e?.user?.role?.permission?.super_user)return Nq(oS);throw new Vu.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new Vu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Vu.ServerError(`Method ${s} is not recognized`,501)}}),E=200,f;if(_==null)E=s==="GET"||s==="HEAD"?404:204,nN.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else{if(_.status>0&&_.headers)return _.headers=my(_.headers,i),_.data!==void 0&&(_.body=Vf(_.data,e,_)),_;if(f=e.lastModified){ede[0]=f;let T=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),g=r["if-none-match"];g&&T==g?(_?.onDone&&_.onDone(),E=304,_=void 0):i.setIfNone("ETag",T),nN.lastModified&&i.setIfNone("Last-Modified",new Date(f).toUTCString())}}e.createdResource&&(E=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:E,headers:i,body:void 0},p=_?.wasLoadedFromSource?.();return p!==void 0&&(h.wasCacheMiss=p,!p&&f&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||f))/1e3))),_!==void 0&&(h.body=Vf(_,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Yc.warn(o):Yc.info(o):Yc.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 rde(e){nN=e,!Cq&&(Cq=!0,oS=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return tde(t,r)},e),e.server.ws(async(t,r,n)=>{zf++;let s=new In;Dq||(Dq=!0,N_(l=>{zf>0&&l.push({metric:"ws-connections",connections:zf,byThread:!0})}));let i;t.on("error",l=>{i=!0,Yc.warn(l)});let o;t.on("message",a(function(d){o||(o=$c(r.requestedContentType??r.headers.asObject["content-type"],!1));let u=o(d);s.push(u)},"message"));let c;t.on("close",()=>{zf--,Fn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),d=oS.getMatch(l,"ws");if(Fn(!!d,"connection","ws","connect"),d){r.handlerPath=d.path,Tr(h=>({count:h.count,total:zf}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let u=new Vc(d.relativeURL),_=d.Resource;c=(await wt(r,()=>_.connect(u,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=xc(f.value,r);t.send(h),Tr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){t.close(nde[l.statusCode]||1011,l.toString())}t.close()},e))}function Pq(e){return e.split(/\s*,\s*/).map(r=>{let n,s=r.split(/\s*;\s*/),i;for(;i=s.pop();)if(i.includes("=")){let[o,c]=i.split(/\s*=\s*/);n={name:o.toLowerCase(),value:c,next:n}}else n={name:i.toLowerCase(),next:n};return n})}var Yc,Vu,Mr,ede,nN,wq,Cq,oS,Dq,zf,nde,Lq=Ce(()=>{Mu();Ri();Yc=B(V()),Vu=B(ce());jf();Tl();dc();Nf();Iq();jf();Mr=new Uint8Array(8),ede=new Float64Array(Mr.buffer,0,1),nN={},wq="openapi";a(tde,"http");zf=0;a(rde,"start");nde={401:3e3,403:3003};a(Pq,"parseHeaderValue")});var sN=b((jDe,Mq)=>{var{recordAction:cS,recordActionBinary:sde}=(Ri(),ie(I_)),ide=require("fastify-plugin"),ode=200;Mq.exports=ide(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,d,u,_;l.config?.isOperation?(d=n.body?.operation,u="operation"):(d=l.url,u="fastify-route",_=l.method),cS(o,"duration",d,_,u),sde(s.raw.statusCode<400,"success",d,_,u);let E=ode;i?.pipe?(i.on("data",T=>{E+=T.length}),i.on("end",()=>{cS(performance.now()-c,"transfer",d,_,u),cS(E,"bytes-sent",d,_,u)})):(E+=i?.length||0,cS(E,"bytes-sent",d,_,u));let f=o.toFixed(3),h=s.getHeader("Server-Timing"),p=`db;dur=${f}`;s.header("Server-Timing",h?`${h}, ${p}`:p)}),r()},{name:"hdb-request-time"})});var uN=b((JDe,Hq)=>{var _S=require("clone"),fS=dt(),ade=ee(),uS=M(),QDe=V(),iN=require("fs"),aN=require("joi"),{string:dS}=aN.types(),{hdb_errors:cde,handleHDBError:lS}=ce(),{HDB_ERROR_MSGS:zDe,HTTP_STATUS_CODES:oN}=cde,{common_validators:Yu}=_i(),Uq=" is required",lde=["insert","update","upsert"],cN={database:{presence:!1,format:Yu.schema_format,length:Yu.schema_length},schema:{presence:!1,format:Yu.schema_format,length:Yu.schema_length},table:{presence:!0,format:Yu.schema_format,length:Yu.schema_length},action:{inclusion:{within:lde,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},ude={schema:dS.required(),table:dS.required(),action:dS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:dde,AWS_SECRET:_de,AWS_BUCKET:fde,AWS_FILE_KEY:Ede,REGION:hde}=uS.S3_BUCKET_AUTH_KEYS,mde={s3:{presence:!0},[`s3.${dde}`]:{presence:!0,type:"String"},[`s3.${_de}`]:{presence:!0,type:"String"},[`s3.${fde}`]:{presence:!0,type:"String"},[`s3.${Ede}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${hde}`]:{presence:!0,type:"String"}},vq=_S(cN);vq.data.presence={message:Uq};var Bq=_S(cN);Bq.file_path.presence={message:Uq};var pde=Object.assign(_S(cN),mde),lN=_S(ude);lN.csv_url=dS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();lN.passthrough_headers=aN.object();function Sde(e){let t=fS.validateObject(e,vq);return ES(e,t)}a(Sde,"dataObject");function Tde(e){let t=fS.validateBySchema(e,aN.object(lN));return ES(e,t)}a(Tde,"urlObject");function gde(e){let t=fS.validateObject(e,Bq);return ES(e,t)}a(gde,"fileObject");function Rde(e){let t=fS.validateObject(e,pde);return ES(e,t)}a(Rde,"s3FileObject");function ES(e,t){if(!t){let r=ade.checkGlobalSchemaTable(e.schema,e.table);if(r)return lS(new Error,r,oN.BAD_REQUEST);if(e.operation===uS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{iN.accessSync(e.file_path,iN.constants.R_OK|iN.constants.F_OK)}catch(n){return n.code===uS.NODE_ERROR_CODES.ENOENT?lS(n,`No such file or directory ${n.path}`,oN.BAD_REQUEST):n.code===uS.NODE_ERROR_CODES.EACCES?lS(n,`Permission denied ${n.path}`,oN.BAD_REQUEST):lS(n)}}return t}a(ES,"postValidateChecks");Hq.exports={dataObject:Sde,urlObject:Tde,fileObject:gde,s3FileObject:Rde}});var dN=b((ZDe,xq)=>{"use strict";var Jf=V(),hS=M();async function Ade(e,t,r,n=void 0){if(!e||typeof e!="function")throw new Error("Invalid function parameter");let s;try{return s=await e(t),r&&await r(t,s,n),t.operation===hS.OPERATIONS_ENUM.INSERT||t.operation===hS.OPERATIONS_ENUM.UPDATE||t.operation===hS.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===hS.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(Jf.info(i.message),i):i.http_resp_msg?(Jf.error(`Error calling operation: ${e.name}`),Jf.error(i.http_resp_msg),i):(Jf.error(`Error calling operation: ${e.name}`),Jf.error(i),i)}}a(Ade,"callOperationFunctionAsAwait");xq.exports={callOperationFunctionAsAwait:Ade}});var kq=b((tPe,Fq)=>{"use strict";var _N=class{static{a(this,"BulkLoadFileObject")}constructor(t,r,n,s,i,o,c=null){this.op=t,this.action=r,this.schema=n,this.table=s,this.file_path=i,this.file_type=o,this.role_perms=c}},fN=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};Fq.exports={BulkLoadFileObject:_N,BulkLoadDataObject:fN}});var qq=b((nPe,Gq)=>{"use strict";var EN=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};Gq.exports=EN});var gN=b((lPe,i$)=>{"use strict";var mS=Kr(),SS=uN(),Ode=require("needle"),zs=M(),iPe=_t(),Ku=ee(),{handleHDBError:$t,hdb_errors:Jq}=ce(),{HTTP_STATUS_CODES:Ur,HDB_ERROR_MSGS:hr,CHECK_LOGS_WRAPPER:Wc}=Jq,Wu=V(),hN=require("papaparse");Ku.promisifyPapaParse();var Js=require("fs-extra"),bde=require("path"),{chain:$q}=require("stream-chain"),Vq=require("stream-json/streamers/StreamArray"),Yq=require("stream-json/utils/Batch"),Kq=require("stream-chain/utils/comp"),{finished:Wq}=require("stream"),yde=te(),Xq=dN(),Nde=Fy(),{BulkLoadFileObject:pN,BulkLoadDataObject:Ide}=kq(),SN=Cy(),{verifyBulkLoadAttributePerms:Zq}=zp(),oPe=qq(),aPe=Ft(),cPe=Ji(),{databases:wde}=(Le(),ie(lt)),{coerceType:Cde}=(Qf(),ie(RN)),jq="No records parsed from csv file.",Kc=`${yde.get("HDB_ROOT")}/tmp`,{schema_regex:Dde}=_i(),Qq=1024*1024*2,zq=5e3,Pde={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};i$.exports={csvDataLoad:Lde,csvURLLoad:Mde,csvFileLoad:Ude,importFromS3:vde};async function Lde(e,t){let r=SS.dataObject(e);if(r)throw $t(r,r.message,Ur.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=r$(e.schema,e.table),i=hN.parse(e.data,{header:!0,skipEmptyLines:!0,transform:mN.bind(null,s),dynamicTyping:!1}),o=new SN;e.hdb_user&&e.hdb_user.role&&e.hdb_user.role.permission&&e.hdb_user.role.permission.super_user!==!0&&Zq(e.hdb_user.role.permission,this.job_operation_function.name,e.action,e.schema,e.table,i.meta.fields,o);let c=o.getPermsResponse();if(c)throw $t(new Error,c,Ur.BAD_REQUEST,void 0,void 0,!0);let l=new Ide(e.action,e.schema,e.table,i.data);return n=await Xq.callOperationFunctionAsAwait(n$,l,null),n.message===jq?jq:s$(n.records,n.number_written)}catch(s){throw jc(s)}}a(Lde,"csvDataLoad");async function Mde(e){let t=SS.urlObject(e);if(t)throw $t(t,t.message,Ur.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Kc}/${r}`;try{await Bde(e,r)}catch(s){throw Wu.error(hr.DOWNLOAD_FILE_ERR(r)+" - "+s),$t(s,Wc(hr.DOWNLOAD_FILE_ERR(r)))}try{let s=new pN(this.job_operation_function.name,e.action,e.schema,e.table,n,zs.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission),i=await TN(s);return await pS(n),i}catch(s){throw await pS(n),jc(s)}}a(Mde,"csvURLLoad");async function Ude(e){let t=SS.fileObject(e);if(t)throw $t(t,t.message,Ur.BAD_REQUEST,void 0,void 0,!0);let r=new pN(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,zs.VALID_S3_FILE_TYPES.CSV,e.hdb_user.role.permission);try{return await TN(r)}catch(n){throw jc(n)}}a(Ude,"csvFileLoad");async function vde(e){let t=SS.s3FileObject(e);if(t)throw $t(t,t.message,Ur.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=bde.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Kc}/${s}`;let i=new pN(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user.role.permission);await Hde(s,e);let o=await TN(i);return await pS(r),o}catch(n){throw await pS(r),jc(n)}}a(vde,"importFromS3");async function Bde(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await Ode("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw $t(n,s,n.statusCode,zs.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Fde(r,e.csv_url),await xde(t,r.raw)}a(Bde,"downloadCSVFile");async function Hde(e,t){try{let r=`${Kc}/${e}`;await Js.mkdirp(Kc),await Js.writeFile(`${Kc}/${e}`,"",{flag:"a+"});let n=await Js.createWriteStream(r),s=await Nde.getFileStreamFromS3(t);await new Promise((i,o)=>{s.on("error",function(c){o(c)}),s.pipe(n).on("error",function(c){o(c)}).on("close",function(){Wu.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Wu.error(hr.S3_DOWNLOAD_ERR+" - "+r),$t(r,Wc(hr.S3_DOWNLOAD_ERR))}}a(Hde,"downloadFileFromS3");async function xde(e,t){try{await Js.mkdirp(Kc),await Js.writeFile(`${Kc}/${e}`,t)}catch(r){throw Wu.error(hr.WRITE_TEMP_FILE_ERR),$t(r,Wc(hr.DEFAULT_BULK_LOAD_ERR))}}a(xde,"writeFileToTempFolder");async function pS(e){if(e)try{await Js.access(e),await Js.unlink(e)}catch{Wu.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(pS,"deleteTempFile");function Fde(e,t){if(e.statusCode!==Jq.HTTP_STATUS_CODES.OK)throw $t(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Ur.BAD_REQUEST);if(!Pde[e.headers["content-type"]])throw $t(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Ur.BAD_REQUEST);if(!e.raw)throw $t(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Ur.BAD_REQUEST)}a(Fde,"validateURLResponse");async function TN(e){try{let t;switch(e.file_type){case zs.VALID_S3_FILE_TYPES.CSV:t=await kde(e);break;case zs.VALID_S3_FILE_TYPES.JSON:t=await Gde(e);break;default:throw $t(new Error,hr.DEFAULT_BULK_LOAD_ERR,Ur.BAD_REQUEST,zs.LOG_LEVELS.ERROR,hr.INVALID_FILE_EXT_ERR(e))}return s$(t.records,t.number_written)}catch(t){throw jc(t)}}a(TN,"fileLoad");async function e$(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 mS.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&Zq(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=$t(c);r(l)}}a(e$,"validateChunk");async function t$(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Ku.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Ku.isEmpty(c)&&!Ku.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(d=>c.add(d))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await Xq.callOperationFunctionAsAwait(n$,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=$t(c,Wc(hr.INSERT_CSV_ERR),Ur.INTERNAL_SERVER_ERROR,zs.LOG_LEVELS.ERROR,hr.INSERT_CSV_ERR+" - "+c);r(l)}}a(t$,"insertChunk");async function kde(e){let t={records:0,number_written:0},r=r$(e.schema,e.table);try{let n=new SN,s=Js.createReadStream(e.file_path,{highWaterMark:Qq});s.setEncoding("utf8"),await hN.parsePromise(s,e$.bind(null,e,n),mN.bind(null,r));let i=n.getPermsResponse();if(i)throw $t(new Error,i,Ur.BAD_REQUEST);return s=Js.createReadStream(e.file_path,{highWaterMark:Qq}),s.setEncoding("utf8"),await hN.parsePromise(s,t$.bind(null,e,t),mN.bind(null,r)),s.destroy(),t}catch(n){throw $t(n,Wc(hr.PAPA_PARSE_ERR),Ur.INTERNAL_SERVER_ERROR,zs.LOG_LEVELS.ERROR,hr.PAPA_PARSE_ERR+n)}}a(kde,"callPapaParse");function r$(e,t){let r=wde[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>Cde(i,s));return n}a(r$,"createTransformMap");function mN(e,t,r){let n=e.get(r);return n?n(t):Ku.autoCast(t)}a(mN,"typeFunction");async function Gde(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new SN,s=$q([Js.createReadStream(e.file_path,{encoding:"utf-8"}),Vq.withParser(),c=>c.value,new Yq({batchSize:zq}),Kq(async c=>{await e$(e,n,r,c)})]);await new Promise((c,l)=>{Wq(s,d=>{d?l(d):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw $t(new Error,i,Ur.BAD_REQUEST);let o=$q([Js.createReadStream(e.file_path,{encoding:"utf-8"}),Vq.withParser(),c=>c.value,new Yq({batchSize:zq}),Kq(async c=>{await t$(e,t,r,c)})]);return await new Promise((c,l)=>{Wq(o,d=>{d?l(d):c()}),o.resume()}),t}catch(n){throw $t(n,Wc(hr.INSERT_JSON_ERR),Ur.INTERNAL_SERVER_ERROR,zs.LOG_LEVELS.ERROR,hr.INSERT_JSON_ERR+n)}}a(Gde,"insertJson");async function n$(e){let t={};try{e.data&&e.data.length>0&&qde(e.data[0])?t=await $de(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Wu.info(t.message))}catch(r){throw jc(r)}return t}a(n$,"callBulkFileLoad");function qde(e){let t=Object.keys(e);for(let r of t)if(!Dde.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(qde,"validateColumnNames");async function $de(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=mS.insert;break;case"update":i=mS.update;break;case"upsert":i=mS.upsert;break;default:throw $t(new Error,hr.INVALID_ACTION_PARAM_ERR(n),Ur.BAD_REQUEST,zs.LOG_LEVELS.ERROR,hr.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let u=global.hdb_schema[t][r].hash_attribute,_=e.length;for(;_--;)o.skipped_hashes.indexOf(e[_][u])>=0&&e.splice(_,1)}let l=Ku.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw jc(o)}}a($de,"bulkFileLoad");function s$(e,t){return`successfully loaded ${t} of ${e} records`}a(s$,"buildResponseMsg");function jc(e){return $t(e,Wc(hr.DEFAULT_BULK_LOAD_ERR),Ur.INTERNAL_SERVER_ERROR,zs.LOG_LEVELS.ERROR,hr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(jc,"buildTopLevelErrMsg")});var a$=b((dPe,o$)=>{"use strict";var AN=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};o$.exports=AN});var u$=b((fPe,l$)=>{"use strict";var Vde=M(),c$=require("moment"),Yde=require("uuid").v4,ON=class{static{a(this,"JobObject")}constructor(){this.id=Yde(),this.type=void 0,this.start_datetime=c$().valueOf(),this.created_datetime=c$().valueOf(),this.end_datetime=void 0,this.status=Vde.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};l$.exports=ON});var bN=b((hPe,S$)=>{"use strict";var Kde=require("uuid").v4,h$=Kr(),m$=Yr(),Wde=ks(),jde=Hl(),Qde=a$(),bt=M(),zde=u$(),Jde=J_(),bs=V(),Xde=e_(),ju=ee(),{promisify:Zde}=require("util"),Qc=require("moment"),e_e=Xp(),TS=uN(),d$=SR(),{deleteTransactionLogsBeforeValidator:t_e}=by(),{handleHDBError:_$,hdb_errors:r_e}=ce(),{HTTP_STATUS_CODES:f$}=r_e,E$=m$.searchByValue,n_e=m$.searchByHash,s_e=h$.insert,i_e=Zde(e_e.evaluateSQL),o_e=h$.update;S$.exports={addJob:l_e,updateJob:d_e,handleGetJob:a_e,handleGetJobsByStartDate:c_e,getJobById:p$};async function a_e(e){try{let t=await p$(e.id);return ju.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}catch(t){let r=`There was an error getting job: ${t}`;throw bs.error("There was an error getting job",t),new Error(r)}}a(a_e,"handleGetJob");async function c_e(e){try{let t=await u_e(e);if(bs.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=Qc(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Qc(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 bs.error(r),new Error(r)}}a(c_e,"handleGetJobsByStartDate");async function l_e(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||ju.isEmptyOrZeroLength(e.operation)){let u="job parameter is invalid";return bs.info(u),t.error=u,t}if(!bt.JOB_TYPE_ENUM[e.operation])return bs.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case bt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=TS.fileObject(e);break;case bt.OPERATIONS_ENUM.CSV_URL_LOAD:n=TS.urlObject(e);break;case bt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=TS.dataObject(e);break;case bt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=TS.s3FileObject(e);break;case bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=d$(e,"date");break;case bt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=d$(e,"timestamp");break;case bt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=t_e(e);break;case bt.OPERATIONS_ENUM.RESTART_SERVICE:if(bt.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw _$(new Error,"Invalid service",f$.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw _$(n,n.message,f$.BAD_REQUEST,void 0,void 0,!0);let s=new zde;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 Wde(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await E$(i))}catch(u){let _=`There was an error inserting a new job: ${u}`;return bs.error(_),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Kde();try{o=await E$(i)}catch(u){let _=`There was an error inserting a new job: ${u}`;return bs.error(_),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return bs.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Xde(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),d;try{d=await s_e(l)}catch(u){return bs.error(`There was an error inserting a job for job type: ${e.operation} -- ${u}`),t.success=!1,t}if(d.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let u=`Created a job with type ${s.type} and id ${s.id}`;t.message=u,t.createdJob=s,t.success=!0,bs.trace(u)}return t}a(l_e,"addJob");async function u_e(e){let t=Qc(e.from_date,Qc.ISO_8601),r=Qc(e.to_date,Qc.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new Qde(n,e.hdb_user);try{return await i_e(s)}catch(i){throw bs.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(u_e,"getJobsInDateRange");async function p$(e){if(ju.isEmptyOrZeroLength(e))return ju.errorizeMessage("Invalid job ID specified.");let t=new jde(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await n_e(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return bs.error(n),ju.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(p$,"getJobById");async function d_e(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(ju.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===bt.JOB_STATUS_ENUM.COMPLETE||e.status===bt.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Qc().valueOf());let t=new Jde(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await o_e(t),r}a(d_e,"updateJob")});var N$=b((pPe,y$)=>{"use strict";var T$=ee(),mr=M(),__e=require("moment"),gS=gN(),Xf=V(),g$=bN(),R$=Zp(),A$=qo(),O$=st(),f_e=Kp(),E_e=Pu(),{parentPort:h_e,isMainThread:b$}=require("worker_threads"),{onMessageByType:m_e}=st(),yN=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function p_e(e){if(!e||Object.keys(e).length===0)throw new Error("Empty runner passed to parseMessage");if(!e.json||Object.keys(e.json).length===0)throw new Error("Empty JSON passed to parseMessage");if(!e.job||Object.keys(e.job).length===0)throw new Error("Empty job passed to parseMessage");if(T$.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(T$.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case mr.JOB_TYPE_ENUM.csv_file_load:await Mi(e,gS.csvFileLoad);break;case mr.JOB_TYPE_ENUM.csv_url_load:await Mi(e,gS.csvURLLoad);break;case mr.JOB_TYPE_ENUM.csv_data_load:await Mi(e,gS.csvDataLoad);break;case mr.JOB_TYPE_ENUM.import_from_s3:await Mi(e,gS.importFromS3);break;case mr.JOB_TYPE_ENUM.empty_trash:break;case mr.JOB_TYPE_ENUM.export_local:await Mi(e,R$.export_local);break;case mr.JOB_TYPE_ENUM.export_to_s3:await Mi(e,R$.export_to_s3);break;case mr.JOB_TYPE_ENUM.delete_files_before:case mr.JOB_TYPE_ENUM.delete_records_before:await Mi(e,A$.deleteFilesBefore);break;case mr.JOB_TYPE_ENUM.delete_audit_logs_before:await Mi(e,A$.deleteAuditLogsBefore);break;case mr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Mi(e,f_e.deleteTransactionLogsBefore);break;case mr.JOB_TYPE_ENUM.restart_service:return await Mi(e,E_e.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(p_e,"parseMessage");async function Mi(e,t){try{e.job.status=mr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=__e().valueOf(),await g$.updateJob(e.job),await S_e(e.job.id)}catch(r){let n=r.message!==void 0?r.message:r;typeof n=="string"?(n=`There was an error running ${t.name} job with id ${e.job.id} - ${n}`,r.message=n):Xf.error(`There was an error running ${t.name} job with id ${e.job.id}`),Xf.error(n),e.job.message=n,e.job.status=mr.JOB_STATUS_ENUM.ERROR;try{await g$.updateJob(e.job)}catch(s){throw Xf.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Mi,"runJob");async function S_e(e){Xf.trace("launching job thread:",e),b$?O$.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[mr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):h_e.postMessage({type:mr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(S_e,"launchJobThread");b$&&m_e(mr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{O$.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[mr.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){Xf.error(r)}});y$.exports={parseMessage:p_e,RunnerMessage:yN}});var w$=b((TPe,I$)=>{"use strict";var NN=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};I$.exports=NN});var K$=b((APe,LN)=>{"use strict";var yS=Yr(),CN=Xp(),RS=gN(),So=j_(),AS=Ei(),tE=qo(),T_e=kO(),Zf=vn(),OS=Jm(),Lt=Oy(),bS=V(),g_e=JO(),R_e=dp(),C$=Pb(),A_e=fp(),O_e=Ub(),b_e=vb(),y_e=xb(),N_e=kb(),IN=pp(),D$=Zp(),I_e=zp(),DN=bN(),q=M(),{hdb_errors:nE,handleHDBError:rE}=ce(),{HTTP_STATUS_CODES:P$}=nE,wN=Wb(),L$=Pu(),q$=require("util"),Qu=Kr(),w_e=is(),C_e=pu(),M$=N$(),U$=ef(),v$=(vp(),ie(If)),B$=It(),H$=Kp(),x$=Gp(),{setServerUtilities:D_e}=(Qf(),ie(RN)),{CONTEXT:RPe}=(rs(),ie(EA)),{_assignPackageExport:P_e}=Yi(),{transformReq:L_e}=ee(),{server:M_e}=(Vr(),ie(Va)),Zr=bS.loggerWithTag("operation"),eE=Ks(),F$=(Pc(),ie(Dc)),U_e=dN(),k$=yS.searchByHash,v_e=yS.searchByValue,B_e=q$.promisify(yS.search),H_e=q$.promisify(CN.evaluateSQL),x_e={[q.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[q.OPERATIONS_ENUM.CREATE_TABLE]:!0,[q.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[q.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[q.OPERATIONS_ENUM.DROP_TABLE]:!0,[q.OPERATIONS_ENUM.DROP_SCHEMA]:!0},j=w$();async function $$(e,t){try{if(e.body.operation!=="read_log"&&(bS.log_level===q.LOG_LEVELS.INFO||bS.log_level===q.LOG_LEVELS.DEBUG||bS.log_level===q.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;Zr.info(o)}}catch(n){Zr.error(n)}let r=await U_e.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return x_e[e.body.operation]&&w_e.setSchemaDataToGlobal(n=>{n&&Zr.error(n)}),r}a($$,"processLocalTransaction");var G$=k_e();LN.exports={chooseOperation:V$,getOperationFunction:Y$,operation:PN,processLocalTransaction:$$};D_e(LN.exports);M_e.operation=PN;function V$(e){let t;try{t=Y$(e)}catch(s){throw Zr.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=CN.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=CN.checkASTPermissions(e,i);if(o)throw Zr.error(`${P$.FORBIDDEN} from operation ${e.operation}`),Zr.warn(`User '${e.hdb_user.username}' is not permitted to ${e.operation}`),rE(new Error,o,nE.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==q.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==q.OPERATIONS_ENUM.LOGIN&&e.operation!==q.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=I_e.verifyPerms(i,s);if(o)throw Zr.error(`${P$.FORBIDDEN} from operation ${e.operation}`),Zr.warn(`User '${i.hdb_user.username}' is not permitted to ${i.operation}`),rE(new Error,o,nE.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw rE(s,"There was an error when trying to choose an operation path")}return r}a(V$,"chooseOperation");function Y$(e){if(Zr.trace(`getOperationFunction with operation: ${e.operation}`),G$.has(e.operation))return G$.get(e.operation);throw rE(new Error,nE.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),nE.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(Y$,"getOperationFunction");P_e("operation",PN);function PN(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=V$(e);return $$({body:e},n)}a(PN,"operation");async function F_e(e){Zr.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[q.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case q.OPERATIONS_ENUM.INSERT:o=await Qu.insert(i);break;case q.OPERATIONS_ENUM.UPDATE:o=await Qu.update(i);break;case q.OPERATIONS_ENUM.UPSERT:o=await Qu.upsert(i);break;case q.OPERATIONS_ENUM.DELETE:o=await tE.deleteRecord(i);break;default:Zr.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){Zr.info("Invalid operation in transaction"),Zr.error(o)}}a(F_e,"catchup");async function Xs(e){L_e(e);let t,r;try{r=await DN.addJob(e),t=r.createdJob,Zr.info("addJob result",r);let n=new M$.RunnerMessage(t,e);return{message:await M$.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 Zr.error(s),rE(n,s)}}a(Xs,"executeJob");function k_e(){let e=new Map;return e.set(q.OPERATIONS_ENUM.INSERT,new j(Qu.insert)),e.set(q.OPERATIONS_ENUM.UPDATE,new j(Qu.update)),e.set(q.OPERATIONS_ENUM.UPSERT,new j(Qu.upsert)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new j(yS.searchByConditions)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_HASH,new j(k$)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_ID,new j(k$)),e.set(q.OPERATIONS_ENUM.SEARCH_BY_VALUE,new j(v_e)),e.set(q.OPERATIONS_ENUM.SEARCH,new j(B_e)),e.set(q.OPERATIONS_ENUM.SQL,new j(H_e)),e.set(q.OPERATIONS_ENUM.CSV_DATA_LOAD,new j(Xs,RS.csvDataLoad)),e.set(q.OPERATIONS_ENUM.CSV_FILE_LOAD,new j(Xs,RS.csvFileLoad)),e.set(q.OPERATIONS_ENUM.CSV_URL_LOAD,new j(Xs,RS.csvURLLoad)),e.set(q.OPERATIONS_ENUM.IMPORT_FROM_S3,new j(Xs,RS.importFromS3)),e.set(q.OPERATIONS_ENUM.CREATE_SCHEMA,new j(So.createSchema)),e.set(q.OPERATIONS_ENUM.CREATE_DATABASE,new j(So.createSchema)),e.set(q.OPERATIONS_ENUM.CREATE_TABLE,new j(So.createTable)),e.set(q.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new j(So.createAttribute)),e.set(q.OPERATIONS_ENUM.DROP_SCHEMA,new j(So.dropSchema)),e.set(q.OPERATIONS_ENUM.DROP_DATABASE,new j(So.dropSchema)),e.set(q.OPERATIONS_ENUM.DROP_TABLE,new j(So.dropTable)),e.set(q.OPERATIONS_ENUM.DROP_ATTRIBUTE,new j(So.dropAttribute)),e.set(q.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new j(AS.describeSchema)),e.set(q.OPERATIONS_ENUM.DESCRIBE_DATABASE,new j(AS.describeSchema)),e.set(q.OPERATIONS_ENUM.DESCRIBE_TABLE,new j(AS.describeTable)),e.set(q.OPERATIONS_ENUM.DESCRIBE_ALL,new j(AS.describeAll)),e.set(q.OPERATIONS_ENUM.DELETE,new j(tE.deleteRecord)),e.set(q.OPERATIONS_ENUM.ADD_USER,new j(Zf.addUser)),e.set(q.OPERATIONS_ENUM.ALTER_USER,new j(Zf.alterUser)),e.set(q.OPERATIONS_ENUM.DROP_USER,new j(Zf.dropUser)),e.set(q.OPERATIONS_ENUM.LIST_USERS,new j(Zf.listUsersExternal)),e.set(q.OPERATIONS_ENUM.LIST_ROLES,new j(OS.listRoles)),e.set(q.OPERATIONS_ENUM.ADD_ROLE,new j(OS.addRole)),e.set(q.OPERATIONS_ENUM.ALTER_ROLE,new j(OS.alterRole)),e.set(q.OPERATIONS_ENUM.DROP_ROLE,new j(OS.dropRole)),e.set(q.OPERATIONS_ENUM.USER_INFO,new j(Zf.userInfo)),e.set(q.OPERATIONS_ENUM.READ_LOG,new j(g_e)),e.set(q.OPERATIONS_ENUM.ADD_NODE,new j(R_e)),e.set(q.OPERATIONS_ENUM.UPDATE_NODE,new j(C$)),e.set(q.OPERATIONS_ENUM.SET_NODE_REPLICATION,new j(C$)),e.set(q.OPERATIONS_ENUM.REMOVE_NODE,new j(A_e)),e.set(q.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new j(O_e)),e.set(q.OPERATIONS_ENUM.PURGE_STREAM,new j(b_e)),e.set(q.OPERATIONS_ENUM.SET_CONFIGURATION,new j(B$.setConfiguration)),e.set(q.OPERATIONS_ENUM.CLUSTER_STATUS,new j(y_e.clusterStatus)),e.set(q.OPERATIONS_ENUM.CLUSTER_NETWORK,new j(N_e)),e.set(q.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new j(IN.setRoutes)),e.set(q.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new j(IN.getRoutes)),e.set(q.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new j(IN.deleteRoutes)),e.set(q.OPERATIONS_ENUM.EXPORT_TO_S3,new j(Xs,D$.export_to_s3)),e.set(q.OPERATIONS_ENUM.CREATE_CSR,new j(eE.createCsr)),e.set(q.OPERATIONS_ENUM.SIGN_CERTIFICATE,new j(eE.signCertificate)),e.set(q.OPERATIONS_ENUM.LIST_CERTIFICATES,new j(eE.listCertificates)),e.set(q.OPERATIONS_ENUM.ADD_CERTIFICATES,new j(eE.addCertificate)),e.set(q.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new j(eE.removeCertificate)),e.set(q.OPERATIONS_ENUM.ADD_NODE_BACK,new j(F$.addNodeBack)),e.set(q.OPERATIONS_ENUM.REMOVE_NODE_BACK,new j(F$.removeNodeBack)),e.set(q.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new j(Xs,tE.deleteFilesBefore)),e.set(q.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new j(Xs,tE.deleteFilesBefore)),e.set(q.OPERATIONS_ENUM.EXPORT_LOCAL,new j(Xs,D$.export_local)),e.set(q.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new j(DN.handleGetJobsByStartDate)),e.set(q.OPERATIONS_ENUM.GET_JOB,new j(DN.handleGetJob)),e.set(q.OPERATIONS_ENUM.GET_FINGERPRINT,new j(wN.getFingerprint)),e.set(q.OPERATIONS_ENUM.SET_LICENSE,new j(wN.setLicense)),e.set(q.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new j(wN.getRegistrationInfo)),e.set(q.OPERATIONS_ENUM.RESTART,new j(L$.restart)),e.set(q.OPERATIONS_ENUM.RESTART_SERVICE,new j(Xs,L$.restartService)),e.set(q.OPERATIONS_ENUM.CATCHUP,new j(F_e)),e.set(q.OPERATIONS_ENUM.SYSTEM_INFORMATION,new j(C_e.systemInformation)),e.set(q.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new j(Xs,tE.deleteAuditLogsBefore)),e.set(q.OPERATIONS_ENUM.READ_AUDIT_LOG,new j(T_e)),e.set(q.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new j(U$.createTokens)),e.set(q.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new j(U$.refreshOperationToken)),e.set(q.OPERATIONS_ENUM.LOGIN,new j(v$.login)),e.set(q.OPERATIONS_ENUM.LOGOUT,new j(v$.logout)),e.set(q.OPERATIONS_ENUM.GET_CONFIGURATION,new j(B$.getConfiguration)),e.set(q.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new j(Lt.customFunctionsStatus)),e.set(q.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new j(Lt.getCustomFunctions)),e.set(q.OPERATIONS_ENUM.GET_COMPONENT_FILE,new j(Lt.getComponentFile)),e.set(q.OPERATIONS_ENUM.GET_COMPONENTS,new j(Lt.getComponents)),e.set(q.OPERATIONS_ENUM.SET_COMPONENT_FILE,new j(Lt.setComponentFile)),e.set(q.OPERATIONS_ENUM.DROP_COMPONENT,new j(Lt.dropComponent)),e.set(q.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new j(Lt.getCustomFunction)),e.set(q.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new j(Lt.setCustomFunction)),e.set(q.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new j(Lt.dropCustomFunction)),e.set(q.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new j(Lt.addComponent)),e.set(q.OPERATIONS_ENUM.ADD_COMPONENT,new j(Lt.addComponent)),e.set(q.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new j(Lt.dropCustomFunctionProject)),e.set(q.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new j(Lt.packageComponent)),e.set(q.OPERATIONS_ENUM.PACKAGE_COMPONENT,new j(Lt.packageComponent)),e.set(q.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new j(Lt.deployComponent)),e.set(q.OPERATIONS_ENUM.DEPLOY_COMPONENT,new j(Lt.deployComponent)),e.set(q.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new j(H$.readTransactionLog)),e.set(q.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new j(Xs,H$.deleteTransactionLogsBefore)),e.set(q.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new j(x$.installModules)),e.set(q.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new j(x$.auditModules)),e.set(q.OPERATIONS_ENUM.GET_BACKUP,new j(So.getBackup)),e.set(q.OPERATIONS_ENUM.ADD_SSH_KEY,new j(Lt.addSSHKey)),e.set(q.OPERATIONS_ENUM.UPDATE_SSH_KEY,new j(Lt.updateSSHKey)),e.set(q.OPERATIONS_ENUM.DELETE_SSH_KEY,new j(Lt.deleteSSHKey)),e.set(q.OPERATIONS_ENUM.LIST_SSH_KEYS,new j(Lt.listSSHKeys)),e.set(q.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new j(Lt.setSSHKnownHosts)),e.set(q.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new j(Lt.getSSHKnownHosts)),e}a(k_e,"initializeOperationFunctionMap")});var IS=b((bPe,Q$)=>{"use strict";var MN=M(),G_e=ee(),sE=V(),{handleHDBError:UN,hdb_errors:NS}=ce(),{isMainThread:q_e}=require("worker_threads"),{Readable:$_e}=require("stream"),W$=require("os"),V_e=require("util"),Y_e=ab(),K_e=V_e.promisify(Y_e.authorize),j$=K$(),{createGzip:W_e,constants:j_e}=require("zlib");function Q_e(e){let t=`Found an uncaught exception with message: ${e.message}. ${W$.EOL}Stack: ${e.stack} ${W$.EOL}Terminating ${q_e?"HDB":"thread"}.`;console.error(t),sE.fatal(t),process.exit(1)}a(Q_e,"handleServerUncaughtException");function z_e(e,t,r){if(sE[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:NS.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR;return typeof e=="string"?r.code(n).send({error:e}):r.code(n).send(e.message?{error:e.message}:e)}a(z_e,"serverErrorHandler");function J_e(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=UN(new Error,"Invalid JSON.",NS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(G_e.isEmpty(e.body.operation)){let n=UN(new Error,"Request body must include an 'operation' property.",NS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(J_e,"reqBodyValidationHandler");function X_e(e,t,r){let n;e.body.operation!==MN.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==MN.OPERATIONS_ENUM.LOGIN&&e.body.operation!==MN.OPERATIONS_ENUM.LOGOUT?K_e(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{sE.warn(s),sE.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(UN(s,i,NS.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.hdb_auth_header=e.headers.authorization,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(X_e,"authHandler");async function Z_e(e,t,r=!1){let n;try{r&&(e.body.operation!=="configure_cluster"||e.body.operation!=="set_configuration")&&(e.body.bypass_auth=r),n=j$.chooseOperation(e.body);let s=await j$.processLocalTransaction(e,n);if(s instanceof $_e&&s.headers){for(let[i,o]of s.headers)t.header(i,o);e.headers["accept-encoding"]?.includes("gzip")&&(t.header("content-encoding","gzip"),s=s.pipe(W_e({level:j_e.Z_BEST_SPEED})))}return s}catch(s){throw sE.error(s),s}}a(Z_e,"handlePostRequest");Q$.exports={authHandler:X_e,handlePostRequest:Z_e,handleServerUncaughtException:Q_e,serverErrorHandler:z_e,reqBodyValidationHandler:J_e}});var Z$=b((NPe,X$)=>{"use strict";var efe=require("fastify-plugin"),{handlePostRequest:z$,authHandler:tfe,reqBodyValidationHandler:rfe}=IS();async function nfe(e){e.decorate("hdbCore",{preValidation:[rfe,tfe],request:t=>J$(z$(t,response)),requestWithoutAuthentication:(t,r)=>J$(z$(t,r,!0))})}a(nfe,"hdbCore");async function J$(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(J$,"convertAsyncIterators");X$.exports=efe(nfe)});var rV=b((CPe,tV)=>{"use strict";var wPe=require("fs"),vN=te();vN.initSync();var{CONFIG_PARAMS:eV}=M(),sfe=1024*1024*1024;function ife(e){let t=vN.get(eV.HTTP_TIMEOUT),r=vN.get(eV.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:sfe,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,https:e}}a(ife,"getServerOptions");tV.exports=ife});var iV=b((PPe,sV)=>{"use strict";var BN=te();BN.initSync();var{CONFIG_PARAMS:nV}=M();function ofe(){let e=BN.get(nV.HTTP_CORSACCESSLIST),t=BN.get(nV.HTTP_CORS),r;return t&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},e&&e.length>0&&e[0]!==null&&e[0]!=="*"&&(r.origin=(n,s)=>s(null,e.indexOf(n)!==-1))),r}a(ofe,"getCORSOptions");sV.exports=ofe});var cV=b((MPe,aV)=>{"use strict";var oV=te();oV.initSync();var afe=M();function cfe(){return oV.get(afe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(cfe,"getHeaderTimeoutConfig");aV.exports=cfe});var xN={};tt(xN,{customFunctionsServer:()=>dfe,ready:()=>OV,start:()=>ufe});function ufe(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){To||(To=AV(t),nt.http((await To).server));let o=await To,c=(0,HN.dirname)(s),l=(0,HN.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!lV.has(c)){lV.add(c);try{o.register(ffe(c,l))}catch(d){if(d.message==="Root plugin has already booted")pt.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw d}}},ready:OV}}async function dfe(){try{pt.info("In Custom Functions Fastify server"+process.cwd()),pt.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),pt.debug(`Custom Functions server process ${process.pid} starting up.`),await _fe();let e=hV.get(mV.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=To=await AV(e)}catch(r){throw pt.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw pt.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){pt.error(`Custom Functions ${process.pid} Error: ${e}`),pt.error(e),process.exit(1)}}async function _fe(){try{pt.info("Custom Functions starting configuration."),await pV.setUsersToGlobal(),pt.info("Custom Functions completed configuration.")}catch(e){pt.error(e)}}function ffe(e,t){return async function(r){try{pt.info("Custom Functions starting buildRoutes"),pt.trace("Loading fastify routes folder "+e),(0,uV.existsSync)(e)&&r.register(EV.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:pt.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?pt.error(s.message):s&&pt.error(s),o()})}catch(n){pt.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function AV(e){pt.info("Custom Functions starting buildServer.");let t=(0,SV.default)(e),r=(0,dV.default)(t);r.server.headersTimeout=(0,gV.default)(),r.setErrorHandler(RV.serverErrorHandler);let n=(0,TV.default)();return n&&r.register(_V.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(fV.default),await r.register(lfe),await r.after(),Ky(r),pt.info("Custom Functions completed buildServer."),r}function OV(){if(To)return To.then?To.then(e=>e.ready()):To.ready()}var HN,uV,dV,_V,fV,EV,hV,mV,pt,lfe,pV,SV,TV,gV,RV,To,lV,bV=Ce(()=>{HN=require("path"),uV=require("fs"),dV=B(require("fastify")),_V=B(require("@fastify/cors")),fV=B(sN()),EV=B(require("@fastify/autoload")),hV=B(te()),mV=B(M()),pt=B(V()),lfe=B(Z$()),pV=B(vn()),SV=B(rV()),TV=B(iV()),gV=B(cV()),RV=B(IS());Mu();Vr();lV=new Set;a(ufe,"start");a(dfe,"customFunctionsServer");a(_fe,"setUp");a(ffe,"buildRouteFolder");a(AV,"buildServer");a(OV,"ready")});var FN={};tt(FN,{start:()=>Efe});function Efe(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,CV.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){NV||(NV=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=yV.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,IV.default)(s,(0,wV.realpathSync)(o))}}return i(s)},{runFirst:!0})),yV.set(r,n)}}}var IV,wV,CV,yV,NV,DV=Ce(()=>{IV=B(require("send")),wV=require("fs"),CV=B(require("serve-static")),yV=new Map;a(Efe,"start")});var $N={};tt($N,{Request:()=>kN,createReuseportFd:()=>wS});var PV,kN,GN,qN,wS,CS=Ce(()=>{PV=require("os"),kN=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new qN(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new GN(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},GN=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},qN=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,PV.platform)()!="win32"&&(wS=require("node-unix-socket").createReuseportFd)});var YN=b((kPe,LV)=>{"use strict";var iE=te();iE.initSync();var zu=require("fs-extra"),VN=require("path"),Ju=M(),hfe=require("crypto"),mfe=require("uuid").v4;LV.exports=pfe;function pfe(){if(iE.getHdbBasePath()!==void 0){let e=VN.join(iE.getHdbBasePath(),Ju.LICENSE_KEY_DIR_NAME,Ju.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=VN.join(iE.getHdbBasePath(),Ju.LICENSE_KEY_DIR_NAME,Ju.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=VN.join(iE.getHdbBasePath(),Ju.LICENSE_KEY_DIR_NAME,Ju.JWT_ENUM.JWT_PASSPHRASE_NAME);try{zu.accessSync(r),zu.accessSync(e),zu.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=mfe(),i=hfe.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});zu.writeFileSync(r,s),zu.writeFileSync(e,i.privateKey),zu.writeFileSync(t,i.publicKey)}else throw n}}}a(pfe,"checkJWTTokenExist")});var UV=b((qPe,MV)=>{"use strict";var KN=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};MV.exports={HdbInfoInsertObject:KN}});var HV=b((VPe,BV)=>{"use strict";var vV=M(),WN=class{static{a(this,"UpgradeObject")}constructor(t,r){this[vV.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[vV.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};BV.exports={UpgradeObject:WN}});var DS=b((KPe,FV)=>{"use strict";var ys=require("prompt"),Xu=require("chalk"),xV=V(),Zs=require("os"),jN=$a(),QN=["yes","y"];async function Sfe(e){let t=`${Zs.EOL}`+Xu.bold.green("Your current HarperDB version requires that we complete an update process.")+`${Zs.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${Zs.EOL}${Zs.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${Zs.EOL}`;ys.override=jN(["CONFIRM_UPGRADE"]),ys.start(),ys.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Xu.magenta(`${Zs.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 ys.get([r])}catch(s){return xV.error("There was an error when prompting user about an upgrade."),xV.error(s),!1}return QN.includes(n.CONFIRM_UPGRADE)}a(Sfe,"forceUpdatePrompt");async function Tfe(e){let t=`${Zs.EOL}`+Xu.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${Zs.EOL}`);ys.override=jN(["CONFIRM_DOWNGRADE"]),ys.start(),ys.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Xu.magenta(`${Zs.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 ys.get([r]);return QN.includes(n.CONFIRM_DOWNGRADE)}a(Tfe,"forceDowngradePrompt");async function gfe(){let e=`${Zs.EOL}`+Xu.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");ys.override=jN(["GENERATE_CERTS"]),ys.start(),ys.message=e;let t={properties:{GENERATE_CERTS:{description:Xu.magenta(`${Zs.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 ys.get([t]);return QN.includes(r.GENERATE_CERTS)}a(gfe,"upgradeCertsPrompt");FV.exports={forceUpdatePrompt:Sfe,forceDowngradePrompt:Tfe,upgradeCertsPrompt:gfe}});var JN=b((jPe,kV)=>{"use strict";var zN=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};kV.exports=zN});var qV=b((eLe,GV)=>{"use strict";var Rfe=ee(),Afe=It(),zPe=V(),JPe=require("path"),XPe=require("fs"),ZPe=M();GV.exports={getOldPropsValue:Ofe};function Ofe(e,t,r=!1){let n=t.getRaw(e);return Rfe.isNotEmptyAndHasValue(n)?n:r?Afe.getDefaultConfig(e):""}a(Ofe,"getOldPropsValue")});var KV=b((rLe,YV)=>{"use strict";var Ra=require("path"),Aa=require("fs-extra"),bfe=require("properties-reader"),yfe=JN(),cr=V(),{getOldPropsValue:St}=qV(),{HDB_SETTINGS_NAMES:Ee,CONFIG_PARAMS:zc}=M(),Jc=It(),PS=te(),$V=ee(),Ui=M(),XN=new yfe("3.1.0"),VV=[];function Nfe(){let e=bfe(PS.get(Ee.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),cr.info(t);let r=` ;Settings for the HarperDB process.
40
+ `},compressible:!1,q:.8});br.set("application/x-www-form-urlencoded",{deserialize(e){let t={};for(let[r,n]of new URLSearchParams(e))if(t.hasOwnProperty(r)){let s=t[r];Array.isArray(s)?s.push(n):t.key=[s,n]}else t[r]=n},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});Tq={type:"application/json",serializeStream:Fd,serialize:$f,deserialize:xue,q:.5};br.set("*/*",Tq);br.set("",Tq);a(xue,"tryJSONParse");a(WO,"registerContentHandlers");kue=require("fastify-plugin"),Fue=kue(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=tS(n.raw);s.type(c),s.serializer(function(l){let d;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let u=l.getColumns;l=l.mapError(_=>(_.toJSON=()=>({error:_.name,message:_.message,..._.partialObject}),_)),l.getColumns=u}d=o.serializeStream}else d=o.serialize;return d(l,{headers:{set:(u,_)=>{s.header(u,_)}}})})}),r()},{name:"content-type-negotiation"});a(tS,"findBestSerializer");_q=$O.default.get(VO.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(Yf,"serialize");a(kc,"serializeMessage");a(Gue,"streamToBuffer");a(Vc,"getDeserializer");a(fq,"deserializerUnknownType");a(que,"transformIterable")});function QO(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let _=d(l);for(let f=1;f<e.length;f++){let h=e[f],T=d(h);_=_.concat(T)}let E=new Set;return _.filter(f=>{let h=f.key??f;return E.has(h)?!1:(E.add(h),!0)})}else{let _=d(l),E=u(e.slice(1),!0,l.estimated_count);return E.length>0?o(_,E):_}function d(_){return _.conditions?QO(_.conditions,_.operator,r,n,s,i,o,c):qu(_,n,_.descending||s.reverse===!0,r,s.allowFullScan,c)}a(d,"executeCondition");function u(_,E,f){return _.map((h,T)=>{if(h.conditions){let p=h.operator==="or",y=u(h.conditions,!p,f);return p?(O,B)=>y.some(x=>x(O,B)):(O,B)=>y.every(x=>x(O,B))}let S=(h.attribute||h[0])===r.primaryKey,R=jf(h,r,i,c,S,f);return E&&T<_.length-1&&f&&(f=Jue(r.primaryStore,h.estimated_count,f)),R}).filter(Boolean)}a(u,"mapConditionsToFilters")}function qu(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(Array.isArray(o)){let p=o[0],y=Di(n.attributes,p);if(y.relationship){if(o.length<2)throw new Vn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let O=y.definition?.tableClass||y.elements?.definition?.tableClass,B=new Map,x=qu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,O,s,B);if(y.relationship.to){i[o[0]]=B;let W=!!Di(O.attributes,y.relationship.to)?.elements;x=Wue(x,y,O.primaryStore,W,B)}if(y.relationship.from){let W=a(q=>(q?.key!==void 0&&(q=q.key),qu({attribute:y.relationship.from,value:q},t,r,n,s,B)),"searchEntry");y.elements?(i[o[0]]=B,x=jue(x,y,O.primaryStore,B,W)):x=x.flatMap(W)}return x}else if(o.length===1)o=o[0];else throw new Vn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let d,u,_,E;c instanceof Date&&(c=c.getTime());let f;switch(zO[l]||l){case"lt":d=!0,u=c;break;case"le":d=!0,u=c,_=!0;break;case"gt":d=c,E=!0;break;case"ge":d=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],d=c,u=c.slice(0),u[u.length-1]=Ci.MAXIMUM_KEY;break;case"starts_with":d=c.toString(),u=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":d=c[0],d instanceof Date&&(d=d.getTime()),u=c[1],u instanceof Date&&(u=u.getTime()),_=l==="gele"||l==="gtle"||l==="between",E=l==="gtlt"||l==="gtle";break;case"equals":case void 0:d=c,u=c,_=!0;break;case"ne":if(c===null){d=c,E=!0;break}case"sort":case"contains":case"ends_with":d=!0,f=!0;break;default:throw new Vn.ClientError(`Unknown query comparator "${l}"`)}let h,T=o===n.primaryKey||o==null;if(typeof d=="string"&&d.length>Os.MAX_SEARCH_KEY_LENGTH&&(d=d.slice(0,Os.MAX_SEARCH_KEY_LENGTH)+Os.OVERFLOW_MARKER,E=!1,h=jf(e,n,null,i,T)),typeof u=="string"&&u.length>Os.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Os.MAX_SEARCH_KEY_LENGTH)+Os.OVERFLOW_MARKER,_=!0,h=h??jf(e,n,null,i,T)),r){let p=d;d=u,u=p,p=!E,E=!_,_=p}let S=T?n.primaryStore:n.indices[o];if(!S||S.isIndexing||f||c===null&&!S.indexNulls){if(s===!1&&!S)throw new Vn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&f)throw new Vn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(S?.isIndexing)throw new Vn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&!S.indexNulls)throw new Vn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??jf(e,n,null,i,T),!h)throw new Vn.ClientError(`Unknown search operator ${e.comparator}`)}let R={start:d,end:u,inclusiveEnd:_,exclusiveStart:E,values:!0,versions:T,transaction:t,reverse:r};if(T){let p=S.getRange(R).map(h?function({key:y,value:O}){return this?.isSync?O&&h(O)?y:Ra.SKIP:new Promise((B,x)=>setImmediate(()=>{try{B(O&&h(O)?y:Ra.SKIP)}catch(W){x(W)}}))}:y=>y.value==null&&!(y.metadataFlags&(Pi|ba))?Ra.SKIP:y);return p.hasEntries=!0,p}else return S?S.getRange(R).map(h?function({key:p,value:y}){let O;return typeof p=="string"&&p.length>Os.MAX_SEARCH_KEY_LENGTH?O=n.primaryStore.get(y):O={[o]:p},this.isSync?h(O)?y:Ra.SKIP:new Promise((B,x)=>setImmediate(()=>{try{B(h(O)?y:Ra.SKIP)}catch(W){x(W)}}))}:({value:p})=>p):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:p,value:y}){return this.isSync?y&&h(y)?p:Ra.SKIP:new Promise((O,B)=>setImmediate(()=>{try{O(y&&h(y)?p:Ra.SKIP)}catch(x){B(x)}}))})}function Di(e,t){if(Array.isArray(t))if(t.length>1){let r=Di(e,t[0]),n=(r?.definition?.tableClass||r?.elements.definition?.tableClass)?.attributes;return n?Di(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function Wue(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=a((d,u)=>{let _=s.get(d);_?_.push(u):s.set(d,_=[u])},"add_entry");for(let d of e){let u=d.value??r.get(d.key??d),_=u?.[c];if(_!=null&&!s.filters?.some(E=>!E(u)))if(n)for(let E=0;E<_.length;E++)l(_[E],d);else l(_,d)}return i=s.keys()[Symbol.iterator](),this.next()}let o=i.next();return o.done?o:{value:o.value}},return(){if(i?.return)return i.return()}}}})}function jue(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let d=l.value;if(!c.has(d))return c.add(d),l}if(!i){let d=new Set;n.fromRecord=u=>u[t.relationship.from]?.filter?.(_=>d.has(_));for(let u of e){if(n.filters){let _=r.get(u);if(n.filters.some(E=>!E(_)))continue}d.add(u)}return i=d[Symbol.iterator](),this.next()}do{let d=i.next();return d.done?d:(o=s(d.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function jf(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let u=c[0],_=Di(t.attributes,u),E=_.definition?.tableClass||_.elements.definition?.tableClass,f=n?.[u],h=jf({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},E,r,f?.[u]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(f){f.filters||(f.filters=[]),f.filters.push(h);return}let T=t.propertyResolvers?.[u],S,R=a((p,y)=>{let O,B;if(T){if(T.from&&h.idFilter){if(!S)if(h.idFilter.idSet?.size===1){for(let W of h.idFilter.idSet)e={attribute:T.from,value:W};S=d(T.from,h.idFilter,!0,!0)}else S=d(T.from,h.idFilter,!1,!0);let x=S(p);return S.idFilter&&(R.idFilter=S.idFilter),x}B=T(p,r,y),O=B?.value}else O=p[u];return O?Array.isArray(O)?O.some(h):h(O,B):!1},"recordFilter");return R}}switch(l instanceof Date&&(l=l.getTime()),zO[o]||o){case Os.SEARCH_TYPES.EQUALS:case void 0:return d(c,u=>u===l,!0);case"contains":return d(c,u=>u?.toString().includes(l));case"ends_with":return d(c,u=>u?.toString().endsWith(l));case"starts_with":return d(c,u=>typeof u=="string"&&u.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],d(c,u=>{if(!Array.isArray(u))return!1;for(let _=0,E=l.length;_<E;_++)if(u[_]!==l[_])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),d(c,u=>(0,Ci.compareKeys)(u,l[0])>=0&&(0,Ci.compareKeys)(u,l[1])<=0,!0);case"gt":return d(c,u=>(0,Ci.compareKeys)(u,l)>0);case"ge":return d(c,u=>(0,Ci.compareKeys)(u,l)>=0);case"lt":return d(c,u=>(0,Ci.compareKeys)(u,l)<0);case"le":return d(c,u=>(0,Ci.compareKeys)(u,l)<=0);case"ne":return d(c,u=>(0,Ci.compareKeys)(u,l)!==0);case"sort":return()=>!0;default:throw new Vn.ClientError(`Unknown query comparator "${o}"`)}function d(u,_,E,f){let h;E=E&&!s&&t?.indices[u]&&i>3,E&&(e.estimated_count==null&&nS(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let T=0,S=3;function R(p){let y=p[u],O;if(typeof y!="object"||!y||f?O=_(y):Array.isArray(y)?O=y.some(_):y instanceof Date&&(O=_(y.getTime())),E&&(S++,!O&&!R.idFilter&&++T/S*(i-S)>h)){let B=qu(e,r.transaction.getReadTxn(),!1,t).map($u),x=new Set(B);R.idFilter=W=>x.has($u(W)),R.idFilter.idSet=x}return O}return a(R,"recordFilter"),s&&(R.idFilter=_),R}a(d,"attributeComparator")}function nS(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/So(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=zO[n]||n,n===Os.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=Di(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=nS(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*So(e.indices[i.relationship.from])/(So(o.primaryStore)||1):c)}else{let i=e.indices[s];r.estimated_count=i?i.getValuesCount(r[1]??r.value):1/0}}else if(n==="contains"||n==="ends_with"||n==="ne"){let s=r[0]??r.attribute,i=e.indices[s];r.value===null&&n==="ne"?r.estimated_count=So(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=Yue*So(e.primaryStore)+1:n==="between"?r.estimated_count=Vue*So(e.primaryStore)+1:n==="sort"?r.estimated_count=So(e.primaryStore)+1:r.estimated_count=$ue*So(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function sS(e){if(e)if(Aa=e,Fu.lastIndex=0,Que.test(e))try{let t=Kf(new Gu,"");if(An!==Aa.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${An} in '${Aa}'`,t}else return new URLSearchParams(e)}function Kf(e,t){let r=Fu,n,s,i,o,c,l=decodeURIComponent,d;for(;n=r.exec(Aa);){An=r.lastIndex;let[,u,_]=n;if(o){if(u)throw new SyntaxError(`expected operator, but encountered '${u}'`);o=!1,c=!1}else c=!0;let E;switch(_){case"=":if(s!=null){if(u.length<=2)i=u;else throw new SyntaxError(`invalid FIQL operator ${u}`);l=Rq}else{if(l=decodeURIComponent,i="equals",!u)throw new SyntaxError("attribute must be specified before equality comparator");s=Wf(u)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=Kue[_],l=jO[i]?Rq:decodeURIComponent,!u)throw new SyntaxError(`attribute must be specified before comparator ${_}`);s=Wf(u);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${_[0]?"'"+_[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${_?"'"+_+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s||null,value:l(u)};if(i==="eq"&&Aq(h,u),s===""){let T=e.conditions[e.conditions.length-1];T.chainedConditions=T.chainedConditions||[],T.chainedConditions.push(h),T.operator=d}else rS(e,d),e.conditions.push(h)}_==="&"?(d="and",s=void 0):_==="|"?(d="or",s=void 0):_==="&="?(d="and",s=""):_==="|="&&(d="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(Wf(u)),s=void 0;break;case"(":Fu.lastIndex=An;let f=Kf(u?[]:new Gu,")");switch(u){case"":rS(e,d),e.conditions.push(f);break;case"limit":switch(f.length){case 1:e.limit=+f[0];break;case 2:e.offset=+f[0],e.limit=f[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(f[0])&&f.length===1&&!f[0].name?(e.select=f[0],e.select.asArray=!0):f.length===1?e.select=f[0]:f.length===2&&f[1]===""?e.select=f.slice(0,1):e.select=f;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=bq(f);break;default:throw new SyntaxError(`unknown query function call ${u}`)}Aa[An]===","?r.lastIndex=++An:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!u)throw new SyntaxError("property sets must have a defined parent property name");Fu.lastIndex=An,E=Kf([],"}"),E.name=u,e.push(E),Aa[An]===","?r.lastIndex=++An:o=!0;break;case"[":Fu.lastIndex=An,u?(E=Kf(new Gu,"]"),E.name=u):E=Kf(e.conditions?new Gu:[],"]"),e.conditions?(rS(e,d),e.conditions.push(E),s=null):e.push(E),Aa[An]===","?r.lastIndex=++An:o=!0;break;case")":case"]":case"}":if(t===_[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(u)};i==="eq"&&Aq(h,u),rS(e,d),e.conditions.push(h)}else if(u)throw new SyntaxError("no attribute or comparison specified")}else(u||e.length>0&&c)&&e.push(Wf(u));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${_[0]}'`):new SyntaxError(`unexpected token '${_[0]}'`);default:throw new SyntaxError(`unexpected operator '${_}'`)}if(t!==")"&&(r=s?zue:Fu,r.lastIndex=An),An===Aa.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function rS(e,t){if(e.conditions.length>0)if(e.operator){if(e.operator!==t)throw new SyntaxError("Can not mix operators within a condition grouping")}else e.operator=t}function Wf(e){return e.indexOf(".")>-1?e.split(".").map(Wf):decodeURIComponent(e)}function Rq(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new Vn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function Aq(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Vn.ClientError("wildcard can only be used at the end of a string")}function bq(e){let t=yq(e[0]);return e.length>1&&(t.next=bq(e.slice(1))),t}function yq(e){if(Array.isArray(e)){let t=yq(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}throw new SyntaxError(`Unknown sort type ${e}`)}function $u(e){return Array.isArray(e)?e.join("\0"):e}function So(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function Jue(e,t,r){return t*r/So(e)}var Vn,Os,Ci,Ra,$ue,Vue,Yue,Kue,jO,zO,Que,Fu,zue,An,Aa,Gu,Yc,Qf=De(()=>{Vn=v(fe()),Os=v(Bt()),Ci=require("ordered-binary"),Ra=require("lmdb");zf();$ue=.3,Vue=.1,Yue=.05,Kue={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},jO={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(QO,"executeConditions");a(qu,"searchByIndex");a(Di,"findAttribute");a(Wue,"joinTo");a(jue,"joinFrom");zO={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};a(jf,"filterByType");a(nS,"estimateCondition");Que=/[()[\]|!<>.]|(=\w*=)/,Fu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,zue=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(sS,"parseQuery");a(Kf,"parseBlock");a(rS,"assignOperator");a(Wf,"decodeProperty");a(Rq,"typedDecoding");a(Aq,"wildcardDecoding");a(bq,"toSortObject");a(yq,"toSortEntry");Gu=class{static{a(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}};a($u,"flattenKey");a(So,"estimatedEntryCount");a(Jue,"intersectionEstimate");Yc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});function Cq(e){let t={openapi:Xue,info:{title:"HarperDB HTTP REST interface",version:(0,wq.version)()},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let d={},u=[];if(o)for(let{type:y,name:O,elements:B,relationship:x,definition:W}of o){if(x)y==="array"?d[O]={type:"array",items:{$ref:ya+B.type}}:d[O]={$ref:ya+y};else{let q=W??B?.definition;if(q){if(!t.components.schemas[q.type]){let z={};q.properties.forEach(_e=>{z[_e.name]=new eN(JO[_e.type],_e.type)}),t.components.schemas[q.type]=new Iq(z)}y==="array"?d[O]={type:"array",items:{$ref:ya+q.type}}:d[O]={$ref:ya+q.type}}else y==="array"?B.type==="Any"||B.type=="ID"?d[O]={type:"array",items:{format:B.type}}:d[O]={type:"array",items:new eN(JO[B.type],B.type)}:y==="Any"||y=="ID"?d[O]={format:y}:d[O]=new eN(JO[y],y)}u.push(new tN(O,"query",d[O]))}let _=Object.keys(d),E=new tN(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new tN("property","path",{enum:_});f.required=!0,t.components.schemas[i]=new Iq(d);let h=l.post!==Resource.prototype.post||l.update,T=typeof l.put=="function",S=typeof l.get=="function",R=typeof l.delete=="function",p="/"+s+"/";h&&(t.paths[p]={},t.paths[p].post=new Zue(i,r,"create a new record auto-assigning a primary key")),S&&(t.paths[p]||(t.paths[p]={}),t.paths[p].get=new XO(u,r,{200:new ZO({$ref:ya+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[p]||(t.paths[p]={}),t.paths[p].delete=new Nq(u,r,"delete all the records that match the provided query",{204:new Oq})),p="/"+s+"/{"+c+"}",S&&(t.paths[p]={},t.paths[p].get=new XO([E],r,{200:new ZO({$ref:ya+i})},"retrieve a record by its primary key")),T&&(t.paths[p]||(t.paths[p]={}),t.paths[p].put=new ede([E],r,i,"create or update the record with the URL path that maps to the record's primary key")),R&&(t.paths[p]||(t.paths[p]={}),t.paths[p].delete=new Nq([E],r,"delete a record with the given primary key",{204:new Oq})),S&&f.schema.enum.length>0&&(p="/"+s+"/{"+c+"}.{property}",t.paths[p]={},t.paths[p].get=new XO([E,f],r,{200:new ZO({enum:_})},"used to retrieve the specified property of the specified record"))}return t}function Zue(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:ya+e}}}},this.security=t,this.responses={200:{description:rN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function XO(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function ZO(e){this.description=rN,this.content={"application/json":{schema:e}}}function Oq(){this.description="successfully processed request, no content returned to client"}function ede(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:ya+r}}}},this.responses={200:{description:rN}}}function Nq(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function Iq(e){this.type="object",this.properties=e}function eN(e,t){this.type=e,this.format=t}function tN(e,t,r){this.name=e,this.in=t,this.schema=r}var wq,Xue,JO,ya,rN,Dq=De(()=>{wq=v(Ic()),Xue="3.0.3",JO={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},ya="#/components/schemas/",rN="successful operation";a(Cq,"generateJsonApi");a(Zue,"Post");a(XO,"Get");a(ZO,"Response200");a(Oq,"Response204");a(ede,"Put");a(Nq,"Delete");a(Iq,"ResourceSchema");a(eN,"Type");a(tN,"Parameter")});var oS={};et(oS,{start:()=>nde});async function rde(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&sS(e);let i=new _o;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==Pq){let S=iS.getMatch(o,n?"sse":"rest");if(!S)return t(e);e.handlerPath=S.path,c=new Yc(S.relativeURL),c.async=!0,l=S.Resource}let d=r["cache-control"];if(d){let S=Uq(d);for(let R of S)switch(R.name){case"max-age":e.expiresAt=R.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}let u=r["x-replicate-to"];if(u){let S=Uq(u).map(R=>(R.next?.name==="confirm"&&R.next.value>=0&&(e.replicatedConfirmation=+R.next.value),R.name));e.replicateTo=S.length===1&&+S[0]>=0?+S[0]:S[0]==="*"?void 0:S}let _=await Ct(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=Vc(r["content-type"],!0)(e.body,e.headers)}catch(S){throw new Vu.ClientError(S,400)}if(e.authorize=!0,o===Pq&&s==="GET"){if(e?.user?.role?.permission?.super_user)return Cq(iS);throw new Vu.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new Vu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Vu.ServerError(`Method ${s} is not recognized`,501)}}),E=200,f;if(_==null)E=s==="GET"||s==="HEAD"?404:204,nN.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else{if(_.status>0&&_.headers)return _.headers=pO(_.headers,i),_.data!==void 0&&(_.body=Yf(_.data,e,_)),_;if(f=e.lastModified){tde[0]=f;let S=String.fromCharCode(34,(Ur[0]&63)+62,(Ur[0]>>6)+(Ur[1]<<2&63)+62,(Ur[1]>>4)+(Ur[2]<<4&63)+62,(Ur[2]>>2)+62,(Ur[3]&63)+62,(Ur[3]>>6)+(Ur[4]<<2&63)+62,(Ur[4]>>4)+(Ur[5]<<4&63)+62,(Ur[5]>>2)+62,(Ur[6]&63)+62,(Ur[6]>>6)+(Ur[7]<<2&63)+62,34),R=r["if-none-match"];R&&S==R?(_?.onDone&&_.onDone(),E=304,_=void 0):i.setIfNone("ETag",S),nN.lastModified&&i.setIfNone("Last-Modified",new Date(f).toUTCString())}}e.createdResource&&(E=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:E,headers:i,body:void 0},T=_?.wasLoadedFromSource?.();return T!==void 0&&(h.wasCacheMiss=T,!T&&f&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||f))/1e3))),_!==void 0&&(h.body=Yf(_,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Kc.warn(o):Kc.info(o):Kc.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Yf(o.contentType?o:o.toString(),e,c),c}}function nde(e){nN=e,!Lq&&(Lq=!0,iS=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return rde(t,r)},e),e.server.ws(async(t,r,n)=>{Jf++;let s=new In;Mq||(Mq=!0,N_(l=>{Jf>0&&l.push({metric:"ws-connections",connections:Jf,byThread:!0})}));let i;t.on("error",l=>{i=!0,Kc.warn(l)});let o;t.on("message",a(function(d){o||(o=Vc(r.requestedContentType??r.headers.asObject["content-type"],!1));let u=o(d);s.push(u)},"message"));let c;t.on("close",()=>{Jf--,kn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),d=iS.getMatch(l,"ws");if(kn(!!d,"connection","ws","connect"),d){r.handlerPath=d.path,gr(h=>({count:h.count,total:Jf}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let u=new Yc(d.relativeURL),_=d.Resource;c=(await Ct(r,()=>_.connect(u,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=kc(f.value,r);t.send(h),gr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){t.close(sde[l.statusCode]||1011,l.toString())}t.close()},e))}function Uq(e){return e.split(/\s*,\s*/).map(r=>{let n,s=r.split(/\s*;\s*/),i;for(;i=s.pop();)if(i.includes("=")){let[o,c]=i.split(/\s*=\s*/);n={name:o.toLowerCase(),value:c,next:n}}else n={name:i.toLowerCase(),next:n};return n})}var Kc,Vu,Ur,tde,nN,Pq,Lq,iS,Mq,Jf,sde,vq=De(()=>{Uu();gi();Kc=v(V()),Vu=v(fe());Qf();Al();uc();Nf();Dq();Qf();Ur=new Uint8Array(8),tde=new Float64Array(Ur.buffer,0,1),nN={},Pq="openapi";a(rde,"http");Jf=0;a(nde,"start");sde={401:3e3,403:3003};a(Uq,"parseHeaderValue")});var sN=b((KDe,Hq)=>{var{recordAction:aS,recordActionBinary:Bq}=(gi(),oe(I_)),ide=require("fastify-plugin"),ode=200;Hq.exports=ide(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,d,u,_;l.config?.isOperation?(d=n.body?.operation,u="operation"):(d=l.url,u="fastify-route",_=l.method),aS(o,"duration",d,_,u),Bq(s.raw.statusCode<400,"success",d,_,u),Bq(1,"response_"+s.raw.statusCode,d,_,u);let E=ode;i?.pipe?(i.on("data",S=>{E+=S.length}),i.on("end",()=>{aS(performance.now()-c,"transfer",d,_,u),aS(E,"bytes-sent",d,_,u)})):(E+=i?.length||0,aS(E,"bytes-sent",d,_,u));let f=o.toFixed(3),h=s.getHeader("Server-Timing"),T=`db;dur=${f}`;s.header("Server-Timing",h?`${h}, ${T}`:T)}),r()},{name:"hdb-request-time"})});var uN=b((QDe,Gq)=>{var dS=require("clone"),_S=ut(),ade=J(),lS=M(),WDe=V(),iN=require("fs"),aN=require("joi"),{string:uS}=aN.types(),{hdb_errors:cde,handleHDBError:cS}=fe(),{HDB_ERROR_MSGS:jDe,HTTP_STATUS_CODES:oN}=cde,{common_validators:Yu}=di(),xq=" is required",lde=["insert","update","upsert"],cN={database:{presence:!1,format:Yu.schema_format,length:Yu.schema_length},schema:{presence:!1,format:Yu.schema_format,length:Yu.schema_length},table:{presence:!0,format:Yu.schema_format,length:Yu.schema_length},action:{inclusion:{within:lde,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},ude={schema:uS.required(),table:uS.required(),action:uS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:dde,AWS_SECRET:_de,AWS_BUCKET:fde,AWS_FILE_KEY:Ede,REGION:hde}=lS.S3_BUCKET_AUTH_KEYS,mde={s3:{presence:!0},[`s3.${dde}`]:{presence:!0,type:"String"},[`s3.${_de}`]:{presence:!0,type:"String"},[`s3.${fde}`]:{presence:!0,type:"String"},[`s3.${Ede}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${hde}`]:{presence:!0,type:"String"}},kq=dS(cN);kq.data.presence={message:xq};var Fq=dS(cN);Fq.file_path.presence={message:xq};var pde=Object.assign(dS(cN),mde),lN=dS(ude);lN.csv_url=uS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();lN.passthrough_headers=aN.object();function Sde(e){let t=_S.validateObject(e,kq);return fS(e,t)}a(Sde,"dataObject");function Tde(e){let t=_S.validateBySchema(e,aN.object(lN));return fS(e,t)}a(Tde,"urlObject");function gde(e){let t=_S.validateObject(e,Fq);return fS(e,t)}a(gde,"fileObject");function Rde(e){let t=_S.validateObject(e,pde);return fS(e,t)}a(Rde,"s3FileObject");function fS(e,t){if(!t){let r=ade.checkGlobalSchemaTable(e.schema,e.table);if(r)return cS(new Error,r,oN.BAD_REQUEST);if(e.operation===lS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{iN.accessSync(e.file_path,iN.constants.R_OK|iN.constants.F_OK)}catch(n){return n.code===lS.NODE_ERROR_CODES.ENOENT?cS(n,`No such file or directory ${n.path}`,oN.BAD_REQUEST):n.code===lS.NODE_ERROR_CODES.EACCES?cS(n,`Permission denied ${n.path}`,oN.BAD_REQUEST):cS(n)}}return t}a(fS,"postValidateChecks");Gq.exports={dataObject:Sde,urlObject:Tde,fileObject:gde,s3FileObject:Rde}});var dN=b((JDe,qq)=>{"use strict";var Xf=V(),ES=M();async function Ade(e,t,r,n=void 0){if(!e||typeof e!="function")throw new Error("Invalid function parameter");let s;try{return s=await e(t),r&&await r(t,s,n),t.operation===ES.OPERATIONS_ENUM.INSERT||t.operation===ES.OPERATIONS_ENUM.UPDATE||t.operation===ES.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===ES.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(Xf.info(i.message),i):i.http_resp_msg?(Xf.error(`Error calling operation: ${e.name}`),Xf.error(i.http_resp_msg),i):(Xf.error(`Error calling operation: ${e.name}`),Xf.error(i),i)}}a(Ade,"callOperationFunctionAsAwait");qq.exports={callOperationFunctionAsAwait:Ade}});var Vq=b((ZDe,$q)=>{"use strict";var _N=class{static{a(this,"BulkLoadFileObject")}constructor(t,r,n,s,i,o,c=null){this.op=t,this.action=r,this.schema=n,this.table=s,this.file_path=i,this.file_type=o,this.role_perms=c}},fN=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};$q.exports={BulkLoadFileObject:_N,BulkLoadDataObject:fN}});var Kq=b((tPe,Yq)=>{"use strict";var EN=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};Yq.exports=EN});var gN=b((aPe,l$)=>{"use strict";var hS=Yr(),pS=uN(),bde=require("needle"),Js=M(),nPe=dt(),Ku=J(),{handleHDBError:$t,hdb_errors:t$}=fe(),{HTTP_STATUS_CODES:vr,HDB_ERROR_MSGS:pr,CHECK_LOGS_WRAPPER:jc}=t$,Wu=V(),hN=require("papaparse");Ku.promisifyPapaParse();var Xs=require("fs-extra"),yde=require("path"),{chain:Wq}=require("stream-chain"),jq=require("stream-json/streamers/StreamArray"),Qq=require("stream-json/utils/Batch"),zq=require("stream-chain/utils/comp"),{finished:Jq}=require("stream"),Ode=te(),r$=dN(),Nde=FO(),{BulkLoadFileObject:pN,BulkLoadDataObject:Ide}=Vq(),SN=DO(),{verifyBulkLoadAttributePerms:n$}=Qp(),sPe=Kq(),iPe=kt(),oPe=zi(),{databases:wde}=(Le(),oe(lt)),{coerceType:Cde}=(zf(),oe(RN)),Xq="No records parsed from csv file.",Wc=`${Ode.get("HDB_ROOT")}/tmp`,{schema_regex:Dde}=di(),Zq=1024*1024*2,e$=5e3,Pde={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};l$.exports={csvDataLoad:Lde,csvURLLoad:Mde,csvFileLoad:Ude,importFromS3:vde};async function Lde(e,t){let r=pS.dataObject(e);if(r)throw $t(r,r.message,vr.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=o$(e.schema,e.table),i=hN.parse(e.data,{header:!0,skipEmptyLines:!0,transform:mN.bind(null,s),dynamicTyping:!1}),o=new SN;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&n$(e.hdb_user?.role?.permission,this.job_operation_function.name,e.action,e.schema,e.table,i.meta.fields,o);let c=o.getPermsResponse();if(c)throw $t(new Error,c,vr.BAD_REQUEST,void 0,void 0,!0);let l=new Ide(e.action,e.schema,e.table,i.data);return n=await r$.callOperationFunctionAsAwait(a$,l,null),n.message===Xq?Xq:c$(n.records,n.number_written)}catch(s){throw Qc(s)}}a(Lde,"csvDataLoad");async function Mde(e){let t=pS.urlObject(e);if(t)throw $t(t,t.message,vr.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Wc}/${r}`;try{await Bde(e,r)}catch(s){throw Wu.error(pr.DOWNLOAD_FILE_ERR(r)+" - "+s),$t(s,jc(pr.DOWNLOAD_FILE_ERR(r)))}try{let s=new pN(this.job_operation_function.name,e.action,e.schema,e.table,n,Js.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await TN(s);return await mS(n),i}catch(s){throw await mS(n),Qc(s)}}a(Mde,"csvURLLoad");async function Ude(e){let t=pS.fileObject(e);if(t)throw $t(t,t.message,vr.BAD_REQUEST,void 0,void 0,!0);let r=new pN(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,Js.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await TN(r)}catch(n){throw Qc(n)}}a(Ude,"csvFileLoad");async function vde(e){let t=pS.s3FileObject(e);if(t)throw $t(t,t.message,vr.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=yde.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Wc}/${s}`;let i=new pN(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Hde(s,e);let o=await TN(i);return await mS(r),o}catch(n){throw await mS(r),Qc(n)}}a(vde,"importFromS3");async function Bde(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await bde("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw $t(n,s,n.statusCode,Js.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}kde(r,e.csv_url),await xde(t,r.raw)}a(Bde,"downloadCSVFile");async function Hde(e,t){try{let r=`${Wc}/${e}`;await Xs.mkdirp(Wc),await Xs.writeFile(`${Wc}/${e}`,"",{flag:"a+"});let n=await Xs.createWriteStream(r),s=await Nde.getFileStreamFromS3(t);await new Promise((i,o)=>{s.on("error",function(c){o(c)}),s.pipe(n).on("error",function(c){o(c)}).on("close",function(){Wu.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Wu.error(pr.S3_DOWNLOAD_ERR+" - "+r),$t(r,jc(pr.S3_DOWNLOAD_ERR))}}a(Hde,"downloadFileFromS3");async function xde(e,t){try{await Xs.mkdirp(Wc),await Xs.writeFile(`${Wc}/${e}`,t)}catch(r){throw Wu.error(pr.WRITE_TEMP_FILE_ERR),$t(r,jc(pr.DEFAULT_BULK_LOAD_ERR))}}a(xde,"writeFileToTempFolder");async function mS(e){if(e)try{await Xs.access(e),await Xs.unlink(e)}catch{Wu.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(mS,"deleteTempFile");function kde(e,t){if(e.statusCode!==t$.HTTP_STATUS_CODES.OK)throw $t(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,vr.BAD_REQUEST);if(!Pde[e.headers["content-type"]])throw $t(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,vr.BAD_REQUEST);if(!e.raw)throw $t(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,vr.BAD_REQUEST)}a(kde,"validateURLResponse");async function TN(e){try{let t;switch(e.file_type){case Js.VALID_S3_FILE_TYPES.CSV:t=await Fde(e);break;case Js.VALID_S3_FILE_TYPES.JSON:t=await Gde(e);break;default:throw $t(new Error,pr.DEFAULT_BULK_LOAD_ERR,vr.BAD_REQUEST,Js.LOG_LEVELS.ERROR,pr.INVALID_FILE_EXT_ERR(e))}return c$(t.records,t.number_written)}catch(t){throw Qc(t)}}a(TN,"fileLoad");async function s$(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;s&&s.pause();let o={operation:e.action,schema:e.schema,table:e.table,records:i};try{let{attributes:c}=await hS.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&n$(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=$t(c);r(l)}}a(s$,"validateChunk");async function i$(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Ku.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Ku.isEmpty(c)&&!Ku.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(d=>c.add(d))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await r$.callOperationFunctionAsAwait(a$,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=$t(c,jc(pr.INSERT_CSV_ERR),vr.INTERNAL_SERVER_ERROR,Js.LOG_LEVELS.ERROR,pr.INSERT_CSV_ERR+" - "+c);r(l)}}a(i$,"insertChunk");async function Fde(e){let t={records:0,number_written:0},r=o$(e.schema,e.table);try{let n=new SN,s=Xs.createReadStream(e.file_path,{highWaterMark:Zq});s.setEncoding("utf8"),await hN.parsePromise(s,s$.bind(null,e,n),mN.bind(null,r));let i=n.getPermsResponse();if(i)throw $t(new Error,i,vr.BAD_REQUEST);return s=Xs.createReadStream(e.file_path,{highWaterMark:Zq}),s.setEncoding("utf8"),await hN.parsePromise(s,i$.bind(null,e,t),mN.bind(null,r)),s.destroy(),t}catch(n){throw $t(n,jc(pr.PAPA_PARSE_ERR),vr.INTERNAL_SERVER_ERROR,Js.LOG_LEVELS.ERROR,pr.PAPA_PARSE_ERR+n)}}a(Fde,"callPapaParse");function o$(e,t){let r=wde[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>Cde(i,s));return n}a(o$,"createTransformMap");function mN(e,t,r){let n=e.get(r);return n?n(t):Ku.autoCast(t)}a(mN,"typeFunction");async function Gde(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new SN,s=Wq([Xs.createReadStream(e.file_path,{encoding:"utf-8"}),jq.withParser(),c=>c.value,new Qq({batchSize:e$}),zq(async c=>{await s$(e,n,r,c)})]);await new Promise((c,l)=>{Jq(s,d=>{d?l(d):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw $t(new Error,i,vr.BAD_REQUEST);let o=Wq([Xs.createReadStream(e.file_path,{encoding:"utf-8"}),jq.withParser(),c=>c.value,new Qq({batchSize:e$}),zq(async c=>{await i$(e,t,r,c)})]);return await new Promise((c,l)=>{Jq(o,d=>{d?l(d):c()}),o.resume()}),t}catch(n){throw $t(n,jc(pr.INSERT_JSON_ERR),vr.INTERNAL_SERVER_ERROR,Js.LOG_LEVELS.ERROR,pr.INSERT_JSON_ERR+n)}}a(Gde,"insertJson");async function a$(e){let t={};try{e.data&&e.data.length>0&&qde(e.data[0])?t=await $de(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Wu.info(t.message))}catch(r){throw Qc(r)}return t}a(a$,"callBulkFileLoad");function qde(e){let t=Object.keys(e);for(let r of t)if(!Dde.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(qde,"validateColumnNames");async function $de(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=hS.insert;break;case"update":i=hS.update;break;case"upsert":i=hS.upsert;break;default:throw $t(new Error,pr.INVALID_ACTION_PARAM_ERR(n),vr.BAD_REQUEST,Js.LOG_LEVELS.ERROR,pr.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let u=global.hdb_schema[t][r].hash_attribute,_=e.length;for(;_--;)o.skipped_hashes.indexOf(e[_][u])>=0&&e.splice(_,1)}let l=Ku.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw Qc(o)}}a($de,"bulkFileLoad");function c$(e,t){return`successfully loaded ${t} of ${e} records`}a(c$,"buildResponseMsg");function Qc(e){return $t(e,jc(pr.DEFAULT_BULK_LOAD_ERR),vr.INTERNAL_SERVER_ERROR,Js.LOG_LEVELS.ERROR,pr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(Qc,"buildTopLevelErrMsg")});var d$=b((lPe,u$)=>{"use strict";var AN=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};u$.exports=AN});var E$=b((dPe,f$)=>{"use strict";var Vde=M(),_$=require("moment"),Yde=require("uuid").v4,bN=class{static{a(this,"JobObject")}constructor(){this.id=Yde(),this.type=void 0,this.start_datetime=_$().valueOf(),this.created_datetime=_$().valueOf(),this.end_datetime=void 0,this.status=Vde.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};f$.exports=bN});var yN=b((fPe,A$)=>{"use strict";var Kde=require("uuid").v4,T$=Yr(),g$=Vr(),Wde=qs(),jde=Fl(),Qde=d$(),Ot=M(),zde=E$(),Jde=J_(),Ns=V(),Xde=Hd(),ju=J(),{promisify:Zde}=require("util"),zc=require("moment"),e_e=Jp(),SS=uN(),h$=SR(),{deleteTransactionLogsBeforeValidator:t_e}=OO(),{handleHDBError:m$,hdb_errors:r_e}=fe(),{HTTP_STATUS_CODES:p$}=r_e,S$=g$.searchByValue,n_e=g$.searchByHash,s_e=T$.insert,i_e=Zde(e_e.evaluateSQL),o_e=T$.update;A$.exports={addJob:l_e,updateJob:d_e,handleGetJob:a_e,handleGetJobsByStartDate:c_e,getJobById:R$};async function a_e(e){try{let t=await R$(e.id);return ju.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}catch(t){let r=`There was an error getting job: ${t}`;throw Ns.error("There was an error getting job",t),new Error(r)}}a(a_e,"handleGetJob");async function c_e(e){try{let t=await u_e(e);if(Ns.trace(`Searching for jobs from ${e.from_date} to ${e.to_date}`),t&&t.length>0)for(let r of t)r.start_datetime&&(r.start_datetime_converted=zc(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=zc(r.end_datetime)),r.request!==void 0&&delete r.request,delete r.__createdtime__,delete r.__updatedtime__;return t}catch(t){let r=`There was an error searching jobs by date: ${t}`;throw Ns.error(r),new Error(r)}}a(c_e,"handleGetJobsByStartDate");async function l_e(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||ju.isEmptyOrZeroLength(e.operation)){let u="job parameter is invalid";return Ns.info(u),t.error=u,t}if(!Ot.JOB_TYPE_ENUM[e.operation])return Ns.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case Ot.OPERATIONS_ENUM.CSV_FILE_LOAD:n=SS.fileObject(e);break;case Ot.OPERATIONS_ENUM.CSV_URL_LOAD:n=SS.urlObject(e);break;case Ot.OPERATIONS_ENUM.CSV_DATA_LOAD:n=SS.dataObject(e);break;case Ot.OPERATIONS_ENUM.IMPORT_FROM_S3:n=SS.s3FileObject(e);break;case Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=h$(e,"date");break;case Ot.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=h$(e,"timestamp");break;case Ot.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=t_e(e);break;case Ot.OPERATIONS_ENUM.RESTART_SERVICE:if(Ot.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw m$(new Error,"Invalid service",p$.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw m$(n,n.message,p$.BAD_REQUEST,void 0,void 0,!0);let s=new zde;s.type=e.operation===Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new Wde(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await S$(i))}catch(u){let _=`There was an error inserting a new job: ${u}`;return Ns.error(_),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Kde();try{o=await S$(i)}catch(u){let _=`There was an error inserting a new job: ${u}`;return Ns.error(_),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return Ns.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Xde(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),d;try{d=await s_e(l)}catch(u){return Ns.error(`There was an error inserting a job for job type: ${e.operation} -- ${u}`),t.success=!1,t}if(d.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let u=`Created a job with type ${s.type} and id ${s.id}`;t.message=u,t.createdJob=s,t.success=!0,Ns.trace(u)}return t}a(l_e,"addJob");async function u_e(e){let t=zc(e.from_date,zc.ISO_8601),r=zc(e.to_date,zc.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new Qde(n,e.hdb_user);try{return await i_e(s)}catch(i){throw Ns.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(u_e,"getJobsInDateRange");async function R$(e){if(ju.isEmptyOrZeroLength(e))return ju.errorizeMessage("Invalid job ID specified.");let t=new jde(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await n_e(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return Ns.error(n),ju.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(R$,"getJobById");async function d_e(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(ju.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===Ot.JOB_STATUS_ENUM.COMPLETE||e.status===Ot.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=zc().valueOf());let t=new Jde(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await o_e(t),r}a(d_e,"updateJob")});var D$=b((hPe,C$)=>{"use strict";var b$=J(),Sr=M(),__e=require("moment"),TS=gN(),Zf=V(),y$=yN(),O$=Xp(),N$=Wo(),I$=it(),f_e=Yp(),E_e=Lu(),{parentPort:h_e,isMainThread:w$}=require("worker_threads"),{onMessageByType:m_e}=it(),ON=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function p_e(e){if(!e||Object.keys(e).length===0)throw new Error("Empty runner passed to parseMessage");if(!e.json||Object.keys(e.json).length===0)throw new Error("Empty JSON passed to parseMessage");if(!e.job||Object.keys(e.job).length===0)throw new Error("Empty job passed to parseMessage");if(b$.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(b$.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Sr.JOB_TYPE_ENUM.csv_file_load:await Li(e,TS.csvFileLoad);break;case Sr.JOB_TYPE_ENUM.csv_url_load:await Li(e,TS.csvURLLoad);break;case Sr.JOB_TYPE_ENUM.csv_data_load:await Li(e,TS.csvDataLoad);break;case Sr.JOB_TYPE_ENUM.import_from_s3:await Li(e,TS.importFromS3);break;case Sr.JOB_TYPE_ENUM.empty_trash:break;case Sr.JOB_TYPE_ENUM.export_local:await Li(e,O$.export_local);break;case Sr.JOB_TYPE_ENUM.export_to_s3:await Li(e,O$.export_to_s3);break;case Sr.JOB_TYPE_ENUM.delete_files_before:case Sr.JOB_TYPE_ENUM.delete_records_before:await Li(e,N$.deleteFilesBefore);break;case Sr.JOB_TYPE_ENUM.delete_audit_logs_before:await Li(e,N$.deleteAuditLogsBefore);break;case Sr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Li(e,f_e.deleteTransactionLogsBefore);break;case Sr.JOB_TYPE_ENUM.restart_service:return await Li(e,E_e.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(p_e,"parseMessage");async function Li(e,t){try{e.job.status=Sr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=__e().valueOf(),await y$.updateJob(e.job),await S_e(e.job.id)}catch(r){let n=r.message!==void 0?r.message:r;typeof n=="string"?(n=`There was an error running ${t.name} job with id ${e.job.id} - ${n}`,r.message=n):Zf.error(`There was an error running ${t.name} job with id ${e.job.id}`),Zf.error(n),e.job.message=n,e.job.status=Sr.JOB_STATUS_ENUM.ERROR;try{await y$.updateJob(e.job)}catch(s){throw Zf.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Li,"runJob");async function S_e(e){Zf.trace("launching job thread:",e),w$?I$.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Sr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):h_e.postMessage({type:Sr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(S_e,"launchJobThread");w$&&m_e(Sr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{I$.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Sr.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){Zf.error(r)}});C$.exports={parseMessage:p_e,RunnerMessage:ON}});var L$=b((pPe,P$)=>{"use strict";var NN=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};P$.exports=NN});var z$=b((gPe,LN)=>{"use strict";var yS=Vr(),CN=Jp(),gS=gN(),To=j_(),RS=fi(),rE=Wo(),T_e=Gb(),eE=vn(),AS=Jm(),Lt=yO(),bS=V(),g_e=Xb(),R_e=dp(),M$=Ly(),A_e=fp(),b_e=vy(),y_e=By(),O_e=ky(),N_e=Gy(),IN=pp(),U$=Xp(),I_e=Qp(),DN=yN(),$=M(),{hdb_errors:sE,handleHDBError:nE}=fe(),{HTTP_STATUS_CODES:v$}=sE,wN=jy(),B$=Lu(),K$=require("util"),Qu=Yr(),w_e=as(),C_e=gu(),H$=D$(),x$=ef(),k$=(vp(),oe(If)),F$=wt(),G$=Yp(),q$=Gp(),{setServerUtilities:D_e}=(zf(),oe(RN)),{CONTEXT:TPe}=(Hs(),oe(EA)),{_assignPackageExport:P_e}=Vi(),{transformReq:L_e}=J(),{server:M_e}=($r(),oe($a)),Xr=bS.loggerWithTag("operation"),tE=js(),$$=(Dc(),oe(Cc)),U_e=dN(),V$=yS.searchByHash,v_e=yS.searchByValue,B_e=K$.promisify(yS.search),H_e=K$.promisify(CN.evaluateSQL),x_e={[$.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[$.OPERATIONS_ENUM.CREATE_TABLE]:!0,[$.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[$.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[$.OPERATIONS_ENUM.DROP_TABLE]:!0,[$.OPERATIONS_ENUM.DROP_SCHEMA]:!0},K=L$();async function W$(e,t){try{if(e.body.operation!=="read_log"&&(bS.log_level===$.LOG_LEVELS.INFO||bS.log_level===$.LOG_LEVELS.DEBUG||bS.log_level===$.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,...o}=e.body;Xr.info(o)}}catch(n){Xr.error(n)}let r=await U_e.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return x_e[e.body.operation]&&w_e.setSchemaDataToGlobal(n=>{n&&Xr.error(n)}),r}a(W$,"processLocalTransaction");var Y$=F_e();LN.exports={chooseOperation:j$,getOperationFunction:Q$,operation:PN,processLocalTransaction:W$};D_e(LN.exports);M_e.operation=PN;function j$(e){let t;try{t=Q$(e)}catch(s){throw Xr.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=CN.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=CN.checkASTPermissions(e,i);if(o)throw Xr.error(`${v$.FORBIDDEN} from operation ${e.operation}`),Xr.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),nE(new Error,o,sE.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==$.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==$.OPERATIONS_ENUM.LOGIN&&e.operation!==$.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=I_e.verifyPerms(i,s);if(o)throw Xr.error(`${v$.FORBIDDEN} from operation ${e.operation}`),Xr.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),nE(new Error,o,sE.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw nE(s,"There was an error when trying to choose an operation path")}return r}a(j$,"chooseOperation");function Q$(e){if(Xr.trace(`getOperationFunction with operation: ${e.operation}`),Y$.has(e.operation))return Y$.get(e.operation);throw nE(new Error,sE.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),sE.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(Q$,"getOperationFunction");P_e("operation",PN);function PN(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=j$(e);return W$({body:e},n)}a(PN,"operation");async function k_e(e){Xr.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[$.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case $.OPERATIONS_ENUM.INSERT:o=await Qu.insert(i);break;case $.OPERATIONS_ENUM.UPDATE:o=await Qu.update(i);break;case $.OPERATIONS_ENUM.UPSERT:o=await Qu.upsert(i);break;case $.OPERATIONS_ENUM.DELETE:o=await rE.deleteRecord(i);break;default:Xr.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){Xr.info("Invalid operation in transaction"),Xr.error(o)}}a(k_e,"catchup");async function Zs(e){L_e(e);let t,r;try{r=await DN.addJob(e),t=r.createdJob,Xr.info("addJob result",r);let n=new H$.RunnerMessage(t,e);return{message:await H$.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw Xr.error(s),nE(n,s)}}a(Zs,"executeJob");function F_e(){let e=new Map;return e.set($.OPERATIONS_ENUM.INSERT,new K(Qu.insert)),e.set($.OPERATIONS_ENUM.UPDATE,new K(Qu.update)),e.set($.OPERATIONS_ENUM.UPSERT,new K(Qu.upsert)),e.set($.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new K(yS.searchByConditions)),e.set($.OPERATIONS_ENUM.SEARCH_BY_HASH,new K(V$)),e.set($.OPERATIONS_ENUM.SEARCH_BY_ID,new K(V$)),e.set($.OPERATIONS_ENUM.SEARCH_BY_VALUE,new K(v_e)),e.set($.OPERATIONS_ENUM.SEARCH,new K(B_e)),e.set($.OPERATIONS_ENUM.SQL,new K(H_e)),e.set($.OPERATIONS_ENUM.CSV_DATA_LOAD,new K(Zs,gS.csvDataLoad)),e.set($.OPERATIONS_ENUM.CSV_FILE_LOAD,new K(Zs,gS.csvFileLoad)),e.set($.OPERATIONS_ENUM.CSV_URL_LOAD,new K(Zs,gS.csvURLLoad)),e.set($.OPERATIONS_ENUM.IMPORT_FROM_S3,new K(Zs,gS.importFromS3)),e.set($.OPERATIONS_ENUM.CREATE_SCHEMA,new K(To.createSchema)),e.set($.OPERATIONS_ENUM.CREATE_DATABASE,new K(To.createSchema)),e.set($.OPERATIONS_ENUM.CREATE_TABLE,new K(To.createTable)),e.set($.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new K(To.createAttribute)),e.set($.OPERATIONS_ENUM.DROP_SCHEMA,new K(To.dropSchema)),e.set($.OPERATIONS_ENUM.DROP_DATABASE,new K(To.dropSchema)),e.set($.OPERATIONS_ENUM.DROP_TABLE,new K(To.dropTable)),e.set($.OPERATIONS_ENUM.DROP_ATTRIBUTE,new K(To.dropAttribute)),e.set($.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new K(RS.describeSchema)),e.set($.OPERATIONS_ENUM.DESCRIBE_DATABASE,new K(RS.describeSchema)),e.set($.OPERATIONS_ENUM.DESCRIBE_TABLE,new K(RS.describeTable)),e.set($.OPERATIONS_ENUM.DESCRIBE_ALL,new K(RS.describeAll)),e.set($.OPERATIONS_ENUM.DELETE,new K(rE.deleteRecord)),e.set($.OPERATIONS_ENUM.ADD_USER,new K(eE.addUser)),e.set($.OPERATIONS_ENUM.ALTER_USER,new K(eE.alterUser)),e.set($.OPERATIONS_ENUM.DROP_USER,new K(eE.dropUser)),e.set($.OPERATIONS_ENUM.LIST_USERS,new K(eE.listUsersExternal)),e.set($.OPERATIONS_ENUM.LIST_ROLES,new K(AS.listRoles)),e.set($.OPERATIONS_ENUM.ADD_ROLE,new K(AS.addRole)),e.set($.OPERATIONS_ENUM.ALTER_ROLE,new K(AS.alterRole)),e.set($.OPERATIONS_ENUM.DROP_ROLE,new K(AS.dropRole)),e.set($.OPERATIONS_ENUM.USER_INFO,new K(eE.userInfo)),e.set($.OPERATIONS_ENUM.READ_LOG,new K(g_e)),e.set($.OPERATIONS_ENUM.ADD_NODE,new K(R_e)),e.set($.OPERATIONS_ENUM.UPDATE_NODE,new K(M$)),e.set($.OPERATIONS_ENUM.SET_NODE_REPLICATION,new K(M$)),e.set($.OPERATIONS_ENUM.REMOVE_NODE,new K(A_e)),e.set($.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new K(b_e)),e.set($.OPERATIONS_ENUM.PURGE_STREAM,new K(y_e)),e.set($.OPERATIONS_ENUM.SET_CONFIGURATION,new K(F$.setConfiguration)),e.set($.OPERATIONS_ENUM.CLUSTER_STATUS,new K(O_e.clusterStatus)),e.set($.OPERATIONS_ENUM.CLUSTER_NETWORK,new K(N_e)),e.set($.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new K(IN.setRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new K(IN.getRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new K(IN.deleteRoutes)),e.set($.OPERATIONS_ENUM.EXPORT_TO_S3,new K(Zs,U$.export_to_s3)),e.set($.OPERATIONS_ENUM.CREATE_CSR,new K(tE.createCsr)),e.set($.OPERATIONS_ENUM.SIGN_CERTIFICATE,new K(tE.signCertificate)),e.set($.OPERATIONS_ENUM.LIST_CERTIFICATES,new K(tE.listCertificates)),e.set($.OPERATIONS_ENUM.ADD_CERTIFICATES,new K(tE.addCertificate)),e.set($.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new K(tE.removeCertificate)),e.set($.OPERATIONS_ENUM.ADD_NODE_BACK,new K($$.addNodeBack)),e.set($.OPERATIONS_ENUM.REMOVE_NODE_BACK,new K($$.removeNodeBack)),e.set($.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new K(Zs,rE.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new K(Zs,rE.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.EXPORT_LOCAL,new K(Zs,U$.export_local)),e.set($.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new K(DN.handleGetJobsByStartDate)),e.set($.OPERATIONS_ENUM.GET_JOB,new K(DN.handleGetJob)),e.set($.OPERATIONS_ENUM.GET_FINGERPRINT,new K(wN.getFingerprint)),e.set($.OPERATIONS_ENUM.SET_LICENSE,new K(wN.setLicense)),e.set($.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new K(wN.getRegistrationInfo)),e.set($.OPERATIONS_ENUM.RESTART,new K(B$.restart)),e.set($.OPERATIONS_ENUM.RESTART_SERVICE,new K(Zs,B$.restartService)),e.set($.OPERATIONS_ENUM.CATCHUP,new K(k_e)),e.set($.OPERATIONS_ENUM.SYSTEM_INFORMATION,new K(C_e.systemInformation)),e.set($.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new K(Zs,rE.deleteAuditLogsBefore)),e.set($.OPERATIONS_ENUM.READ_AUDIT_LOG,new K(T_e)),e.set($.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new K(x$.createTokens)),e.set($.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new K(x$.refreshOperationToken)),e.set($.OPERATIONS_ENUM.LOGIN,new K(k$.login)),e.set($.OPERATIONS_ENUM.LOGOUT,new K(k$.logout)),e.set($.OPERATIONS_ENUM.GET_CONFIGURATION,new K(F$.getConfiguration)),e.set($.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new K(Lt.customFunctionsStatus)),e.set($.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new K(Lt.getCustomFunctions)),e.set($.OPERATIONS_ENUM.GET_COMPONENT_FILE,new K(Lt.getComponentFile)),e.set($.OPERATIONS_ENUM.GET_COMPONENTS,new K(Lt.getComponents)),e.set($.OPERATIONS_ENUM.SET_COMPONENT_FILE,new K(Lt.setComponentFile)),e.set($.OPERATIONS_ENUM.DROP_COMPONENT,new K(Lt.dropComponent)),e.set($.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new K(Lt.getCustomFunction)),e.set($.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new K(Lt.setCustomFunction)),e.set($.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new K(Lt.dropCustomFunction)),e.set($.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new K(Lt.addComponent)),e.set($.OPERATIONS_ENUM.ADD_COMPONENT,new K(Lt.addComponent)),e.set($.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new K(Lt.dropCustomFunctionProject)),e.set($.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new K(Lt.packageComponent)),e.set($.OPERATIONS_ENUM.PACKAGE_COMPONENT,new K(Lt.packageComponent)),e.set($.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new K(Lt.deployComponent)),e.set($.OPERATIONS_ENUM.DEPLOY_COMPONENT,new K(Lt.deployComponent)),e.set($.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new K(G$.readTransactionLog)),e.set($.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new K(Zs,G$.deleteTransactionLogsBefore)),e.set($.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new K(q$.installModules)),e.set($.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new K(q$.auditModules)),e.set($.OPERATIONS_ENUM.GET_BACKUP,new K(To.getBackup)),e.set($.OPERATIONS_ENUM.ADD_SSH_KEY,new K(Lt.addSSHKey)),e.set($.OPERATIONS_ENUM.UPDATE_SSH_KEY,new K(Lt.updateSSHKey)),e.set($.OPERATIONS_ENUM.DELETE_SSH_KEY,new K(Lt.deleteSSHKey)),e.set($.OPERATIONS_ENUM.LIST_SSH_KEYS,new K(Lt.listSSHKeys)),e.set($.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new K(Lt.setSSHKnownHosts)),e.set($.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new K(Lt.getSSHKnownHosts)),e}a(F_e,"initializeOperationFunctionMap")});var NS=b((APe,Z$)=>{"use strict";var MN=M(),G_e=J(),iE=V(),{handleHDBError:UN,hdb_errors:OS}=fe(),{isMainThread:q_e}=require("worker_threads"),{Readable:$_e}=require("stream"),J$=require("os"),V_e=require("util"),Y_e=cy(),K_e=V_e.promisify(Y_e.authorize),X$=z$(),{createGzip:W_e,constants:j_e}=require("zlib");function Q_e(e){let t=`Found an uncaught exception with message: ${e.message}. ${J$.EOL}Stack: ${e.stack} ${J$.EOL}Terminating ${q_e?"HDB":"thread"}.`;console.error(t),iE.fatal(t),process.exit(1)}a(Q_e,"handleServerUncaughtException");function z_e(e,t,r){if(iE[e.logLevel||"error"](e),e.statusCode)return typeof e.http_resp_msg!="object"?r.code(e.statusCode).send({error:e.http_resp_msg||e.message}):r.code(e.statusCode).send(e.http_resp_msg);let n=e.statusCode?e.statusCode:OS.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR;return typeof e=="string"?r.code(n).send({error:e}):r.code(n).send(e.message?{error:e.message}:e)}a(z_e,"serverErrorHandler");function J_e(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=UN(new Error,"Invalid JSON.",OS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(G_e.isEmpty(e.body.operation)){let n=UN(new Error,"Request body must include an 'operation' property.",OS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(J_e,"reqBodyValidationHandler");function X_e(e,t,r){let n;e.body.operation!==MN.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==MN.OPERATIONS_ENUM.LOGIN&&e.body.operation!==MN.OPERATIONS_ENUM.LOGOUT?K_e(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{iE.warn(s),iE.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(UN(s,i,OS.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.hdb_auth_header=e.headers.authorization,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(X_e,"authHandler");async function Z_e(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=X$.chooseOperation(e.body);let s=await X$.processLocalTransaction(e,n);if(s instanceof $_e&&s.headers){for(let[i,o]of s.headers)t.header(i,o);e.headers["accept-encoding"]?.includes("gzip")&&(t.header("content-encoding","gzip"),s=s.pipe(W_e({level:j_e.Z_BEST_SPEED})))}return s}catch(s){throw iE.error(s),s}}a(Z_e,"handlePostRequest");Z$.exports={authHandler:X_e,handlePostRequest:Z_e,handleServerUncaughtException:Q_e,serverErrorHandler:z_e,reqBodyValidationHandler:J_e}});var nV=b((yPe,rV)=>{"use strict";var efe=require("fastify-plugin"),{handlePostRequest:eV,authHandler:tfe,reqBodyValidationHandler:rfe}=NS();async function nfe(e){e.decorate("hdbCore",{preValidation:[rfe,tfe],request:t=>tV(eV(t,response)),requestWithoutAuthentication:(t,r)=>tV(eV(t,r,!0))})}a(nfe,"hdbCore");async function tV(e){if(e=await e,e?.[Symbol.asyncIterator]&&!e[Symbol.iterator]){let t=[];for await(let r of e)t.push(r);return t}return e}a(tV,"convertAsyncIterators");rV.exports=efe(nfe)});var oV=b((IPe,iV)=>{"use strict";var NPe=require("fs"),vN=te();vN.initSync();var{CONFIG_PARAMS:sV}=M(),sfe=1024*1024*1024;function ife(e){let t=vN.get(sV.HTTP_TIMEOUT),r=vN.get(sV.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:sfe,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,https:e}}a(ife,"getServerOptions");iV.exports=ife});var lV=b((CPe,cV)=>{"use strict";var BN=te();BN.initSync();var{CONFIG_PARAMS:aV}=M();function ofe(){let e=BN.get(aV.HTTP_CORSACCESSLIST),t=BN.get(aV.HTTP_CORS),r;return t&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},e&&e.length>0&&e[0]!==null&&e[0]!=="*"&&(r.origin=(n,s)=>s(null,e.indexOf(n)!==-1))),r}a(ofe,"getCORSOptions");cV.exports=ofe});var _V=b((PPe,dV)=>{"use strict";var uV=te();uV.initSync();var afe=M();function cfe(){return uV.get(afe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(cfe,"getHeaderTimeoutConfig");dV.exports=cfe});var xN={};et(xN,{customFunctionsServer:()=>dfe,ready:()=>IV,start:()=>ufe});function ufe(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){go||(go=NV(t),st.http((await go).server));let o=await go,c=(0,HN.dirname)(s),l=(0,HN.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!fV.has(c)){fV.add(c);try{o.register(ffe(c,l))}catch(d){if(d.message==="Root plugin has already booted")St.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw d}}},ready:IV}}async function dfe(){try{St.info("In Custom Functions Fastify server"+process.cwd()),St.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),St.debug(`Custom Functions server process ${process.pid} starting up.`),await _fe();let e=TV.get(gV.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=go=await NV(e)}catch(r){throw St.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw St.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){St.error(`Custom Functions ${process.pid} Error: ${e}`),St.error(e),process.exit(1)}}async function _fe(){try{St.info("Custom Functions starting configuration."),await RV.setUsersToGlobal(),St.info("Custom Functions completed configuration.")}catch(e){St.error(e)}}function ffe(e,t){return async function(r){try{St.info("Custom Functions starting buildRoutes"),St.trace("Loading fastify routes folder "+e),(0,EV.existsSync)(e)&&r.register(SV.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:St.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?St.error(s.message):s&&St.error(s),o()})}catch(n){St.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function NV(e){St.info("Custom Functions starting buildServer.");let t=(0,AV.default)(e),r=(0,hV.default)(t);r.server.headersTimeout=(0,yV.default)(),r.setErrorHandler(OV.serverErrorHandler);let n=(0,bV.default)();return n&&r.register(mV.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(pV.default),await r.register(lfe),await r.after(),WO(r),St.info("Custom Functions completed buildServer."),r}function IV(){if(go)return go.then?go.then(e=>e.ready()):go.ready()}var HN,EV,hV,mV,pV,SV,TV,gV,St,lfe,RV,AV,bV,yV,OV,go,fV,wV=De(()=>{HN=require("path"),EV=require("fs"),hV=v(require("fastify")),mV=v(require("@fastify/cors")),pV=v(sN()),SV=v(require("@fastify/autoload")),TV=v(te()),gV=v(M()),St=v(V()),lfe=v(nV()),RV=v(vn()),AV=v(oV()),bV=v(lV()),yV=v(_V()),OV=v(NS());Uu();$r();fV=new Set;a(ufe,"start");a(dfe,"customFunctionsServer");a(_fe,"setUp");a(ffe,"buildRouteFolder");a(NV,"buildServer");a(IV,"ready")});var kN={};et(kN,{start:()=>Efe});function Efe(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,MV.default)(r,e);return e.server.http(async(s,i)=>{if(!s.isWebSocket)return new Promise(o=>n(s._nodeRequest,s._nodeResponse,()=>{o(i(s))}))}),!0}},handleFile(t,r,n){DV||(DV=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=CV.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,PV.default)(s,(0,LV.realpathSync)(o))}}return i(s)},{runFirst:!0})),CV.set(r,n)}}}var PV,LV,MV,CV,DV,UV=De(()=>{PV=v(require("send")),LV=require("fs"),MV=v(require("serve-static")),CV=new Map;a(Efe,"start")});var $N={};et($N,{Request:()=>FN,createReuseportFd:()=>IS});var vV,FN,GN,qN,IS,wS=De(()=>{vV=require("os"),FN=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new qN(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new GN(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},GN=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},qN=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,vV.platform)()!="win32"&&(IS=require("node-unix-socket").createReuseportFd)});var YN=b((xPe,BV)=>{"use strict";var oE=te();oE.initSync();var zu=require("fs-extra"),VN=require("path"),Ju=M(),hfe=require("crypto"),mfe=require("uuid").v4;BV.exports=pfe;function pfe(){if(oE.getHdbBasePath()!==void 0){let e=VN.join(oE.getHdbBasePath(),Ju.LICENSE_KEY_DIR_NAME,Ju.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=VN.join(oE.getHdbBasePath(),Ju.LICENSE_KEY_DIR_NAME,Ju.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=VN.join(oE.getHdbBasePath(),Ju.LICENSE_KEY_DIR_NAME,Ju.JWT_ENUM.JWT_PASSPHRASE_NAME);try{zu.accessSync(r),zu.accessSync(e),zu.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=mfe(),i=hfe.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});zu.writeFileSync(r,s),zu.writeFileSync(e,i.privateKey),zu.writeFileSync(t,i.publicKey)}else throw n}}}a(pfe,"checkJWTTokenExist")});var xV=b((FPe,HV)=>{"use strict";var KN=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};HV.exports={HdbInfoInsertObject:KN}});var GV=b((qPe,FV)=>{"use strict";var kV=M(),WN=class{static{a(this,"UpgradeObject")}constructor(t,r){this[kV.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[kV.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};FV.exports={UpgradeObject:WN}});var CS=b((VPe,$V)=>{"use strict";var Is=require("prompt"),Xu=require("chalk"),qV=V(),ei=require("os"),jN=qa(),QN=["yes","y"];async function Sfe(e){let t=`${ei.EOL}`+Xu.bold.green("Your current HarperDB version requires that we complete an update process.")+`${ei.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${ei.EOL}${ei.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${ei.EOL}`;Is.override=jN(["CONFIRM_UPGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Xu.magenta(`${ei.EOL}[CONFIRM_UPGRADE] Do you want to upgrade your HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n;try{n=await Is.get([r])}catch(s){return qV.error("There was an error when prompting user about an upgrade."),qV.error(s),!1}return QN.includes(n.CONFIRM_UPGRADE)}a(Sfe,"forceUpdatePrompt");async function Tfe(e){let t=`${ei.EOL}`+Xu.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${ei.EOL}`);Is.override=jN(["CONFIRM_DOWNGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Xu.magenta(`${ei.EOL}[CONFIRM_DOWNGRADE] Do you want to proceed with using your downgraded HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n=await Is.get([r]);return QN.includes(n.CONFIRM_DOWNGRADE)}a(Tfe,"forceDowngradePrompt");async function gfe(){let e=`${ei.EOL}`+Xu.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");Is.override=jN(["GENERATE_CERTS"]),Is.start(),Is.message=e;let t={properties:{GENERATE_CERTS:{description:Xu.magenta(`${ei.EOL}[GENERATE_CERTS] Do you want HarperDB to generate all new certificates? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"yes",required:!0}}},r=await Is.get([t]);return QN.includes(r.GENERATE_CERTS)}a(gfe,"upgradeCertsPrompt");$V.exports={forceUpdatePrompt:Sfe,forceDowngradePrompt:Tfe,upgradeCertsPrompt:gfe}});var JN=b((KPe,VV)=>{"use strict";var zN=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};VV.exports=zN});var KV=b((XPe,YV)=>{"use strict";var Rfe=J(),Afe=wt(),jPe=V(),QPe=require("path"),zPe=require("fs"),JPe=M();YV.exports={getOldPropsValue:bfe};function bfe(e,t,r=!1){let n=t.getRaw(e);return Rfe.isNotEmptyAndHasValue(n)?n:r?Afe.getDefaultConfig(e):""}a(bfe,"getOldPropsValue")});var zV=b((eLe,QV)=>{"use strict";var Oa=require("path"),Na=require("fs-extra"),yfe=require("properties-reader"),Ofe=JN(),cr=V(),{getOldPropsValue:Tt}=KV(),{HDB_SETTINGS_NAMES:he,CONFIG_PARAMS:Jc}=M(),Xc=wt(),DS=te(),WV=J(),Mi=M(),XN=new Ofe("3.1.0"),jV=[];function Nfe(){let e=yfe(DS.get(he.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),cr.info(t);let r=` ;Settings for the HarperDB process.
39
41
 
40
42
  ;The directory selected during install where the database files reside.
41
- ${Ee.HDB_ROOT_KEY} = ${St(Ee.HDB_ROOT_KEY,e)}
43
+ ${he.HDB_ROOT_KEY} = ${Tt(he.HDB_ROOT_KEY,e)}
42
44
  ;The port the HarperDB REST interface will listen on.
43
- ${Ee.SERVER_PORT_KEY} = ${St(Ee.SERVER_PORT_KEY,e)}
45
+ ${he.SERVER_PORT_KEY} = ${Tt(he.SERVER_PORT_KEY,e)}
44
46
  ;Set to true to enable HTTPS on the HarperDB REST endpoint. Requires a valid certificate and key.
45
- ${Ee.HTTP_SECURE_ENABLED_KEY} = ${St(Ee.HTTP_SECURE_ENABLED_KEY,e)}
47
+ ${he.HTTP_SECURE_ENABLED_KEY} = ${Tt(he.HTTP_SECURE_ENABLED_KEY,e)}
46
48
  ;The path to the SSL certificate used when running with HTTPS enabled.
47
- ${Ee.CERT_KEY} = ${St(Ee.CERT_KEY,e)}
49
+ ${he.CERT_KEY} = ${Tt(he.CERT_KEY,e)}
48
50
  ;The path to the SSL private key used when running with HTTPS enabled.
49
- ${Ee.PRIVATE_KEY_KEY} = ${St(Ee.PRIVATE_KEY_KEY,e)}
51
+ ${he.PRIVATE_KEY_KEY} = ${Tt(he.PRIVATE_KEY_KEY,e)}
50
52
  ;Set to true to enable Cross Origin Resource Sharing, which allows requests across a domain.
51
- ${Ee.CORS_ENABLED_KEY} = ${St(Ee.CORS_ENABLED_KEY,e)}
53
+ ${he.CORS_ENABLED_KEY} = ${Tt(he.CORS_ENABLED_KEY,e)}
52
54
  ;Allows for setting allowable domains with CORS. Comma separated list.
53
- ${Ee.CORS_WHITELIST_KEY} = ${St(Ee.CORS_WHITELIST_KEY,e)}
55
+ ${he.CORS_WHITELIST_KEY} = ${Tt(he.CORS_WHITELIST_KEY,e)}
54
56
  ;Length of time in milliseconds after which a request will timeout. Defaults to 120,000 ms (2 minutes).
55
- ${Ee.SERVER_TIMEOUT_KEY} = ${St(Ee.SERVER_TIMEOUT_KEY,e,!0)}
57
+ ${he.SERVER_TIMEOUT_KEY} = ${Tt(he.SERVER_TIMEOUT_KEY,e,!0)}
56
58
  ;The number of milliseconds of inactivity a server needs to wait for additional incoming data, after it has finished writing the last response. Defaults to 5,000 ms (5 seconds).
57
- ${Ee.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${St(Ee.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0)}
59
+ ${he.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${Tt(he.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0)}
58
60
  ;Limit the amount of time the parser will wait to receive the complete HTTP headers.. Defaults to 60,000 ms (1 minute).
59
- ${Ee.SERVER_HEADERS_TIMEOUT_KEY} = ${St(Ee.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
61
+ ${he.SERVER_HEADERS_TIMEOUT_KEY} = ${Tt(he.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
60
62
  ;Define whether to log to file or not.
61
- ${Ee.LOG_TO_FILE} = ${Jc.getDefaultConfig(zc.LOGGING_FILE)}
63
+ ${he.LOG_TO_FILE} = ${Xc.getDefaultConfig(Jc.LOGGING_FILE)}
62
64
  ;Define whether to log to stdout/stderr or not. NOTE HarperDB must run in foreground in order to receive the std stream from HarperDB.
63
- ${Ee.LOG_TO_STDSTREAMS} = ${Jc.getDefaultConfig(zc.LOGGING_STDSTREAMS)}
65
+ ${he.LOG_TO_STDSTREAMS} = ${Xc.getDefaultConfig(Jc.LOGGING_STDSTREAMS)}
64
66
  ;Set to control amount of logging generated. Accepted levels are trace, debug, warn, error, fatal.
65
- ${Ee.LOG_LEVEL_KEY} = ${St(Ee.LOG_LEVEL_KEY,e)}
67
+ ${he.LOG_LEVEL_KEY} = ${Tt(he.LOG_LEVEL_KEY,e)}
66
68
  ;The path where log files will be written. If there is no file name included in the path, the log file will be created by default as 'hdb_log.log'
67
- ${Ee.LOG_PATH_KEY} = ${St(Ee.LOG_PATH_KEY,e)}
69
+ ${he.LOG_PATH_KEY} = ${Tt(he.LOG_PATH_KEY,e)}
68
70
  ;Set to true to enable daily log file rotations - each log file name will be prepended with YYYY-MM-DD.
69
- ${Ee.LOG_DAILY_ROTATE_KEY} = ${St(Ee.LOG_DAILY_ROTATE_KEY,e)}
71
+ ${he.LOG_DAILY_ROTATE_KEY} = ${Tt(he.LOG_DAILY_ROTATE_KEY,e)}
70
72
  ;Set the number of daily log files to maintain when LOG_DAILY_ROTATE is enabled. If no integer value is set, no limit will be set for
71
73
  ;daily log files which may consume a large amount of storage depending on your log settings.
72
- ${Ee.LOG_MAX_DAILY_FILES_KEY} = ${St(Ee.LOG_MAX_DAILY_FILES_KEY,e)}
74
+ ${he.LOG_MAX_DAILY_FILES_KEY} = ${Tt(he.LOG_MAX_DAILY_FILES_KEY,e)}
73
75
  ;The environment used by NodeJS. Setting to production will be the most performant, settings to development will generate more logging.
74
- ${Ee.PROPS_ENV_KEY} = ${St(Ee.PROPS_ENV_KEY,e)}
76
+ ${he.PROPS_ENV_KEY} = ${Tt(he.PROPS_ENV_KEY,e)}
75
77
  ;This allows self signed certificates to be used in clustering. This is a security risk
76
78
  ;as clustering will not validate the cert, so should only be used internally.
77
79
  ;The HDB install creates a self signed certificate, if you use that cert this must be set to true.
78
- ${Ee.ALLOW_SELF_SIGNED_SSL_CERTS} = ${St(Ee.ALLOW_SELF_SIGNED_SSL_CERTS,e,!0)}
80
+ ${he.ALLOW_SELF_SIGNED_SSL_CERTS} = ${Tt(he.ALLOW_SELF_SIGNED_SSL_CERTS,e,!0)}
79
81
  ;Set the max number of processes HarperDB will start. This can also be limited by number of cores and licenses.
80
- ${Ee.MAX_HDB_PROCESSES} = ${St(Ee.MAX_HDB_PROCESSES,e)}
82
+ ${he.MAX_HDB_PROCESSES} = ${Tt(he.MAX_HDB_PROCESSES,e)}
81
83
  ;Set to true to enable clustering. Requires a valid enterprise license.
82
- ${Ee.CLUSTERING_ENABLED_KEY} = ${St(Ee.CLUSTERING_ENABLED_KEY,e,!0)}
84
+ ${he.CLUSTERING_ENABLED_KEY} = ${Tt(he.CLUSTERING_ENABLED_KEY,e,!0)}
83
85
  ;The port that will be used for HarperDB clustering.
84
- ${Ee.CLUSTERING_PORT_KEY} = ${St(Ee.CLUSTERING_PORT_KEY,e)}
86
+ ${he.CLUSTERING_PORT_KEY} = ${Tt(he.CLUSTERING_PORT_KEY,e)}
85
87
  ;The name of this node in your HarperDB cluster topology. This must be a value unique from the rest of your cluster node names.
86
- ${Ee.CLUSTERING_NODE_NAME_KEY} = ${St(Ee.CLUSTERING_NODE_NAME_KEY,e)}
88
+ ${he.CLUSTERING_NODE_NAME_KEY} = ${Tt(he.CLUSTERING_NODE_NAME_KEY,e)}
87
89
  ;The user used to connect to other instances of HarperDB, this user must have a role of cluster_user.
88
- ${Ee.CLUSTERING_USER_KEY} = ${St(Ee.CLUSTERING_USER_KEY,e)}
90
+ ${he.CLUSTERING_USER_KEY} = ${Tt(he.CLUSTERING_USER_KEY,e)}
89
91
  ;Defines if this instance does not record transactions. Note, if Clustering is enabled and Transaction Log is disabled your nodes will not catch up.
90
- ${Ee.DISABLE_TRANSACTION_LOG_KEY} = ${St(Ee.DISABLE_TRANSACTION_LOG_KEY,e,!0)}
92
+ ${he.DISABLE_TRANSACTION_LOG_KEY} = ${Tt(he.DISABLE_TRANSACTION_LOG_KEY,e,!0)}
91
93
  ;Defines the length of time an operation token will be valid until it expires. Example values: https://github.com/vercel/ms
92
- ${Ee.OPERATION_TOKEN_TIMEOUT_KEY} = ${St(Ee.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
94
+ ${he.OPERATION_TOKEN_TIMEOUT_KEY} = ${Tt(he.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
93
95
  ;Defines the length of time a refresh token will be valid until it expires. Example values: https://github.com/vercel/ms
94
- ${Ee.REFRESH_TOKEN_TIMEOUT_KEY} = ${St(Ee.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
96
+ ${he.REFRESH_TOKEN_TIMEOUT_KEY} = ${Tt(he.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
95
97
  ;The port the IPC server will run on.
96
- ${Ee.IPC_SERVER_PORT} = ${Jc.getDefaultConfig(zc.IPC_NETWORK_PORT)}
98
+ ${he.IPC_SERVER_PORT} = ${Xc.getDefaultConfig(Jc.IPC_NETWORK_PORT)}
97
99
  ;Run HDB in the foreground.
98
- ${Ee.RUN_IN_FOREGROUND} = ${Jc.getDefaultConfig(zc.OPERATIONSAPI_FOREGROUND)}
100
+ ${he.RUN_IN_FOREGROUND} = ${Xc.getDefaultConfig(Jc.OPERATIONSAPI_FOREGROUND)}
99
101
  ;Set to true to enable custom API endpoints. Requires a valid enterprise license.
100
- ${Ee.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${Jc.getDefaultConfig(zc.CUSTOMFUNCTIONS_ENABLED)}
102
+ ${he.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${Xc.getDefaultConfig(Jc.CUSTOMFUNCTIONS_ENABLED)}
101
103
  ;The port used to access the custom functions server.
102
- ${Ee.CUSTOM_FUNCTIONS_PORT_KEY} = ${Jc.getDefaultConfig(zc.HTTP_PORT)}
104
+ ${he.CUSTOM_FUNCTIONS_PORT_KEY} = ${Xc.getDefaultConfig(Jc.HTTP_PORT)}
103
105
  ;The path to the folder containing HarperDB custom function files.
104
- ${Ee.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${Ra.join(St(Ee.HDB_ROOT_KEY,e),"custom_functions")}
106
+ ${he.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${Oa.join(Tt(he.HDB_ROOT_KEY,e),"custom_functions")}
105
107
  ;Set the max number of processes HarperDB will start for the Custom Functions server
106
- ${Ee.MAX_CUSTOM_FUNCTION_PROCESSES} = ${Jc.getDefaultConfig(zc.HTTP_THREADS)}
107
- `,n=PS.get("settings_path"),s=Ra.dirname(n),i=Ra.join(s,"3_1_0_upgrade_settings.bak");try{cr.info(`Backing up old settings file to: ${i}`),Aa.copySync(n,i)}catch(c){throw cr.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{cr.info("New settings file values for 3.1.0 upgrade:",r),cr.info(`Creating new/upgraded settings file at '${n}'`),Aa.writeFileSync(n,r),cr.info("Updating env variables with new settings values")}catch(c){throw console.error("There was a problem writing the new settings file. Please check the log for details."),cr.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),cr.error(c),Aa.copySync(i,n),c}PS.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),cr.info(o),o}a(Nfe,"updateSettingsFile_3_1_0");function Ife(){let e=Ra.join($V.getHomeDir(),Ui.HDB_HOME_DIR_NAME,Ui.LICENSE_KEY_DIR_NAME,Ui.LICENSE_FILE_NAME),t=Ra.join($V.getHomeDir(),Ui.HDB_HOME_DIR_NAME,Ui.LICENSE_KEY_DIR_NAME,Ui.REG_KEY_FILE_NAME),r=Ra.join(PS.getHdbBasePath(),Ui.LICENSE_KEY_DIR_NAME,Ui.LICENSE_FILE_NAME),n=Ra.join(r,Ui.LICENSE_FILE_NAME),s=Ra.join(r,Ui.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),cr.info(i);let o="Creating .license directory";console.log(o),cr.info(o),Aa.mkdirpSync(r);try{Aa.accessSync(e);try{let c="Moving licence file";console.log(c),cr.info(c),Aa.moveSync(e,n);let l="License file successfully moved.";console.log(l),cr.info(l)}catch{let l="moving license file failed";console.error(l),cr.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),cr.warn(l)}try{Aa.accessSync(t);try{let c="Moving registration file";console.log(c),cr.info(c),Aa.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),cr.info(l)}catch{let l="moving registration file failed";console.error(l),cr.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),cr.warn(l)}}a(Ife,"moveLicenseFiles");XN.sync_functions.push(Nfe);XN.sync_functions.push(Ife);VV.push(XN);YV.exports=VV});var JV=b((sLe,zV)=>{"use strict";var Yn=Et(),{insertRecords:wfe}=za(),Cfe=nn(),Oa=Bt(),Dfe=ee(),go=V(),Pfe=ee(),vi=require("fs-extra"),Ro=require("path"),Lfe=require("cli-progress"),oE=require("assert"),Mfe=require("pino"),Ufe=te();zV.exports=vfe;var LS,WV,MS,ZN,en,aE=!1;async function vfe(e=!0){return LS=Ufe.getHdbBasePath(),WV=Ro.join(LS,"schema"),MS=Ro.join(LS,"4_0_0_upgrade_tmp"),ZN=Ro.join(LS,"transactions"),console.info("Reindexing upgrade started for schemas"),go.notify("Reindexing upgrade started for schemas"),await jV(WV,!1,e),await vi.pathExists(ZN)&&(console.info(`
108
+ ${he.MAX_CUSTOM_FUNCTION_PROCESSES} = ${Xc.getDefaultConfig(Jc.HTTP_THREADS)}
109
+ `,n=DS.get("settings_path"),s=Oa.dirname(n),i=Oa.join(s,"3_1_0_upgrade_settings.bak");try{cr.info(`Backing up old settings file to: ${i}`),Na.copySync(n,i)}catch(c){throw cr.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{cr.info("New settings file values for 3.1.0 upgrade:",r),cr.info(`Creating new/upgraded settings file at '${n}'`),Na.writeFileSync(n,r),cr.info("Updating env variables with new settings values")}catch(c){throw console.error("There was a problem writing the new settings file. Please check the log for details."),cr.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),cr.error(c),Na.copySync(i,n),c}DS.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),cr.info(o),o}a(Nfe,"updateSettingsFile_3_1_0");function Ife(){let e=Oa.join(WV.getHomeDir(),Mi.HDB_HOME_DIR_NAME,Mi.LICENSE_KEY_DIR_NAME,Mi.LICENSE_FILE_NAME),t=Oa.join(WV.getHomeDir(),Mi.HDB_HOME_DIR_NAME,Mi.LICENSE_KEY_DIR_NAME,Mi.REG_KEY_FILE_NAME),r=Oa.join(DS.getHdbBasePath(),Mi.LICENSE_KEY_DIR_NAME,Mi.LICENSE_FILE_NAME),n=Oa.join(r,Mi.LICENSE_FILE_NAME),s=Oa.join(r,Mi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),cr.info(i);let o="Creating .license directory";console.log(o),cr.info(o),Na.mkdirpSync(r);try{Na.accessSync(e);try{let c="Moving licence file";console.log(c),cr.info(c),Na.moveSync(e,n);let l="License file successfully moved.";console.log(l),cr.info(l)}catch{let l="moving license file failed";console.error(l),cr.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),cr.warn(l)}try{Na.accessSync(t);try{let c="Moving registration file";console.log(c),cr.info(c),Na.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),cr.info(l)}catch{let l="moving registration file failed";console.error(l),cr.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),cr.warn(l)}}a(Ife,"moveLicenseFiles");XN.sync_functions.push(Nfe);XN.sync_functions.push(Ife);jV.push(XN);QV.exports=jV});var t1=b((rLe,e1)=>{"use strict";var Yn=ht(),{insertRecords:wfe}=Qa(),Cfe=nn(),Ia=Bt(),Dfe=J(),Ro=V(),Pfe=J(),Ui=require("fs-extra"),Ao=require("path"),Lfe=require("cli-progress"),aE=require("assert"),Mfe=require("pino"),Ufe=te();e1.exports=vfe;var PS,JV,LS,ZN,Zr,cE=!1;async function vfe(e=!0){return PS=Ufe.getHdbBasePath(),JV=Ao.join(PS,"schema"),LS=Ao.join(PS,"4_0_0_upgrade_tmp"),ZN=Ao.join(PS,"transactions"),console.info("Reindexing upgrade started for schemas"),Ro.notify("Reindexing upgrade started for schemas"),await XV(JV,!1,e),await Ui.pathExists(ZN)&&(console.info(`
108
110
 
109
- Reindexing upgrade started for transaction logs`),go.notify("Reindexing upgrade started for transaction logs"),await jV(ZN,!0,e)),go.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(aE?", but errors occurred":"")}a(vfe,"reindexUpgrade");async function jV(e,t,r){let n=await vi.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Ro.join(e,o.toString());if(o===".DS_Store")continue;let l=await vi.readdir(c),d=l.length;for(let u=0;u<d;u++){let _=l[u];if(_!==".DS_Store"&&vi.statSync(Ro.join(c,_)).isDirectory())try{await Bfe(o,_,t),en.info(`Reindexing started for ${o}.${_}`),go.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${_}`),await xfe(o,_,c,t,r),en.info(`Reindexing completed for ${o}.${_}`),go.notify(`Reindexing completed for ${o}.${_}`)}catch(E){aE=!0,E.schema_path=c,E.table_name=_,go.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),go.error(E),en.error(E),console.error(E)}}}if(!aE)try{await vi.rm(MS,{recursive:!0})}catch{}}a(jV,"processTables");async function Bfe(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Ro.join(MS,s);await vi.ensureDir(MS),await vi.writeFile(i,""),en=Mfe({level:"debug",formatters:{bindings(){}}},i)}a(Bfe,"initPinoLogger");var Hfe=20;async function xfe(e,t,r,n,s){let i;try{i=await Yn.openEnvironment(r,t,n)}catch(S){if(S.message==="MDB_INVALID: File is not an LMDB file"){go.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`),en.error(S);return}throw S}let o=Gfe(i.dbis),c=Yn.openDBI(i,o),l=Object.keys(i.dbis),d=Yn.statDBI(i,o);en.info(`Old environment stats: ${JSON.stringify(d)}`);let u=new Lfe.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});u.start(d.entryCount,0,{});let _=await Yn.createEnvironment(r,t,!1);Yn.createDBI(_,o,!1,!0);let E=[];try{for(let S of c.getRange({start:!1}))S.value={...S.value},E.push(S),n||e==="system"&&(t==="hdb_schema"&&(S.key=S.key.toString(),S.value.name=S.value.name.toString()),t==="hdb_table"&&(S.key=S.key.toString(),S.value.schema=S.value.schema.toString(),S.value.name=S.value.name.toString()),t==="hdb_attribute"&&(S.key=S.key.toString(),S.value.schema=S.value.schema.toString(),S.value.table=S.value.table.toString(),S.value.attribute=S.value.attribute.toString())),E.length>Hfe&&await f();await f()}catch(S){throw aE=!0,en.error(S),S}async function f(){let S,C=E.map(({value:x})=>x);n?S=await Promise.all(C.map(x=>Ffe(_,x))):S=await wfe(_,o,l.filter(x=>x!=="__blob__"),C,!1);for(let x=0,F=E.length;x<F;x++){let{key:Y,value:$}=E[x];en.info(`Record hash value: ${Y} hash: ${o}`);let Z;n?Z=S[x]:Z=S.written_hashes.indexOf(Y)>-1,oE(Z,!0),kfe(_,o,$[o],n),en.info(`Insert success, written hashes: ${S.written_hashes}`),u.increment()}E=[],u.value/u.total*100%10===0&&go.notify(`${e}.${t} ${u.value}/${u.total} records inserted`),en.info(`${u.value}/${u.total} records inserted`)}a(f,"finishOutstanding"),u.stop();let h=Yn.statDBI(i,o),p=Yn.statDBI(_,o);if(en.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${p.entryCount}`),oE.deepStrictEqual(h.entryCount,p.entryCount),await Yn.closeEnvironment(i),await Yn.closeEnvironment(_),delete global.lmdb_map[`${e}.${t}`],s){let S=Ro.join(r,t),C=Ro.join(S,"data.mdb"),y=Ro.join(S,"lock.mdb");await vi.unlink(C),await vi.unlink(y),await vi.rmdir(S),en.info(`Deleted old environment files from schema folder: ${C}, ${y}`)}let T=await Yn.openEnvironment(r,t),g=Yn.statDBI(T,o);en.info(`New stats: ${JSON.stringify(p)}. New stats after move: ${JSON.stringify(g)}`),oE.deepStrictEqual(g.entryCount,p.entryCount),await Yn.closeEnvironment(T),delete global.lmdb_map[`${e}.${t}`]}a(xfe,"processTable");async function Ffe(e,t){Yn.initializeDBIs(e,Oa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Oa.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[Oa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[Oa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),Pfe.isEmpty(t.user_name)||e.dbis[Oa.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[Oa.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(Ffe,"insertTransaction");function kfe(e,t,r,n){let i=e.dbis[t].get(r);oE.deepStrictEqual(typeof i,"object");let o;if(n){let c={[Oa.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[Oa.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE]:i.hash_values};o=Object.entries(c)}else o=Object.entries(i);for(let[c,l]of o)if(c!==t&&e.dbis[c]!==void 0&&!Dfe.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let d=0,u=l.length;d<u;d++){let _=l[d];QV(e,c,_,r)}else QV(e,c,l,r)}a(kfe,"validateIndices");function QV(e,t,r,n){try{let s=!1,i=Cfe.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||en.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),oE.deepStrictEqual(s,!0)}catch(s){aE=!0,en.error(s),console.error(s)}}a(QV,"validateIndex");function Gfe(e){let t;for(let[r,n]of Object.entries(e))if(n.__dbi_defintion__.is_hash_attribute===!0){t=r;break}return t}a(Gfe,"getHashDBI")});var r1=b((aLe,t1)=>{"use strict";var US=require("path"),ba=require("fs-extra"),qfe=JN(),Xc=V(),XV=It(),eI=te(),ei=M(),vS=ee(),$fe=require("properties-reader"),Vfe=ks(),Yfe=J_(),Kfe=Yr(),oLe=require("util"),Wfe=Kfe.searchByValue,jfe=Kr(),Qfe=pp(),zfe=_t(),Jfe=JV(),ZV=Ks(),Xfe=DS(),uE=new qfe("4.0.0"),e1=[],cE,lE;async function Zfe(){try{if(await Xfe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),cE){let t=vS.changeExtension(cE,".bak");await ba.move(cE,t)}if(lE){let t=vS.changeExtension(lE,".bak");await ba.move(lE,t)}await ZV.generateKeys()}else console.log("Using existing certificates."),ZV.updateConfigCert(cE,lE,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(Zfe,"generateNewKeys");async function eEe(){console.log("Updating HarperDB nodes."),Xc.info("Updating HarperDB nodes.");let e=[];try{let t=new Vfe(ei.SYSTEM_SCHEMA_NAME,ei.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await Wfe(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!zfe.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let u=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(u),u}let l={host:c.host,port:c.port};e.push(l);let d=[];for(let u=0,_=c.subscriptions.length;u<_;u++){let E=c.subscriptions[u],f=E.channel.split(":");d.push({schema:f[0],table:f[1],publish:E.publish,subscribe:E.subscribe})}n.push({name:c.name,subscriptions:d,system_info:{hdb_version:ei.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(vS.isEmptyOrZeroLength(n))return;let s=new Yfe(ei.SYSTEM_SCHEMA_NAME,ei.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await jfe.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{Qfe.setRoutes({server:"hub",routes:e})}catch(t){throw console.error("There was a problem setting the clustering routes. Please check the log for details."),t}}a(eEe,"updateNodes");async function tEe(){let e=eI.get(ei.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(US.join("config","settings.js"))){Xc.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),Xc.info(t);let r=US.dirname(e),n=eI.get(ei.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=US.join(n,"backup","4_0_0_upgrade_settings.bak"),i=US.join(n,ei.HDB_CONFIG_FILE);try{Xc.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),ba.copySync(e,s)}catch(_){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),_}try{Xc.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),Xc.info("Updating env variables with new settings values");let _=XV.initOldConfig(e);cE=_[ei.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],lE=_[ei.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],XV.createConfigFile(_)}catch(_){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),_}let o=vS.getPropsFilePath();ba.accessSync(o,ba.constants.F_OK|ba.constants.R_OK);let l=$fe(o).get(ei.HDB_SETTINGS_NAMES.INSTALL_USER),d=`settings_path = ${i}
110
- install_user = ${l}`;try{ba.writeFileSync(o,d)}catch(_){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),_}try{eI.initSync(!0)}catch(_){throw console.error("Unable to initialize new properties. Please check the log for details."),_}let u="New settings file for 4.0.0 upgrade successfully created.";try{ba.removeSync(r),console.log(u),Xc.info(u)}catch(_){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),_}}a(tEe,"updateSettingsFile_4_0_0");uE.async_functions.push(tEe);uE.async_functions.push(Zfe);uE.async_functions.push(Jfe);uE.async_functions.push(eEe);e1.push(uE);t1.exports=e1});var tI=b((lLe,o1)=>{"use strict";var Zc=ee(),rEe=M(),n1=V(),{DATA_VERSION:nEe,UPGRADE_VERSION:sEe}=rEe.UPGRADE_JSON_FIELD_NAMES_ENUM,s1=KV(),BS=r1(),el=new Map;s1&&s1.forEach(e=>{el.set(e.version,e)});BS&&BS.forEach(e=>{el.set(e.version,e)});BS&&BS.forEach(e=>{el.set(e.version,e)});function iEe(){return[...el.keys()].sort(Zc.compareVersions)}a(iEe,"getSortedVersions");function i1(e){let t=e[nEe],r=e[sEe];return Zc.isEmptyOrZeroLength(t)||Zc.isEmptyOrZeroLength(r)?(n1.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),n1.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."),[]):[...el.keys()].sort(Zc.compareVersions).filter(function(n){return Zc.compareVersions(n,t)>0&&Zc.compareVersions(n,r)<=0})}a(i1,"getVersionsForUpgrade");function oEe(e){return i1(e).length>0}a(oEe,"hasUpgradesRequired");function aEe(e){return Zc.isEmptyOrZeroLength(e)?null:el.has(e)?el.get(e):null}a(aEe,"getDirectiveByVersion");o1.exports={getSortedVersions:iEe,getDirectiveByVersion:aEe,getVersionsForUpgrade:i1,hasUpgradesRequired:oEe}});var xS=b((dLe,d1)=>{"use strict";var cEe=require("util"),rI=require("chalk"),lEe=require("os"),c1=Kr(),uEe=Yr(),Kn=M(),l1=UV(),sI=OR(),{UpgradeObject:a1}=HV(),{forceDowngradePrompt:dEe}=DS(),_Ee=wc(),HS=V(),Zu=ee(),iI=is(),fEe=(Le(),ie(lt)),EEe=tI(),hEe=cEe.promisify(iI.setSchemaDataToGlobal),mEe=uEe.searchByValue,pEe="info_id",SEe="2.9.9",TEe="3.0.0";async function gEe(e){let t=new l1.HdbInfoInsertObject(1,e,e),r=new sI.InsertObject(Kn.OPERATIONS_ENUM.INSERT,Kn.SYSTEM_SCHEMA_NAME,Kn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Kn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return iI.setSchemaDataToGlobal(),c1.insert(r)}a(gEe,"insertHdbInstallInfo");async function nI(e){let t,r=await u1(),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 l1.HdbInfoInsertObject(i,e,e);let o=new sI.InsertObject(Kn.OPERATIONS_ENUM.INSERT,Kn.SYSTEM_SCHEMA_NAME,Kn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Kn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return await hEe(),c1.insert(o)}a(nI,"insertHdbUpgradeInfo");async function u1(){let e=new sI.NoSQLSeachObject(Kn.SYSTEM_SCHEMA_NAME,Kn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,pEe,Kn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await mEe(e))}catch(r){console.error(r)}return t}a(u1,"getAllHdbInfoRecords");async function REe(){let e=await u1();if(e.length===0)return;let t,r=new Map;for(let s of e)r.set(s.info_id,s);let n=Math.max.apply(null,[...r.keys()]);return t=r.get(n),t}a(REe,"getLatestHdbInfoRecord");async function AEe(){HS.info("Checking if HDB software has been updated");try{let e=_Ee.version(),t=await REe(),r;if(Zu.isEmpty(t))r=SEe;else if(r=t.data_version_num,Zu.compareVersions(r.toString(),e.toString())>0){if(!Zu.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(rI.yellow(`This instance's data was last run on version ${r}`)),console.error(rI.red(`You have installed a version lower than the version that your data was created on or was upgraded to. This may cause issues and is currently not supported.${lEe.EOL}${Kn.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Zu.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(rI.yellow(`This instance's data was last run on version ${r}`)),await dEe(new a1(r,e))?await nI(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(iI.setSchemaDataToGlobal(),OEe(r),e.toString()===r.toString())return;let n=new a1(r,e);if(EEe.hasUpgradesRequired(n))return n;Zu.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await nI(n.upgrade_version),HS.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw HS.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),HS.fatal(e),e}}a(AEe,"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 ${Kn.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in fEe.databases.system))throw console.log(t),new Error(t);if(!Zu.isEmpty(e)&&e<TEe)throw console.log(t),new Error(t)}a(OEe,"checkIfInstallIsSupported");d1.exports={insertHdbInstallInfo:gEe,insertHdbUpgradeInfo:nI,getVersionUpdateInfo:AEe}});var h1=b((fLe,E1)=>{"use strict";var FS=require("joi"),{boolean:bEe,string:oI,number:yEe}=FS.types(),_1=require("fs-extra"),dE=M(),f1=require("path"),NEe=dt();E1.exports=IEe;function IEe(e){let t=oI.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=FS.object({[dE.INSTALL_PROMPTS.ROOTPATH]:FS.custom(wEe),[dE.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:FS.alternatives([yEe.min(0),oI]).allow("null",null),[dE.INSTALL_PROMPTS.TC_AGREEMENT]:oI.valid("yes","YES","Yes"),[dE.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[dE.INSTALL_PROMPTS.CLUSTERING_ENABLED]:bEe});return NEe.validateBySchema(e,r)}a(IEe,"installValidator");function wEe(e,t){if(_1.existsSync(f1.join(e,"system/hdb_user/data.mdb"))||_1.existsSync(f1.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(wEe,"validateRootAvailable")});var p1=b((hLe,m1)=>{"use strict";var{mkdirpSync:CEe}=require("fs-extra"),Bi=require("path"),ed=M(),cI=V(),DEe=Pn(),aI=Qi(),PEe=Tt();m1.exports=LEe;async function LEe(e){cI.trace("Mounting HarperDB"),ti(e),ti(Bi.join(e,"backup")),ti(Bi.join(e,"trash")),ti(Bi.join(e,"keys")),ti(Bi.join(e,"keys",ed.LICENSE_FILE_NAME)),ti(Bi.join(e,"log")),ti(Bi.join(e,"doc")),ti(Bi.join(e,"database")),ti(Bi.join(e,ed.TRANSACTIONS_DIR_NAME)),ti(Bi.join(e,"clustering","leaf")),ti(Bi.join(e,"components")),await MEe()}a(LEe,"mountHdb");async function MEe(){let e=Fl(),t=Object.keys(aI);for(let r=0;r<t.length;r++){let n=t[r],s=aI[n].hash_attribute;try{PEe.initSystemSchemaPaths(ed.SYSTEM_SCHEMA_NAME,n);let i=new e(ed.SYSTEM_SCHEMA_NAME,n,s);i.attributes=aI[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,await DEe.createTable(n,i)}catch(i){throw cI.error(`issue creating environment for ${ed.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(MEe,"createLMDBTables");function ti(e){CEe(e,{mode:ed.HDB_FILE_PERMISSIONS}),cI.info(`Directory ${e} created`)}a(ti,"makeDirectory")});var L1=b((TLe,P1)=>{"use strict";var uI=require("os"),A1=require("inquirer"),Is=require("fs-extra"),UEe=require("properties-reader"),rl=require("chalk"),xi=require("path"),vEe=require("human-readable-ids").hri,BEe=require("ora"),HEe=require("yaml"),lr=V(),ya=te(),_E=ee(),GS=$a(),O1=xS(),b1=wc(),ae=M(),{CONFIG_PARAM_MAP:pLe,CONFIG_PARAMS:Mt}=ae,xEe=h1(),FEe=p1(),dI=It(),kEe=vn(),GEe=Jm(),qEe=YN(),$Ee=is(),VEe=require("util").promisify,YEe=VEe($Ee.setSchemaDataToGlobal),S1=Ks(),tl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),Br=a(e=>rl.magenta.bold(e),"HDB_PROMPT_MSG"),KEe="https://harperdb.io/legal/end-user-license-agreement",Na=uI.EOL,Ao="",WEe="yes",T1="Starting HarperDB install...",g1="HarperDB installation was successful.",R1="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",jEe="An out of date version of HarperDB is already installed.",lI="It appears that HarperDB is already installed. Exiting install...",QEe="Aborting install",SLe=new RegExp(/^([0-9]{1,4}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5])$/),zEe=new RegExp(/^[^\s.,*>]+$/),JEe=uI.homedir(),XEe=xi.join(JEe,ae.HDB_ROOT_DIR_NAME),ZEe="HDB_ADMIN",ehe="CLUSTER_USER",the="dev",rhe="localhost",kS={[Mt.HTTP_CORS]:!0,[Mt.HTTP_CORSACCESSLIST]:["*"],[Mt.HTTP_PORT]:9926,[Mt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Mt.THREADS_COUNT]:1,[Mt.THREADS_DEBUG]:!0,[Mt.LOGGING_STDSTREAMS]:!0,[Mt.LOGGING_LEVEL]:"info",[Mt.OPERATIONSAPI_NETWORK_PORT]:9925,[Mt.LOCALSTUDIO_ENABLED]:!0},vr={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:"},Ia=GS([ae.INSTALL_PROMPTS.HDB_CONFIG]),Hi,y1=!1,N1=!1,I1=!1;P1.exports={install:w1,updateConfigEnv:fhe,setIgnoreExisting:Ehe};w1.createSuperUser=D1;async function w1(){console.log(Br(Na+T1+Na)),lr.notify(T1);let e;Ia[ae.INSTALL_PROMPTS.HDB_CONFIG]&&(e=nhe());let t=ihe();Object.assign(t,e),t[ae.INSTALL_PROMPTS.TC_AGREEMENT]&&t[ae.INSTALL_PROMPTS.ROOTPATH]&&t[ae.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[ae.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&(I1=!0,t[ae.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=xEe(t);if(r)throw r.message;await ohe(),await ahe(t);let n=await she(t);Hi=n[ae.INSTALL_PROMPTS.ROOTPATH],Ia[ae.INSTALL_PROMPTS.HDB_CONFIG]&&xi.dirname(Ia[ae.INSTALL_PROMPTS.HDB_CONFIG])===Hi&&(y1=!0),!Ia[ae.INSTALL_PROMPTS.HDB_CONFIG]&&await Is.pathExists(xi.join(Hi,ae.HDB_CONFIG_FILE))&&(console.error(lI),process.exit());let s=BEe({prefixText:Br("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),_E.isEmpty(Hi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");ya.setHdbBasePath(Hi),await FEe(Hi),await che(),await lhe(n),lr.initLogSettings(!0),await D1(n),await dhe(n),await S1.updateConfigCert(),await S1.generateCertsKeys(),await _he(),qEe(),s.stop(),console.log(Br(Na+g1+Na)),lr.notify(g1)}a(w1,"install");function nhe(){let e=HEe.parseDocument(Is.readFileSync(Ia[ae.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=dI.flattenConfig(e.toJSON());return t[ae.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[ae.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(nhe,"getConfigFromFile");async function she(e){lr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:tl,when:Oo(e[ae.INSTALL_PROMPTS.ROOTPATH],vr.DESTINATION),name:ae.INSTALL_PROMPTS.ROOTPATH,prefix:Ao,default:XEe,validate:async s=>Ns(s)?Ns(s):await Is.pathExists(xi.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,message:Br(vr.DESTINATION)},{type:"input",transformer:tl,when:Oo(e[ae.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],vr.HDB_USERNAME),name:ae.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Ao,default:ZEe,validate:s=>Ns(s)?Ns(s):(t=s,!0),message:Br(vr.HDB_USERNAME)},{type:"password",when:Oo(e[ae.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],vr.HDB_PASS),name:ae.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Ao,validate:s=>Ns(s)?Ns(s):!0,message:Br(vr.HDB_PASS)},{type:"input",transformer:tl,when:Oo(e[ae.INSTALL_PROMPTS.DEFAULTS_MODE],vr.DEFAULTS_MODE),name:ae.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Ao,default:the,validate:s=>Ns(s)?Ns(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,message:Br(vr.DEFAULTS_MODE)}];if(I1||r.push({type:"input",name:ae.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:tl,when:Oo(e[ae.INSTALL_PROMPTS.REPLICATION_HOSTNAME],vr.REPLICATION_HOSTNAME),prefix:Ao,default:rhe,message:Br(vr.REPLICATION_HOSTNAME)}),_E.autoCastBoolean(e[ae.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:tl,when:Oo(e[ae.INSTALL_PROMPTS.CLUSTERING_NODENAME],vr.NODE_NAME),name:ae.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Ao,default:vEe.random(),validate:i=>zEe.test(i)?!0:"Invalid node name, must not contain ., * or >",message:Br(vr.NODE_NAME)},{type:"input",transformer:tl,when:Oo(e[ae.INSTALL_PROMPTS.CLUSTERING_USER],vr.CLUSTER_USERNAME),name:ae.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Ao,default:ehe,validate:i=>Ns(i)?Ns(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,message:Br(vr.CLUSTER_USERNAME)},{type:"password",when:Oo(e[ae.INSTALL_PROMPTS.CLUSTERING_PASSWORD],vr.CLUSTER_PASS),name:ae.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Ao,validate:i=>Ns(i)?Ns(i):!0,message:Br(vr.CLUSTER_PASS)}];r.push(...s)}let n=await A1.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(she,"installPrompts");function Oo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${Br(t)} ${rl.gray("[hidden]")}`),lr.trace(`${Br(t)} [hidden]`)):(console.log(`${Br(t)} ${e}`),lr.trace(`${Br(t)} ${e}`)),!1):!0}a(Oo,"displayCmdEnvVar");function Ns(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(Ns,"checkForEmptyValue");function ihe(){let e=Object.keys(ae.INSTALL_PROMPTS),t=GS(e),r=GS(Object.keys(ae.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=ae.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(ihe,"checkForPromptOverride");async function ohe(){lr.trace("Checking for existing install.");let e=_E.getPropsFilePath(),t=await Is.pathExists(e),r;if(t){lr.trace(`Install found an existing boot prop file at:${e}`);let n=UEe(e),s=dI.getConfigValue(ae.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(ae.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Is.pathExists(s)}if(!t&&_E.noBootFile()&&(r=!0),r&&!N1){if(lr.trace(`Install found existing HDB config at:${e}`),await O1.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${b1.version()}. Exiting install...`;console.log(Na+rl.magenta.bold(jEe)),console.log(rl.magenta.bold(s)),lr.error(s)}else console.log(Na+rl.magenta.bold(lI)),lr.error(lI);process.exit(0)}}a(ohe,"checkForExistingInstall");async function ahe(e){lr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${KEe}${Na}and can be viewed by typing or copying and pasting the URL into your web browser.${Na}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Ao,transformer:tl,when:Oo(e[ae.INSTALL_PROMPTS.TC_AGREEMENT],t),name:ae.INSTALL_PROMPTS.TC_AGREEMENT,message:Br(t),validate:s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:rl.yellow("Please enter 'yes' or 'no'")},n=await A1.prompt([r]);n[ae.INSTALL_PROMPTS.TC_AGREEMENT]&&n[ae.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==WEe&&(console.log(rl.yellow(R1)),lr.error(R1),process.exit(0))}a(ahe,"termsAgreement");async function che(){let e=xi.join(Hi,ae.HDB_CONFIG_FILE),t;try{t=uI.userInfo().username}catch{t=process.env.USERNAME||process.env.USER||process.env.LOGNAME||process.env.LNAME||process.env.SUDO_USER}if(t){let r=`settings_path = ${e}
111
- install_user = ${t}`,n=_E.getHomeDir(),s=xi.join(n,ae.HDB_HOME_DIR_NAME),i=xi.join(s,ae.LICENSE_KEY_DIR_NAME);try{Is.mkdirpSync(s,{mode:ae.HDB_FILE_PERMISSIONS}),Is.mkdirpSync(i,{mode:ae.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${ae.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=xi.join(s,ae.BOOT_PROPS_FILE_NAME);try{await Is.writeFile(o,r)}catch(c){throw lr.error(`There was an error creating the boot file at path: ${o}`),c}ya.setProperty(ae.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),ya.setProperty(ae.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),ya.setProperty(ya.BOOT_PROPS_FILE_PATH,o)}}a(che,"createBootPropertiesFile");async function lhe(e){lr.trace("Creating HarperDB config file");let t=GS(Object.keys(ae.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[ae.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in kS){if(r===Mt.HTTP_PORT&&t[Mt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??kS[r],t[Mt.HTTP_SECUREPORT]=null;continue}else if(r===Mt.HTTP_PORT)continue;if(r===Mt.OPERATIONSAPI_NETWORK_PORT&&t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??kS[r],t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Mt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=kS[r])}}else t[Mt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Mt.HTTP_PORT.toLowerCase()]&&(t[Mt.HTTP_SECUREPORT]=null);try{Ia[ae.INSTALL_PROMPTS.HDB_CONFIG]||dI.createConfigFile(t),ya.initSync()}catch(r){uhe(r)}}a(lhe,"createConfigFile");function uhe(e){lr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(QEe);let t=xi.resolve(ya.get(ya.BOOT_PROPS_FILE_PATH),"../");t&&Is.removeSync(t),Hi&&(y1?Is.readdirSync(Hi,{withFileTypes:!0}).forEach(n=>{let s=xi.join(n.path,n.name);s!==Ia[ae.INSTALL_PROMPTS.HDB_CONFIG]&&Is.removeSync(s)}):Is.removeSync(Hi)),process.exit(1)}a(uhe,"rollbackInstall");async function C1(e,t){lr.trace("Creating admin user"),await YEe();let r;try{r=await GEe.addRole(e)}catch(n){if(n.message.includes("already exists"))t=void 0;else throw n.message+="Error creating role",n}if(t)try{t.role=r.role,await kEe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(C1,"createAdminUser");async function D1(e){lr.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[ae.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[ae.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await C1(t,r),delete e[ae.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[ae.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(D1,"createSuperUser");async function dhe(e){lr.trace("Creating Cluster user.");let t;e[ae.INSTALL_PROMPTS.CLUSTERING_USER]&&e[ae.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[ae.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[ae.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await C1({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[ae.INSTALL_PROMPTS.CLUSTERING_USER],delete e[ae.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(dhe,"createClusterUser");async function _he(){let e=b1.version();if(e)await O1.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(_he,"insertHdbVersionInfo");function fhe(e){Ia[ae.INSTALL_PROMPTS.HDB_CONFIG]=e}a(fhe,"updateConfigEnv");function Ehe(e){N1=e}a(Ehe,"setIgnoreExisting")});var v1=b((RLe,U1)=>{"use strict";var _I=ee(),Wn=V(),M1=tI();U1.exports={processDirectives:hhe};async function hhe(e){console.log("Starting upgrade process...");let t=M1.getVersionsForUpgrade(e),r=She(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;Wn.notify(c),console.log(c);let l=[],d=[];try{l=mhe(o.sync_functions)}catch(u){throw Wn.error(`Error while running an upgrade script for ${o.version}`),u}try{d=await phe(o.async_functions)}catch(u){throw Wn.error(`Error while running an upgrade script for ${o.version}`),u}n.push(...l,...d)}return n}a(hhe,"processDirectives");function mhe(e){if(_I.isEmptyOrZeroLength(e))return Wn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Wn.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(Wn.info(`Running function ${r.name}`),!(r instanceof Function)){Wn.info("Variable being processed is not a function");continue}let n=r();Wn.info(n),t.push(n)}return t}a(mhe,"runSyncFunctions");async function phe(e){if(_I.isEmptyOrZeroLength(e))return Wn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Wn.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(Wn.info(`Running function ${s.name}`),!(s instanceof Function)){Wn.info("Variable being processed is not a function");continue}let i=await s();Wn.info(i),t.push(i)}return t}a(phe,"runAsyncFunctions");function She(e){if(_I.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=M1.getDirectiveByVersion(r);n&&t.push(n)}return t}a(She,"getUpgradeDirectivesToInstall")});var q1=b((OLe,G1)=>{"use strict";var qS=te();qS.initSync();var F1=require("chalk"),B1=require("fs-extra"),yo=V(),bo=M(),H1=wc(),The=v1(),fI=ee(),k1=xS(),ghe=DS(),x1=fg(),Rhe=is(),Ahe=require("util").promisify,Ohe=Ahe(Rhe.setSchemaDataToGlobal),EI,{UPGRADE_VERSION:$S}=bo.UPGRADE_JSON_FIELD_NAMES_ENUM;G1.exports={upgrade:bhe};async function bhe(e){await Ohe(),EI===void 0&&(EI=Tf()),B1.existsSync(qS.get(qS.BOOT_PROPS_FILE_PATH))||(fE("The hdb_boot_properties file was not found. Please install HDB.",bo.LOG_LEVELS.ERROR),process.exit(1)),B1.existsSync(qS.get(bo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(fE("The hdb settings file was not found. Please make sure HDB is installed.",bo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await k1.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),fE(`This version of HarperDB is ${H1.version()}`,bo.LOG_LEVELS.INFO);let r=t[$S]?t[$S]:H1.version();r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${bo.HDB_SUPPORT_ADDRESS}`),yo.notify("Missing new version field from upgrade info object"),process.exit(1)),await yhe();let n,s=0;try{n=await ghe.forceUpdatePrompt(t)}catch(i){yo.error("There was an error when prompting user about upgrade."),yo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),yo.info(`Starting upgrade to version ${r}`),await Nhe(t),fE(`HarperDB was successfully upgraded to version ${t[$S]}`,bo.LOG_LEVELS.INFO)}a(bhe,"upgrade");async function yhe(){let e=!1,t=await x1.findPs(bo.HDB_PROC_NAME);if(fI.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await x1.findPs("hdb_express");fI.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await EI.list();fI.isEmptyOrZeroLength(r)||(e=!0)}if(e){let r="HarperDB is running, please stop all HarperDB services with 'harperdb stop' and run the upgrade command again.";console.log(F1.red(r)),yo.error(r),process.exit(1)}}a(yhe,"checkIfRunning");async function Nhe(e){try{await The.processDirectives(e)}catch(t){throw fE("There was an error during the data upgrade. Please check the logs.",bo.LOG_LEVELS.ERROR),t}try{await k1.insertHdbUpgradeInfo(e[$S])}catch(t){yo.error("Error updating the 'hdb_info' system table."),yo.error(t)}}a(Nhe,"runUpgrade");function fE(e,t=void 0){t||(t=yo.info),yo[t](e),console.log(F1.magenta(e))}a(fE,"printToLogAndConsole")});var W1=b((yLe,K1)=>{"use strict";var{promises:mI,createReadStream:Ihe,createWriteStream:whe}=require("fs"),{createGzip:Che}=require("zlib"),{promisify:Dhe}=require("util"),{pipeline:Phe}=require("stream"),Lhe=Dhe(Phe),Mhe=require("path"),sl=te();sl.initSync();var nl=V(),{CONFIG_PARAMS:EE,ITC_EVENT_TYPES:Uhe}=M(),{onMessageFromWorkers:vhe}=st(),Bhe=6e4,Hhe="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",xhe="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",hI,V1;K1.exports=Y1;vhe(e=>{e.type===Uhe.RESTART&&(sl.initSync(!0),clearInterval(V1),sl.get(EE.LOGGING_ROTATION_ENABLED)&&Y1())});async function Y1(){try{let e=nl.getLogFilePath(),t=sl.get(EE.LOGGING_ROTATION_MAXSIZE),r=sl.get(EE.LOGGING_ROTATION_INTERVAL);if(!t&&!r){nl.error(Hhe);return}let n=sl.get(EE.LOGGING_ROTATION_PATH);if(!n){nl.error(xhe);return}let s;if(t){let o=t.slice(-1),c=t.slice(0,-1);o==="G"?s=c*1e9:o==="M"?s=c*1e6:s=c*1e3}let i;if(r){let o=r.slice(-1),c=r.slice(0,-1);o==="D"?i=c*1440:o==="H"?i=c*60:i=c}hI=Date.now()/6e4,nl.trace("Log rotate enabled, maxSize:",t,"interval:",r),V1=setInterval(async()=>{if(s){let o;o=await mI.stat(e),o.size>=s&&await $1(e,n)}i&&Date.now()/6e4-hI>=i&&(await $1(e,n),hI=Date.now()/6e4)},Bhe).unref()}catch(e){nl.error(e)}}a(Y1,"logRotator");async function $1(e,t){let r=sl.get(EE.LOGGING_ROTATION_COMPRESS),n=Mhe.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.${r?"log.gz":"log"}`);r?(await Lhe(Ihe(e),Che(),whe(n)),await mI.unlink(e)):await mI.rename(e,n),nl.closeLogFile(),nl.notify(`hdb.log rotated, old log moved to ${n}`)}a($1,"moveLogFile")});var tY=b(eY=>{"use strict";var Se=te();Se.initSync();var ILe=Pu(),Zt=M(),ri=V(),No=require("fs-extra"),wa=require("path"),Fhe=require("systeminformation"),khe=YN(),{install:Ghe}=L1(),pI=require("chalk"),qhe=$l(),Io=ee(),SI=It(),Q1=$a(),j1=Ap(),$he=q1(),Vhe=W1(),{compactOnStart:Yhe}=(oy(),ie(iy)),Khe=require("minimist"),Whe=Ks(),{PACKAGE_ROOT:jhe,CONFIG_PARAMS:De}=M(),{startHTTPThreads:Qhe,startSocketServer:wLe,mostIdleRouting:CLe,remoteAffinityRouting:DLe}=(TI(),ie(rY)),zhe=xS(),{isMainThread:Jhe}=require("worker_threads"),PLe=Qi(),LLe=Ei(),MLe=TA(),ULe=Fl(),VS=M(),Fi,td,z1=!1,Xhe="Upgrade complete. Starting HarperDB.",Zhe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",eme="HarperDB not found, starting install process.",tme="There was an error during install, check install_log.log for more details. Exiting.",rme="HarperDB successfully started.";function nme(){if(!z1){let e=a(()=>{No.removeSync(wa.join(Se.get(Zt.CONFIG_PARAMS.ROOTPATH),Zt.HDB_PID_FILE)),process.exit(0)},"remove_hdb_pid");process.on("exit",()=>{e()}),process.on("SIGINT",()=>{e()}),process.on("SIGQUIT",()=>{e()}),process.on("SIGTERM",()=>{e()})}}a(nme,"addExitListeners");async function J1(e=!1,t=!1){if(console.log(pI.magenta("Starting HarperDB...")),ri.suppressLogging?.(()=>{console.log(pI.magenta(""+No.readFileSync(wa.join(jhe,"utility/install/ascii_logo.txt"))))}),await Z1()===!1){console.log(eme);try{await Ghe()}catch(o){console.error(tme,o),ri.error(o),process.exit(1)}}if(!e){let o=Q1(Object.keys(Zt.CONFIG_PARAM_MAP),!0);!Io.isEmpty(o)&&!Io.isEmptyOrZeroLength(Object.keys(o))&&SI.updateConfigValue(void 0,void 0,o,!0,!0)}let r,n=td?.service==="clustering";td?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));try{let o=Number.parseInt(await No.readFile(wa.join(Se.get(Zt.CONFIG_PARAMS.ROOTPATH),Zt.HDB_PID_FILE),"utf8")),c=await Fhe.processes();for(let l of c.list)if(l.pid===o){n?r=!0:console.log("HarperDB appears to be already running.");break}}catch{}Fi===void 0&&(Fi=Tf()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),Se.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await j1.generateNatsConfig(),await Fi.startClusteringProcesses(!0),process.exit()),nme(),await No.writeFile(wa.join(Se.get(VS.CONFIG_PARAMS.ROOTPATH),VS.HDB_PID_FILE),`${process.pid}`),ri.info("HarperDB PID",process.pid);let s;try{let o=await zhe.getVersionUpdateInfo();o!==void 0&&(s=o[Zt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await $he.upgrade(o),console.log(Xhe))}catch(o){s?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${s}. Exiting HarperDB.`,o),ri.error(o)):(console.error(Zhe,o),ri.error(o)),process.exit(1)}khe(),ome(),await Whe.reviewSelfSignedCert(),Io.autoCastBoolean(Se.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&Jhe&&await j1.generateNatsConfig(t)}a(J1,"initialize");async function sme(e=!1){try{td=Khe(process.argv),td.ROOTPATH&&SI.updateConfigObject("settings_path",wa.join(td.ROOTPATH,Zt.HDB_CONFIG_FILE)),await J1(e,!0),Se.get(Zt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Yhe();let t=process.env.IS_SCRIPTED_SERVICE&&!td.service;Io.autoCastBoolean(Se.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Fi.startClusteringProcesses(),await Fi.startClusteringThreads()),await Qhe(process.env.DEV_MODE?1:Se.get(VS.CONFIG_PARAMS.THREADS_COUNT)??Se.get(VS.CONFIG_PARAMS.THREADS)),Se.get(Zt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Vhe(),t||X1()}catch(t){console.error(t),ri.error(t),process.exit(1)}}a(sme,"main");function X1(){ri.suppressLogging(()=>{console.log(pI.magenta(`HarperDB ${qhe.version} successfully started`))}),ri.notify(rme)}a(X1,"started");async function ime(e=!0){z1=!e;try{Fi===void 0&&(Fi=Tf()),Fi.enterPM2Mode(),await J1(),Io.autoCastBoolean(Se.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Fi.startClusteringProcesses(),await Fi.startService(Zt.PROCESS_DESCRIPTORS.HDB),X1(),e&&process.exit(0)}catch(t){console.error(t),ri.error(t),process.exit(1)}}a(ime,"launch");function ome(){let e=wa.join(Se.get(Zt.CONFIG_PARAMS.ROOTPATH),Zt.LICENSE_KEY_DIR_NAME,Zt.LICENSE_FILE_NAME),t=wa.join(e,Zt.LICENSE_FILE_NAME),r=wa.join(e,Zt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=Q1(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Io.isEmpty(n)||Io.isEmpty(s))return;No.mkdirpSync(e),No.writeFileSync(r,n),No.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),ri.error(s)}}a(ome,"writeLicenseFromVars");Object.assign(eY,{launch:ime,main:sme,isHdbInstalled:Z1,startupLog:ame});async function Z1(){try{await No.stat(Io.getPropsFilePath()),await No.stat(Se.get(Zt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Io.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw ri.error(`Error checking for HDB install - ${e}`),e}return!0}a(Z1,"isHdbInstalled");function ame(e){let r=a(E=>E.padEnd(20),"pad"),n=`
112
- `;Se.get(De.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${Se.get(De.REPLICATION_HOSTNAME)}
113
- `),Se.get(De.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${Se.get(De.REPLICATION_URL)}
114
- `),n+=`${r("Worker Threads:")}${Se.get(De.THREADS_COUNT)}
115
- `,n+=`${r("Root Path:")}${Se.get(De.ROOTPATH)}
116
- `,Se.get(De.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=Se.get(De.THREADS_DEBUG_PORT)?`, TCP: ${Se.get(De.THREADS_DEBUG_PORT)}
111
+ Reindexing upgrade started for transaction logs`),Ro.notify("Reindexing upgrade started for transaction logs"),await XV(ZN,!0,e)),Ro.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(cE?", but errors occurred":"")}a(vfe,"reindexUpgrade");async function XV(e,t,r){let n=await Ui.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Ao.join(e,o.toString());if(o===".DS_Store")continue;let l=await Ui.readdir(c),d=l.length;for(let u=0;u<d;u++){let _=l[u];if(_!==".DS_Store"&&Ui.statSync(Ao.join(c,_)).isDirectory())try{await Bfe(o,_,t),Zr.info(`Reindexing started for ${o}.${_}`),Ro.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${_}`),await xfe(o,_,c,t,r),Zr.info(`Reindexing completed for ${o}.${_}`),Ro.notify(`Reindexing completed for ${o}.${_}`)}catch(E){cE=!0,E.schema_path=c,E.table_name=_,Ro.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Ro.error(E),Zr.error(E),console.error(E)}}}if(!cE)try{await Ui.rm(LS,{recursive:!0})}catch{}}a(XV,"processTables");async function Bfe(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Ao.join(LS,s);await Ui.ensureDir(LS),await Ui.writeFile(i,""),Zr=Mfe({level:"debug",formatters:{bindings(){}}},i)}a(Bfe,"initPinoLogger");var Hfe=20;async function xfe(e,t,r,n,s){let i;try{i=await Yn.openEnvironment(r,t,n)}catch(p){if(p.message==="MDB_INVALID: File is not an LMDB file"){Ro.notify(`${e}.${t} file is not from the old environment and has been skipped`),console.info(`${e}.${t} file is not from the old environment and has been skipped`),Zr.error(p);return}throw p}let o=Gfe(i.dbis),c=Yn.openDBI(i,o),l=Object.keys(i.dbis),d=Yn.statDBI(i,o);Zr.info(`Old environment stats: ${JSON.stringify(d)}`);let u=new Lfe.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});u.start(d.entryCount,0,{});let _=await Yn.createEnvironment(r,t,!1);Yn.createDBI(_,o,!1,!0);let E=[];try{for(let p of c.getRange({start:!1}))p.value={...p.value},E.push(p),n||e==="system"&&(t==="hdb_schema"&&(p.key=p.key.toString(),p.value.name=p.value.name.toString()),t==="hdb_table"&&(p.key=p.key.toString(),p.value.schema=p.value.schema.toString(),p.value.name=p.value.name.toString()),t==="hdb_attribute"&&(p.key=p.key.toString(),p.value.schema=p.value.schema.toString(),p.value.table=p.value.table.toString(),p.value.attribute=p.value.attribute.toString())),E.length>Hfe&&await f();await f()}catch(p){throw cE=!0,Zr.error(p),p}async function f(){let p,y=E.map(({value:B})=>B);n?p=await Promise.all(y.map(B=>kfe(_,B))):p=await wfe(_,o,l.filter(B=>B!=="__blob__"),y,!1);for(let B=0,x=E.length;B<x;B++){let{key:W,value:q}=E[B];Zr.info(`Record hash value: ${W} hash: ${o}`);let z;n?z=p[B]:z=p.written_hashes.indexOf(W)>-1,aE(z,!0),Ffe(_,o,q[o],n),Zr.info(`Insert success, written hashes: ${p.written_hashes}`),u.increment()}E=[],u.value/u.total*100%10===0&&Ro.notify(`${e}.${t} ${u.value}/${u.total} records inserted`),Zr.info(`${u.value}/${u.total} records inserted`)}a(f,"finishOutstanding"),u.stop();let h=Yn.statDBI(i,o),T=Yn.statDBI(_,o);if(Zr.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${T.entryCount}`),aE.deepStrictEqual(h.entryCount,T.entryCount),await Yn.closeEnvironment(i),await Yn.closeEnvironment(_),delete global.lmdb_map[`${e}.${t}`],s){let p=Ao.join(r,t),y=Ao.join(p,"data.mdb"),O=Ao.join(p,"lock.mdb");await Ui.unlink(y),await Ui.unlink(O),await Ui.rmdir(p),Zr.info(`Deleted old environment files from schema folder: ${y}, ${O}`)}let S=await Yn.openEnvironment(r,t),R=Yn.statDBI(S,o);Zr.info(`New stats: ${JSON.stringify(T)}. New stats after move: ${JSON.stringify(R)}`),aE.deepStrictEqual(R.entryCount,T.entryCount),await Yn.closeEnvironment(S),delete global.lmdb_map[`${e}.${t}`]}a(xfe,"processTable");async function kfe(e,t){Yn.initializeDBIs(e,Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Ia.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),Pfe.isEmpty(t.user_name)||e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(kfe,"insertTransaction");function Ffe(e,t,r,n){let i=e.dbis[t].get(r);aE.deepStrictEqual(typeof i,"object");let o;if(n){let c={[Ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[Ia.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE]:i.hash_values};o=Object.entries(c)}else o=Object.entries(i);for(let[c,l]of o)if(c!==t&&e.dbis[c]!==void 0&&!Dfe.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let d=0,u=l.length;d<u;d++){let _=l[d];ZV(e,c,_,r)}else ZV(e,c,l,r)}a(Ffe,"validateIndices");function ZV(e,t,r,n){try{let s=!1,i=Cfe.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||Zr.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),aE.deepStrictEqual(s,!0)}catch(s){cE=!0,Zr.error(s),console.error(s)}}a(ZV,"validateIndex");function Gfe(e){let t;for(let[r,n]of Object.entries(e))if(n.__dbi_defintion__.is_hash_attribute===!0){t=r;break}return t}a(Gfe,"getHashDBI")});var o1=b((iLe,i1)=>{"use strict";var MS=require("path"),wa=require("fs-extra"),qfe=JN(),Zc=V(),r1=wt(),eI=te(),ti=M(),US=J(),$fe=require("properties-reader"),Vfe=qs(),Yfe=J_(),Kfe=Vr(),sLe=require("util"),Wfe=Kfe.searchByValue,jfe=Yr(),Qfe=pp(),zfe=dt(),Jfe=t1(),n1=js(),Xfe=CS(),dE=new qfe("4.0.0"),s1=[],lE,uE;async function Zfe(){try{if(await Xfe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),lE){let t=US.changeExtension(lE,".bak");await wa.move(lE,t)}if(uE){let t=US.changeExtension(uE,".bak");await wa.move(uE,t)}await n1.generateKeys()}else console.log("Using existing certificates."),n1.updateConfigCert(lE,uE,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(Zfe,"generateNewKeys");async function eEe(){console.log("Updating HarperDB nodes."),Zc.info("Updating HarperDB nodes.");let e=[];try{let t=new Vfe(ti.SYSTEM_SCHEMA_NAME,ti.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await Wfe(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!zfe.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let u=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(u),u}let l={host:c.host,port:c.port};e.push(l);let d=[];for(let u=0,_=c.subscriptions.length;u<_;u++){let E=c.subscriptions[u],f=E.channel.split(":");d.push({schema:f[0],table:f[1],publish:E.publish,subscribe:E.subscribe})}n.push({name:c.name,subscriptions:d,system_info:{hdb_version:ti.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(US.isEmptyOrZeroLength(n))return;let s=new Yfe(ti.SYSTEM_SCHEMA_NAME,ti.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await jfe.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{Qfe.setRoutes({server:"hub",routes:e})}catch(t){throw console.error("There was a problem setting the clustering routes. Please check the log for details."),t}}a(eEe,"updateNodes");async function tEe(){let e=eI.get(ti.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(MS.join("config","settings.js"))){Zc.info("pre 4.0.0 settings.js file not found, skipping settings file update");return}let t="Updating settings file for version 4.0.0";console.log(t),Zc.info(t);let r=MS.dirname(e),n=eI.get(ti.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=MS.join(n,"backup","4_0_0_upgrade_settings.bak"),i=MS.join(n,ti.HDB_CONFIG_FILE);try{Zc.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),wa.copySync(e,s)}catch(_){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),_}try{Zc.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),Zc.info("Updating env variables with new settings values");let _=r1.initOldConfig(e);lE=_[ti.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],uE=_[ti.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],r1.createConfigFile(_)}catch(_){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),_}let o=US.getPropsFilePath();wa.accessSync(o,wa.constants.F_OK|wa.constants.R_OK);let l=$fe(o).get(ti.HDB_SETTINGS_NAMES.INSTALL_USER),d=`settings_path = ${i}
112
+ install_user = ${l}`;try{wa.writeFileSync(o,d)}catch(_){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),_}try{eI.initSync(!0)}catch(_){throw console.error("Unable to initialize new properties. Please check the log for details."),_}let u="New settings file for 4.0.0 upgrade successfully created.";try{wa.removeSync(r),console.log(u),Zc.info(u)}catch(_){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),_}}a(tEe,"updateSettingsFile_4_0_0");dE.async_functions.push(tEe);dE.async_functions.push(Zfe);dE.async_functions.push(Jfe);dE.async_functions.push(eEe);s1.push(dE);i1.exports=s1});var tI=b((aLe,u1)=>{"use strict";var el=J(),rEe=M(),a1=V(),{DATA_VERSION:nEe,UPGRADE_VERSION:sEe}=rEe.UPGRADE_JSON_FIELD_NAMES_ENUM,c1=zV(),vS=o1(),tl=new Map;c1&&c1.forEach(e=>{tl.set(e.version,e)});vS&&vS.forEach(e=>{tl.set(e.version,e)});vS&&vS.forEach(e=>{tl.set(e.version,e)});function iEe(){return[...tl.keys()].sort(el.compareVersions)}a(iEe,"getSortedVersions");function l1(e){let t=e[nEe],r=e[sEe];return el.isEmptyOrZeroLength(t)||el.isEmptyOrZeroLength(r)?(a1.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),a1.error("There was an error when trying to evaluate the version information for your instance. Trying to start the server anyways but it may fail. If you continue to have this problem, please contact support@harperdb.io."),[]):[...tl.keys()].sort(el.compareVersions).filter(function(n){return el.compareVersions(n,t)>0&&el.compareVersions(n,r)<=0})}a(l1,"getVersionsForUpgrade");function oEe(e){return l1(e).length>0}a(oEe,"hasUpgradesRequired");function aEe(e){return el.isEmptyOrZeroLength(e)?null:tl.has(e)?tl.get(e):null}a(aEe,"getDirectiveByVersion");u1.exports={getSortedVersions:iEe,getDirectiveByVersion:aEe,getVersionsForUpgrade:l1,hasUpgradesRequired:oEe}});var HS=b((lLe,h1)=>{"use strict";var cEe=require("util"),rI=require("chalk"),lEe=require("os"),_1=Yr(),uEe=Vr(),Kn=M(),f1=xV(),sI=bR(),{UpgradeObject:d1}=GV(),{forceDowngradePrompt:dEe}=CS(),_Ee=Ic(),BS=V(),Zu=J(),iI=as(),fEe=(Le(),oe(lt)),EEe=tI(),hEe=cEe.promisify(iI.setSchemaDataToGlobal),mEe=uEe.searchByValue,pEe="info_id",SEe="2.9.9",TEe="3.0.0";async function gEe(e){let t=new f1.HdbInfoInsertObject(1,e,e),r=new sI.InsertObject(Kn.OPERATIONS_ENUM.INSERT,Kn.SYSTEM_SCHEMA_NAME,Kn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Kn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return iI.setSchemaDataToGlobal(),_1.insert(r)}a(gEe,"insertHdbInstallInfo");async function nI(e){let t,r=await E1(),n=new Map([[0,{}]]);for(let c of r)n.set(c.info_id,c);let i=Math.max.apply(null,[...n.keys()])+1;t=new f1.HdbInfoInsertObject(i,e,e);let o=new sI.InsertObject(Kn.OPERATIONS_ENUM.INSERT,Kn.SYSTEM_SCHEMA_NAME,Kn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Kn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return await hEe(),_1.insert(o)}a(nI,"insertHdbUpgradeInfo");async function E1(){let e=new sI.NoSQLSeachObject(Kn.SYSTEM_SCHEMA_NAME,Kn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,pEe,Kn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await mEe(e))}catch(r){console.error(r)}return t}a(E1,"getAllHdbInfoRecords");async function REe(){let e=await E1();if(e.length===0)return;let t,r=new Map;for(let s of e)r.set(s.info_id,s);let n=Math.max.apply(null,[...r.keys()]);return t=r.get(n),t}a(REe,"getLatestHdbInfoRecord");async function AEe(){BS.info("Checking if HDB software has been updated");try{let e=_Ee.version(),t=await REe(),r;if(Zu.isEmpty(t))r=SEe;else if(r=t.data_version_num,Zu.compareVersions(r.toString(),e.toString())>0){if(!Zu.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(rI.yellow(`This instance's data was last run on version ${r}`)),console.error(rI.red(`You have installed a version lower than the version that your data was created on or was upgraded to. This may cause issues and is currently not supported.${lEe.EOL}${Kn.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Zu.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(rI.yellow(`This instance's data was last run on version ${r}`)),await dEe(new d1(r,e))?await nI(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(iI.setSchemaDataToGlobal(),bEe(r),e.toString()===r.toString())return;let n=new d1(r,e);if(EEe.hasUpgradesRequired(n))return n;Zu.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await nI(n.upgrade_version),BS.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw BS.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),BS.fatal(e),e}}a(AEe,"getVersionUpdateInfo");function bEe(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${Kn.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in fEe.databases.system))throw console.log(t),new Error(t);if(!Zu.isEmpty(e)&&e<TEe)throw console.log(t),new Error(t)}a(bEe,"checkIfInstallIsSupported");h1.exports={insertHdbInstallInfo:gEe,insertHdbUpgradeInfo:nI,getVersionUpdateInfo:AEe}});var T1=b((dLe,S1)=>{"use strict";var xS=require("joi"),{boolean:yEe,string:oI,number:OEe}=xS.types(),m1=require("fs-extra"),_E=M(),p1=require("path"),NEe=ut();S1.exports=IEe;function IEe(e){let t=oI.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=xS.object({[_E.INSTALL_PROMPTS.ROOTPATH]:xS.custom(wEe),[_E.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:xS.alternatives([OEe.min(0),oI]).allow("null",null),[_E.INSTALL_PROMPTS.TC_AGREEMENT]:oI.valid("yes","YES","Yes"),[_E.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[_E.INSTALL_PROMPTS.CLUSTERING_ENABLED]:yEe});return NEe.validateBySchema(e,r)}a(IEe,"installValidator");function wEe(e,t){if(m1.existsSync(p1.join(e,"system/hdb_user/data.mdb"))||m1.existsSync(p1.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(wEe,"validateRootAvailable")});var R1=b((fLe,g1)=>{"use strict";var{mkdirpSync:CEe,copySync:DEe}=require("fs-extra"),Ca=require("path"),ed=M(),cI=V(),PEe=Pn(),aI=ji(),LEe=gt();g1.exports=MEe;async function MEe(e){cI.trace("Mounting HarperDB"),rl(e),rl(Ca.join(e,"backup")),rl(Ca.join(e,"keys")),rl(Ca.join(e,"keys",ed.LICENSE_FILE_NAME)),rl(Ca.join(e,"log")),rl(Ca.join(e,"database")),rl(Ca.join(e,"components")),DEe(Ca.resolve(ed.PACKAGE_ROOT,"./utility/install/README.md"),Ca.join(e,"README.md")),await UEe()}a(MEe,"mountHdb");async function UEe(){let e=ql(),t=Object.keys(aI);for(let r=0;r<t.length;r++){let n=t[r],s=aI[n].hash_attribute;try{LEe.initSystemSchemaPaths(ed.SYSTEM_SCHEMA_NAME,n);let i=new e(ed.SYSTEM_SCHEMA_NAME,n,s);i.attributes=aI[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,await PEe.createTable(n,i)}catch(i){throw cI.error(`issue creating environment for ${ed.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(UEe,"createLMDBTables");function rl(e){CEe(e,{mode:ed.HDB_FILE_PERMISSIONS}),cI.info(`Directory ${e} created`)}a(rl,"makeDirectory")});var B1=b((pLe,v1)=>{"use strict";var uI=require("os"),N1=require("inquirer"),Cs=require("fs-extra"),vEe=require("properties-reader"),sl=require("chalk"),Bi=require("path"),BEe=require("human-readable-ids").hri,HEe=require("ora"),xEe=require("yaml"),lr=V(),Da=te(),fE=J(),FS=qa(),I1=HS(),w1=Ic(),le=M(),{CONFIG_PARAM_MAP:hLe,CONFIG_PARAMS:Mt}=le,kEe=T1(),FEe=R1(),dI=wt(),GEe=vn(),qEe=Jm(),$Ee=YN(),VEe=as(),YEe=require("util").promisify,KEe=YEe(VEe.setSchemaDataToGlobal),A1=js(),nl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),Hr=a(e=>sl.magenta.bold(e),"HDB_PROMPT_MSG"),WEe="https://harperdb.io/legal/end-user-license-agreement",Pa=uI.EOL,bo="",jEe="yes",b1="Starting HarperDB install...",y1="HarperDB installation was successful.",O1="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",QEe="An out of date version of HarperDB is already installed.",lI="It appears that HarperDB is already installed. Exiting install...",zEe="Aborting install",mLe=new RegExp(/^([0-9]{1,4}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5])$/),JEe=new RegExp(/^[^\s.,*>]+$/),XEe=uI.homedir(),ZEe=Bi.join(XEe,le.HDB_ROOT_DIR_NAME),ehe="HDB_ADMIN",the="CLUSTER_USER",rhe="dev",nhe="localhost",kS={[Mt.HTTP_CORS]:!0,[Mt.HTTP_CORSACCESSLIST]:["*"],[Mt.HTTP_PORT]:9926,[Mt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Mt.THREADS_COUNT]:1,[Mt.THREADS_DEBUG]:!0,[Mt.LOGGING_STDSTREAMS]:!0,[Mt.LOGGING_LEVEL]:"info",[Mt.OPERATIONSAPI_NETWORK_PORT]:9925,[Mt.LOCALSTUDIO_ENABLED]:!0},Br={DESTINATION:"Please enter a destination for HarperDB:",HDB_USERNAME:"Please enter a username for the administrative user:",HDB_PASS:"Please enter a password for the administrative user:",NODE_NAME:"Please enter a unique name for this node:",CLUSTER_USERNAME:"Please enter a username for the CLUSTER_USER:",CLUSTER_PASS:"Please enter a password for the CLUSTER_USER:",DEFAULTS_MODE:"Default Config - dev (easy access/debugging) or prod (security/performance): (dev/prod)",REPLICATION_HOSTNAME:"Please enter the hostname for this server:"},La=FS([le.INSTALL_PROMPTS.HDB_CONFIG]),vi,C1=!1,D1=!1,P1=!1;v1.exports={install:L1,updateConfigEnv:Ehe,setIgnoreExisting:hhe};L1.createSuperUser=U1;async function L1(){console.log(Hr(Pa+b1+Pa)),lr.notify(b1);let e;La[le.INSTALL_PROMPTS.HDB_CONFIG]&&(e=she());let t=ohe();Object.assign(t,e),t[le.INSTALL_PROMPTS.TC_AGREEMENT]&&t[le.INSTALL_PROMPTS.ROOTPATH]&&t[le.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[le.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&(P1=!0,t[le.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=kEe(t);if(r)throw r.message;await ahe(),await che(t);let n=await ihe(t);vi=n[le.INSTALL_PROMPTS.ROOTPATH],La[le.INSTALL_PROMPTS.HDB_CONFIG]&&Bi.dirname(La[le.INSTALL_PROMPTS.HDB_CONFIG])===vi&&(C1=!0),!La[le.INSTALL_PROMPTS.HDB_CONFIG]&&await Cs.pathExists(Bi.join(vi,le.HDB_CONFIG_FILE))&&(console.error(lI),process.exit());let s=HEe({prefixText:Hr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),fE.isEmpty(vi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");Da.setHdbBasePath(vi),await FEe(vi),await lhe(),await uhe(n),lr.initLogSettings(!0),await U1(n),await _he(n),await A1.updateConfigCert(),await A1.generateCertsKeys(),await fhe(),$Ee(),s.stop(),console.log(Hr(Pa+y1+Pa)),lr.notify(y1)}a(L1,"install");function she(){let e=xEe.parseDocument(Cs.readFileSync(La[le.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=dI.flattenConfig(e.toJSON());return t[le.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[le.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(she,"getConfigFromFile");async function ihe(e){lr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:nl,when:yo(e[le.INSTALL_PROMPTS.ROOTPATH],Br.DESTINATION),name:le.INSTALL_PROMPTS.ROOTPATH,prefix:bo,default:ZEe,validate:async s=>ws(s)?ws(s):await Cs.pathExists(Bi.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,message:Hr(Br.DESTINATION)},{type:"input",transformer:nl,when:yo(e[le.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Br.HDB_USERNAME),name:le.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:bo,default:ehe,validate:s=>ws(s)?ws(s):(t=s,!0),message:Hr(Br.HDB_USERNAME)},{type:"password",when:yo(e[le.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Br.HDB_PASS),name:le.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:bo,validate:s=>ws(s)?ws(s):!0,message:Hr(Br.HDB_PASS)},{type:"input",transformer:nl,when:yo(e[le.INSTALL_PROMPTS.DEFAULTS_MODE],Br.DEFAULTS_MODE),name:le.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:bo,default:rhe,validate:s=>ws(s)?ws(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,message:Hr(Br.DEFAULTS_MODE)}];if(P1||r.push({type:"input",name:le.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:nl,when:yo(e[le.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Br.REPLICATION_HOSTNAME),prefix:bo,default:nhe,message:Hr(Br.REPLICATION_HOSTNAME)}),fE.autoCastBoolean(e[le.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:nl,when:yo(e[le.INSTALL_PROMPTS.CLUSTERING_NODENAME],Br.NODE_NAME),name:le.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:bo,default:BEe.random(),validate:i=>JEe.test(i)?!0:"Invalid node name, must not contain ., * or >",message:Hr(Br.NODE_NAME)},{type:"input",transformer:nl,when:yo(e[le.INSTALL_PROMPTS.CLUSTERING_USER],Br.CLUSTER_USERNAME),name:le.INSTALL_PROMPTS.CLUSTERING_USER,prefix:bo,default:the,validate:i=>ws(i)?ws(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,message:Hr(Br.CLUSTER_USERNAME)},{type:"password",when:yo(e[le.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Br.CLUSTER_PASS),name:le.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:bo,validate:i=>ws(i)?ws(i):!0,message:Hr(Br.CLUSTER_PASS)}];r.push(...s)}let n=await N1.prompt(r);if(Object.keys(n).length===0)return e;for(let s in n)e[s]===void 0&&(e[s]=n[s]);return e}a(ihe,"installPrompts");function yo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${Hr(t)} ${sl.gray("[hidden]")}`),lr.trace(`${Hr(t)} [hidden]`)):(console.log(`${Hr(t)} ${e}`),lr.trace(`${Hr(t)} ${e}`)),!1):!0}a(yo,"displayCmdEnvVar");function ws(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(ws,"checkForEmptyValue");function ohe(){let e=Object.keys(le.INSTALL_PROMPTS),t=FS(e),r=FS(Object.keys(le.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=le.CONFIG_PARAM_MAP[s.toLowerCase()];t[s]?i===void 0?n[s]=t[s]:n[i.toUpperCase()]=t[s]:i!==void 0&&r[i.toLowerCase()]&&(n[s]=r[i.toLowerCase()])}return n}a(ohe,"checkForPromptOverride");async function ahe(){lr.trace("Checking for existing install.");let e=fE.getPropsFilePath(),t=await Cs.pathExists(e),r;if(t){lr.trace(`Install found an existing boot prop file at:${e}`);let n=vEe(e),s=dI.getConfigValue(le.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(le.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Cs.pathExists(s)}if(!t&&fE.noBootFile()&&(r=!0),r&&!D1){if(lr.trace(`Install found existing HDB config at:${e}`),await I1.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${w1.version()}. Exiting install...`;console.log(Pa+sl.magenta.bold(QEe)),console.log(sl.magenta.bold(s)),lr.error(s)}else console.log(Pa+sl.magenta.bold(lI)),lr.error(lI);process.exit(0)}}a(ahe,"checkForExistingInstall");async function che(e){lr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${WEe}${Pa}and can be viewed by typing or copying and pasting the URL into your web browser.${Pa}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:bo,transformer:nl,when:yo(e[le.INSTALL_PROMPTS.TC_AGREEMENT],t),name:le.INSTALL_PROMPTS.TC_AGREEMENT,message:Hr(t),validate:s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:sl.yellow("Please enter 'yes' or 'no'")},n=await N1.prompt([r]);n[le.INSTALL_PROMPTS.TC_AGREEMENT]&&n[le.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==jEe&&(console.log(sl.yellow(O1)),lr.error(O1),process.exit(0))}a(che,"termsAgreement");async function lhe(){let e=Bi.join(vi,le.HDB_CONFIG_FILE),t;try{t=uI.userInfo().username}catch{t=process.env.USERNAME||process.env.USER||process.env.LOGNAME||process.env.LNAME||process.env.SUDO_USER}if(t){let r=`settings_path = ${e}
113
+ install_user = ${t}`,n=fE.getHomeDir(),s=Bi.join(n,le.HDB_HOME_DIR_NAME),i=Bi.join(s,le.LICENSE_KEY_DIR_NAME);try{Cs.mkdirpSync(s,{mode:le.HDB_FILE_PERMISSIONS}),Cs.mkdirpSync(i,{mode:le.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${le.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Bi.join(s,le.BOOT_PROPS_FILE_NAME);try{await Cs.writeFile(o,r)}catch(c){throw lr.error(`There was an error creating the boot file at path: ${o}`),c}Da.setProperty(le.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),Da.setProperty(le.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),Da.setProperty(Da.BOOT_PROPS_FILE_PATH,o)}}a(lhe,"createBootPropertiesFile");async function uhe(e){lr.trace("Creating HarperDB config file");let t=FS(Object.keys(le.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[le.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in kS){if(r===Mt.HTTP_PORT&&t[Mt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??kS[r],t[Mt.HTTP_SECUREPORT]=null;continue}else if(r===Mt.HTTP_PORT)continue;if(r===Mt.OPERATIONSAPI_NETWORK_PORT&&t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??kS[r],t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Mt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=kS[r])}}else t[Mt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Mt.HTTP_PORT.toLowerCase()]&&(t[Mt.HTTP_SECUREPORT]=null);try{La[le.INSTALL_PROMPTS.HDB_CONFIG]||dI.createConfigFile(t),Da.initSync()}catch(r){dhe(r)}}a(uhe,"createConfigFile");function dhe(e){lr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(zEe);let t=Bi.resolve(Da.get(Da.BOOT_PROPS_FILE_PATH),"../");t&&Cs.removeSync(t),vi&&(C1?Cs.readdirSync(vi,{withFileTypes:!0}).forEach(n=>{let s=Bi.join(n.path,n.name);s!==La[le.INSTALL_PROMPTS.HDB_CONFIG]&&Cs.removeSync(s)}):Cs.removeSync(vi)),process.exit(1)}a(dhe,"rollbackInstall");async function M1(e,t){lr.trace("Creating admin user"),await KEe();let r;try{r=await qEe.addRole(e)}catch(n){if(n.message.includes("already exists"))t=void 0;else throw n.message+="Error creating role",n}if(t)try{t.role=r.role,await GEe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(M1,"createAdminUser");async function U1(e){lr.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[le.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[le.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await M1(t,r),delete e[le.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[le.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(U1,"createSuperUser");async function _he(e){lr.trace("Creating Cluster user.");let t;e[le.INSTALL_PROMPTS.CLUSTERING_USER]&&e[le.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[le.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[le.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await M1({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[le.INSTALL_PROMPTS.CLUSTERING_USER],delete e[le.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(_he,"createClusterUser");async function fhe(){let e=w1.version();if(e)await I1.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(fhe,"insertHdbVersionInfo");function Ehe(e){La[le.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Ehe,"updateConfigEnv");function hhe(e){D1=e}a(hhe,"setIgnoreExisting")});var k1=b((TLe,x1)=>{"use strict";var _I=J(),Wn=V(),H1=tI();x1.exports={processDirectives:mhe};async function mhe(e){console.log("Starting upgrade process...");let t=H1.getVersionsForUpgrade(e),r=The(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;Wn.notify(c),console.log(c);let l=[],d=[];try{l=phe(o.sync_functions)}catch(u){throw Wn.error(`Error while running an upgrade script for ${o.version}`),u}try{d=await She(o.async_functions)}catch(u){throw Wn.error(`Error while running an upgrade script for ${o.version}`),u}n.push(...l,...d)}return n}a(mhe,"processDirectives");function phe(e){if(_I.isEmptyOrZeroLength(e))return Wn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Wn.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(Wn.info(`Running function ${r.name}`),!(r instanceof Function)){Wn.info("Variable being processed is not a function");continue}let n=r();Wn.info(n),t.push(n)}return t}a(phe,"runSyncFunctions");async function She(e){if(_I.isEmptyOrZeroLength(e))return Wn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Wn.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(Wn.info(`Running function ${s.name}`),!(s instanceof Function)){Wn.info("Variable being processed is not a function");continue}let i=await s();Wn.info(i),t.push(i)}return t}a(She,"runAsyncFunctions");function The(e){if(_I.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=H1.getDirectiveByVersion(r);n&&t.push(n)}return t}a(The,"getUpgradeDirectivesToInstall")});var K1=b((RLe,Y1)=>{"use strict";var GS=te();GS.initSync();var $1=require("chalk"),F1=require("fs-extra"),No=V(),Oo=M(),G1=Ic(),ghe=k1(),fI=J(),V1=HS(),Rhe=CS(),q1=fg(),Ahe=as(),bhe=require("util").promisify,yhe=bhe(Ahe.setSchemaDataToGlobal),EI,{UPGRADE_VERSION:qS}=Oo.UPGRADE_JSON_FIELD_NAMES_ENUM;Y1.exports={upgrade:Ohe};async function Ohe(e){await yhe(),EI===void 0&&(EI=Tf()),F1.existsSync(GS.get(GS.BOOT_PROPS_FILE_PATH))||(EE("The hdb_boot_properties file was not found. Please install HDB.",Oo.LOG_LEVELS.ERROR),process.exit(1)),F1.existsSync(GS.get(Oo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(EE("The hdb settings file was not found. Please make sure HDB is installed.",Oo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await V1.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),EE(`This version of HarperDB is ${G1.version()}`,Oo.LOG_LEVELS.INFO);let r=t[qS]?t[qS]:G1.version();r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${Oo.HDB_SUPPORT_ADDRESS}`),No.notify("Missing new version field from upgrade info object"),process.exit(1)),await Nhe();let n,s=0;try{n=await Rhe.forceUpdatePrompt(t)}catch(i){No.error("There was an error when prompting user about upgrade."),No.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),No.info(`Starting upgrade to version ${r}`),await Ihe(t),EE(`HarperDB was successfully upgraded to version ${t[qS]}`,Oo.LOG_LEVELS.INFO)}a(Ohe,"upgrade");async function Nhe(){let e=!1,t=await q1.findPs(Oo.HDB_PROC_NAME);if(fI.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await q1.findPs("hdb_express");fI.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await EI.list();fI.isEmptyOrZeroLength(r)||(e=!0)}if(e){let r="HarperDB is running, please stop all HarperDB services with 'harperdb stop' and run the upgrade command again.";console.log($1.red(r)),No.error(r),process.exit(1)}}a(Nhe,"checkIfRunning");async function Ihe(e){try{await ghe.processDirectives(e)}catch(t){throw EE("There was an error during the data upgrade. Please check the logs.",Oo.LOG_LEVELS.ERROR),t}try{await V1.insertHdbUpgradeInfo(e[qS])}catch(t){No.error("Error updating the 'hdb_info' system table."),No.error(t)}}a(Ihe,"runUpgrade");function EE(e,t=void 0){t||(t=No.info),No[t](e),console.log($1.magenta(e))}a(EE,"printToLogAndConsole")});var J1=b((bLe,z1)=>{"use strict";var{promises:mI,createReadStream:whe,createWriteStream:Che}=require("fs"),{createGzip:Dhe}=require("zlib"),{promisify:Phe}=require("util"),{pipeline:Lhe}=require("stream"),Mhe=Phe(Lhe),Uhe=require("path"),ol=te();ol.initSync();var il=V(),{CONFIG_PARAMS:hE,ITC_EVENT_TYPES:vhe}=M(),{onMessageFromWorkers:Bhe}=it(),Hhe=6e4,xhe="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",khe="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",hI,j1;z1.exports=Q1;Bhe(e=>{e.type===vhe.RESTART&&(ol.initSync(!0),clearInterval(j1),ol.get(hE.LOGGING_ROTATION_ENABLED)&&Q1())});async function Q1(){try{let e=il.getLogFilePath(),t=ol.get(hE.LOGGING_ROTATION_MAXSIZE),r=ol.get(hE.LOGGING_ROTATION_INTERVAL);if(!t&&!r){il.error(xhe);return}let n=ol.get(hE.LOGGING_ROTATION_PATH);if(!n){il.error(khe);return}let s;if(t){let o=t.slice(-1),c=t.slice(0,-1);o==="G"?s=c*1e9:o==="M"?s=c*1e6:s=c*1e3}let i;if(r){let o=r.slice(-1),c=r.slice(0,-1);o==="D"?i=c*1440:o==="H"?i=c*60:i=c}hI=Date.now()/6e4,il.trace("Log rotate enabled, maxSize:",t,"interval:",r),j1=setInterval(async()=>{if(s){let o;o=await mI.stat(e),o.size>=s&&await W1(e,n)}i&&Date.now()/6e4-hI>=i&&(await W1(e,n),hI=Date.now()/6e4)},Hhe).unref()}catch(e){il.error(e)}}a(Q1,"logRotator");async function W1(e,t){let r=ol.get(hE.LOGGING_ROTATION_COMPRESS),n=Uhe.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.${r?"log.gz":"log"}`);r?(await Mhe(whe(e),Dhe(),Che(n)),await mI.unlink(e)):await mI.rename(e,n),il.closeLogFile(),il.notify(`hdb.log rotated, old log moved to ${n}`)}a(W1,"moveLogFile")});var iY=b(sY=>{"use strict";var me=te();me.initSync();var OLe=Lu(),Zt=M(),jn=V(),Io=require("fs-extra"),wo=require("path"),Fhe=require("systeminformation"),Ghe=YN(),{install:qhe}=B1(),pI=require("chalk"),$he=Kl(),Co=J(),SI=wt(),Z1=qa(),X1=Ap(),Vhe=K1(),Yhe=J1(),{compactOnStart:Khe}=(aO(),oe(oO)),Whe=require("minimist"),jhe=js(),{PACKAGE_ROOT:Qhe,CONFIG_PARAMS:Ne}=M(),{startHTTPThreads:zhe,startSocketServer:NLe,mostIdleRouting:ILe,remoteAffinityRouting:wLe}=(TI(),oe(oY)),Jhe=HS(),{isMainThread:Xhe}=require("worker_threads"),CLe=ji(),DLe=fi(),PLe=TA(),LLe=ql(),$S=M(),Hi,td,eY=!1,Zhe="Upgrade complete. Starting HarperDB.",eme="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",tme="HarperDB not found, starting install process.",rme="There was an error during install, check install_log.log for more details. Exiting.",nme="HarperDB successfully started.";function sme(){if(!eY){let e=a(()=>{Io.removeSync(wo.join(me.get(Zt.CONFIG_PARAMS.ROOTPATH),Zt.HDB_PID_FILE)),process.exit(0)},"remove_hdb_pid");process.on("exit",()=>{e()}),process.on("SIGINT",()=>{e()}),process.on("SIGQUIT",()=>{e()}),process.on("SIGTERM",()=>{e()})}}a(sme,"addExitListeners");async function tY(e=!1,t=!1){if(console.log(pI.magenta("Starting HarperDB...")),jn.suppressLogging?.(()=>{console.log(pI.magenta(""+Io.readFileSync(wo.join(Qhe,"utility/install/ascii_logo.txt"))))}),await nY()===!1){console.log(tme);try{await qhe()}catch(o){console.error(rme,o),jn.error(o),process.exit(1)}}if(!e){let o=Z1(Object.keys(Zt.CONFIG_PARAM_MAP),!0);!Co.isEmpty(o)&&!Co.isEmptyOrZeroLength(Object.keys(o))&&SI.updateConfigValue(void 0,void 0,o,!0,!0)}let r,n=td?.service==="clustering";td?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));try{let o=Number.parseInt(await Io.readFile(wo.join(me.get(Zt.CONFIG_PARAMS.ROOTPATH),Zt.HDB_PID_FILE),"utf8")),c=await Fhe.processes();for(let l of c.list)if(l.pid===o){n?r=!0:console.log("HarperDB appears to be already running.");break}}catch{}Hi===void 0&&(Hi=Tf()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),me.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await X1.generateNatsConfig(),await Hi.startClusteringProcesses(!0),process.exit()),sme(),await Io.writeFile(wo.join(me.get($S.CONFIG_PARAMS.ROOTPATH),$S.HDB_PID_FILE),`${process.pid}`),jn.info("HarperDB PID",process.pid);let s;try{let o=await Jhe.getVersionUpdateInfo();o!==void 0&&(s=o[Zt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Vhe.upgrade(o),console.log(Zhe))}catch(o){s?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${s}. Exiting HarperDB.`,o),jn.error(o)):(console.error(eme,o),jn.error(o)),process.exit(1)}Ghe(),ame(),await jhe.reviewSelfSignedCert(),Co.autoCastBoolean(me.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&Xhe&&await X1.generateNatsConfig(t)}a(tY,"initialize");async function ime(e=!1){try{td=Whe(process.argv),td.ROOTPATH&&SI.updateConfigObject("settings_path",wo.join(td.ROOTPATH,Zt.HDB_CONFIG_FILE)),await tY(e,!0),me.get(Zt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Khe();let t=process.env.IS_SCRIPTED_SERVICE&&!td.service;Co.autoCastBoolean(me.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Hi.startClusteringProcesses(),await Hi.startClusteringThreads()),await zhe(process.env.DEV_MODE?1:me.get($S.CONFIG_PARAMS.THREADS_COUNT)??me.get($S.CONFIG_PARAMS.THREADS)),me.get(Zt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Yhe(),t||rY()}catch(t){console.error(t),jn.error(t),process.exit(1)}}a(ime,"main");function rY(){jn.suppressLogging(()=>{console.log(pI.magenta(`HarperDB ${$he.version} successfully started`))}),jn.notify(nme)}a(rY,"started");async function ome(e=!0){eY=!e;try{Hi===void 0&&(Hi=Tf()),Hi.enterPM2Mode(),await tY(),Co.autoCastBoolean(me.get(Zt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Hi.startClusteringProcesses(),await Hi.startService(Zt.PROCESS_DESCRIPTORS.HDB),rY(),e&&process.exit(0)}catch(t){console.error(t),jn.error(t),process.exit(1)}}a(ome,"launch");function ame(){let e=wo.join(me.get(Zt.CONFIG_PARAMS.ROOTPATH),Zt.LICENSE_KEY_DIR_NAME,Zt.LICENSE_FILE_NAME),t=wo.join(e,Zt.LICENSE_FILE_NAME),r=wo.join(e,Zt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=Z1(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Co.isEmpty(n)||Co.isEmpty(s))return;Io.mkdirpSync(e),Io.writeFileSync(r,n),Io.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),jn.error(s)}}a(ame,"writeLicenseFromVars");Object.assign(sY,{launch:ome,main:ime,isHdbInstalled:nY,startupLog:cme});async function nY(){try{await Io.stat(Co.getPropsFilePath()),await Io.stat(me.get(Zt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Co.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw jn.error(`Error checking for HDB install - ${e}`),e}return!0}a(nY,"isHdbInstalled");function cme(e){let r=a(f=>f.padEnd(20),"pad"),n=`
114
+ `;me.get(Ne.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${me.get(Ne.REPLICATION_HOSTNAME)}
115
+ `),me.get(Ne.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${me.get(Ne.REPLICATION_URL)}
116
+ `),n+=`${r("Worker Threads:")}${me.get(Ne.THREADS_COUNT)}
117
+ `,n+=`${r("Root Path:")}${me.get(Ne.ROOTPATH)}
118
+ `,me.get(Ne.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=me.get(Ne.THREADS_DEBUG_PORT)?`, TCP: ${me.get(Ne.THREADS_DEBUG_PORT)}
117
119
  `:`
118
- `),n+=`${r("Logging:")}level: ${Se.get(De.LOGGING_LEVEL)}, location: ${Se.get(De.LOGGING_ROOT)}
119
- `,n+=r("Default:"),n+=Se.get(De.HTTP_PORT)?`HTTP (and WS): ${Se.get(De.HTTP_PORT)}, `:"",n+=Se.get(De.HTTP_SECUREPORT)?`HTTPS (and WS): ${Se.get(De.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${Se.get(De.HTTP_CORS)?`enabled for ${Se.get(De.HTTP_CORSACCESSLIST)}`:"disabled"}
120
- `,n+=r("Operations API:"),n+=Se.get(De.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${Se.get(De.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=Se.get(De.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${Se.get(De.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${Se.get(De.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${Se.get(De.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${Se.get(De.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
121
- `,n+=r("MQTT:"),n+=Se.get(De.MQTT_NETWORK_PORT)?`TCP: ${Se.get(De.MQTT_NETWORK_PORT)}, `:"",n+=Se.get(De.MQTT_NETWORK_SECUREPORT)?`TLS: ${Se.get(De.MQTT_NETWORK_SECUREPORT)}`:"",n+=Se.get(De.MQTT_WEBSOCKET)&&Se.get(De.HTTP_PORT)?`, WS: ${Se.get(De.HTTP_PORT)}`:"",n+=Se.get(De.MQTT_WEBSOCKET)&&Se.get(De.HTTP_SECUREPORT)?`, WSS: ${Se.get(De.HTTP_SECUREPORT)}
120
+ `);let s=wo.join(me.get(Ne.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${me.get(Ne.LOGGING_LEVEL)}, location: ${s+(me.get(Ne.LOGGING_STDSTREAMS)?", stdout/err":"")}
121
+ `,n+=r("Default:"),n+=me.get(Ne.HTTP_PORT)?`HTTP (and WS): ${me.get(Ne.HTTP_PORT)}, `:"",n+=me.get(Ne.HTTP_SECUREPORT)?`HTTPS (and WS): ${me.get(Ne.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${me.get(Ne.HTTP_CORS)?`enabled for ${me.get(Ne.HTTP_CORSACCESSLIST)}`:"disabled"}
122
+ `,n+=r("Operations API:"),n+=me.get(Ne.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${me.get(Ne.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=me.get(Ne.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${me.get(Ne.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${me.get(Ne.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${me.get(Ne.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${me.get(Ne.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
123
+ `,n+=r("MQTT:"),n+=me.get(Ne.MQTT_NETWORK_PORT)?`TCP: ${me.get(Ne.MQTT_NETWORK_PORT)}, `:"",n+=me.get(Ne.MQTT_NETWORK_SECUREPORT)?`TLS: ${me.get(Ne.MQTT_NETWORK_SECUREPORT)}`:"",n+=me.get(Ne.MQTT_WEBSOCKET)&&me.get(Ne.HTTP_PORT)?`, WS: ${me.get(Ne.HTTP_PORT)}`:"",n+=me.get(Ne.MQTT_WEBSOCKET)&&me.get(Ne.HTTP_SECUREPORT)?`, WSS: ${me.get(Ne.HTTP_SECUREPORT)}
122
124
  `:`
123
- `;let s=Se.get(De.REPLICATION_PORT)??Se.get(De.OPERATIONSAPI_NETWORK_PORT),i=Se.get(De.REPLICATION_SECUREPORT)??Se.get(De.OPERATIONSAPI_NETWORK_SECUREPORT),o=r("Replication:");o+=s?`WS: ${s}, `:"",o+=i?`WSS: ${i} `:"",n+=`${o.slice(0,-2)}
124
- `;let c=[],l=SI.getConfigObj();for(let E in l)l[E].package&&c.push(E);let d={},u=`${r("REST:")}`;for(let[E,f]of e)for(let h of f){let p=h.name;p==="rest"&&(u+=`${h.protocol_name}: ${E}, `),c.includes(p)&&(d[p]?d[p]+=`${h.protocol_name}: ${E}, `:d[p]=`${h.protocol_name}: ${E}, `)}u.length>21&&(u=u.slice(0,-2),n+=`${u}
125
- `);let _=Se.get(De.HTTP_PORT)?`HTTP: ${Se.get(De.HTTP_PORT)}, `:"";_+=Se.get(De.HTTP_SECUREPORT)?`HTTPS: ${Se.get(De.HTTP_SECUREPORT)}, `:"",_.length>21&&(_=_.slice(0,-2));for(let E of c)d[E]?n+=`${r(E)}${d[E].slice(0,-2)}
126
- `:n+=`${r(E)}${_}
127
- `;console.log(n)}a(ame,"startupLog")});var CI=b(Ca=>{"use strict";var{isMainThread:RI,parentPort:SE,threadId:KS,workerData:cme}=require("worker_threads"),{Socket:lme,createServer:ume}=require("net"),{createServer:dme,IncomingMessage:_me}=require("http"),{createServer:fme}=require("https"),{unlinkSync:iY,existsSync:Eme}=require("fs"),tn=V(),Rt=te(),er=M(),{server:zS}=(Vr(),ie(Va)),{WebSocketServer:hme}=require("ws"),{createServer:mme}=require("node:tls"),{getTicketKeys:pme,restartNumber:Sme,getWorkerIndex:rd}=st(),{Headers:AI,appendHeader:Tme}=(Nf(),ie(kk)),{recordAction:hE,recordActionBinary:gme}=(Ri(),ie(I_)),{Request:oY,createReuseportFd:pE}=(CS(),ie($N)),{checkMemoryLimit:Rme}=ic(),{createTLSSelector:aY}=Ks(),{resolvePath:cY}=It(),{startupLog:Ame}=tY(),lY=Rt.get(er.CONFIG_PARAMS.THREADS_DEBUG);if(lY){let e;if(RI)e=Rt.get(er.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){tn.info("Could not close debugger",t)}});else{let t=Rt.get(er.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&rd()>=0&&(e=t+rd())}if(e){let t=Rt.get(er.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=Rt.get(er.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){tn.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&RI)try{require("inspector").open(9229)}catch(e){Sme<=1&&tn.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:HLe,CONFIG_PARAMS:Ome}=er;Rt.initSync();var bme=Rt.get(Ome.HTTP_SESSIONAFFINITY),ki={},OI=new Map;Ca.registerServer=II;Ca.httpServer=wI;Ca.deliverSocket=NI;Ca.startServers=uY;Ca.listenOnPorts=dY;Ca.when_components_loaded=null;zS.http=wI;zS.request=wme;zS.socket=Cme;zS.ws=Dme;var gI={},mE={},yme,YS={},WS={},Nme=[],bI=[];function uY(){return Ca.when_components_loaded=JS().loadRootComponents(!0).then(()=>{SE?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)NI(n,r,s);else if(t.requestId)Ime(t);else if(t.type===er.ITC_EVENT_TYPES.SHUTDOWN){tn.trace("received shutdown request",KS);for(let i in ki){let o=ki[i],c;if(o.closeIdleConnections){let d=Object.getOwnPropertySymbols(o).find(E=>E.description.includes("connections")),u=0,_=setInterval(()=>{u++;let E=u>=100,f=o[d][E?"all":"idle"]();if(f.length===0){E&&clearInterval(_);return}u===1?tn.info(`Closing ${f.length} idle connections`):E&&tn.warn(`Forcefully closing ${f.length} active connections`);for(let h=0,p=f.length;h<p;h++){let T=f[h].socket;T._httpMessage&&!T._httpMessage.finished&&!E||(E?T.destroySoon():T.end(`HTTP/1.1 408 Request Timeout\r
125
+ `;let i=me.get(Ne.REPLICATION_PORT)??me.get(Ne.OPERATIONSAPI_NETWORK_PORT),o=me.get(Ne.REPLICATION_SECUREPORT)??me.get(Ne.OPERATIONSAPI_NETWORK_SECUREPORT),c=r("Replication:");c+=i?`WS: ${i}, `:"",c+=o?`WSS: ${o} `:"",n+=`${c.slice(0,-2)}
126
+ `;let l=[],d=SI.getConfigObj();for(let f in d)d[f].package&&l.push(f);let u={},_=`${r("REST:")}`;for(let[f,h]of e)for(let T of h){let S=T.name;S==="rest"&&(_+=`${T.protocol_name}: ${f}, `),l.includes(S)&&(u[S]?u[S]+=`${T.protocol_name}: ${f}, `:u[S]=`${T.protocol_name}: ${f}, `)}_.length>21&&(_=_.slice(0,-2),n+=`${_}
127
+ `);let E=me.get(Ne.HTTP_PORT)?`HTTP: ${me.get(Ne.HTTP_PORT)}, `:"";E+=me.get(Ne.HTTP_SECUREPORT)?`HTTPS: ${me.get(Ne.HTTP_SECUREPORT)}, `:"",E.length>21&&(E=E.slice(0,-2));for(let f of l)u[f]?n+=`${r(f)}${u[f].slice(0,-2)}
128
+ `:n+=`${r(f)}${E}
129
+ `;console.log(n),me.get(Ne.LOGGING_STDSTREAMS)&&jn.logsAtLevel("info")&&jn.suppressLogging(()=>{console.log(`Note that log messages are being sent to the console (stdout and stderr) in addition to the log file ${s}. This can be disabled by setting logging.stdStreams to false, and the log file can be directly monitored/tailed.`)})}a(cme,"startupLog")});var CI=b(Ma=>{"use strict";var{isMainThread:RI,parentPort:TE,threadId:YS,workerData:lme}=require("worker_threads"),{Socket:ume,createServer:dme}=require("net"),{createServer:_me,IncomingMessage:fme}=require("http"),{createServer:Eme}=require("https"),{unlinkSync:uY,existsSync:hme}=require("fs"),en=V(),At=te(),er=M(),{server:QS}=($r(),oe($a)),{WebSocketServer:mme}=require("ws"),{createServer:pme}=require("node:tls"),{getTicketKeys:Sme,restartNumber:Tme,getWorkerIndex:rd}=it(),{Headers:AI,appendHeader:gme}=(Nf(),oe(qF)),{recordAction:mE,recordActionBinary:aY}=(gi(),oe(I_)),{Request:dY,createReuseportFd:SE}=(wS(),oe($N)),{checkMemoryLimit:Rme}=sc(),{createTLSSelector:_Y}=js(),{resolvePath:fY}=wt(),{startupLog:Ame}=iY(),EY=At.get(er.CONFIG_PARAMS.THREADS_DEBUG);if(EY){let e;if(RI)e=At.get(er.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){en.info("Could not close debugger",t)}});else{let t=At.get(er.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&rd()>=0&&(e=t+rd())}if(e){let t=At.get(er.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=At.get(er.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){en.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&RI)try{require("inspector").open(9229)}catch(e){Tme<=1&&en.trace("Could not start debugging on port 9229, you may already be debugging:",e.message)}process.on("uncaughtException",e=>{e.isHandled||e.code==="ECONNRESET"||e.code==="ECONNREFUSED"||e.message!=="write EIO"&&console.error("uncaughtException",e)});var{HDB_SETTINGS_NAMES:vLe,CONFIG_PARAMS:bme}=er;At.initSync();var yme=At.get(bme.HTTP_SESSIONAFFINITY),xi={},bI=new Map;Ma.registerServer=II;Ma.httpServer=wI;Ma.deliverSocket=NI;Ma.startServers=hY;Ma.listenOnPorts=mY;Ma.when_components_loaded=null;QS.http=wI;QS.request=wme;QS.socket=Cme;QS.ws=Dme;var gI={},pE={},Ome,VS={},KS={},Nme=[],yI=[];function hY(){return Ma.when_components_loaded=zS().loadRootComponents(!0).then(()=>{TE?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)NI(n,r,s);else if(t.requestId)Ime(t);else if(t.type===er.ITC_EVENT_TYPES.SHUTDOWN){en.trace("received shutdown request",YS);for(let i in xi){let o=xi[i],c;if(o.closeIdleConnections){let d=Object.getOwnPropertySymbols(o).find(E=>E.description.includes("connections")),u=0,_=setInterval(()=>{u++;let E=u>=100,f=o[d][E?"all":"idle"]();if(f.length===0){E&&clearInterval(_);return}u===1?en.info(`Closing ${f.length} idle connections`):E&&en.warn(`Forcefully closing ${f.length} active connections`);for(let h=0,T=f.length;h<T;h++){let S=f[h].socket;S._httpMessage&&!S._httpMessage.finished&&!E||(E?S.destroySoon():S.end(`HTTP/1.1 408 Request Timeout\r
128
130
  Connection: close\r
129
131
  \r
130
- `))}},25).unref()}o.close?.(()=>{if(Rt.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&rd()==0)try{iY(cY(Rt.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,KS),o.cantCleanupProperly||tn.warn("Had to forcefully exit the thread",KS),process.exit(0)},5e3).unref()})}if(lY||process.env.DEV_MODE)try{require("inspector").close()}catch(i){tn.info("Could not close debugger",i)}}}).ref();let e;pE&&!bme&&(e=dY()),Promise.resolve(e).then(()=>{if(rd()===0)try{Ame(OI)}catch(t){console.error("Error displaying start-up log",t)}SE?.postMessage({type:er.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(uY,"startServers");function dY(){let e=[];for(let t in ki){let r=ki[t];if(t.includes?.("/")&&rd()==0){Eme(t)&&iY(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),tn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=Rt.get(er.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=rd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?pE?n={fd:pE(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:pE?n={fd:pE(+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}),tn.trace("Listening on port "+t,KS)}).on("error",c)}))}return Promise.all(e)}a(dY,"listenOnPorts");!RI&&!cme.noServerStart&&uY();function NI(e,t,r){let n=e?.read?e:new lme({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=ki[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=ki[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(tn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(NI,"deliverSocket");var nY=new Map;function Ime(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=nY.get(s),r){case"connection":i=NI(void 0,t),nY.set(s,i),i.write=(c,l,d)=>(SE.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),d&&d(),!0),i.end=(c,l,d)=>(SE.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),d&&d(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),SE.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(Ime,"proxyRequest");var{getComponentName:jS}=(Lf(),ie(Pf));function II(e,t,r=!0){t||(t=Rt.get(er.CONFIG_PARAMS.HTTP_PORT));let n=ki[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",sY),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else ki[t]=e;e.on("unhandled",sY)}a(II,"registerServer");function _Y(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=[],Rt.get(er.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:Rt.get(er.CONFIG_PARAMS.HTTP_PORT),secure:Rt.get(er.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),Rt.get(er.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:Rt.get(er.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&Rt.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:cY(Rt.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(_Y,"getPorts");function wI(e,t){let r=[];for(let{port:n,secure:s}of _Y(t))r.push(fY(n,s,t?.isOperationsServer)),typeof e=="function"?bI[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,II(e,n,!1)),WS[n]=yI(bI,n),yme=yI(Nme,n);return r}a(wI,"httpServer");function QS(e,t){let r=OI.get(e)??[];OI.set(e,[...r,t])}a(QS,"setPortServerMap");function fY(e,t,r){if(QS(e,{protocol_name:t?"HTTPS":"HTTP",name:jS()}),!YS[e]){let n=r?"operationsApi_network":"http",s={noDelay:!0,keepAliveTimeout:Rt.get(n+"_keepAliveTimeout"),headersTimeout:Rt.get(n+"_headersTimeout"),requestTimeout:Rt.get(n+"_timeout"),highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600},i=Rt.get(n+"_mtls"),o=Rt.get(n+"_mtls_required");t&&Object.assign(s,{allowHTTP1:!0,rejectUnauthorized:!!o,requestCert:!!(i||r),ticketKeys:pme(),maxHeaderSize:Rt.get(er.CONFIG_PARAMS.HTTP_MAXHEADERSIZE),SNICallback:aY(r?"operations-api":"server",i),ALPNCallback:function(d){return d.protocols.includes("harperdb-replication")&&(this.isReplicationConnection=!0),"http/1.1"},ALPNProtocols:null});let c=Rme(),l=YS[e]=(t?fme:dme)(s,async(d,u)=>{try{let E=performance.now(),f=new oY(d,u);r&&(f.isOperationsServer=!0);let h=await WS[e](f);if(!h){if(f._nodeResponse.statusCode)return;h=EY(f)}if(h.headers?.set||(h.headers=new AI(h.headers)),c?h.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):h.headers?.set?.("Server","HarperDB"),h.status===-1){for(let F of h.headers||[])u.setHeader(F[0],F[1]);return d.baseRequest=f,u.baseResponse=h,YS[e].emit("unhandled",d,u)}let p=h.status||200,T=performance.now(),g=T-E,S=h.body,C;if(!h.handlesHeaders){let F=h.headers||new AI;S?S.length>=0&&(typeof S=="string"?F.set("Content-Length",Buffer.byteLength(S)):F.set("Content-Length",S.length),C=!0):(F.set("Content-Length","0"),C=!0);let Y=`hdb;dur=${g.toFixed(2)}`;h.wasCacheMiss&&(Y+=", miss"),Tme(F,"Server-Timing",Y,!0),u.writeHead(p,F&&(F[Symbol.iterator]?Array.from(F):F)),C&&u.end(S)}let y=f.handlerPath,x=f.method;if(hE(g,"duration",y,x,h.wasCacheMiss==null?void 0:h.wasCacheMiss?"cache-miss":"cache-hit"),gme(p<400,"success",y,x),!C)if(S?.pipe){S.pipe(u),S.destroy&&u.on("close",()=>{S.destroy()});let F=0;S.on("data",Y=>{F+=Y.length}),S.on("end",()=>{hE(performance.now()-T,"transfer",y,x),hE(F,"bytes-sent",y,x)})}else S?.then?S.then(F=>{u.end(F)},_):u.end(S)}catch(E){_(E)}function _(E){let f=E.headers;u.writeHead(E.statusCode||500,f&&(f[Symbol.iterator]?Array.from(f):f)),u.end(E.toString()),E.statusCode?E.statusCode===500?tn.warn(E):tn.info(E):tn.error(E)}a(_,"onError")});t&&(l.ports||(l.ports=[]),l.ports.push(e),s.SNICallback.initialize(l),i&&(l.mtlsConfig=i),l.on("secureConnection",d=>{d._parent.startTime&&hE(performance.now()-d._parent.startTime,"tls-handshake",e),hE(d.isSessionReused(),"tls-reused",e)}),l.isSecure=!0),II(l,e)}return YS[e]}a(fY,"getHTTPServer");function yI(e,t){let r=EY;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(yI,"makeCallbackChain");function EY(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new AI}}a(EY,"unhandled");function wme(e,t){wI(e,{requestOnly:!0,...t})}a(wme,"onRequest");function Cme(e,t){let r;if(t.securePort){QS(t.securePort,{protocol_name:"TLS",name:jS()});let n=aY("server",t.mtls);r=mme({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),ki[t.securePort]=r}return t.port&&(QS(t.port,{protocol_name:"TCP",name:jS()}),r=ume(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),ki[t.port]=r),r}a(Cme,"onSocket");Object.defineProperty(_me.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.startsWith("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});function Dme(e,t){let r=[];for(let{port:n,secure:s}of _Y(t)){if(QS(n,{protocol_name:s?"WSS":"WS",name:jS()}),!mE[n]){let c;mE[n]=new hme({server:c=fY(n,s,t?.isOperationsServer)}),c._ws=mE[n],r.push(c),mE[n].on("connection",async(l,d)=>{try{let u=new oY(d);u.isWebSocket=!0;let _=WS[n](u),E=d.headers["sec-websocket-protocol"],f=gI[n],h;if(E){for(let p=0;p<f.length;p++){let T=f[p];T.protocol===E&&(h=!0,T.listener(l,u,_))}if(h)return}for(let p=0;p<f.length;p++){let T=f[p];T.protocol||(T.listener(l,u,_),h=!0)}h||l.close(1008,"No handler for protocol")}catch(u){tn.warn("Error handling WebSocket connection",u)}}),mE[n].on("error",l=>{console.log("Error in setting up WebSocket server",l)})}let i=t?.subProtocol||"",o=gI[n];o||(o=gI[n]=[]),o.push({listener:e,protocol:i}),WS[n]=yI(bI,n)}return r}a(Dme,"onWebSocket");function sY(e,t){t.writeHead(404),t.end(`Not found
131
- `)}a(sY,"defaultNotFound")});var rY={};tt(rY,{startHTTPThreads:()=>Lme,startSocketServer:()=>UI,updateWorkerIdleness:()=>AY});async function Lme(e=2,t){try{if(t)LI(0,1,!0);else{let{loadRootComponents:r}=JS();if(e===0)return(0,ws.setMainIsWorker)(!0),await CI().startServers(),Promise.resolve([]);await r()}RY();for(let r=0;r<e;r++)LI(r,e);return Promise.all(gY)}finally{(0,ws.threadsHaveStarted)()}}function RY(){let e=(0,SY.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),PI=setInterval(()=>{eT.notify(e)},Pme).unref())}function LI(e,t=1,r){if(DI++,(0,ws.startWorker)("server/threads/threadServer.js",{name:ad.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(d){d.type===ad.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});gY.push(s),await s,nd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=ZS.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=nd.indexOf(n);o>-1&&nd.splice(o,1)}if(a(i,"removeWorker"),sd){let o=sd;sd=[];for(let c of o)TY[c.localPort](null,c)}}}),r){let n=setInterval(()=>{MI?MI=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,ws.shutdownWorkers)(),DI=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function UI(e=0,t){if(typeof e=="string")try{(0,tT.existsSync)(e)&&(0,tT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=Mme:r=Ume(t):r=vI;let n=(0,id.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=TY[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),MI=!0,r(o,(c,l)=>{if(!c){if(hY){let u=o._socket||new id.Socket({handle:o,writable:!0,readable:!0});hY.deliverSocket(u,e,l),u.resume()}else DI>0?(sd.length===0&&setTimeout(()=>{sd.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,sd.push(o)):(console.log("start up a dynamic thread to handle request"),LI(0));Tr(!1,"socket-routed");return}c.requests++;let d=o.fd;if(d>=0)c.postMessage({port:e,fd:d,data:l});else{let u=o._socket||new id.Socket({handle:o,writable:!0,readable:!0});Hme(u,c,e)}Tr(!0,"socket-routed")})};let s=$l();eT.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function vI(e,t){let r,n=0;for(let s of nd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=XS)return XS=i,t(r);n=i}XS=0,t(r)}function Mme(e,t){let r={};e.getpeername(r);let n=r.address,s=od.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);vI(e,o=>{od.set(n,{worker:o,lastUsed:i}),t(o)})}function Ume(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new id.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],d=od.get(l),u=Date.now();if(d&&d.worker.threadId!==-1)return d.lastUsed=u,s(d.worker);vI(n,_=>{od.set(l,{worker:_,lastUsed:u}),s(_,o)})})}a(r,"findByHeaderAffinity")}function AY(){XS=0;for(let e of nd)e.expectedIdle=e.recentELU.idle+vme,e.requests=1;nd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Hme(e,t,r){let n=Bme++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),ZS.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")),ZS.delete(n)),s.event=="destroy"&&(e.destroy(),ZS.delete(n))})}var ws,id,ad,eT,tT,pY,SY,nd,sd,TY,hY,DI,gY,PI,Pme,MI,XS,mY,od,vme,ZS,Bme,TI=Ce(()=>{ws=B(st()),id=require("net"),ad=B(M()),eT=B(V()),tT=require("fs");Ri();pY=require("worker_threads"),SY=B(ic()),nd=[],sd=[],TY=[],DI=0,gY=[];pY.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,ws.onMessageFromWorkers)(e=>{e.type===ad.ITC_EVENT_TYPES.RESTART&&PI&&(clearInterval(PI),RY())}));Pme=6e5;a(Lme,"startHTTPThreads");a(RY,"licenseWarning");a(LI,"startHTTPWorker");a(UI,"startSocketServer");XS=0;a(vI,"findMostIdleWorker");mY=36e5,od=new Map;a(Mme,"findByRemoteAddressAffinity");a(Ume,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of od)r.lastUsed+mY<e&&od.delete(t)},mY).unref();vme=1e3;a(AY,"updateWorkerIdleness");(0,ws.setMonitorListener)(AY);ZS=new Map,Bme=1;a(Hme,"proxySocket")});var NY=b((WLe,yY)=>{"use strict";var xme=require("cluster"),il=te();il.initSync();var bY=M(),qLe=require("util"),wo=V(),$Le=require("fs"),Fme=require("fastify"),VLe=$l(),kme=require("@fastify/cors"),Gme=require("@fastify/compress"),qme=require("@fastify/static"),$me=sN(),Vme=require("path"),{PACKAGE_ROOT:Yme}=M(),Kme=is(),Wme=ee(),jme=vn(),Qme=ic(),{server:zme}=(Vr(),ie(Va)),{node_request_key:YLe}=(CS(),ie($N)),{authHandler:Jme,handlePostRequest:Xme,serverErrorHandler:Zme,reqBodyValidationHandler:epe}=IS(),KLe=require("net"),{registerContentHandlers:tpe}=(Mu(),ie(Sq)),rpe=6e4,npe=1024*1024*1024,spe="TRUE",{CONFIG_PARAMS:TE}=bY,cd;yY.exports={hdbServer:OY,start:OY};async function OY(e){try{wo.debug("In Fastify server"+process.cwd()),wo.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),wo.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=xme.isMaster,await ipe();let t=e.securePort>0;cd=ope(t),await cd.ready(),e||(e={}),e.isOperationsServer=!0;try{zme.http(cd.server,e),cd.server.closeIdleConnections||await cd.listen({port:0,host:"::"})}catch(r){throw cd.close(),wo.error(r),wo.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),wo.fatal(t),process.exit(1)}}a(OY,"operationsServer");async function ipe(){wo.trace("Configuring HarperDB process."),Kme.setSchemaDataToGlobal(),await jme.setUsersToGlobal(),await Qme.getLicense()}a(ipe,"setUp");function ope(e){wo.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=ape(e),r=Fme(t);r.server.headersTimeout=lpe(),r.setErrorHandler(Zme);let n=cpe();n&&r.register(kme,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,d){r.server.emit("unhandled",l.raw,d.raw)}),c()}),r.register($me),r.register(Gme),r.register(qme,{root:Vme.join(Yme,"studio/build-local")}),tpe(r);let s=il.get(bY.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Wme.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[epe,Jme],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Xme(i,o)}),r.get("/health",()=>"HarperDB is running."),wo.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(ope,"buildServer");function ape(e){let t=il.get(TE.OPERATIONSAPI_NETWORK_TIMEOUT),r=il.get(TE.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:npe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(ape,"getServerOptions");function cpe(){let e=il.get(TE.OPERATIONSAPI_NETWORK_CORS),t=il.get(TE.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===spe)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(cpe,"getCORSOpts");function lpe(){return il.get(TE.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??rpe}a(lpe,"getHeaderTimeoutConfig")});var GI={};tt(GI,{disableNATS:()=>dpe,publishToStream:()=>sT,setNATSReplicator:()=>BI,setPublishToStream:()=>_pe,setSubscription:()=>kI,start:()=>upe});function upe(){gE.default.get(RE.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&Epe()}function dpe(e=!0){PY=e}function _pe(e,t){sT=e,kI=t}function Epe(){if(PY||process.env._DISABLE_NATS)return;let e=ht(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];BI(s,r,i)}}bc((r,n)=>{BI(r.tableName,r.databaseName,r),n&&MY(r)}),!IY&&(IY=!0)}function BI(e,t,r){if(t==="system"&&hpe.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends yr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[ze],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[ze]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[ze],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[ze],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[ze]})}static defineSchema(i){MY(i)}static subscribe(){let i=new In;return kI(t,e,i),i}static subscribeOnThisThread(i){return i<(gE.default.get(RE.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??fpe)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new rT(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=LY;return i}a(n,"getNATSTransaction")}function MY(e){let t=gE.default.get(RE.default.CONFIG_PARAMS.CLUSTERING_NODENAME);sT(`${xI.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,FI.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 wY,xI,FI,CY,DY,gE,RE,nT,PY,sT,kI,fpe,LY,IY,hpe,rT,HI,UY=Ce(()=>{Le();rs();wY=B(Ft()),xI=B(_t()),FI=B(Ji());Tl();CY=B(rO()),DY=B(nn()),gE=B(te()),RE=B(M()),nT=B(V());a(upe,"start");a(dpe,"disableNATS");sT=wY.publishToStream,kI=CY.setSubscription;a(_pe,"setPublishToStream");fpe=2;a(Epe,"assignReplicationSource");hpe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(BI,"setNATSReplicator");a(MY,"publishSchema");rT=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=gE.default.get(RE.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,d;for(let u of i){let _=u.table,E=u.operation=="put"?"upsert":u.operation;l||(nT.trace(`Sending transaction event ${E}`),d=l={operation:E,schema:s,table:_,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===_&&l.operation===E?(o.push(u.record),c.push(u.id)):d=d.next={operation:E,table:_,id:u.id,record:u.record},u.expiresAt&&(d.expiresAt=u.expiresAt)}l&&n.push(sT(`${xI.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,FI.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(u=>{throw nT.error("An error has occurred trying to replicate transaction",l,u),u.statusCode=504,u}))}return Promise.all(n)}},HI=class extends rT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,DY.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};LY=new HI});async function FY({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await qI.get(e,{returnNonexistent:!0});i=new YI(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await qI.get(e);o&&o.delete()}i=new oT(e,t)}return n&&(n.id=e,n.user={username:t?.username},AE.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function $I(){return iT++,iT>65500&&(iT=1),iT}function VI(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Qo.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return wt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var BY,Da,HY,xY,vY,qI,AE,iT,oT,YI,kY=Ce(()=>{Le();B_();BY=B(nn()),Da=B(V());dc();HY=B(st()),xY=B(CI());Vr();vY=100,qI=ft({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),AE=ft({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,HY.getWorkerIndex)()===0&&(async()=>{await xY.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of AE.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await nt.getUser(r.user.username));try{await VI(r,t,r)}catch{(0,Da.warn)("Failed to publish will",t)}AE.delete(e.id)}})();a(FY,"getSession");iT=1;a($I,"getNextMessageId");oT=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,d;if(c>-1?(l=s.slice(c),d=s.slice(0,c)):d=s,!d)throw new Error("No topic provided");if(d.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let u=this.subscriptions.find(g=>g.topic===s),_;u?(_=i>0,u.end(),this.subscriptions.splice(this.subscriptions.indexOf(u),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,Da.trace)("Resuming subscription from",s,"from",o);let f=Qo.getMatch(d,"mqtt");if(!f){let g=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw g.statusCode=404,g}if(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let g=E.url.slice(1);if(g.indexOf("#")>-1&&g.indexOf("#")!==g.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,g.indexOf("+")===g.length-1)E.onlyChildren=!0,E.url="/"+g.slice(0,g.length-1);else{let S=g.split("/"),C;for(let F=0;F<S.length;F++)if(S[F].indexOf("+")>-1)if(S[F]==="+")C=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&C)throw new Error("Filters can not be combined");let y=!0;S[S.length-1]==="#"&&(S.length--,y=!1),C&&(n=a(F=>{let Y=F.id;if(!Array.isArray(Y)||y&&Y.length!==S.length)return!1;for(let $=0;$<S.length;$++)if(S[$]!=="+"&&S[$]!==Y[$])return!1;return!0},"filter"));let x=S.indexOf("+");E.url="/"+(x>-1?S.slice(0,x):S).concat("").join("/")}}let h=f.path,p=f.Resource,T=await wt(E,async()=>{let g=this.createContext();g.topic=s,g.retainHandling=i;let S=await p.subscribe(E,g);if(!S)throw new Error(`No subscription was returned from subscribe for topic ${s}`);if(!S[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let C=(async()=>{for await(let y of S)try{let x;if(y.type&&y.type!=="put"&&y.type!=="delete"&&y.type!=="message"&&y.type!=="patch"||n&&!n(y))continue;r?(y.topic=s,x=this.needsAcknowledge(y)):(y.acknowledge?.(),x=$I());let F=y.id;if(Array.isArray(F)&&(F=Ql(F)),F==null&&(F=""),await this.listener(h+"/"+F,y.value,x,t)===!1)break;this.awaitingAcks?.size>vY?await new Promise($=>setTimeout($,this.awaitingAcks.size-vY)):await new Promise(setImmediate)}catch(x){(0,Da.warn)(x)}})();return S});return T.topic=s,T.qos=t.qos,this.subscriptions.push(T),T}resume(){}needsAcknowledge(t){let r=$I();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,t.acknowledge)),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return VI(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();wt(r,async()=>{try{if(!t){let n=await AE.get(this.sessionId);n?.doesExist()&&await VI(n,n.data,r)}}finally{await AE.delete(this.sessionId)}}).catch(n=>{(0,Da.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(VI,"publish");YI=class extends oT{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.timestamp):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=$I(),n={topic:t.topic,timestamp:t.timestamp};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Da.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,BY.getNextMonotonicTime)()),(0,Da.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),qI.put(this.sessionRecord)}}});var WI={};tt(WI,{bypassAuth:()=>mpe,start:()=>ppe});function mpe(){YY=!0}function ppe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new VY.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((d,u,_)=>{if(d.protocol==="mqtt"){o.events.emit("connection",d),Hr.debug?.("Received WebSocket connection for MQTT from",d._socket.remoteAddress);let{onMessage:E,onClose:f}=qY(d,h=>{d.send(h)},u,Promise.resolve(_).then(()=>u?.user),o);d.on("message",E),d.on("close",f),d.on("error",h=>{Hr.info?.("WebSocket error",h)})}},{subProtocol:"mqtt",...n})),(t||s)&&c.push(e.socket(async d=>{let u;if(o.events.emit("connection",d),Hr.debug?.(`Received ${d.getCertificate?"SSL":"TCP"} connection for MQTT from ${d.remoteAddress}`),l){if(d.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=d.getPeerCertificate().subject.CN);try{u=await e.getUser(f,null,null),(0,ld.get)(xr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&cT.notify?.({username:u?.username,status:xr.AUTH_AUDIT_STATUS.SUCCESS,type:xr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:d.remoteAddress})}catch(h){throw(0,ld.get)(xr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&cT.error?.({username:f,status:xr.AUTH_AUDIT_STATUS.FAILURE,type:xr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:d.remoteAddress}),h}}else Hr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",d.remoteAddress)}catch(f){o.events.emit("error",f,d),Hr.error?.(f)}else if(l.required)return Hr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${d.authorizationError}`),d.end()}!u&&YY&&d.remoteAddress.includes("127.0.0.1")&&(u=await(0,$Y.getSuperUser)(),Hr.debug?.("Auto-authorizing local connection",u?.username));let{onMessage:_,onClose:E}=qY(d,f=>d.write(f),null,u,o);d.on("data",_),d.on("close",E),d.on("error",f=>{Hr.info?.("Socket error",f)})},{port:t,securePort:s,mtls:l})),c}function qY(e,t,r,n,s){GY||(GY=!0,N_(_=>{aT>0&&_.push({metric:"mqtt-connections",connections:aT,byThread:!0})}));let i;aT++;let o,c={protocolVersion:4},l=(0,lT.parser)({protocolVersion:5});function d(_){l.parse(_)}a(d,"onMessage");function u(){aT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Fn(!1,"connection","mqtt","disconnect"),Hr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(u,"onClose"),l.on("packet",async _=>{n?.then&&(n=await n),o?.then&&await o;let E=_.topic,f=E?.indexOf("/",1),h=f>0?E.slice(0,f):E;Tr(_.length,"bytes-received",h,T(_),"mqtt");try{switch(o?.receivedPacket?.(),_.cmd){case"connect":if(c.protocolVersion=_.protocolVersion,_.username)try{n=await nt.getUser(_.username,_.password.toString(),r),(0,ld.get)(xr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&cT.notify?.({username:n?.username,status:xr.AUTH_AUDIT_STATUS.SUCCESS,type:xr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch($){return(0,ld.get)(xr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&cT.error?.({username:_.username,status:xr.AUTH_AUDIT_STATUS.FAILURE,type:xr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",_,e,$),Fn(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",_,e),Fn(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(_,n),_.will){let $=e.deserialize||(e.deserialize=$c(r?.headers.get?.("content-type")));_.will.data=_.will.payload?.length>0?$(_.will.payload):void 0,delete _.will.payload}o=FY({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch($){return Hr.error?.($),s.events.emit("auth-failed",_,e,$),Fn(!1,"connection","mqtt","connect"),p({cmd:"connack",reasonCode:$.code||5,returnCode:$.code||128})}s.events.emit("connected",o,e),Fn(!0,"connection","mqtt","connect"),p({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener(($,Z,Q,_e)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",$);let K=$.indexOf("/",1),se=K>0?$.slice(0,K):$;p({cmd:"publish",topic:$,payload:g(Z),messageId:Q||Math.floor(Math.random()*1e8),qos:_e.qos},se);let le=e._socket??e;return le.writableNeedDrain?new Promise(we=>le.once("drain",we)):!le.closed}catch(K){return Hr.error?.(K),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let S=[];for(let $ of _.subscriptions){let Z;try{Z=(await o.addSubscription($,$.qos>=1)).qos||0}catch(Q){s.events.emit("error",Q,e,$,o),Hr.error?.(Q),Z=c.protocolVersion<5?128:Q.statusCode===403?135:Q.statusCode===404?143:128}S.push(Z)}await o.committed,p({cmd:"suback",granted:S,messageId:_.messageId});break;case"unsubscribe":{let $=[];for(let Z of _.unsubscriptions)$.push(o.removeSubscription(Z)?0:17);p({cmd:"unsuback",granted:$,messageId:_.messageId});break}case"pubrel":p({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let C=_.qos===2?"pubrec":"puback",y=e.deserialize||(e.deserialize=$c(r?.headers.get?.("content-type"))),F=(_.payload?.length||0)>0?y(_.payload):void 0,Y;try{Y=await o.publish(_,F)}catch($){s.events.emit("error",$,e,_,o),Hr.warn?.($),_.qos>0&&p({cmd:C,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&p({cmd:C,messageId:_.messageId,reasonCode:Y===!1?144:0},_.topic);break;case"pubrec":p({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":p({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),Fn(!0,"connection","mqtt","disconnect"),Hr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(S){s.events.emit("error",S,e,_,o),Hr.error?.(S),p({cmd:"disconnect"})}function p(S,C){let y=(0,lT.generate)(S,c);t(y),Tr(y.length,"bytes-sent",C,T(S),"mqtt")}a(p,"sendPacket");function T(S){return S.qos>0?S.cmd+",qos="+S.qos:S.cmd}a(T,"packetMethodName");function g(S){return xc(S,r)}a(g,"serialize")}),l.on("error",_=>{Hr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:d,onClose:u}}var lT,$Y,ld,xr,KI,VY,cT,Hr,YY,GY,aT,KY=Ce(()=>{lT=require("mqtt-packet");kY();$Y=B(vn());Mu();Ri();Vr();ld=B(te()),xr=B(M()),KI=B(Wl()),VY=require("events"),cT=(0,KI.loggerWithTag)("auth-event"),Hr=(0,KI.loggerWithTag)("mqtt"),YY=(0,ld.get)(xr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(mpe,"bypassAuth");a(ppe,"start");aT=0;a(qY,"onSocket")});var Pf={};tt(Pf,{component_errors:()=>dd,getComponentName:()=>Ape,loadComponent:()=>dT,loadComponentDirectories:()=>eK,setErrorReporter:()=>Rpe});function eK(e,t){t&&(QI=t),e&&(zI=e);let r=[];if((0,yt.existsSync)(jI)){let s=(0,yt.readdirSync)(jI,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Ut.join)(jI,o);r.push(dT(c,QI,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(dT(n,QI,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{ZY=!0})}function Rpe(e){OE=e}async function dT(e,t,r,n,s,i){let o=(0,yt.realpathSync)(e);if(!jY.has(o)){jY.set(o,!0),s&&(zI=s);try{let c;n&&(dd=new Map);let l=(0,Ut.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,yt.existsSync)(l)?c=n?(0,_T.getConfigObj)():(0,QY.parseDocument)((0,yt.readFileSync)(l,"utf8")).toJSON():c=JI;let d=(0,Ut.join)(e,"node_modules","harperdb");try{ol.isMainThread&&(n||(0,yt.existsSync)(d)&&(0,yt.realpathSync)(fd.PACKAGE_ROOT)!==(0,yt.realpathSync)(d))&&((0,yt.rmSync)(d,{recursive:!0,force:!0}),(0,yt.existsSync)((0,Ut.join)(e,"node_modules"))||(0,yt.mkdirSync)((0,Ut.join)(e,"node_modules")),(0,yt.symlinkSync)(fd.PACKAGE_ROOT,d,"dir"))}catch(E){ud.default.error("Error symlinking harperdb module",E)}let u=uT,_=n;for(let E in c){uT=E;let f=c[E];if(dd.set(n?E:(0,Ut.basename)(e),!1),!f)continue;let h,p=f.package;try{if(p){let y=e,x;for(;!(0,yt.existsSync)(x=(0,Ut.join)(y,"node_modules",E));)if(y=(0,Ut.dirname)(y),y.length<(0,XY.getHdbBasePath)().length){x=null;break}if(x)h=await dT(x,t,r,!1),_=!0;else throw new Error(`Unable to find package ${E}:${p}`)}else h=gpe[E];if(!h)continue;let T=a(y=>(y.origin=r,ft(y)),"ensureTable"),g=f.network||(f.port||f.securePort)&&f,S=g?.securePort||g?.https&&g.port,C=!g?.https&&g?.port;if(ol.isMainThread&&(h=await h.startOnMainThread?.({server:nt,ensureTable:T,port:C,securePort:S,resources:t,...f})||h,n&&g))for(let y of[C,S])try{if(+y&&!WY.includes(y)){let x=XI.get(fd.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);x&&ud.default.warn("Session affinity is not recommended and may cause memory leaks"),(x||!wS)&&(WY.push(y),UI(y,x))}}catch(x){console.error("Error listening on socket",y,x,E)}if(t.isWorker&&(h=await h.start?.({server:nt,ensureTable:T,port:C,securePort:S,resources:t,...f})||h),zI.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&f.files!=null){if(f.files.includes(".."))throw(0,JY.handleHDBError)("Can not reference parent directories");let y=(0,Ut.join)(e,f.files).replace(/\\/g,"/"),x=y.indexOf("/*");if(x>-1&&f.files!==JI[E]?.files&&!(0,yt.existsSync)(y.slice(0,x)))throw new Error(`The path '${y.slice(0,x)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let F=(0,Ut.basename)(e),Y=f.path||"/";Y=Y.startsWith("/")?Y:Y.startsWith("./")?"/"+F+Y.slice(2):Y==="."?"/"+F:"/"+F+"/"+Y;let $,Z,Q;if(f.root){let K=f.root;K.startsWith("/")&&(K=K.slice(1)),K.endsWith("/")&&(K=K.slice(0,-1)),K+="/",Z=(0,Ut.join)(e,K)}else(Q=y.indexOf("/*"))>-1&&(Z=y.slice(0,Q+1),$=(0,Ut.relative)(e,Z));let _e=!1;if(ol.isMainThread&&h.setupDirectory&&(_e=await h.setupDirectory?.(Y,Z,t)),t.isWorker&&h.handleDirectory&&(_e=await h.handleDirectory?.(Y,Z,t)),_e)continue;for(let K of await(0,zY.default)(y,{onlyFiles:!1,objectMode:!0})){let{path:se,dirent:le}=K;_=!0;let we=(0,Ut.relative)(e,se).replace(/\\/g,"/");if($)if(we.startsWith($))we=we.slice($.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${we}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let ve=Y+(Y.endsWith("/")?"":"/")+we;try{if(le.isFile()){let et=await Tpe(se);ol.isMainThread&&await h.setupFile?.(et,ve,se,t),t.isWorker&&await h.handleFile?.(et,ve,se,t)}else ol.isMainThread&&await h.setupDirectory?.(ve,se,t),t.isWorker&&await h.handleDirectory?.(ve,se,t)}catch(et){et.message=`Could not load ${le.isFile()?"file":"directory"} '${se}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${et.message}`,OE?.(et),((0,_d.getWorkerIndex)()===0?console:ud.default).error(et),t.set(f.path||"/",new jo(et)),dd.set(n?E:(0,Ut.basename)(e),et.message)}}}}catch(T){T.message=`Could not load component '${E}' for application '${(0,Ut.basename)(e)}' due to: ${T.message}`,OE?.(T),((0,_d.getWorkerIndex)()===0?console:ud.default).error(T),t.set(f.path||"/",new jo(T),null,!0),dd.set(n?E:(0,Ut.basename)(e),T.message)}}if(uT=u,ol.isMainThread&&!ZY&&i&&(0,_d.watchDir)(e,async()=>eK()),c.extensionModule)return await ch((0,Ut.join)(e,c.extensionModule));if(!_&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;OE?.(new Error(E)),((0,_d.getWorkerIndex)()===0?console:ud.default).error(E),dd.set((0,Ut.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,OE?.(c),t.set("",new jo(c))}}}var yt,Ut,ol,QY,XI,fd,zY,_d,ud,JY,XY,Spe,_T,Tpe,jI,zI,ZY,QI,dd,gpe,JI,WY,jY,OE,uT,Ape,Lf=Ce(()=>{yt=require("fs"),Ut=require("path"),ol=require("worker_threads"),QY=require("yaml"),XI=B(te()),fd=B(M());JC();tD();rD();Lq();bV();DV();zY=B(require("fast-glob")),_d=B(st()),ud=B(V());gg();Vr();JY=B(ce());Le();TI();XY=B(te()),Spe=B(NY());vp();UY();as();KY();_T=B(It());CS();hO();({readFile:Tpe}=yt.promises),jI=(0,_T.resolvePath)(XI.get(fd.CONFIG_PARAMS.COMPONENTSROOT)),zI=new Map,dd=new Map;a(eK,"loadComponentDirectories");gpe={REST:aS,rest:aS,graphqlSchema:Tg,jsResource:Ag,fastifyRoutes:xN,login:bg,static:FN,operationsApi:Spe,customFunctions:{},http:{},clustering:GI,replication:ta,authentication:If,mqtt:WI},JI={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(JI,"static",{value:{files:"web/**"}});WY=[],jY=new Map;a(Rpe,"setErrorReporter");Ape=a(()=>uT,"getComponentName");a(dT,"loadComponent")});var JS=b((RMe,rK)=>{var{isMainThread:tK}=require("worker_threads"),{getTables:Ope,getDatabases:TMe,table:gMe}=(Le(),ie(lt)),{loadComponentDirectories:bpe,loadComponent:ype}=(Lf(),ie(Pf)),{resetResources:Npe}=(B_(),ie(tB)),Ipe=gy(),wpe=It(),{dirname:Cpe}=require("path"),{getConnection:Dpe}=Ft(),Ppe=te(),{CONFIG_PARAMS:Lpe}=M(),{loadCertificates:Mpe}=Ks(),ZI=new Map;async function Upe(e=!1){!tK&&Ppe.get(Lpe.CLUSTERING_ENABLED)&&Dpe();try{tK&&await Ipe()}catch(n){console.error(n)}let t=Npe();Ope(),t.isWorker=e,await Mpe(),await ype(Cpe(wpe.getConfigFilePath()),t,"hdb",!0,ZI),await bpe(ZI,t);let r=[];for(let[n]of ZI)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(Upe,"loadRootComponents");rK.exports.loadRootComponents=Upe});var st=b((OMe,ni)=>{"use strict";var{Worker:vpe,MessageChannel:Bpe,parentPort:Gi,isMainThread:sw,threadId:Hpe,workerData:qi}=require("worker_threads"),{PACKAGE_ROOT:xpe}=M(),{join:oK,isAbsolute:Fpe,extname:kpe}=require("path"),{server:aK}=(Vr(),ie(Va)),{watch:Gpe,readdir:qpe}=require("fs/promises"),{totalmem:nK}=require("os"),bE=M(),cK=te(),$i=V(),{randomBytes:$pe}=require("crypto"),{_assignPackageExport:Vpe}=Yi(),Ype=M(),sK=1024*1024,Pa=[],Cs=[],Kpe=50,iw=1e4,Wpe="restart",lK="request_thread_info",uK="resource_report",dK="thread_info",_K="added-port",jpe="ack",ew;Vpe("threads",Cs);ni.exports={startWorker:tw,restartWorkers:aw,shutdownWorkers:Zpe,workers:Pa,setMonitorListener:aSe,onMessageFromWorkers:eSe,onMessageByType:TK,broadcast:rSe,broadcastWithAcknowledgement:sSe,setChildListenerByType:Xpe,getWorkerIndex:fK,getWorkerCount:EK,getTicketKeys:mK,setMainIsWorker:zpe,setTerminateTimeout:Qpe,restartNumber:qi?.restartNumber||1};Cs.onMessageByType=TK;Cs.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Cs.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};ni.exports.whenThreadsStarted=new Promise(e=>{ni.exports.threadsHaveStarted=e});var ow;function Qpe(e){iw=e}a(Qpe,"setTerminateTimeout");function fK(){return qi?qi.workerIndex:ow?0:void 0}a(fK,"getWorkerIndex");function EK(){return qi?qi.workerCount:ow?1:void 0}a(EK,"getWorkerCount");function zpe(e){ow=e,ni.exports.threadsHaveStarted()}a(zpe,"setMainIsWorker");var hK=1,fT;function mK(){return fT||(fT=sw?$pe(48):qi.ticketKeys,fT)}a(mK,"getTicketKeys");Object.defineProperty(aK,"workerIndex",{get(){return fK()}});Object.defineProperty(aK,"workerCount",{get(){return EK()}});var pK={[lK](e,t){iSe(t)},[uK](e,t){oSe(t,e)}};function tw(e,t={}){let r=process.constrainedMemory?.()||nK();r=Math.min(r,nK(),2e4*sK);let n=cK.get(bE.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/sK/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Cs){let d=new Bpe;d.existingPort=l,i.push(d),o.push(d.port2)}kpe(e)||(e+=".js");let c=new vpe(Fpe(e)?e:oK(xpe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:hK=t.threadCount,name:t.name,restartNumber:ni.exports.restartNumber,ticketKeys:mK()},transferList:o,...t});for(let{port1:l,existingPort:d}of i)d.postMessage({type:_K,port:l,threadId:c.threadId},[l]);return hT(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>tw(e,t),c.on("error",l=>{$i.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{Pa.splice(Pa.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<Kpe?(t.unexpectedRestarts=c.unexpectedRestarts+1,tw(e,t)):$i.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{pK[l.type]?.(l,c)}),Pa.push(c),lSe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(tw,"startWorker");var Jpe=[bE.THREAD_TYPES.HTTP];async function aw(e=null,t=Math.max(hK>3,1),r=!0){if(sw){if(r){let{loadRootComponents:o}=JS();await o()}ni.exports.restartNumber++,t<1&&(t=t*Pa.length);let n=[],s=[];for(let o of Pa.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;$i.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:ni.exports.restartNumber,type:bE.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=Jpe.indexOf(o.name)>-1,l=new Promise(d=>{let u=setTimeout(()=>{$i.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},iw*2).unref();o.on("exit",()=>{clearTimeout(u),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),d()})});if(n.push(l),c&&r){let d=o.startCopy(),u=new Promise(_=>{let E=a(f=>{f.type===Ype.ITC_EVENT_TYPES.CHILD_STARTED&&($i.trace("Worker has started",d.threadId),_(),s.splice(s.indexOf(u)),d.off("message",E))},"startListener");$i.trace("Waiting for worker to start",d.threadId),d.on("message",E)});s.push(u),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=Pu();r&&(e==="http"||!e)&&cK.get(bE.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Gi.postMessage({type:Wpe,workerType:e})}a(aw,"restartWorkers");function Xpe(e,t){pK[e]=t}a(Xpe,"setChildListenerByType");function Zpe(e){return aw(e,1/0,!1)}a(Zpe,"shutdownWorkers");var SK=[];function eSe(e){SK.push(e)}a(eSe,"onMessageFromWorkers");var rw=new Map;function TK(e,t){let r=rw.get(e);r||rw.set(e,r=[]),r.push(t)}a(TK,"onMessageByType");var tSe=10;async function rSe(e,t){let r=0;for(let n of Cs)try{n.postMessage(e),r++>tSe&&(r=0,await new Promise(setImmediate))}catch(s){$i.error("Unable to send message to worker",s)}t&&RK(e,null)}a(rSe,"broadcast");var ET=new Map,nSe=1;function sSe(e){return new Promise(t=>{let r=0;for(let n of Cs)try{let s=nSe++,i=a(()=>{ET.delete(s),--r===0&&t(),n!==Gi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,ET.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of ET)o.port===n&&o()})),n.postMessage(e),r++}catch(s){$i.error("Unable to send message to worker",s)}r===0&&t()})}a(sSe,"broadcastWithAcknowledgement");function iSe(e){e.postMessage({type:dK,workers:gK()})}a(iSe,"sendThreadInfo");function gK(){let e=Date.now();return Pa.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(gK,"getChildWorkerInfo");function oSe(e,t){e.resources=t,e.resources.updated=Date.now()}a(oSe,"recordResourceReport");var nw;function aSe(e){nw=e}a(aSe,"setMonitorListener");var cSe=1e3,iK=!1;function lSe(){iK||(iK=!0,setInterval(()=>{for(let e of Pa){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}nw&&nw()},cSe).unref())}a(lSe,"startMonitoring");var uSe=1e3;if(Gi&&qi?.addPorts){hT(Gi);for(let e=0,t=qi.addPorts.length;e<t;e++){let r=qi.addPorts[e];r.threadId=qi.addThreadIds[e],hT(r)}setInterval(()=>{let e=process.memoryUsage();Gi.postMessage({type:uK,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},uSe).unref(),ew=a(()=>new Promise((e,t)=>{Gi.on("message",r),Gi.postMessage({type:lK});function r(n){n.type===dK&&(Gi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else ew=gK;ni.exports.getThreadInfo=ew;function hT(e,t){Cs.push(e),e.on("message",r=>{if(r.type===_K)r.port.threadId=r.threadId,hT(r.port);else if(r.type===jpe){let n=ET.get(r.id);n&&n()}else RK(r,e)}).on("close",()=>{Cs.splice(Cs.indexOf(e),1)}).on("exit",()=>{Cs.splice(Cs.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(hT,"addPort");function RK(e,t){for(let n of SK)n(e,t);let r=rw.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){$i.error(s)}}a(RK,"notifyMessageListeners");if(sw){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await qpe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(oK(s,o.name));try{for await(let{filename:o}of Gpe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await aw(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");ni.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Gi.on("message",async e=>{let{type:t}=e;t===bE.ITC_EVENT_TYPES.SHUTDOWN&&(ni.exports.restartNumber=e.restartNumber,Gi.unref(),setTimeout(()=>{$i.warn("Thread did not voluntarily terminate",Hpe),process.exit(0)},iw).unref())})});var ov={};tt(ov,{AUDIT_STORE_OPTIONS:()=>Rf,Decoder:()=>au,HAS_CURRENT_RESIDENCY_ID:()=>Wa,HAS_EXPIRATION_EXTENDED_TYPE:()=>Yd,HAS_ORIGINATING_OPERATION:()=>Vd,HAS_PREVIOUS_RESIDENCY_ID:()=>ja,REMOTE_SEQUENCE_UPDATE:()=>Fm,createAuditEntry:()=>Rl,getLastRemoved:()=>HO,openAuditStore:()=>gT,readAuditEntry:()=>Ht,setAuditRetention:()=>_Se,transactionKeyEncoder:()=>LK});function gT(e){let t=e.auditStore=e.openDB(cw.AUDIT_STORE_NAME,{create:!1,...Rf});t||(t=e.auditStore=e.openDB(cw.AUDIT_STORE_NAME,Rf),OK(t,1)),t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=mT){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:d,value:u}of t.getRange({start:1,snapshot:!1,end:Date.now()-lw})){if((u[0]&15)===uw){let _=Ht(u),E=_.tableId;r[E]?.(_.recordId)}if(c=t.remove(d),l=d,await new Promise(setImmediate),++o>=dSe){i=10;break}}await c}finally{o===0?i=Math.min(i<<1,lw/10):OK(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,NE.getWorkerIndex)()===(0,NE.getWorkerCount)()-1&&s(mT),(0,NE.getWorkerIndex)()===0&&!AK)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(AK=!0,TT.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 OK(e,t){dw[0]=t,e.put(Symbol.for("last-removed"),MK)}function HO(e){let t=e.get(Symbol.for("last-removed"));if(t)return MK.set(t),dw[0]}function _Se(e,t=mT){lw=e,mT=t}function Rl(e,t,r,n,s,i,o,c,l,d,u,_,E){let f=UK[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?La.setFloat64(0,n):Ds.set(Gg),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}g(s),g(t),T(r),La.setFloat64(h,e),h+=8,l&Wa&&g(d),l&ja&&g(u),l&Yd&&(La.setFloat64(h,_),h+=8),l&Vd&&g(vK[E]),i?T(i):Ds[h++]=0,l?La.setUint16(n?8:0,f|l|32768):Ds[n?8:0]=f;let p=Ds.subarray(0,h);if(c)return Buffer.concat([p,c]);return p;function T(S){let C=h;h+=1,h=(0,Ed.writeKey)(S,Ds,h);let y=h-C-1;y>127?y>16383?(TT.error("Key or username was too large for audit entry",S),h=C+1,Ds[C]=0):(Ds.copyWithin(C+2,C+1,h),La.setUint16(C,y|32768),h++):Ds[C]=y}function g(S){S<128?Ds[h++]=S:S<16384?(La.setUint16(h,S|32768),h+=2):S<1056964608?(La.setUint32(h,S|3221225472),h+=4):(Ds[h]=255,La.setUint32(h+1,S),h+=5)}}function Ht(e){try{let t=e.dataView||(e.dataView=new au(e.buffer,e.byteOffset,e.byteLength)),r;e[t.position]==66&&(r=t.readFloat64());let n=t.readInt(),s=t.readInt(),i=t.readInt(),o=t.readInt(),c=t.position,l=t.position+=o,d=t.readFloat64(),u,_,E,f;if(n&Wa&&(u=t.readInt()),n&ja&&(_=t.readInt()),n&Yd&&(E=t.readFloat64()),n&Vd){let T=t.readInt();f=vK[T]}o=t.readInt();let h=t.position,p=t.position+=o;return{type:UK[n&7],tableId:i,nodeId:s,get recordId(){return CK(e,c,l)},getBinaryRecordId(){return e.subarray(c,l)},version:d,previousLocalTime:r,get user(){return p>h?CK(e,h,p):void 0},encoded:e,getValue(T,g,S){if(n&pT||n&yE&&!g)return T.decoder.decode(e.subarray(t.position));if(n&yE&&S)return _w(T.getEntry(this.recordId),S,T)},getBinaryValue(){return n&(pT|yE)?e.subarray(t.position):void 0},extendedType:n,residencyId:u,previousResidencyId:_,expiresAt:E,originatingOperation:f}}catch(t){return TT.error("Reading audit entry error",t,e),{}}}function CK(e,t,r){let n=e.subarray(t,r);return(0,Ed.readKey)(n,0,r-t)}var Ed,ST,cw,DK,NE,PK,TT,Ds,La,LK,Rf,lw,dSe,dw,MK,mT,AK,pT,yE,bK,uw,yK,NK,IK,wK,Fm,Wa,ja,Vd,Yd,UK,vK,au,Wi=Ce(()=>{Ed=require("ordered-binary"),ST=B(te()),cw=B(Bt()),DK=B(M()),NE=B(st()),PK=B(ee());Al();TT=B(V());RT();(0,ST.initSync)();Ds=Buffer.alloc(1024),La=new DataView(Ds.buffer,Ds.byteOffset,1024),LK={writeKey(e,t,r){return e===$d?(t.set($d,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Ed.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,Ed.readKey)(e,t,r)}},Rf={encoding:"binary",keyEncoder:LK},lw=(0,PK.convertToMS)((0,ST.get)(DK.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,dSe=1e3,dw=new Float64Array(1),MK=new Uint8Array(dw.buffer),mT=1e4,AK=!1;a(gT,"openAuditStore");a(OK,"updateLastRemoved");a(HO,"getLastRemoved");a(_Se,"setAuditRetention");pT=16,yE=32,bK=1,uw=2,yK=3,NK=4,IK=5,wK=6,Fm=11,Wa=512,ja=1024,Vd=2048,Yd=4096,UK={put:bK|pT,[bK]:"put",delete:uw,[uw]:"delete",message:yK|pT,[yK]:"message",invalidate:NK|yE,[NK]:"invalidate",patch:IK|yE,[IK]:"patch",relocate:wK,[wK]:"relocate"},vK={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Rl,"createAuditEntry");a(Ht,"readAuditEntry");au=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;try{t=this.getUint8(this.position++)}catch(r){throw r}return t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch{debugger}}};a(CK,"readKeySafely")});var fw={};tt(fw,{add:()=>AT,applyReverse:()=>BK,getRecordAtTime:()=>_w,rebuildUpdateBefore:()=>OT});function AT(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 OT(e,t){let r=null;for(let n in e)if(n in t){let s=t[n];if(s?.__op__){let i=e[n];if(i?.__op__)if(i.__op__===s.__op__)r||(r={}),r[n]=i;else throw new Error("Can not merge updates with different operations");else r||(r={}),r[n]=i,AT(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function BK(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=fSe[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=HK}}function _w(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),d=Ht(l);switch(d.type){case"put":s=d.getValue(r);break;case"patch":BK(s,d.getValue(r));break;case"delete":s=null}i=d.previousLocalTime}let o={},c=0;for(let l in s)s[l]===HK&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),d=Ht(l),u;switch(d.type){case"put":u=d.getValue(r);break;case"patch":u=d.getValue(r);break}for(let _ in u)o[_]&&(s[_]=u[_],o[_]=!1,c--);i=d.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var fSe,HK,RT=Ce(()=>{Wi();a(AT,"add");AT.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};fSe={add:AT};a(OT,"rebuildUpdateBefore");a(BK,"applyReverse");HK={};a(_w,"getRecordAtTime")});function jn(e){return e[ur]||(e[ur]=Object.create(null))}function wT(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,d;if(o.resolve)d={get(){return o.resolve(this,this[xe])},set(u){return o.set(this,u)},configurable:!0};else{switch(o.type){case"String":l=a(function(u){if(!(typeof u=="string"||u==null&&o.nullable!==!1))throw new Ps.ClientError(`${c} must be a string, attempt to assign ${u}`);jn(this)[c]=u},"set");break;case"ID":l=a(function(u){if(!(typeof u=="string"||u?.length>0&&u.every?.(_=>typeof _=="string")||u==null&&o.nullable!==!1))throw new Ps.ClientError(`${c} must be a string, attempt to assign ${u}`);jn(this)[c]=u},"set");break;case"Float":case"Number":l=a(function(u){let _=u?.__op__?u.value:u;if(!(typeof _=="number"||u==null&&o.nullable!==!1))throw new Ps.ClientError(`${c} must be a number, attempt to assign ${_}`);jn(this)[c]=u},"set");break;case"Int":l=a(function(u){let _=u?.__op__?u.value:u;if(!(_>>0===_||u==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),u?.__op__?u.value=_:u=_;else throw new Ps.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${u}`);jn(this)[c]=u},"set");break;case"Long":l=a(function(u){let _=u?.__op__?u.value:u;if(!(Math.round(_)===u&&Math.abs(_)<=9007199254740992||u==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),u?.__op__?u.value=_:u=_;else throw new Ps.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${u}`);jn(this)[c]=u},"set");break;case"BigInt":l=a(function(u){let _=u?.__op__?u.value:u;if(!(typeof _=="bigint"||u==null&&o.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),u?.__op__?u.value=_:u=_;else throw new Ps.ClientError(`${c} must be a number, attempt to assign ${u}`);jn(this)[c]=u},"set");break;case"Boolean":l=a(function(u){if(!(typeof u=="boolean"||u==null&&o.nullable!==!1))throw new Ps.ClientError(`${c} must be a boolean, attempt to assign ${u}`);jn(this)[c]=u},"set");break;case"Date":l=a(function(u){if(!(u instanceof Date||u==null&&o.nullable!==!1))if(typeof u=="string"||typeof u=="number")u=new Date(u);else throw new Ps.ClientError(`${c} must be a Date, attempt to assign ${u}`);jn(this)[c]=u},"set");break;case"Bytes":l=a(function(u){if(!(u instanceof Uint8Array||u==null&&o.nullable!==!1))throw new Ps.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${u}`);jn(this)[c]=u},"set");break;case"Any":case void 0:l=a(function(u){jn(this)[c]=u},"set");break;default:l=a(function(u){if(!(typeof u=="object"||u==null&&o.nullable!==!1))throw new Ps.ClientError(`${c} must be an object, attempt to assign ${u}`);jn(this)[c]=u},"set")}d={get(){let u=this[ur];if(u&&c in u){let E=u[c];if(E?.__op__){let f=this[Ue]?.[c];return E.update(f)}return E}let _=this[Ue]?.[c];if(_&&typeof _=="object"){let E=FK(_,o);if(E)return u||(u=this[ur]=Object.create(null)),u[c]=E}return _},set:l,enumerable:!0,configurable:!0}}d.get.isAttribute=!0,n[c]=d,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,d)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let l=this[ur];return l?.[o]!==void 0?l[o]:this[Ue]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new Ps.ClientError("Can not add a property to a sealed table schema");jn(this)[o]=c}),i("deleteProperty",function(o){jn(this)[o]=void 0}),i("toJSON",function(){let o=this[ur],c;for(let d in o){c||(c={...this[Ue]});let u=o[d];if(u?.__op__){let _=c[d];u=u.update(_)}c[d]=u}return Object.keys(this).length>0&&(c||(c={...this[Ue]}),Object.assign(c,this)),c||this[Ue]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function FK(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[Ue])throw new Error("Can not track an already tracked object, check for circular references");this[Ue]=s}},wT(r,t)),new r(e)):new bT(e);case Array:let n=new NT(e.length);n[Ue]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=FK(o,t?.elements)),n[s]=o}return n;default:return e}}function am(e){let t=e[ur],r;for(let s in t){r||(r={...e[Ue]});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=am(i);r[s]=i}return Object.keys(e).length>0&&(r||(r={...e[Ue]}),Object.assign(r,e)),r||e[Ue]}function cl(e,t=e[ur]){let r;if(xK.call(e,Ue)&&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=cl(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[Ue]});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=fw[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=cl(s);r[n]=s}return r?Object.freeze(r):xK.call(e,Ue)?e[Ue]:e}function yT(e){let t=e[Ue];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[al]||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?.[Ue]===s){if(yT(i))return!0}else return!0}}else{let r=e[ur];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[Ue]===i){if(yT(s))return!0}else return!0}else return!0}}return!1}var Ps,ur,bT,xK,al,NT,IT,cm=Ce(()=>{rs();Ps=B(ce());RT();ur=Symbol("own-data");a(jn,"getChanges");a(wT,"assignTrackedAccessors");a(FK,"trackObject");bT=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[Ue])throw new Error("Can not track an already tracked object, check for circular references");this[Ue]=t}};wT(bT,{});a(am,"collapseData");xK=Object.prototype.hasOwnProperty;a(cl,"deepFreeze");a(yT,"hasChanges");al=Symbol.for("has-array-changes"),NT=class extends Array{static{a(this,"TrackedArray")}[al];constructor(t){super(t)}splice(...t){return this[al]=!0,super.splice(...t)}push(...t){return this[al]=!0,super.push(...t)}pop(){return this[al]=!0,super.pop()}unshift(...t){return this[al]=!0,super.unshift(...t)}shift(){return this[al]=!0,super.shift()}};NT.prototype.constructor=Array;IT=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var EA={};tt(EA,{CONTEXT:()=>xe,ID_PROPERTY:()=>ze,IS_COLLECTION:()=>si,MultiPartId:()=>$u,RECORD_PROPERTY:()=>Ue,Resource:()=>yr,snake_case:()=>hSe,transformForSelect:()=>DT});function hSe(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function kK(e,t){if(IE=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(IE=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new $u;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){IE=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function Qn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,d,u;if(r?(o?(u=i,o=o[xe]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(u=s,c=u[this.primaryKey]??null,o=i[xe]||i):u=i:(u=s,s=void 0,c=u[ze]??u[this.primaryKey]),c===null&&(d=!0)):i?o=i[xe]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let p=this.parseQuery(c.slice(f+1));l?l=Object.assign(p,l):l=p,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),d=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],d=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,d=!1)))}c===void 0&&(c=s.id??null,c==null&&(d=!0))}else c=s,l=new Vc(c),c===null&&(d=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||d?(_={...t},l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),d&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return wt(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,u,o):f.allowUpdate(o.user,u,o):t.type==="create"?f.allowCreate(o.user,u,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(p=>{if(!p)throw new CT(o.user);return typeof u?.then=="function"?u.then(T=>e(f,l,o,T)):e(f,l,o,u)});if(!h)throw new CT(o.user)}return typeof u?.then=="function"?u.then(h=>e(f,l,o,h)):e(f,l,o,u)}a(E,"authorizeActionOnResource")}}function zn(e,t){let r=new $K.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function Ew(e,t,r){let n=e[Ue];if(n){let s=e[ur];return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function DT(e,t){let r=t?.propertyResolvers,n=t[xe],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):Ew(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let d=[],u=i(Ew(l,r,n));for(let _ of e)d.push(u(_));return d},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let d={},u=i(Ew(l,r,n)),_;for(let E of e){let f=u(E);f===void 0&&o&&(f=null),f?.then?(_||(_=[]),_.push(f.then(h=>d[E.name||E]=h))):d[E.name||E]=f}return _?Promise.all(_).then(()=>d):d},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let u=r[c.name]?.definition?.tableClass;l=s[c.name]=DT(c.select||c,u)}let d=o(c.name);return l(d)}else return o(c);else return c}}a(i,"handleProperty")}var GK,qK,$K,xe,ze,si,Ue,ESe,yr,CT,IE,$u,rs=Ce(()=>{GK=require("crypto");Tl();qK=B(Yi()),$K=B(ce());cm();dc();jf();xe=Symbol.for("context"),ze=Symbol.for("primary-key"),si=Symbol("is-collection"),Ue=Symbol("stored-record"),ESe={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},yr=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[ze]=t;let n=r?.[xe];this[xe]=n!==void 0?n:r||null}static get=Qn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let d=DT(l,t.constructor);return typeof c?.map=="function"?c.map(d):d(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=Qn(function(t,r,n,s){if(Array.isArray(s)&&t[si]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,d=l.getResource(c[l.primaryKey],n,{async:!0});d.then?i.push(d.then(u=>u.put(c,n))):i.push(d.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):zn(t,"put")},{hasContent:!0,type:"update"});static patch=Qn(function(t,r,n,s){return t.patch?t.patch(s,r):zn(t,"patch")},{hasContent:!0,type:"update"});static delete=Qn(function(t,r,n,s){return t.delete?t.delete(r):zn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,GK.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),wt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):zn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=Qn(function(t,r,n,s){return t.invalidate?t.invalidate(r):zn(t,"delete")},{hasContent:!1,type:"update"});static post=Qn(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Qn(function(t,r,n,s){return t.connect?t.connect(s,r):zn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Qn(function(t,r,n,s){return t.subscribe?t.subscribe(r):zn(t,"subscribe")},{type:"read"});static publish=Qn(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.publish?t.publish(s,r):zn(t,"publish")},{hasContent:!0,type:"create"});static search=Qn(function(t,r,n,s){let i=t.search?t.search(r):zn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=DT(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Qn(function(t,r,n,s){return t.search?t.search(s,r):zn(t,"search")},{hasContent:!0,type:"read"});static copy=Qn(function(t,r,n,s){return t.copy?t.copy(s,r):zn(t,"copy")},{hasContent:!0,type:"create"});static move=Qn(function(t,r,n,s){return t.move?t.move(s,r):zn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[si])return(await this.constructor.create(this[ze],t,this[xe]))[ze];zn(this,"post")}static isCollection(t){return t?.[si]}static coerceId(t){return t}static parseQuery(t){return iS(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&ESe[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:kK(t,this),isCollection:IE}}let i=kK(t,this);return IE?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[xe],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let d=l.asMap.get(t);if(s=d?.find(u=>u.constructor===c),s)return s;d||l.asMap.set(t,d=[]),d.push(s=new c(t,i))}else{if(s=l.find(d=>d[ze]===t&&d.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let d=new Map;for(let u of l){let _=u[ze],E=d.get(_);E?E.push(u):d.set(_,[u])}i.resourceCache.length=0,i.resourceCache.asMap=d}}}else s=new c(t,i);return o&&(s[si]=!0),s}subscribe(t){return new In}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new In}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[ze]}getContext(){return this[xe]}};yr.prototype[xe]=null;(0,qK._assignPackageExport)("Resource",yr);a(hSe,"snake_case");CT=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(kK,"pathToId");$u=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(Qn,"transactional");a(zn,"missingMethod");a(Ew,"selectFromObject");a(DT,"transformForSelect")});var RN={};tt(RN,{EVICTED:()=>Ta,INVALIDATED:()=>Li,coerceType:()=>LT,makeTable:()=>vT,setServerUtilities:()=>bSe,updateResource:()=>MT});function vT(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:d,dbisDB:u,sealed:_,replicate:E}=e,{expirationMS:f,evictionMS:h,audit:p,trackDeletes:T}=e,{attributes:g}=e;g||(g=[]);let S=Vg(i,n,l),C,y,x={},F=Promise.resolve(),Y,$,Z;for(let G of g)(G.assignCreatedTime||G.name==="__createdtime__")&&(Y=G),(G.assignUpdatedTime||G.name==="__updatedtime__")&&($=G),G.expiresAt&&(Z=G),G.isPrimaryKey&&(x=G);let Q,_e=[],K=[],se=1,le=2,we={},ve={},et=864e5,va,Ba,bn,Rd=!1,Ad,YE=new Map,zT=new Map,At,Ha,Zn=hd.get(Ls.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(Zn)){for(let G of Zn)if(G.name===c&&G.replicateTo>=0){Ha=G.replicateTo;break}}let Ms=i.getRange({start:!1,end:!1}).constructor,KE=10,Uw=6;p&&ge();class ye extends yr{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=p;static databasePath=o;static databaseName=c;static attributes=g;static replicate=E;static sealed=_;static createdTimeProperty=Y;static updatedTimeProperty=$;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return f}static dbisDB=u;static schemaDefined=d;static sourcedFrom(m,R){if(R&&(this.sourceOptions=R,(R.expiration||R.eviction||R.scanInterval)&&this.setTTLExpiration(R)),R?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(w=>!w.intermediateSource))throw new Error("Can not have multiple canonical (non-intermediate) sources");this.sources.push(m)}y=y||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),C=C||m.load;let O=a(w=>{let N=this.sources;if(N=N.filter(v=>v.intermediateSource&&v[w]&&(!v[w].reliesOnPrototype||v.prototype[w])),N.length>0)if(N.length===1){let v=N[0];return(U,L,P)=>{if(U?.source!==v)return v[w](L,P,U)}}else return(v,U,L)=>{let P=[];for(let H of N){if(v?.source===H)break;P.push(H[w](U,L,v))}return Promise.all(P)}},"getApplyToIntermediateSource"),A=this.sources[this.sources.length-1];A.intermediateSource&&(A={});let I=a(w=>{if(A[w]&&(!A[w].reliesOnPrototype||A.prototype[w]))return(N,v,U)=>{if(!N?.source)return A[w](v,U,N)}},"getApplyToCanonicalSource");return we={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish")},ve={put:O("put"),patch:O("patch"),delete:O("delete"),publish:O("publish"),invalidate:O("invalidate")},(async()=>{let w=!1,N,v=a(async(U,L)=>{let P=U.value,H=U.table?Ve[c][U.table]:ye;if(c===Ls.SYSTEM_SCHEMA_NAME&&(U.table===Ls.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||U.table===Ls.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(w=!0),U.id===void 0&&(U.id=P[H.primaryKey],U.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(U));U.source=m;let k={residencyId:Te(U.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:U.nodeId},ue=await H.getResource(U.id,L,k);switch(U.type){case"put":return ue._writeUpdate(P,!0,k);case"patch":return ue._writeUpdate(P,!1,k);case"delete":return ue._writeDelete(k);case"publish":return ue._writePublish(P,k);case"invalidate":return ue._writeInvalidate(k);case"relocate":return ue._writeRelocate(k);default:Ye.default.error?.("Unknown operation",U.type,U.id)}},"writeUpdate");try{let U=m.subscribe;U&&T==null&&(T=!0);let L=m.subscribeOnThisThread?m.subscribeOnThisThread((0,ul.getWorkerIndex)()):(0,ul.getWorkerIndex)()===0,P=U&&L&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(P){let H;for await(let k of P)try{if(!(k.type==="transaction"?k.writes[0]:k)){Ye.default.error?.("Bad subscription event",k);continue}if(k.source=m,k.type==="end_txn"){if(H?.resolve(),k.localTime&&N!==k.localTime){if(k.remoteNodeIds?.length>0){let Ne=[Symbol.for("seq"),k.remoteNodeIds[0]],fe=u.get(Ne),he=fe?.nodes;he||(he=[]);for(let z of k.remoteNodeIds.slice(1)){let Re=he.find(ke=>ke.name===z);Re||(Re={id:z,seqId:0},he.push(Re)),Re.seqId=Math.max(fe?.seqId??1,k.localTime),z===k.nodeId&&(Re.lastTxnTime=k.timestamp)}let ne=Math.max(fe?.seqId??1,k.localTime);Ye.default.trace?.("Received txn",c,ne,k.localTime,k.remoteNodeIds),u.put(Ne,{seqId:ne,nodes:he})}N=k.localTime}k.onCommit&&H?.committed.then(k.onCommit);continue}if(H)if(k.beginTxn)H.resolve();else{H.write_promises.push(v(k,H));continue}let X=wt(k,()=>{if(k.type==="transaction"){let Ne=[];for(let fe of k.writes)try{Ne.push(v(fe,k))}catch(he){throw he.message+=" writing "+JSON.stringify(fe)+" of event "+JSON.stringify(k),he}return Promise.all(Ne)}else if(k.type==="define_schema"){let Ne=this.attributes.slice(0),fe;for(let he of k.attributes)Ne.find(ne=>ne.name===he.name)||(Ne.push(he),fe=!0);fe&&(ft({table:s,database:c,attributes:Ne,origin:"cluster"}),LE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,Ls.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return k.beginTxn?(H=k,H.write_promises=[v(k,k)],new Promise(Ne=>{H.resolve=()=>Ne(Promise.all(H.write_promises))})):v(k,k)});H&&(H.committed=X),w&&X&&!X?.waitingForUserChange&&(X.then(()=>LE.signalUserChange(new ME.UserEventMsg(process.pid))),X.waitingForUserChange=!0),k.onCommit&&(X?X.then(k.onCommit):k.onCommit())}catch(ue){Ye.default.error?.("error in subscription handler",ue)}}}catch(U){Ye.default.error?.(U)}})(),this}static getResource(m,R,O){let A=super.getResource(m,R,O);if(m!=null){oi(m);try{if(A.hasOwnProperty(Ue))return A;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let I=!O?.async||i.cache?.get(m),w=Gr(R),N=w.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return hl(m,R,{transaction:N,ensureLoaded:O?.ensureLoaded},I,v=>{if(v?MT(A,v):A[Ue]=null,R.onlyIfCached&&R.noCacheStore){if(!A.doesExist())throw new kr.ServerError("Entry is not cached",504)}else if(O?.ensureLoaded){let U=Fa(m,v,R,A);if(U)return w?.disregardReadTxn(),A[hw]=!0,pw(U,L=>(MT(A,L),A))}return A})}catch(I){throw I.message.includes("Unable to serialize object")&&(I.message+=": "+JSON.stringify(m)),I}}return A}ensureLoaded(){let m=Fa(this[ze],this[Fr],this[xe]);if(m)return this[hw]=!0,pw(m,R=>{this[Fr]=R,this[Ue]=R.value,this[DE]=R.version})}static getNewId(){let m=x?.type;if(m==="String"||m==="ID")return super.getNewId();if(!At){let I=i.getEntry(Symbol.for("id_allocation")),w=I?.value,N;if(w&&w.nodeName===server.hostname&&(!NSe(i)||w.pid===process.pid)){let v=w.start,U=w.end;N=v;for(let L of i.getKeys({start:U,end:v,limit:1,reverse:!0}))N=L}else w=A(I?.version??null),N=w.start;At=new BigInt64Array([BigInt(N)+1n]),At=new BigInt64Array(i.getUserSharedBuffer("id",At.buffer)),At.maxSafeId=w.end}let R=Number(Atomics.add(At,0,1n)),O=m==="Int"?512:1048576;if(R+O>=At.maxSafeId){let I=a(w=>{At.maxSafeId=R+(m==="Int"?1023:4194303);let N=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,v=w?void 0:i.useReadTransaction(),U=Number(At[0]);for(let H of i.getKeys({start:U+1,end:N,limit:1,transaction:v}))N=H;v?.done();let{value:L,version:P}=i.getEntry(Symbol.for("id_allocation"));if(At.maxSafeId<N){if(L.end>At.maxSafeId-100)return;Ye.default.info?.("New id allocation",R,At.maxSafeId,P),i.put(Symbol.for("id_allocation"),{start:L.start,end:At.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),P)}else{Ye.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${At.maxSafeId}, but id of ${N} detected`);let H=A(P);H.alreadyUpdated||Atomics.store(At,0,BigInt(H.start+1)),At.maxSafeId=H.end}},"updateEnd");R+O===At.maxSafeId?setImmediate(I):R+100>=At.maxSafeId&&(Ye.default.warn?.(`Synchronous id allocation required on table ${s}${m=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>I(!0)))}return R;function A(I){let w=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,N=w/4,v,U,L=!1,P,H;do{P=Math.floor(Math.random()*w),H={start:P,end:P+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},v=0;for(let k of i.getKeys({start:P,limit:1,reverse:!0}))v=k;U=w;for(let k of i.getKeys({start:P+1,end:w,limit:1}))U=k;N*=.875,N<1e3&&!L&&(L=!0,Ye.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":""}`,P,v,U,N))}while(!(N<U-P&&(N<P-v||v===0)));return i.transactionSync(()=>{let k=i.getEntry(Symbol.for("id_allocation"));return(k?.version??null)==I?(Ye.default.info?.("Allocated new id range",H),i.put(Symbol.for("id_allocation"),H,Date.now()),H):(Ye.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...k.value})})}}static setTTLExpiration(m){if(typeof m=="number")f=m*1e3,h||(h=0);else if(m&&typeof m=="object")f=m.expiration*1e3,h=(m.eviction||0)*1e3,et=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(f<0)throw new Error("Expiration can not be negative");et=et||(f+h)/4,re()}static getResidencyRecord(m){return u.get([Symbol.for("residency_by_id"),m])}static setResidency(m){ye.getResidency=m}static setResidencyById(m){ye.getResidencyById=m}static getResidency(m,R,O){if(ye.getResidencyById)return ye.getResidencyById(m[t]);let A=Ha;if(R.replicateTo!=null){if(Array.isArray(R.replicateTo))return R.replicateTo.includes(server.hostname)?R.replicateTo:[server.hostname,...R.replicateTo];R.replicateTo>=0&&(A=R.replicateTo)}if(A>=0&&server.nodes){let I=[server.hostname];if(O)I.push(...O.slice(0,A));else{let w=server.nodes.map(U=>U.name),N=Math.floor(w.length*Math.random());I.push(...w.slice(N,N+A));let v=N+A-w.length;v>0&&I.push(...w.slice(0,v))}return I}}static enableAuditing(m=!0){p=m,m&&ge(),ye.audit=m}static coerceId(m){return m===""?null:LT(m,x)}static async dropTable(){if(delete Ve[c][s],c===o){for(let m of g)u.remove(ye.tableName+"/"+m.name),r[m.name]?.drop();u.remove(ye.tableName+"/"),i.drop(),await u.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));LE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,Ls.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[si])return this.search(m);if(this[ze]===null){if(m?.conditions)return this.search(m);let R=ye.getRecordCount();return{recordCount:R.recordCount,estimatedRecordRange:R.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:g}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[xe]?.returnNonexistent)return this}allowRead(m,R){let O=ml(m);if(O?.read){if(O.isSuperUser)return!0;let A=O.attribute_permissions,I=R?.select;if(A?.length>0||Rd&&I){if(R||(R={}),I){let w=A?.length>0&&mw(A,"read");R.select=I.map(N=>{let v=N.name||N;if(!w||w[v]){let U=bn[v]?.definition?.tableClass;if(U){if(N.name||(N={name:N}),!U.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else R.select=A.filter(w=>w.read&&!bn[w.attribute_name]).map(w=>w.attribute_name);return R}else return!0}}allowUpdate(m,R){let O=ml(m);if(O?.update){let A=O.attribute_permissions;if(A?.length>0){let I=mw(A,"update");for(let w in R)if(!I[w])return!1;for(let w of A){let N=w.attribute_name;!w.update&&!(N in R)&&(R[N]=this.getProperty(N))}}return Po(this[xe])}}allowCreate(m,R){if(this[si]){let O=ml(m);if(O?.insert){let A=O.attribute_permissions;if(A?.length>0){let I=mw(A,"insert");for(let w in R)if(!I[w])return!1;return Po(this[xe])}else return Po(this[xe])}}else return this.allowUpdate(m,{})}allowDelete(m){return ml(m)?.delete&&Po(this[xe])}update(m,R){if(!Gr(this[xe]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let A;return typeof m=="object"&&m&&(R?(Object.isFrozen(m)&&(m={...m}),this[Ue]={},this[ur]=m):(A=this[ur],A&&(m=Object.assign(A,m)),this[ur]=A=m)),this._writeUpdate(this[ur],R),this}addTo(m,R){if(typeof R=="number"||typeof R=="bigint")this[wE]===YK?this.set(m,(+this.getProperty(m)||0)+R):(this[wE]||this.update(),this.set(m,new IT(R)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,R){if(typeof R=="number")return this.addTo(m,-R);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Fr]}invalidate(){this._writeInvalidate()}_writeInvalidate(m){let R=this[xe],O=this[ze];oi(O),Gr(this[xe]).addWrite({key:O,store:i,invalidated:!0,entry:this[Fr],before:we.invalidate?.bind(this,R,O),beforeIntermediate:ve.invalidate?.bind(this,R,O),commit:(I,w)=>{if(Ga(I,w,m?.nodeId))return;let N=null;for(let v in r)N||(N={}),N[v]=this.getProperty(v);Ye.default.trace?.(`Invalidating entry id: ${O}, timestamp: ${new Date(I).toISOString()}`),S(O,N,this[Fr],I,Li,p,{user:R?.user,residencyId:m?.residencyId,nodeId:m?.nodeId},"invalidate")}})}_writeRelocate(m){let R=this[xe],O=this[ze];oi(O),Gr(this[xe]).addWrite({key:O,store:i,invalidated:!0,entry:this[Fr],before:we.relocate?.bind(this,R,O),beforeIntermediate:ve.relocate?.bind(this,R,O),commit:(I,w)=>{if(Ga(I,w,m?.nodeId))return;let N=ye.getResidencyRecord(m.residencyId),v=0,U=null,L=w?.value;if(N&&!N.includes(server.hostname)){for(let P in r)U||(U={}),U[P]=L(P);v=Li}else U=L;Ye.default.trace?.(`Relocating entry id: ${O}, timestamp: ${new Date(I).toISOString()}`),S(O,U,this[Fr],I,v,p,{user:R.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)}})}static _recordRelocate(m,R){let O={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},A=this.getResidency(R.value,O),I;if(A){if(!Array.isArray(A))throw new Error("Residency must be an array, but was: "+A);if(!A.includes(server.hostname))return;I=Te(A)}let N=S(m.key,R.value,m,m.version,0,!0,{residencyId:I,expiresAt:R.expiresAt},"relocate",!1,null)}static evict(m,R,O){let A=this.Source,I;if(!((y||p)&&(!R||(I=i.getEntry(m),!I||!R)||I.version!==O))){if(y){if(i.hasLock(m,I.version))return;let w;for(let N in r)w||(w={}),w[N]=R[N];if(w)return S(m,w,I,O,Ta,null,null,null,!0)}return i.ifVersion(m,O,()=>{xa(m,R,null)}),p?S(m,null,I,O,Ta,null,null,null,!0):i.remove(m,O)}}lock(){throw new Error("Not yet implemented")}static operation(m,R){return m.table||=s,m.schema||=c,XK.operation(m,R)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,R,O){let A=this[xe],I=Gr(A),w=this[ze];oi(w);let N=this[Fr];this[wE]=R?YK:RSe;let v={key:w,store:i,entry:N,nodeName:A?.nodeName,validate:U=>{m||(m=this[ur]),R||m&&yT(this[ur]===m?this:m)?A?.source||(I.checkOverloaded(),this.validate(m,!R),$&&(m[$.name]=$.type==="Date"?new Date(U):$.type==="String"?new Date(U).toISOString():U),R&&(t&&m[t]!==w&&(m[t]=w),Y&&(N?.value?m[Y.name]=N?.value[Y.name]:m[Y.name]=Y.type==="Date"?new Date(U):Y.type==="String"?new Date(U).toISOString():U),m=cl(m))):I.removeWrite(v)},before:R?we.put?()=>we.put(A,w,m):null:we.patch?()=>we.patch(A,w,m):we.put?()=>we.put(A,w,cl(this)):null,beforeIntermediate:R?ve.put?()=>ve.put(A,w,m):null:ve.patch?()=>ve.patch(A,w,m):ve.put?()=>ve.put(A,w,cl(this)):null,commit:(U,L,P)=>{if(P){if(A&&L?.version>(A.lastModified||0)&&(A.lastModified=L.version),this[Fr]=L,L?.value?.[Ue])throw new Error("Can not assign a record to a record, check for circular references");R||(this[Ue]=L?.value??null)}this[ur]=void 0,this[DE]=U;let H=L?.value,k=m;if(this[wE]=0,Ga(U,L,O?.nodeId))if(p){let z=L.localTime,Re=L.version;for(;k&&(z>U||Re>=U&&z>0);){let ke=l.get(z);if(!ke)break;let Kt=Ht(ke);if(Re=Kt.version,Re>U){if(Kt.type==="patch"){let me=Kt.getValue(i);k=OT(k,me)}else if(Kt.type==="put"||Kt.type==="delete")return}else if(Re===U)return;z=Kt.previousLocalTime}}else{if(R)return;k=OT(k,H)}let X;if(R?X=k:(this[Ue]=H,X=R?k:cl(this,k)),this[Ue]=X,X?.[Ue])throw new Error("Can not assign a record to a record, check for circular references");let Ne,fe;if(O?.residencyId!=null)fe=O.residencyId;else{N?.residencyId&&(A.previousResidency=ye.getResidencyRecord(N.residencyId));let z=ye.getResidency(X,A);if(z){if(!Array.isArray(z))throw new Error("Residency must be an array, got: "+z);z.includes(server.hostname)||z.push(server.hostname)}fe=Te(z)}R||(Ne=m);let he=A?.expiresAt??(f?f+Date.now():-1);Ye.default.trace?.(`Saving record with id: ${w}, timestamp: ${new Date(U).toISOString()}${he?", expires at: "+new Date(he).toISOString():""}${L?", replaces entry from: "+new Date(L.version).toISOString():", new entry"}`),xa(w,H,X);let ne=R?"put":"patch";S(w,X,L,U,0,p,{user:A?.user,residencyId:fe,expiresAt:he,nodeId:O?.nodeId,originatingOperation:A?.originatingOperation},ne,!1,Ne),A.expiresAt&&re()}};I.addWrite(v)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[si]){for await(let R of this.search(m))(await ye.getResource(R[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[Ue]?this._writeDelete(m):!1}_writeDelete(m){let R=Gr(this[xe]),O=this[ze];oi(O);let A=this[xe];return R.addWrite({key:O,store:i,resource:this,nodeName:A?.nodeName,before:we.delete?.bind(this,A,O),beforeIntermediate:ve.delete?.bind(this,A,O),commit:(I,w,N)=>{let v=w?.value;N&&(A&&w?.version>(A.lastModified||0)&&(A.lastModified=w.version),MT(this,w)),!Ga(I,w,m?.nodeId)&&(xa(this[ze],v),Ye.default.trace?.(`Deleting record with id: ${O}, txn timestamp: ${new Date(I).toISOString()}`),p||T?(S(O,null,this[Fr],I,0,p,{user:A?.user,nodeId:m?.nodeId},"delete"),p||re()):i.remove(this[ze]))}}),!0}search(m){let R=this[xe],O=Gr(R);if(!m)throw new Error("No query provided");let A=m.conditions;A?A.length===void 0&&(A=A[Symbol.iterator]?Array.from(A):[A]):A=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[ze]&&(A=[{attribute:null,comparator:"prefix",value:this[ze]}].concat(A));let I,w={};function N(z,Re){let ke;switch(Re){case"and":case void 0:if(z.length<1)throw new Error('An "and" operator requires at least one condition');ke=!0;break;case"or":if(z.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+Re)}let Kt=ke&&{},me;for(let Oe of z){if(Oe.conditions){Oe.conditions=N(Oe.conditions,Oe.operator);continue}let Ke=Oe[0]??Oe.attribute,Xe=Ke==null?x:Pi(g,Ke);if(Xe){if(ke){let We=Qs(Ke),at=Kt[We];at?(at.push(Oe),me=!0):Kt[We]=[Oe]}(Xe.type||jy[Oe.comparator])&&(Oe[1]===void 0?Oe.value=U(Oe.value,Xe):Oe[1]=U(Oe[1],Xe))}else if(Ke!=null)throw(0,kr.handleHDBError)(new Error,`${Ke} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return z;if(me)for(let Oe in Kt){let Ke=Kt[Oe],Xe=Ke.length;if(Xe>1)for(let We=0;We<Xe;We++){let at=Ke[We];if(at.comparator==="ge"||at.comparator==="greater_than_equal")for(let Sr=0;Sr<Xe;Sr++){let qr=Ke[Sr];(qr.comparator==="le"||qr.comparator==="less_than_equal")&&(at.comparator="between",at.value=[at.value,qr.value],z.splice(z.indexOf(qr),1))}if(at.comparator==="equals"||!at.comparator){for(let Sr=0;Sr<Xe;Sr++)if(Sr!==We){let qr=Ke[Sr];z.splice(z.indexOf(qr),1)}break}}}return z}a(N,"prepareConditions");function v(z,Re){if(m.enforceExecutionOrder)return z;for(let ke of z)ke.conditions&&(ke.conditions=v(ke.conditions,ke.operator));return z.length>1&&Re!=="or"?(0,JK.sortBy)(z,sS(ye)):z}a(v,"orderConditions");function U(z,Re){return Array.isArray(z)?z.map(ke=>LT(ke,Re)):LT(z,Re)}a(U,"coerceTypedValues");let L=m.operator;(A.length>0||L)&&(A=N(A,L));let P=typeof m.sort=="object"&&m.sort,H;if(P&&L!=="or"){let z=P.attribute;if(I=A.find(Re=>Qs(Re.attribute)===Qs(z)),!I){let Re=Pi(g,z);if(!Re)throw(0,kr.handleHDBError)(new Error,`${Array.isArray(z)?z.join("."):z} is not a defined attribute`,404);if(Re.indexed)I={attribute:z,comparator:"sort"},A.push(I);else if(A.length===0&&!m.allowFullScan)throw(0,kr.handleHDBError)(new Error,`${Array.isArray(z)?z.join("."):z} is not indexed and not combined with any other conditions`,404)}I&&(I.descending=!!P.descending)}A=v(A,L),P&&(I&&A[0]===I?P.next&&(H={dbOrderedAttribute:P.attribute,attribute:P.next.attribute,descending:P.next.descending,next:P.next.next}):(I&&A.splice(A.indexOf(I),1),H=P));let k=m.select;if(A.length===0&&(A=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:A,operator:L,postOrdering:H,selectApplied:!!k};let ue=O.useReadTxn(),X=Qy(A,L,ye,ue,m,R,(z,Re)=>ka(z,k,R,ue,Re),w),Ne=m.ensureLoaded!==!1;H||(X=ne(X));let fe=ye.transformEntryForSelect(k,R,ue,w,Ne,!0),he=ye.transformToOrderedSelect(X,k,H,ue,R,fe);function ne(z){return m.offset||m.limit!==void 0?z.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):z}return a(ne,"applyOffset"),H&&(he=ne(he)),he.onDone=()=>{he.onDone=null,O.doneReadTxn()},he.selectApplied=!0,he.getColumns=()=>{if(k){let z=[];for(let Re of k)Re==="*"?z.push(...g.map(ke=>ke.name)):z.push(Re.name||Re);return z}return g.filter(z=>!z.computed&&!z.relationship).map(z=>z.name)},he}static transformToOrderedSelect(m,R,O,A,I,w){let N=new Ms;if(O){m=ka(m,R,A,I,null);let v;N.iterate=function(){let L,P=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),H,k=O.dbOrderedAttribute,ue,X,Ne=!0;function fe(ne){let z=ne.next&&fe(ne.next),Re=ne.descending;return(ke,Kt)=>{let me=pl(ke,ne.attribute,A),Oe=pl(Kt,ne.attribute,A),Ke=Re?(0,dl.compareKeys)(Oe,me):(0,dl.compareKeys)(me,Oe);return Ke===0?z?.(ke,Kt)||0:Ke}}a(fe,"createComparator");let he=fe(O);return{async next(){let ne;if(L)if(ne=L.next(),ne.done){if(H)return N.onDone&&N.onDone(),ne}else return{value:await w.call(this,ne.value)};v=[],ue&&v.push(ue);do if(ne=await P.next(),ne.done){if(H=!0,v.length)break;return N.onDone&&N.onDone(),ne}else{let z=ne.value;if(z?.then&&(z=await z),k){let Re=pl(z,k,A);if(Ne)Ne=!1,X=Re;else if(Re!==X){X=Re,ue=z;break}}v.push(z)}while(!0);return O.isGrouped,v.sort(he),L=v[Symbol.iterator](),ne=L.next(),ne.done?(N.onDone&&N.onDone(),ne):{value:await w.call(this,ne.value)}},return(){N.onDone&&N.onDone(),P.return()},throw(){N.onDone&&N.onDone(),P.throw()}}};let U=a(L=>{if(typeof R=="object"&&Array.isArray(L.attribute))for(let P=0;P<R.length;P++){let H=R[P],k;if(H.name===L.attribute[0]){for(k=H.sort||(H.sort={});k.next;)k=k.next;k.attribute=L.attribute.slice(1),k.descending=L.descending}else H===L.attribute[0]&&(R[P]=k={name:H,sort:{attribute:L.attribute.slice(1),descending:L.descending}})}L.next&&U(L.next)},"applySortingOnSelect");U(O)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(function(v){try{let U=w.call(this,v);return typeof U?.catch=="function"?U.catch(L=>{throw L.partialObject={[t]:v.key},L}):U}catch(U){throw U.partialObject={[t]:v.key},U}});return N}static transformEntryForSelect(m,R,O,A,I,w){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let L=a(P=>(R?.transaction?.stale&&(R.transaction.stale=!1),P?.key??P),"transform");return m===t?L:m.asArray?P=>[L(P)]:P=>({[t]:L(P)})}let N;I&&y&&!(typeof m=="string"?[m]:m)?.every(L=>{let P;return typeof L=="object"?P=L.name:P=L,r[P]||P===t})&&(N=!0);let v,U=a(function(L){let P;if(R?.transaction?.stale&&(R.transaction.stale=!1),L!=null){if(P=L.value||L.deref?.(),!P&&(L.key===void 0||L.deref)){if(L=hl(L.key??L,R,{transaction:O,lazy:m?.length<4},this?.isSync,H=>H),L?.then)return L.then(U.bind(this));P=L?.value}if(N&&L?.metadataFlags&(Li|Ta)||L?.expiresAt!=null&&L?.expiresAt<Date.now()){let H=Fa(L.key??L,L,R);if(H?.then)return H.then(U)}}if(P==null)return w?ll.SKIP:P;if(m&&!(m[0]==="*"&&m.length===1)){let H,k=a((X,Ne)=>{let fe;typeof X=="object"?fe=X.name:fe=X;let he=bn?.[fe],ne;if(he){let z=A?.[fe];if(z)if(z.hasMappings){let ke=he.from?P[he.from]:Qs(L.key);ne=z.get(ke),ne||(ne=[])}else ne=z.fromRecord?.(P);else ne=he(P,R,L);let Re=a(ke=>{if(ke&&typeof ke=="object"){let Kt=he.definition?.tableClass||ye;v||(v={});let me=v[fe]||(v[fe]=Kt.transformEntryForSelect(fe===X?null:X.select||(Array.isArray(X)?X:null),R,O,z,I));if(Array.isArray(ke)){let Oe=[],Ke=Kt.transformToOrderedSelect(ke,X.select,typeof X.sort=="object"&&X.sort,R,O,me)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Xe=a(at=>{for(;!at.done;){if(at?.then)return at.then(Xe);Oe.push(at.value),at=Ke.next()}Ne(Oe,fe)},"nextValue"),We=Xe(Ke.next());We&&(H||(H=[]),H.push(We));return}else if(ke=me.call(this,ke),ke?.then){H||(H=[]),H.push(ke.then(Oe=>Ne(Oe,fe)));return}}Ne(ke,fe)},"handleResolvedValue");ne?.then?(H||(H=[]),H.push(ne.then(Re))):Re(ne);return}else ne=P[fe],ne&&typeof ne=="object"&&fe!==X&&(ne=ye.transformEntryForSelect(X.select||X,R,O,null)({value:ne}));Ne(ne,fe)},"selectAttribute"),ue;if(typeof m=="string")k(m,X=>{ue=X});else if(Array.isArray(m))if(m.asArray)ue=[],m.forEach((X,Ne)=>{X==="*"?m[Ne]=P:k(X,fe=>ue[Ne]=fe)});else{ue={};let X=m.forceNulls;for(let Ne of m)if(Ne==="*")for(let fe in P)ue[fe]=P[fe];else k(Ne,(fe,he)=>{fe===void 0&&X&&(fe=null),ue[he]=fe})}else throw new kr.ClientError("Invalid select"+m);return H?Promise.all(H).then(()=>ue):ue}return P},"transform");return U}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");p||ft({table:s,database:c,schemaDefined:d,attributes:g,audit:!0}),m||(m={});let R=!m.rawEvents,O=[],A=SO(ye,this[ze]??null,function(w,N,v,U){try{let L=N.getValue?.(i,R),P=N.type;if(!L&&N.type==="patch"&&R){let k=i.getEntry(w);k?.version===N.version?L=k.value:L=N.getValue?.(i,!0,v),P="put"}let H={id:w,timestamp:v,value:L,version:N.version,type:P,beginTxn:U};O?O.push(H):this.send(H)}catch(L){Ye.default.error?.(L)}},m.startTime||0,m),I=(async()=>{this[si]&&(A.includeDescendants=!0,m.onlyChildren&&(A.onlyChildren=!0)),m.supportsTransactions&&(A.supportsTransactions=!0);let w=this[ze],N=m.previousCount;N>1e3&&(N=1e3);let v=m.startTime;if(this[si]){if(v){if(N)throw new kr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:U,value:L}of l.getRange({start:v,exclusiveStart:!0,snapshot:!1})){let P=Ht(L);if(P.tableId!==n)continue;let H=P.recordId;if(w==null||QK(w,H)){let k=P.getValue(i,R,U);if(A.send({id:H,timestamp:U,value:k,version:P.version,type:P.type}),A.queue?.length>WK&&await A.waitForDrain()===!1)return}A.startTime=U}}else if(N){let U=[];for(let{key:L,value:P}of l.getRange({start:"z",end:!1,reverse:!0}))try{let H=Ht(P);if(H.tableId!==n)continue;let k=H.recordId;if(w==null||QK(w,k)){let ue=H.getValue(i,R,L);if(U.push({id:k,timestamp:L,value:ue,version:H.version,type:H.type}),--N<=0)break}}catch(H){Ye.default.error("Error getting history entry",L,H)}for(let L=U.length;L>0;)A.send(U[--L]);U[0]&&(A.startTime=U[0].timestamp)}else if(!m.omitCurrent){for(let{key:U,value:L,version:P,localTime:H}of i.getRange({start:w??!1,end:w==null?void 0:[w,dl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(L&&(A.send({id:U,timestamp:H,value:L,version:P,type:"put"}),A.queue?.length>WK&&await A.waitForDrain()===!1))return}}else{N&&!v&&(v=0);let U=this[Fr]?.localTime;if(U===$g&&(i.cache?.delete(w),this[Fr]=i.getEntry(w),Ye.default.trace?.("re-retrieved record",U,this[Fr]?.localTime),U=this[Fr]?.localTime),Ye.default.trace?.("Subscription from",v,"from",w,U),v<U){let L=[],P=U;do{let H=l.get(P);if(H){m.omitCurrent=!0;let k=Ht(H),ue=k.getValue(i,R,P);R&&(k.type="put"),L.push({id:w,value:ue,timestamp:P,...k}),P=k.previousLocalTime}else break;N&&N--}while(P>v&&N!==0);for(let H=L.length;H>0;)A.send(L[--H]);A.startTime=U}!m.omitCurrent&&this.doesExist()&&A.send({id:w,timestamp:U,value:this[Ue],version:this[DE],type:"put"})}for(let U of O)A.send(U);O=null})();return m.listener&&A.on("data",m.listener),A}doesExist(){return!!(this[Ue]||this[wE])}publish(m,R){this._writePublish(m,R)}_writePublish(m,R){let O=Gr(this[xe]),A=this[ze]||null;A!=null&&oi(A);let I=this[xe];O.addWrite({key:A,store:i,entry:this[Fr],nodeName:I?.nodeName,validate:()=>{I?.source||(O.checkOverloaded(),this.validate(m))},before:we.publish?.bind(this,I,A,m),beforeIntermediate:ve.publish?.bind(this,I,A,m),commit:(w,N,v)=>{N===void 0&&T&&!p&&re(),Ye.default.trace?.(`Publishing message to id: ${A}, timestamp: ${new Date(w).toISOString()}`),S(A,N?.value??null,N,N?.version||w,0,!0,{user:I?.user,residencyId:R?.residencyId,expiresAt:I?.expiresAt,nodeId:R?.nodeId},"message",!1,m)}})}validate(m,R){let O,A=a((I,w,N)=>{if(w.type&&I!=null)if(R&&I.__op__&&(I=I.value),w.properties){typeof I!="object"&&(O||(O=[])).push(`Value ${ii(I)} in property ${N} must be an object${w.type?" ("+w.type+")":""}`);let v=w.properties;for(let U=0,L=v.length;U<L;U++){let P=v[U],H=A(I[P.name],P,N+"."+P.name);H&&(I[P.name]=H)}if(w.sealed&&I!=null&&typeof I=="object")for(let U in I)v.find(L=>L.name===U)||(O||(O=[])).push(`Property ${U} is not allowed within object in property ${N}`)}else switch(w.type){case"Int":(typeof I!="number"||I>>0!==I)&&(O||(O=[])).push(`Value ${ii(I)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof I!="number"||!(Math.floor(I)===I&&Math.abs(I)<=9007199254740992))&&(O||(O=[])).push(`Value ${ii(I)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof I!="number"&&(O||(O=[])).push(`Value ${ii(I)} in property ${N} must be a number`);break;case"ID":typeof I=="string"||I?.length>0&&I.every?.(v=>typeof v=="string")||(O||(O=[])).push(`Value ${ii(I)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof I!="string"&&(O||(O=[])).push(`Value ${ii(I)} in property ${N} must be a string`);break;case"Boolean":typeof I!="boolean"&&(O||(O=[])).push(`Value ${ii(I)} in property ${N} must be a boolean`);break;case"Date":if(!(I instanceof Date)){if(typeof I=="string"||typeof I=="number")return new Date(I);(O||(O=[])).push(`Value ${ii(I)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof I!="bigint"){if(typeof I=="string"||typeof I=="number")return BigInt(I);(O||(O=[])).push(`Value ${ii(I)} in property ${N} must be a bigint`)}break;case"Bytes":I instanceof Uint8Array||(O||(O=[])).push(`Value ${ii(I)} in property ${N} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(I)){if(w.elements)for(let v=0,U=I.length;v<U;v++){let L=I[v],P=A(L,w.elements,N+"[*]");P&&(I[v]=P)}}else(O||(O=[])).push(`Value ${ii(I)} in property ${N} must be a Buffer or Uint8Array`);break}w.nullable===!1&&I==null&&(O||(O=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let I=0,w=g.length;I<w;I++){let N=g[I];if(!(N.relationship||N.computed)&&(!R||N.name in m)){let v=A(m[N.name],N,N.name);v&&(m[N.name]=v)}}if(_)for(let I in m)g.find(w=>w.name===I)||(O||(O=[])).push(`Property ${I} is not allowed`);if(O)throw new kr.ClientError(O.join(". "))}getUpdatedTime(){return this[DE]}wasLoadedFromSource(){return y?!!this[hw]:void 0}static async addAttributes(m){let R=g.slice(0);for(let O of m){if(!O.name)throw new kr.ClientError("Attribute name is required");if(O.name.match(/[`/]/))throw new kr.ClientError("Attribute names cannot include backticks or forward slashes");R.push(O)}return ft({table:s,database:c,schemaDefined:d,attributes:R}),ye.indexingOperation}static async removeAttributes(m){let R=g.filter(O=>!m.includes(O.name));return ft({table:s,database:c,schemaDefined:d,attributes:R}),ye.indexingOperation}static getRecordCount(m){let R=i.getStats().entryCount,O=1e3/2,A=performance.now(),I=Math.floor(R/2),w=m?.exactCount,N=0,v=0,U;for(let{value:L}of i.getRange({start:!0,lazy:!0}))if(L!=null&&N++,v++,!w&&v<I&&performance.now()-A>O){U=v;break}if(U){let L=N;N=0;for(let{value:ne}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:U}))ne!=null&&N++;let P=U*2,H=(N+L)/P,k=Math.pow((N-L+1)/U/2,2)+H*(1-H)/P,ue=Math.max(Math.sqrt(k)*R,1),X=Math.round(H*R),Ne=Math.max(X-1.96*ue,N+L),fe=Math.min(X+1.96*ue,R),he=Math.pow(10,Math.round(Math.log10(ue)));return he>X&&(he=he/10),N=Math.round(X/he)*he,{recordCount:N,estimatedRange:[Math.round(Ne),Math.round(fe)]}}return{recordCount:N}}static updatedAttributes(){bn=this.propertyResolvers={$id:(m,R,O)=>({value:O.key}),$updatedtime:(m,R,O)=>O.version,$record:(m,R,O)=>O?{value:m}:m};for(let m of this.attributes){m.resolve=null;let R=m.relationship,O=m.computed;if(R)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),O&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),Rd=!0,R.to)m.elements?.definition?(bn[m.name]=m.resolve=(A,I,w)=>{let N=A[R.from?R.from:t],v=m.elements.definition.tableClass;return w?qu({attribute:R.to,value:N},Gr(I).getReadTxn(),!1,v,!1).asArray:v.search([{attribute:R.to,value:N}],I).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,R.from&&(m.resolve.from=R.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(R.from){let A=m.definition||m.elements?.definition;A?(bn[m.name]=m.resolve=(I,w,N)=>{let v=I[R.from];if(v!==void 0){if(m.elements){let U,L=v.map(P=>{let H=N?A.tableClass.primaryStore.getEntry(P,{transaction:Gr(w).getReadTxn()}):A.tableClass.get(P,w);return H?.then&&(U=!0),H});return R.filterMissing?U?Promise.all(L).then(P=>P.filter(zK)):L.filter(zK):U?Promise.all(L):L}return N?A.tableClass.primaryStore.getEntry(v,{transaction:Gr(w).getReadTxn()}):A.tableClass.get(v,w)}},m.set=(I,w)=>{if(Array.isArray(w)){let N=w.map(v=>v[ze]||v[A.tableClass.primaryKey]);I[R.from]=N}else{let N=w[ze]||w[A.tableClass.primaryKey];I[R.from]=N}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=R.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else O&&(typeof O.from=="function"&&this.setComputedAttribute(m.name,O.from),bn[m.name]=m.resolve=(A,I,w)=>{let N=typeof O.from=="string"?A[O.from]:A,v=this.userResolvers[m.name];if(v)return v(N,I,w);Ye.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]=()=>{}})}wT(this,this)}static setComputedAttribute(m,R){let O=Pi(g,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]=R}static async deleteHistory(m=0){let R;for(let{key:O,value:A}of l.getRange({start:0,end:m}))await CE(),Ht(A).tableId===n&&(R=l.remove(O));await R}static async*getHistory(m=0,R=1/0){for(let{key:O,value:A}of l.getRange({start:m,end:R})){await CE();let I=Ht(A);I.tableId===n&&(yield{id:I.recordId,localTime:O,version:I.version,type:I.type,value:I.getValue(i,!0,O),user:I.user,operation:I.originatingOperation})}}static async getHistoryOfRecord(m){let R=[];if(m==null)throw new Error("An id is required");let O=i.getEntry(m);if(!O)return R;let A=O.localTime;if(!A)throw new Error("The entry does not have a local audit time");let I=0;do{await CE();let w=l.get(A);if(w){let N=Ht(w);R.push({id:N.recordId,localTime:A,version:N.version,type:N.type,value:N.getValue(i,!0,A),user:N.user}),A=N.previousLocalTime}else break}while(I<1e3&&A);return R.reverse()}static cleanup(){Q?.remove()}}ye.updatedAttributes();let WE=ye.prototype;return WE[gSe]=!0,f&&ye.setTTLExpiration(f/1e3),Z&&ot(),ye;function xa(G,m,R){let O;for(let A in r){let I=r[A],w=I.isIndexing,N=bn[A],v=R&&(N?N(R):R[A]),U=m&&(N?N(m):m[A]);if(v===U&&!w)continue;O=!0;let L=I.indexNulls,P=(0,PE.getIndexedValues)(v,L),H=(0,PE.getIndexedValues)(U,L);if(H?.length>0){let k=new Set(H);if(P=P?P.filter(ue=>{if(k.has(ue))k.delete(ue);else return!0}):[],H=Array.from(k),(H.length>0||P.length>0)&&VK){let ue=H.concat(P).map(X=>({key:X,value:G}));I.prefetch(ue,jK)}for(let ue=0,X=H.length;ue<X;ue++)I.remove(H[ue],G)}else P?.length>0&&VK&&I.prefetch(P.map(k=>({key:k,value:G})),jK);if(P)for(let k=0,ue=P.length;k<ue;k++)I.put(P[k],G)}return O}a(xa,"updateIndices");function oi(G){switch(typeof G){case"number":return!0;case"string":if(G.length<659)return!0;if(G.length>KK)throw new Error("Primary key size is too large: "+G.length);break;case"object":if(G===null)throw new Error("Invalid primary key of null");break;case"bigint":if(G<2n**64n&&G>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof G)}if((0,dl.writeKey)(G,ASe,0)>KK)throw new Error("Primary key size is too large: "+G.length);return!0}a(oi,"checkValidId");function hl(G,m,R,O,A){if(ye.getResidencyById&&R.ensureLoaded){let w=ye.getResidencyById(G);if(w&&!w.includes(server.hostname))return C({key:G,residency:w}).then(A)}let I=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),R.transaction?.isDone)return A(null,G);let w=i.getEntry(G,R);return w?.residencyId&&w.metadataFlags&Li&&C&&R.ensureLoaded?C(w).then(N=>A(N,G)):(w&&m&&(w?.version>(m.lastModified||0)&&(m.lastModified=w.version),w?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=w.localTime)),A(w,G))},"whenPrefetched");return O?I():se>0?(se--,I()):new Promise((w,N)=>{se===0?(se--,i.prefetch([G],()=>{v(),U()})):(_e.push(G),K.push(U),_e.length>Uw&&(se--,v()));function v(){if(_e.length>0){let L=K;i.prefetch(_e,()=>{se===-1?v():se++;for(let P of L)P()}),_e=[],K=[],le>2&&le--}else se=le,le<KE&&le++}a(v,"prefetch");function U(){try{w(I())}catch(L){N(L)}}a(U,"load")})}a(hl,"loadLocalRecord");function ml(G){if(!G?.role)return;let m=G.role.permission;if(m.super_user)return OSe;let R=m[c],O,A=R?.tables;if(A)return A[s];if(c==="data"&&(O=m[s])&&!O.tables)return O}a(ml,"getTablePermissions");function Fa(G,m,R,O){if(y){let A=!1;if(R.noCache?A=!0:(m?(!m.value||m.metadataFlags&(Li|Ta)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(A=!0):A=!0,Fn(!A,"cache-hit",s)),A){let I=Od(G,m,R).then(w=>(w?.value?.[Ue]&&Ye.default.error?.("Can not assign a record with a record property"),R&&(w?.version>(R.lastModified||0)&&(R.lastModified=w.version),R.lastRefreshed=Date.now()),w));if(R?.onlyIfCached||m?.value&&O?.allowStaleWhileRevalidate?.(m,G)){if(I.catch(w=>Ye.default.warn?.(w)),R?.onlyIfCached&&!O.doesExist())throw new kr.ServerError("Entry is not cached",504);return}else return I}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return ye.evict(m.key,m.value,m.version),m.value=null,{then(A){return A(m)}}}a(Fa,"ensureLoadedFromSource");function Gr(G){let m=G?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let R=m.next;if(!R)return m=m.next=new uc,m.lmdbDb=i,m;m=R}while(!0)}else return new sm}a(Gr,"txnForContext");function pl(G,m,R){if(!G)return;let O=G.value||G.deref?.()||i.getEntry(G.key)?.value;if(typeof m=="object"){let I=bn,w=O;for(let N=0,v=m.length;N<v;N++){let U=m[N],L=I?.[U];w=L&&w?L(w,R,!0)?.value:w?.[U],I=L?.definition?.tableClass?.propertyResolvers}return w}let A=bn[m];return A?A(O,R):O[m]}a(pl,"getAttributeValue");function ka(G,m,R,O,A){let I=A?.length,w={transaction:O,lazy:I>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function v(U,L){let P=U?.value;if(!P)return ll.SKIP;for(let H=0;H<I;H++)if(!N?.includes(H)&&!A[H](P,U))return ll.SKIP;return L!==void 0&&(U.key=L),U}if(a(v,"processEntry"),I>0||!G.hasEntries){let U=G.map(L=>{if(N=null,typeof L=="object"&&L?.key!==void 0)return I>0?v(L):L;if(L==null)return ll.SKIP;for(let P=0;P<I;P++){let k=A[P].idFilter;if(k){if(!k(L))return ll.SKIP;N||(N=[]),N.push(P)}}return hl(L,R,w,!1,v)});return Array.isArray(G)&&(U=U.filter(L=>L!==ll.SKIP)),U.hasEntries=!0,U}return G}a(ka,"transformToEntries");function Ga(G,m,R=server.replication?.getThisNodeId(l)){if(G<=m?.version){if(m?.version===G&&R!==void 0){let O=server.replication?.exportIdMapping(l),A=m.localTime,I=l.get(A);if(I){let w,N,v=Ht(I);for(let U in O)O[U]===R&&(w=U),O[U]===v.nodeId&&(N=U);if(w>N)return!1}}return!0}return!1}a(Ga,"precedesExistingVersion");async function Od(G,m,R){let O=m?.metadataFlags,A=m?.version,I,w;if(!i.attemptLock(G,A,()=>{clearTimeout(w);let L=i.getEntry(G);!L||!L.value||L.metadataFlags&(Li|Ta)?I(Od(G,i.getEntry(G),R)):I(L)}))return new Promise(L=>{I=L,w=setTimeout(()=>{i.unlock(G,A)},TSe)});let N=m?.value,v={requestContext:R,replacingRecord:N,replacingEntry:m,replacingVersion:A,noCacheStore:!1,source:null,resourceCache:R?.resourceCache},U=R?.responseHeaders;return new Promise((L,P)=>{let H;pw(wt(v,async k=>{let ue=performance.now(),X,Ne,fe;try{for(let Re of ye.sources)if(Re.get&&(!Re.get.reliesOnPrototype||Re.prototype.get)){if(Re.available?.(m)===!1)continue;if(v.source=Re,X=await Re.get(G,v),X)break}fe=O&Li;let ne=v.lastModified||fe&&A;Ne=fe||ne>A||!N,ne||(ne=(0,PE.getNextMonotonicTime)());let z=performance.now()-ue;if(Tr(z,"cache-resolution",s),U&&hy(U,"Server-Timing",`cache-resolve;dur=${z.toFixed(2)}`,!0),k.timestamp=ne,f&&v.expiresAt==null&&(v.expiresAt=Date.now()+f),X){if(typeof X!="object")throw new Error("Only objects can be cached and stored in tables");if(X.status>0&&X.headers)if(X.status>=300)if(X.status===304)X=N,ne=A;else throw new kr.ServerError(X.body||"Error from source",X.status);else X=X.body;typeof X.toJSON=="function"&&(X=X.toJSON()),t&&X[t]!==G&&(X[t]=G)}H=!0,L({key:G,version:ne,value:X})}catch(ne){ne.message+=` while resolving record ${G} for ${s}`,N&&((ne.code==="ECONNRESET"||ne.code==="ECONNREFUSED"||ne.code==="EAI_AGAIN")&&!R?.mustRevalidate||R?.staleIfError&&(ne.statusCode===500||ne.statusCode===502||ne.statusCode===503||ne.statusCode===504))?(L({key:G,version:A,value:N}),Ye.default.trace?.(ne.message,"(returned stale record)")):P(ne),v.transaction.abort();return}if(R?.noCacheStore||v.noCacheStore){v.transaction.abort();return}Gr(v).addWrite({key:G,store:i,entry:m,nodeName:"source",commit:(ne,z)=>{if(z?.version!==A)return;let Re=xa(G,N,X);X?(ve.put?.(v,G,X),Ye.default.trace?.(`Writing resolved record from source with id: ${G}, timestamp: ${new Date(ne).toISOString()}`),S(G,X,z,ne,0,p&&Ne||null,{user:v?.user,expiresAt:v.expiresAt},"put",!!fe)):z&&(ve.delete?.(v,G),Ye.default.trace?.(`Deleting resolved record from source with id: ${G}, timestamp: ${new Date(ne).toISOString()}`),p||T?S(G,null,z,ne,0,p&&Ne||null,{user:v?.user},"delete",!!fe):i.remove(G,A))}})}),()=>{i.unlock(G,A)},k=>{i.unlock(G,A),H&&Ye.default.error?.("Error committing cache update",k)})})}a(Od,"getFromSource");function Po(G){if(!G||G.user?.role?.permission?.super_user)return!0;if(G.replicateTo)throw new kr.ClientError("Can not specify replication parameters without super user permissions",403);if(G.replicatedConfirmation)throw new kr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(Po,"checkContextPermissions");function re(){if(et!==va&&(va=et,(0,ul.getWorkerIndex)()===(0,ul.getWorkerCount)()-1)){if(Ba&&clearTimeout(Ba),!et)return;let G=new Date;G.setMonth(0),G.setDate(1),G.setHours(0),G.setMinutes(0),G.setSeconds(0);let m=Math.ceil((Date.now()-G.getTime())/et)*et+G.getTime(),R=a(O=>{Ye.default.trace?.(`Scheduled next cleanup scan at ${new Date(O)}ms`),Ba=setTimeout(()=>F=F.then(async()=>{if(R(Math.max(O+et,Date.now())),i.rootStore.status!=="open"){clearTimeout(Ba);return}let A=50,I=new Array(A),w=0;Ye.default.info?.(`Starting cleanup scan for ${s}`);try{let N=0;for(let{key:v,value:U,version:L,expiresAt:P}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let H;U===null&&!p&&L+SSe<Date.now()?H=i.remove(v,L):P!=null&&P+h<Date.now()&&(H=ye.evict(v,U,L),N++),H&&(await I[w],I[w]=H.catch(k=>{Ye.default.error?.("Cleanup error",k)}),++w>=A&&(w=0)),await CE()}Ye.default.info?.(`Finished cleanup scan for ${s}, evicted ${N} entries`)}catch(N){Ye.default.warn?.(`Error in cleanup scan for ${s}:`,N)}}),Math.min(O-Date.now(),2147483647)).unref()},"startNextTimer");R(m)}}a(re,"scheduleCleanup");function ge(){Q=l?.addDeleteRemovalCallback(n,G=>{let m=i.getEntry(G);m?.value===null&&i.remove(G,m.version)})}a(ge,"addDeleteRemoval");function ot(){(0,ul.getWorkerIndex)()===0&&setInterval(async()=>{if(!Ad){Ad=!0;try{let G=Z.name,m=r[G];if(!m)throw new Error(`expiresAt attribute ${Z} must be indexed`);for(let R of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let O of m.getValues(R)){let A=i.getEntry(O);A?.value?A.value[G]<Date.now()&&ye.evict(O,A.value,A.version):i.ifVersion(O,A?.version,()=>m.remove(R,O))}await CE()}}catch(G){Ye.default.error?.("Error in evicting old records",G)}finally{Ad=!1}}},pSe).unref()}a(ot,"runRecordExpirationEviction");function Te(G){if(G){let m=G.join(","),R=u.get([Symbol.for("residency_by_set"),m]);return R||(u.put([Symbol.for("residency_by_set"),m],R=Math.floor(Math.random()*2147483647)),u.put([Symbol.for("residency_by_id"),R],G),R)}}a(Te,"getResidencyId")}function mw(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function jK(){}function bSe(e){XK=e}function LT(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return PT(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return PT(+e);case"Float":return e==="null"?null:PT(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;ySe.test(e)||(e+="Z");let n=new Date(e);return PT(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,UT.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function PT(e){if(isNaN(e))throw new SyntaxError;return e}function QK(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t;if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function pw(e,t,r){return e?.then?e.then(t,r):t(e)}function MT(e,t){e[Fr]=t,e[Ue]=t?.value??null,e[DE]=t?.version}function zK(e){return e!=null}function ii(e){try{return JSON.stringify(e)}catch{return e}}function NSe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Ls,ll,PE,JK,hd,kr,LE,ME,Ye,dl,ul,UT,mSe,XK,pSe,SSe,VK,TSe,DE,gSe,Fr,wE,YK,RSe,hw,Li,Ta,ASe,KK,WK,OSe,ZMe,ySe,CE,Qf=Ce(()=>{Ls=B(M()),ll=require("lmdb"),PE=B(nn()),JK=require("lodash");rs();im();hd=B(te());TO();kr=B(ce()),LE=B(Xi()),ME=B(Fs());Le();jf();Ye=B(Wl());cm();dc();dl=require("ordered-binary"),ul=B(st());Wi();UT=B(ee());Al();Ri();RT();Nf();mSe=new Uint8Array(9);mSe[8]=192;pSe=6e4,SSe=864e5;hd.initSync();VK=hd.get(Ls.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),TSe=1e4,DE=Symbol.for("version"),gSe=Symbol.for("incremental-update"),Fr=Symbol("entry"),wE=Symbol("is-saving"),YK=1,RSe=2,hw=Symbol("loaded-from-source"),Li=1,Ta=8,ASe=Buffer.allocUnsafeSlow(8192),KK=1978,WK=100,OSe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},ZMe=(0,UT.convertToMS)(hd.get(Ls.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(vT,"makeTable");a(mw,"attributesAsObject");a(jK,"noop");a(bSe,"setServerUtilities");ySe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(LT,"coerceType");a(PT,"rejectNaN");a(QK,"isDescendantId");CE=a(()=>new Promise(setImmediate),"rest");a(pw,"when");a(MT,"updateResource");a(zK,"exists");a(ii,"stringify");a(NSe,"hasOtherProcesses")});var lt={};tt(lt,{database:()=>Gl,databases:()=>Ve,dropDatabase:()=>kA,dropTableMeta:()=>PSe,getDatabases:()=>ht,getDefaultCompression:()=>Cp,getTables:()=>ISe,onRemovedDB:()=>V_,onUpdatedTable:()=>bc,readMetaDb:()=>UE,resetDatabases:()=>wu,table:()=>ft,tables:()=>wn});function ISe(){return FT||ht(),wn||{}}function ht(){if(FT)return Ve;FT=!0,Sd=new Map;let e=(0,tr.getHdbBasePath)()&&(0,vt.join)((0,tr.getHdbBasePath)(),pr.DATABASES_DIR_NAME),t=(0,tr.get)(pr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,tr.get)(pr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,Jn.existsSync)(e)?e:(0,vt.join)((0,tr.getHdbBasePath)(),pr.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,Jn.existsSync)(e))for(let n of(0,Jn.readdirSync)(e,{withFileTypes:!0})){let s=(0,vt.basename)(n.name,".mdb");n.isFile()&&(0,vt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&UE((0,vt.join)(e,n.name),null,s)}if((0,Jn.existsSync)((0,pd.getBaseSchemaPath)())){for(let n of(0,Jn.readdirSync)((0,pd.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,vt.join)((0,pd.getBaseSchemaPath)(),n.name),i=(0,vt.join)((0,pd.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,Jn.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,vt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,vt.join)(i,o.name);UE((0,vt.join)(s,o.name),(0,vt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,Jn.existsSync)(i))for(let c of(0,Jn.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,vt.extname)(c.name).toLowerCase()===".mdb"&&UE((0,vt.join)(i,c.name),(0,vt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],d=(0,vt.join)(l.path,(0,vt.basename)(c+".mdb"));(0,Jn.existsSync)(d)&&UE(d,c,n,null,!0)}}for(let n in Ve){let s=Sd.get(n);if(s){let i=Ve[n];n.includes("delete")&&Vt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Vt.trace(`delete table class ${o}`),delete i[o])}else if(delete Ve[n],n==="data"){for(let i in wn)delete wn[i];delete wn[kT]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(Ve.system)for(let n of r)Ve.system[n]&&(Ve.system[n].replicate=!1);return Sd=null,Ve}function wu(){FT=!1;for(let[,e]of Ma)e.needsDeletion=!0;ht();for(let[e,t]of Ma)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Ma.delete(e),delete Ve[t.databaseName],BE.forEach(r=>r(t.databaseName)));return Ve}function UE(e,t,r=gw,n,s){let i=new Sw.default(e,!1);try{let o=Ma.get(e);o?o.needsDeletion=!1:(o=(0,Td.open)(i),Ma.set(e,o));let c=new _l.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(BT.INTERNAL_DBIS_NAME,c)),d=o.auditStore;d||(n?(0,Jn.existsSync)(n)&&(i.path=n,d=(0,Td.open)(i),d.isLegacy=!0):d=gT(o));let u=rW(r),_=u[kT],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[p,T]=f.toString().split("/");T===""?T=h.name:T||(T=p,p=t,h.name||(h.name=T,h.indexed=!h.is_hash_attribute)),_?.add(p);let g=E.get(p);g||E.set(p,g={attributes:[]}),(T==null||h.is_hash_attribute)&&(g.primary=h),T!=null&&g.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:p,primary:T}=h;if(!T){for(let K of p)if(K.is_hash_attribute||K.isPrimaryKey){T=K;break}if(!T){Vt.fatal(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(p)}`);continue}}let g=u[f],S={},C=[],y,x,F=typeof T.audit=="boolean"?T.audit:(0,tr.get)(pr.CONFIG_PARAMS.LOGGING_AUDITLOG),Y=T.trackDeletes,$=T.expiration,Z=T.eviction,Q=T.sealed,_e=T.replicate;if(g)S=g.indices,C=g.attributes,g.schemaVersion++;else{y=T.tableId,y?y>=(l.get(md)||0)&&(l.putSync(md,y+1),Vt.info(`Updating next table id (it was out of sync) to ${y+1} for ${f}`)):(T.tableId=y=l.get(md),y||(y=1),Vt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(md,y+1),l.putSync(T.key,T));let K=new _l.default(!T.is_hash_attribute,T.is_hash_attribute);if(K.compression=T.compression,K.compression){let se=(0,tr.get)(pr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||tW;K.compression.threshold=se}x=Eh(o.openDB(T.key,K)),o.databaseName=r,x.rootStore=o,x.tableId=y}for(let K of p){K.attribute=K.name;try{if(!K.is_hash_attribute&&(K.indexed||K.attribute&&!K.name)){if(!S[K.name]){let le=new _l.default(!K.is_hash_attribute,K.is_hash_attribute);S[K.name]=o.openDB(K.key,le),S[K.name].indexNulls=K.indexNulls}let se=C.find(le=>le.name===K.name);se?C.splice(C.indexOf(se),1,K):C.push(K)}}catch(se){Vt.error("Error trying to update attribute",K,C,S,se)}}if(!g){g=nW(u,f,vT({primaryStore:x,auditStore:d,audit:F,sealed:Q,replicate:_e,expirationMS:$&&$*1e3,evictionMS:Z&&Z*1e3,trackDeletes:Y,tableName:f,tableId:y,primaryKey:T.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:S,attributes:p,schemaDefined:T.schemaDefined,dbisDB:l})),g.schemaVersion=1;for(let K of vE)K(g)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function rW(e){let t=Ve[e];if(t||(e==="data"?t=Ve[e]=wn:e==="system"?Object.defineProperty(Ve,"system",{value:t=Object.create(null),configurable:!0}):t=Ve[e]=Object.create(null)),Sd&&!Sd.has(e)){let r=new Set;t[kT]=r,Sd.set(e,r)}return t}function nW(e,t,r){return e[t]=r,r}function Gl({database:e,table:t}){e||(e=gw),ht();let r=rW(e),n=(0,vt.join)((0,tr.getHdbBasePath)(),pr.DATABASES_DIR_NAME),s=(0,tr.get)(pr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,tr.get)(pr.CONFIG_PARAMS.STORAGE_PATH)||((0,Jn.existsSync)(n)?n:(0,vt.join)((0,tr.getHdbBasePath)(),pr.LEGACY_DATABASES_DIR_NAME));let o=(0,vt.join)(n,(i?t:e)+".mdb"),c=Ma.get(o);if(!c||c.status==="closed"){let l=new Sw.default(o,!1);c=(0,Td.open)(l),Ma.set(o,c)}return c.auditStore||(c.auditStore=gT(c)),c}async function kA(e){if(!Ve[e])throw new Error("Schema does not exist");let t=Ve[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Ma.delete(r.path),r.status==="open"&&(await r.close(),await HE.remove(r.path));if(r||(r=Gl({database:e,table:null}),r.status==="open"&&(await r.close(),await HE.remove(r.path))),e==="data"){for(let n in wn)delete wn[n];delete wn[kT]}delete Ve[e],BE.forEach(n=>n(e))}function ft(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,replicate:d,trackDeletes:u,schemaDefined:_,origin:E}=e;r||(r=gw);let f=Gl({database:r,table:t}),h=Ve[r];Vt.trace(`Defining ${t} in ${r}`);let p=h?.[t];if(f.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let T,g,S;_==null&&(_=!0);let C=new _l.default(!1);for(let Q of o)Q.attribute&&!Q.name?(Q.name=Q.attribute,Q.indexed=!0):Q.attribute=Q.name,Q.expiresAt&&(Q.indexed=!0);let y,x;if(p){if(T=p.primaryKey,p.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);p.attributes.splice(0,p.attributes.length,...o)}else{let Q=f.auditStore;g=o.find(le=>le.isPrimaryKey)||{},T=g.name,g.is_hash_attribute=!0,g.schemaDefined=_,g.compression=Cp(),u&&(g.trackDeletes=!0),c=g.audit=typeof c=="boolean"?c:(0,tr.get)(pr.CONFIG_PARAMS.LOGGING_AUDITLOG),n&&(g.expiration=n),s&&(g.eviction=s),typeof l=="boolean"&&(g.sealed=l),typeof d=="boolean"&&(g.replicate=d),E&&(g.origins?g.origins.includes(E)||g.origins.push(E):g.origins=[E]),Vt.trace(`${t} table loading, opening primary store`);let _e=new _l.default(!1,!0);_e.compression=g.compression;let K=t+"/";if(S=f.dbisDb=f.openDB(BT.INTERNAL_DBIS_NAME,C),Z(),S.get(K))return x&&x(),wu(),ft(e);let se=Eh(f.openDB(K,_e));f.databaseName=r,se.rootStore=f,se.tableId=S.get(md),Vt.trace(`Assigning new table id ${se.tableId} for ${t}`),se.tableId||(se.tableId=1),S.put(md,se.tableId+1),g.tableId=se.tableId,p=nW(h,t,vT({primaryStore:se,auditStore:Q,audit:c,sealed:l,replicate:d,trackDeletes:u,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:T,tableName:t,tableId:se.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:_,dbisDB:S})),p.schemaVersion=1,y=!0,S.put(K,g)}let F=p.indices;S=S||(f.dbisDb=f.openDB(BT.INTERNAL_DBIS_NAME,C)),p.dbisDB=S;let Y=[];for(let{key:Q,value:_e}of S.getRange({start:!0})){let[K,se]=Q.toString().split("/");if(se===""&&(se=_e.name),se){if(K!==t)continue}else se=K;if(!o.find(we=>we.name===se)?.indexed&&_e.indexed&&!_e.isPrimaryKey){Z(),y=!0,S.remove(Q);let we=p.indices[K];we&&Y.push(we)}}let $=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(y=!0,Q.relationship))continue;let _e=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:_e,configurable:!0});let K=S.get(_e);if(Q.isPrimaryKey){if(K=K||S.get(_e=t+"/")||{},c!==void 0&&c!==p.audit||l!==void 0&&l!==p.sealed||d!==void 0&&d!==p.replicate||(+n||void 0)!==(+K.expiration||void 0)||(+s||void 0)!==(+K.eviction||void 0)){let le={...K};typeof c=="boolean"&&(c&&p.enableAuditing(c),le.audit=c),n&&(le.expiration=+n),s&&(le.eviction=+s),l!==void 0&&(le.sealed=l),d!==void 0&&(le.replicate=d),y=!0,Z(),S.put(_e,le)}continue}K?.attribute&&!K.name&&(K.indexed=!0);let se=!K||K.type!==Q.type||K.indexed!==Q.indexed||K.nullable!==Q.nullable||K.version!==Q.version||JSON.stringify(K.attributes)!==JSON.stringify(Q.attributes)||JSON.stringify(K.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let le=new _l.default(!0,!1),we=f.openDB(_e,le);(se||K.indexingPID&&K.indexingPID!==process.pid||K.restartNumber<xE.workerData?.restartNumber)&&(y=!0,Z(),K=S.get(_e),(se||K.indexingPID&&K.indexingPID!==process.pid||K.restartNumber<xE.workerData?.restartNumber)&&(y=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),p.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=K?.lastIndexedKey??void 0,Q.indexingPID=process.pid,we.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:we}),$.push(Q))),S.put(_e,Q)),K?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),we.indexNulls=Q.indexNulls,F[Q.name]=we}else se&&(y=!0,Z(),S.put(_e,Q))}}finally{x&&x()}if(y&&(p.schemaVersion++,p.updatedAttributes()),Vt.trace(`${t} table loading, running index`),$.length>0||Y.length>0?p.indexingOperation=DSe(p,$,Y):y&&HT.signalSchemaChange(new xT.SchemaEventMsg(process.pid,"schema-change",p.databaseName,p.tableName)),p.origin=E,y)for(let Q of vE)Q(p,E!=="cluster");return(n||s||i)&&p.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Vt.trace(`${t} table loaded`),p;function Z(){x||f.transactionSync(()=>({then(Q){x=Q}}))}a(Z,"startTxn")}async function DSe(e,t,r){try{Vt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await HT.signalSchemaChange(new xT.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let d of r)s=d.drop();let i,o={},c=0,l=t.length;if(await new Promise(d=>setImmediate(d)),l>0){let d;for(let _ of t)(0,Td.compareKeys)(_.lastIndexedKey,d)<0&&(d=_.lastIndexedKey),_.lastIndexedKey==null&&_.dbi.clearAsync();let u=0;for(let{key:_,value:E,version:f}of e.primaryStore.getRange({start:d,lazy:l<4,versions:!0,snapshot:!1}))if(E){if(u++,s=e.primaryStore.ifVersion(_,f,()=>{for(let h=0;h<l;h++){let p=t[h],T=p.name;try{let g=p.resolve,S=E&&(g?g(E):E[T]),C=(0,ZK.getIndexedValues)(S);if(C)for(let y=0,x=C.length;y<x;y++)p.dbi.put(C[y],_)}catch(g){o[T]||(o[T]=!0,Vt.error(`Error indexing attribute ${T}`,g))}}}),s.then(()=>u--,h=>{u--,Vt.error(h)}),xE.workerData&&xE.workerData.restartNumber!==eW.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}u>wSe?await s:u>CSe&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await HT.signalSchemaChange(new xT.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Vt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Vt.error("Error in indexing",n)}}function PSe({table:e,database:t}){let r=Gl({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function bc(e){return vE.push(e),{remove(){let t=vE.indexOf(e);t>-1&&vE.splice(t,1)}}}function V_(e){return BE.push(e),{remove(){let t=BE.indexOf(e);t>-1&&BE.splice(t,1)}}}function Cp(){let e=(0,tr.get)(pr.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,tr.get)(pr.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,tr.get)(pr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||tW,n={startingOffset:32};return t&&(n.dictionary=HE.readFileSync(t)),r&&(n.threshold=r),e&&n}var tr,BT,Td,vt,Jn,pd,_l,Sw,pr,HE,Tw,ZK,HT,xT,xE,Vt,eW,gw,kT,tW,wn,Ve,md,vE,BE,FT,Ma,Sd,wSe,CSe,Le=Ce(()=>{tr=B(te()),BT=B(Bt()),Td=require("lmdb"),vt=require("path"),Jn=require("fs"),pd=B(Tt());Qf();_l=B(Kd()),Sw=B(Wd()),pr=B(M()),HE=B(require("fs-extra")),Tw=B(Yi()),ZK=B(nn()),HT=B(Xi()),xT=B(Fs()),xE=require("worker_threads"),Vt=B(V()),eW=B(st());Wi();Al();gw="data",kT=Symbol("defined-tables"),tW=((0,tr.get)(pr.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,tr.initSync)();wn=Object.create(null),Ve=Object.create(null);(0,Tw._assignPackageExport)("databases",Ve);(0,Tw._assignPackageExport)("tables",wn);md=Symbol.for("next-table-id"),vE=[],BE=[],Ma=new Map;a(ISe,"getTables");a(ht,"getDatabases");a(wu,"resetDatabases");a(UE,"readMetaDb");a(rW,"ensureDB");a(nW,"setTable");a(Gl,"database");a(kA,"dropDatabase");a(ft,"table");wSe=1e3,CSe=10;a(DSe,"runIndexing");a(PSe,"dropTableMeta");a(bc,"onUpdatedTable");a(V_,"onRemovedDB");a(Cp,"getDefaultCompression")});var ee=b((cUe,pW)=>{"use strict";var Ua=require("path"),cW=require("fs-extra"),On=V(),sW=require("fs-extra"),GT=require("os"),LSe=require("net"),MSe=require("recursive-iterator"),Yt=M(),USe=fg(),iW=require("papaparse"),qT=require("moment"),{inspect:vSe}=require("util"),oW=require("is-number"),aUe=require("lodash"),BSe=require("minimist"),HSe=require("https"),xSe=require("http"),{hdb_errors:$T}=ce(),FSe=/^((\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)))$/,lW=require("util").promisify(setTimeout),kSe=100,GSe=5,qSe="",$Se=4,aW={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};pW.exports={isEmpty:Xn,isEmptyOrZeroLength:Vi,arrayHasEmptyValues:KSe,arrayHasEmptyOrZeroLengthValues:WSe,buildFolderPath:jSe,isBoolean:uW,errorizeMessage:VSe,stripFileExtension:zSe,autoCast:JSe,autoCastJSON:dW,autoCastJSONDeep:Aw,removeDir:XSe,compareVersions:ZSe,isCompatibleDataVersion:eTe,escapeRawValue:tTe,unescapeValue:rTe,stringifyProps:nTe,timeoutPromise:iTe,isClusterOperation:aTe,getClusterUser:lTe,checkGlobalSchemaTable:cTe,getHomeDir:fW,getPropsFilePath:sTe,promisifyPapaParse:uTe,removeBOM:EW,createEventPromise:dTe,checkProcessRunning:_Te,checkSchemaTableExist:fTe,checkSchemaExists:hW,checkTableExists:mW,getStartOfTomorrowInSeconds:ETe,getLimitKey:hTe,isObject:QSe,isNotEmptyAndHasValue:YSe,autoCasterIsNumberCheck:_W,backtickASTSchemaItems:mTe,isPortTaken:oTe,createForkArgs:pTe,autoCastBoolean:STe,async_set_timeout:lW,getTableHashAttribute:TTe,doesSchemaExist:gTe,doesTableExist:RTe,stringifyObj:ATe,ms_to_time:OTe,changeExtension:bTe,getEnvCliRootPath:Ow,noBootFile:yTe,httpRequest:NTe,transformReq:ITe,convertToMS:wTe,PACKAGE_ROOT:Yt.PACKAGE_ROOT};function VSe(e){return e instanceof Error?e:new Error(e)}a(VSe,"errorizeMessage");function Xn(e){return e==null}a(Xn,"isEmpty");function YSe(e){return!Xn(e)&&(e||e===0||e===""||uW(e))}a(YSe,"isNotEmptyAndHasValue");function Vi(e){return Xn(e)||e.length===0||e.size===0}a(Vi,"isEmptyOrZeroLength");function KSe(e){if(Xn(e))return!0;for(let t=0;t<e.length;t++)if(Xn(e[t]))return!0;return!1}a(KSe,"arrayHasEmptyValues");function WSe(e){if(Vi(e))return!0;for(let t=0;t<e.length;t++)if(Vi(e[t]))return!0;return!1}a(WSe,"arrayHasEmptyOrZeroLengthValues");function jSe(...e){try{return e.join(Ua.sep)}catch{console.error(e)}}a(jSe,"buildFolderPath");function uW(e){return Xn(e)?!1:e===!0||e===!1}a(uW,"isBoolean");function QSe(e){return Xn(e)?!1:typeof e=="object"}a(QSe,"isObject");function zSe(e){return Vi(e)?qSe:e.slice(0,-$Se)}a(zSe,"stripFileExtension");function JSe(e){return Xn(e)||e===""||typeof e!="string"?e:aW[e]!==void 0?aW[e]:_W(e)===!0?Number(e):FSe.test(e)?new Date(e):e}a(JSe,"autoCast");function dW(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(dW,"autoCastJSON");function Aw(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=Aw(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=Aw(r);n!==r&&(e[t]=n)}return e}else return dW(e)}a(Aw,"autoCastJSONDeep");function _W(e){if(e.startsWith("0.")&&oW(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&oW(e))}a(_W,"autoCasterIsNumberCheck");async function XSe(e){if(Vi(e))throw new Error(`Directory path: ${e} does not exist`);try{await sW.emptyDir(e),await sW.remove(e)}catch(t){throw On.error(`Error removing files in ${e} -- ${t}`),t}}a(XSe,"removeDir");function ZSe(e,t){if(Vi(e)){On.info("Invalid current version sent as parameter.");return}if(Vi(t)){On.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let d=0;d<l;d++)if(r=parseInt(o[d],10)-parseInt(c[d],10),r)return r;return o.length-c.length}a(ZSe,"compareVersions");function eTe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(eTe,"isCompatibleDataVersion");function tTe(e){if(Xn(e))return e;let t=String(e);return t==="."?Yt.UNICODE_PERIOD:t===".."?Yt.UNICODE_PERIOD+Yt.UNICODE_PERIOD:t.replace(Yt.FORWARD_SLASH_REGEX,Yt.UNICODE_FORWARD_SLASH)}a(tTe,"escapeRawValue");function rTe(e){if(Xn(e))return e;let t=String(e);return t===Yt.UNICODE_PERIOD?".":t===Yt.UNICODE_PERIOD+Yt.UNICODE_PERIOD?"..":String(e).replace(Yt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(rTe,"unescapeValue");function nTe(e,t){if(Xn(e))return On.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+GT.EOL}!Vi(n)&&n[0]===";"?r+=" "+n+s+GT.EOL:Vi(n)||(r+=n+"="+s+GT.EOL)}catch{On.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(nTe,"stringifyProps");function fW(){let e;try{e=GT.homedir()}catch{e=process.env.HOME}return e}a(fW,"getHomeDir");function sTe(){let e=Ua.join(fW(),Yt.HDB_HOME_DIR_NAME,Yt.BOOT_PROPS_FILE_NAME);return cW.existsSync(e)||(e=Ua.join(__dirname,"../","hdb_boot_properties.file")),e}a(sTe,"getPropsFilePath");function iTe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(iTe,"timeoutPromise");async function oTe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=LSe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(oTe,"isPortTaken");function aTe(e){try{return Yt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){On.error(`Error checking operation against cluster ops ${t}`)}return!1}a(aTe,"isClusterOperation");function cTe(e,t){let r=(Le(),ie(lt)).getDatabases();if(!r[e])return $T.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return $T.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(cTe,"checkGlobalSchemaTable");function lTe(e,t){if(Xn(t)){On.warn("No CLUSTERING_USER defined, clustering disabled");return}if(Xn(e)||Vi(e)){On.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){On.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){On.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(lTe,"getClusterUser");function uTe(){iW.parsePromise=function(e,t,r){return new Promise(function(n,s){iW.parse(e,{header:!0,transformHeader:EW,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(uTe,"promisifyPapaParse");function EW(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(EW,"removeBOM");function dTe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;On.info(`Got cluster status event response: ${vSe(s)}`);try{i.cancel()}catch{On.error("Error trying to cancel timeout.")}n(s)})})}a(dTe,"createEventPromise");async function _Te(e){let t=!0,r=0;do await lW(kSe*r++),(await USe.findPs(e)).length>0&&(t=!1);while(t&&r<GSe);if(t)throw new Error(`process ${e} was not started`)}a(_Te,"checkProcessRunning");function fTe(e,t){let r=hW(e);if(r)return r;let n=mW(e,t);if(n)return n}a(fTe,"checkSchemaTableExist");function hW(e){let{getDatabases:t}=(Le(),ie(lt));if(!t()[e])return $T.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(hW,"checkSchemaExists");function mW(e,t){let{getDatabases:r}=(Le(),ie(lt));if(!r()[e][t])return $T.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(mW,"checkTableExists");function ETe(){let e=qT().utc().add(1,Yt.MOMENT_DAYS_TAG).startOf(Yt.MOMENT_DAYS_TAG).unix(),t=qT().utc().unix();return e-t}a(ETe,"getStartOfTomorrowInSeconds");function hTe(){return qT().utc().format("DD-MM-YYYY")}a(hTe,"getLimitKey");function mTe(e){try{let t=new MSe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){On.error("Got an error back ticking items."),On.error(t)}}a(mTe,"backtickASTSchemaItems");function pTe(e){return[e]}a(pTe,"createForkArgs");function STe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(STe,"autoCastBoolean");function TTe(e,t){let{getDatabases:r}=(Le(),ie(lt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(TTe,"getTableHashAttribute");function gTe(e){let{getDatabases:t}=(Le(),ie(lt));return t()[e]!==void 0}a(gTe,"doesSchemaExist");function RTe(e,t){let{getDatabases:r}=(Le(),ie(lt));return r()[e]?.[t]!==void 0}a(RTe,"doesTableExist");function ATe(e){try{return JSON.stringify(e)}catch{return e}}a(ATe,"stringifyObj");function OTe(e){let t=qT.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(OTe,"ms_to_time");function bTe(e,t){let r=Ua.basename(e,Ua.extname(e));return Ua.join(Ua.dirname(e),r+t)}a(bTe,"changeExtension");function Ow(){if(process.env[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=BSe(process.argv);if(e[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(Ow,"getEnvCliRootPath");var Rw;function yTe(){if(Rw)return Rw;let e=Ow();if(Ow()&&cW.pathExistsSync(Ua.join(e,Yt.HDB_CONFIG_FILE)))return Rw=!0,!0}a(yTe,"noBootFile");function NTe(e,t){let r;return e.protocol==="http:"?r=xSe:r=HSe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",l=>{c.body+=l}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(NTe,"httpRequest");function ITe(e){if(!e.schema&&!e.database){e.schema=Yt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(ITe,"transformReq");function wTe(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(wTe,"convertToMS")});var te=b((AW,OW)=>{"use strict";var bw=require("fs-extra"),fl=require("path"),SW=require("os"),CTe=require("properties-reader"),kE=V(),FE=ee(),Pe=M(),VT=It(),DTe="Error initializing environment manager",YT="BOOT_PROPS_FILE_PATH",TW=!1,PTe={[Pe.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Co={};Object.assign(AW,OW.exports={BOOT_PROPS_FILE_PATH:YT,getHdbBasePath:LTe,setHdbBasePath:MTe,get:gW,initSync:vTe,setProperty:Je,initTestEnvironment:HTe,setCloneVar:BTe});function LTe(){return Co[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(LTe,"getHdbBasePath");function MTe(e){Co[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(MTe,"setHdbBasePath");function gW(e){let t=VT.getConfigValue(e);return t===void 0?Co[e]:t}a(gW,"get");function Je(e,t){PTe[e]&&(Co[e]=t),VT.updateConfigObject(e,t)}a(Je,"setProperty");function UTe(){let e;try{e=FE.getPropsFilePath(),bw.accessSync(e,bw.constants.F_OK|bw.constants.R_OK),TW=!0;let t=CTe(e);return Co[Pe.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Pe.HDB_SETTINGS_NAMES.INSTALL_USER),Co[Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Co[YT]=e,!0}catch{return kE.trace(`Environment manager found no properties file at ${e}`),!1}}a(UTe,"doesPropFileExist");function vTe(e=!1){try{(TW||UTe()||FE.noBootFile())&&!RW&&(VT.initConfig(e),Co[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=VT.getConfigValue(Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){kE.error(DTe),kE.error(t),console.error(t),process.exit(1)}}a(vTe,"initSync");var RW=!1;function BTe(e){RW=e}a(BTe,"setCloneVar");function HTe(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=fl.join(__dirname,"../../","unitTests");Co[YT]=fl.join(l,"hdb_boot_properties.file"),Je(Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,fl.join(l,"settings.test")),Je(Pe.HDB_SETTINGS_NAMES.INSTALL_USER,SW.userInfo()?SW.userInfo().username:void 0),Je(Pe.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Je(Pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY,fl.join(l,"envDir","log")),Je(Pe.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Je(Pe.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Je(Pe.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Je(Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,fl.join(l,"envDir")),Je(Pe.CONFIG_PARAMS.STORAGE_PATH,fl.join(l,"envDir")),s&&(Je(Pe.CONFIG_PARAMS.HTTP_SECUREPORT,gW(Pe.CONFIG_PARAMS.HTTP_PORT)),Je(Pe.CONFIG_PARAMS.HTTP_PORT,null)),Je(Pe.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Je(Pe.CONFIG_PARAMS.HTTP_PORT,9926),Je(Pe.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Je(Pe.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Je(Pe.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,FE.isEmpty(i)?!1:i),Je(Pe.CONFIG_PARAMS.HTTP_CORS,FE.isEmpty(i)?!1:i),Je(Pe.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Je(Pe.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Je(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Je(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Je(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,fl.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Je(Pe.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,FE.isEmpty(c)?!1:c),o&&(Je("CORS_ACCESSLIST",o),Je(Pe.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Je(Pe.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Je(Pe.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Je(Pe.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Je(Pe.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Je(Pe.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Je(Pe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${YT}. Please check your boot props and settings files`;kE.fatal(r),kE.error(t)}}a(HTe,"initTestEnvironment")});var wW=b((dUe,IW)=>{"use strict";var NW=require("joi"),{string:GE,boolean:bW,array:xTe}=NW.types(),yW=M(),FTe=dt();IW.exports=kTe;function kTe(e){let t=NW.object({operation:GE.valid(yW.OPERATIONS_ENUM.ADD_NODE,yW.OPERATIONS_ENUM.UPDATE_NODE).required(),node_name:GE.required(),subscriptions:xTe.items({schema:GE.required(),table:GE.optional(),hash_attribute:GE.optional(),subscribe:bW.required(),publish:bW.required()}).min(1).required()});return FTe.validateBySchema(e,t)}a(kTe,"updateRemoteSourceValidator")});var qE=b((fUe,CW)=>{"use strict";var yw=class{static{a(this,"UpdateRemoteResponseObject")}constructor(t,r,n=void 0){this.status=t,this.message=r,this.system_info=n}};CW.exports=yw});var MW=b((hUe,LW)=>{"use strict";var GTe=wW(),Do=V(),Nw=_t(),qTe=M(),Iw=_s(),El=Ft(),DW=j_(),$Te=Fl(),{Node:VTe,NodeSubscription:PW}=la(),ww=qE(),Cw=ee(),YTe=te(),{cloneDeep:KTe}=require("lodash"),{broadcast:WTe}=st();LW.exports=jTe;async function jTe(e){try{let t=GTe(e);if(t)return Do.error(`Validation error in updateRemoteSource: ${t.message}`),new ww(Nw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let{subscriptions:r,node_name:n,system_info:s}=e,i=[],o=KTe(await Iw.getNodeRecord(n)),c=!Cw.isEmptyOrZeroLength(o);o=c?o[0]:o,c&&Do.trace(`Existing record found for ${n}, updating records subscriptions`);for(let d=0,u=r.length;d<u;d++){let _=r[d],E=_.schema,f=_.table;if(!Cw.doesSchemaExist(E)){Do.trace(`updateRemoteSource creating schema: ${E}`);try{await DW.createSchema({operation:"create_schema",schema:E})}catch(h){Do.error(h)}}if(f&&!Cw.doesTableExist(E,f)){let h=new $Te(E,f,_.hash_attribute);_.attributes&&(h.attributes=_.attributes),Do.trace(`updateRemoteSource creating table: ${f} in schema: ${E} with attributes: ${JSON.stringify(_.attributes)}`);try{await DW.createTable(h)}catch(p){Do.error(p)}}if(Do.trace(`Creating local stream for ${E}.${f}`),await El.createLocalTableStream(E,f),c?(await El.updateConsumerIterator(E,f,n,"stop"),await El.updateRemoteConsumer(_,n),_.subscribe===!0&&await El.updateConsumerIterator(E,f,n,"start")):(await El.updateRemoteConsumer(_,n),_.subscribe===!0?await El.updateConsumerIterator(E,f,n,"start"):await El.updateConsumerIterator(E,f,n,"stop")),c){let h=!1;for(let p=0,T=o.subscriptions.length;p<T;p++){let g=o.subscriptions[p];if(g.schema===E&&g.table===f){g.publish=_.publish,g.subscribe=_.subscribe,h=!0;break}}h||o.subscriptions.push(new PW(E,f,_.publish,_.subscribe))}else i.push(new PW(E,f,_.publish,_.subscribe))}c||(o=new VTe(n,i,void 0),Do.trace(`No record found for ${n}, creating a new one`));let l=Object.create({});return Object.assign(l,o),l.system_info=s,await Iw.upsertNodeRecord(l),WTe({type:"nats_update"}),new ww(Nw.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${YTe.get(qTe.CONFIG_PARAMS.CLUSTERING_NODENAME)} successfully updated remote source`,await Iw.getSystemInfo())}catch(t){Do.error(t);let r=t.message?t.message:t;return new ww(Nw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(jTe,"updateRemoteSource")});var HW=b((pUe,BW)=>{"use strict";var vW=require("joi"),{string:UW}=vW.types(),QTe=M(),zTe=dt();BW.exports=JTe;function JTe(e){let t=vW.object({operation:UW.valid(QTe.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:UW.required()});return zTe.validateBySchema(e,t)}a(JTe,"removeRemoteSourceValidator")});var kW=b((TUe,FW)=>{"use strict";var XTe=HW(),KT=V(),WT=_t(),Dw=M(),ZTe=_s(),ege=ee(),xW=Ft(),tge=te(),jT=qE(),{NodeSubscription:rge}=la(),nge=xl(),sge=qo(),{broadcast:ige}=st(),oge=tge.get(Dw.CONFIG_PARAMS.CLUSTERING_NODENAME);FW.exports=age;async function age(e){try{let t=XTe(e);if(t)return KT.error(`Validation error in removeRemoteSource: ${t.message}`),new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let r=e.node_name,n=await ZTe.getNodeRecord(r);if(ege.isEmptyOrZeroLength(n)){let i=`No record found for node '${r}'`;return KT.error(i),new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,i)}n=n[0];for(let i=0,o=n.subscriptions.length;i<o;i++){let c=n.subscriptions[i];KT.trace(`remove remote source removing subscription: ${c.schema}.${c.table} for node: ${r}`);let l=new rge(c.schema,c.table,!1,!1);await xW.updateConsumerIterator(c.schema,c.table,r,"stop"),await xW.updateRemoteConsumer(l,r)}let s=new nge(Dw.SYSTEM_SCHEMA_NAME,Dw.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await sge.deleteRecord(s),ige({type:"nats_update"}),new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${oge} successfully removed node '${r}'.`)}catch(t){KT.error(t);let r=t.message?t.message:t;return new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(age,"removeRemoteSource")});var VW=b((RUe,$W)=>{"use strict";var QT=V(),$E=M(),GW=_t(),Pw=te(),cge=ee(),qW=qE(),lge=_s(),uge=J_(),dge=Kr();$W.exports=_ge;async function _ge(e){try{QT.trace("getRemoteSourceConfig called");let t=process.uptime()*1e3,r=cge.ms_to_time(t),n=new fge(Pw.get($E.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),Pw.get($E.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)??Pw.get($E.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT),r,await lge.getSystemInfo());try{let s={name:e.node_name,system_info:e.system_info},i=new uge($E.SYSTEM_SCHEMA_NAME,$E.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[s]);await dge.update(i)}catch(s){QT.error("Get remote config encountered an error updating system info for node:",e.node_name,s)}return QT.trace("getRemoteSourceConfig response:",n),new qW(GW.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,n)}catch(t){QT.error(t);let r=t.message?t.message:t;return new qW(GW.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(_ge,"getRemoteSourceConfig");function fge(e,t,r,n){this.uptime=r,this.ports={clustering:e,operations_api:t},this.system_info=n}a(fge,"ConfigResponseObject")});var jW=b((OUe,WW)=>{"use strict";var YW=te();YW.initSync();var KW=Ft(),VE=V(),gd=M(),Lw=_t(),Ege=MW(),hge=kW(),mge=VW(),pge=qE(),{encode:Sge,decode:Tge}=require("msgpackr"),gge=is(),Rge=Ei(),Age=require("util"),Oge=M(),{isMainThread:bge,parentPort:yge}=require("worker_threads");st();var Nge=Age.promisify(gge.setSchemaDataToGlobal),Mw=YW.get(gd.CONFIG_PARAMS.CLUSTERING_NODENAME);WW.exports=Ige;async function Ige(){try{VE.notify("Starting reply service."),await Nge();let e=await KW.getConnection(),t=`${Mw}.__request__`,r=e.subscribe(t,{queue:Mw});await wge(r)}catch(e){VE.error(e)}}a(Ige,"initialize");async function wge(e){for await(let t of e){let r=Tge(t.data),n;switch(r.operation){case gd.OPERATIONS_ENUM.ADD_NODE:case gd.OPERATIONS_ENUM.UPDATE_NODE:n=await Ege(r);break;case gd.OPERATIONS_ENUM.REMOVE_NODE:n=await hge(r);break;case gd.OPERATIONS_ENUM.CLUSTER_STATUS:n=await mge(r);break;case gd.OPERATIONS_ENUM.DESCRIBE_ALL:n=await Cge();break;default:let s=`node '${Mw}' reply service received unrecognized request operation`;VE.error(s),n=new pge(Lw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,s)}VE.trace(n),t.respond(Sge(n))}}a(wge,"handleRequest");async function Cge(){try{return{status:Lw.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,message:await Rge.describeAll()}}catch(e){return VE.error(e),{status:Lw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,message:e.message}}}a(Cge,"getRemoteDescribeAll");bge||yge.on("message",async e=>{let{type:t}=e;t===Oge.ITC_EVENT_TYPES.SHUTDOWN&&KW.closeConnection()})});var Dge=jW();(async()=>{try{await Dge()}catch(e){console.error("Error launching Nats reply service."),console.error(e)}})();
132
+ `))}},25).unref()}o.close?.(()=>{if(At.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&rd()==0)try{uY(fY(At.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,YS),o.cantCleanupProperly||en.warn("Had to forcefully exit the thread",YS),process.exit(0)},5e3).unref()})}if(EY||process.env.DEV_MODE)try{require("inspector").close()}catch(i){en.info("Could not close debugger",i)}}}).ref();let e;SE&&!yme&&(e=mY()),Promise.resolve(e).then(()=>{if(rd()===0)try{Ame(bI)}catch(t){console.error("Error displaying start-up log",t)}TE?.postMessage({type:er.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(hY,"startServers");function mY(){let e=[];for(let t in xi){let r=xi[t];if(t.includes?.("/")&&rd()==0){hme(t)&&uY(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),en.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=At.get(er.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=rd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?SE?n={fd:SE(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:SE?n={fd:SE(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),en.trace("Listening on port "+t,YS)}).on("error",c)}))}return Promise.all(e)}a(mY,"listenOnPorts");!RI&&!lme.noServerStart&&hY();function NI(e,t,r){let n=e?.read?e:new ume({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=xi[t];if(s.isSecure&&(n.startTime=performance.now()),s)typeof s=="function"?s(n):s.emit("connection",n),r&&n.emit("data",r);else{let i=a(o=>{setTimeout(()=>{let c=xi[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(en.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(NI,"deliverSocket");var cY=new Map;function Ime(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=cY.get(s),r){case"connection":i=NI(void 0,t),cY.set(s,i),i.write=(c,l,d)=>(TE.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),d&&d(),!0),i.end=(c,l,d)=>(TE.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),d&&d(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),TE.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(Ime,"proxyRequest");var{getComponentName:WS}=(Mf(),oe(Lf));function II(e,t,r=!0){t||(t=At.get(er.CONFIG_PARAMS.HTTP_PORT));let n=xi[t];if(n){let s=n.lastServer||n;if(s===e)throw new Error(`Can not register the same server twice for the same port ${t}`);if(r&&!!s.sessionIdContext!=!!e.sessionIdContext&&+t)throw new Error(`Can not mix secure HTTPS and insecure HTTP on the same port ${t}`);s.off("unhandled",lY),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else xi[t]=e;e.on("unhandled",lY)}a(II,"registerServer");function pY(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],At.get(er.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:At.get(er.CONFIG_PARAMS.HTTP_PORT),secure:At.get(er.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),At.get(er.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:At.get(er.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&At.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:fY(At.get(er.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(pY,"getPorts");function wI(e,t){let r=[];for(let{port:n,secure:s}of pY(t))r.push(SY(n,s,t?.isOperationsServer)),typeof e=="function"?yI[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,II(e,n,!1)),KS[n]=OI(yI,n),Ome=OI(Nme,n);return r}a(wI,"httpServer");function jS(e,t){let r=bI.get(e)??[];bI.set(e,[...r,t])}a(jS,"setPortServerMap");function SY(e,t,r){if(jS(e,{protocol_name:t?"HTTPS":"HTTP",name:WS()}),!VS[e]){let n=r?"operationsApi_network":"http",s={noDelay:!0,keepAliveTimeout:At.get(n+"_keepAliveTimeout"),headersTimeout:At.get(n+"_headersTimeout"),requestTimeout:At.get(n+"_timeout"),highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600},i=At.get(n+"_mtls"),o=At.get(n+"_mtls_required");t&&Object.assign(s,{allowHTTP1:!0,rejectUnauthorized:!!o,requestCert:!!(i||r),ticketKeys:Sme(),maxHeaderSize:At.get(er.CONFIG_PARAMS.HTTP_MAXHEADERSIZE),SNICallback:_Y(r?"operations-api":"server",i),ALPNCallback:function(d){return d.protocols.includes("harperdb-replication")&&(this.isReplicationConnection=!0),"http/1.1"},ALPNProtocols:null});let c=Rme(),l=VS[e]=(t?Eme:_me)(s,async(d,u)=>{try{let E=performance.now(),f=new dY(d,u);r&&(f.isOperationsServer=!0);let h=await KS[e](f);if(!h){if(f._nodeResponse.statusCode)return;h=TY(f)}if(h.headers?.set||(h.headers=new AI(h.headers)),c?h.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):h.headers?.set?.("Server","HarperDB"),h.status===-1){for(let x of h.headers||[])u.setHeader(x[0],x[1]);return d.baseRequest=f,u.baseResponse=h,VS[e].emit("unhandled",d,u)}let T=h.status||200,S=performance.now(),R=S-E,p=h.body,y;if(!h.handlesHeaders){let x=h.headers||new AI;p?p.length>=0&&(typeof p=="string"?x.set("Content-Length",Buffer.byteLength(p)):x.set("Content-Length",p.length),y=!0):(x.set("Content-Length","0"),y=!0);let W=`hdb;dur=${R.toFixed(2)}`;h.wasCacheMiss&&(W+=", miss"),gme(x,"Server-Timing",W,!0),u.writeHead(T,x&&(x[Symbol.iterator]?Array.from(x):x)),y&&u.end(p)}let O=f.handlerPath,B=f.method;if(mE(R,"duration",O,B,h.wasCacheMiss==null?void 0:h.wasCacheMiss?"cache-miss":"cache-hit"),aY(T<400,"success",O,B),aY(1,"response_"+T,O,B),!y)if(p?.pipe){p.pipe(u),p.destroy&&u.on("close",()=>{p.destroy()});let x=0;p.on("data",W=>{x+=W.length}),p.on("end",()=>{mE(performance.now()-S,"transfer",O,B),mE(x,"bytes-sent",O,B)})}else p?.then?p.then(x=>{u.end(x)},_):u.end(p)}catch(E){_(E)}function _(E){let f=E.headers;u.writeHead(E.statusCode||500,f&&(f[Symbol.iterator]?Array.from(f):f)),u.end(E.toString()),E.statusCode?E.statusCode===500?en.warn(E):en.info(E):en.error(E)}a(_,"onError")});t&&(l.ports||(l.ports=[]),l.ports.push(e),s.SNICallback.initialize(l),i&&(l.mtlsConfig=i),l.on("secureConnection",d=>{d._parent.startTime&&mE(performance.now()-d._parent.startTime,"tls-handshake",e),mE(d.isSessionReused(),"tls-reused",e)}),l.isSecure=!0),II(l,e)}return VS[e]}a(SY,"getHTTPServer");function OI(e,t){let r=TY;for(let n=e.length;n>0;){let{listener:s,port:i}=e[--n];if(i===t||i==="all"){let o=r;r=a(c=>s(c,o),"next_callback")}}return r}a(OI,"makeCallbackChain");function TY(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new AI}}a(TY,"unhandled");function wme(e,t){wI(e,{requestOnly:!0,...t})}a(wme,"onRequest");function Cme(e,t){let r;if(t.securePort){jS(t.securePort,{protocol_name:"TLS",name:WS()});let n=_Y("server",t.mtls);r=pme({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),xi[t.securePort]=r}return t.port&&(jS(t.port,{protocol_name:"TCP",name:WS()}),r=dme(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),xi[t.port]=r),r}a(Cme,"onSocket");Object.defineProperty(fme.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.includes("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});function Dme(e,t){let r=[];for(let{port:n,secure:s}of pY(t)){if(jS(n,{protocol_name:s?"WSS":"WS",name:WS()}),!pE[n]){let c;pE[n]=new mme({server:c=SY(n,s,t?.isOperationsServer)}),c._ws=pE[n],r.push(c),pE[n].on("connection",async(l,d)=>{try{let u=new dY(d);u.isWebSocket=!0;let _=KS[n](u),E=d.headers["sec-websocket-protocol"],f=gI[n],h;if(E){for(let T=0;T<f.length;T++){let S=f[T];S.protocol===E&&(h=!0,S.listener(l,u,_))}if(h)return}for(let T=0;T<f.length;T++){let S=f[T];S.protocol||(S.listener(l,u,_),h=!0)}h||l.close(1008,"No handler for protocol")}catch(u){en.warn("Error handling WebSocket connection",u)}}),pE[n].on("error",l=>{console.log("Error in setting up WebSocket server",l)})}let i=t?.subProtocol||"",o=gI[n];o||(o=gI[n]=[]),o.push({listener:e,protocol:i}),KS[n]=OI(yI,n)}return r}a(Dme,"onWebSocket");function lY(e,t){t.writeHead(404),t.end(`Not found
133
+ `)}a(lY,"defaultNotFound")});var oY={};et(oY,{startHTTPThreads:()=>Lme,startSocketServer:()=>UI,updateWorkerIdleness:()=>IY});async function Lme(e=2,t){try{if(t)LI(0,1,!0);else{let{loadRootComponents:r}=zS();if(e===0)return(0,Ds.setMainIsWorker)(!0),await CI().startServers(),Promise.resolve([]);await r()}NY();for(let r=0;r<e;r++)LI(r,e);return Promise.all(OY)}finally{(0,Ds.threadsHaveStarted)()}}function NY(){let e=(0,bY.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),PI=setInterval(()=>{ZS.notify(e)},Pme).unref())}function LI(e,t=1,r){if(DI++,(0,Ds.startWorker)("server/threads/threadServer.js",{name:ad.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(d){d.type===ad.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});OY.push(s),await s,nd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=XS.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=nd.indexOf(n);o>-1&&nd.splice(o,1)}if(a(i,"removeWorker"),sd){let o=sd;sd=[];for(let c of o)yY[c.localPort](null,c)}}}),r){let n=setInterval(()=>{MI?MI=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Ds.shutdownWorkers)(),DI=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function UI(e=0,t){if(typeof e=="string")try{(0,eT.existsSync)(e)&&(0,eT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=Mme:r=Ume(t):r=vI;let n=(0,id.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=yY[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),MI=!0,r(o,(c,l)=>{if(!c){if(gY){let u=o._socket||new id.Socket({handle:o,writable:!0,readable:!0});gY.deliverSocket(u,e,l),u.resume()}else DI>0?(sd.length===0&&setTimeout(()=>{sd.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,sd.push(o)):(console.log("start up a dynamic thread to handle request"),LI(0));gr(!1,"socket-routed");return}c.requests++;let d=o.fd;if(d>=0)c.postMessage({port:e,fd:d,data:l});else{let u=o._socket||new id.Socket({handle:o,writable:!0,readable:!0});Hme(u,c,e)}gr(!0,"socket-routed")})};let s=Kl();ZS.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function vI(e,t){let r,n=0;for(let s of nd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=JS)return JS=i,t(r);n=i}JS=0,t(r)}function Mme(e,t){let r={};e.getpeername(r);let n=r.address,s=od.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);vI(e,o=>{od.set(n,{worker:o,lastUsed:i}),t(o)})}function Ume(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new id.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],d=od.get(l),u=Date.now();if(d&&d.worker.threadId!==-1)return d.lastUsed=u,s(d.worker);vI(n,_=>{od.set(l,{worker:_,lastUsed:u}),s(_,o)})})}a(r,"findByHeaderAffinity")}function IY(){JS=0;for(let e of nd)e.expectedIdle=e.recentELU.idle+vme,e.requests=1;nd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Hme(e,t,r){let n=Bme++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),XS.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),XS.delete(n)),s.event=="destroy"&&(e.destroy(),XS.delete(n))})}var Ds,id,ad,ZS,eT,AY,bY,nd,sd,yY,gY,DI,OY,PI,Pme,MI,JS,RY,od,vme,XS,Bme,TI=De(()=>{Ds=v(it()),id=require("net"),ad=v(M()),ZS=v(V()),eT=require("fs");gi();AY=require("worker_threads"),bY=v(sc()),nd=[],sd=[],yY=[],DI=0,OY=[];AY.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Ds.onMessageFromWorkers)(e=>{e.type===ad.ITC_EVENT_TYPES.RESTART&&PI&&(clearInterval(PI),NY())}));Pme=6e5;a(Lme,"startHTTPThreads");a(NY,"licenseWarning");a(LI,"startHTTPWorker");a(UI,"startSocketServer");JS=0;a(vI,"findMostIdleWorker");RY=36e5,od=new Map;a(Mme,"findByRemoteAddressAffinity");a(Ume,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of od)r.lastUsed+RY<e&&od.delete(t)},RY).unref();vme=1e3;a(IY,"updateWorkerIdleness");(0,Ds.setMonitorListener)(IY);XS=new Map,Bme=1;a(Hme,"proxySocket")});var PY=b((YLe,DY)=>{"use strict";var xme=require("cluster"),al=te();al.initSync();var CY=M(),FLe=require("util"),Do=V(),GLe=require("fs"),kme=require("fastify"),qLe=Kl(),Fme=require("@fastify/cors"),Gme=require("@fastify/compress"),qme=require("@fastify/static"),$me=sN(),Vme=require("path"),{PACKAGE_ROOT:Yme}=M(),Kme=as(),Wme=J(),jme=vn(),Qme=sc(),{server:zme}=($r(),oe($a)),{node_request_key:$Le}=(wS(),oe($N)),{authHandler:Jme,handlePostRequest:Xme,serverErrorHandler:Zme,reqBodyValidationHandler:epe}=NS(),VLe=require("net"),{registerContentHandlers:tpe}=(Uu(),oe(gq)),rpe=6e4,npe=1024*1024*1024,spe="TRUE",{CONFIG_PARAMS:gE}=CY,cd;DY.exports={hdbServer:wY,start:wY};async function wY(e){try{Do.debug("In Fastify server"+process.cwd()),Do.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Do.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=xme.isMaster,await ipe();let t=e.securePort>0;cd=ope(t),await cd.ready(),e||(e={}),e.isOperationsServer=!0;try{zme.http(cd.server,e),cd.server.closeIdleConnections||await cd.listen({port:0,host:"::"})}catch(r){throw cd.close(),Do.error(r),Do.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Do.fatal(t),process.exit(1)}}a(wY,"operationsServer");async function ipe(){Do.trace("Configuring HarperDB process."),Kme.setSchemaDataToGlobal(),await jme.setUsersToGlobal(),await Qme.getLicense()}a(ipe,"setUp");function ope(e){Do.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=ape(e),r=kme(t);r.server.headersTimeout=lpe(),r.setErrorHandler(Zme);let n=cpe();n&&r.register(Fme,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,d){r.server.emit("unhandled",l.raw,d.raw)}),c()}),r.register($me),r.register(Gme),r.register(qme,{root:Vme.join(Yme,"studio/build-local")}),tpe(r);let s=al.get(CY.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Wme.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[epe,Jme],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Xme(i,o)}),r.get("/health",()=>"HarperDB is running."),Do.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(ope,"buildServer");function ape(e){let t=al.get(gE.OPERATIONSAPI_NETWORK_TIMEOUT),r=al.get(gE.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:npe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(ape,"getServerOptions");function cpe(){let e=al.get(gE.OPERATIONSAPI_NETWORK_CORS),t=al.get(gE.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===spe)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(cpe,"getCORSOpts");function lpe(){return al.get(gE.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??rpe}a(lpe,"getHeaderTimeoutConfig")});var GI={};et(GI,{disableNATS:()=>dpe,publishToStream:()=>nT,setNATSReplicator:()=>BI,setPublishToStream:()=>_pe,setSubscription:()=>FI,start:()=>upe});function upe(){RE.default.get(AE.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&Epe()}function dpe(e=!0){BY=e}function _pe(e,t){nT=e,FI=t}function Epe(){if(BY||process.env._DISABLE_NATS)return;let e=mt(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];BI(s,r,i)}}bc((r,n)=>{BI(r.tableName,r.databaseName,r),n&&xY(r)}),!LY&&(LY=!0)}function BI(e,t,r){if(t==="system"&&hpe.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends Ir{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[je],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[je]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[je],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[je],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[je]})}static defineSchema(i){xY(i)}static subscribe(){let i=new In;return FI(t,e,i),i}static subscribeOnThisThread(i){return i<(RE.default.get(AE.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??fpe)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new tT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=HY;return i}a(n,"getNATSTransaction")}function xY(e){let t=RE.default.get(AE.default.CONFIG_PARAMS.CLUSTERING_NODENAME);nT(`${xI.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,kI.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var MY,xI,kI,UY,vY,RE,AE,rT,BY,nT,FI,fpe,HY,LY,hpe,tT,HI,kY=De(()=>{Le();Hs();MY=v(kt()),xI=v(dt()),kI=v(zi());Al();UY=v(rb()),vY=v(nn()),RE=v(te()),AE=v(M()),rT=v(V());a(upe,"start");a(dpe,"disableNATS");nT=MY.publishToStream,FI=UY.setSubscription;a(_pe,"setPublishToStream");fpe=2;a(Epe,"assignReplicationSource");hpe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(BI,"setNATSReplicator");a(xY,"publishSchema");tT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=RE.default.get(AE.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,d;for(let u of i){let _=u.table,E=u.operation=="put"?"upsert":u.operation;l||(rT.trace(`Sending transaction event ${E}`),d=l={operation:E,schema:s,table:_,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===_&&l.operation===E?(o.push(u.record),c.push(u.id)):d=d.next={operation:E,table:_,id:u.id,record:u.record},u.expiresAt&&(d.expiresAt=u.expiresAt)}l&&n.push(nT(`${xI.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,kI.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(u=>{throw rT.error("An error has occurred trying to replicate transaction",l,u),u.statusCode=504,u}))}return Promise.all(n)}},HI=class extends tT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,vY.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};HY=new HI});async function VY({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await qI.get(e,{returnNonexistent:!0});i=new YI(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await qI.get(e);o&&o.delete()}i=new iT(e,t)}return n&&(n.id=e,n.user={username:t?.username},bE.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function $I(){return sT++,sT>65500&&(sT=1),sT}function VI(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=ea.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Ct(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var GY,Ua,qY,$Y,FY,qI,bE,sT,iT,YI,YY=De(()=>{Le();B_();GY=v(nn()),Ua=v(V());uc();qY=v(it()),$Y=v(CI());$r();FY=100,qI=Et({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),bE=Et({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,qY.getWorkerIndex)()===0&&(async()=>{await $Y.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of bE.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await st.getUser(r.user.username));try{await VI(r,t,r)}catch{(0,Ua.warn)("Failed to publish will",t)}bE.delete(e.id)}})();a(VY,"getSession");sT=1;a($I,"getNextMessageId");iT=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,d;if(c>-1?(l=s.slice(c),d=s.slice(0,c)):d=s,!d)throw new Error("No topic provided");if(d.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let u=this.subscriptions.find(R=>R.topic===s),_;u?(_=i>0,u.end(),this.subscriptions.splice(this.subscriptions.indexOf(u),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,Ua.trace)("Resuming subscription from",s,"from",o);let f=ea.getMatch(d,"mqtt");if(!f){let R=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw R.statusCode=404,R}if(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let R=E.url.slice(1);if(R.indexOf("#")>-1&&R.indexOf("#")!==R.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,R.indexOf("+")===R.length-1)E.onlyChildren=!0,E.url="/"+R.slice(0,R.length-1);else{let p=R.split("/"),y;for(let x=0;x<p.length;x++)if(p[x].indexOf("+")>-1)if(p[x]==="+")y=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&y)throw new Error("Filters can not be combined");let O=!0;p[p.length-1]==="#"&&(p.length--,O=!1),y&&(n=a(x=>{let W=x.id;if(!Array.isArray(W)||O&&W.length!==p.length)return!1;for(let q=0;q<p.length;q++)if(p[q]!=="+"&&p[q]!==W[q])return!1;return!0},"filter"));let B=p.indexOf("+");E.url="/"+(B>-1?p.slice(0,B):p).concat("").join("/")}}let h=f.path,T=f.Resource,S=await Ct(E,async()=>{let R=this.createContext();R.topic=s,R.retainHandling=i;let p=await T.subscribe(E,R);if(!p)throw new Error(`No subscription was returned from subscribe for topic ${s}`);if(!p[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let y=(async()=>{for await(let O of p)try{let B;if(O.type&&O.type!=="put"&&O.type!=="delete"&&O.type!=="message"&&O.type!=="patch"||n&&!n(O))continue;r?(O.topic=s,B=this.needsAcknowledge(O)):(O.acknowledge?.(),B=$I());let x=O.id;if(Array.isArray(x)&&(x=Xl(x)),x==null&&(x=""),await this.listener(h+"/"+x,O.value,B,t)===!1)break;this.awaitingAcks?.size>FY?await new Promise(q=>setTimeout(q,this.awaitingAcks.size-FY)):await new Promise(setImmediate)}catch(B){(0,Ua.warn)(B)}})();return p});return S.topic=s,S.qos=t.qos,this.subscriptions.push(S),S}resume(){}needsAcknowledge(t){let r=$I();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,t.acknowledge)),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return VI(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Ct(r,async()=>{try{if(!t){let n=await bE.get(this.sessionId);n?.doesExist()&&await VI(n,n.data,r)}}finally{await bE.delete(this.sessionId)}}).catch(n=>{(0,Ua.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(VI,"publish");YI=class extends iT{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.timestamp):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=$I(),n={topic:t.topic,timestamp:t.timestamp};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ua.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,GY.getNextMonotonicTime)()),(0,Ua.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),qI.put(this.sessionRecord)}}});var WI={};et(WI,{bypassAuth:()=>mpe,start:()=>ppe});function mpe(){zY=!0}function ppe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new QY.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((d,u,_)=>{if(d.protocol==="mqtt"){o.events.emit("connection",d),xr.debug?.("Received WebSocket connection for MQTT from",d._socket.remoteAddress);let{onMessage:E,onClose:f}=WY(d,h=>{d.send(h)},u,Promise.resolve(_).then(()=>u?.user),o);d.on("message",E),d.on("close",f),d.on("error",h=>{xr.info?.("WebSocket error",h)})}},{subProtocol:"mqtt",...n})),(t||s)&&c.push(e.socket(async d=>{let u;if(o.events.emit("connection",d),xr.debug?.(`Received ${d.getCertificate?"SSL":"TCP"} connection for MQTT from ${d.remoteAddress}`),l){if(d.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=d.getPeerCertificate().subject.CN);try{u=await e.getUser(f,null,null),(0,ld.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&aT.notify?.({username:u?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:d.remoteAddress})}catch(h){throw(0,ld.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&aT.error?.({username:f,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:d.remoteAddress}),h}}else xr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",d.remoteAddress)}catch(f){o.events.emit("error",f,d),xr.error?.(f)}else if(l.required)return xr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${d.authorizationError}`),d.end()}!u&&zY&&d.remoteAddress.includes("127.0.0.1")&&(u=await(0,jY.getSuperUser)(),xr.debug?.("Auto-authorizing local connection",u?.username));let{onMessage:_,onClose:E}=WY(d,f=>d.write(f),null,u,o);d.on("data",_),d.on("close",E),d.on("error",f=>{xr.info?.("Socket error",f)})},{port:t,securePort:s,mtls:l})),c}function WY(e,t,r,n,s){KY||(KY=!0,N_(_=>{oT>0&&_.push({metric:"mqtt-connections",connections:oT,byThread:!0})}));let i;oT++;let o,c={protocolVersion:4},l=(0,cT.parser)({protocolVersion:5});function d(_){l.parse(_)}a(d,"onMessage");function u(){oT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),kn(!1,"connection","mqtt","disconnect"),xr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(u,"onClose"),l.on("packet",async _=>{n?.then&&(n=await n),o?.then&&await o;let E=_.topic,f=E?.indexOf("/",1),h=f>0?E.slice(0,f):E;gr(_.length,"bytes-received",h,S(_),"mqtt");try{switch(o?.receivedPacket?.(),_.cmd){case"connect":if(c.protocolVersion=_.protocolVersion,_.username)try{n=await st.getUser(_.username,_.password.toString(),r),(0,ld.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&aT.notify?.({username:n?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(q){return(0,ld.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&aT.error?.({username:_.username,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",_,e,q),kn(!1,"connection","mqtt","connect"),T({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",_,e),kn(!1,"connection","mqtt","connect"),T({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(_,n),_.will){let q=e.deserialize||(e.deserialize=Vc(r?.headers.get?.("content-type")));_.will.data=_.will.payload?.length>0?q(_.will.payload):void 0,delete _.will.payload}o=VY({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(q){return xr.error?.(q),s.events.emit("auth-failed",_,e,q),kn(!1,"connection","mqtt","connect"),T({cmd:"connack",reasonCode:q.code||5,returnCode:q.code||128})}s.events.emit("connected",o,e),kn(!0,"connection","mqtt","connect"),T({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((q,z,_e,X)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",q);let ue=q.indexOf("/",1),j=ue>0?q.slice(0,ue):q;T({cmd:"publish",topic:q,payload:R(z),messageId:_e||Math.floor(Math.random()*1e8),qos:X.qos},j);let ie=e._socket??e;return ie.writableNeedDrain?new Promise(ye=>ie.once("drain",ye)):!ie.closed}catch(ue){return xr.error?.(ue),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let p=[];for(let q of _.subscriptions){let z;try{z=(await o.addSubscription(q,q.qos>=1)).qos||0}catch(_e){s.events.emit("error",_e,e,q,o),xr.error?.(_e),z=c.protocolVersion<5?128:_e.statusCode===403?135:_e.statusCode===404?143:128}p.push(z)}await o.committed,T({cmd:"suback",granted:p,messageId:_.messageId});break;case"unsubscribe":{let q=[];for(let z of _.unsubscriptions)q.push(o.removeSubscription(z)?0:17);T({cmd:"unsuback",granted:q,messageId:_.messageId});break}case"pubrel":T({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let y=_.qos===2?"pubrec":"puback",O=e.deserialize||(e.deserialize=Vc(r?.headers.get?.("content-type"))),x=(_.payload?.length||0)>0?O(_.payload):void 0,W;try{W=await o.publish(_,x)}catch(q){s.events.emit("error",q,e,_,o),xr.warn?.(q),_.qos>0&&T({cmd:y,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&T({cmd:y,messageId:_.messageId,reasonCode:W===!1?144:0},_.topic);break;case"pubrec":T({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":T({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),kn(!0,"connection","mqtt","disconnect"),xr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(p){s.events.emit("error",p,e,_,o),xr.error?.(p),T({cmd:"disconnect"})}function T(p,y){let O=(0,cT.generate)(p,c);t(O),gr(O.length,"bytes-sent",y,S(p),"mqtt")}a(T,"sendPacket");function S(p){return p.qos>0?p.cmd+",qos="+p.qos:p.cmd}a(S,"packetMethodName");function R(p){return kc(p,r)}a(R,"serialize")}),l.on("error",_=>{xr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:d,onClose:u}}var cT,jY,ld,kr,KI,QY,aT,xr,zY,KY,oT,JY=De(()=>{cT=require("mqtt-packet");YY();jY=v(vn());Uu();gi();$r();ld=v(te()),kr=v(M()),KI=v(zl()),QY=require("events"),aT=(0,KI.loggerWithTag)("auth-event"),xr=(0,KI.loggerWithTag)("mqtt"),zY=(0,ld.get)(kr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(mpe,"bypassAuth");a(ppe,"start");oT=0;a(WY,"onSocket")});var Lf={};et(Lf,{component_errors:()=>dd,getComponentName:()=>Ape,loadComponent:()=>uT,loadComponentDirectories:()=>iK,setErrorReporter:()=>Rpe});function iK(e,t){t&&(QI=t),e&&(zI=e);let r=[];if((0,Nt.existsSync)(jI)){let s=(0,Nt.readdirSync)(jI,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Ut.join)(jI,o);r.push(uT(c,QI,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(uT(n,QI,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{sK=!0})}function Rpe(e){yE=e}async function uT(e,t,r,n,s,i){let o=(0,Nt.realpathSync)(e);if(!ZY.has(o)){ZY.set(o,!0),s&&(zI=s);try{let c;n&&(dd=new Map);let l=(0,Ut.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Nt.existsSync)(l)?c=n?(0,dT.getConfigObj)():(0,eK.parseDocument)((0,Nt.readFileSync)(l,"utf8")).toJSON():c=JI;let d=(0,Ut.join)(e,"node_modules","harperdb");try{cl.isMainThread&&(n||(0,Nt.existsSync)(d)&&(0,Nt.realpathSync)(fd.PACKAGE_ROOT)!==(0,Nt.realpathSync)(d))&&((0,Nt.rmSync)(d,{recursive:!0,force:!0}),(0,Nt.existsSync)((0,Ut.join)(e,"node_modules"))||(0,Nt.mkdirSync)((0,Ut.join)(e,"node_modules")),(0,Nt.symlinkSync)(fd.PACKAGE_ROOT,d,"dir"))}catch(E){ud.default.error("Error symlinking harperdb module",E)}let u=lT,_=n;for(let E in c){lT=E;let f=c[E];if(dd.set(n?E:(0,Ut.basename)(e),!1),!f)continue;let h,T=f.package;try{if(T){let O=e,B;for(;!(0,Nt.existsSync)(B=(0,Ut.join)(O,"node_modules",E));)if(O=(0,Ut.dirname)(O),O.length<(0,nK.getHdbBasePath)().length){B=null;break}if(B)h=await uT(B,t,r,!1),_=!0;else throw new Error(`Unable to find package ${E}:${T}`)}else h=gpe[E];if(!h)continue;let S=a(O=>(O.origin=r,Et(O)),"ensureTable"),R=f.network||(f.port||f.securePort)&&f,p=R?.securePort||R?.https&&R.port,y=!R?.https&&R?.port;if(cl.isMainThread&&(h=await h.startOnMainThread?.({server:st,ensureTable:S,port:y,securePort:p,resources:t,...f})||h,n&&R))for(let O of[y,p])try{if(+O&&!XY.includes(O)){let B=XI.get(fd.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);B&&ud.default.warn("Session affinity is not recommended and may cause memory leaks"),(B||!IS)&&(XY.push(O),UI(O,B))}}catch(B){console.error("Error listening on socket",O,B,E)}if(t.isWorker&&(h=await h.start?.({server:st,ensureTable:S,port:y,securePort:p,resources:t,...f})||h),zI.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&f.files!=null){if(f.files.includes(".."))throw(0,rK.handleHDBError)("Can not reference parent directories");let O=(0,Ut.join)(e,f.files).replace(/\\/g,"/"),B=O.indexOf("/*");if(B>-1&&f.files!==JI[E]?.files&&!(0,Nt.existsSync)(O.slice(0,B)))throw new Error(`The path '${O.slice(0,B)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let x=(0,Ut.basename)(e),W=f.path||"/";W=W.startsWith("/")?W:W.startsWith("./")?"/"+x+W.slice(2):W==="."?"/"+x:"/"+x+"/"+W;let q,z,_e;if(f.root){let ue=f.root;ue.startsWith("/")&&(ue=ue.slice(1)),ue.endsWith("/")&&(ue=ue.slice(0,-1)),ue+="/",z=(0,Ut.join)(e,ue)}else(_e=O.indexOf("/*"))>-1&&(z=O.slice(0,_e+1),q=(0,Ut.relative)(e,z));let X=!1;if(cl.isMainThread&&h.setupDirectory&&(X=await h.setupDirectory?.(W,z,t)),t.isWorker&&h.handleDirectory&&(X=await h.handleDirectory?.(W,z,t)),X)continue;for(let ue of await(0,tK.default)(O,{onlyFiles:!1,objectMode:!0})){let{path:j,dirent:ie}=ue;_=!0;let ye=(0,Ut.relative)(e,j).replace(/\\/g,"/");if(q)if(ye.startsWith(q))ye=ye.slice(q.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${ye}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ie=W+(W.endsWith("/")?"":"/")+ye;try{if(ie.isFile()){let Me=await Tpe(j);cl.isMainThread&&await h.setupFile?.(Me,Ie,j,t),t.isWorker&&await h.handleFile?.(Me,Ie,j,t)}else cl.isMainThread&&await h.setupDirectory?.(Ie,j,t),t.isWorker&&await h.handleDirectory?.(Ie,j,t)}catch(Me){Me.message=`Could not load ${ie.isFile()?"file":"directory"} '${j}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${Me.message}`,yE?.(Me),((0,_d.getWorkerIndex)()===0?console:ud.default).error(Me),t.set(f.path||"/",new Zo(Me)),dd.set(n?E:(0,Ut.basename)(e),Me.message)}}}}catch(S){S.message=`Could not load component '${E}' for application '${(0,Ut.basename)(e)}' due to: ${S.message}`,yE?.(S),((0,_d.getWorkerIndex)()===0?console:ud.default).error(S),t.set(f.path||"/",new Zo(S),null,!0),dd.set(n?E:(0,Ut.basename)(e),S.message)}}if(lT=u,cl.isMainThread&&!sK&&i&&(0,_d.watchDir)(e,async()=>iK()),c.extensionModule)return await _h((0,Ut.join)(e,c.extensionModule));if(!_&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;yE?.(new Error(E)),((0,_d.getWorkerIndex)()===0?console:ud.default).error(E),dd.set((0,Ut.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,yE?.(c),t.set("",new Zo(c))}}}var Nt,Ut,cl,eK,XI,fd,tK,_d,ud,rK,nK,Spe,dT,Tpe,jI,zI,sK,QI,dd,gpe,JI,XY,ZY,yE,lT,Ape,Mf=De(()=>{Nt=require("fs"),Ut=require("path"),cl=require("worker_threads"),eK=require("yaml"),XI=v(te()),fd=v(M());rD();oD();aD();vq();wV();UV();tK=v(require("fast-glob")),_d=v(it()),ud=v(V());Ag();$r();rK=v(fe());Le();TI();nK=v(te()),Spe=v(PY());vp();kY();ls();JY();dT=v(wt());wS();hb();({readFile:Tpe}=Nt.promises),jI=(0,dT.resolvePath)(XI.get(fd.CONFIG_PARAMS.COMPONENTSROOT)),zI=new Map,dd=new Map;a(iK,"loadComponentDirectories");gpe={REST:oS,rest:oS,graphqlSchema:Rg,jsResource:yg,fastifyRoutes:xN,login:Ng,static:kN,operationsApi:Spe,customFunctions:{},http:{},clustering:GI,replication:sa,authentication:If,mqtt:WI},JI={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(JI,"static",{value:{files:"web/**"}});XY=[],ZY=new Map;a(Rpe,"setErrorReporter");Ape=a(()=>lT,"getComponentName");a(uT,"loadComponent")});var zS=b((TMe,aK)=>{var{isMainThread:oK}=require("worker_threads"),{getTables:bpe,getDatabases:pMe,table:SMe}=(Le(),oe(lt)),{loadComponentDirectories:ype,loadComponent:Ope}=(Mf(),oe(Lf)),{resetResources:Npe}=(B_(),oe(rB)),Ipe=RO(),wpe=wt(),{dirname:Cpe}=require("path"),{getConnection:Dpe}=kt(),Ppe=te(),{CONFIG_PARAMS:Lpe}=M(),{loadCertificates:Mpe}=js(),ZI=new Map;async function Upe(e=!1){!oK&&Ppe.get(Lpe.CLUSTERING_ENABLED)&&Dpe();try{oK&&await Ipe()}catch(n){console.error(n)}let t=Npe();bpe(),t.isWorker=e,await Mpe(),await Ope(Cpe(wpe.getConfigFilePath()),t,"hdb",!0,ZI),await ype(ZI,t);let r=[];for(let[n]of ZI)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(Upe,"loadRootComponents");aK.exports.loadRootComponents=Upe});var it=b((RMe,ri)=>{"use strict";var{Worker:vpe,MessageChannel:Bpe,parentPort:ki,isMainThread:sw,threadId:Hpe,workerData:Fi}=require("worker_threads"),{PACKAGE_ROOT:xpe}=M(),{join:dK,isAbsolute:kpe,extname:Fpe}=require("path"),{server:_K}=($r(),oe($a)),{watch:Gpe,readdir:qpe}=require("fs/promises"),{totalmem:cK}=require("os"),OE=M(),fK=te(),Gi=V(),{randomBytes:$pe}=require("crypto"),{_assignPackageExport:Vpe}=Vi(),Ype=M(),lK=1024*1024,va=[],Ps=[],Kpe=50,iw=1e4,Wpe="restart",EK="request_thread_info",hK="resource_report",mK="thread_info",pK="added-port",jpe="ack",ew;Vpe("threads",Ps);ri.exports={startWorker:tw,restartWorkers:aw,shutdownWorkers:Zpe,workers:va,setMonitorListener:aSe,onMessageFromWorkers:eSe,onMessageByType:yK,broadcast:rSe,broadcastWithAcknowledgement:sSe,setChildListenerByType:Xpe,getWorkerIndex:SK,getWorkerCount:TK,getTicketKeys:RK,setMainIsWorker:zpe,setTerminateTimeout:Qpe,restartNumber:Fi?.restartNumber||1};Ps.onMessageByType=yK;Ps.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Ps.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};ri.exports.whenThreadsStarted=new Promise(e=>{ri.exports.threadsHaveStarted=e});var ow;function Qpe(e){iw=e}a(Qpe,"setTerminateTimeout");function SK(){return Fi?Fi.workerIndex:ow?0:void 0}a(SK,"getWorkerIndex");function TK(){return Fi?Fi.workerCount:ow?1:void 0}a(TK,"getWorkerCount");function zpe(e){ow=e,ri.exports.threadsHaveStarted()}a(zpe,"setMainIsWorker");var gK=1,_T;function RK(){return _T||(_T=sw?$pe(48):Fi.ticketKeys,_T)}a(RK,"getTicketKeys");Object.defineProperty(_K,"workerIndex",{get(){return SK()}});Object.defineProperty(_K,"workerCount",{get(){return TK()}});var AK={[EK](e,t){iSe(t)},[hK](e,t){oSe(t,e)}};function tw(e,t={}){let r=process.constrainedMemory?.()||cK();r=Math.min(r,cK(),2e4*lK);let n=fK.get(OE.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/lK/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Ps){let d=new Bpe;d.existingPort=l,i.push(d),o.push(d.port2)}Fpe(e)||(e+=".js");let c=new vpe(kpe(e)?e:dK(xpe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:gK=t.threadCount,name:t.name,restartNumber:ri.exports.restartNumber,ticketKeys:RK()},transferList:o,...t});for(let{port1:l,existingPort:d}of i)d.postMessage({type:pK,port:l,threadId:c.threadId},[l]);return ET(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>tw(e,t),c.on("error",l=>{Gi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{va.splice(va.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<Kpe?(t.unexpectedRestarts=c.unexpectedRestarts+1,tw(e,t)):Gi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{AK[l.type]?.(l,c)}),va.push(c),lSe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(tw,"startWorker");var Jpe=[OE.THREAD_TYPES.HTTP];async function aw(e=null,t=Math.max(gK>3,1),r=!0){if(sw){if(r){let{loadRootComponents:o}=zS();await o()}ri.exports.restartNumber++,t<1&&(t=t*va.length);let n=[],s=[];for(let o of va.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Gi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:ri.exports.restartNumber,type:OE.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=Jpe.indexOf(o.name)>-1,l=new Promise(d=>{let u=setTimeout(()=>{Gi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},iw*2).unref();o.on("exit",()=>{clearTimeout(u),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),d()})});if(n.push(l),c&&r){let d=o.startCopy(),u=new Promise(_=>{let E=a(f=>{f.type===Ype.ITC_EVENT_TYPES.CHILD_STARTED&&(Gi.trace("Worker has started",d.threadId),_(),s.splice(s.indexOf(u)),d.off("message",E))},"startListener");Gi.trace("Waiting for worker to start",d.threadId),d.on("message",E)});s.push(u),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=Lu();r&&(e==="http"||!e)&&fK.get(OE.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else ki.postMessage({type:Wpe,workerType:e})}a(aw,"restartWorkers");function Xpe(e,t){AK[e]=t}a(Xpe,"setChildListenerByType");function Zpe(e){return aw(e,1/0,!1)}a(Zpe,"shutdownWorkers");var bK=[];function eSe(e){bK.push(e)}a(eSe,"onMessageFromWorkers");var rw=new Map;function yK(e,t){let r=rw.get(e);r||rw.set(e,r=[]),r.push(t)}a(yK,"onMessageByType");var tSe=10;async function rSe(e,t){let r=0;for(let n of Ps)try{n.postMessage(e),r++>tSe&&(r=0,await new Promise(setImmediate))}catch(s){Gi.error("Unable to send message to worker",s)}t&&NK(e,null)}a(rSe,"broadcast");var fT=new Map,nSe=1;function sSe(e){return new Promise(t=>{let r=0;for(let n of Ps)try{let s=nSe++,i=a(()=>{fT.delete(s),--r===0&&t(),n!==ki&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,fT.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of fT)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Gi.error("Unable to send message to worker",s)}r===0&&t()})}a(sSe,"broadcastWithAcknowledgement");function iSe(e){e.postMessage({type:mK,workers:OK()})}a(iSe,"sendThreadInfo");function OK(){let e=Date.now();return va.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(OK,"getChildWorkerInfo");function oSe(e,t){e.resources=t,e.resources.updated=Date.now()}a(oSe,"recordResourceReport");var nw;function aSe(e){nw=e}a(aSe,"setMonitorListener");var cSe=1e3,uK=!1;function lSe(){uK||(uK=!0,setInterval(()=>{for(let e of va){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}nw&&nw()},cSe).unref())}a(lSe,"startMonitoring");var uSe=1e3;if(ki&&Fi?.addPorts){ET(ki);for(let e=0,t=Fi.addPorts.length;e<t;e++){let r=Fi.addPorts[e];r.threadId=Fi.addThreadIds[e],ET(r)}setInterval(()=>{let e=process.memoryUsage();ki.postMessage({type:hK,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},uSe).unref(),ew=a(()=>new Promise((e,t)=>{ki.on("message",r),ki.postMessage({type:EK});function r(n){n.type===mK&&(ki.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else ew=OK;ri.exports.getThreadInfo=ew;function ET(e,t){Ps.push(e),e.on("message",r=>{if(r.type===pK)r.port.threadId=r.threadId,ET(r.port);else if(r.type===jpe){let n=fT.get(r.id);n&&n()}else NK(r,e)}).on("close",()=>{Ps.splice(Ps.indexOf(e),1)}).on("exit",()=>{Ps.splice(Ps.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(ET,"addPort");function NK(e,t){for(let n of bK)n(e,t);let r=rw.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Gi.error(s)}}a(NK,"notifyMessageListeners");if(sw){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await qpe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(dK(s,o.name));try{for await(let{filename:o}of Gpe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await aw(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");ri.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else ki.on("message",async e=>{let{type:t}=e;t===OE.ITC_EVENT_TYPES.SHUTDOWN&&(ri.exports.restartNumber=e.restartNumber,ki.unref(),setTimeout(()=>{Gi.warn("Thread did not voluntarily terminate",Hpe),process.exit(0)},iw).unref())})});var cv={};et(cv,{AUDIT_STORE_OPTIONS:()=>Rf,Decoder:()=>uu,HAS_CURRENT_RESIDENCY_ID:()=>Ka,HAS_EXPIRATION_EXTENDED_TYPE:()=>Wd,HAS_ORIGINATING_OPERATION:()=>Kd,HAS_PREVIOUS_RESIDENCY_ID:()=>Wa,REMOTE_SEQUENCE_UPDATE:()=>km,createAuditEntry:()=>yl,getLastRemoved:()=>xb,openAuditStore:()=>TT,readAuditEntry:()=>Ht,setAuditRetention:()=>_Se,transactionKeyEncoder:()=>BK});function TT(e){let t=e.auditStore=e.openDB(cw.AUDIT_STORE_NAME,{create:!1,...Rf});t||(t=e.auditStore=e.openDB(cw.AUDIT_STORE_NAME,Rf),wK(t,1)),t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=hT){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:d,value:u}of t.getRange({start:1,snapshot:!1,end:Date.now()-lw})){if((u[0]&15)===uw){let _=Ht(u),E=_.tableId;r[E]?.(_.recordId)}if(c=t.remove(d),l=d,await new Promise(setImmediate),++o>=dSe){i=10;break}}await c}finally{o===0?i=Math.min(i<<1,lw/10):wK(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,IE.getWorkerIndex)()===(0,IE.getWorkerCount)()-1&&s(hT),(0,IE.getWorkerIndex)()===0&&!IK)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(IK=!0,ST.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function wK(e,t){dw[0]=t,e.put(Symbol.for("last-removed"),HK)}function xb(e){let t=e.get(Symbol.for("last-removed"));if(t)return HK.set(t),dw[0]}function _Se(e,t=hT){lw=e,hT=t}function yl(e,t,r,n,s,i,o,c,l,d,u,_,E){let f=xK[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?Ba.setFloat64(0,n):Ls.set($g),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}R(s),R(t),S(r),Ba.setFloat64(h,e),h+=8,l&Ka&&R(d),l&Wa&&R(u),l&Wd&&(Ba.setFloat64(h,_),h+=8),l&Kd&&R(kK[E]),i?S(i):Ls[h++]=0,l?Ba.setUint16(n?8:0,f|l|32768):Ls[n?8:0]=f;let T=Ls.subarray(0,h);if(c)return Buffer.concat([T,c]);return T;function S(p){let y=h;h+=1,h=(0,ll.writeKey)(p,Ls,h);let O=h-y-1;O>127?O>16383?(ST.error("Key or username was too large for audit entry",p),h=y+1,Ls[y]=0):(Ls.copyWithin(y+2,y+1,h),Ba.setUint16(y,O|32768),h++):Ls[y]=O}function R(p){p<128?Ls[h++]=p:p<16384?(Ba.setUint16(h,p|32768),h+=2):p<1056964608?(Ba.setUint32(h,p|3221225472),h+=4):(Ls[h]=255,Ba.setUint32(h+1,p),h+=5)}}function Ht(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new uu(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),d=n.position,u=n.position+=l,_=n.readFloat64(),E,f,h,T;if(i&Ka&&(E=n.readInt()),i&Wa&&(f=n.readInt()),i&Wd&&(h=n.readFloat64()),i&Kd){let p=n.readInt();T=kK[p]}l=n.readInt();let S=n.position,R=n.position+=l;return{type:xK[i&7],tableId:c,nodeId:o,get recordId(){return(0,ll.readKey)(e,d,u)},getBinaryRecordId(){return e.subarray(d,u)},version:_,previousLocalTime:s,get user(){return R>S?(0,ll.readKey)(e,S,R):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(p,y,O){if(i&mT||i&NE&&!y)return p.decoder.decode(e.subarray(n.position,r));if(i&NE&&O)return _w(p.getEntry(this.recordId),O,p)},getBinaryValue(){return i&(mT|NE)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:E,previousResidencyId:f,expiresAt:h,originatingOperation:T}}catch(n){return ST.error("Reading audit entry error",n,e),{}}}var ll,pT,cw,UK,IE,vK,ST,Ls,Ba,BK,Rf,lw,dSe,dw,HK,hT,IK,mT,NE,CK,uw,DK,PK,LK,MK,km,Ka,Wa,Kd,Wd,xK,kK,uu,Ki=De(()=>{ll=require("ordered-binary"),pT=v(te()),cw=v(Bt()),UK=v(M()),IE=v(it()),vK=v(J());Ol();ST=v(V());gT();(0,pT.initSync)();Ls=Buffer.alloc(1024),Ba=new DataView(Ls.buffer,Ls.byteOffset,1024),BK={writeKey(e,t,r){return e===Yd?(t.set(Yd,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,ll.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,ll.readKey)(e,t,r)}},Rf={encoding:"binary",keyEncoder:BK},lw=(0,vK.convertToMS)((0,pT.get)(UK.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,dSe=1e3,dw=new Float64Array(1),HK=new Uint8Array(dw.buffer),hT=1e4,IK=!1;a(TT,"openAuditStore");a(wK,"updateLastRemoved");a(xb,"getLastRemoved");a(_Se,"setAuditRetention");mT=16,NE=32,CK=1,uw=2,DK=3,PK=4,LK=5,MK=6,km=11,Ka=512,Wa=1024,Kd=2048,Wd=4096,xK={put:CK|mT,[CK]:"put",delete:uw,[uw]:"delete",message:DK|mT,[DK]:"message",invalidate:PK|NE,[PK]:"invalidate",patch:LK|NE,[LK]:"patch",relocate:MK,[MK]:"relocate"},kK={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(yl,"createAuditEntry");a(Ht,"readAuditEntry");uu=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;try{t=this.getUint8(this.position++)}catch(r){throw r}return t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch{debugger}}}});var fw={};et(fw,{add:()=>RT,applyReverse:()=>FK,getRecordAtTime:()=>_w,rebuildUpdateBefore:()=>AT});function RT(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function AT(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,RT(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function FK(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=fSe[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=GK}}function _w(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),d=Ht(l);switch(d.type){case"put":s=d.getValue(r);break;case"patch":FK(s,d.getValue(r));break;case"delete":s=null}i=d.previousLocalTime}let o={},c=0;for(let l in s)s[l]===GK&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),d=Ht(l),u;switch(d.type){case"put":u=d.getValue(r);break;case"patch":u=d.getValue(r);break}for(let _ in u)o[_]&&(s[_]=u[_],o[_]=!1,c--);i=d.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var fSe,GK,gT=De(()=>{Ki();a(RT,"add");RT.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};fSe={add:RT};a(AT,"rebuildUpdateBefore");a(FK,"applyReverse");GK={};a(_w,"getRecordAtTime")});function Qn(e){return e[ur]||(e[ur]=Object.create(null))}function IT(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,d;if(o.resolve)d={get(){return o.resolve(this,this[xe])},set(u){return o.set(this,u)},configurable:!0};else{switch(o.type){case"String":l=a(function(u){if(!(typeof u=="string"||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"ID":l=a(function(u){if(!(typeof u=="string"||u?.length>0&&u.every?.(_=>typeof _=="string")||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Float":case"Number":l=a(function(u){let _=u?.__op__?u.value:u;if(!(typeof _=="number"||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a number, attempt to assign ${_}`);Qn(this)[c]=u},"set");break;case"Int":l=a(function(u){let _=u?.__op__?u.value:u;if(!(_>>0===_||u==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),u?.__op__?u.value=_:u=_;else throw new Ms.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Long":l=a(function(u){let _=u?.__op__?u.value:u;if(!(Math.round(_)===u&&Math.abs(_)<=9007199254740992||u==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),u?.__op__?u.value=_:u=_;else throw new Ms.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"BigInt":l=a(function(u){let _=u?.__op__?u.value:u;if(!(typeof _=="bigint"||u==null&&o.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),u?.__op__?u.value=_:u=_;else throw new Ms.ClientError(`${c} must be a number, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Boolean":l=a(function(u){if(!(typeof u=="boolean"||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a boolean, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Date":l=a(function(u){if(!(u instanceof Date||u==null&&o.nullable!==!1))if(typeof u=="string"||typeof u=="number")u=new Date(u);else throw new Ms.ClientError(`${c} must be a Date, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Bytes":l=a(function(u){if(!(u instanceof Uint8Array||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${u}`);Qn(this)[c]=u},"set");break;case"Any":case void 0:l=a(function(u){Qn(this)[c]=u},"set");break;default:l=a(function(u){if(!(typeof u=="object"||u==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be an object, attempt to assign ${u}`);Qn(this)[c]=u},"set")}d={get(){let u=this[ur];if(u&&c in u){let E=u[c];if(E?.__op__){let f=this[ve]?.[c];return E.update(f)}return E}let _=this[ve]?.[c];if(_&&typeof _=="object"){let E=$K(_,o);if(E)return u||(u=this[ur]=Object.create(null)),u[c]=E}return _},set:l,enumerable:!0,configurable:!0}}d.get.isAttribute=!0,n[c]=d,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,d)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let l=this[ur];return l?.[o]!==void 0?l[o]:this[ve]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new Ms.ClientError("Can not add a property to a sealed table schema");Qn(this)[o]=c}),i("deleteProperty",function(o){Qn(this)[o]=void 0}),i("toJSON",function(){let o=this[ur],c;for(let d in o){c||(c={...this[ve]});let u=o[d];if(u?.__op__){let _=c[d];u=u.update(_)}c[d]=u}return Object.keys(this).length>0&&(c||(c={...this[ve]}),Object.assign(c,this)),c||this[ve]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function $K(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=s}},IT(r,t)),new r(e)):new bT(e);case Array:let n=new OT(e.length);n[ve]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=$K(o,t?.elements)),n[s]=o}return n;default:return e}}function am(e){let t=e[ur],r;for(let s in t){r||(r={...e[ve]});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=am(i);r[s]=i}return Object.keys(e).length>0&&(r||(r={...e[ve]}),Object.assign(r,e)),r||e[ve]}function dl(e,t=e[ur]){let r;if(qK.call(e,ve)&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=dl(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e[ve]});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=fw[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=dl(s);r[n]=s}return r?Object.freeze(r):qK.call(e,ve)?e[ve]:e}function yT(e){let t=e[ve];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[ul]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.[ve]===s){if(yT(i))return!0}else return!0}}else{let r=e[ur];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[ve]===i){if(yT(s))return!0}else return!0}else return!0}}return!1}var Ms,ur,bT,qK,ul,OT,NT,cm=De(()=>{Hs();Ms=v(fe());gT();ur=Symbol("own-data");a(Qn,"getChanges");a(IT,"assignTrackedAccessors");a($K,"trackObject");bT=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=t}};IT(bT,{});a(am,"collapseData");qK=Object.prototype.hasOwnProperty;a(dl,"updateAndFreeze");a(yT,"hasChanges");ul=Symbol.for("has-array-changes"),OT=class extends Array{static{a(this,"TrackedArray")}[ul];constructor(t){super(t)}splice(...t){return this[ul]=!0,super.splice(...t)}push(...t){return this[ul]=!0,super.push(...t)}pop(){return this[ul]=!0,super.pop()}unshift(...t){return this[ul]=!0,super.unshift(...t)}shift(){return this[ul]=!0,super.shift()}};OT.prototype.constructor=Array;NT=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var EA={};et(EA,{CONTEXT:()=>xe,ID_PROPERTY:()=>je,IS_COLLECTION:()=>ni,MultiPartId:()=>CT,RECORD_PROPERTY:()=>ve,Resource:()=>Ir,snake_case:()=>hSe,transformForSelect:()=>DT});function hSe(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function VK(e,t){if(_l=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(_l=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new CT;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){_l=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return _l=!0,null;e[e.length-1]==="/"&&(_l=!0)}return t.coerceId(decodeURIComponent(e))}function zn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,d,u;if(r?(o?(u=i,o=o[xe]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(u=s,c=u[this.primaryKey]??null,o=i[xe]||i):u=i:(u=s,s=void 0,c=u[je]??u[this.primaryKey]),c===null&&(d=!0)):i?o=i[xe]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let T=this.parseQuery(c.slice(f+1));l?l=Object.assign(T,l):l=T,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),d=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],d=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,d=!1)))}c===void 0&&(c=s.id??null,c==null&&(d=!0))}else c=s,l=new Yc(c),c===null&&(d=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||d?(_={...t},l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),d&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return Ct(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,u,o):f.allowUpdate(o.user,u,o):t.type==="create"?f.allowCreate(o.user,u,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(T=>{if(!T)throw new wT(o.user);return typeof u?.then=="function"?u.then(S=>e(f,l,o,S)):e(f,l,o,u)});if(!h)throw new wT(o.user)}return typeof u?.then=="function"?u.then(h=>e(f,l,o,h)):e(f,l,o,u)}a(E,"authorizeActionOnResource")}}function Jn(e,t){let r=new WK.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function Ew(e,t,r){let n=e[ve];if(n){let s=e[ur];return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function DT(e,t){let r=t?.propertyResolvers,n=t[xe],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):Ew(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let d=[],u=i(Ew(l,r,n));for(let _ of e)d.push(u(_));return d},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let d={},u=i(Ew(l,r,n)),_;for(let E of e){let f=u(E);f===void 0&&o&&(f=null),f?.then?(_||(_=[]),_.push(f.then(h=>d[E.name||E]=h))):d[E.name||E]=f}return _?Promise.all(_).then(()=>d):d},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let u=r[c.name]?.definition?.tableClass;l=s[c.name]=DT(c.select||c,u)}let d=o(c.name);return l(d)}else return o(c);else return c}}a(i,"handleProperty")}var YK,KK,WK,xe,je,ni,ve,ESe,Ir,wT,_l,CT,Hs=De(()=>{YK=require("crypto");Al();KK=v(Vi()),WK=v(fe());cm();uc();Qf();xe=Symbol.for("context"),je=Symbol.for("primary-key"),ni=Symbol("is-collection"),ve=Symbol("stored-record"),ESe={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Ir=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[je]=t;let n=r?.[xe];this[xe]=n!==void 0?n:r||null}static get=zn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let d=DT(l,t.constructor);return typeof c?.map=="function"?c.map(d):d(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=zn(function(t,r,n,s){if(Array.isArray(s)&&t[ni]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,d=l.getResource(c[l.primaryKey],n,{async:!0});d.then?i.push(d.then(u=>u.put(c,n))):i.push(d.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):Jn(t,"put")},{hasContent:!0,type:"update"});static patch=zn(function(t,r,n,s){return t.patch?t.patch(s,r):Jn(t,"patch")},{hasContent:!0,type:"update"});static delete=zn(function(t,r,n,s){return t.delete?t.delete(r):Jn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,YK.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),Ct(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):Jn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=zn(function(t,r,n,s){return t.invalidate?t.invalidate(r):Jn(t,"delete")},{hasContent:!1,type:"update"});static post=zn(function(t,r,n,s){return t[je]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=zn(function(t,r,n,s){return t.connect?t.connect(s,r):Jn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=zn(function(t,r,n,s){return t.subscribe?t.subscribe(r):Jn(t,"subscribe")},{type:"read"});static publish=zn(function(t,r,n,s){return t[je]!=null&&t.update?.(),t.publish?t.publish(s,r):Jn(t,"publish")},{hasContent:!0,type:"create"});static search=zn(function(t,r,n,s){let i=t.search?t.search(r):Jn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=DT(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=zn(function(t,r,n,s){return t.search?t.search(s,r):Jn(t,"search")},{hasContent:!0,type:"read"});static copy=zn(function(t,r,n,s){return t.copy?t.copy(s,r):Jn(t,"copy")},{hasContent:!0,type:"create"});static move=zn(function(t,r,n,s){return t.move?t.move(s,r):Jn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[ni])return(await this.constructor.create(this[je],t,this[xe]))[je];Jn(this,"post")}static isCollection(t){return t?.[ni]}static coerceId(t){return t}static parseQuery(t){return sS(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&ESe[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:VK(t,this),isCollection:_l}}let i=VK(t,this);return _l?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[xe],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let d=l.asMap.get(t);if(s=d?.find(u=>u.constructor===c),s)return s;d||l.asMap.set(t,d=[]),d.push(s=new c(t,i))}else{if(s=l.find(d=>d[je]===t&&d.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let d=new Map;for(let u of l){let _=u[je],E=d.get(_);E?E.push(u):d.set(_,[u])}i.resourceCache.length=0,i.resourceCache.asMap=d}}}else s=new c(t,i);return o&&(s[ni]=!0),s}subscribe(t){return new In}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new In}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[je]}getContext(){return this[xe]}};Ir.prototype[xe]=null;(0,KK._assignPackageExport)("Resource",Ir);a(hSe,"snake_case");wT=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(VK,"pathToId");CT=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(zn,"transactional");a(Jn,"missingMethod");a(Ew,"selectFromObject");a(DT,"transformForSelect")});var RN={};et(RN,{EVICTED:()=>ba,INVALIDATED:()=>Pi,coerceType:()=>LT,makeTable:()=>vT,setServerUtilities:()=>ySe,updateResource:()=>MT});function vT(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:d,dbisDB:u,sealed:_,splitSegments:E,replicate:f}=e,{expirationMS:h,evictionMS:T,audit:S,trackDeletes:R}=e,{attributes:p}=e;p||(p=[]);let y=Kg(i,n,l),O,B,x={},W=Promise.resolve(),q,z,_e;for(let k of p)(k.assignCreatedTime||k.name==="__createdtime__")&&(q=k),(k.assignUpdatedTime||k.name==="__updatedtime__")&&(z=k),k.expiresAt&&(_e=k),k.isPrimaryKey&&(x=k);let X,ue=[],j=[],ie=1,ye=2,Ie={},Me={},tn=864e5,gd,ka,yn,YE=!1,Fa,zT=new Map,Rd=new Map,bt,es,ts=Ed.get(Us.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(ts)){for(let k of ts)if(k.name===c&&k.replicateTo>=0){es=k.replicateTo;break}}let KE=i.getRange({start:!1,end:!1}).constructor,Uw=10,rs=6;S&&rt();class Ge extends Ir{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=S;static databasePath=o;static databaseName=c;static attributes=p;static replicate=f;static sealed=_;static splitSegments=E??!0;static createdTimeProperty=q;static updatedTimeProperty=z;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=u;static schemaDefined=d;static sourcedFrom(m,g){if(g&&(this.sourceOptions=g,(g.expiration||g.eviction||g.scanInterval)&&this.setTTLExpiration(g)),g?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(w=>!w.intermediateSource))throw new Error("Can not have multiple canonical (non-intermediate) sources");this.sources.push(m)}B=B||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),O=O||m.load;let D=a(w=>{let N=this.sources;if(N=N.filter(H=>H.intermediateSource&&H[w]&&(!H[w].reliesOnPrototype||H.prototype[w])),N.length>0)if(N.length===1){let H=N[0];return(U,C,L)=>{if(U?.source!==H)return H[w](C,L,U)}}else return(H,U,C)=>{let L=[];for(let F of N){if(H?.source===F)break;L.push(F[w](U,C,H))}return Promise.all(L)}},"getApplyToIntermediateSource"),A=this.sources[this.sources.length-1];A.intermediateSource&&(A={});let I=a(w=>{if(A[w]&&(!A[w].reliesOnPrototype||A.prototype[w]))return(N,H,U)=>{if(!N?.source)return A[w](H,U,N)}},"getApplyToCanonicalSource");return Ie={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish")},Me={put:D("put"),patch:D("patch"),delete:D("delete"),publish:D("publish"),invalidate:D("invalidate")},(async()=>{let w=!1,N,H=a(async(U,C)=>{let L=U.value,F=U.table?We[c][U.table]:Ge;if(c===Us.SYSTEM_SCHEMA_NAME&&(U.table===Us.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||U.table===Us.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(w=!0),U.id===void 0&&(U.id=L[F.primaryKey],U.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(U));U.source=m;let G={residencyId:ft(U.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:U.nodeId},ce=await F.getResource(U.id,C,G);switch(U.type){case"put":return ce._writeUpdate(L,!0,G);case"patch":return ce._writeUpdate(L,!1,G);case"delete":return ce._writeDelete(G);case"publish":return ce._writePublish(L,G);case"invalidate":return ce._writeInvalidate(G);case"relocate":return ce._writeRelocate(G);default:Fe.default.error?.("Unknown operation",U.type,U.id)}},"writeUpdate");try{let U=m.subscribe;U&&R==null&&(R=!0);let C=m.subscribeOnThisThread?m.subscribeOnThisThread((0,El.getWorkerIndex)()):(0,El.getWorkerIndex)()===0,L=U&&C&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(L){let F;for await(let G of L)try{if(!(G.type==="transaction"?G.writes[0]:G)){Fe.default.error?.("Bad subscription event",G);continue}if(G.source=m,G.type==="end_txn"){if(F?.resolve(),G.localTime&&N!==G.localTime){if(G.remoteNodeIds?.length>0){let Te=[Symbol.for("seq"),G.remoteNodeIds[0]],de=u.get(Te),Oe=de?.nodes;Oe||(Oe=[]);for(let ee of G.remoteNodeIds.slice(1)){let ge=Oe.find(Ke=>Ke.name===ee);ge||(ge={id:ee,seqId:0},Oe.push(ge)),ge.seqId=Math.max(de?.seqId??1,G.localTime),ee===G.nodeId&&(ge.lastTxnTime=G.timestamp)}let Z=Math.max(de?.seqId??1,G.localTime);Fe.default.trace?.("Received txn",c,Z,G.localTime,G.remoteNodeIds),u.put(Te,{seqId:Z,nodes:Oe})}N=G.localTime}G.onCommit&&F?.committed.then(G.onCommit);continue}if(F)if(G.beginTxn)F.resolve();else{F.write_promises.push(H(G,F));continue}let re=Ct(G,()=>{if(G.type==="transaction"){let Te=[];for(let de of G.writes)try{Te.push(H(de,G))}catch(Oe){throw Oe.message+=" writing "+JSON.stringify(de)+" of event "+JSON.stringify(G),Oe}return Promise.all(Te)}else if(G.type==="define_schema"){let Te=this.attributes.slice(0),de;for(let Oe of G.attributes)Te.find(Z=>Z.name===Oe.name)||(Te.push(Oe),de=!0);de&&(Et({table:s,database:c,attributes:Te,origin:"cluster"}),LE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(F=G,F.write_promises=[H(G,G)],new Promise(Te=>{F.resolve=()=>Te(Promise.all(F.write_promises))})):H(G,G)});F&&(F.committed=re),w&&re&&!re?.waitingForUserChange&&(re.then(()=>LE.signalUserChange(new ME.UserEventMsg(process.pid))),re.waitingForUserChange=!0),G.onCommit&&(re?re.then(G.onCommit):G.onCommit())}catch(ce){Fe.default.error?.("error in subscription handler",ce)}}}catch(U){Fe.default.error?.(U)}})(),this}static getResource(m,g,D){let A=super.getResource(m,g,D);if(m!=null){$i(m);try{if(A.hasOwnProperty(ve))return A;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let I=!D?.async||i.cache?.get(m),w=Gr(g),N=w.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Ad(m,g,{transaction:N,ensureLoaded:D?.ensureLoaded},I,H=>{if(H?MT(A,H):A[ve]=null,g.onlyIfCached&&g.noCacheStore){if(!A.doesExist())throw new yr.ServerError("Entry is not cached",504)}else if(D?.ensureLoaded){let U=Tl(m,H,g,A);if(U)return w?.disregardReadTxn(),A[hw]=!0,pw(U,C=>(MT(A,C),A))}return A})}catch(I){throw I.message.includes("Unable to serialize object")&&(I.message+=": "+JSON.stringify(m)),I}}return A}ensureLoaded(){let m=Tl(this[je],this[Fr],this[xe]);if(m)return this[hw]=!0,pw(m,g=>{this[Fr]=g,this[ve]=g.value,this[DE]=g.version})}static getNewId(){let m=x?.type;if(m==="String"||m==="ID")return super.getNewId();if(!bt){let I=i.getEntry(Symbol.for("id_allocation")),w=I?.value,N;if(w&&w.nodeName===server.hostname&&(!NSe(i)||w.pid===process.pid)){let H=w.start,U=w.end;N=H;for(let C of i.getKeys({start:U,end:H,limit:1,reverse:!0}))N=C}else w=A(I?.version??null),N=w.start;bt=new BigInt64Array([BigInt(N)+1n]),bt=new BigInt64Array(i.getUserSharedBuffer("id",bt.buffer)),bt.maxSafeId=w.end}let g=Number(Atomics.add(bt,0,1n)),D=m==="Int"?512:1048576;if(g+D>=bt.maxSafeId){let I=a(w=>{bt.maxSafeId=g+(m==="Int"?1023:4194303);let N=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,H=w?void 0:i.useReadTransaction(),U=Number(bt[0]);for(let F of i.getKeys({start:U+1,end:N,limit:1,transaction:H}))N=F;H?.done();let{value:C,version:L}=i.getEntry(Symbol.for("id_allocation"));if(bt.maxSafeId<N){if(C.end>bt.maxSafeId-100)return;Fe.default.info?.("New id allocation",g,bt.maxSafeId,L),i.put(Symbol.for("id_allocation"),{start:C.start,end:bt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),L)}else{Fe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${bt.maxSafeId}, but id of ${N} detected`);let F=A(L);F.alreadyUpdated||Atomics.store(bt,0,BigInt(F.start+1)),bt.maxSafeId=F.end}},"updateEnd");g+D===bt.maxSafeId?setImmediate(I):g+100>=bt.maxSafeId&&(Fe.default.warn?.(`Synchronous id allocation required on table ${s}${m=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>I(!0)))}return g;function A(I){let w=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,N=w/4,H,U,C=!1,L,F;do{L=Math.floor(Math.random()*w),F={start:L,end:L+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},H=0;for(let G of i.getKeys({start:L,limit:1,reverse:!0}))H=G;U=w;for(let G of i.getKeys({start:L+1,end:w,limit:1}))U=G;N*=.875,N<1e3&&!C&&(C=!0,Fe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${m==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,L,H,U,N))}while(!(N<U-L&&(N<L-H||H===0)));return i.transactionSync(()=>{let G=i.getEntry(Symbol.for("id_allocation"));return(G?.version??null)==I?(Fe.default.info?.("Allocated new id range",F),i.put(Symbol.for("id_allocation"),F,Date.now()),F):(Fe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...G.value})})}}static setTTLExpiration(m){if(typeof m=="number")h=m*1e3,T||(T=0);else if(m&&typeof m=="object")h=m.expiration*1e3,T=(m.eviction||0)*1e3,tn=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");tn=tn||(h+T)/4,Se()}static getResidencyRecord(m){return u.get([Symbol.for("residency_by_id"),m])}static setResidency(m){Ge.getResidency=m}static setResidencyById(m){Ge.getResidencyById=m}static getResidency(m,g,D){if(Ge.getResidencyById)return Ge.getResidencyById(m[t]);let A=es;if(g.replicateTo!=null){if(Array.isArray(g.replicateTo))return g.replicateTo.includes(server.hostname)?g.replicateTo:[server.hostname,...g.replicateTo];g.replicateTo>=0&&(A=g.replicateTo)}if(A>=0&&server.nodes){let I=[server.hostname];if(D)I.push(...D.slice(0,A));else{let w=server.nodes.map(U=>U.name),N=Math.floor(w.length*Math.random());I.push(...w.slice(N,N+A));let H=N+A-w.length;H>0&&I.push(...w.slice(0,H))}return I}}static enableAuditing(m=!0){S=m,m&&rt(),Ge.audit=m}static coerceId(m){return m===""?null:LT(m,x)}static async dropTable(){if(delete We[c][s],c===o){for(let m of p)u.remove(Ge.tableName+"/"+m.name),r[m.name]?.drop();u.remove(Ge.tableName+"/"),i.drop(),await u.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));LE.signalSchemaChange(new ME.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[ni])return this.search(m);if(this[je]===null){if(m?.conditions)return this.search(m);let g=Ge.getRecordCount();return{recordCount:g.recordCount,estimatedRecordRange:g.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:p}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[xe]?.returnNonexistent)return this}allowRead(m,g){let D=Uo(m);if(D?.read){if(D.isSuperUser)return!0;let A=D.attribute_permissions,I=g?.select;if(A?.length>0||YE&&I){if(g||(g={}),I){let w=A?.length>0&&mw(A,"read");g.select=I.map(N=>{let H=N.name||N;if(!w||w[H]){let U=yn[H]?.definition?.tableClass;if(U){if(N.name||(N={name:N}),!U.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else g.select=A.filter(w=>w.read&&!yn[w.attribute_name]).map(w=>w.attribute_name);return g}else return!0}}allowUpdate(m,g){let D=Uo(m);if(D?.update){let A=D.attribute_permissions;if(A?.length>0){let I=mw(A,"update");for(let w in g)if(!I[w])return!1;for(let w of A){let N=w.attribute_name;!w.update&&!(N in g)&&(g[N]=this.getProperty(N))}}return se(this[xe])}}allowCreate(m,g){if(this[ni]){let D=Uo(m);if(D?.insert){let A=D.attribute_permissions;if(A?.length>0){let I=mw(A,"insert");for(let w in g)if(!I[w])return!1;return se(this[xe])}else return se(this[xe])}}else return this.allowUpdate(m,{})}allowDelete(m){return Uo(m)?.delete&&se(this[xe])}update(m,g){if(!Gr(this[xe]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let A;return typeof m=="object"&&m&&(g?(Object.isFrozen(m)&&(m={...m}),this[ve]={},this[ur]=m):(A=this[ur],A&&(m=Object.assign(A,m)),this[ur]=A=m)),this._writeUpdate(this[ur],g),this}addTo(m,g){if(typeof g=="number"||typeof g=="bigint")this[wE]===QK?this.set(m,(+this.getProperty(m)||0)+g):(this[wE]||this.update(),this.set(m,new NT(g)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,g){if(typeof g=="number")return this.addTo(m,-g);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Fr]}invalidate(){this._writeInvalidate()}_writeInvalidate(m){let g=this[xe],D=this[je];$i(D),Gr(this[xe]).addWrite({key:D,store:i,invalidated:!0,entry:this[Fr],before:Ie.invalidate?.bind(this,g,D),beforeIntermediate:Me.invalidate?.bind(this,g,D),commit:(I,w)=>{if(Bo(I,w,m?.nodeId)<=0)return;let N=null;for(let H in r)N||(N={}),N[H]=this.getProperty(H);Fe.default.trace?.(`Invalidating entry id: ${D}, timestamp: ${new Date(I).toISOString()}`),y(D,N,this[Fr],I,Pi,S,{user:g?.user,residencyId:m?.residencyId,nodeId:m?.nodeId},"invalidate")}})}_writeRelocate(m){let g=this[xe],D=this[je];$i(D),Gr(this[xe]).addWrite({key:D,store:i,invalidated:!0,entry:this[Fr],before:Ie.relocate?.bind(this,g,D),beforeIntermediate:Me.relocate?.bind(this,g,D),commit:(I,w)=>{if(Bo(I,w,m?.nodeId)<=0)return;let N=Ge.getResidencyRecord(m.residencyId),H=0,U=null,C=w?.value;if(N&&!N.includes(server.hostname)){for(let L in r)U||(U={}),U[L]=C(L);H=Pi}else U=C;Fe.default.trace?.(`Relocating entry id: ${D}, timestamp: ${new Date(I).toISOString()}`),y(D,U,this[Fr],I,H,S,{user:g.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)}})}static _recordRelocate(m,g){let D={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},A=this.getResidency(g.value,D),I;if(A){if(!Array.isArray(A))throw new Error("Residency must be an array, but was: "+A);if(!A.includes(server.hostname))return;I=ft(A)}let N=y(m.key,g.value,m,m.version,0,!0,{residencyId:I,expiresAt:g.expiresAt},"relocate",!1,null)}static evict(m,g,D){let A=this.Source,I;if(!((B||S)&&(!g||(I=i.getEntry(m),!I||!g)||I.version!==D))){if(B){if(i.hasLock(m,I.version))return;let w;for(let N in r)w||(w={}),w[N]=g[N];if(w)return y(m,w,I,D,ba,null,null,null,!0)}return i.ifVersion(m,D,()=>{Mo(m,g,null)}),S?y(m,null,I,D,ba,null,null,null,!0):i.remove(m,D)}}lock(){throw new Error("Not yet implemented")}static operation(m,g){return m.table||=s,m.schema||=c,nW.operation(m,g)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,g,D){let A=this[xe],I=Gr(A),w=this[je];$i(w);let N=this[Fr];this[wE]=g?QK:RSe;let H={key:w,store:i,entry:N,nodeName:A?.nodeName,validate:U=>{m||(m=this[ur]),g||m&&yT(this[ur]===m?this:m)?A?.source||(I.checkOverloaded(),this.validate(m,!g),z&&(m[z.name]=z.type==="Date"?new Date(U):z.type==="String"?new Date(U).toISOString():U),g&&(t&&m[t]!==w&&(m[t]=w),q&&(N?.value?m[q.name]=N?.value[q.name]:m[q.name]=q.type==="Date"?new Date(U):q.type==="String"?new Date(U).toISOString():U),m=dl(m))):I.removeWrite(H)},before:g?Ie.put?()=>Ie.put(A,w,m):null:Ie.patch?()=>Ie.patch(A,w,m):Ie.put?()=>Ie.put(A,w,dl(this)):null,beforeIntermediate:g?Me.put?()=>Me.put(A,w,m):null:Me.patch?()=>Me.patch(A,w,m):Me.put?()=>Me.put(A,w,dl(this)):null,commit:(U,C,L)=>{if(L){if(A&&C?.version>(A.lastModified||0)&&(A.lastModified=C.version),this[Fr]=C,C?.value?.[ve])throw new Error("Can not assign a record to a record, check for circular references");g||(this[ve]=C?.value??null)}this[ur]=void 0,this[DE]=U;let F=C?.value,G=m;this[wE]=0;let ce=Bo(U,C,D?.nodeId),re;if(ce<=0)if(S){let ee=C.localTime,ge=C.version;Fe.default.trace?.("Applying CRDT update to record with id: ",w,"applying later update:",ge);let Ke=[];for(;ee>U||ge>=U&&ee>0;){let ne=l.get(ee);if(!ne)break;let we=Ht(ne);if(ge=we.version,ge>=U){if(ge===U){if(ce=Bo(U,{version:ge,localTime:ee},D?.nodeId),ce===0)return;if(ce>0)continue}if(we.type==="patch")Ke.push(we),re=m;else if(we.type==="put"||we.type==="delete")return}ee=we.previousLocalTime}Ke.sort((ne,we)=>ne.version-we.version);for(let ne of Ke){let we=ne.getValue(i);if(G=AT(G,we,g),Fe.default.debug?.("Rebuilding update with future patch:",G),!G)return}}else{if(g)return;G=AT(G,F,g),Fe.default.debug?.("Rebuilding update without audit:",G)}let Te;if(g?Te=G:(this[ve]=F,Te=dl(this,G)),this[ve]=Te,Te?.[ve])throw new Error("Can not assign a record to a record, check for circular references");let de;if(D?.residencyId!=null)de=D.residencyId;else{N?.residencyId&&(A.previousResidency=Ge.getResidencyRecord(N.residencyId));let ee=Ge.getResidency(Te,A);if(ee){if(!Array.isArray(ee))throw new Error("Residency must be an array, got: "+ee);ee.includes(server.hostname)||ee.push(server.hostname)}de=ft(ee)}g||(re=m);let Oe=A?.expiresAt??(h?h+Date.now():-1);Fe.default.trace?.(`Saving record with id: ${w}, timestamp: ${new Date(U).toISOString()}${Oe?", expires at: "+new Date(Oe).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,Te),Mo(w,F,Te);let Z=g?"put":"patch";y(w,Te,C,U,0,S,{user:A?.user,residencyId:de,expiresAt:Oe,nodeId:D?.nodeId,originatingOperation:A?.originatingOperation},Z,!1,re),A.expiresAt&&Se()}};I.addWrite(H)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[ni]){for await(let g of this.search(m))(await Ge.getResource(g[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[ve]?this._writeDelete(m):!1}_writeDelete(m){let g=Gr(this[xe]),D=this[je];$i(D);let A=this[xe];return g.addWrite({key:D,store:i,resource:this,nodeName:A?.nodeName,before:Ie.delete?.bind(this,A,D),beforeIntermediate:Me.delete?.bind(this,A,D),commit:(I,w,N)=>{let H=w?.value;N&&(A&&w?.version>(A.lastModified||0)&&(A.lastModified=w.version),MT(this,w)),!(Bo(I,w,m?.nodeId)<=0)&&(Mo(this[je],H),Fe.default.trace?.(`Deleting record with id: ${D}, txn timestamp: ${new Date(I).toISOString()}`),S||R?(y(D,null,this[Fr],I,0,S,{user:A?.user,nodeId:m?.nodeId},"delete"),S||Se()):i.remove(this[je]))}}),!0}search(m){let g=this[xe],D=Gr(g);if(!m)throw new Error("No query provided");let A=m.conditions;A?A.length===void 0&&(A=A[Symbol.iterator]?Array.from(A):[A]):A=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[je]&&(A=[{attribute:null,comparator:Array.isArray(this[je])?"prefix":"starts_with",value:this[je]}].concat(A));let I,w={};function N(ee,ge){let Ke;switch(ge){case"and":case void 0:if(ee.length<1)throw new Error('An "and" operator requires at least one condition');Ke=!0;break;case"or":if(ee.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+ge)}for(let ne of ee){if(ne.conditions){ne.conditions=N(ne.conditions,ne.operator);continue}let we=ne[0]??ne.attribute,nt=we==null?x:Di(p,we);if(nt)(nt.type||jO[ne.comparator])&&(ne[1]===void 0?ne.value=U(ne.value,nt):ne[1]=U(ne[1],nt));else if(we!=null)throw(0,yr.handleHDBError)(new Error,`${we} is not a defined attribute`,404);if(ne.chainedConditions)if(ne.chainedConditions.length===1&&(!ne.operator||ne.operator=="and")){let Xe=ne.chainedConditions[0],$e,Kt;if(Xe.comparator==="gt"||Xe.comparator==="greater_than"||Xe.comparator==="ge"||Xe.comparator==="greater_than_equal"?($e=ne,Kt=Xe):($e=Xe,Kt=ne),$e.comparator!=="lt"&&$e.comparator!=="less_than"&&$e.comparator!=="le"&&$e.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let Or=Kt.comparator==="ge"||Kt.comparator==="greater_than_equal",ii=$e.comparator==="le"||$e.comparator==="less_than_equal";ne.comparator=(Or?"ge":"gt")+(ii?"le":"lt"),ne.value=[Kt.value,$e.value]}else throw new Error("Multiple chained conditions are not currently supported")}return ee}a(N,"prepareConditions");function H(ee,ge){if(m.enforceExecutionOrder)return ee;for(let Ke of ee)Ke.conditions&&(Ke.conditions=H(Ke.conditions,Ke.operator));return ee.length>1&&ge!=="or"?(0,tW.sortBy)(ee,nS(Ge)):ee}a(H,"orderConditions");function U(ee,ge){return Array.isArray(ee)?ee.map(Ke=>LT(Ke,ge)):LT(ee,ge)}a(U,"coerceTypedValues");let C=m.operator;(A.length>0||C)&&(A=N(A,C));let L=typeof m.sort=="object"&&m.sort,F;if(L&&C!=="or"){let ee=L.attribute;if(ee==null)throw new yr.ClientError("Sort requires an attribute");if(I=A.find(ge=>$u(ge.attribute)===$u(ee)),!I){let ge=Di(p,ee);if(!ge)throw(0,yr.handleHDBError)(new Error,`${Array.isArray(ee)?ee.join("."):ee} is not a defined attribute`,404);if(ge.indexed)I={attribute:ee,comparator:"sort"},A.push(I);else if(A.length===0&&!m.allowFullScan)throw(0,yr.handleHDBError)(new Error,`${Array.isArray(ee)?ee.join("."):ee} is not indexed and not combined with any other conditions`,404)}I&&(I.descending=!!L.descending)}A=H(A,C),L&&(I&&A[0]===I?L.next&&(F={dbOrderedAttribute:L.attribute,attribute:L.next.attribute,descending:L.next.descending,next:L.next.next}):(I&&A.splice(A.indexOf(I),1),F=L));let G=m.select;if(A.length===0&&(A=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:A,operator:C,postOrdering:F,selectApplied:!!G};let ce=D.useReadTxn(),re=QO(A,C,Ge,ce,m,g,(ee,ge)=>bd(ee,G,g,ce,ge),w),Te=m.ensureLoaded!==!1;F||(re=Z(re));let de=Ge.transformEntryForSelect(G,g,ce,w,Te,!0),Oe=Ge.transformToOrderedSelect(re,G,F,ce,g,de);function Z(ee){return m.offset||m.limit!==void 0?ee.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):ee}return a(Z,"applyOffset"),F&&(Oe=Z(Oe)),Oe.onDone=()=>{Oe.onDone=null,D.doneReadTxn()},Oe.selectApplied=!0,Oe.getColumns=()=>{if(G){let ee=[];for(let ge of G)ge==="*"?ee.push(...p.map(Ke=>Ke.name)):ee.push(ge.name||ge);return ee}return p.filter(ee=>!ee.computed&&!ee.relationship).map(ee=>ee.name)},Oe}static transformToOrderedSelect(m,g,D,A,I,w){let N=new KE;if(D){m=bd(m,g,A,I,null);let H;N.iterate=function(){let C,L=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),F,G=D.dbOrderedAttribute,ce,re,Te=!0;function de(Z){let ee=Z.next&&de(Z.next),ge=Z.descending;return(Ke,ne)=>{let we=vo(Ke,Z.attribute,A),nt=vo(ne,Z.attribute,A),Xe=ge?(0,hl.compareKeys)(nt,we):(0,hl.compareKeys)(we,nt);return Xe===0?ee?.(Ke,ne)||0:Xe}}a(de,"createComparator");let Oe=de(D);return{async next(){let Z;if(C)if(Z=C.next(),Z.done){if(F)return N.onDone&&N.onDone(),Z}else return{value:await w.call(this,Z.value)};H=[],ce&&H.push(ce);do if(Z=await L.next(),Z.done){if(F=!0,H.length)break;return N.onDone&&N.onDone(),Z}else{let ee=Z.value;if(ee?.then&&(ee=await ee),G){let ge=vo(ee,G,A);if(Te)Te=!1,re=ge;else if(ge!==re){re=ge,ce=ee;break}}H.push(ee)}while(!0);return D.isGrouped,H.sort(Oe),C=H[Symbol.iterator](),Z=C.next(),Z.done?(N.onDone&&N.onDone(),Z):{value:await w.call(this,Z.value)}},return(){N.onDone&&N.onDone(),L.return()},throw(){N.onDone&&N.onDone(),L.throw()}}};let U=a(C=>{if(typeof g=="object"&&Array.isArray(C.attribute))for(let L=0;L<g.length;L++){let F=g[L],G;if(F.name===C.attribute[0]){for(G=F.sort||(F.sort={});G.next;)G=G.next;G.attribute=C.attribute.slice(1),G.descending=C.descending}else F===C.attribute[0]&&(g[L]=G={name:F,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&U(C.next)},"applySortingOnSelect");U(D)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(function(H){try{let U=w.call(this,H);return typeof U?.catch=="function"?U.catch(C=>{throw C.partialObject={[t]:H.key},C}):U}catch(U){throw U.partialObject={[t]:H.key},U}});return N}static transformEntryForSelect(m,g,D,A,I,w){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let C=a(L=>(g?.transaction?.stale&&(g.transaction.stale=!1),L?.key??L),"transform");return m===t?C:m.asArray?L=>[C(L)]:L=>({[t]:C(L)})}let N;I&&B&&!(typeof m=="string"?[m]:m)?.every(C=>{let L;return typeof C=="object"?L=C.name:L=C,r[L]||L===t})&&(N=!0);let H,U=a(function(C){let L;if(g?.transaction?.stale&&(g.transaction.stale=!1),C!=null){if(L=C.value||C.deref?.(),!L&&(C.key===void 0||C.deref)){if(C=Ad(C.key??C,g,{transaction:D,lazy:m?.length<4},this?.isSync,F=>F),C?.then)return C.then(U.bind(this));L=C?.value}if(N&&C?.metadataFlags&(Pi|ba)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(g.onlyIfCached&&g.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let F=Tl(C.key??C,C,g);if(F?.then)return F.then(U)}}if(L==null)return w?fl.SKIP:L;if(m&&!(m[0]==="*"&&m.length===1)){let F,G=a((re,Te)=>{let de;typeof re=="object"?de=re.name:de=re;let Oe=yn?.[de],Z;if(Oe){let ee=A?.[de];if(ee)if(ee.hasMappings){let Ke=Oe.from?L[Oe.from]:$u(C.key);Z=ee.get(Ke),Z||(Z=[])}else Z=ee.fromRecord?.(L);else Z=Oe(L,g,C);let ge=a(Ke=>{if(Ke&&typeof Ke=="object"){let ne=Oe.definition?.tableClass||Ge;H||(H={});let we=H[de]||(H[de]=ne.transformEntryForSelect(de===re?null:re.select||(Array.isArray(re)?re:null),g,D,ee,I));if(Array.isArray(Ke)){let nt=[],Xe=ne.transformToOrderedSelect(Ke,re.select,typeof re.sort=="object"&&re.sort,g,D,we)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),$e=a(Or=>{for(;!Or.done;){if(Or?.then)return Or.then($e);nt.push(Or.value),Or=Xe.next()}Te(nt,de)},"nextValue"),Kt=$e(Xe.next());Kt&&(F||(F=[]),F.push(Kt));return}else if(Ke=we.call(this,Ke),Ke?.then){F||(F=[]),F.push(Ke.then(nt=>Te(nt,de)));return}}Te(Ke,de)},"handleResolvedValue");Z?.then?(F||(F=[]),F.push(Z.then(ge))):ge(Z);return}else Z=L[de],Z&&typeof Z=="object"&&de!==re&&(Z=Ge.transformEntryForSelect(re.select||re,g,D,null)({value:Z}));Te(Z,de)},"selectAttribute"),ce;if(typeof m=="string")G(m,re=>{ce=re});else if(Array.isArray(m))if(m.asArray)ce=[],m.forEach((re,Te)=>{re==="*"?m[Te]=L:G(re,de=>ce[Te]=de)});else{ce={};let re=m.forceNulls;for(let Te of m)if(Te==="*")for(let de in L)ce[de]=L[de];else G(Te,(de,Oe)=>{de===void 0&&re&&(de=null),ce[Oe]=de})}else throw new yr.ClientError("Invalid select"+m);return F?Promise.all(F).then(()=>ce):ce}return L},"transform");return U}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");S||Et({table:s,database:c,schemaDefined:d,attributes:p,audit:!0}),m||(m={});let g=!m.rawEvents,D=[],A=Sb(Ge,this[je]??null,function(w,N,H,U){try{let C=N.getValue?.(i,g),L=N.type;if(!C&&N.type==="patch"&&g){let G=i.getEntry(w);G?.version===N.version?C=G.value:C=N.getValue?.(i,!0,H),L="put"}let F={id:w,timestamp:H,value:C,version:N.version,type:L,beginTxn:U};D?D.push(F):this.send(F)}catch(C){Fe.default.error?.(C)}},m.startTime||0,m),I=(async()=>{this[ni]&&(A.includeDescendants=!0,m.onlyChildren&&(A.onlyChildren=!0)),m.supportsTransactions&&(A.supportsTransactions=!0);let w=this[je],N=m.previousCount;N>1e3&&(N=1e3);let H=m.startTime;if(this[ni]){if(H){if(N)throw new yr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:U,value:C}of l.getRange({start:H,exclusiveStart:!0,snapshot:!1})){let L=Ht(C);if(L.tableId!==n)continue;let F=L.recordId;if(w==null||ZK(w,F)){let G=L.getValue(i,g,U);if(A.send({id:F,timestamp:U,value:G,version:L.version,type:L.type}),A.queue?.length>JK&&await A.waitForDrain()===!1)return}A.startTime=U}}else if(N){let U=[];for(let{key:C,value:L}of l.getRange({start:"z",end:!1,reverse:!0}))try{let F=Ht(L);if(F.tableId!==n)continue;let G=F.recordId;if(w==null||ZK(w,G)){let ce=F.getValue(i,g,C);if(U.push({id:G,timestamp:C,value:ce,version:F.version,type:F.type}),--N<=0)break}}catch(F){Fe.default.error("Error getting history entry",C,F)}for(let C=U.length;C>0;)A.send(U[--C]);U[0]&&(A.startTime=U[0].timestamp)}else if(!m.omitCurrent){for(let{key:U,value:C,version:L,localTime:F}of i.getRange({start:w??!1,end:w==null?void 0:[w,hl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(C&&(A.send({id:U,timestamp:F,value:C,version:L,type:"put"}),A.queue?.length>JK&&await A.waitForDrain()===!1))return}}else{N&&!H&&(H=0);let U=this[Fr]?.localTime;if(U===Yg&&(i.cache?.delete(w),this[Fr]=i.getEntry(w),Fe.default.trace?.("re-retrieved record",U,this[Fr]?.localTime),U=this[Fr]?.localTime),Fe.default.trace?.("Subscription from",H,"from",w,U),H<U){let C=[],L=U;do{let F=l.get(L);if(F){m.omitCurrent=!0;let G=Ht(F),ce=G.getValue(i,g,L);g&&(G.type="put"),C.push({id:w,value:ce,timestamp:L,...G}),L=G.previousLocalTime}else break;N&&N--}while(L>H&&N!==0);for(let F=C.length;F>0;)A.send(C[--F]);A.startTime=U}!m.omitCurrent&&this.doesExist()&&A.send({id:w,timestamp:U,value:this[ve],version:this[DE],type:"put"})}for(let U of D)A.send(U);D=null})();return m.listener&&A.on("data",m.listener),A}doesExist(){return!!(this[ve]||this[wE])}publish(m,g){this._writePublish(m,g)}_writePublish(m,g){let D=Gr(this[xe]),A=this[je]||null;A!=null&&$i(A);let I=this[xe];D.addWrite({key:A,store:i,entry:this[Fr],nodeName:I?.nodeName,validate:()=>{I?.source||(D.checkOverloaded(),this.validate(m))},before:Ie.publish?.bind(this,I,A,m),beforeIntermediate:Me.publish?.bind(this,I,A,m),commit:(w,N,H)=>{N===void 0&&R&&!S&&Se(),Fe.default.trace?.(`Publishing message to id: ${A}, timestamp: ${new Date(w).toISOString()}`),y(A,N?.value??null,N,N?.version||w,0,!0,{user:I?.user,residencyId:g?.residencyId,expiresAt:I?.expiresAt,nodeId:g?.nodeId},"message",!1,m)}})}validate(m,g){let D,A=a((I,w,N)=>{if(w.type&&I!=null)if(g&&I.__op__&&(I=I.value),w.properties){typeof I!="object"&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be an object${w.type?" ("+w.type+")":""}`);let H=w.properties;for(let U=0,C=H.length;U<C;U++){let L=H[U],F=A(I[L.name],L,N+"."+L.name);F&&(I[L.name]=F)}if(w.sealed&&I!=null&&typeof I=="object")for(let U in I)H.find(C=>C.name===U)||(D||(D=[])).push(`Property ${U} is not allowed within object in property ${N}`)}else switch(w.type){case"Int":(typeof I!="number"||I>>0!==I)&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof I!="number"||!(Math.floor(I)===I&&Math.abs(I)<=9007199254740992))&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof I!="number"&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a number`);break;case"ID":typeof I=="string"||I?.length>0&&I.every?.(H=>typeof H=="string")||(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof I!="string"&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a string`);break;case"Boolean":typeof I!="boolean"&&(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a boolean`);break;case"Date":if(!(I instanceof Date)){if(typeof I=="string"||typeof I=="number")return new Date(I);(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof I!="bigint"){if(typeof I=="string"||typeof I=="number")return BigInt(I);(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a bigint`)}break;case"Bytes":I instanceof Uint8Array||(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(I)){if(w.elements)for(let H=0,U=I.length;H<U;H++){let C=I[H],L=A(C,w.elements,N+"[*]");L&&(I[H]=L)}}else(D||(D=[])).push(`Value ${si(I)} in property ${N} must be a Buffer or Uint8Array`);break}w.nullable===!1&&I==null&&(D||(D=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let I=0,w=p.length;I<w;I++){let N=p[I];if(!(N.relationship||N.computed)&&(!g||N.name in m)){let H=A(m[N.name],N,N.name);H&&(m[N.name]=H)}}if(_)for(let I in m)p.find(w=>w.name===I)||(D||(D=[])).push(`Property ${I} is not allowed`);if(D)throw new yr.ClientError(D.join(". "))}getUpdatedTime(){return this[DE]}wasLoadedFromSource(){return B?!!this[hw]:void 0}static async addAttributes(m){let g=p.slice(0);for(let D of m){if(!D.name)throw new yr.ClientError("Attribute name is required");if(D.name.match(/[`/]/))throw new yr.ClientError("Attribute names cannot include backticks or forward slashes");(0,rW.validateAttribute)(D.name),g.push(D)}return Et({table:s,database:c,schemaDefined:d,attributes:g}),Ge.indexingOperation}static async removeAttributes(m){let g=p.filter(D=>!m.includes(D.name));return Et({table:s,database:c,schemaDefined:d,attributes:g}),Ge.indexingOperation}static getRecordCount(m){let g=i.getStats().entryCount,D=1e3/2,A=performance.now(),I=Math.floor(g/2),w=m?.exactCount,N=0,H=0,U;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&N++,H++,!w&&H<I&&performance.now()-A>D){U=H;break}if(U){let C=N;N=0;for(let{value:Z}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:U}))Z!=null&&N++;let L=U*2,F=(N+C)/L,G=Math.pow((N-C+1)/U/2,2)+F*(1-F)/L,ce=Math.max(Math.sqrt(G)*g,1),re=Math.round(F*g),Te=Math.max(re-1.96*ce,N+C),de=Math.min(re+1.96*ce,g),Oe=Math.pow(10,Math.round(Math.log10(ce)));return Oe>re&&(Oe=Oe/10),N=Math.round(re/Oe)*Oe,{recordCount:N,estimatedRange:[Math.round(Te),Math.round(de)]}}return{recordCount:N}}static updatedAttributes(){yn=this.propertyResolvers={$id:(m,g,D)=>({value:D.key}),$updatedtime:(m,g,D)=>D.version,$record:(m,g,D)=>D?{value:m}:m};for(let m of this.attributes){m.resolve=null;let g=m.relationship,D=m.computed;if(g)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),D&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),YE=!0,g.to)m.elements?.definition?(yn[m.name]=m.resolve=(A,I,w)=>{let N=A[g.from?g.from:t],H=m.elements.definition.tableClass;return w?qu({attribute:g.to,value:N},Gr(I).getReadTxn(),!1,H,!1).asArray:H.search([{attribute:g.to,value:N}],I).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,g.from&&(m.resolve.from=g.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(g.from){let A=m.definition||m.elements?.definition;A?(yn[m.name]=m.resolve=(I,w,N)=>{let H=I[g.from];if(H!==void 0){if(m.elements){let U,C=H?.map(L=>{let F=N?A.tableClass.primaryStore.getEntry(L,{transaction:Gr(w).getReadTxn()}):A.tableClass.get(L,w);return F?.then&&(U=!0),F});return g.filterMissing?U?Promise.all(C).then(L=>L.filter(eW)):C.filter(eW):U?Promise.all(C):C}return N?A.tableClass.primaryStore.getEntry(H,{transaction:Gr(w).getReadTxn()}):A.tableClass.get(H,w)}},m.set=(I,w)=>{if(Array.isArray(w)){let N=w.map(H=>H[je]||H[A.tableClass.primaryKey]);I[g.from]=N}else{let N=w[je]||w[A.tableClass.primaryKey];I[g.from]=N}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=g.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else D&&(typeof D.from=="function"&&this.setComputedAttribute(m.name,D.from),yn[m.name]=m.resolve=(A,I,w)=>{let N=typeof D.from=="string"?A[D.from]:A,H=this.userResolvers[m.name];if(H)return H(N,I,w);Fe.default.warn(`Computed attribute "${m.name}" does not have a function assigned to it. Please use setComputedAttribute('${m.name}', resolver) to assign a resolver function.`),this.userResolvers[m.name]=()=>{}})}IT(this,this)}static setComputedAttribute(m,g){let D=Di(p,m);if(!D){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!D.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=g}static async deleteHistory(m=0){let g;for(let{key:D,value:A}of l.getRange({start:0,end:m}))await CE(),Ht(A).tableId===n&&(g=l.remove(D));await g}static async*getHistory(m=0,g=1/0){for(let{key:D,value:A}of l.getRange({start:m,end:g})){await CE();let I=Ht(A);I.tableId===n&&(yield{id:I.recordId,localTime:D,version:I.version,type:I.type,value:I.getValue(i,!0,D),user:I.user,operation:I.originatingOperation})}}static async getHistoryOfRecord(m){let g=[];if(m==null)throw new Error("An id is required");let D=i.getEntry(m);if(!D)return g;let A=D.localTime;if(!A)throw new Error("The entry does not have a local audit time");let I=0;do{await CE();let w=l.get(A);if(w){let N=Ht(w);g.push({id:N.recordId,localTime:A,version:N.version,type:N.type,value:N.getValue(i,!0,A),user:N.user}),A=N.previousLocalTime}else break}while(I<1e3&&A);return g.reverse()}static cleanup(){X?.remove()}}Ge.updatedAttributes();let WE=Ge.prototype;return WE[gSe]=!0,h&&Ge.setTTLExpiration(h/1e3),_e&&Re(),Ge;function Mo(k,m,g){let D;for(let A in r){let I=r[A],w=I.isIndexing,N=yn[A],H=g&&(N?N(g):g[A]),U=m&&(N?N(m):m[A]);if(H===U&&!w)continue;D=!0;let C=I.indexNulls,L=(0,PE.getIndexedValues)(H,C),F=(0,PE.getIndexedValues)(U,C);if(F?.length>0){let G=new Set(F);if(L=L?L.filter(ce=>{if(G.has(ce))G.delete(ce);else return!0}):[],F=Array.from(G),(F.length>0||L.length>0)&&jK){let ce=F.concat(L).map(re=>({key:re,value:k}));I.prefetch(ce,XK)}for(let ce=0,re=F.length;ce<re;ce++)I.remove(F[ce],k)}else L?.length>0&&jK&&I.prefetch(L.map(G=>({key:G,value:k})),XK);if(L)for(let G=0,ce=L.length;G<ce;G++)I.put(L[G],k)}return D}a(Mo,"updateIndices");function $i(k){switch(typeof k){case"number":return!0;case"string":if(k.length<659)return!0;if(k.length>zK)throw new Error("Primary key size is too large: "+k.length);break;case"object":if(k===null)throw new Error("Invalid primary key of null");break;case"bigint":if(k<2n**64n&&k>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof k)}if((0,hl.writeKey)(k,ASe,0)>zK)throw new Error("Primary key size is too large: "+k.length);return!0}a($i,"checkValidId");function Ad(k,m,g,D,A){if(Ge.getResidencyById&&g.ensureLoaded){let w=Ge.getResidencyById(k);if(w&&!w.includes(server.hostname))return O({key:k,residency:w}).then(A)}let I=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),g.transaction?.isDone)return A(null,k);let w=i.getEntry(k,g);return w?.residencyId&&w.metadataFlags&Pi&&O&&g.ensureLoaded?O(w).then(N=>A(N,k)):(w&&m&&(w?.version>(m.lastModified||0)&&(m.lastModified=w.version),w?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=w.localTime)),A(w,k))},"whenPrefetched");return D?I():ie>0?(ie--,I()):new Promise((w,N)=>{ie===0?(ie--,i.prefetch([k],()=>{H(),U()})):(ue.push(k),j.push(U),ue.length>rs&&(ie--,H()));function H(){if(ue.length>0){let C=j;i.prefetch(ue,()=>{ie===-1?H():ie++;for(let L of C)L()}),ue=[],j=[],ye>2&&ye--}else ie=ye,ye<Uw&&ye++}a(H,"prefetch");function U(){try{w(I())}catch(C){N(C)}}a(U,"load")})}a(Ad,"loadLocalRecord");function Uo(k){if(!k?.role)return;let m=k.role.permission;if(m.super_user)return bSe;let g=m[c],D,A=g?.tables;if(A)return A[s];if(c==="data"&&(D=m[s])&&!D.tables)return D}a(Uo,"getTablePermissions");function Tl(k,m,g,D){if(B){let A=!1;if(g.noCache?A=!0:(m?(!m.value||m.metadataFlags&(Pi|ba)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(A=!0):A=!0,kn(!A,"cache-hit",s)),A){let I=gl(k,m,g).then(w=>(w?.value?.[ve]&&Fe.default.error?.("Can not assign a record with a record property"),g&&(w?.version>(g.lastModified||0)&&(g.lastModified=w.version),g.lastRefreshed=Date.now()),w));if(g?.onlyIfCached||m?.value&&D?.allowStaleWhileRevalidate?.(m,k)){if(I.catch(w=>Fe.default.warn?.(w)),g?.onlyIfCached&&!D.doesExist())throw new yr.ServerError("Entry is not cached",504);return}else return I}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return Ge.evict(m.key,m.value,m.version),m.value=null,{then(A){return A(m)}}}a(Tl,"ensureLoadedFromSource");function Gr(k){let m=k?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let g=m.next;if(!g)return m=m.next=new lc,m.lmdbDb=i,m;m=g}while(!0)}else return new sm}a(Gr,"txnForContext");function vo(k,m,g){if(!k)return;let D=k.value||k.deref?.()||i.getEntry(k.key)?.value;if(typeof m=="object"){let I=yn,w=D;for(let N=0,H=m.length;N<H;N++){let U=m[N],C=I?.[U];w=C&&w?C(w,g,!0)?.value:w?.[U],I=C?.definition?.tableClass?.propertyResolvers}return w}let A=yn[m];return A?A(D,g):D[m]}a(vo,"getAttributeValue");function bd(k,m,g,D,A){let I=A?.length,w={transaction:D,lazy:I>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function H(U,C){let L=U?.value;if(!L)return fl.SKIP;for(let F=0;F<I;F++)if(!N?.includes(F)&&!A[F](L,U))return fl.SKIP;return C!==void 0&&(U.key=C),U}if(a(H,"processEntry"),I>0||!k.hasEntries){let U=k.map(C=>{if(N=null,typeof C=="object"&&C?.key!==void 0)return I>0?H(C):C;if(C==null)return fl.SKIP;for(let L=0;L<I;L++){let G=A[L].idFilter;if(G){if(!G(C))return fl.SKIP;N||(N=[]),N.push(L)}}return Ad(C,g,w,!1,H)});return Array.isArray(k)&&(U=U.filter(C=>C!==fl.SKIP)),U.hasEntries=!0,U}return k}a(bd,"transformToEntries");function Bo(k,m,g=server.replication?.getThisNodeId(l)){if(k<=m?.version){if(m?.version===k&&g!==void 0){let D=server.replication?.exportIdMapping(l),A=m.localTime,I=l.get(A);if(I){let w,N,H=Ht(I);for(let U in D)D[U]===g&&(w=U),D[U]===H.nodeId&&(N=U);if(w>N)return 1;if(w===N)return 0}}return-1}return 1}a(Bo,"precedesExistingVersion");async function gl(k,m,g){let D=m?.metadataFlags,A=m?.version,I,w;if(!i.attemptLock(k,A,()=>{clearTimeout(w);let C=i.getEntry(k);!C||!C.value||C.metadataFlags&(Pi|ba)?I(gl(k,i.getEntry(k),g)):I(C)}))return new Promise(C=>{I=C,w=setTimeout(()=>{i.unlock(k,A)},TSe)});let N=m?.value,H={requestContext:g,replacingRecord:N,replacingEntry:m,replacingVersion:A,noCacheStore:!1,source:null,resourceCache:g?.resourceCache},U=g?.responseHeaders;return new Promise((C,L)=>{let F;pw(Ct(H,async G=>{let ce=performance.now(),re,Te,de;try{for(let ge of Ge.sources)if(ge.get&&(!ge.get.reliesOnPrototype||ge.prototype.get)){if(ge.available?.(m)===!1)continue;if(H.source=ge,re=await ge.get(k,H),re)break}de=D&Pi;let Z=H.lastModified||de&&A;Te=de||Z>A||!N,Z||(Z=(0,PE.getNextMonotonicTime)());let ee=performance.now()-ce;if(gr(ee,"cache-resolution",s),U&&mO(U,"Server-Timing",`cache-resolve;dur=${ee.toFixed(2)}`,!0),G.timestamp=Z,h&&H.expiresAt==null&&(H.expiresAt=Date.now()+h),re){if(typeof re!="object")throw new Error("Only objects can be cached and stored in tables");if(re.status>0&&re.headers)if(re.status>=300)if(re.status===304)re=N,Z=A;else throw new yr.ServerError(re.body||"Error from source",re.status);else re=re.body;typeof re.toJSON=="function"&&(re=re.toJSON()),t&&re[t]!==k&&(re[t]=k)}F=!0,C({key:k,version:Z,value:re})}catch(Z){Z.message+=` while resolving record ${k} for ${s}`,N&&((Z.code==="ECONNRESET"||Z.code==="ECONNREFUSED"||Z.code==="EAI_AGAIN")&&!g?.mustRevalidate||g?.staleIfError&&(Z.statusCode===500||Z.statusCode===502||Z.statusCode===503||Z.statusCode===504))?(C({key:k,version:A,value:N}),Fe.default.trace?.(Z.message,"(returned stale record)")):L(Z),H.transaction.abort();return}if(g?.noCacheStore||H.noCacheStore){H.transaction.abort();return}Gr(H).addWrite({key:k,store:i,entry:m,nodeName:"source",commit:(Z,ee)=>{if(ee?.version!==A)return;let ge=Mo(k,N,re);re?(Me.put?.(H,k,re),Fe.default.trace?.(`Writing resolved record from source with id: ${k}, timestamp: ${new Date(Z).toISOString()}`),y(k,re,ee,Z,0,S&&Te||null,{user:H?.user,expiresAt:H.expiresAt},"put",!!de)):ee&&(Me.delete?.(H,k),Fe.default.trace?.(`Deleting resolved record from source with id: ${k}, timestamp: ${new Date(Z).toISOString()}`),S||R?y(k,null,ee,Z,0,S&&Te||null,{user:H?.user},"delete",!!de):i.remove(k,A))}})}),()=>{i.unlock(k,A)},G=>{i.unlock(k,A),F&&Fe.default.error?.("Error committing cache update",G)})})}a(gl,"getFromSource");function se(k){if(!k||k.user?.role?.permission?.super_user)return!0;if(k.replicateTo)throw new yr.ClientError("Can not specify replication parameters without super user permissions",403);if(k.replicatedConfirmation)throw new yr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(se,"checkContextPermissions");function Se(){if(tn!==gd&&(gd=tn,(0,El.getWorkerIndex)()===(0,El.getWorkerCount)()-1)){if(ka&&clearTimeout(ka),!tn)return;let k=new Date;k.setMonth(0),k.setDate(1),k.setHours(0),k.setMinutes(0),k.setSeconds(0);let m=Math.ceil((Date.now()-k.getTime())/tn)*tn+k.getTime(),g=a(D=>{Fe.default.trace?.(`Scheduled next cleanup scan at ${new Date(D)}ms`),ka=setTimeout(()=>W=W.then(async()=>{if(g(Math.max(D+tn,Date.now())),i.rootStore.status!=="open"){clearTimeout(ka);return}let A=50,I=new Array(A),w=0;Fe.default.info?.(`Starting cleanup scan for ${s}`);try{let N=0;for(let{key:H,value:U,version:C,expiresAt:L}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let F;U===null&&!S&&C+SSe<Date.now()?F=i.remove(H,C):L!=null&&L+T<Date.now()&&(F=Ge.evict(H,U,C),N++),F&&(await I[w],I[w]=F.catch(G=>{Fe.default.error?.("Cleanup error",G)}),++w>=A&&(w=0)),await CE()}Fe.default.info?.(`Finished cleanup scan for ${s}, evicted ${N} entries`)}catch(N){Fe.default.warn?.(`Error in cleanup scan for ${s}:`,N)}}),Math.min(D-Date.now(),2147483647)).unref()},"startNextTimer");g(m)}}a(Se,"scheduleCleanup");function rt(){X=l?.addDeleteRemovalCallback(n,k=>{let m=i.getEntry(k);m?.value===null&&i.remove(k,m.version)})}a(rt,"addDeleteRemoval");function Re(){(0,El.getWorkerIndex)()===0&&setInterval(async()=>{if(!Fa){Fa=!0;try{let k=_e.name,m=r[k];if(!m)throw new Error(`expiresAt attribute ${_e} must be indexed`);for(let g of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let D of m.getValues(g)){let A=i.getEntry(D);A?.value?A.value[k]<Date.now()&&Ge.evict(D,A.value,A.version):i.ifVersion(D,A?.version,()=>m.remove(g,D))}await CE()}}catch(k){Fe.default.error?.("Error in evicting old records",k)}finally{Fa=!1}}},pSe).unref()}a(Re,"runRecordExpirationEviction");function ft(k){if(k){let m=k.join(","),g=u.get([Symbol.for("residency_by_set"),m]);return g||(u.put([Symbol.for("residency_by_set"),m],g=Math.floor(Math.random()*2147483647)),u.put([Symbol.for("residency_by_id"),g],k),g)}}a(ft,"getResidencyId")}function mw(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function XK(){}function ySe(e){nW=e}function LT(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return PT(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return PT(+e);case"Float":return e==="null"?null:PT(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;OSe.test(e)||(e+="Z");let n=new Date(e);return PT(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,UT.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function PT(e){if(isNaN(e))throw new SyntaxError;return e}function ZK(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function pw(e,t,r){return e?.then?e.then(t,r):t(e)}function MT(e,t){e[Fr]=t,e[ve]=t?.value??null,e[DE]=t?.version}function eW(e){return e!=null}function si(e){try{return JSON.stringify(e)}catch{return e}}function NSe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Us,fl,PE,tW,rW,Ed,yr,LE,ME,Fe,hl,El,UT,mSe,nW,pSe,SSe,jK,TSe,DE,gSe,Fr,wE,QK,RSe,hw,Pi,ba,ASe,zK,JK,bSe,JMe,OSe,CE,zf=De(()=>{Us=v(M()),fl=require("lmdb"),PE=v(nn()),tW=require("lodash"),rW=v(xd());Hs();im();Ed=v(te());Tb();yr=v(fe()),LE=v(Ji()),ME=v(Gs());Le();Qf();Fe=v(zl());cm();uc();hl=require("ordered-binary"),El=v(it());Ki();UT=v(J());Ol();gi();gT();Nf();mSe=new Uint8Array(9);mSe[8]=192;pSe=6e4,SSe=864e5;Ed.initSync();jK=Ed.get(Us.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),TSe=1e4,DE=Symbol.for("version"),gSe=Symbol.for("incremental-update"),Fr=Symbol("entry"),wE=Symbol("is-saving"),QK=1,RSe=2,hw=Symbol("loaded-from-source"),Pi=1,ba=8,ASe=Buffer.allocUnsafeSlow(8192),zK=1978,JK=100,bSe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},JMe=(0,UT.convertToMS)(Ed.get(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(vT,"makeTable");a(mw,"attributesAsObject");a(XK,"noop");a(ySe,"setServerUtilities");OSe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(LT,"coerceType");a(PT,"rejectNaN");a(ZK,"isDescendantId");CE=a(()=>new Promise(setImmediate),"rest");a(pw,"when");a(MT,"updateResource");a(eW,"exists");a(si,"stringify");a(NSe,"hasOtherProcesses")});var lt={};et(lt,{database:()=>Vl,databases:()=>We,dropDatabase:()=>FA,dropTableMeta:()=>PSe,getDatabases:()=>mt,getDefaultCompression:()=>Cp,getTables:()=>ISe,onRemovedDB:()=>V_,onUpdatedTable:()=>bc,readMetaDb:()=>UE,resetDatabases:()=>Cu,table:()=>Et,tables:()=>wn});function ISe(){return kT||mt(),wn||{}}function mt(){if(kT)return We;kT=!0,pd=new Map;let e=(0,tr.getHdbBasePath)()&&(0,vt.join)((0,tr.getHdbBasePath)(),Tr.DATABASES_DIR_NAME),t=(0,tr.get)(Tr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,Xn.existsSync)(e)?e:(0,vt.join)((0,tr.getHdbBasePath)(),Tr.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,Xn.existsSync)(e))for(let n of(0,Xn.readdirSync)(e,{withFileTypes:!0})){let s=(0,vt.basename)(n.name,".mdb");n.isFile()&&(0,vt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&UE((0,vt.join)(e,n.name),null,s)}if((0,Xn.existsSync)((0,md.getBaseSchemaPath)())){for(let n of(0,Xn.readdirSync)((0,md.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,vt.join)((0,md.getBaseSchemaPath)(),n.name),i=(0,vt.join)((0,md.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,Xn.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,vt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,vt.join)(i,o.name);UE((0,vt.join)(s,o.name),(0,vt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,Xn.existsSync)(i))for(let c of(0,Xn.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,vt.extname)(c.name).toLowerCase()===".mdb"&&UE((0,vt.join)(i,c.name),(0,vt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],d=(0,vt.join)(l.path,(0,vt.basename)(c+".mdb"));(0,Xn.existsSync)(d)&&UE(d,c,n,null,!0)}}for(let n in We){let s=pd.get(n);if(s){let i=We[n];n.includes("delete")&&Vt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Vt.trace(`delete table class ${o}`),delete i[o])}else if(delete We[n],n==="data"){for(let i in wn)delete wn[i];delete wn[FT]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(We.system)for(let n of r)We.system[n]&&(We.system[n].replicate=!1);return pd=null,We}function Cu(){kT=!1;for(let[,e]of Ha)e.needsDeletion=!0;mt();for(let[e,t]of Ha)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Ha.delete(e),delete We[t.databaseName],BE.forEach(r=>r(t.databaseName)));return We}function UE(e,t,r=gw,n,s){let i=new Sw.default(e,!1);try{let o=Ha.get(e);o?o.needsDeletion=!1:(o=(0,Sd.open)(i),Ha.set(e,o));let c=new ml.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(BT.INTERNAL_DBIS_NAME,c)),d=o.auditStore;d||(n?(0,Xn.existsSync)(n)&&(i.path=n,d=(0,Sd.open)(i),d.isLegacy=!0):d=TT(o));let u=aW(r),_=u[FT],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[T,S]=f.toString().split("/");S===""?S=h.name:S||(S=T,T=t,h.name||(h.name=S,h.indexed=!h.is_hash_attribute)),_?.add(T);let R=E.get(T);R||E.set(T,R={attributes:[]}),(S==null||h.is_hash_attribute)&&(R.primary=h),S!=null&&R.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:T,primary:S}=h;if(!S){for(let j of T)if(j.is_hash_attribute||j.isPrimaryKey){S=j;break}if(!S){Vt.warn(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(T)}`);continue}}let R=u[f],p={},y=[],O,B,x=typeof S.audit=="boolean"?S.audit:(0,tr.get)(Tr.CONFIG_PARAMS.LOGGING_AUDITLOG),W=S.trackDeletes,q=S.expiration,z=S.eviction,_e=S.sealed,X=S.splitSegments,ue=S.replicate;if(R)p=R.indices,y=R.attributes,R.schemaVersion++;else{O=S.tableId,O?O>=(l.get(hd)||0)&&(l.putSync(hd,O+1),Vt.info(`Updating next table id (it was out of sync) to ${O+1} for ${f}`)):(S.tableId=O=l.get(hd),O||(O=1),Vt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(hd,O+1),l.putSync(S.key,S));let j=new ml.default(!S.is_hash_attribute,S.is_hash_attribute);if(j.compression=S.compression,j.compression){let ie=(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||oW;j.compression.threshold=ie}B=Sh(o.openDB(S.key,j)),o.databaseName=r,B.rootStore=o,B.tableId=O}for(let j of T){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!p[j.name]){let ye=new ml.default(!j.is_hash_attribute,j.is_hash_attribute);p[j.name]=o.openDB(j.key,ye),p[j.name].indexNulls=j.indexNulls}let ie=y.find(ye=>ye.name===j.name);ie?y.splice(y.indexOf(ie),1,j):y.push(j)}}catch(ie){Vt.error("Error trying to update attribute",j,y,p,ie)}}if(!R){R=cW(u,f,vT({primaryStore:B,auditStore:d,audit:x,sealed:_e,splitSegments:X,replicate:ue,expirationMS:q&&q*1e3,evictionMS:z&&z*1e3,trackDeletes:W,tableName:f,tableId:O,primaryKey:S.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:p,attributes:T,schemaDefined:S.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let j of vE)j(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function aW(e){let t=We[e];if(t||(e==="data"?t=We[e]=wn:e==="system"?Object.defineProperty(We,"system",{value:t=Object.create(null),configurable:!0}):t=We[e]=Object.create(null)),pd&&!pd.has(e)){let r=new Set;t[FT]=r,pd.set(e,r)}return t}function cW(e,t,r){return e[t]=r,r}function Vl({database:e,table:t}){e||(e=gw),mt();let r=aW(e),n=(0,vt.join)((0,tr.getHdbBasePath)(),Tr.DATABASES_DIR_NAME),s=(0,tr.get)(Tr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_PATH)||((0,Xn.existsSync)(n)?n:(0,vt.join)((0,tr.getHdbBasePath)(),Tr.LEGACY_DATABASES_DIR_NAME));let o=(0,vt.join)(n,(i?t:e)+".mdb"),c=Ha.get(o);if(!c||c.status==="closed"){let l=new Sw.default(o,!1);c=(0,Sd.open)(l),Ha.set(o,c)}return c.auditStore||(c.auditStore=TT(c)),c}async function FA(e){if(!We[e])throw new Error("Schema does not exist");let t=We[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Ha.delete(r.path),r.status==="open"&&(await r.close(),await HE.remove(r.path));if(r||(r=Vl({database:e,table:null}),r.status==="open"&&(await r.close(),await HE.remove(r.path))),e==="data"){for(let n in wn)delete wn[n];delete wn[FT]}delete We[e],BE.forEach(n=>n(e))}function Et(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:d,replicate:u,trackDeletes:_,schemaDefined:E,origin:f}=e;r||(r=gw);let h=Vl({database:r,table:t}),T=We[r];Vt.trace(`Defining ${t} in ${r}`);let S=T?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let R,p,y;E==null&&(E=!0);let O=new ml.default(!1);for(let X of o)X.attribute&&!X.name?(X.name=X.attribute,X.indexed=!0):X.attribute=X.name,X.expiresAt&&(X.indexed=!0);let B,x;if(S){if(R=S.primaryKey,S.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);d==null&&(d=S.splitSegments),S.attributes.splice(0,S.attributes.length,...o)}else{let X=h.auditStore;p=o.find(ye=>ye.isPrimaryKey)||{},R=p.name,p.is_hash_attribute=p.isPrimaryKey=!0,p.schemaDefined=E,p.compression=Cp(),_&&(p.trackDeletes=!0),c=p.audit=typeof c=="boolean"?c:(0,tr.get)(Tr.CONFIG_PARAMS.LOGGING_AUDITLOG),n&&(p.expiration=n),s&&(p.eviction=s),p.splitSegments=!1,typeof l=="boolean"&&(p.sealed=l),typeof u=="boolean"&&(p.replicate=u),f&&(p.origins?p.origins.includes(f)||p.origins.push(f):p.origins=[f]),Vt.trace(`${t} table loading, opening primary store`);let ue=new ml.default(!1,!0);ue.compression=p.compression;let j=t+"/";if(y=h.dbisDb=h.openDB(BT.INTERNAL_DBIS_NAME,O),_e(),y.get(j))return x&&x(),Cu(),Et(e);let ie=Sh(h.openDB(j,ue));h.databaseName=r,ie.rootStore=h,ie.tableId=y.get(hd),Vt.trace(`Assigning new table id ${ie.tableId} for ${t}`),ie.tableId||(ie.tableId=1),y.put(hd,ie.tableId+1),p.tableId=ie.tableId,S=cW(T,t,vT({primaryStore:ie,auditStore:X,audit:c,sealed:l,splitSegments:d,replicate:u,trackDeletes:_,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:R,tableName:t,tableId:ie.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:E,dbisDB:y})),S.schemaVersion=1,B=!0,y.put(j,p)}let W=S.indices;y=y||(h.dbisDb=h.openDB(BT.INTERNAL_DBIS_NAME,O)),S.dbisDB=y;let q=[];for(let{key:X,value:ue}of y.getRange({start:!0})){let[j,ie]=X.toString().split("/");if(ie===""&&(ie=ue.name),ie){if(j!==t)continue}else continue;let ye=o.find(Me=>Me.name===ie),Ie=!ye?.indexed&&ue.indexed&&!ue.isPrimaryKey;if((!ye||Ie)&&(_e(),B=!0,ye||y.remove(X),Ie)){let Me=S.indices[j];Me&&q.push(Me)}}let z=[];try{for(let X of o||[]){if((X.relationship||X.computed)&&(B=!0,X.relationship))continue;let ue=t+"/"+(X.name||"");Object.defineProperty(X,"key",{value:ue,configurable:!0});let j=y.get(ue);if(X.isPrimaryKey){if(j=j||y.get(ue=t+"/")||{},c!==void 0&&c!==S.audit||l!==void 0&&l!==S.sealed||u!==void 0&&u!==S.replicate||(+n||void 0)!==(+j.expiration||void 0)||(+s||void 0)!==(+j.eviction||void 0)){let ye={...j};typeof c=="boolean"&&(c&&S.enableAuditing(c),ye.audit=c),n&&(ye.expiration=+n),s&&(ye.eviction=+s),l!==void 0&&(ye.sealed=l),u!==void 0&&(ye.replicate=u),B=!0,_e(),y.put(ue,ye)}continue}j?.attribute&&!j.name&&(j.indexed=!0);let ie=!j||j.type!==X.type||j.indexed!==X.indexed||j.nullable!==X.nullable||j.version!==X.version||JSON.stringify(j.attributes)!==JSON.stringify(X.attributes)||JSON.stringify(j.elements)!==JSON.stringify(X.elements);if(X.indexed){let ye=new ml.default(!0,!1),Ie=h.openDB(ue,ye);(ie||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<xE.workerData?.restartNumber)&&(B=!0,_e(),j=y.get(ue),(ie||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<xE.workerData?.restartNumber)&&(B=!0,X.indexNulls===void 0&&(X.indexNulls=!0),S.primaryStore.getStats().entryCount>0&&(X.lastIndexedKey=j?.lastIndexedKey??void 0,X.indexingPID=process.pid,Ie.isIndexing=!0,Object.defineProperty(X,"dbi",{value:Ie}),z.push(X))),y.put(ue,X)),j?.indexNulls&&X.indexNulls===void 0&&(X.indexNulls=!0),Ie.indexNulls=X.indexNulls,W[X.name]=Ie}else ie&&(B=!0,_e(),y.put(ue,X))}}finally{x&&x()}if(B&&(S.schemaVersion++,S.updatedAttributes()),Vt.trace(`${t} table loading, running index`),z.length>0||q.length>0?S.indexingOperation=DSe(S,z,q):B&&HT.signalSchemaChange(new xT.SchemaEventMsg(process.pid,"schema-change",S.databaseName,S.tableName)),S.origin=f,B)for(let X of vE)X(S,f!=="cluster");return(n||s||i)&&S.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Vt.trace(`${t} table loaded`),S;function _e(){x||h.transactionSync(()=>({then(X){x=X}}))}a(_e,"startTxn")}async function DSe(e,t,r){try{Vt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await HT.signalSchemaChange(new xT.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let d of r)s=d.drop();let i,o={},c=0,l=t.length;if(await new Promise(d=>setImmediate(d)),l>0){let d;for(let _ of t)(0,Sd.compareKeys)(_.lastIndexedKey,d)<0&&(d=_.lastIndexedKey),_.lastIndexedKey==null&&_.dbi.clearAsync();let u=0;for(let{key:_,value:E,version:f}of e.primaryStore.getRange({start:d,lazy:l<4,versions:!0,snapshot:!1}))if(E){if(u++,s=e.primaryStore.ifVersion(_,f,()=>{for(let h=0;h<l;h++){let T=t[h],S=T.name;try{let R=T.resolve,p=E&&(R?R(E):E[S]),y=(0,sW.getIndexedValues)(p);if(y)for(let O=0,B=y.length;O<B;O++)T.dbi.put(y[O],_)}catch(R){o[S]||(o[S]=!0,Vt.error(`Error indexing attribute ${S}`,R))}}}),s.then(()=>u--,h=>{u--,Vt.error(h)}),xE.workerData&&xE.workerData.restartNumber!==iW.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}u>wSe?await s:u>CSe&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await HT.signalSchemaChange(new xT.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Vt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Vt.error("Error in indexing",n)}}function PSe({table:e,database:t}){let r=Vl({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function bc(e){return vE.push(e),{remove(){let t=vE.indexOf(e);t>-1&&vE.splice(t,1)}}}function V_(e){return BE.push(e),{remove(){let t=BE.indexOf(e);t>-1&&BE.splice(t,1)}}}function Cp(){let e=(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||oW,n={startingOffset:32};return t&&(n.dictionary=HE.readFileSync(t)),r&&(n.threshold=r),e&&n}var tr,BT,Sd,vt,Xn,md,ml,Sw,Tr,HE,Tw,sW,HT,xT,xE,Vt,iW,gw,FT,oW,wn,We,hd,vE,BE,kT,Ha,pd,wSe,CSe,Le=De(()=>{tr=v(te()),BT=v(Bt()),Sd=require("lmdb"),vt=require("path"),Xn=require("fs"),md=v(gt());zf();ml=v(jd()),Sw=v(Qd()),Tr=v(M()),HE=v(require("fs-extra")),Tw=v(Vi()),sW=v(nn()),HT=v(Ji()),xT=v(Gs()),xE=require("worker_threads"),Vt=v(V()),iW=v(it());Ki();Ol();gw="data",FT=Symbol("defined-tables"),oW=((0,tr.get)(Tr.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,tr.initSync)();wn=Object.create(null),We=Object.create(null);(0,Tw._assignPackageExport)("databases",We);(0,Tw._assignPackageExport)("tables",wn);hd=Symbol.for("next-table-id"),vE=[],BE=[],Ha=new Map;a(ISe,"getTables");a(mt,"getDatabases");a(Cu,"resetDatabases");a(UE,"readMetaDb");a(aW,"ensureDB");a(cW,"setTable");a(Vl,"database");a(FA,"dropDatabase");a(Et,"table");wSe=1e3,CSe=10;a(DSe,"runIndexing");a(PSe,"dropTableMeta");a(bc,"onUpdatedTable");a(V_,"onRemovedDB");a(Cp,"getDefaultCompression")});var J=b((oUe,AW)=>{"use strict";var xa=require("path"),fW=require("fs-extra"),bn=V(),lW=require("fs-extra"),GT=require("os"),LSe=require("net"),MSe=require("recursive-iterator"),Yt=M(),USe=fg(),uW=require("papaparse"),qT=require("moment"),{inspect:vSe}=require("util"),dW=require("is-number"),iUe=require("lodash"),BSe=require("minimist"),HSe=require("https"),xSe=require("http"),{hdb_errors:$T}=fe(),kSe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,EW=require("util").promisify(setTimeout),FSe=100,GSe=5,qSe="",$Se=4,_W={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};AW.exports={isEmpty:Zn,isEmptyOrZeroLength:qi,arrayHasEmptyValues:KSe,arrayHasEmptyOrZeroLengthValues:WSe,buildFolderPath:jSe,isBoolean:hW,errorizeMessage:VSe,stripFileExtension:zSe,autoCast:JSe,autoCastJSON:mW,autoCastJSONDeep:Aw,removeDir:XSe,compareVersions:ZSe,isCompatibleDataVersion:eTe,escapeRawValue:tTe,unescapeValue:rTe,stringifyProps:nTe,timeoutPromise:iTe,isClusterOperation:aTe,getClusterUser:lTe,checkGlobalSchemaTable:cTe,getHomeDir:SW,getPropsFilePath:sTe,promisifyPapaParse:uTe,removeBOM:TW,createEventPromise:dTe,checkProcessRunning:_Te,checkSchemaTableExist:fTe,checkSchemaExists:gW,checkTableExists:RW,getStartOfTomorrowInSeconds:ETe,getLimitKey:hTe,isObject:QSe,isNotEmptyAndHasValue:YSe,autoCasterIsNumberCheck:pW,backtickASTSchemaItems:mTe,isPortTaken:oTe,createForkArgs:pTe,autoCastBoolean:STe,async_set_timeout:EW,getTableHashAttribute:TTe,doesSchemaExist:gTe,doesTableExist:RTe,stringifyObj:ATe,ms_to_time:bTe,changeExtension:yTe,getEnvCliRootPath:bw,noBootFile:OTe,httpRequest:NTe,transformReq:ITe,convertToMS:wTe,PACKAGE_ROOT:Yt.PACKAGE_ROOT};function VSe(e){return e instanceof Error?e:new Error(e)}a(VSe,"errorizeMessage");function Zn(e){return e==null}a(Zn,"isEmpty");function YSe(e){return!Zn(e)&&(e||e===0||e===""||hW(e))}a(YSe,"isNotEmptyAndHasValue");function qi(e){return Zn(e)||e.length===0||e.size===0}a(qi,"isEmptyOrZeroLength");function KSe(e){if(Zn(e))return!0;for(let t=0;t<e.length;t++)if(Zn(e[t]))return!0;return!1}a(KSe,"arrayHasEmptyValues");function WSe(e){if(qi(e))return!0;for(let t=0;t<e.length;t++)if(qi(e[t]))return!0;return!1}a(WSe,"arrayHasEmptyOrZeroLengthValues");function jSe(...e){try{return e.join(xa.sep)}catch{console.error(e)}}a(jSe,"buildFolderPath");function hW(e){return Zn(e)?!1:e===!0||e===!1}a(hW,"isBoolean");function QSe(e){return Zn(e)?!1:typeof e=="object"}a(QSe,"isObject");function zSe(e){return qi(e)?qSe:e.slice(0,-$Se)}a(zSe,"stripFileExtension");function JSe(e){return Zn(e)||e===""||typeof e!="string"?e:_W[e]!==void 0?_W[e]:pW(e)===!0?Number(e):kSe.test(e)?new Date(e):e}a(JSe,"autoCast");function mW(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(mW,"autoCastJSON");function Aw(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=Aw(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=Aw(r);n!==r&&(e[t]=n)}return e}else return mW(e)}a(Aw,"autoCastJSONDeep");function pW(e){if(e.startsWith("0.")&&dW(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&dW(e))}a(pW,"autoCasterIsNumberCheck");async function XSe(e){if(qi(e))throw new Error(`Directory path: ${e} does not exist`);try{await lW.emptyDir(e),await lW.remove(e)}catch(t){throw bn.error(`Error removing files in ${e} -- ${t}`),t}}a(XSe,"removeDir");function ZSe(e,t){if(qi(e)){bn.info("Invalid current version sent as parameter.");return}if(qi(t)){bn.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let d=0;d<l;d++)if(r=parseInt(o[d],10)-parseInt(c[d],10),r)return r;return o.length-c.length}a(ZSe,"compareVersions");function eTe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(eTe,"isCompatibleDataVersion");function tTe(e){if(Zn(e))return e;let t=String(e);return t==="."?Yt.UNICODE_PERIOD:t===".."?Yt.UNICODE_PERIOD+Yt.UNICODE_PERIOD:t.replace(Yt.FORWARD_SLASH_REGEX,Yt.UNICODE_FORWARD_SLASH)}a(tTe,"escapeRawValue");function rTe(e){if(Zn(e))return e;let t=String(e);return t===Yt.UNICODE_PERIOD?".":t===Yt.UNICODE_PERIOD+Yt.UNICODE_PERIOD?"..":String(e).replace(Yt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(rTe,"unescapeValue");function nTe(e,t){if(Zn(e))return bn.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+GT.EOL}!qi(n)&&n[0]===";"?r+=" "+n+s+GT.EOL:qi(n)||(r+=n+"="+s+GT.EOL)}catch{bn.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(nTe,"stringifyProps");function SW(){let e;try{e=GT.homedir()}catch{e=process.env.HOME}return e}a(SW,"getHomeDir");function sTe(){let e=xa.join(SW(),Yt.HDB_HOME_DIR_NAME,Yt.BOOT_PROPS_FILE_NAME);return fW.existsSync(e)||(e=xa.join(__dirname,"../","hdb_boot_properties.file")),e}a(sTe,"getPropsFilePath");function iTe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(iTe,"timeoutPromise");async function oTe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=LSe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(oTe,"isPortTaken");function aTe(e){try{return Yt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){bn.error(`Error checking operation against cluster ops ${t}`)}return!1}a(aTe,"isClusterOperation");function cTe(e,t){let r=(Le(),oe(lt)).getDatabases();if(!r[e])return $T.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return $T.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(cTe,"checkGlobalSchemaTable");function lTe(e,t){if(Zn(t)){bn.warn("No CLUSTERING_USER defined, clustering disabled");return}if(Zn(e)||qi(e)){bn.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){bn.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){bn.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(lTe,"getClusterUser");function uTe(){uW.parsePromise=function(e,t,r){return new Promise(function(n,s){uW.parse(e,{header:!0,transformHeader:TW,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(uTe,"promisifyPapaParse");function TW(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(TW,"removeBOM");function dTe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;bn.info(`Got cluster status event response: ${vSe(s)}`);try{i.cancel()}catch{bn.error("Error trying to cancel timeout.")}n(s)})})}a(dTe,"createEventPromise");async function _Te(e){let t=!0,r=0;do await EW(FSe*r++),(await USe.findPs(e)).length>0&&(t=!1);while(t&&r<GSe);if(t)throw new Error(`process ${e} was not started`)}a(_Te,"checkProcessRunning");function fTe(e,t){let r=gW(e);if(r)return r;let n=RW(e,t);if(n)return n}a(fTe,"checkSchemaTableExist");function gW(e){let{getDatabases:t}=(Le(),oe(lt));if(!t()[e])return $T.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(gW,"checkSchemaExists");function RW(e,t){let{getDatabases:r}=(Le(),oe(lt));if(!r()[e][t])return $T.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(RW,"checkTableExists");function ETe(){let e=qT().utc().add(1,Yt.MOMENT_DAYS_TAG).startOf(Yt.MOMENT_DAYS_TAG).unix(),t=qT().utc().unix();return e-t}a(ETe,"getStartOfTomorrowInSeconds");function hTe(){return qT().utc().format("DD-MM-YYYY")}a(hTe,"getLimitKey");function mTe(e){try{let t=new MSe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){bn.error("Got an error back ticking items."),bn.error(t)}}a(mTe,"backtickASTSchemaItems");function pTe(e){return[e]}a(pTe,"createForkArgs");function STe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(STe,"autoCastBoolean");function TTe(e,t){let{getDatabases:r}=(Le(),oe(lt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(TTe,"getTableHashAttribute");function gTe(e){let{getDatabases:t}=(Le(),oe(lt));return t()[e]!==void 0}a(gTe,"doesSchemaExist");function RTe(e,t){let{getDatabases:r}=(Le(),oe(lt));return r()[e]?.[t]!==void 0}a(RTe,"doesTableExist");function ATe(e){try{return JSON.stringify(e)}catch{return e}}a(ATe,"stringifyObj");function bTe(e){let t=qT.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(bTe,"ms_to_time");function yTe(e,t){let r=xa.basename(e,xa.extname(e));return xa.join(xa.dirname(e),r+t)}a(yTe,"changeExtension");function bw(){if(process.env[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=BSe(process.argv);if(e[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Yt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(bw,"getEnvCliRootPath");var Rw;function OTe(){if(Rw)return Rw;let e=bw();if(bw()&&fW.pathExistsSync(xa.join(e,Yt.HDB_CONFIG_FILE)))return Rw=!0,!0}a(OTe,"noBootFile");function NTe(e,t){let r;return e.protocol==="http:"?r=xSe:r=HSe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",l=>{c.body+=l}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(NTe,"httpRequest");function ITe(e){if(!e.schema&&!e.database){e.schema=Yt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(ITe,"transformReq");function wTe(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(wTe,"convertToMS")});var te=b((IW,wW)=>{"use strict";var yw=require("fs-extra"),pl=require("path"),bW=require("os"),CTe=require("properties-reader"),FE=V(),kE=J(),Pe=M(),VT=wt(),DTe="Error initializing environment manager",YT="BOOT_PROPS_FILE_PATH",yW=!1,PTe={[Pe.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Po={};Object.assign(IW,wW.exports={BOOT_PROPS_FILE_PATH:YT,getHdbBasePath:LTe,setHdbBasePath:MTe,get:OW,initSync:vTe,setProperty:Je,initTestEnvironment:HTe,setCloneVar:BTe});function LTe(){return Po[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(LTe,"getHdbBasePath");function MTe(e){Po[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(MTe,"setHdbBasePath");function OW(e){let t=VT.getConfigValue(e);return t===void 0?Po[e]:t}a(OW,"get");function Je(e,t){PTe[e]&&(Po[e]=t),VT.updateConfigObject(e,t)}a(Je,"setProperty");function UTe(){let e;try{e=kE.getPropsFilePath(),yw.accessSync(e,yw.constants.F_OK|yw.constants.R_OK),yW=!0;let t=CTe(e);return Po[Pe.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Pe.HDB_SETTINGS_NAMES.INSTALL_USER),Po[Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Po[YT]=e,!0}catch{return FE.trace(`Environment manager found no properties file at ${e}`),!1}}a(UTe,"doesPropFileExist");function vTe(e=!1){try{(yW||UTe()||kE.noBootFile())&&!NW&&(VT.initConfig(e),Po[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=VT.getConfigValue(Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){FE.error(DTe),FE.error(t),console.error(t),process.exit(1)}}a(vTe,"initSync");var NW=!1;function BTe(e){NW=e}a(BTe,"setCloneVar");function HTe(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=pl.join(__dirname,"../../","unitTests");Po[YT]=pl.join(l,"hdb_boot_properties.file"),Je(Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,pl.join(l,"settings.test")),Je(Pe.HDB_SETTINGS_NAMES.INSTALL_USER,bW.userInfo()?bW.userInfo().username:void 0),Je(Pe.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Je(Pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY,pl.join(l,"envDir","log")),Je(Pe.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Je(Pe.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Je(Pe.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Je(Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,pl.join(l,"envDir")),Je(Pe.CONFIG_PARAMS.STORAGE_PATH,pl.join(l,"envDir")),s&&(Je(Pe.CONFIG_PARAMS.HTTP_SECUREPORT,OW(Pe.CONFIG_PARAMS.HTTP_PORT)),Je(Pe.CONFIG_PARAMS.HTTP_PORT,null)),Je(Pe.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Je(Pe.CONFIG_PARAMS.HTTP_PORT,9926),Je(Pe.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Je(Pe.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Je(Pe.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,kE.isEmpty(i)?!1:i),Je(Pe.CONFIG_PARAMS.HTTP_CORS,kE.isEmpty(i)?!1:i),Je(Pe.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Je(Pe.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Je(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Je(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Je(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,pl.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Je(Pe.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,kE.isEmpty(c)?!1:c),o&&(Je("CORS_ACCESSLIST",o),Je(Pe.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Je(Pe.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Je(Pe.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Je(Pe.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Je(Pe.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Je(Pe.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Je(Pe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${YT}. Please check your boot props and settings files`;FE.fatal(r),FE.error(t)}}a(HTe,"initTestEnvironment")});var MW=b((lUe,LW)=>{"use strict";var PW=require("joi"),{string:GE,boolean:CW,array:xTe}=PW.types(),DW=M(),kTe=ut();LW.exports=FTe;function FTe(e){let t=PW.object({operation:GE.valid(DW.OPERATIONS_ENUM.ADD_NODE,DW.OPERATIONS_ENUM.UPDATE_NODE).required(),node_name:GE.required(),subscriptions:xTe.items({schema:GE.required(),table:GE.optional(),hash_attribute:GE.optional(),subscribe:CW.required(),publish:CW.required()}).min(1).required()});return kTe.validateBySchema(e,t)}a(FTe,"updateRemoteSourceValidator")});var qE=b((dUe,UW)=>{"use strict";var Ow=class{static{a(this,"UpdateRemoteResponseObject")}constructor(t,r,n=void 0){this.status=t,this.message=r,this.system_info=n}};UW.exports=Ow});var xW=b((fUe,HW)=>{"use strict";var GTe=MW(),Lo=V(),Nw=dt(),qTe=M(),Iw=hs(),Sl=kt(),vW=j_(),$Te=ql(),{Node:VTe,NodeSubscription:BW}=_a(),ww=qE(),Cw=J(),YTe=te(),{cloneDeep:KTe}=require("lodash"),{broadcast:WTe}=it();HW.exports=jTe;async function jTe(e){try{let t=GTe(e);if(t)return Lo.error(`Validation error in updateRemoteSource: ${t.message}`),new ww(Nw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let{subscriptions:r,node_name:n,system_info:s}=e,i=[],o=KTe(await Iw.getNodeRecord(n)),c=!Cw.isEmptyOrZeroLength(o);o=c?o[0]:o,c&&Lo.trace(`Existing record found for ${n}, updating records subscriptions`);for(let d=0,u=r.length;d<u;d++){let _=r[d],E=_.schema,f=_.table;if(!Cw.doesSchemaExist(E)){Lo.trace(`updateRemoteSource creating schema: ${E}`);try{await vW.createSchema({operation:"create_schema",schema:E})}catch(h){Lo.error(h)}}if(f&&!Cw.doesTableExist(E,f)){let h=new $Te(E,f,_.hash_attribute);_.attributes&&(h.attributes=_.attributes),Lo.trace(`updateRemoteSource creating table: ${f} in schema: ${E} with attributes: ${JSON.stringify(_.attributes)}`);try{await vW.createTable(h)}catch(T){Lo.error(T)}}if(Lo.trace(`Creating local stream for ${E}.${f}`),await Sl.createLocalTableStream(E,f),c?(await Sl.updateConsumerIterator(E,f,n,"stop"),await Sl.updateRemoteConsumer(_,n),_.subscribe===!0&&await Sl.updateConsumerIterator(E,f,n,"start")):(await Sl.updateRemoteConsumer(_,n),_.subscribe===!0?await Sl.updateConsumerIterator(E,f,n,"start"):await Sl.updateConsumerIterator(E,f,n,"stop")),c){let h=!1;for(let T=0,S=o.subscriptions.length;T<S;T++){let R=o.subscriptions[T];if(R.schema===E&&R.table===f){R.publish=_.publish,R.subscribe=_.subscribe,h=!0;break}}h||o.subscriptions.push(new BW(E,f,_.publish,_.subscribe))}else i.push(new BW(E,f,_.publish,_.subscribe))}c||(o=new VTe(n,i,void 0),Lo.trace(`No record found for ${n}, creating a new one`));let l=Object.create({});return Object.assign(l,o),l.system_info=s,await Iw.upsertNodeRecord(l),WTe({type:"nats_update"}),new ww(Nw.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${YTe.get(qTe.CONFIG_PARAMS.CLUSTERING_NODENAME)} successfully updated remote source`,await Iw.getSystemInfo())}catch(t){Lo.error(t);let r=t.message?t.message:t;return new ww(Nw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(jTe,"updateRemoteSource")});var qW=b((hUe,GW)=>{"use strict";var FW=require("joi"),{string:kW}=FW.types(),QTe=M(),zTe=ut();GW.exports=JTe;function JTe(e){let t=FW.object({operation:kW.valid(QTe.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:kW.required()});return zTe.validateBySchema(e,t)}a(JTe,"removeRemoteSourceValidator")});var YW=b((pUe,VW)=>{"use strict";var XTe=qW(),KT=V(),WT=dt(),Dw=M(),ZTe=hs(),ege=J(),$W=kt(),tge=te(),jT=qE(),{NodeSubscription:rge}=_a(),nge=Gl(),sge=Wo(),{broadcast:ige}=it(),oge=tge.get(Dw.CONFIG_PARAMS.CLUSTERING_NODENAME);VW.exports=age;async function age(e){try{let t=XTe(e);if(t)return KT.error(`Validation error in removeRemoteSource: ${t.message}`),new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,t.message);let r=e.node_name,n=await ZTe.getNodeRecord(r);if(ege.isEmptyOrZeroLength(n)){let i=`No record found for node '${r}'`;return KT.error(i),new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,i)}n=n[0];for(let i=0,o=n.subscriptions.length;i<o;i++){let c=n.subscriptions[i];KT.trace(`remove remote source removing subscription: ${c.schema}.${c.table} for node: ${r}`);let l=new rge(c.schema,c.table,!1,!1);await $W.updateConsumerIterator(c.schema,c.table,r,"stop"),await $W.updateRemoteConsumer(l,r)}let s=new nge(Dw.SYSTEM_SCHEMA_NAME,Dw.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await sge.deleteRecord(s),ige({type:"nats_update"}),new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,`Node ${oge} successfully removed node '${r}'.`)}catch(t){KT.error(t);let r=t.message?t.message:t;return new jT(WT.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(age,"removeRemoteSource")});var QW=b((TUe,jW)=>{"use strict";var QT=V(),$E=M(),KW=dt(),Pw=te(),cge=J(),WW=qE(),lge=hs(),uge=J_(),dge=Yr();jW.exports=_ge;async function _ge(e){try{QT.trace("getRemoteSourceConfig called");let t=process.uptime()*1e3,r=cge.ms_to_time(t),n=new fge(Pw.get($E.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),Pw.get($E.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)??Pw.get($E.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT),r,await lge.getSystemInfo());try{let s={name:e.node_name,system_info:e.system_info},i=new uge($E.SYSTEM_SCHEMA_NAME,$E.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[s]);await dge.update(i)}catch(s){QT.error("Get remote config encountered an error updating system info for node:",e.node_name,s)}return QT.trace("getRemoteSourceConfig response:",n),new WW(KW.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,n)}catch(t){QT.error(t);let r=t.message?t.message:t;return new WW(KW.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,r)}}a(_ge,"getRemoteSourceConfig");function fge(e,t,r,n){this.uptime=r,this.ports={clustering:e,operations_api:t},this.system_info=n}a(fge,"ConfigResponseObject")});var ZW=b((RUe,XW)=>{"use strict";var zW=te();zW.initSync();var JW=kt(),VE=V(),Td=M(),Lw=dt(),Ege=xW(),hge=YW(),mge=QW(),pge=qE(),{encode:Sge,decode:Tge}=require("msgpackr"),gge=as(),Rge=fi(),Age=require("util"),bge=M(),{isMainThread:yge,parentPort:Oge}=require("worker_threads");it();var Nge=Age.promisify(gge.setSchemaDataToGlobal),Mw=zW.get(Td.CONFIG_PARAMS.CLUSTERING_NODENAME);XW.exports=Ige;async function Ige(){try{VE.notify("Starting reply service."),await Nge();let e=await JW.getConnection(),t=`${Mw}.__request__`,r=e.subscribe(t,{queue:Mw});await wge(r)}catch(e){VE.error(e)}}a(Ige,"initialize");async function wge(e){for await(let t of e){let r=Tge(t.data),n;switch(r.operation){case Td.OPERATIONS_ENUM.ADD_NODE:case Td.OPERATIONS_ENUM.UPDATE_NODE:n=await Ege(r);break;case Td.OPERATIONS_ENUM.REMOVE_NODE:n=await hge(r);break;case Td.OPERATIONS_ENUM.CLUSTER_STATUS:n=await mge(r);break;case Td.OPERATIONS_ENUM.DESCRIBE_ALL:n=await Cge();break;default:let s=`node '${Mw}' reply service received unrecognized request operation`;VE.error(s),n=new pge(Lw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,s)}VE.trace(n),t.respond(Sge(n))}}a(wge,"handleRequest");async function Cge(){try{return{status:Lw.UPDATE_REMOTE_RESPONSE_STATUSES.SUCCESS,message:await Rge.describeAll({bypass_auth:!0})}}catch(e){return VE.error(e),{status:Lw.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR,message:e.message}}}a(Cge,"getRemoteDescribeAll");yge||Oge.on("message",async e=>{let{type:t}=e;t===bge.ITC_EVENT_TYPES.SHUTDOWN&&JW.closeConnection()})});var Dge=ZW();(async()=>{try{await Dge()}catch(e){console.error("Error launching Nats reply service."),console.error(e)}})();