harperdb 4.7.0-beta.2 → 4.7.0-beta.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bin/harperdb.js +31 -31
- package/bin/lite.js +3 -3
- package/launchServiceScripts/launchNatsIngestService.js +3 -3
- package/launchServiceScripts/launchNatsReplyService.js +3 -3
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +3 -3
- package/npm-shrinkwrap.json +5 -5
- package/package.json +1 -1
- package/resources/RequestTarget.d.ts +2 -0
- package/resources/analytics/hostnames.d.ts +5 -477
- package/resources/databases.d.ts +1 -478
- package/server/jobs/jobProcess.js +3 -3
- package/server/threads/threadServer.js +3 -3
- package/studio/web/assets/{index-CXaPu3wc.js → index-BqOgGOeU.js} +2 -2
- package/studio/web/assets/{index-B797owPM.js → index-C4VX60Fd.js} +1 -1
- package/studio/web/assets/{profiler-CgmzpljF.js → profiler-OUXA1uul.js} +1 -1
- package/studio/web/assets/{startRecording-DiD-ht9H.js → startRecording-D8PRkhto.js} +1 -1
- package/studio/web/index.html +1 -1
- package/utility/scripts/restartHdb.js +3 -3
package/bin/lite.js
CHANGED
|
@@ -13,7 +13,7 @@ var tX=Object.create;var rm=Object.defineProperty;var rX=Object.getOwnPropertyDe
|
|
|
13
13
|
`),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
|
|
14
14
|
`)},ese="certificate.pem",tse="privateKey.pem",rse="caCertificate.pem",nse="natsCertificate.pem",sse="natsCaCertificate.pem",Pt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},ise={tls_certificate:Pt.SERVER,tlsCertificateAuthority:Pt.CA,customFunctions_tls_certificate:Pt.SERVER,customFunctionsTlsCertificateAuthority:Pt.CA,operationsApi_tls_certificate:Pt["OPERATIONS-API"],operationsApiTlsCertificateAuthority:Pt["OPERATIONS-CA"]},ose={[Pt.SERVER]:2,[Pt.DEFAULT]:1},ase={[Pt["OPERATIONS-API"]]:3,[Pt.SERVER]:2,[Pt.DEFAULT]:1},cse={[Pt["OPERATIONS-API"]]:3,[Pt.SERVER]:2,[Pt.DEFAULT]:1},lse={[Pt["OPERATIONS-CA"]]:3,[Pt.CA]:2,[Pt["DEFAULT-CA"]]:1},use={[Pt["OPERATIONS-CA"]]:3,[Pt.CA]:2,[Pt["DEFAULT-CA"]]:1},dse={[Pt.CA]:2,[Pt["DEFAULT-CA"]]:1};En.CERTIFICATE_PEM_NAME=ese;En.PRIVATEKEY_PEM_NAME=tse;En.CA_PEM_NAME=rse;En.CERT_NAME=Pt;En.CERT_CONFIG_NAME_MAP=ise;En.CERT_PREFERENCE_APP=ose;En.CERT_PREFERENCE_OPS=ase;En.CERT_PREFERENCE_REP=cse;En.CA_CERT_PREFERENCE_REP=lse;En.CA_CERT_PREFERENCE_OPS=use;En.CA_CERT_PREFERENCE_APP=dse;En.CERTIFICATE_VALUES=Zne;En.NATS_CERTIFICATE_PEM_NAME=nse;En.NATS_CA_PEM_NAME=sse});var ww=v((mDe,fH)=>{"use strict";var uH=require("fs-extra"),ge=require("joi"),fse=require("os"),{boolean:We,string:gt,number:dr,array:za}=ge.types(),{totalmem:aH}=require("os"),yl=require("path"),mse=Q(),Iw=ae(),fDe=Aw(),cH=(q(),M(z)),pse=mt(),lH="log",hse="components",Ese="Invalid logging.rotation.maxSize unit. Available units are G, M or K",_se="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",gse="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",Sse="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",Tse="rootPath config parameter is undefined",qn=ge.alternatives([dr.min(0),gt]).optional().empty(null),Mg=ge.alternatives([za.items(gt,{host:gt.required(),port:qn},{hostname:gt.required(),port:qn}).empty(null),za.items(gt)]),Xi,dH=!1;fH.exports={configValidator:yse,routesValidator:Nse,routeConstraints:Mg};function yse(e,t=!1){if(dH=t,Xi=e.rootPath,Iw.isEmpty(Xi))throw Tse;let r=We.optional(),n=dr.min(0).max(1e3).empty(null).default(wse),s=gt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Ep),i=gt.optional().empty(null),a=gt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=ge.string().empty(null).default(Ep),l=ge.custom(bse).empty(null).default(Ep),u=e.clustering?.enabled,d=ge.object({certificate:i,certificateAuthority:i,privateKey:i}),f;return u===!0?f=ge.object({enabled:r,hubServer:ge.object({cluster:ge.object({name:ge.required().empty(null),network:ge.object({port:qn,routes:Mg}).required()}).required(),leafNodes:ge.object({network:ge.object({port:qn}).required()}).required(),network:ge.object({port:qn}).required()}).required(),leafServer:ge.object({network:ge.object({port:qn,routes:Mg}).required(),streams:ge.object({maxAge:dr.min(120).allow(null).optional(),maxBytes:dr.min(1).allow(null).optional(),maxMsgs:dr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:ge.valid("error","warn","info","debug","trace"),nodeName:a,republishMessages:We.optional(),databaseLevel:We.optional(),tls:ge.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:We.required(),verify:We.optional()}),user:gt.optional().empty(null)}).optional():f=ge.object({enabled:r,tls:ge.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:We.optional()})}).optional(),ge.object({authentication:ge.alternatives(ge.object({authorizeLocal:We,cacheTTL:dr.required(),cookie:ge.object({domains:za.items(gt).optional(),expires:gt.optional()}),enableSessions:We,hashFunction:gt.valid("md5","sha256","argon2id").optional().empty(null)}),We).optional(),analytics:ge.object({aggregatePeriod:dr,replicate:We.optional()}),replication:ge.object({hostname:ge.alternatives(gt,dr).optional().empty(null),url:gt.optional().empty(null),port:qn,securePort:qn,routes:za.optional().empty(null),databases:ge.alternatives(gt,za),enableRootCAs:We.optional(),copyTablesToCatchUp:We.optional()}).optional(),componentsRoot:s.optional(),clustering:f,localStudio:ge.object({enabled:r}).required(),logging:ge.object({auditAuthEvents:ge.object({logFailed:We,logSuccessful:We}),file:We.required(),level:ge.valid("notify","fatal","error","warn","info","debug","trace"),rotation:ge.object({enabled:We.optional(),compress:We.optional(),interval:gt.custom(Ise).optional().empty(null),maxSize:gt.custom(Ase).optional().empty(null),path:gt.optional().empty(null).default(Ep)}).required(),root:s,stdStreams:We.required(),auditLog:We.required()}).required(),operationsApi:ge.object({network:ge.object({cors:We.optional(),corsAccessList:za.optional(),headersTimeout:dr.min(1).optional(),keepAliveTimeout:dr.min(1).optional(),port:qn,domainSocket:ge.optional().empty("hdb/operations-server").default(Ep),securePort:qn,timeout:dr.min(1).optional()}).optional(),tls:ge.alternatives([ge.array().items(d),d])}).required(),rootPath:gt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:ge.object({network:ge.object({port:qn,securePort:qn,mtls:ge.alternatives([We.optional(),ge.object({user:gt.optional(),certificateAuthority:i,required:We.optional()})])}).required(),webSocket:We.optional(),requireAuthentication:We.optional()}),http:ge.object({compressionThreshold:dr.optional(),cors:We.optional(),corsAccessList:za.optional(),headersTimeout:dr.min(1).optional(),port:qn,securePort:qn,maxHeaderSize:dr.optional(),mtls:ge.alternatives([We.optional(),ge.object({user:gt.optional(),certificateAuthority:i,required:We.optional()})]),threadRange:ge.alternatives([za.optional(),gt.optional()])}).required(),threads:ge.alternatives(n.optional(),ge.object({count:n.optional(),debug:ge.alternatives(We.optional(),ge.object({startingPort:dr.min(1).optional(),host:gt.optional(),waitForDebugger:We.optional()})),maxHeapMemory:dr.min(0).optional()})),storage:ge.object({writeAsync:We.required(),overlappingSync:We.optional(),caching:We.optional(),compression:ge.alternatives([We.optional(),ge.object({dictionary:gt.optional(),threshold:dr.optional()})]),compactOnStart:We.optional(),compactOnStartKeepBackup:We.optional(),noReadAhead:We.optional(),path:l,prefetchWrites:We.optional(),maxFreeSpaceToLoad:dr.optional(),maxFreeSpaceToRetain:dr.optional()}).required(),ignoreScripts:We.optional(),tls:ge.alternatives([ge.array().items(d),d])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}o(yse,"configValidator");function Rse(e){return dH||uH.existsSync(e)?null:`Specified path ${e} does not exist.`}o(Rse,"doesPathExist");function bse(e,t){ge.assert(e,gt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=Rse(e);if(r)return t.message(r)}o(bse,"validatePath");function Ase(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(Ese);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(gse):e}o(Ase,"validateRotationMaxSize");function Ise(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(_se);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(Sse):e}o(Ise,"validateRotationInterval");function wse(e,t){let r=t.state.path.join("."),n=fse.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||aH();return i=Math.round(Math.min(i,aH())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),mse.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}o(wse,"setDefaultThreads");function Ep(e,t){let r=t.state.path.join(".");if(!Iw.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Iw.isEmpty(Xi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return yl.join(Xi,hse);case"logging.root":return yl.join(Xi,lH);case"clustering.leafServer.streams.path":return yl.join(Xi,"clustering","leaf");case"storage.path":let n=yl.join(Xi,cH.LEGACY_DATABASES_DIR_NAME);return uH.existsSync(n)?n:yl.join(Xi,cH.DATABASES_DIR_NAME);case"logging.rotation.path":return yl.join(Xi,lH);case"operationsApi.network.domainSocket":return r==null?null:yl.join(Xi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}o(Ep,"setDefaultRoot");function Nse(e){let t=ge.object({routes:Mg});return pse.validateBySchema({routes:e},t)}o(Nse,"routesValidator")});var St=v(nr=>{"use strict";var Bs=(q(),M(z)),wr=ae(),fr=Q(),{configValidator:Cse,routesValidator:mH}=ww(),_n=require("fs-extra"),hH=require("yaml"),us=require("path"),Ose=require("is-number"),EH=require("properties-reader"),Pse=require("lodash"),{handleHDBError:Lse}=_e(),{HTTP_STATUS_CODES:Dse,HDB_ERROR_MSGS:id}=zr(),{server:Mse}=(Fr(),M(nm)),{PACKAGE_ROOT:_H}=Ct(),{DATABASES_PARAM_CONFIG:_p,CONFIG_PARAMS:ls,CONFIG_PARAM_MAP:mi}=Bs,vse="Unable to get config value because config is uninitialized",Use="Config successfully initialized",xse="Error backing up config file",Bse="Empty parameter sent to getConfigValue",gH=us.join(_H,"config","yaml",Bs.HDB_DEFAULT_CONFIG_FILE),Fse=us.join(_H,"config","yaml","defaultNatsConfig.yaml"),kse="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",pH={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"},vg,kt,Ug;nr.createConfigFile=Hse;nr.getDefaultConfig=Gse;nr.getConfigValue=TH;nr.initConfig=xg;nr.flattenConfig=od;nr.updateConfigValue=yH;nr.updateConfigObject=$se;nr.getConfiguration=Yse;nr.setConfiguration=Wse;nr.readConfigFile=Pw;nr.getClusteringRoutes=zse;nr.initOldConfig=RH;nr.getConfigFromFile=jse;nr.getConfigFilePath=Rl;nr.addConfig=Qse;nr.deleteConfigFromFile=Jse;nr.getConfigObj=Xse;nr.resolvePath=Nw;nr.getFlatConfigObj=Zse;function Nw(e){if(e?.startsWith("~/"))return us.join(wr.getHomeDir(),e.slice(1));let t=me();try{return us.resolve(t.getHdbBasePath(),e)}catch(r){return console.error("Unable to resolve path",e,r),e}}o(Nw,"resolvePath");function Hse(e,t=!1){let r=ja(gH);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=hH.parseDocument(_n.readFileSync(Fse,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}vg=od(r.toJSON());let n;for(let c in e){let l=mi[c.toLowerCase()];if(l===ls.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),d=Cw(l,e[c]);l==="rootPath"&&d?.endsWith("/")&&(d=d.slice(0,-1));try{u.length>1&&typeof r.getIn(u.slice(0,-1))=="boolean"&&r.deleteIn(u.slice(0,-1)),r.setIn([...u],d)}catch(f){fr.error(f)}}}n&&SH(r,n),Ow(r,t);let s=r.toJSON();kt=od(s);let i=r.getIn(["rootPath"]),a=us.join(i,Bs.HDB_CONFIG_FILE);if(_n.createFileSync(a),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);_n.writeFileSync(a,String(r)),fr.trace(`Config file written to ${a}`)}o(Hse,"createConfigFile");function SH(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!wr.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(_p.TABLES))for(let i in n[s][_p.TABLES])for(let a in n[s][_p.TABLES][i]){let c=n[s][_p.TABLES][i][a],l=[ls.DATABASES,s,_p.TABLES,i,a];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let a=n[s][i],c=[ls.DATABASES,s,i];e.hasIn(c)?e.setIn(c,a):e.addIn(c,a)}}}catch(n){fr.error("Error parsing schemas CLI/env config arguments",n)}}o(SH,"setSchemasConfig");function Gse(e){if(vg===void 0){let r=ja(gH);vg=od(r.toJSON())}let t=mi[e.toLowerCase()];if(t!==void 0)return vg[t.toLowerCase()]}o(Gse,"getDefaultConfig");function TH(e){if(e==null){fr.info(Bse);return}if(kt===void 0){fr.trace(vse);return}let t=mi[e.toLowerCase()];if(t!==void 0)return kt[t.toLowerCase()]}o(TH,"getConfigValue");function Rl(e=wr.getPropsFilePath()){let t=wr.getEnvCliRootPath();if(t)return Nw(us.join(t,Bs.HDB_CONFIG_FILE));let r=EH(e);return Nw(r.get(Bs.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}o(Rl,"getConfigFilePath");function xg(e=!1){if(kt===void 0||e){let t;if(!wr.noBootFile()){t=wr.getPropsFilePath();try{_n.accessSync(t,_n.constants.F_OK|_n.constants.R_OK)}catch(i){throw fr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Rl(t),n;if(r.includes("config/settings.js"))try{RH(r);return}catch(i){if(i.code!==Bs.NODE_ERROR_CODES.ENOENT)throw i}try{n=ja(r)}catch(i){if(i.code===Bs.NODE_ERROR_CODES.ENOENT){fr.trace(`HarperDB config file not found at ${r}.
|
|
15
15
|
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}`)}qse(n,r),Ow(n);let s=n.toJSON();if(Mse.config=s,kt=od(s),kt.logging_rotation_rotate)for(let i in pH)kt[i]&&fr.error(`Config ${pH[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);fr.trace(Use)}}o(xg,"initConfig");function qse(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],us.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],us.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,replicate:!1}),n=!0),n){if(fr.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);_n.writeFileSync(t,String(e))}}o(qse,"checkForUpdatedConfig");function Ow(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 id.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 id.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=Cse(r,t);if(n.error)throw id.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)}o(Ow,"validateConfig");function $se(e,t){kt===void 0&&(kt={});let r=mi[e.toLowerCase()];if(r===void 0){fr.trace(`Unable to update config object because config param '${e}' does not exist`);return}kt[r.toLowerCase()]=t}o($se,"updateConfigObject");function yH(e,t,r=void 0,n=!1,s=!1,i=!1){kt===void 0&&xg();let a=TH(mi.hdb_root),c=us.join(a,Bs.HDB_CONFIG_FILE),l=ja(c),u;if(r&&kt){let m=!1;for(let p in r)if(r[p]!=kt[p.toLowerCase()]){m=!0;break}if(!m){fr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===ls.DATABASES)u=t;else if(r===void 0){let m;if(i)m=e;else if(m=mi[e.toLowerCase()],m===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let p=m.split("_"),h=Cw(m,t);l.setIn([...p],h)}else for(let m in r){let p=mi[m.toLowerCase()];if(p===ls.HTTP_SECUREPORT&&r[m]===kt[ls.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),p===ls.OPERATIONSAPI_NETWORK_SECUREPORT&&r[m]===kt[ls.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),p===ls.DATABASES){u=r[m];continue}if(p?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!p&&(m.endsWith("_package")||m.endsWith("_port"))&&(p=m),p!==void 0){let h=p.split("_"),E=Bs.LEGACY_CONFIG_PARAMS[m.toUpperCase()];E&&E.startsWith("customFunctions")&&l.hasIn(E.split("_"))&&(p=E,h=E.split("_"));let g=Cw(p,r[m]);p==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],g)}catch(R){fr.error(R)}}}u&&SH(l,u),Ow(l);let d=l.getIn(["rootPath"]),f=us.join(d,Bs.HDB_CONFIG_FILE);if(n===!0&&Vse(c,d),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);_n.writeFileSync(f,String(l)),s&&(kt=od(l.toJSON())),fr.trace(`Config parameter: ${e} updated with value: ${t}`)}o(yH,"updateConfigValue");function Vse(e,t){try{let r=us.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${Bs.HDB_CONFIG_FILE}.bak`);_n.copySync(e,r),fr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){fr.error(xse),fr.error(r)}}o(Vse,"backupConfigFile");var Kse=["databases"];function od(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}),Ug=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])&&!Kse.includes(i)){let a=r(n[i]);for(let c in a){if(!a.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!ls[l.toUpperCase()]&&mi[l]&&(s[mi[l].toLowerCase()]=a[c]),s[l]=a[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}o(r,"squashObj")}o(od,"flattenConfig");function Cw(e,t){if(e===ls.CLUSTERING_NODENAME||e===ls.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(Ose(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||wr.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 wr.autoCast(t)}o(Cw,"castConfigValue");function Yse(){let e=wr.getPropsFilePath(),t=Rl(e);return ja(t).toJSON()}o(Yse,"getConfiguration");async function Wse(e){let{operation:t,hdb_user:r,hdbAuthHeader:n,...s}=e;try{return yH(void 0,void 0,s,!0),kse}catch(i){throw typeof i=="string"||i instanceof String?Lse(i,i,Dse.BAD_REQUEST,void 0,void 0,!0):i}}o(Wse,"setConfiguration");function Pw(){let e=wr.getPropsFilePath();try{_n.accessSync(e,_n.constants.F_OK|_n.constants.R_OK)}catch(n){if(!wr.noBootFile())throw fr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Rl(e);return ja(t).toJSON()}o(Pw,"readConfigFile");function ja(e){return hH.parseDocument(_n.readFileSync(e,"utf8"),{simpleKeys:!0})}o(ja,"parseYamlDoc");function zse(){let e=Pw(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=wr.isEmptyOrZeroLength(t)?[]:t;let r=mH(t);if(r)throw id.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=wr.isEmptyOrZeroLength(n)?[]:n;let s=mH(n);if(s)throw id.CONFIG_VALIDATION(s.message);if(!wr.isEmptyOrZeroLength(n)&&!wr.isEmptyOrZeroLength(t)){let i=t.filter(a=>n.some(c=>c.host===a.host&&c.port===a.port));if(!wr.isEmptyOrZeroLength(i)){let a=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw id.CONFIG_VALIDATION(a)}}return{hub_routes:t,leaf_routes:n}}o(zse,"getClusteringRoutes");function RH(e){let t=EH(e);kt={};for(let r in mi){let n=t.get(r.toUpperCase());if(wr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=mi[r].toLowerCase();s===ls.LOGGING_ROOT?kt[s]=us.dirname(n):kt[s]=n}return kt}o(RH,"initOldConfig");function jse(e){let t=Pw();return Pse.get(t,e.replaceAll("_","."))}o(jse,"getConfigFromFile");async function Qse(e,t){let r=ja(Rl());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await _n.writeFile(Rl(),String(r))}o(Qse,"addConfig");function Jse(e){let t=Rl(wr.getPropsFilePath()),r=ja(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=us.join(n,Bs.HDB_CONFIG_FILE);_n.writeFileSync(s,String(r))}o(Jse,"deleteConfigFromFile");function Xse(){return Ug||(xg(),Ug)}o(Xse,"getConfigObj");function Zse(){return kt||xg(),kt}o(Zse,"getFlatConfigObj")});var ds=v((_De,qr)=>{"use strict";var IH="username is required",wH="nothing to update, must supply active, role or password to update",NH="password cannot be an empty string",CH="If role is specified, it cannot be empty.",OH="active must be true or false";qr.exports.addUser=cie;qr.exports.alterUser=lie;qr.exports.dropUser=die;qr.exports.getSuperUser=Eie;qr.exports.userInfo=fie;qr.exports.listUsers=Fg;qr.exports.listUsersExternal=mie;qr.exports.setUsersWithRolesCache=bl;qr.exports.findAndValidateUser=kw;qr.exports.getClusterUser=_ie;qr.exports.getUsersWithRolesCache=hie;qr.exports.USERNAME_REQUIRED=IH;qr.exports.ALTERUSER_NOTHING_TO_UPDATE=wH;qr.exports.EMPTY_PASSWORD=NH;qr.exports.EMPTY_ROLE=CH;qr.exports.ACTIVE_BOOLEAN=OH;var PH=Hn(),eie=Sl(),gp=(dw(),M(uw)),LH=Ik(),Sp=hn(),Uw=Ho(),Zi=ae(),DH=require("validate.js"),xw=Q(),{promisify:tie}=require("util"),Bw=Ji(),Dw=(q(),M(z)),bH=Ot(),rie=St(),nie=me(),sie=Yi(),{hdbErrors:iie,ClientError:pi}=_e(),{HTTP_STATUS_CODES:Vo,AUTHENTICATION_ERROR_MSGS:Lw,HDB_ERROR_MSGS:ad}=iie,{UserEventMsg:Fw}=ss(),Mw=require("lodash"),{server:Bg}=(Fr(),M(nm)),oie=Q();Bg.getUser=(e,t)=>kw(e,t,t!=null);Bg.authenticateUser=(e,t)=>kw(e,t);var MH={username:!0,active:!0,role:!0,password:!0},AH=new Map,aie=tie(eie.delete),vw=nie.get(Dw.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??gp.HASH_FUNCTION.SHA256,eo;async function cie(e){let t=DH.cleanAttributes(e,MH),r=LH.addUserValidation(t);if(r)throw new pi(r.message);let n=await Sp.searchByValue({schema:"system",table:"hdb_role",attribute:"role",value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new pi(ad.ROLE_NAME_NOT_FOUND(t.role),Vo.NOT_FOUND);if(n.length>1)throw new pi(ad.DUP_ROLES_FOUND(t.role),Vo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=Bw.encrypt(t.password)),t.password=await gp.hash(t.password,vw),t.hash_function=vw,t.role=n[0].id;let s=await PH.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(xw.debug(s),await bl(),s.skipped_hashes.length===1)throw new pi(ad.USER_ALREADY_EXISTS(t.username),Vo.CONFLICT);return Uw.signalUserChange(new Fw(process.pid)),`${t.username} successfully added`}o(cie,"addUser");async function lie(e){let t=DH.cleanAttributes(e,MH);if(Zi.isEmptyOrZeroLength(t.username))throw new Error(IH);if(Zi.isEmptyOrZeroLength(t.password)&&Zi.isEmptyOrZeroLength(t.role)&&Zi.isEmptyOrZeroLength(t.active))throw new Error(wH);if(!Zi.isEmpty(t.password)&&Zi.isEmptyOrZeroLength(t.password.trim()))throw new Error(NH);if(!Zi.isEmpty(t.active)&&!Zi.isBoolean(t.active))throw new Error(OH);if(!Zi.isEmpty(t.password)&&!Zi.isEmptyOrZeroLength(t.password.trim())&&(uie(t.username)&&(t.hash=Bw.encrypt(t.password)),t.password=await gp.hash(t.password,vw)),t.role==="")throw new Error(CH);if(t.role){let n=await Sp.searchByValue({schema:"system",table:"hdb_role",attribute:"role",value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new pi(ad.ALTER_USER_ROLE_NOT_FOUND(t.role),Vo.NOT_FOUND);if(n.length>1)throw new pi(ad.DUP_ROLES_FOUND(t.role),Vo.CONFLICT);t.role=n[0].id}let r=await PH.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await bl(),Uw.signalUserChange(new Fw(process.pid)),r}o(lie,"alterUser");function uie(e){let t=!1,r=eo.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}o(uie,"isClusterUser");async function die(e){let t=LH.dropUserValidation(e);if(t)throw new pi(t.message);if(eo.get(e.username)===void 0)throw new pi(ad.USER_NOT_EXIST(e.username),Vo.NOT_FOUND);let r=await aie({table:"hdb_user",schema:"system",hash_values:[e.username]});return xw.debug(r),await bl(),Uw.signalUserChange(new Fw(process.pid)),`${e.username} successfully deleted`}o(die,"dropUser");async function fie(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Mw.cloneDeep(e.hdb_user);let r=await Sp.searchByHash({schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]});return t.role=r[0],delete t.password,delete t.refresh_token,delete t.hash,delete t.hash_function,t}o(fie,"userInfo");async function mie(){let e=await Fg();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}o(mie,"listUsersExternal");async function Fg(){let e=await Sp.searchByValue({schema:"system",table:"hdb_role",value:"*",attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Mw.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await Sp.searchByValue({schema:"system",table:"hdb_user",value:"*",attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Mw.cloneDeep(s),s.role=t[s.role],pie(s.role),n.set(s.username,s);return n}o(Fg,"listUsers");function pie(e){if(!e){xw.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(sie)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}o(pie,"appendSystemTablesToRole");async function bl(e=void 0){e?eo=e:eo=await Fg()}o(bl,"setUsersWithRolesCache");async function hie(){return eo||await bl(),eo}o(hie,"getUsersWithRolesCache");async function kw(e,t,r=!0){eo||await bl();let n=eo.get(e);if(!n){if(!r)return{username:e};throw new pi(Lw.GENERIC_AUTH_FAIL,Vo.UNAUTHORIZED)}if(n&&!n.active)throw new pi(Lw.USER_INACTIVE,Vo.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(AH.get(t)===n.password)return s;{let i=gp.validate(n.password,t,n.hash_function||gp.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)AH.set(t,n.password);else throw new pi(Lw.GENERIC_AUTH_FAIL,Vo.UNAUTHORIZED)}}return s}o(kw,"findAndValidateUser");async function Eie(){eo||await bl();for(let[,e]of eo)if(e.role.role==="super_user")return e}o(Eie,"getSuperUser");async function _ie(){let e=await Fg(),t=rie.getConfigFromFile(Dw.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==Dw.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=Bw.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+bH.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+bH.SERVER_SUFFIX.ADMIN,r}o(_ie,"getClusterUser");var vH=[];Bg.invalidateUser=function(e){for(let t of vH)try{t(e)}catch(r){oie.error("Error invalidating user",r)}};Bg.onInvalidatedUser=function(e){vH.push(e)}});var Ie,cd=se(()=>{Ie={HEALTHY:"healthy",WARNING:"warning",ERROR:"error",UNKNOWN:"unknown",LOADING:"loading"}});var ld,Hw=se(()=>{cd();ld=class{static{o(this,"ComponentStatus")}lastChecked;status;message;error;constructor(t,r,n){this.lastChecked=new Date,this.status=t,this.message=r,this.error=n}updateStatus(t,r){this.status=t,this.message=r,this.lastChecked=new Date,t!==Ie.ERROR&&(this.error=void 0)}markHealthy(t){this.updateStatus(Ie.HEALTHY,t||"Component is healthy")}markError(t,r){this.status=Ie.ERROR,this.error=t,this.message=r||(typeof t=="string"?t:t.message),this.lastChecked=new Date}markWarning(t){this.updateStatus(Ie.WARNING,t)}markLoading(t){this.updateStatus(Ie.LOADING,t||"Component is loading")}isHealthy(){return this.status===Ie.HEALTHY}hasError(){return this.status===Ie.ERROR}isLoading(){return this.status===Ie.LOADING}hasWarning(){return this.status===Ie.WARNING}getSummary(){let t=this.status.toUpperCase(),r=this.message?`: ${this.message}`:"";return`${t}${r}`}}});var Al,Qa,Gw,ud,qw,dd,$w,kg=se(()=>{Al=b(zr()),Qa=class extends Error{static{o(this,"ComponentStatusError")}statusCode;timestamp;constructor(t,r=Al.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR){super(t),this.name="ComponentStatusError",this.statusCode=r,this.timestamp=new Date,Error.captureStackTrace(this,this.constructor)}},Gw=class extends Qa{static{o(this,"CrossThreadTimeoutError")}requestId;timeoutMs;collectedCount;constructor(t,r,n){super(`Component status collection timeout after ${r}ms. Collected ${n} responses for request ${t}.`,Al.HTTP_STATUS_CODES.GATEWAY_TIMEOUT),this.name="CrossThreadTimeoutError",this.requestId=t,this.timeoutMs=r,this.collectedCount=n}},ud=class extends Qa{static{o(this,"ITCError")}operation;cause;constructor(t,r){super(`Inter-thread communication failed during ${t}: ${r?.message||"Unknown error"}`,Al.HTTP_STATUS_CODES.SERVICE_UNAVAILABLE),this.name="ITCError",this.operation=t,this.cause=r}},qw=class extends Qa{static{o(this,"AggregationError")}componentCount;cause;constructor(t,r){super(`Failed to aggregate status for ${t} components: ${r?.message||"Unknown error"}`,Al.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR),this.name="AggregationError",this.componentCount=t,this.cause=r}},dd=class extends Qa{static{o(this,"ComponentStatusOperationError")}componentName;operation;constructor(t,r,n){super(`Component '${t}' ${r} failed: ${n}`,Al.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR),this.name="ComponentStatusOperationError",this.componentName=t,this.operation=r}},$w=class extends Qa{static{o(this,"CrossThreadCollectionError")}result;constructor(t){let r=t.success?`Partial collection success: ${t.collectedFromThreads} threads responded`+(t.timedOutThreads.length>0?`, ${t.timedOutThreads.length} timed out`:""):`Collection failed: ${t.errors.map(n=>n.message).join(", ")}`;super(r,Al.HTTP_STATUS_CODES.OK),this.name="CrossThreadCollectionError",this.result=t}getDiagnostics(){let t=[`Cross-thread collection ${this.result.success?"partially succeeded":"failed"}`,`Threads responded: ${this.result.collectedFromThreads}`];return this.result.expectedThreads&&t.push(`Expected threads: ${this.result.expectedThreads}`),this.result.timedOutThreads.length>0&&t.push(`Timed out threads: ${this.result.timedOutThreads.join(", ")}`),this.result.errors.length>0&&(t.push("Errors:"),this.result.errors.forEach((r,n)=>{t.push(` ${n+1}. ${r.name}: ${r.message}`)})),t.join(`
|
|
16
|
-
`)}}});var UH,Il,xH,Ja,Tp,fd,gie,Hg,Vw=se(()=>{UH=b(ss()),Il=b(nt());q();xH=b(Xn());cd();kg();Ja=(0,xH.loggerWithTag)("componentStatus.crossThread"),Tp=class{static{o(this,"CrossThreadStatusCollector")}awaitingResponses=new Map;responseCheckers=new Map;nextRequestId=1;listenerAttached=!1;timeout;cleanupTimer=null;constructor(t=5e3){this.timeout=t}attachListener(){this.listenerAttached||((0,Il.onMessageByType)(t_.COMPONENT_STATUS_RESPONSE,({message:t})=>{let r=t.isMainThread?"main":`worker-${t.workerIndex}`;Ja.trace?.("Received component status response from %s, with requestId: %d",r,t.requestId);let n=this.awaitingResponses.get(t.requestId);if(n){n.push({workerIndex:t.workerIndex,isMainThread:t.isMainThread||!1,statuses:t.statuses||[]});let s=this.responseCheckers.get(t.requestId);s&&s()}}),this.listenerAttached=!0)}scheduleCleanup(){this.cleanupTimer&&clearTimeout(this.cleanupTimer),this.awaitingResponses.size>0&&(this.cleanupTimer=setTimeout(()=>{this.awaitingResponses.size>0&&(Ja.debug?.(`Cleaning up ${this.awaitingResponses.size} stale pending requests`),this.awaitingResponses.clear()),this.cleanupTimer=null},3e4))}async collect(t){try{this.attachListener(),this.scheduleCleanup();let r=this.nextRequestId++,n=[];this.awaitingResponses.set(r,n);let a=((0,Il.getWorkerCount)()||1)+1-1,l=await new Promise((p,h)=>{let E=!1,g=o(()=>{let y=this.awaitingResponses.get(r);y&&y.length>=a&&!E&&(E=!0,S(),Ja.trace?.(`Collected all ${y.length} expected responses for request ${r}`),p(y))},"checkComplete"),R=setTimeout(()=>{if(!E){E=!0;let y=this.awaitingResponses.get(r)||[];this.awaitingResponses.delete(r),Ja.debug?.(`Collection timeout for request ${r}: collected ${y.length}/${a} responses`),p(y)}},this.timeout),S=o(()=>{this.awaitingResponses.delete(r),clearTimeout(R)},"cleanup");this.responseCheckers.set(r,g),(0,UH.sendItcEvent)({type:t_.COMPONENT_STATUS_REQUEST,message:{requestId:r}}).then(()=>{g()}).catch(y=>{E=!0,S(),this.responseCheckers.delete(r),h(new ud("sendItcEvent",y))})});this.responseCheckers.delete(r);let u=new Map,d=t.getAllStatuses(),f=(0,Il.getWorkerIndex)(),m=f===void 0?"main":`worker-${f}`;for(let[p,h]of d)u.set(`${p}@${m}`,{...h,workerIndex:f});for(let p of l)for(let[h,E]of p.statuses){let g=p.isMainThread?"main":`worker-${p.workerIndex}`;u.set(`${h}@${g}`,{...E,workerIndex:p.workerIndex})}return Ja.debug?.(`Collected component status from ${l.length+1} threads (including local)`),u}catch(r){return r instanceof ud?Ja.error?.(`ITC failure during component status collection: ${r.message}`):Ja.warn?.("Failed to collect component status from all threads:",r),Ja.debug?.(`Collection failed for request. Error: ${r instanceof Error?r.message:"Unknown error"}`),this.getLocalStatusOnly(t)}}getLocalStatusOnly(t){let r=t.getAllStatuses(),n=new Map,s=(0,Il.getWorkerIndex)(),i=s===void 0?"main":`worker-${s}`;for(let[a,c]of r)n.set(`${a}@${i}`,{...c,workerIndex:s});return n}cleanup(){this.awaitingResponses.clear(),this.responseCheckers.clear(),this.cleanupTimer&&(clearTimeout(this.cleanupTimer),this.cleanupTimer=null)}},fd=class{static{o(this,"StatusAggregator")}static aggregate(t){let r=new Map,n=new Map;for(let[s,i]of t){let a=s.indexOf("@"),c=a!==-1?s.substring(0,a):s,l=n.get(c);l||(l=[],n.set(c,l)),l.push([s,i])}for(let[s,i]of n){let a=this.aggregateComponentGroup(s,i);r.set(s,a)}return r}static aggregateComponentGroup(t,r){let n={workers:{}},s=0,i,a,c=new Map,l=new Map;for(let[m,p]of r){let h=m.lastIndexOf("@"),E=h!==-1?m.substring(h+1):"",g=p.lastChecked instanceof Date?p.lastChecked.getTime():new Date(p.lastChecked).getTime();if(E==="main")n.main=g;else if(E&&E.startsWith("worker-")){let R=parseInt(E.substring(7));isNaN(R)||(n.workers[R]=g)}c.set(p.status,(c.get(p.status)||0)+1),p.status!==Ie.HEALTHY&&p.message&&(!i||g>s)&&(s=g,i=p.message),p.error&&!a&&(a=p.error)}let u=this.determineOverallStatus(c);if(Array.from(c.keys()).length>1)for(let[m,p]of r)p.status!==u&&l.set(m,{workerIndex:p.workerIndex!==void 0?p.workerIndex:-1,status:p.status,message:p.message,error:p.error});let f={componentName:t,status:u,lastChecked:n,latestMessage:i,error:a};return l.size>0&&(f.abnormalities=l),f}static determineOverallStatus(t){let r=[Ie.ERROR,Ie.WARNING,Ie.LOADING,Ie.UNKNOWN,Ie.HEALTHY];for(let n of r)if(t.has(n)&&t.get(n)>0)return n;return Ie.UNKNOWN}},gie=parseInt(process.env.COMPONENT_STATUS_TIMEOUT||"5000"),Hg=new Tp(gie)});var Xa,Gg=se(()=>{Hw();cd();Vw();kg();Xa=class e{static{o(this,"ComponentStatusRegistry")}statusMap=new Map;reset(){this.statusMap=new Map}setStatus(t,r,n,s){if(!t||typeof t!="string")throw new dd(String(t),"setStatus","Component name must be a non-empty string");if(!Object.values(Ie).includes(r))throw new dd(t,"setStatus",`Invalid status level: ${r}. Must be one of: ${Object.values(Ie).join(", ")}`);this.statusMap.set(t,new ld(r,n,s))}getStatus(t){return this.statusMap.get(t)}getAllStatuses(){return this.statusMap}reportHealthy(t,r){this.setStatus(t,Ie.HEALTHY,r)}reportError(t,r,n){this.setStatus(t,Ie.ERROR,n,r)}reportWarning(t,r){this.setStatus(t,Ie.WARNING,r)}initializeLoading(t,r){this.setStatus(t,Ie.LOADING,r||"Component is loading")}markLoaded(t,r){this.setStatus(t,Ie.HEALTHY,r||"Component loaded successfully")}markFailed(t,r,n){this.setStatus(t,Ie.ERROR,n,r)}getComponentsByStatus(t){let r=[];for(let[n,s]of this.statusMap)s.status===t&&r.push({name:n,status:s});return r}getStatusSummary(){let t={[Ie.HEALTHY]:0,[Ie.ERROR]:0,[Ie.WARNING]:0,[Ie.LOADING]:0,[Ie.UNKNOWN]:0};for(let r of this.statusMap.values())t[r.status]++;return t}static async getAggregatedFromAllThreads(t){let r=await Hg.collect(t);return fd.aggregate(r)}async getAggregatedStatusFor(t,r){r||(r=await e.getAggregatedFromAllThreads(this));let n=[],s=t+".",i=r.get(t);i&&n.push({key:t,...i});for(let[f,m]of r)f.startsWith(s)&&n.push({key:f,...m});if(n.length===0)return{status:Ie.UNKNOWN,message:"The component has not been loaded yet (may need a restart)",lastChecked:{workers:{}}};let a=n.some(f=>f.status===Ie.ERROR),c=n.some(f=>f.status===Ie.LOADING),l=a?Ie.ERROR:c?Ie.LOADING:Ie.HEALTHY,u="All components loaded successfully",d={};if(a||c){u=n.filter(m=>m.status===Ie.ERROR||m.status===Ie.LOADING).map(m=>`${m.key}: ${m.latestMessage||m.status}`).join("; ");for(let m of n)m.status!==Ie.HEALTHY&&(d[m.key]={status:m.status,message:m.latestMessage})}return{status:l,message:u,...Object.keys(d).length>0&&{details:d},lastChecked:n[0]?.lastChecked||{workers:{}}}}}});var mr,qg=se(()=>{Gg();mr=new Xa});function FH(e){let t=BH.get(e);return t||(t=new Kw(e),BH.set(e,t)),t}function kH(){mr.reset()}var Kw,BH,to,HH,GH=se(()=>{qg();cd();Kw=class{static{o(this,"ComponentStatusBuilder")}componentName;constructor(t){this.componentName=t}healthy(t){return mr.setStatus(this.componentName,Ie.HEALTHY,t),this}warning(t){return mr.setStatus(this.componentName,Ie.WARNING,t),this}error(t,r){return mr.setStatus(this.componentName,Ie.ERROR,t,r),this}loading(t){return mr.setStatus(this.componentName,Ie.LOADING,t||"Loading..."),this}unknown(t){return mr.setStatus(this.componentName,Ie.UNKNOWN,t),this}get(){return mr.getStatus(this.componentName)}},BH=new Map;o(FH,"statusForComponent");to={loading(e,t){mr.initializeLoading(e,t)},loaded(e,t){mr.markLoaded(e,t)},failed(e,t,r){mr.markFailed(e,t,r)}};o(kH,"reset");HH=Ie});var yp={};Re(yp,{AggregationError:()=>qw,COMPONENT_STATUS_LEVELS:()=>Ie,ComponentStatus:()=>ld,ComponentStatusError:()=>Qa,ComponentStatusOperationError:()=>dd,ComponentStatusRegistry:()=>Xa,CrossThreadCollectionError:()=>$w,CrossThreadStatusCollector:()=>Tp,CrossThreadTimeoutError:()=>Gw,ITCError:()=>ud,StatusAggregator:()=>fd,componentStatusRegistry:()=>mr,crossThreadCollector:()=>Hg,query:()=>Sie});var Sie,qH=se(()=>{qg();Gg();Hw();Gg();Vw();qg();kg();cd();Sie={get(e){return mr.getStatus(e)},all(){return mr.getAllStatuses()},byStatus(e){return mr.getComponentsByStatus(e)},summary(){return mr.getStatusSummary()},async allThreads(){return Xa.getAggregatedFromAllThreads(mr)}}});var Yw={};Re(Yw,{STATUS:()=>HH,internal:()=>yp,lifecycle:()=>to,reset:()=>kH,statusForComponent:()=>FH});var Rp=se(()=>{GH();qH()});var Ap=v((JDe,KH)=>{"use strict";var fs=Q(),gn=(q(),M(z)),Tie=u0(),yie=ds(),{validateEvent:Ww}=ss(),bp=as(),Rie=require("process"),{resetDatabases:bie}=(we(),M(ft)),Aie={[gn.ITC_EVENT_TYPES.SCHEMA]:Iie,[gn.ITC_EVENT_TYPES.USER]:VH,[gn.ITC_EVENT_TYPES.COMPONENT_STATUS_REQUEST]:Nie};async function Iie(e){let t=Ww(e);if(t){fs.error(t);return}fs.trace("ITC schemaHandler received schema event:",e),await Tie(e.message),await wie(e.message)}o(Iie,"schemaHandler");async function wie(e){try{bp.resetReadTxn(gn.SYSTEM_SCHEMA_NAME,gn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),bp.resetReadTxn(gn.SYSTEM_SCHEMA_NAME,gn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),bp.resetReadTxn(gn.SYSTEM_SCHEMA_NAME,gn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=bie();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){fs.error(t)}}o(wie,"syncSchemaMetadata");var $H=[];async function VH(e){try{try{bp.resetReadTxn(gn.SYSTEM_SCHEMA_NAME,gn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),bp.resetReadTxn(gn.SYSTEM_SCHEMA_NAME,gn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){fs.warn(r)}let t=Ww(e);if(t){fs.error(t);return}fs.trace(`ITC userHandler ${gn.HDB_ITC_CLIENT_PREFIX}${Rie.pid} received user event:`,e),await yie.setUsersWithRolesCache();for(let r of $H)r()}catch(t){fs.error(t)}}o(VH,"userHandler");VH.addListener=function(e){$H.push(e)};async function Nie(e){try{let t=Ww(e);if(t){fs.error(t);return}fs.trace("ITC componentStatusRequestHandler received request:",e);let{internal:r}=(Rp(),M(Yw)),{getWorkerIndex:n}=nt(),{sendItcEvent:s}=ss(),i=r.componentStatusRegistry.getAllStatuses(),a=Array.from(i.entries()),c=n(),l=c===void 0,u=e.message.originator,d={type:gn.ITC_EVENT_TYPES.COMPONENT_STATUS_RESPONSE,message:{requestId:e.message.requestId,statuses:a,workerIndex:c,isMainThread:l}};u!==void 0&&threads.sendToThread(u,d)?fs.trace(`Sent component status response directly to thread ${u}`):(u===void 0?fs.debug("No originator threadId, falling back to broadcast"):fs.warn(`Failed to send direct response to thread ${u}, falling back to broadcast`),await s(d))}catch(t){fs.error("Error handling component status request:",t)}}o(Nie,"componentStatusRequestHandler");KH.exports=Aie});var ss=v((nMe,WH)=>{"use strict";var ZDe=Q(),zw=ae(),Cie=(q(),M(z)),{ITC_ERRORS:Ip}=zr(),{parentPort:eMe,threadId:Oie,isMainThread:Pie,workerData:tMe}=require("worker_threads"),{onMessageFromWorkers:Lie,broadcast:rMe,broadcastWithAcknowledgement:Die}=nt();WH.exports={sendItcEvent:Mie,validateEvent:YH,SchemaEventMsg:vie,UserEventMsg:Uie};var $g;Lie(async(e,t)=>{$g=$g||Ap(),YH(e),$g[e.type]&&await $g[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function Mie(e){return!Pie&&e.message&&(e.message.originator=Oie),Die(e)}o(Mie,"sendItcEvent");function YH(e){if(typeof e!="object")return Ip.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||zw.isEmpty(e.type))return Ip.MISSING_TYPE;if(!e.hasOwnProperty("message")||zw.isEmpty(e.message))return Ip.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||zw.isEmpty(e.message.originator))return Ip.MISSING_ORIGIN;if(Cie.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Ip.INVALID_EVENT(e.type)}o(YH,"validateEvent");function vie(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}o(vie,"SchemaEventMsg");function Uie(e){this.originator=e}o(Uie,"UserEventMsg")});var Ho=v((oMe,JH)=>{"use strict";var zH=(q(),M(z)),iMe=ae(),Vg=Q(),jH=Yx(),md,{sendItcEvent:QH}=ss();function xie(e){try{Vg.debug("signalSchemaChange called with message:",e),md=md||Ap();let t=new jH(zH.ITC_EVENT_TYPES.SCHEMA,e);return md.schema(t),QH(t)}catch(t){Vg.error(t)}}o(xie,"signalSchemaChange");function Bie(e){try{Vg.trace("signalUserChange called with message:",e),md=md||Ap();let t=new jH(zH.ITC_EVENT_TYPES.USER,e);return md.user(t),QH(t)}catch(t){Vg.error(t)}}o(Bie,"signalUserChange");JH.exports={signalSchemaChange:xie,signalUserChange:Bie}});function wp(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 XH(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new Fs(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 Fs,Np=se(()=>{Fs=class extends Map{static{o(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 a=i[1];if(n)r=(typeof a=="string"?a:a.join(", "))+", "+r;else if(typeof a=="string")r=[a,r];else{a.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};o(wp,"appendHeader");o(XH,"mergeHeaders")});function Kg(e,t,r=kie){let n;return function(...i){return n?n.length*jw>r?t(...i):new Promise((a,c)=>{n.push({args:i,fn(){try{let l=e(...i);a(l)}catch(l){c(l)}}})}):(n=[],s(performance.now(),i),e(...i))};function s(i,a){setImmediate(()=>{let c=performance.now();jw=(jw*4+c-i)/5;let l=n.shift();if(l){let{args:u,fn:d}=l;d(),s(c,u)}else n=null})}}var tG,Fie,kie,ZH,Hie,Qw,eG,jw,Jw=se(()=>{tG=b(Xn()),Fie=3e3,kie=2e4,ZH=0,Hie=3e4,Qw=3e3,eG=performance.now()+Qw,jw=0;o(Kg,"throttle");setInterval(()=>{let e=performance.now();e-eG-Qw>Fie&&ZH+Hie<e&&(tG.default.warn?.("JavaScript execution has taken too long and is not allowing proper event queue cycling, consider using 'await new Promise(setImmediate)' in code that will execute for a long duration"),ZH=e),eG=e},Qw).unref()});var fG={};Re(fG,{EVICTED:()=>ka,INVALIDATED:()=>vn,coerceType:()=>Wg,makeTable:()=>jg});function jg(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:a,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:f,splitSegments:m,replicate:p}=e,{expirationMS:h,evictionMS:E,audit:g,trackDeletes:R}=e;E??=0;let{attributes:S}=e;S||(S=[]);let y=wA(i,n,l),C,I,k={},J=Promise.resolve(),G,H,X;for(let K of S)(K.assignCreatedTime||K.name==="__createdtime__")&&(G=K),(K.assignUpdatedTime||K.name==="__updatedtime__")&&(H=K),K.expiresAt&&(X=K),K.isPrimaryKey&&(k=K);let W,ue=[],ce=[],te=1,ye=2,Ae={},Ye={},qe=864e5,Ar=0,tr,Wr,vr,_u=!1,Fc,xt,ri,Na=Nl.get(F.REPLICATION_DATABASES);if(Array.isArray(Na)){for(let K of Na)if(K.name===c&&K.replicateTo>=0){ri=K.replicateTo;break}}let GE=i.getRange({start:!1,end:!1}).constructor,jf=10,qE=6;g&&em(),Cm(i.env.path,K=>{if(I)return Oa(K)});class Qf extends ml{static{o(this,"Updatable")}getUpdatedTime(){return Ba.get(this.getRecord())?.version}getExpiresAt(){return Ba.get(this.getRecord())?.expiresAt}addTo(_,T){if(typeof T=="number"||typeof T=="bigint")this.set(_,new ap(T));else throw new Error("Can not add or subtract a non-numeric value")}subtractFrom(_,T){return this.addTo(_,-T)}}class Pe extends Hr{#e;#t;#r;#n;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=a;static databaseName=c;static attributes=S;static replicate=p;static sealed=f;static splitSegments=m??!0;static createdTimeProperty=G;static updatedTimeProperty=H;static propertyResolvers;static userResolvers={};static sources=[];static getResidencyById;static get expirationMS(){return h}static dbisDB=d;static schemaDefined=u;static sourcedFrom(_,T){if(T&&(this.sourceOptions=T,(T.expiration||T.eviction||T.scanInterval)&&this.setTTLExpiration(T)),T?.intermediateSource)_.intermediateSource=!0,this.sources.unshift(_);else{if(this.sources.some(L=>!L.intermediateSource)){if(this.sources.some(L=>L.name===_.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(_)}I=I||_.get&&(!_.get.reliesOnPrototype||_.prototype.get),C=C||_.load;let N=o(L=>{let A=this.sources;if(A=A.filter(U=>U.intermediateSource&&U[L]&&(!U[L].reliesOnPrototype||U.prototype[L])),A.length>0)if(A.length===1){let U=A[0];return(w,D,$)=>{if(w?.source!==U)return U[L](D,$,w)}}else return(U,w,D)=>{let $=[];for(let Y of A){if(U?.source===Y)break;$.push(Y[L](w,D,U))}return Promise.all($)}},"getApplyToIntermediateSource"),P=this.sources[this.sources.length-1];P.intermediateSource&&(P={});let O=o(L=>{if(P[L]&&(!P[L].reliesOnPrototype||P.prototype[L]))return(A,U,w)=>{if(!A?.source)return P[L](U,w,A)}},"getApplyToCanonicalSource");Ae={put:O("put"),patch:O("patch"),delete:O("delete"),publish:O("publish")},Ye={put:N("put"),patch:N("patch"),delete:N("delete"),publish:N("publish"),invalidate:N("invalidate")};let x=P.shouldRevalidateEvents;return(async()=>{let L=!1,A,U=o(async(w,D)=>{let $=w.value,Y=w.table?De[c][w.table]:Pe;if(c===im&&(w.table===bu.ROLE_TABLE_NAME||w.table===bu.USER_TABLE_NAME)&&(L=!0),w.id===void 0&&(w.id=$[Y.primaryKey],w.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(w));w.source=_;let j={residencyId:kc(w.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:w.nodeId,async:!0},B=w.id,Ee=await Y.getResource(B,D,j);switch(w.finished&&await w.finished,w.type){case"put":return x?Ee._writeInvalidate(B,$,j):Ee._writeUpdate(B,$,!0,j);case"patch":return x?Ee._writeInvalidate(B,$,j):Ee._writeUpdate(B,$,!1,j);case"delete":return Ee._writeDelete(B,j);case"publish":case"message":return Ee._writePublish(B,$,j);case"invalidate":return Ee._writeInvalidate(B,$,j);case"relocate":return Ee._writeRelocate(B,j);default:Fe.default.error?.("Unknown operation",w.type,w.id)}},"writeUpdate");try{let w=_.subscribe;w&&R==null&&(R=!0);let D={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},$=_.subscribeOnThisThread?_.subscribeOnThisThread((0,wl.getWorkerIndex)(),D):(0,wl.getWorkerIndex)()===0,Y=w&&$&&await _.subscribe?.(D);if(Y){let j;for await(let B of Y)try{if(!(B.type==="transaction"?B.writes[0]:B)){Fe.default.error?.("Bad subscription event",B);continue}if(B.source=_,B.type==="end_txn"){if(j?.resolve(),B.localTime&&A!==B.localTime){if(B.remoteNodeIds?.length>0){let pe=[Symbol.for("seq"),B.remoteNodeIds[0]],ne=d.get(pe),ie=ne?.nodes;ie||(ie=[]);for(let de of B.remoteNodeIds.slice(1)){let oe=ie.find(ke=>ke.id===de);ie=ie.filter(ke=>ke.id!==de||ke===oe),oe||(oe={id:de,seqId:0},ie.push(oe)),oe.seqId=Math.max(ne?.seqId??1,B.localTime),de===j?.nodeId&&(oe.lastTxnTime=B.timestamp)}let xe=Math.max(ne?.seqId??1,B.localTime);Fe.default.trace?.("Received txn",c,xe,new Date(xe),B.localTime,new Date(B.localTime),B.remoteNodeIds),d.put(pe,{seqId:xe,nodes:ie})}A=B.localTime}B.onCommit&&j?.committed.then(B.onCommit);continue}if(j)if(B.beginTxn)j.resolve();else{j.write_promises.push(U(B,j));continue}!B.timestamp&&B.version&&(B.timestamp=B.version);let fe=bt(B,()=>{if(B.type==="transaction"){let pe=[];for(let ne of B.writes)try{pe.push(U(ne,B))}catch(ie){throw ie.message+=" writing "+JSON.stringify(ne)+" of event "+JSON.stringify(B),ie}return Promise.all(pe)}else if(B.type==="define_schema"){let pe=this.attributes.slice(0),ne=!1;for(let ie of B.attributes)pe.find(xe=>xe.name===ie.name)||(pe.push(ie),ne=!0);ne&&(Ze({table:s,database:c,attributes:pe,origin:"cluster"}),Op.signalSchemaChange(new Pp.SchemaEventMsg(process.pid,V.CREATE_TABLE,c,s)))}else return B.beginTxn?(j=B,j.write_promises=[U(B,B)],new Promise(pe=>{j.resolve=()=>pe(Promise.all(j.write_promises))})):U(B,B)});j&&(j.committed=fe),L&&fe&&!fe?.waitingForUserChange&&(fe.then(()=>Op.signalUserChange(new Pp.UserEventMsg(process.pid))),fe.waitingForUserChange=!0),B.onCommit&&(fe?fe.then(B.onCommit):B.onCommit())}catch(Ee){Fe.default.error?.("error in subscription handler",Ee)}}}catch(w){Fe.default.error?.(w)}})(),this}static get isCaching(){return I}static get shouldRevalidateEvents(){return this.prototype.get!==Pe.prototype.get}static getResource(_,T,N){let P=super.getResource(_,T,N);if(this.loadAsInstance===!1&&(T._freezeRecords=!0),_!=null&&this.loadAsInstance!==!1){Ui(_);try{if(P.getRecord?.())return P;if(typeof _=="object"&&_&&!Array.isArray(_))throw new Error(`Invalid id ${JSON.stringify(_)}`);let O=!N?.async||i.cache?.get?.(_),x=Ur(T),L=x.getReadTxn();if(L?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Io(_,T,{transaction:L,ensureLoaded:N?.ensureLoaded},O,A=>{if(A?Pe._updateResource(P,A):P.#e=null,T.onlyIfCached){if(!P.doesExist())throw new lt.ServerError("Entry is not cached",504)}else if(N?.ensureLoaded){let U=dn(_,A,T,P);if(U)return x?.disregardReadTxn(),P.#i=!0,T.loadedFromSource=!0,ks(U,w=>(Pe._updateResource(P,w),P))}return P})}catch(O){throw O.message.includes("Unable to serialize object")&&(O.message+=": "+JSON.stringify(_)),O}}return P}static _updateResource(_,T){_.#n=T,_.#e=T?.value??null,_.#r=T?.version}ensureLoaded(){let _=dn(this.getId(),this.#n,this.getContext());if(_)return this.#i=!0,this.getContext().loadedFromSource=!0,ks(_,T=>{this.#n=T,this.#e=T.value,this.#r=T.version})}static getNewId(){let _=k?.type;if(_==="String"||_==="ID")return super.getNewId();if(!xt){let O=i.getEntry(Symbol.for("id_allocation")),x=O?.value,L;if(x&&x.nodeName===server.hostname&&(!Xie(i)||x.pid===process.pid)){let A=x.start,U=x.end;L=A;for(let w of i.getKeys({start:U,end:A,limit:1,reverse:!0}))L=w}else x=P(O?.version??null),L=x.start;xt=new BigInt64Array([BigInt(L)+1n]),xt=new BigInt64Array(i.getUserSharedBuffer("id",xt.buffer)),xt.maxSafeId=x.end}let T=Number(Atomics.add(xt,0,1n)),N=_==="Int"?512:1048576;if(T+N>=xt.maxSafeId){let O=o(x=>{xt.maxSafeId=T+(_==="Int"?1023:4194303);let L=(_==="Int"?Math.pow(2,31):Math.pow(2,49))-1,A=x?void 0:i.useReadTransaction(),U=Number(xt[0]);for(let $ of i.getKeys({start:U+1,end:L,limit:1,transaction:A}))L=$;A?.done();let{value:w,version:D}=i.getEntry(Symbol.for("id_allocation"));if(xt.maxSafeId<L){if(w.end>xt.maxSafeId-100)return;Fe.default.info?.("New id allocation",T,xt.maxSafeId,D),i.put(Symbol.for("id_allocation"),{start:w.start,end:xt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),D)}else{Fe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${xt.maxSafeId}, but id of ${L} detected`);let $=P(D);$.alreadyUpdated||Atomics.store(xt,0,BigInt($.start+1)),xt.maxSafeId=$.end}},"updateEnd");T+N===xt.maxSafeId?setImmediate(O):T+100>=xt.maxSafeId&&(Fe.default.warn?.(`Synchronous id allocation required on table ${s}${_=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>O(!0)))}return T;function P(O){let x=(_==="Int"?Math.pow(2,31):Math.pow(2,49))-1,L=x/4,A,U,w=!1,D,$;do{D=Math.floor(Math.random()*x),$={start:D,end:D+(_==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},A=0;for(let Y of i.getKeys({start:D,limit:1,reverse:!0}))A=Y;U=x;for(let Y of i.getKeys({start:D+1,end:x,limit:1}))U=Y;L*=.875,L<1e3&&!w&&(w=!0,Fe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${_==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,D,A,U,L))}while(!(L<U-D&&(L<D-A||A===0)));return i.transactionSync(()=>{let Y=i.getEntry(Symbol.for("id_allocation"));return(Y?.version??null)==O?(Fe.default.info?.("Allocated new id range",$),i.put(Symbol.for("id_allocation"),$,Date.now()),$):(Fe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...Y.value})})}}static setTTLExpiration(_){if(typeof _=="number")h=_*1e3,E||(E=0);else if(_&&typeof _=="object")h=_.expiration*1e3,E=(_.eviction||0)*1e3,qe=_.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");qe=qe||(h+E)/4,Oa()}static getResidencyRecord(_){return d.get([Symbol.for("residency_by_id"),_])}static setResidency(_){Pe.getResidency=_&&((T,N)=>{try{return _(T,N)}catch(P){throw P.message+=` in residency function for table ${s}`,P}})}static setResidencyById(_){Pe.getResidencyById=_&&(T=>{try{return _(T)}catch(N){throw N.message+=` in residency function for table ${s}`,N}})}static getResidency(_,T){if(Pe.getResidencyById)return Pe.getResidencyById(_[t]);let N=ri;if(T.replicateTo!=null){if(Array.isArray(T.replicateTo))return T.replicateTo.includes(server.hostname)?T.replicateTo:[server.hostname,...T.replicateTo];T.replicateTo>=0&&(N=T.replicateTo)}if(N>=0&&server.nodes){let P=[server.hostname];if(T.previousResidency)P.push(...T.previousResidency.slice(0,N));else{let O=server.nodes.map(A=>A.name),x=Math.floor(O.length*Math.random());P.push(...O.slice(x,x+N));let L=x+N-O.length;L>0&&P.push(...O.slice(0,L))}return P}}static enableAuditing(){g||(g=!0,em(),Pe.audit=!0)}static coerceId(_){return _===""?null:Wg(_,k)}static async dropTable(){delete De[c][s];for(let _ of i.getRange({versions:!0,snapshot:!1,lazy:!0}))_.metadataFlags&Jr&&_.value&&va(_.value);if(c===a){for(let _ of S)d.remove(Pe.tableName+"/"+_.name),r[_.name]?.drop();d.remove(Pe.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),Zw.default.unlinkSync(i.env.path);Op.signalSchemaChange(new Pp.SchemaEventMsg(process.pid,V.DROP_TABLE,c,s))}get(_){let T=this.constructor;if(typeof _=="string"&&T.loadAsInstance!==!1)return this.getProperty(_);if(Jf(_))return this.search(_);if(_&&_.id===void 0&&!_.toString()){let N={records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:S,recordCount:void 0,estimatedRecordRange:void 0};return this.getContext()?.includeExpensiveRecordCountEstimates?Pe.getRecordCount().then(P=>(N.recordCount=P.recordCount,N.estimatedRecordRange=P.estimatedRange,N)):N}if(_!==void 0&&T.loadAsInstance===!1){let N=this.getContext(),P=Ur(N),O=P.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");let x=Os(_);Ui(x);let L=!0;return _.checkPermission&&(L=this.allowRead(N.user,_)),ks(ks(L,A=>{if(!A)throw new lt.AccessViolation(N.user);let U=!0;return Io(x,N,{transaction:O,ensureLoaded:U},!1,w=>{if(N.onlyIfCached){if(!w?.value)throw new lt.ServerError("Entry is not cached",504)}else if(U){let D=dn(x,w,N);if(D)return P?.disregardReadTxn(),N.loadedFromSource=!0,D.then($=>$?.value)}return w?.value})}),A=>{let U=_?.select;return U&&A!=null?Vu(U,this.constructor)(A):A})}if(_?.property)return this.getProperty(_.property);if(this.doesExist()||_?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(_,T){let N=On(_,T);if(N?.read){if(N.isSuperUser)return!0;let P=N.attribute_permissions,O=T?.select;if(P?.length>0||_u&&O){if(T||(T={}),O){let x=P?.length>0&&Xw(P,"read");T.select=O.map(L=>{let A=L.name||L;if(!x||x[A]){let U=vr[A]?.definition?.tableClass;if(U){if(L.name||(L={name:L}),!L.checkPermission&&T.checkPermission&&(L.checkPermission=T.checkPermission),!U.prototype.allowRead.call(null,_,L))return!1;if(!L.select)return L.name}return L}}).filter(Boolean)}else T.select=P.filter(x=>x.read&&!vr[x.attribute_name]).map(x=>x.attribute_name);return T}else return!0}}allowUpdate(_,T,N){let P=On(_,N);if(P?.update){let O=P.attribute_permissions;if(O?.length>0){let x=Xw(O,"update");for(let L in T)if(!x[L])return!1;for(let L of O){let A=L.attribute_name;!L.update&&!(A in T)&&(T[A]=this.getProperty(A))}}return Ca(this.getContext())}}allowCreate(_,T,N){if(this.isCollection){let P=On(_,N);if(P?.insert){let O=P.attribute_permissions;if(O?.length>0){let x=Xw(O,"insert");for(let L in T)if(!x[L])return!1;return Ca(this.getContext())}else return Ca(this.getContext())}}else return this.allowUpdate(_,{})}allowDelete(_,T){return On(_,T)?.delete&&Ca(this.getContext())}update(_,T){let N,P=typeof T=="boolean"||T===void 0&&(_==null||typeof _=="object"&&!(_ instanceof URLSearchParams)),O=!1;P?(O=T,T=_,N=this.getId()):N=Os(_);let x=this.getContext();if(!Ur(x))throw new Error("Can not update a table resource outside of a transaction");if(T===!1)return this;if(typeof T=="object"&&T)if(O)Object.isFrozen(T)&&(T={...T}),this.#e={},this.#t=T;else if(P){let A=this.#t;A&&(T=Object.assign(A,T)),this.#t=T}else{let A=!0;if(_==null)throw new TypeError("Can not put a record without a target");return _.checkPermission&&(A=this.allowUpdate(x.user,T,_)),ks(A,U=>{if(!U)throw new lt.AccessViolation(x.user);return ks(i.get(Os(_)),w=>{let D=new Qf(w);return D._setChanges(T),this._writeUpdate(N,D.getChanges(),!1),D})})}return this._writeUpdate(N,this.#t,O),this}addTo(_,T){if(typeof T=="number"||typeof T=="bigint")this.#s===nG?this.set(_,(+this.getProperty(_)||0)+T):(this.#s||this.update(),this.set(_,new ap(T)));else throw new Error("Can not add a non-numeric value")}subtractFrom(_,T){if(typeof T=="number")return this.addTo(_,-T);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#n}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(_){this.#t=_}setRecord(_){this.#e=_}invalidate(_){let T=!0,N=this.getContext();return _?.checkPermission&&(T=this.allowDelete(N.user,_,N)),ks(T,P=>{if(!P)throw new lt.AccessViolation(N.user);this._writeInvalidate(_?Os(_):this.getId())})}_writeInvalidate(_,T,N){let P=this.getContext();Ui(_),Ur(this.getContext()).addWrite({key:_,store:i,invalidated:!0,entry:this.#n,before:Ae.invalidate?.bind(this,P,_),beforeIntermediate:yu(T,Ye.invalidate?.bind(this,P,_)),commit:o((x,L)=>{if(!(xr(x,L,N?.nodeId)<=0)){T??=null;for(let A in r)T||(T={}),T[A]===void 0&&(T[A]=this.getProperty(A));Fe.default.trace?.(`Invalidating entry in ${s} id: ${_}, timestamp: ${new Date(x).toISOString()}`),y(_,T,L,x,vn,g,{user:P?.user,residencyId:N?.residencyId,nodeId:N?.nodeId,tableToTrack:s},"invalidate")}},"commit")})}_writeRelocate(_,T){let N=this.getContext();Ui(_),Ur(this.getContext()).addWrite({key:_,store:i,invalidated:!0,entry:this.#n,before:Ae.relocate?.bind(this,N,_),beforeIntermediate:Ye.relocate?.bind(this,N,_),commit:o((O,x)=>{if(xr(O,x,T?.nodeId)<=0)return;let L=Pe.getResidencyRecord(T.residencyId),A=0,U=null,w=x?.value;if(L&&!L.includes(server.hostname)){for(let D in r)U||(U={}),U[D]=w[D];A=vn}else U=w;Fe.default.trace?.(`Relocating entry id: ${_}, timestamp: ${new Date(O).toISOString()}`),y(_,U,x,O,A,g,{user:N.user,residencyId:T.residencyId,nodeId:T.nodeId,expiresAt:T.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(_,T){let N={previousResidency:this.getResidencyRecord(_.residencyId),isRelocation:!0},P=Pa(this.getResidency(T.value,N)),O;if(P){if(!P.includes(server.hostname))return!1;O=kc(P)}let x=0;Fe.default.debug?.("Performing a relocate of an entry",existing_entry.key,T.value,P);let L=y(_.key,T.value,_,_.version,x,!0,{residencyId:O,expiresAt:T.expiresAt},"relocate",!1,null);return!0}static evict(_,T,N){let P=this.Source,O;if(!((I||g)&&(!T||(O=i.getEntry(_),!O||!T)||O.version!==N))){if(I){if(i.hasLock(_,O.version))return;let x;for(let L in r)x||(x={}),x[L]=T[L];if(x)return y(_,x,O,N,ka,null,null,null,!0)}if(i.ifVersion(_,N,()=>{gu(_,T,null)}),g)return y(_,null,O,N,ka,null,null,null,!0);nl(i,O??i.getEntry(_),N)}}lock(){throw new Error("Not yet implemented")}static operation(_,T){return _.table||=s,_.schema||=c,global.operation(_,T)}put(_,T){if(T===void 0||T instanceof URLSearchParams)this.update(_,!0);else{let N=!0;if(_==null)throw new TypeError("Can not put a record without a target");let P=this.getContext();return _.checkPermission&&(N=this.allowUpdate(P.user,T,_)),ks(N,O=>{if(!O)throw new lt.AccessViolation(P.user);if(Array.isArray(T))for(let x of T){let L=x[t];this._writeUpdate(L,x,!0)}else{let x=Os(_);this._writeUpdate(x,T,!0)}})}}create(_,T){let N=!0,P=this.getContext();if(!T&&!(_ instanceof URLSearchParams)&&(T=_,_=void 0),!T||typeof T!="object"||Array.isArray(T))throw new TypeError("Can not create a record without an object");return _?.checkPermission&&(N=this.allowCreate(P.user,T,_)),ks(N,O=>{if(!O)throw new lt.AccessViolation(P.user);let x=Os(_)??T[t];if(x===void 0)x=this.constructor.getNewId();else if(i.get(x))throw new lt.ClientError("Record already exists",409);return this._writeUpdate(x,T,!0),T})}patch(_,T){if(T===void 0||T instanceof URLSearchParams)this.update(_,!1);else{let N=this.update(_,T);if(N?.then)return N.then(()=>{})}}_writeUpdate(_,T,N,P){let O=this.getContext(),x=Ur(O);Ui(_);let L=this.#n??i.getEntry(_);this.#s=N?nG:zie;let A=o(w=>N?w.put?()=>w.put(O,_,T):null:w.patch?()=>w.patch(O,_,T):w.put?()=>w.put(O,_,pl(this)):null,"writeToSources"),U={key:_,store:i,entry:L,nodeName:O?.nodeName,validate:o(w=>{T||(T=this.#t),N||T&&yg(this.#t===T?this:T)?O?.source||(x.checkOverloaded(),this.validate(T,!N),H&&(T[H.name]=H.type==="Date"?new Date(w):H.type==="String"?new Date(w).toISOString():w),N&&(t&&T[t]!==_&&(T[t]=_),G&&(L?.value?T[G.name]=L?.value[G.name]:T[G.name]=G.type==="Date"?new Date(w):G.type==="String"?new Date(w).toISOString():w),T=pl(T))):x.removeWrite(U)},"validate"),before:A(Ae),beforeIntermediate:yu(T,A(Ye)),commit:o((w,D,$)=>{if($){if(O&&D?.version>(O.lastModified||0)&&(O.lastModified=D.version),this.#n=D,D?.value&&D.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");N||(this.#e=D?.value??null)}this.#t=void 0,this.#r=w;let Y=D?.value,j;this.#s=0;let B=!1,Ee=xr(w,D,P?.nodeId),fe;if(Ee<=0){if(g){let de=D.localTime,oe=D.version;Fe.default.trace?.("Applying CRDT update to record with id: ",_,"txn time",new Date(w),"applying later update from:",new Date(oe),"local recorded time",new Date(de));let ke=[];for(;de>w||oe>=w&&de>0;){let Be=l.get(de);if(!Be)break;let Le=At(Be);if(oe=Le.version,oe>=w){if(oe===w){if(Ee=xr(w,{version:oe,localTime:de},P?.nodeId),Ee===0)return;if(Ee>0)continue}if(Le.type==="patch")ke.push(Le),fe=T;else if(Le.type==="put"||Le.type==="delete")return}de=Le.previousLocalTime}de||Fe.default.debug?.("No further audit history, applying incremental updates based on available history",_,"existing version preserved",D),ke.sort((Be,Le)=>Be.version-Le.version);for(let Be of ke){let Le=Be.getValue(i);if(Fe.default.debug?.("Rebuilding update with future patch:",new Date(Be.version),Le,Be),j=f_(j??T,Le,N),!j)return}}else{if(N)return;j=f_(j??T,Y,N),Fe.default.debug?.("Rebuilding update without audit:",j)}Fe.default.trace?.("Rebuilt record to save:",j," is full update:",N)}let pe;if(N&&!j?pe=T:this.constructor.loadAsInstance===!1?pe=pl(Y,j??T):(this.#e=Y,pe=pl(this,j??T)),this.#e=pe,pe&&pe.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let ne;if(P?.residencyId!=null)ne=P.residencyId;else{L?.residencyId&&(O.previousResidency=Pe.getResidencyRecord(L.residencyId));let de=Pa(Pe.getResidency(pe,O));if(de&&!de.includes(server.hostname))if(fe??=pe,B=!0,Pe.getResidencyById)pe=void 0;else{pe=null;for(let oe in r)pe||(pe={}),pe[oe]=fe[oe]}ne=kc(de)}N||(fe=T);let ie=O?.expiresAt??(h?h+Date.now():-1);Fe.default.trace?.(`Saving record with id: ${_}, timestamp: ${new Date(w).toISOString()}${ie?", expires at: "+new Date(ie).toISOString():""}${D?", replaces entry from: "+new Date(D.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(pe).slice(0,100)}catch{return""}})()),gu(_,Y,pe);let xe=N?"put":"patch";y(_,pe,D,w,B?vn:0,g,{omitLocalRecord:B,user:O?.user,residencyId:ne,expiresAt:ie,nodeId:P?.nodeId,originatingOperation:O?.originatingOperation,tableToTrack:c==="system"?null:s},xe,!1,fe),O.expiresAt&&Oa()},"commit")};x.addWrite(U)}async delete(_){if(Jf(_)){_.select=["$id"];for await(let T of this.search(_))this._writeDelete(T.$id);return!0}if(_){let T=!0,N=this.getContext();return _.checkPermission&&(T=this.allowDelete(N.user,_,N)),ks(T,P=>{if(!P)throw new lt.AccessViolation(N.user);let O=Os(_);return this._writeDelete(O),!0})}return this._writeDelete(this.getId()),!!this.#e}_writeDelete(_,T){let N=Ur(this.getContext());Ui(_);let P=this.getContext();return N.addWrite({key:_,store:i,entry:this.#n,nodeName:P?.nodeName,before:Ae.delete?.bind(this,P,_),beforeIntermediate:Ye.delete?.bind(this,P,_),commit:o((O,x,L)=>{let A=x?.value;L&&(P&&x?.version>(P.lastModified||0)&&(P.lastModified=x.version),Pe._updateResource(this,x)),!(xr(O,x,T?.nodeId)<=0)&&(gu(this.getId(),A),Fe.default.trace?.(`Deleting record with id: ${_}, txn timestamp: ${new Date(O).toISOString()}`),g||R?(y(_,null,x,O,0,g,{user:P?.user,nodeId:T?.nodeId,tableToTrack:s},"delete"),g||Oa()):nl(i,x))},"commit")}),!0}search(_){let T=this.getContext(),N=Ur(T);if(!_)throw new Error("No query provided");if(_.parseError)throw _.parseError;if(_.checkPermission&&!this.allowRead(T.user,_))throw new lt.AccessViolation(T.user);T&&(T.lastModified=Vie);let P=_.conditions;P?P.length===void 0&&(P=P[Symbol.iterator]?Array.from(P):[P]):P=Array.isArray(_)?_:_[Symbol.iterator]?Array.from(_):[];let O=_.id??this.getId();O&&(P=[{attribute:null,comparator:Array.isArray(O)?"prefix":"starts_with",value:O}].concat(P));let x,L={};function A(ie,xe){let de;switch(xe){case"and":case void 0:if(ie.length<1)throw new Error('An "and" operator requires at least one condition');de=!0;break;case"or":if(ie.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+xe)}for(let oe of ie){if(oe.conditions){oe.conditions=A(oe.conditions,oe.operator);continue}let ke=oe[0]??oe.attribute,Be=ke==null?k:qi(S,ke);if(Be)(Be.type||CA[oe.comparator])&&(oe[1]===void 0?oe.value=w(oe.value,Be):oe[1]=w(oe[1],Be));else if(ke!=null)throw(0,lt.handleHDBError)(new Error,`${ke} is not a defined attribute`,404);if(oe.chainedConditions)if(oe.chainedConditions.length===1&&(!oe.operator||oe.operator=="and")){let Le=oe.chainedConditions[0],Me,pt;if(Le.comparator==="gt"||Le.comparator==="greater_than"||Le.comparator==="ge"||Le.comparator==="greater_than_equal"?(Me=oe,pt=Le):(Me=Le,pt=oe),Me.comparator!=="lt"&&Me.comparator!=="less_than"&&Me.comparator!=="le"&&Me.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let wt=pt.comparator==="ge"||pt.comparator==="greater_than_equal",Et=Me.comparator==="le"||Me.comparator==="less_than_equal";oe.comparator=(wt?"ge":"gt")+(Et?"le":"lt"),oe.value=[pt.value,Me.value]}else throw new Error("Multiple chained conditions are not currently supported")}return ie}o(A,"prepareConditions");function U(ie,xe){if(_.enforceExecutionOrder)return ie;for(let de of ie)de.conditions&&(de.conditions=U(de.conditions,de.operator));return ie.length>1&&xe!=="or"?Gie(ie,Q_(Pe)):ie}o(U,"orderConditions");function w(ie,xe){return Array.isArray(ie)?ie.map(de=>Wg(de,xe)):Wg(ie,xe)}o(w,"coerceTypedValues");let D=_.operator;(P.length>0||D)&&(P=A(P,D));let $=typeof _.sort=="object"&&_.sort,Y;if($&&D!=="or"){let ie=$.attribute;if(ie==null)throw new lt.ClientError("Sort requires an attribute");if(x=P.find(xe=>Gu(xe.attribute)===Gu(ie)),!x){let xe=qi(S,ie);if(!xe)throw(0,lt.handleHDBError)(new Error,`${Array.isArray(ie)?ie.join("."):ie} is not a defined attribute`,404);if(xe.indexed)x={...$,comparator:"sort"},P.push(x);else if(P.length===0&&!_.allowFullScan)throw(0,lt.handleHDBError)(new Error,`${Array.isArray(ie)?ie.join("."):ie} is not indexed and not combined with any other conditions`,404)}x&&(x.descending=!!$.descending)}P=U(P,D),$&&(x&&P[0]===x?$.next&&(Y={dbOrderedAttribute:$.attribute,attribute:$.next.attribute,descending:$.next.descending,next:$.next.next}):(x&&P.splice(P.indexOf(x),1),Y=$));let j=_.select;if(P.length===0&&(P=[{attribute:t,comparator:"greater_than",value:!0}]),_.explain)return{conditions:P,operator:D,postOrdering:Y,selectApplied:!!j};let B=N.useReadTxn(),Ee=OA(P,D,Pe,B,_,T,(ie,xe)=>Zf(ie,j,T,B,xe),L),fe=_.ensureLoaded!==!1,pe=Pe.transformEntryForSelect(j,T,B,L,fe,!0),ne=Pe.transformToOrderedSelect(Ee,j,Y,T,B,pe);return(_.offset||_.limit!==void 0)&&(ne=ne.slice(_.offset,_.limit!==void 0?(_.offset||0)+_.limit:void 0)),ne.onDone=()=>{ne.onDone=null,N.doneReadTxn()},ne.selectApplied=!0,ne.getColumns=()=>{if(j){let ie=[];for(let xe of j)xe==="*"?ie.push(...S.map(de=>de.name)):ie.push(xe.name||xe);return ie}return S.filter(ie=>!ie.computed&&!ie.relationship).map(ie=>ie.name)},ne}static transformToOrderedSelect(_,T,N,P,O,x){let L=new GE;if(N){_=Zf(_,T,P,O,null);let A;L.iterate=function(){let w,D=_[Symbol.asyncIterator]?_[Symbol.asyncIterator]():_[Symbol.iterator](),$,Y=N.dbOrderedAttribute,j,B,Ee=!0;function fe(ne){let ie=ne.next&&fe(ne.next),xe=ne.descending;return P.sort=ne,(de,oe)=>{let ke=Su(de,ne.attribute,P),Be=Su(oe,ne.attribute,P),Le=xe?(0,Cl.compareKeys)(Be,ke):(0,Cl.compareKeys)(ke,Be);return Le===0?ie?.(de,oe)||0:Le}}o(fe,"createComparator");let pe=fe(N);return{async next(){let ne;if(w)if(ne=w.next(),ne.done){if($)return L.onDone&&L.onDone(),ne}else return{value:await x.call(this,ne.value)};A=[],j&&A.push(j);do if(ne=await D.next(),ne.done){if($=!0,A.length)break;return L.onDone&&L.onDone(),ne}else{let ie=ne.value;if(ie?.then&&(ie=await ie),Y){let xe=Su(ie,Y,P);if(Ee)Ee=!1,B=xe;else if(xe!==B){B=xe,j=ie;break}}A.push(ie)}while(!0);return N.isGrouped,A.sort(pe),w=A[Symbol.iterator](),ne=w.next(),ne.done?(L.onDone&&L.onDone(),ne):{value:await x.call(this,ne.value)}},return(){return L.onDone&&L.onDone(),D.return()},throw(){return L.onDone&&L.onDone(),D.throw()}}};let U=o(w=>{if(typeof T=="object"&&Array.isArray(w.attribute))for(let D=0;D<T.length;D++){let $=T[D],Y;if($.name===w.attribute[0]){for(Y=$.sort||($.sort={});Y.next;)Y=Y.next;Y.attribute=w.attribute.slice(1),Y.descending=w.descending}else $===w.attribute[0]&&(T[D]=Y={name:$,sort:{attribute:w.attribute.slice(1),descending:w.descending}})}w.next&&U(w.next)},"applySortingOnSelect");U(N)}else L.iterate=(_[Symbol.asyncIterator]||_[Symbol.iterator]).bind(_),L=L.map(function(A){try{let U=x.call(this,A);return typeof U?.catch=="function"?U.catch(w=>{throw w.partialObject={[t]:A.key},w}):U}catch(U){throw U.partialObject={[t]:A.key},U}});return L}static transformEntryForSelect(_,T,N,P,O,x){let L;O&&I&&!(typeof _=="string"?[_]:_)?.every(w=>{let D;return typeof w=="object"?D=w.name:D=w,r[D]||D===t})&&(L=!0);let A,U=o(function(w){let D;if(T?.transaction?.stale&&(T.transaction.stale=!1),w!=null){if(D=w.deref?w.deref():w.value,!D&&(w.key===void 0||w.deref)||w.metadataFlags&vn){if(w.metadataFlags&vn&&T.replicateFrom===!1&&x&&w.residencyId)return ec.SKIP;if(w=Io(w.key??w,T,{transaction:N,lazy:_?.length<4,ensureLoaded:O},this?.isSync,$=>$),w?.then)return w.then(U.bind(this));D=w?.value}if(L&&w?.metadataFlags&(vn|ka)||w?.expiresAt!=null&&w?.expiresAt<Date.now()){if(T.onlyIfCached)return{[t]:w.key,message:"This entry has expired"};let $=dn(w.key??w,w,T);if($?.then)return $.then(U)}}if(D==null)return x?ec.SKIP:D;if(_&&!(_[0]==="*"&&_.length===1)){let $,Y=o((B,Ee)=>{let fe;typeof B=="object"?fe=B.name:fe=B;let pe=vr?.[fe],ne;if(pe){let ie=P?.[fe];if(ie)if(ie.hasMappings){let de=pe.from?D[pe.from]:Gu(w.key);ne=ie.get(de),ne||(ne=[])}else ne=ie.fromRecord?.(D);else ne=pe(D,T,w,!0);let xe=o(de=>{if(pe.directReturn)return Ee(de,fe);if(de&&typeof de=="object"){let oe=pe.definition?.tableClass||Pe;A||(A={});let ke=A[fe]||(A[fe]=oe.transformEntryForSelect(fe===B?null:B.select||(Array.isArray(B)?B:null),T,N,ie,O));if(Array.isArray(de)){let Be=[],Le=oe.transformToOrderedSelect(de,B.select,typeof B.sort=="object"&&B.sort,T,N,ke)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Me=o(wt=>{for(;!wt.done;){if(wt?.then)return wt.then(Me);Be.push(wt.value),wt=Le.next()}Ee(Be,fe)},"nextValue"),pt=Me(Le.next());pt&&($||($=[]),$.push(pt));return}else if(de=ke.call(this,de),de?.then){$||($=[]),$.push(de.then(Be=>Ee(Be,fe)));return}}Ee(de,fe)},"handleResolvedValue");ne?.then?($||($=[]),$.push(ne.then(xe))):xe(ne);return}else ne=D[fe],ne&&typeof ne=="object"&&fe!==B&&(ne=Pe.transformEntryForSelect(B.select||B,T,N,null)({value:ne}));Ee(ne,fe)},"selectAttribute"),j;if(typeof _=="string")Y(_,B=>{j=B});else if(Array.isArray(_))if(_.asArray)j=[],_.forEach((B,Ee)=>{B==="*"?_[Ee]=D:Y(B,fe=>j[Ee]=fe)});else{j={};let B=_.forceNulls;for(let Ee of _)if(Ee==="*")for(let fe in D)j[fe]=D[fe];else Y(Ee,(fe,pe)=>{fe===void 0&&B&&(fe=null),j[pe]=fe})}else throw new lt.ClientError("Invalid select"+_);return $?Promise.all($).then(()=>j):j}return D},"transform");return U}async subscribe(_){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||Ze({table:s,database:c,schemaDefined:u,attributes:S,audit:!0}),_||(_={});let T=!_.rawEvents,N=[],P=xA(Pe,this.getId()??null,function(L,A,U,w){try{let D=A.getValue?.(i,T),$=A.type;if(!D&&$==="patch"&&T){let j=i.getEntry(L);j?.version===A.version?D=j.value:D=A.getValue?.(i,!0,U),$="put"}let Y={id:L,localTime:U,value:D,version:A.version,type:$,beginTxn:w};N?N.push(Y):(c!=="system"&&Ve(A.size??1,"db-message",s,null),this.send(Y))}catch(D){Fe.default.error?.(D)}},_.startTime||0,_),O=(async()=>{this.isCollection&&(P.includeDescendants=!0,_.onlyChildren&&(P.onlyChildren=!0)),_.supportsTransactions&&(P.supportsTransactions=!0);let L=this.getId(),A=_.previousCount;A>1e3&&(A=1e3);let U=_.startTime;if(this.isCollection){if(U){if(A)throw new lt.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:w,value:D}of l.getRange({start:U,exclusiveStart:!0,snapshot:!1})){let $=At(D);if($.tableId!==n)continue;let Y=$.recordId;if(L==null||aG(L,Y)){let j=$.getValue(i,T,w);if(x({id:Y,localTime:w,value:j,version:$.version,type:$.type,size:$.size}),P.queue?.length>iG&&await P.waitForDrain()===!1)return}P.startTime=w}}else if(A){let w=[];for(let{key:D,value:$}of l.getRange({start:"z",end:!1,reverse:!0}))try{let Y=At($);if(Y.tableId!==n)continue;let j=Y.recordId;if(L==null||aG(L,j)){let B=Y.getValue(i,T,D);if(w.push({id:j,localTime:D,value:B,version:Y.version,type:Y.type}),--A<=0)break}}catch(Y){Fe.default.error("Error getting history entry",D,Y)}for(let D=w.length;D>0;)x(w[--D]);w[0]&&(P.startTime=w[0].localTime)}else if(!_.omitCurrent){for(let{key:w,value:D,version:$,localTime:Y,size:j}of i.getRange({start:L??!1,end:L==null?void 0:[L,Cl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(D&&(x({id:w,localTime:Y,value:D,version:$,type:"put",size:j}),P.queue?.length>iG&&await P.waitForDrain()===!1))return}}else{A&&!U&&(U=0);let w=this.#n?.localTime;if(w===IA&&(i.cache?.delete(L),this.#n=i.getEntry(L),Fe.default.trace?.("re-retrieved record",w,this.#n?.localTime),w=this.#n?.localTime),Fe.default.trace?.("Subscription from",U,"from",L,w),U<w){let D=[],$=w;do{let Y=l.get($);if(Y){_.omitCurrent=!0;let j=At(Y),B=j.getValue(i,T,$);T&&(j.type="put"),D.push({id:L,value:B,localTime:$,...j}),$=j.previousLocalTime}else break;A&&A--}while($>U&&A!==0);for(let Y=D.length;Y>0;)x(D[--Y]);P.startTime=w}!_.omitCurrent&&this.doesExist()&&x({id:L,localTime:w,value:this.#e,version:this.#r,type:"put"})}for(let w of N)x(w);N=null})();function x(L){c!=="system"&&Ve(L.size??1,"db-message",s,null),P.send(L)}return o(x,"send"),_.listener&&P.on("data",_.listener),P}static subscribeOnThisThread(_,T){return _===0||T?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(_,T,N){if(T===void 0||T instanceof URLSearchParams)this._writePublish(this.getId(),_,T);else{let P=!0,O=this.getContext();return _.checkPermission&&(P=this.allowCreate(O.user,_,O)),ks(P,x=>{if(!x)throw new lt.AccessViolation(O.user);let L=Os(_);this._writePublish(L,T,N)})}}_writePublish(_,T,N){let P=Ur(this.getContext());_??=null,_!==null&&Ui(_);let O=this.getContext();P.addWrite({key:_,store:i,entry:this.#n,nodeName:O?.nodeName,validate:o(()=>{O?.source||(P.checkOverloaded(),this.validate(T))},"validate"),before:Ae.publish?.bind(this,O,_,T),beforeIntermediate:yu(T,Ye.publish?.bind(this,O,_,T)),commit:o((x,L,A)=>{L===void 0&&R&&!g&&Oa(),Fe.default.trace?.(`Publishing message to id: ${_}, timestamp: ${new Date(x).toISOString()}`),y(_,L?.value??null,L,L?.version||x,0,!0,{user:O?.user,residencyId:N?.residencyId,expiresAt:O?.expiresAt,nodeId:N?.nodeId,tableToTrack:s},"message",!1,T)},"commit")})}validate(_,T){let N,P=o((O,x,L)=>{if(x.type&&O!=null)if(T&&O.__op__&&(O=O.value),x.properties){typeof O!="object"&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be an object${x.type?" ("+x.type+")":""}`);let A=x.properties;for(let U=0,w=A.length;U<w;U++){let D=A[U];if(D.relationship||D.computed){_.hasOwnProperty(D.name)&&(N||(N=[])).push(`Computed property ${L}.${D.name} may not be directly assigned a value`);continue}let $=P(O[D.name],D,L+"."+D.name);$&&(O[D.name]=$)}if(x.sealed&&O!=null&&typeof O=="object")for(let U in O)A.find(w=>w.name===U)||(N||(N=[])).push(`Property ${U} is not allowed within object in property ${L}`)}else switch(x.type){case"Int":(typeof O!="number"||O>>0!==O)&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof O!="number"||!(Math.floor(O)===O&&Math.abs(O)<=9007199254740992))&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof O!="number"&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a number`);break;case"ID":typeof O=="string"||O?.length>0&&O.every?.(A=>typeof A=="string")||(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a string, or an array of strings`);break;case"String":typeof O!="string"&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a string`);break;case"Boolean":typeof O!="boolean"&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a boolean`);break;case"Date":if(!(O instanceof Date)){if(typeof O=="string"||typeof O=="number")return new Date(O);(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a Date`)}break;case"BigInt":if(typeof O!="bigint"){if(typeof O=="string"||typeof O=="number")return BigInt(O);(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a bigint`)}break;case"Bytes":if(!(O instanceof Uint8Array)){if(typeof O=="string")return Buffer.from(O);(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(O instanceof Ls)){if(typeof O=="string"&&(O=Buffer.from(O)),O instanceof Buffer)return createBlob(O,{type:"text/plain"});(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a Blob`)}break;case"array":if(Array.isArray(O)){if(x.elements)for(let A=0,U=O.length;A<U;A++){let w=O[A],D=P(w,x.elements,L+"[*]");D&&(O[A]=D)}}else(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be an Array`);break}x.nullable===!1&&O==null&&(N||(N=[])).push(`Property ${L} is required (and not does not allow null values)`)},"validateValue");for(let O=0,x=S.length;O<x;O++){let L=S[O];if(L.relationship||L.computed){Object.hasOwn(_,L.name)&&(N||(N=[])).push(`Computed property ${L.name} may not be directly assigned a value`);continue}if(!T||L.name in _){let A=P(_[L.name],L,L.name);A!==void 0&&(_[L.name]=A)}}if(f)for(let O in _)S.find(x=>x.name===O)||(N||(N=[])).push(`Property ${O} is not allowed`);if(N)throw new lt.ClientError(N.join(". "))}getUpdatedTime(){return this.#r}wasLoadedFromSource(){return I?!!this.#i:void 0}static async addAttributes(_){let T=S.slice(0);for(let N of _){if(!N.name)throw new lt.ClientError("Attribute name is required");if(N.name.match(/[`/]/))throw new lt.ClientError("Attribute names cannot include backticks or forward slashes");qie(N.name),T.push(N)}return Ze({table:s,database:c,schemaDefined:u,attributes:T}),Pe.indexingOperation}static async removeAttributes(_){let T=S.filter(N=>!_.includes(N.name));return Ze({table:s,database:c,schemaDefined:u,attributes:T}),Pe.indexingOperation}static getSize(){let _=i.getStats();return(_.treeBranchPageCount+_.treeLeafPageCount+_.overflowPages)*_.pageSize}static getAuditSize(){let _=l?.getStats();return _&&(_.treeBranchPageCount+_.treeLeafPageCount+_.overflowPages)*_.pageSize}static getStorageStats(){let _=i.env.path,T=Zw.default.statfsSync?.(_)??{};return{available:T.bavail*T.bsize,free:T.bfree*T.bsize,size:T.blocks*T.bsize}}static async getRecordCount(_){let T=i.getStats().entryCount,N=1e3/2,P=performance.now(),O=Math.floor(T/2),x=_?.exactCount,L=0,A=0,U;for(let{value:w}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(w!=null&&L++,A++,await Za(),!x&&A<O&&performance.now()-P>N){U=A;break}if(U){let w=L;L=0;for(let{value:ne}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:U,snapshot:!1}))ne!=null&&L++,await Za();let D=U*2,$=(L+w)/D,Y=Math.pow((L-w+1)/U/2,2)+$*(1-$)/D,j=Math.max(Math.sqrt(Y)*T,1),B=Math.round($*T),Ee=Math.max(B-1.96*j,L+w),fe=Math.min(B+1.96*j,T),pe=Math.pow(10,Math.round(Math.log10(j)));return pe>B&&(pe=pe/10),L=Math.round(B/pe)*pe,{recordCount:L,estimatedRange:[Math.round(Ee),Math.round(fe)]}}return{recordCount:L}}static updatedAttributes(){vr=this.propertyResolvers={$id:o((_,T,N)=>({value:N.key}),"$id"),$updatedtime:o((_,T,N)=>N.version,"$updatedtime"),$updatedTime:o((_,T,N)=>N.version,"$updatedTime"),$expiresAt:o((_,T,N)=>N.expiresAt,"$expiresAt"),$record:o((_,T,N)=>N?{value:_}:_,"$record"),$distance:o((_,T,N)=>N&&(N.distance??T?.vectorDistances?.get(N)),"$distance")};for(let _ of this.attributes){_.isPrimaryKey&&(k=_),_.resolve=null;let T=_.relationship,N=_.computed;if(T)if(_.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),N&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),_u=!0,T.to)_.elements?.definition?(vr[_.name]=_.resolve=(P,O,x,L)=>{let A=P[T.from?T.from:t],U=_.elements.definition.tableClass;return L?Hu({attribute:T.to,value:A},Ur(O).getReadTxn(),!1,U,!1).map(w=>w&&w.key!==void 0?w:U.primaryStore.getEntry(w,{transaction:Ur(O).getReadTxn()})).asArray:U.search([{attribute:T.to,value:A}],O).asArray},_.set=()=>{},_.resolve.definition=_.elements.definition,_.resolve.to=T.to,T.from&&(_.resolve.from=T.from)):console.error(`The one-to-many/many-to-many relationship property "${_.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(T.from){let P=_.definition||_.elements?.definition;P?(vr[_.name]=_.resolve=(O,x,L,A)=>{let U=O[T.from];if(U===void 0)return;if(_.elements){let D,$=U?.map(Y=>{let j=P.tableClass.primaryStore[A?"getEntry":"get"](Y,{transaction:Ur(x).getReadTxn()});return j?.then&&(D=!0),Pe.loadAsInstance===!1&&Object.freeze(A?j?.value:j),j});return T.filterMissing?D?Promise.all($).then(Y=>Y.filter(cG)):$.filter(cG):D?Promise.all($):$}let w=P.tableClass.primaryStore[A?"getEntry":"get"](U,{transaction:Ur(x).getReadTxn()});return Pe.loadAsInstance===!1&&Object.freeze(A?w?.value:w),w},_.set=(O,x)=>{if(Array.isArray(x)){let L=x.map(A=>A.getId?.()||A[P.tableClass.primaryKey]);O[T.from]=L}else{let L=x.getId?.()||x[P.tableClass.primaryKey];O[T.from]=L}},_.resolve.definition=_.definition||_.elements?.definition,_.resolve.from=T.from):console.error(`The relationship property "${_.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${_.name}" in table "${s}" must use either "from" or "to" arguments`);else if(N)typeof N.from=="function"&&this.setComputedAttribute(_.name,N.from),vr[_.name]=_.resolve=(P,O,x)=>{let L=typeof N.from=="string"?P[N.from]:P,A=this.userResolvers[_.name];if(A)return A(L,O,x);Fe.default.warn(`Computed attribute "${_.name}" does not have a function assigned to it. Please use setComputedAttribute('${_.name}', resolver) to assign a resolver function.`),this.userResolvers[_.name]=()=>{}},_.resolve.directReturn=!0;else if(r[_.name]?.customIndex?.propertyResolver){let P=r[_.name].customIndex;vr[_.name]=(O,x,L)=>{let A=O[_.name];return P.propertyResolver(A,x,L)},vr[_.name].directReturn=!0}}cp(this,this),cp(Qf,this,!0);for(let _ of S){let T=_.name;_.resolve&&Object.defineProperty(i.encoder.structPrototype,T,{get(){return _.resolve(this,$u.getStore())},set(N){return _.set(this,N)},configurable:!0})}}static setComputedAttribute(_,T){let N=qi(S,_);if(!N){console.error(`The attribute "${_}" does not exist in the table "${s}"`);return}if(!N.computed){console.error(`The attribute "${_}" is not defined as computed in the table "${s}"`);return}this.userResolvers[_]=T}static async deleteHistory(_=0,T=!1){let N;for(let{key:P,value:O}of l.getRange({start:0,end:_}))await Za(),At(O).tableId===n&&(N=v_(l,P,O));if(T)for(let P of i.getRange({start:0,versions:!0})){let{key:O,value:x,localTime:L}=P;await Za(),x===null&&L<_&&(N=nl(i,P))}await N}static async*getHistory(_=0,T=1/0){for(let{key:N,value:P}of l.getRange({start:_||1,end:T})){await Za();let O=At(P);O.tableId===n&&(yield{id:O.recordId,localTime:N,version:O.version,type:O.type,value:O.getValue(i,!0,N),user:O.user,operation:O.originatingOperation})}}static async getHistoryOfRecord(_){let T=[];if(_==null)throw new Error("An id is required");let N=i.getEntry(_);if(!N)return T;let P=N.localTime;if(!P)throw new Error("The entry does not have a local audit time");let O=0;do{await Za();let x=l.get(P);if(x){let L=At(x);T.push({id:L.recordId,localTime:P,version:L.version,type:L.type,value:L.getValue(i,!0,P),user:L.user}),P=L.previousLocalTime}else break}while(O<1e3&&P);return T.reverse()}static cleanup(){W?.remove()}}let $E=Kg(async(K,_,T)=>{for(let N of Pe.sources)if(N.get&&(!N.get.reliesOnPrototype||N.prototype.get)){if(N.available?.(T)===!1)continue;_.source=N;let P=await N.get(K,_);if(P)return P}},()=>{throw new lt.ServerError("Service unavailable, exceeded request queue limit for resolving cache record",503)});Pe.updatedAttributes();let cb=Pe.prototype;return h&&Pe.setTTLExpiration(h/1e3),X&&VE(),Pe;function gu(K,_,T){let N;for(let P in r){let O=r[P],x=O.isIndexing,L=vr[P],A=T&&(L?L(T):T[P]),U=_&&(L?L(_):_[P]);if(A===U&&!x)continue;if(O.customIndex){O.customIndex.index(K,A,U);continue}N=!0;let w=O.indexNulls,D=(0,Cp.getIndexedValues)(A,w),$=(0,Cp.getIndexedValues)(U,w);if($?.length>0){let Y=new Set($);if(D=D?D.filter(j=>{if(Y.has(j))Y.delete(j);else return!0}):[],$=Array.from(Y),($.length>0||D.length>0)&&rG){let j=$.concat(D).map(B=>({key:B,value:K}));O.prefetch(j,oG)}for(let j=0,B=$.length;j<B;j++)O.remove($[j],K)}else D?.length>0&&rG&&O.prefetch(D.map(Y=>({key:Y,value:K})),oG);if(D)for(let Y=0,j=D.length;Y<j;Y++)O.put(D[Y],K)}return N}o(gu,"updateIndices");function Ui(K){switch(typeof K){case"number":return!0;case"string":if(K.length<659)return!0;if(K.length>sG)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,Cl.writeKey)(K,jie,0)>sG)throw new Error("Primary key size is too large: "+K.length);return!0}o(Ui,"checkValidId");function Os(K){return typeof K=="object"&&K?K.id:K}o(Os,"requestTargetToId");function Jf(K){return typeof K=="object"&&K&&K.isCollection}o(Jf,"isSearchTarget");function Xf(K){}o(Xf,"isRequestTarget");function Io(K,_,T,N,P){if(Pe.getResidencyById&&T.ensureLoaded&&_?.replicateFrom!==!1){let x=Pa(Pe.getResidencyById(K));if(x&&!x.includes(server.hostname)&&C)return C({key:K,residency:x}).then(P)}let O=o(()=>{if(_?.transaction?.stale&&(_.transaction.stale=!1),T.transaction?.isDone)return P(null,K);let x=i.getEntry(K,T);return(c!=="system"||s==="hdb_analytics")&&(dG.default.trace?.("Recording db-read action for",`${c}.${s}`),Ve(x?.size??1,"db-read",s,null)),_?._freezeRecords&&Object.freeze(x?.value),x?.residencyId&&x.metadataFlags&vn&&C&&T.ensureLoaded&&_?.replicateFrom!==!1?C(x).then(L=>P(L,K),L=>(Fe.default.error?.("Error loading remote record",K,x,T,L),P(null,K))):(x&&_&&(x?.version>(_.lastModified||0)&&(_.lastModified=x.version),x?.localTime&&!_.lastRefreshed&&(_.lastRefreshed=x.localTime)),P(x,K))},"whenPrefetched");return N?O():te>0?(te--,O()):new Promise((x,L)=>{te===0?(te--,i.prefetch([K],()=>{A(),U()})):(ue.push(K),ce.push(U),ue.length>qE&&(te--,A()));function A(){if(ue.length>0){let w=ce;i.prefetch(ue,()=>{te===-1?A():te++;for(let D of w)D()}),ue=[],ce=[],ye>2&&ye--}else te=ye,ye<jf&&ye++}o(A,"prefetch");function U(){try{x(O())}catch(w){L(w)}}o(U,"load")})}o(Io,"loadLocalRecord");function On(K,_){let T=_?.checkPermission;if(typeof T!="object"){if(!K?.role)return;T=K.role.permission}if(T.super_user)return Qie;let N=T[c],P,O=N?.tables;if(O)return O[s];if(c==="data"&&(P=T[s])&&!P.tables)return P}o(On,"getTablePermissions");function dn(K,_,T,N){if(I){let P=!1;if(T.noCache?P=!0:(_?(!_.value||_.metadataFlags&(vn|ka)||_.expiresAt!=null&&_.expiresAt<Date.now())&&(P=!0):P=!0,Zr(!P,"cache-hit",s)),P){let O=Tu(K,_,T).then(x=>(x?.value&&x?.value.getRecord?.()&&Fe.default.error?.("Can not assign a record that is already a resource"),T&&(x?.version>(T.lastModified||0)&&(T.lastModified=x.version),T.lastRefreshed=Date.now()),x));if(T?.onlyIfCached||_?.value&&N?.allowStaleWhileRevalidate?.(_,K)){if(O.catch(x=>Fe.default.warn?.(x)),T?.onlyIfCached&&!N.doesExist())throw new lt.ServerError("Entry is not cached",504);return}else return O}}else if(_?.value&&_.expiresAt!=null&&_.expiresAt<Date.now())return Pe.evict(_.key,_.value,_.version),_.value=null,{then(P){return P(_)}}}o(dn,"ensureLoadedFromSource");function Ur(K){let _=K?.transaction;if(_){if(!_.lmdbDb)return _.lmdbDb=i,_;do{if(_.lmdbDb?.path===i.path)return _;let T=_.next;if(!T)return _=_.next=new No,_.lmdbDb=i,_;_=T}while(!0)}else return new u_}o(Ur,"txnForContext");function Su(K,_,T){if(!K)return;let N=(K.deref?K.deref():K.value)??i.getEntry(K.key)?.value;if(typeof _=="object"){let O=vr,x=N;for(let L=0,A=_.length;L<A;L++){let U=_[L],w=O?.[U];x=w&&x?w(x,T,K):x?.[U],K=null,O=w?.definition?.tableClass?.propertyResolvers}return x}let P=vr[_];return P?P(N,T,K):N[_]}o(Su,"getAttributeValue");function Zf(K,_,T,N,P){let O=P?.length,x={transaction:N,lazy:O>0||typeof _=="string"||_?.length<4,alwaysPrefetch:!0},L;function A(U,w){let D=U?.value;if(!D)return ec.SKIP;for(let $=0;$<O;$++)if(!L?.includes($)&&!P[$](D,U))return ec.SKIP;return w!==void 0&&(U.key=w),U}if(o(A,"processEntry"),O>0||!K.hasEntries){let U=K.map(w=>{if(L=null,typeof w=="object"&&w?.key!==void 0)return O>0?A(w):w;if(w==null)return ec.SKIP;for(let D=0;D<O;D++){let Y=P[D].idFilter;if(Y){if(!Y(w))return ec.SKIP;L||(L=[]),L.push(D)}}return Io(w,T,x,!1,A)});return Array.isArray(K)&&(U=U.filter(w=>w!==ec.SKIP)),U.hasEntries=!0,U}return K}o(Zf,"transformToEntries");function xr(K,_,T=server.replication?.getThisNodeId(l)){if(K<=_?.version){if(_?.version===K&&T!==void 0){let N=server.replication?.exportIdMapping(l),P=_.localTime,O=P&&l.get(P);if(O){let x,L,A=At(O);for(let U in N)N[U]===T&&(x=U),N[U]===A.nodeId&&(L=U);if(x>L)return 1;if(x===L)return 0}}return-1}return 1}o(xr,"precedesExistingVersion");async function Tu(K,_,T){let N=_?.metadataFlags,P=_?.version,O,x;if(!i.attemptLock(K,P,()=>{clearTimeout(x);let w=i.getEntry(K);!w||!w.value||w.metadataFlags&(vn|ka)?O(Tu(K,i.getEntry(K),T)):O(w)}))return new Promise(w=>{O=w,x=setTimeout(()=>{i.unlock(K,P)},Wie)});let L=_?.value,A={requestContext:T,replacingRecord:L,replacingEntry:_,replacingVersion:P,noCacheStore:!1,source:null,resourceCache:T?.resourceCache,transaction:void 0,expiresAt:void 0,lastModified:void 0},U=T?.responseHeaders;return new Promise((w,D)=>{let $;ks(bt(A,async Y=>{let j=performance.now(),B,Ee,fe;try{B=await $E(K,A,_),fe=N&vn;let ne=A.lastModified||fe&&P;Ee=fe||ne>P||!L,ne||(ne=(0,Cp.getNextMonotonicTime)());let ie=performance.now()-j;if(Ve(ie,"cache-resolution",s,null,"success"),U&&wp(U,"Server-Timing",`cache-resolve;dur=${ie.toFixed(2)}`,!0),Y.timestamp=ne,h&&A.expiresAt==null&&(A.expiresAt=Date.now()+h),B){if(typeof B!="object")throw new Error("Only objects can be cached and stored in tables");if(B.status>0&&B.headers)if(B.status>=300)if(B.status===304)B=L,ne=P;else throw new lt.ServerError(B.body||"Error from source",B.status);else B=B.body;typeof B.toJSON=="function"&&(B=B.toJSON()),t&&B[t]!==K&&(B[t]=K)}$=!0,w({key:K,version:ne,value:B})}catch(ne){ne.message+=` while resolving record ${K} for ${s}`,L&&((ne.code==="ECONNRESET"||ne.code==="ECONNREFUSED"||ne.code==="EAI_AGAIN")&&!T?.mustRevalidate||T?.staleIfError&&(ne.statusCode===500||ne.statusCode===502||ne.statusCode===503||ne.statusCode===504))?(w({key:K,version:P,value:L}),Fe.default.trace?.(ne.message,"(returned stale record)")):D(ne);let ie=performance.now()-j;Ve(ie,"cache-resolution",s,null,"fail"),U&&wp(U,"Server-Timing",`cache-resolve;dur=${ie.toFixed(2)}`,!0),A.transaction.abort();return}if(T?.noCacheStore||A.noCacheStore){A.transaction.abort();return}Ur(A).addWrite({key:K,store:i,entry:_,nodeName:"source",before:yu(B),commit:o((ne,ie)=>{if(ie?.version!==P)return;let xe=gu(K,L,B);if(B){Ye.put?.(A,K,B),ie&&(T.previousResidency=Pe.getResidencyRecord(ie.residencyId));let de,oe=!1,ke,Be=Pa(Pe.getResidency(B,T));if(Be){if(!Be.includes(server.hostname))if(de=B,oe=!0,Pe.getResidencyById)B=void 0;else{B=null;for(let Le in r)B||(B={}),B[Le]=de[Le]}ke=kc(Be)}Fe.default.trace?.(`Writing resolved record from source with id: ${K}, timestamp: ${new Date(ne).toISOString()}`),y(K,B,ie,ne,oe?vn:0,g&&(Ee||oe)||null,{user:A?.user,expiresAt:A.expiresAt,residencyId:ke,tableToTrack:s},"put",!!fe,de)}else ie&&(Ye.delete?.(A,K),Fe.default.trace?.(`Deleting resolved record from source with id: ${K}, timestamp: ${new Date(ne).toISOString()}`),g||R?y(K,null,ie,ne,0,g&&Ee||null,{user:A?.user,tableToTrack:s},"delete",!!fe):nl(i,ie,P))},"commit")})}),()=>{i.unlock(K,P)},Y=>{i.unlock(K,P),$&&Fe.default.error?.("Error committing cache update",Y)})})}o(Tu,"getFromSource");function Ca(K){if(!K||K.user?.role?.permission?.super_user)return!0;if(K.replicateTo)throw new lt.ClientError("Can not specify replication parameters without super user permissions",403);if(K.replicatedConfirmation)throw new lt.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}o(Ca,"checkContextPermissions");function Oa(K){let _=!1;if(K&&(K-Ar>1&&(_=!0),Ar=K),!(qe===tr&&!_)&&(tr=qe,(0,wl.getWorkerIndex)()===(0,wl.getWorkerCount)()-1))return Wr&&clearTimeout(Wr),qe?new Promise(T=>{let N=new Date;N.setMonth(0),N.setDate(1),N.setHours(0),N.setMinutes(0),N.setSeconds(0);let P=qe/(1+Ar),O=_?Date.now():Math.ceil((Date.now()-N.getTime())/P)*P+N.getTime(),x=o(L=>{Fe.default.trace?.(`Scheduled next cleanup scan at ${new Date(L)}`),Wr=setTimeout(()=>J=J.then(async()=>{if(x(Math.max(L+qe,Date.now())),i.rootStore.status!=="open"){clearTimeout(Wr);return}let A=50,U=new Array(A),w=0,D=Math.pow(Ar,8)*(Nl.get(F.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),$=E/Math.pow(Math.max(Ar,1),4);Fe.default.debug?.(`Starting cleanup scan for ${s}, evict threshold ${D}, adjusted eviction ${$}ms`);function Y(j,B,Ee,fe){let pe=j+$-Date.now();if(pe<0)return!0;if(Ar){let ne=i.lastSize;return Ee&Jr&&Wc(fe,ie=>{ie.size&&(ne+=ie.size)}),Fe.default.trace?.(`shouldEvict adjusted ${pe} ${ne}, ${pe*(j-B)/ne} < ${D}`),pe*(j-B)/ne<D}return!1}o(Y,"shouldEvict");try{let j=0;for(let B of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:Ee,value:fe,version:pe,expiresAt:ne,metadataFlags:ie}=B,xe;fe===null&&!g&&pe+Yie<Date.now()?xe=nl(i,B,pe):ne!=null&&Y(ne,pe,ie,fe)&&(xe=Pe.evict(Ee,fe,pe),j++),xe&&(await U[w],U[w]=xe.catch(de=>{Fe.default.error?.("Cleanup error",de)}),++w>=A&&(w=0)),await Za()}Fe.default.debug?.(`Finished cleanup scan for ${s}, evicted ${j} entries`)}catch(j){Fe.default.warn?.(`Error in cleanup scan for ${s}:`,j)}T(void 0),Ar=0}),Math.min(L-Date.now(),2147483647)).unref()},"startNextTimer");x(O)}):void 0}o(Oa,"scheduleCleanup");function em(){W=l?.addDeleteRemovalCallback(n,i,(K,_)=>{i.remove(K,_)})}o(em,"addDeleteRemoval");function VE(){(0,wl.getWorkerIndex)()===0&&setInterval(async()=>{if(!Fc){Fc=!0;try{let K=X.name,_=r[K];if(!_)throw new Error(`expiresAt attribute ${X} must be indexed`);for(let T of _.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let N of _.getValues(T)){let P=i.getEntry(N);P?.value?P.value[K]<Date.now()&&Pe.evict(N,P.value,P.version):i.ifVersion(N,P?.version,()=>_.remove(T,N))}await Za()}}catch(K){Fe.default.error?.("Error in evicting old records",K)}finally{Fc=!1}}},Kie).unref()}o(VE,"runRecordExpirationEviction");function Pa(K){if(K!=null){if(Array.isArray(K))return K;if(typeof K=="number"){if(K>=65536)throw new Error(`Shard id ${K} must be below 65536`);let _=server.shards?.get?.(K);if(_)return Fe.default.trace?.(`Shard ${K} mapped to ${_.map(T=>T.name).join(", ")}`),_.map(T=>T.name);throw new Error(`Shard ${K} is not defined`)}throw new Error(`Shard or residency list ${K} is not a valid type, must be a shard number or residency list of node hostnames`)}}o(Pa,"residencyFromFunction");function kc(K){if(K){let _=K.join(","),T=d.get([Symbol.for("residency_by_set"),_]);return T||(d.put([Symbol.for("residency_by_set"),_],T=Math.floor(Math.random()*2147418112)+65535),d.put([Symbol.for("residency_by_id"),T],K),T)}}o(kc,"getResidencyId");function yu(K,_){let T=Qb(K,i.rootStore);if(T){let N=_;return N?async()=>{await N(),await T}:()=>T}return _}o(yu,"preCommitBlobsForRecordBefore")}function Xw(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 oG(){}function Wg(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 Yg(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return Yg(+e);case"Float":return e==="null"?null:Yg(+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;Jie.test(e)||(e+="Z");let n=new Date(e);return Yg(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,zg.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function Yg(e){if(isNaN(e))throw new SyntaxError;return e}function aG(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 ks(e,t,r){return e?.then?e.then(t,r):t(e)}function cG(e){return e!=null}function Hs(e){try{return JSON.stringify(e)}catch{return e}}function Xie(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var ec,Cp,lG,uG,Nl,lt,Op,Pp,Fe,Cl,wl,zg,Zw,dG,Gie,qie,$ie,Vie,Kie,Yie,rG,Wie,nG,zie,vn,ka,jie,sG,iG,Qie,CMe,Jie,Za,Z_=se(()=>{q();ec=require("lmdb"),Cp=b(Ln()),lG=b(require("lodash")),uG=b(hm());Ha();_m();Nl=b(me());BA();lt=b(_e()),Op=b(Ho()),Pp=b(ss());we();X_();Fe=b(Xn());KI();Ma();Cl=require("ordered-binary"),wl=b(nt());Bi();zg=b(ae());el();es();m_();Np();Zw=b(require("node:fs"));Zn();P_();dG=b(Q());Jw();({sortBy:Gie}=lG.default),{validateAttribute:qie}=uG.default,$ie=new Uint8Array(9);$ie[8]=192;Vie=1/0,Kie=6e4,Yie=864e5;Nl.initSync();rG=Nl.get(F.STORAGE_PREFETCHWRITES),Wie=1e4,nG=1,zie=2,vn=1,ka=8,jie=Buffer.allocUnsafeSlow(8192),sG=1978,iG=100,Qie={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},CMe=(0,zg.convertToMS)(Nl.get(F.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;o(jg,"makeTable");o(Xw,"attributesAsObject");o(oG,"noop");Jie=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;o(Wg,"coerceType");o(Yg,"rejectNaN");o(aG,"isDescendantId");Za=o(()=>new Promise(setImmediate),"rest");o(ks,"when");o(cG,"exists");o(Hs,"stringify");o(Xie,"hasOtherProcesses")});function Qg(e,t){if(!Array.isArray(e)||!Array.isArray(t))throw new Error("Euclidean distance comparison requires an array");let r=0,n=Math.max(e.length,t.length);for(let s=0;s<n;s++){let i=e[s]||0,a=t[s]||0,c=i-a;r+=c*c}return r}function Jg(e,t){if(!Array.isArray(e)||!Array.isArray(t))throw new Error("Cosine distance comparison requires an array");let r=0,n=0,s=0,i=Math.max(e.length,t.length);for(let a=0;a<i;a++){let c=e[a]||0,l=t[a]||0;r+=c*l,n+=c*c,s+=l*l}return n=Math.sqrt(n),s=Math.sqrt(s),1-r/(n*s||1)}var mG=se(()=>{o(Qg,"euclideanDistance");o(Jg,"cosineDistance")});var pG,hG,hd,ro,pd,Zie,eoe,Xg,EG=se(()=>{mG();pG=require("msgpackr"),hG=b(Xn()),hd=b(_e()),ro=(0,hG.loggerWithTag)("HNSW"),pd=Symbol.for("entryPoint"),Zie=Symbol.for("key"),eoe=10,Xg=class{static{o(this,"HierarchicalNavigableSmallWorld")}static useObjectStore=!0;indexStore;M=16;efConstruction=100;efConstructionSearch=50;mL=1/Math.log(this.M);optimizeRouting=.5;nodesVisitedCount=0;idIncrementer;distance;constructor(t,r){this.indexStore=t,t&&(this.indexStore.encoder.useFloat32=pG.FLOAT32_OPTIONS.ALWAYS),this.distance=r?.distance==="euclidean"?Qg:Jg,r&&(r.M!==void 0&&(this.M=r.M,this.mL=1/Math.log(this.M)),r.efConstruction!==void 0&&(this.efConstruction=this.efConstructionSearch=r.efConstruction),r.efConstructionSearch!==void 0&&(this.efConstructionSearch=r.efConstructionSearch),r.mL!==void 0&&(this.mL=r.mL),r.optimizeRouting!==void 0&&(this.optimizeRouting=r.optimizeRouting))}index(t,r,n){let s=typeof t=="number"?[Zie,t]:t,i=this.indexStore.get(s);if(!i){if(!r)return;if(!this.idIncrementer){let f=0;for(let m of this.indexStore.getKeys({reverse:!0,limit:1,start:1/0,end:0}))typeof m=="number"&&(f=m);this.idIncrementer=new BigInt64Array([BigInt(f)+1n]),this.idIncrementer=new BigInt64Array(this.indexStore.getUserSharedBuffer("next-id",this.idIncrementer.buffer))}i=Number(Atomics.add(this.idIncrementer,0,1n)),this.indexStore.put(s,i)}let a=new Map,c,l=this.indexStore.get(pd);if(n?c={...this.indexStore.get(i)}:c={},r){let f=l&&this.indexStore.get(l);if(f===void 0){let E=Math.floor(-Math.log(Math.random())*this.mL),g={vector:r,level:E,primaryKey:t};for(let R=0;R<=E;R++)g[R]=[];if(this.indexStore.put(i,g),typeof i!="number")throw new Error("Invalid nodeId: "+i);ro.debug?.("setting entry point to",i),this.indexStore.put(pd,i);return}let m=c.level??Math.min(Math.floor(-Math.log(Math.random())*this.mL),eoe),p=f.level;if(m>=p){if(typeof i!="number")throw new Error("Invalid nodeId: "+i);ro.debug?.("setting entry point to",i),this.indexStore.put(pd,i)}for(;p>m;){let E=this.searchLayer(r,l,f,this.efConstruction,p);E.length>0&&(l=E[0].id,f=E[0].node),p--}let h=new Array(m+1);for(let E=0;E<=m;E++)h[E]=[];for(let E=Math.min(m,p);E>=0;E--){let g=this.searchLayer(r,l,f,this.efConstruction,E);g=g.slice(0,this.M<<1),g.length===0&&E===0&&ro.info?.("should not have zero connections for",l);let R=h[E];for(let S=0;S<g.length;S++){let{id:y,distance:C,node:I}=g[S];if(y===i)continue;let k=[];if(this.optimizeRouting){let H=!1,X=I[E],W=1+this.optimizeRouting*(1+.5*S/this.M);for(let ue=0;ue<X.length;ue++){let{id:ce,distance:te}=X[ue],ye=1+this.optimizeRouting*(1+.5*ue/this.M);for(let Ae=0;Ae<R.length;Ae++){let{id:Ye,distance:qe}=R[Ae];if(Ye===ce){C*W>qe+te?H=!0:te*ye>C+qe&&(k.push({fromId:Ye,toId:y}),k.push({fromId:y,toId:Ye}));break}}if(H)break}if(H)continue}else if(S>=(E>0?this.M:this.M<<1))continue;R.push({id:y,distance:C});for(let{fromId:H,toId:X}of k){let W=d(H);W||(W=d(H,this.indexStore.get(H)));for(let ue=0;ue<W[E].length;ue++)if(W[E][ue].id===X){Object.isFrozen(W[E])&&(W[E]=W[E].slice()),W[E].splice(ue,1);break}}let J=c[E],G=J?.find(({id:H})=>H===y);if(G){let H=J?.indexOf(G);J.copied||(J=[...J],J.copied=!0,c[E]=J),J.splice(H,1)}else this.addConnection(y,d(y,I),i,E,C,d)}}this.indexStore.put(i,{vector:r,level:m,primaryKey:t,...h})}else{if(l===i){let f=c.level??0;for(let m=f;m>=0&&(l=c[m][0]?.id,l===void 0);m--);if(l===void 0){let m=-1;for(let{key:p,value:h}of this.indexStore.getRange({start:0,end:1/0}))if(h.level>m){if(l=p,h.level===f)break;m=h.level}}if(l===void 0)this.indexStore.remove(pd);else{if(typeof l!="number")throw new Error("Invalid nodeId: "+l);ro.debug?.("setting entry point to",l),this.indexStore.put(pd,l)}}this.indexStore.remove(i)}let u=new Map;if(c.level!==void 0)for(let f=0;f<=c.level;f++){let m=c[f];for(let{id:p}of m){let h=d(p,this.indexStore.get(p));for(let E=0;E<=f;E++)h[E]=h[E]?.filter(({id:g})=>g!==i),h[E].length===0&&(ro.info?.("node was left orphaned, will reindex",p),u.set(h.primaryKey,h.vector))}}function d(f,m){let p=a.get(f);return!p&&m&&(p={...m},a.set(f,p)),p}o(d,"updateNode");for(let[f,m]of a)this.indexStore.put(f,m);for(let[f,m]of u)this.index(f,m,m);this.checkSymmetry(i,this.indexStore.get(i))}getEntryPoint(){let t=this.indexStore.get(pd);if(t===void 0)return;let r=this.indexStore.get(t);return{id:t,...r}}searchLayer(t,r,n,s,i,a=this.distance){let c=new Set([r]),l=[{id:r,distance:this.distance(t,n.vector),node:n}],u=[...l];for(;l.length>0;){l.sort((p,h)=>p.distance-h.distance);let d=l.shift(),f=u[u.length-1].distance;if(d.distance>f)break;let m=d.node;for(let{id:p}of m[i]||[]){if(c.has(p)||p===void 0)continue;c.add(p);let h=this.indexStore.get(p);if(!h)continue;this.nodesVisitedCount++;let E=a(t,h.vector);if(E<f||u.length<s){let g={id:p,distance:E,node:h};l.push(g),u.push(g)}}u.sort((p,h)=>p.distance-h.distance),u.length>s&&u.splice(s,u.length-s)}return u.visited=c.size,u}search({target:t,value:r,descending:n,distance:s,comparator:i}){let a=0;switch(i){case"lt":case"le":a=r;case"sort":break;default:throw new hd.ClientError(`Can not use "${i}" comparator with HNSW`)}if(n)throw new hd.ClientError("Can not use descending sort order with HNSW");let c;if(s==="cosine")c=Jg;else if(s==="euclidean")c=Qg;else{if(s)throw new hd.ClientError("Unknown distance function");c=this.distance}if(!t)throw new hd.ClientError("A target vector must be provided for an HNSW query");if(!Array.isArray(t))throw new hd.ClientError("The target vector must be an array");let l=this.getEntryPoint();if(!l)return[];let u=l.id,d=[];for(let f=l.level;f>=0;f--)if(d=this.searchLayer(t,u,l,this.efConstructionSearch,f,c),d.length>0){let m=d[0];l=m.node,u=m.id}return a&&(d=d.filter(f=>f.distance<a)),d.map(f=>({key:f.node.primaryKey,distance:f.distance}))}checkSymmetry(t,r){if(!r)return;let n=0,s;for(;(s=r[n])&&s.length!==0;){for(let{id:i}of s){let a=this.indexStore.get(i);if(!a){ro.info?.("could not find neighbor node",a);continue}a[n]?.find(({id:l})=>l==t)||ro.info?.("asymmetry detected",a[n])}n++}}addConnection(t,r,n,s,i,a){r[s]||(r[s]=[]);let c=s===0?this.M<<1:this.M;if(this.optimizeRouting&&(c<<=2),r[s].length>=c+(c>>2)){ro.warn?.("maxConnections reached, removing some connections",c);let l=[...r[s]];l.sort((f,m)=>f.distance-m.distance);let u=l.slice(0,c),d=l.slice(c);r[s]=u;for(let f of d){let m=a(f.id)??this.indexStore.get(f.id);m&&m[s]&&(m=a(f.id,m),m[s]=m[s].filter(({id:p})=>p!==t),s===0&&m[s].length===0&&ro.info?.("should not remove last connection",t,n))}}r[s].find(({id:l})=>l===n)?ro.debug?.("already connected",t,n):r[s]=[...r[s],{id:n,distance:i}]}validateConnectivity(t=0){let r=this.getEntryPoint(),n=new Set,s=[r.id];n.add(r.id);let i=0;for(;s.length>0;){let a=s.shift(),c=this.indexStore.get(a);for(let l=t;l<=c.level;l++)for(let{id:u}of c[l]||[])i++,n.has(u)||(n.add(u),s.push(u))}return n.size!==this.totalNodes&&console.log("visited",n.size,"total",this.totalNodes),{isFullyConnected:n.size===this.totalNodes,averageConnections:i/n.size}}get totalNodes(){return Array.from(this.indexStore.getKeys({start:0,end:1/0})).length}estimateCountAsSort(){return Math.sqrt(this.indexStore.getStats().entryCount*this.efConstructionSearch)}propertyResolver(t,r,n){let s=r?.sort;if(s){let i=s.vectorDistances;if(i){let l=i.get(n);if(l)return l}else i=r.vectorDistances=s.vectorDistances=new Map;let a=this.distance;s.type&&(a=s.distance==="euclidean"?Qg:Jg);let c=a(s.target,t);return i.set(n,c),c}return t}}});var eN,_G=se(()=>{EG();eN={HNSW:Xg}});var ft={};Re(ft,{NON_REPLICATING_SYSTEM_TABLES:()=>Zg,database:()=>td,databaseEnvs:()=>Ko,databases:()=>De,dropDatabase:()=>QI,dropTableMeta:()=>ooe,getDatabases:()=>at,getDefaultCompression:()=>oS,getTables:()=>roe,onRemovedDB:()=>Bp,onUpdatedTable:()=>Ol,readMetaDb:()=>Lp,resetDatabases:()=>Td,table:()=>Ze,tables:()=>Sn});function xp(e,t){let r=sS.OpenDBIObject??sS.default.OpenDBIObject;return new r(e,t)}function roe(){return nS||at(),Sn||{}}function at(){if(nS)return De;nS=!0,gd=new Map;let e=(0,zt.getHdbBasePath)()&&(0,Ht.join)((0,zt.getHdbBasePath)(),qc),t=(0,zt.get)(F.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,zt.get)(F.STORAGE_PATH)||e&&((0,ms.existsSync)(e)?e:(0,Ht.join)((0,zt.getHdbBasePath)(),XE)),!!e){if((0,ms.existsSync)(e))for(let r of(0,ms.readdirSync)(e,{withFileTypes:!0})){let n=(0,Ht.basename)(r.name,".mdb");r.isFile()&&(0,Ht.extname)(r.name).toLowerCase()===".mdb"&&!t[n]?.path&&Lp((0,Ht.join)(e,r.name),null,n)}if((0,ms.existsSync)((0,_d.getBaseSchemaPath)())){for(let r of(0,ms.readdirSync)((0,_d.getBaseSchemaPath)(),{withFileTypes:!0}))if(!r.isFile()){let n=(0,Ht.join)((0,_d.getBaseSchemaPath)(),r.name),s=(0,Ht.join)((0,_d.getTransactionAuditStoreBasePath)(),r.name);for(let i of(0,ms.readdirSync)(n,{withFileTypes:!0}))if(i.isFile()&&(0,Ht.extname)(i.name).toLowerCase()===".mdb"){let a=(0,Ht.join)(s,i.name);Lp((0,Ht.join)(n,i.name),(0,Ht.basename)(i.name,".mdb"),r.name,a,!0)}}}if(t)for(let r in t){let n=t[r],s=n.path;if((0,ms.existsSync)(s))for(let a of(0,ms.readdirSync)(s,{withFileTypes:!0}))a.isFile()&&(0,Ht.extname)(a.name).toLowerCase()===".mdb"&&Lp((0,Ht.join)(s,a.name),(0,Ht.basename)(a.name,".mdb"),r);let i=n.tables;if(i)for(let a in i){let c=i[a],l=(0,Ht.join)(c.path,(0,Ht.basename)(a+".mdb"));(0,ms.existsSync)(l)&&Lp(l,a,r,null,!0)}}for(let r in De){let n=gd.get(r);if(n){let s=De[r];r.includes("delete")&&Nr.trace(`defined tables ${Array.from(n.keys())}`);for(let i in s)n.has(i)||(Nr.trace(`delete table class ${i}`),delete s[i])}else if(delete De[r],r==="data"){for(let s in Sn)delete Sn[s];delete Sn[iS]}}if((0,zt.get)(F.ANALYTICS_REPLICATE)===!1?Zg.includes("hdb_analytics")||Zg.push("hdb_analytics"):(De.system?.hdb_analytics?.enableAuditing(),De.system?.hdb_analytics_hostname?.enableAuditing()),De.system)for(let r of Zg)De.system[r]&&(De.system[r].replicate=!1);return gd=null,De}}function Td(){nS=!1;for(let[,e]of Ko)e.needsDeletion=!0;at();for(let[e,t]of Ko)if(t.needsDeletion&&!e.endsWith("system.mdb")){t.close(),Ko.delete(e);let r=De[t.databaseName];for(let n in r)if(r[n].primaryStore.path===e){delete De[t.databaseName],Mp.forEach(i=>i(t.databaseName));break}}return De}function Lp(e,t,r=nN,n,s){let i=new tN.default(e,!1);try{let a=Ko.get(e);a?a.needsDeletion=!1:(a=(0,Sd.open)(i),Ko.set(e,a));let c=new xp(!1),l=a.dbisDb||(a.dbisDb=a.openDB(eS.INTERNAL_DBIS_NAME,c)),u=a.auditStore;u||(n?(0,ms.existsSync)(n)&&(i.path=n,u=(0,Sd.open)(i),u.isLegacy=!0):u=M_(a));let d=RG(r),f=d[iS],m=new Map;for(let{key:p,value:h}of l.getRange({start:!1})){let[E,g]=p.toString().split("/");g===""?g=h.name:g||(g=E,E=t,h.name||(h.name=g,h.indexed=!h.is_hash_attribute)),f?.add(E);let R=m.get(E);R||m.set(E,R={attributes:[]}),(g==null||h.is_hash_attribute)&&(R.primary=h),g!=null&&R.attributes.push(h),Object.defineProperty(h,"key",{value:p,configurable:!0})}for(let[p,h]of m){let{attributes:E,primary:g}=h;if(!g){for(let te of E)if(te.is_hash_attribute||te.isPrimaryKey){g=te;break}if(!g){Nr.warn(`Unable to find a primary key attribute on table ${p}, with attributes: ${JSON.stringify(E)}`);continue}}let R=d[p],S={},y=[],C,I,k=typeof g.audit=="boolean"?g.audit:(0,zt.get)(F.LOGGING_AUDITLOG),J=g.trackDeletes,G=g.expiration,H=g.eviction,X=g.sealed,W=g.splitSegments,ue=g.replicate;if(R)S=R.indices,y=R.attributes,R.schemaVersion++;else{C=g.tableId,C?C>=(l.get(Ed)||0)&&(l.putSync(Ed,C+1),Nr.info(`Updating next table id (it was out of sync) to ${C+1} for ${p}`)):(g.tableId=C=l.get(Ed),C||(C=1),Nr.debug("Table {tableName} missing an id, assigning {tableId}"),l.putSync(Ed,C+1),l.putSync(g.key,g));let te=new xp(!g.is_hash_attribute,g.is_hash_attribute);if(te.compression=g.compression,te.compression){let ye=(0,zt.get)(F.STORAGE_COMPRESSION_THRESHOLD)||yG;te.compression.threshold=ye}I=z_(a.openDB(g.key,te),a),a.databaseName=r,I.tableId=C}let ce;for(let te of E){te.attribute=te.name;try{if(!te.is_hash_attribute&&(te.indexed||te.attribute&&!te.name)){if(!S[te.name]){let Ae=AG(te.key,a,te);S[te.name]=Ae,S[te.name].indexNulls=te.indexNulls}let ye=y.find(Ae=>Ae.name===te.name);ye?y.splice(y.indexOf(ye),1,te):y.push(te),ce=!0}}catch(ye){Nr.error("Error trying to update attribute",te,y,S,ye)}}for(let te of y)if(!E.find(Ae=>Ae.name===te.name)){if(te.is_hash_attribute){Nr.error("Unable to remove existing primary key attribute",te);continue}te.indexed&&(y.splice(y.indexOf(te),1),ce=!0)}if(R)ce&&(R.schemaVersion++,R.updatedAttributes());else{R=bG(d,p,jg({primaryStore:I,auditStore:u,audit:k,sealed:X,splitSegments:W,replicate:ue,expirationMS:G&&G*1e3,evictionMS:H&&H*1e3,trackDeletes:J,tableName:p,tableId:C,primaryKey:g.name,databasePath:s?r+"/"+p:r,databaseName:r,indices:S,attributes:E,schemaDefined:g.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let te of Dp)te(R)}}return a}catch(a){throw a.message+=` opening database ${e}`,a}}function RG(e){let t=De[e];if(t||(e==="data"?t=De[e]=Sn:e==="system"?Object.defineProperty(De,"system",{value:t=Object.create(null),configurable:!0}):t=De[e]=Object.create(null)),gd&&!gd.has(e)){let r=new Set;t[iS]=r,gd.set(e,r)}return t}function bG(e,t,r){return e[t]=r,r}function td({database:e,table:t}){e||(e=nN),at();let r=RG(e),n=(0,Ht.join)((0,zt.getHdbBasePath)(),qc),s=(0,zt.get)(F.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,zt.get)(F.STORAGE_PATH)||((0,ms.existsSync)(n)?n:(0,Ht.join)((0,zt.getHdbBasePath)(),XE));let a=(0,Ht.join)(n,(i?t:e)+".mdb"),c=Ko.get(a);if(!c||c.status==="closed"){let l=new tN.default(a,!1);c=(0,Sd.open)(l),Ko.set(a,c)}return c.auditStore||(c.auditStore=M_(c)),c}async function QI(e){if(!De[e])throw new Error("Schema does not exist");let t=De[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Ko.delete(r.path),r.status==="open"&&(await r.close(),await vp.remove(r.path));if(r||(r=td({database:e,table:null}),r.status==="open"&&(await r.close(),await vp.remove(r.path))),e==="data"){for(let n in Sn)delete Sn[n];delete Sn[iS]}delete De[e],Mp.forEach(n=>n(e)),await jb(r)}function AG(e,t,r){let n=r.is_hash_attribute||r.indexed.type&&eN[r.indexed.type]?.useObjectStore,s=new xp(!n,n),i=t.openDB(e,s);if(r.indexed.type){let a=eN[r.indexed.type];a?i.customIndex=new a(i,r.indexed):Nr.error(`The indexing type '${r.indexed.type}' is unknown`)}return i}function Ze(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:a,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:f,schemaDefined:m,origin:p}=e;r||(r=nN);let h=td({database:r,table:t}),E=De[r];Nr.trace(`Defining ${t} in ${r}`);let g=E?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let R,S,y;m==null&&(m=!0);let C=new xp(!1);for(let W of a)W.attribute&&!W.name?(W.name=W.attribute,W.indexed=!0):W.attribute=W.name,W.expiresAt&&(W.indexed=!0);let I,k;if(g){if(R=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...a)}else{let W=h.auditStore;S=a.find(ye=>ye.isPrimaryKey)||{},R=S.name,S.is_hash_attribute=S.isPrimaryKey=!0,S.schemaDefined=m,S.compression=oS(),f&&(S.trackDeletes=!0),c=S.audit=typeof c=="boolean"?c:(0,zt.get)(F.LOGGING_AUDITLOG),n&&(S.expiration=n),s&&(S.eviction=s),u??=!1,S.splitSegments=u,typeof l=="boolean"&&(S.sealed=l),typeof d=="boolean"&&(S.replicate=d),p&&(S.origins?S.origins.includes(p)||S.origins.push(p):S.origins=[p]),Nr.trace(`${t} table loading, opening primary store`);let ue=new xp(!1,!0);ue.compression=S.compression;let ce=t+"/";if(y=h.dbisDb=h.openDB(eS.INTERNAL_DBIS_NAME,C),X(),y.get(ce))return k&&k(),Td(),Ze(e);let te=z_(h.openDB(ce,ue),h);h.databaseName=r,te.tableId=y.get(Ed),Nr.trace(`Assigning new table id ${te.tableId} for ${t}`),te.tableId||(te.tableId=1),y.put(Ed,te.tableId+1),S.tableId=te.tableId,g=bG(E,t,jg({primaryStore:te,auditStore:W,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:f,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:R,tableName:t,tableId:te.tableId,databasePath:r,databaseName:r,indices:{},attributes:a,schemaDefined:m,dbisDB:y})),g.schemaVersion=1,I=!0,y.put(ce,S)}let J=g.indices;y=y||(h.dbisDb=h.openDB(eS.INTERNAL_DBIS_NAME,C)),g.dbisDB=y;let G=[];for(let{key:W,value:ue}of y.getRange({start:!0})){let[ce,te]=W.toString().split("/");if(te===""&&(te=ue.name),te){if(ce!==t)continue}else continue;let ye=a.find(Ye=>Ye.name===te),Ae=!ye?.indexed&&ue.indexed&&!ue.isPrimaryKey;if((!ye||Ae)&&(X(),I=!0,ye||y.remove(W),Ae)){let Ye=g.indices[ce];Ye&&G.push(Ye)}}let H=[];try{for(let W of a||[]){if((W.relationship||W.computed)&&(I=!0,W.relationship))continue;let ue=t+"/"+(W.name||"");Object.defineProperty(W,"key",{value:ue,configurable:!0});let ce=y.get(ue);if(W.isPrimaryKey){if(ce=ce||y.get(ue=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||d!==void 0&&d!==g.replicate||(+n||void 0)!==(+ce.expiration||void 0)||(+s||void 0)!==(+ce.eviction||void 0)||W.type!==ce.type){let ye={...ce};typeof c=="boolean"&&(c&&g.enableAuditing(c),ye.audit=c),n&&(ye.expiration=+n),s&&(ye.eviction=+s),l!==void 0&&(ye.sealed=l),d!==void 0&&(ye.replicate=d),W.type&&(ye.type=W.type),I=!0,X(),y.put(ue,ye)}continue}ce?.attribute&&!ce.name&&(ce.indexed=!0);let te=!ce||ce.type!==W.type||JSON.stringify(ce.indexed)!==JSON.stringify(W.indexed)||ce.nullable!==W.nullable||ce.version!==W.version||JSON.stringify(ce.properties)!==JSON.stringify(W.properties)||JSON.stringify(ce.elements)!==JSON.stringify(W.elements);if(W.indexed){let ye=AG(ue,h,W);(te||ce.indexingPID&&ce.indexingPID!==process.pid||ce.restartNumber<Up.workerData?.restartNumber)&&(I=!0,X(),ce=y.get(ue),(te||ce.indexingPID&&ce.indexingPID!==process.pid||ce.restartNumber<Up.workerData?.restartNumber)&&(I=!0,W.indexNulls===void 0&&(W.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(W.lastIndexedKey=ce?.lastIndexedKey??void 0,W.indexingPID=process.pid,ye.isIndexing=!0,Object.defineProperty(W,"dbi",{value:ye}),H.push(W))),y.put(ue,W)),ce?.indexNulls&&W.indexNulls===void 0&&(W.indexNulls=!0),ye.indexNulls=W.indexNulls,J[W.name]=ye}else te&&(I=!0,X(),y.put(ue,W))}}finally{k&&k()}if(I&&(g.schemaVersion++,g.updatedAttributes()),Nr.trace(`${t} table loading, running index`),H.length>0||G.length>0?g.indexingOperation=ioe(g,H,G):I&&tS.signalSchemaChange(new rS.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=p,I)for(let W of Dp)W(g,p!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Nr.trace(`${t} table loaded`),g;function X(){k||h.transactionSync(()=>({then(W){k=W}}))}o(X,"startTxn")}async function ioe(e,t,r){try{Nr.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await tS.signalSchemaChange(new rS.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,a={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let f of t)(0,Sd.compareKeys)(f.lastIndexedKey,u)<0&&(u=f.lastIndexedKey),f.lastIndexedKey==null&&f.dbi.clearAsync();let d=0;for(let{key:f,value:m,version:p}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(m){if(d++,s=e.primaryStore.ifVersion(f,p,()=>{for(let h=0;h<l;h++){let E=t[h],g=E.name,R=E.dbi;try{let S=E.resolve,y=m&&(S?S(m):m[g]);if(R.customIndex){R.customIndex.index(f,y);continue}let C=(0,gG.getIndexedValues)(y);if(C)for(let I=0,k=C.length;I<k;I++)R.put(C[I],f)}catch(S){a[g]||(a[g]=!0,Nr.error(`Error indexing attribute ${g}`,S))}}}),s.then(()=>d--,h=>{d--,Nr.error(h)}),Up.workerData&&Up.workerData.restartNumber!==TG.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=f,e.dbisDB.put(h.key,h);if(i)return}d>noe?await s:d>soe&&await new Promise(h=>setImmediate(h))}for(let f of t)delete f.lastIndexedKey,delete f.indexingPID,f.dbi.isIndexing=!1,s=e.dbisDB.put(f.key,f)}await s,await tS.signalSchemaChange(new rS.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Nr.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Nr.error("Error in indexing",n)}}function ooe({table:e,database:t}){let r=td({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 Ol(e){return Dp.push(e),{remove(){let t=Dp.indexOf(e);t>-1&&Dp.splice(t,1)}}}function Bp(e){return Mp.push(e),{remove(){let t=Mp.indexOf(e);t>-1&&Mp.splice(t,1)}}}function oS(){let e=(0,zt.get)(F.STORAGE_COMPRESSION),t=(0,zt.get)(F.STORAGE_COMPRESSION_DICTIONARY),r=(0,zt.get)(F.STORAGE_COMPRESSION_THRESHOLD)||yG,n={startingOffset:32};return t&&(n.dictionary=vp.readFileSync(t)),r&&(n.threshold=r),e&&n}var zt,eS,Sd,Ht,ms,_d,tN,vp,rN,gG,tS,rS,Up,SG,TG,sS,toe,Nr,nN,iS,yG,Zg,Sn,De,Ed,Dp,Mp,nS,Ko,gd,noe,soe,we=se(()=>{zt=b(me()),eS=b(Yt()),Sd=require("lmdb"),Ht=require("path"),ms=require("fs"),_d=b(Rt());Z_();tN=b(Vm());q();vp=b(require("fs-extra")),rN=b(si()),gG=b(Ln()),tS=b(Ho()),rS=b(ss()),Up=require("worker_threads"),SG=b(Q()),TG=b(nt());Bi();el();Zn();_G();sS=b($m()),{forComponent:toe}=SG.default;o(xp,"OpenDBIObject");Nr=toe("storage"),nN="data",iS=Symbol("defined-tables"),yG=((0,zt.get)(F.STORAGE_PAGESIZE)||4096)-60;(0,zt.initSync)();Zg=["hdb_temp","hdb_certificate","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_info"],Sn=Object.create(null),De=Object.create(null);(0,rN._assignPackageExport)("databases",De);(0,rN._assignPackageExport)("tables",Sn);Ed=Symbol.for("next-table-id"),Dp=[],Mp=[],Ko=new Map;o(roe,"getTables");o(at,"getDatabases");o(Td,"resetDatabases");o(Lp,"readMetaDb");o(RG,"ensureDB");o(bG,"setTable");o(td,"database");o(QI,"dropDatabase");o(AG,"openIndex");o(Ze,"table");noe=1e3,soe=10;o(ioe,"runIndexing");o(ooe,"dropTableMeta");o(Ol,"onUpdatedTable");o(Bp,"onRemovedDB");o(oS,"getDefaultCompression")});var ae=v(be=>{"use strict";var tc=require("path"),OG=require("fs-extra"),$n=Q(),IG=require("fs-extra"),aS=require("os"),aoe=require("net"),coe=require("recursive-iterator"),Cr=(q(),M(z)),{PACKAGE_ROOT:loe}=Ct(),uoe=bb(),wG=require("papaparse"),cS=require("moment"),{inspect:doe}=require("util"),NG=require("is-number"),foe=require("minimist"),moe=require("https"),poe=require("http"),hoe=/^((\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)))$/,PG=require("util").promisify(setTimeout),Eoe=100,_oe=5,goe="",Soe=4,CG={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};be.isEmpty=ps;be.isEmptyOrZeroLength=no;be.arrayHasEmptyValues=Roe;be.arrayHasEmptyOrZeroLengthValues=boe;be.buildFolderPath=Aoe;be.isBoolean=LG;be.errorizeMessage=Toe;be.stripFileExtension=woe;be.autoCast=Noe;be.autoCastJSON=DG;be.autoCastJSONDeep=iN;be.removeDir=Coe;be.compareVersions=Ooe;be.isCompatibleDataVersion=Poe;be.escapeRawValue=Loe;be.unescapeValue=Doe;be.stringifyProps=Moe;be.timeoutPromise=Uoe;be.isClusterOperation=Boe;be.getClusterUser=koe;be.checkGlobalSchemaTable=Foe;be.getHomeDir=vG;be.getPropsFilePath=voe;be.promisifyPapaParse=Hoe;be.removeBOM=UG;be.createEventPromise=Goe;be.checkProcessRunning=qoe;be.checkSchemaTableExist=$oe;be.checkSchemaExists=xG;be.checkTableExists=BG;be.getStartOfTomorrowInSeconds=Voe;be.getLimitKey=Koe;be.isObject=Ioe;be.isNotEmptyAndHasValue=yoe;be.autoCasterIsNumberCheck=MG;be.backtickASTSchemaItems=Yoe;be.isPortTaken=xoe;be.createForkArgs=Woe;be.autoCastBoolean=zoe;be.asyncSetTimeout=PG;be.getTableHashAttribute=joe;be.doesSchemaExist=Qoe;be.doesTableExist=Joe;be.stringifyObj=Xoe;be.ms_to_time=Zoe;be.changeExtension=eae;be.getEnvCliRootPath=oN;be.noBootFile=tae;be.httpRequest=rae;be.transformReq=nae;be.convertToMS=sae;be.PACKAGE_ROOT=loe;function Toe(e){return e instanceof Error?e:new Error(e)}o(Toe,"errorizeMessage");function ps(e){return e==null}o(ps,"isEmpty");function yoe(e){return!ps(e)&&(e||e===0||e===""||LG(e))}o(yoe,"isNotEmptyAndHasValue");function no(e){return ps(e)||e.length===0||e.size===0}o(no,"isEmptyOrZeroLength");function Roe(e){if(ps(e))return!0;for(let t=0;t<e.length;t++)if(ps(e[t]))return!0;return!1}o(Roe,"arrayHasEmptyValues");function boe(e){if(no(e))return!0;for(let t=0;t<e.length;t++)if(no(e[t]))return!0;return!1}o(boe,"arrayHasEmptyOrZeroLengthValues");function Aoe(...e){try{return e.join(tc.sep)}catch{console.error(e)}}o(Aoe,"buildFolderPath");function LG(e){return ps(e)?!1:e===!0||e===!1}o(LG,"isBoolean");function Ioe(e){return ps(e)?!1:typeof e=="object"}o(Ioe,"isObject");function woe(e){return no(e)?goe:e.slice(0,-Soe)}o(woe,"stripFileExtension");function Noe(e){return ps(e)||e===""||typeof e!="string"?e:CG[e]!==void 0?CG[e]:MG(e)===!0?Number(e):hoe.test(e)?new Date(e):e}o(Noe,"autoCast");function DG(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}o(DG,"autoCastJSON");function iN(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=iN(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=iN(r);n!==r&&(e[t]=n)}return e}else return DG(e)}o(iN,"autoCastJSONDeep");function MG(e){if(e.startsWith("0.")&&NG(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&NG(e))}o(MG,"autoCasterIsNumberCheck");async function Coe(e){if(no(e))throw new Error(`Directory path: ${e} does not exist`);try{await IG.emptyDir(e),await IG.remove(e)}catch(t){throw $n.error(`Error removing files in ${e} -- ${t}`),t}}o(Coe,"removeDir");function Ooe(e,t){if(no(e)){$n.info("Invalid current version sent as parameter.");return}if(no(t)){$n.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,a=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(a.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(a[u],10)-parseInt(c[u],10),r)return r;return a.length-c.length}o(Ooe,"compareVersions");function Poe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}o(Poe,"isCompatibleDataVersion");function Loe(e){if(ps(e))return e;let t=String(e);return t==="."?Cr.UNICODE_PERIOD:t===".."?Cr.UNICODE_PERIOD+Cr.UNICODE_PERIOD:t.replace(Cr.FORWARD_SLASH_REGEX,Cr.UNICODE_FORWARD_SLASH)}o(Loe,"escapeRawValue");function Doe(e){if(ps(e))return e;let t=String(e);return t===Cr.UNICODE_PERIOD?".":t===Cr.UNICODE_PERIOD+Cr.UNICODE_PERIOD?"..":String(e).replace(Cr.ESCAPED_FORWARD_SLASH_REGEX,"/")}o(Doe,"unescapeValue");function Moe(e,t){if(ps(e))return $n.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let a of i)r+=";"+a+aS.EOL}!no(n)&&n[0]===";"?r+=" "+n+s+aS.EOL:no(n)||(r+=n+"="+s+aS.EOL)}catch{$n.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}o(Moe,"stringifyProps");function vG(){let e;try{e=aS.homedir()}catch{e=process.env.HOME}return e}o(vG,"getHomeDir");function voe(){let e=tc.join(vG(),Cr.HDB_HOME_DIR_NAME,Cr.BOOT_PROPS_FILE_NAME);return OG.existsSync(e)||(e=tc.join(__dirname,"../","hdb_boot_properties.file")),e}o(voe,"getPropsFilePath");function Uoe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:o(function(){clearTimeout(r)},"cancel")}}o(Uoe,"timeoutPromise");async function xoe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=aoe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}o(xoe,"isPortTaken");function Boe(e){try{return Cr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){$n.error(`Error checking operation against cluster ops ${t}`)}return!1}o(Boe,"isClusterOperation");function Foe(e,t){let r=(we(),M(ft)).getDatabases();if(!r[e])return lS.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return lS.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}o(Foe,"checkGlobalSchemaTable");function koe(e,t){if(ps(t)){$n.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ps(e)||no(e)){$n.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){$n.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){$n.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}o(koe,"getClusterUser");function Hoe(){wG.parsePromise=function(e,t,r){return new Promise(function(n,s){wG.parse(e,{header:!0,transformHeader:UG,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}o(Hoe,"promisifyPapaParse");function UG(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}o(UG,"removeBOM");function Goe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;$n.info(`Got cluster status event response: ${doe(s)}`);try{i.cancel()}catch{$n.error("Error trying to cancel timeout.")}n(s)})})}o(Goe,"createEventPromise");async function qoe(e){let t=!0,r=0;do await PG(Eoe*r++),(await uoe.findPs(e)).length>0&&(t=!1);while(t&&r<_oe);if(t)throw new Error(`process ${e} was not started`)}o(qoe,"checkProcessRunning");function $oe(e,t){let r=xG(e);if(r)return r;let n=BG(e,t);if(n)return n}o($oe,"checkSchemaTableExist");function xG(e){let{getDatabases:t}=(we(),M(ft));if(!t()[e])return lS.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}o(xG,"checkSchemaExists");function BG(e,t){let{getDatabases:r}=(we(),M(ft));if(!r()[e][t])return lS.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}o(BG,"checkTableExists");function Voe(){let e=cS().utc().add(1,"d").startOf("d").unix(),t=cS().utc().unix();return e-t}o(Voe,"getStartOfTomorrowInSeconds");function Koe(){return cS().utc().format("DD-MM-YYYY")}o(Koe,"getLimitKey");function Yoe(e){try{let t=new coe(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){$n.error("Got an error back ticking items."),$n.error(t)}}o(Yoe,"backtickASTSchemaItems");function Woe(e){return[e]}o(Woe,"createForkArgs");function zoe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}o(zoe,"autoCastBoolean");function joe(e,t){let{getDatabases:r}=(we(),M(ft)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}o(joe,"getTableHashAttribute");function Qoe(e){let{getDatabases:t}=(we(),M(ft));return t()[e]!==void 0}o(Qoe,"doesSchemaExist");function Joe(e,t){let{getDatabases:r}=(we(),M(ft));return r()[e]?.[t]!==void 0}o(Joe,"doesTableExist");function Xoe(e){try{return JSON.stringify(e)}catch{return e}}o(Xoe,"stringifyObj");function Zoe(e){let t=cS.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}o(Zoe,"ms_to_time");function eae(e,t){let r=tc.basename(e,tc.extname(e));return tc.join(tc.dirname(e),r+t)}o(eae,"changeExtension");function oN(){if(process.env[Cr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Cr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=foe(process.argv);if(e[Cr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Cr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}o(oN,"getEnvCliRootPath");var sN;function tae(){if(sN)return sN;let e=oN();if(oN()&&OG.pathExistsSync(tc.join(e,Cr.HDB_CONFIG_FILE)))return sN=!0,!0}o(tae,"noBootFile");function rae(e,t){let r;return e.protocol==="http:"?r=poe:r=moe,new Promise((n,s)=>{let i=r.request(e,a=>{a.setEncoding("utf8"),a.body="",a.on("data",c=>{a.body+=c}),a.on("end",()=>{n(a)})});i.on("error",a=>{s(a)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}o(rae,"httpRequest");function nae(e){if(!e.schema&&!e.database){e.schema=Cr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}o(nae,"transformReq");function sae(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}o(sae,"convertToMS");var lS=zr()});var $G=v((zMe,qG)=>{"use strict";var{promises:yd,createReadStream:iae,createWriteStream:oae}=require("fs"),{createGzip:aae}=require("zlib"),{promisify:cae}=require("util"),{pipeline:lae}=require("stream"),uae=cae(lae),cN=require("path"),GG=me();GG.initSync();var uS=Q(),{CONFIG_PARAMS:dae,ITC_EVENT_TYPES:YMe}=(q(),M(z)),{onMessageFromWorkers:WMe}=nt(),{convertToMS:FG}=ae(),{onStorageReclamation:fae}=(P_(),M(OU)),mae=6e4,pae="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",hae="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",aN,kG;qG.exports=Eae;function Eae({logger:e,maxSize:t,interval:r,retention:n,enabled:s,path:i,auditInterval:a}){if(s===!1)return;let c=0;if(fae(e.path,f=>{c=f},!0),!t&&!r)throw new Error(pae);if(!i)throw new Error(hae);let l;if(t){let f=t.slice(-1),m=t.slice(0,-1);f==="G"?l=m*1e9:f==="M"?l=m*1e6:l=m*1e3}let u;r&&(u=FG(r));let d;return aN=Date.now(),uS.trace("Log rotate enabled, maxSize:",t,"interval:",r),kG=setInterval(async()=>{if(l){let f;f=await yd.stat(e.path),f.size>=l&&(d=await HG(e.path,i))}if(u&&Date.now()-aN>=u&&(d=await HG(e.path,i),aN=Date.now()),n||c){let f=FG(n??"1M")/(1+c);c=0;let m=await yd.readdir(i);for(let p of m)try{let h=await yd.stat(cN.join(i,p));Date.now()-h.mtimeMs>f&&await yd.unlink(cN.join(i,p))}catch(h){uS.error("Error trying to remove log",p,h)}}},a??mae).unref(),{end(){clearInterval(kG)},getLastRotatedLogPath(){return d}}}o(Eae,"logRotator");async function HG(e,t){let r=GG.get(dae.LOGGING_ROTATION_COMPRESS),n=cN.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);return await yd.rename(e,n),r&&(e=n,n+=".gz",await uae(iae(e),aae(),oae(n)),await yd.unlink(e)),uS.closeLogFile(),uS.notify(`hdb.log rotated, old log moved to ${n}`),n}o(HG,"moveLogFile")});var zG={};Re(zG,{RootConfigWatcher:()=>lN});var VG,KG,YG,dS,WG,lN,jG=se(()=>{VG=b(require("chokidar")),KG=require("node:fs/promises"),YG=b(St()),dS=require("node:stream"),WG=require("yaml"),lN=class extends dS.EventEmitter{static{o(this,"RootConfigWatcher")}#e;#t;#r;ready;constructor(){super(),this.#e=(0,YG.getConfigFilePath)(),this.ready=(0,dS.once)(this,"ready"),this.#t=VG.default.watch(this.#e,{persistent:!1}).on("add",this.handleChange.bind(this)).on("change",this.handleChange.bind(this)).on("error",this.handleError.bind(this))}handleError(t){this.emit("error",t)}handleChange(){(0,KG.readFile)(this.#e,"utf-8").then(t=>{if(!t)return;let r=(0,WG.parse)(t);if(!this.#r){this.#r=r,this.emit("ready",this.#r);return}this.emit("change",this.#r=r)}).catch(t=>{})}close(){return this.#t.close(),this.#r=void 0,this.emit("close"),this.removeAllListeners(),this}get config(){return this.#r}}});var Q=v((ZMe,SS)=>{"use strict";var Yo=require("fs-extra"),{workerData:_ae,threadId:gae,isMainThread:tq}=require("worker_threads"),Hp=require("path"),rq=require("yaml"),nq=require("properties-reader"),$r=(q(),M(z)),QG=$c(),Sae=require("os"),{PACKAGE_ROOT:_N}=Ct(),{_assignPackageExport:Tae}=si(),{Console:yae}=require("console"),dN=process.env.IS_SCRIPTED_SERVICE?function(){}:process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),JG=new Map,{join:Wo}=Hp,XG=1e4,sr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},Rae={STDOUT:"stdOut",STDERR:"stdErr"},XMe=Wo(_N,"logs"),bae=Wo(_N,"config/yaml/",$r.HDB_DEFAULT_CONFIG_FILE),Aae=1e4,Gp,qp,fS,so,fN,uN,pS,Lt,hs,hS,ES,Rd,kp,Fp;function mS(e,t,r){e.rotation=t.rotation;let n=t.path;n?t.root||(t.root=Hp.dirname(n)):t.root?n=Wo(t.root,fN):(n=Lt.path,t.root||(t.root=Hp.dirname(n))),n?e.path=n:console.error("No path for logger",t),e.level=sr[t.level]??Lt?.level??sr.info,sq(e),e.logToStdstreams=t.stdStreams??!1,e.tag=t.tag??(Lt.path===e.path&&r)}o(mS,"updateLogger");function sq(e){let t=e.conditional??(e.conditional={});t.notify=sr.notify>=e.level?e.notify.bind(e):void 0,t.fatal=sr.fatal>=e.level?e.fatal.bind(e):void 0,t.error=sr.error>=e.level?e.error.bind(e):void 0,t.warn=sr.warn>=e.level?e.warn.bind(e):void 0,t.info=sr.info>=e.level?e.info.bind(e):void 0,t.debug=sr.debug>=e.level?e.debug.bind(e):void 0,t.trace=sr.trace>=e.level?e.trace.bind(e):void 0}o(sq,"updateConditional");async function mN(){Fp||(Fp=new Vae,await Fp.ready,Fp.on("change",mN));let e=Fp.config,t=e.logging??{};mS(Lt,t),pS=Lt.path,Gp=t.console??!1,t.external&&mS(hs,t.external);for(let r in e){let n=e[r];n.logging?mS(Lt.forComponent(r),n.logging,r):Lt.hasComponent(r)&&mS(Lt.forComponent(r),t,r)}}o(mN,"updateLogSettings");var pN=class extends yae{static{o(this,"HarperLogger")}constructor(t,r){t.stdout.removeListener=()=>{},t.stderr.removeListener=()=>{},t.stdout.listenerCount=()=>{},t.stderr.listenerCount=()=>{},super(t),this.level=r}trace(...t){Tn="trace",this.level<=sr.trace&&super.info(...t),Tn="info"}debug(...t){Tn="debug",this.level<=sr.debug&&super.info(...t),Tn="info"}info(...t){Tn="info",this.level<=sr.info&&super.info(...t),Tn="info"}warn(...t){Tn="warn",this.level<=sr.warn&&super.warn(...t),Tn="info"}error(...t){Tn="error",this.level<=sr.error&&super.error(...t),Tn="info"}fatal(...t){Rd=!0;try{Tn="fatal",this.level<=sr.fatal&&super.error(...t),Tn="info"}finally{Rd=!1}}notify(...t){Rd=!0;try{Tn="notify",this.level<=sr.notify&&super.info(...t),Tn="info"}finally{Rd=!1}}withTag(t){return oq(t,!0,this)}forComponent(t){return this}hasComponent(t){return!1}};kp===void 0&&iq();SS.exports={notify:Mae,fatal:vae,error:EN,warn:Uae,info:Pae,debug:Dae,trace:Lae,logLevel:so,loggerWithTag:oq,suppressLogging:Cae,initLogSettings:iq,logCustomLevel:xae,closeLogFile:aq,createLogger:gS,logsAtLevel:wae,getLogFilePath:o(()=>pS,"getLogFilePath"),forComponent:o(e=>Lt.forComponent(e),"forComponent"),setMainLogger:qae,setLogLevel:Fae,OUTPUTS:Rae,AuthAuditLog:$ae,start:mN,startOnMainThread:mN,errorToString:Gae,disableStdio:Iae};function Iae(){dN=o(function(){},"nativeStdWrite")}o(Iae,"disableStdio");SS.exports.externalLogger={notify(...e){hs.notify(...e)},fatal(...e){hs.fatal(...e)},error(...e){hs.error(...e)},warn(...e){hs.warn(...e)},info(...e){hs.info(...e)},debug(...e){hs.debug(...e)},trace(...e){hs.trace(...e)},withTag(e){return hs.withTag(e)}};Tae("logger",SS.exports.externalLogger);function wae(e){return sr[so]<=sr[e]}o(wae,"logsAtLevel");function iq(e=!1){try{if(kp===void 0||e){aq();let t=Bae(),r=QG(["ROOTPATH"]);try{kp=nq(t)}catch(s){if(!r.ROOTPATH||r.ROOTPATH&&!Yo.pathExistsSync(Wo(r.ROOTPATH,$r.HDB_CONFIG_FILE)))throw s}let n;if({level:so,configLogPath:uN,toFile:qp,logConsole:Gp,rotation:n,toStream:fS}=kae(r.ROOTPATH?Wo(r.ROOTPATH,$r.HDB_CONFIG_FILE):kp.get("settings_path")),fN=$r.LOG_NAMES.HDB,pS=Wo(uN,fN),Lt=gS({path:pS,level:so,stdStreams:fS,rotation:n}),hs=Lt.forComponent("external"),hs.tag=null,tq)try{require("segfault-handler").registerHandler(Wo(uN,"crash.log"))}catch{}}}catch(t){if(kp=void 0,t.code===$r.NODE_ERROR_CODES.ENOENT||t.code===$r.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=QG(Object.keys($r.CONFIG_PARAM_MAP),!0);for(let s in r){let i=$r.CONFIG_PARAM_MAP[s];i&&i.toLowerCase();let a=r[s];if(i===$r.CONFIG_PARAMS.LOGGING_LEVEL){so=a;continue}i===$r.CONFIG_PARAMS.LOGGING_CONSOLE&&(Gp=i)}let{defaultLevel:n}=Hae();qp=!1,fS=!0,so=so===void 0?n:so,Lt=gS({level:so}),hs=Lt.forComponent("external"),hs.tag=null;return}throw EN("Error initializing log settings"),EN(t),t}process.env.DEV_MODE&&(fS=!0),Nae()}o(iq,"initLogSettings");var rc=!0;function Nae(){qp&&(process.stdout.write=function(e){return typeof e=="string"&&rc&&Gp&&(e=e.toString(),e[e.length-1]===`
|
|
16
|
+
`)}}});var UH,Il,xH,Ja,Tp,fd,gie,Hg,Vw=se(()=>{UH=b(ss()),Il=b(nt());q();xH=b(Xn());cd();kg();Ja=(0,xH.loggerWithTag)("componentStatus.crossThread"),Tp=class{static{o(this,"CrossThreadStatusCollector")}awaitingResponses=new Map;responseCheckers=new Map;nextRequestId=1;listenerAttached=!1;timeout;cleanupTimer=null;constructor(t=5e3){this.timeout=t}attachListener(){this.listenerAttached||((0,Il.onMessageByType)(t_.COMPONENT_STATUS_RESPONSE,({message:t})=>{let r=t.isMainThread?"main":`worker-${t.workerIndex}`;Ja.trace?.("Received component status response from %s, with requestId: %d",r,t.requestId);let n=this.awaitingResponses.get(t.requestId);if(n){n.push({workerIndex:t.workerIndex,isMainThread:t.isMainThread||!1,statuses:t.statuses||[]});let s=this.responseCheckers.get(t.requestId);s&&s()}}),this.listenerAttached=!0)}scheduleCleanup(){this.cleanupTimer&&clearTimeout(this.cleanupTimer),this.awaitingResponses.size>0&&(this.cleanupTimer=setTimeout(()=>{this.awaitingResponses.size>0&&(Ja.debug?.(`Cleaning up ${this.awaitingResponses.size} stale pending requests`),this.awaitingResponses.clear()),this.cleanupTimer=null},3e4))}async collect(t){try{this.attachListener(),this.scheduleCleanup();let r=this.nextRequestId++,n=[];this.awaitingResponses.set(r,n);let a=((0,Il.getWorkerCount)()||1)+1-1,l=await new Promise((p,h)=>{let E=!1,g=o(()=>{let y=this.awaitingResponses.get(r);y&&y.length>=a&&!E&&(E=!0,S(),Ja.trace?.(`Collected all ${y.length} expected responses for request ${r}`),p(y))},"checkComplete"),R=setTimeout(()=>{if(!E){E=!0;let y=this.awaitingResponses.get(r)||[];this.awaitingResponses.delete(r),Ja.debug?.(`Collection timeout for request ${r}: collected ${y.length}/${a} responses`),p(y)}},this.timeout),S=o(()=>{this.awaitingResponses.delete(r),clearTimeout(R)},"cleanup");this.responseCheckers.set(r,g),(0,UH.sendItcEvent)({type:t_.COMPONENT_STATUS_REQUEST,message:{requestId:r}}).then(()=>{g()}).catch(y=>{E=!0,S(),this.responseCheckers.delete(r),h(new ud("sendItcEvent",y))})});this.responseCheckers.delete(r);let u=new Map,d=t.getAllStatuses(),f=(0,Il.getWorkerIndex)(),m=f===void 0?"main":`worker-${f}`;for(let[p,h]of d)u.set(`${p}@${m}`,{...h,workerIndex:f});for(let p of l)for(let[h,E]of p.statuses){let g=p.isMainThread?"main":`worker-${p.workerIndex}`;u.set(`${h}@${g}`,{...E,workerIndex:p.workerIndex})}return Ja.debug?.(`Collected component status from ${l.length+1} threads (including local)`),u}catch(r){return r instanceof ud?Ja.error?.(`ITC failure during component status collection: ${r.message}`):Ja.warn?.("Failed to collect component status from all threads:",r),Ja.debug?.(`Collection failed for request. Error: ${r instanceof Error?r.message:"Unknown error"}`),this.getLocalStatusOnly(t)}}getLocalStatusOnly(t){let r=t.getAllStatuses(),n=new Map,s=(0,Il.getWorkerIndex)(),i=s===void 0?"main":`worker-${s}`;for(let[a,c]of r)n.set(`${a}@${i}`,{...c,workerIndex:s});return n}cleanup(){this.awaitingResponses.clear(),this.responseCheckers.clear(),this.cleanupTimer&&(clearTimeout(this.cleanupTimer),this.cleanupTimer=null)}},fd=class{static{o(this,"StatusAggregator")}static aggregate(t){let r=new Map,n=new Map;for(let[s,i]of t){let a=s.indexOf("@"),c=a!==-1?s.substring(0,a):s,l=n.get(c);l||(l=[],n.set(c,l)),l.push([s,i])}for(let[s,i]of n){let a=this.aggregateComponentGroup(s,i);r.set(s,a)}return r}static aggregateComponentGroup(t,r){let n={workers:{}},s=0,i,a,c=new Map,l=new Map;for(let[m,p]of r){let h=m.lastIndexOf("@"),E=h!==-1?m.substring(h+1):"",g=p.lastChecked instanceof Date?p.lastChecked.getTime():new Date(p.lastChecked).getTime();if(E==="main")n.main=g;else if(E&&E.startsWith("worker-")){let R=parseInt(E.substring(7));isNaN(R)||(n.workers[R]=g)}c.set(p.status,(c.get(p.status)||0)+1),p.status!==Ie.HEALTHY&&p.message&&(!i||g>s)&&(s=g,i=p.message),p.error&&!a&&(a=p.error)}let u=this.determineOverallStatus(c);if(Array.from(c.keys()).length>1)for(let[m,p]of r)p.status!==u&&l.set(m,{workerIndex:p.workerIndex!==void 0?p.workerIndex:-1,status:p.status,message:p.message,error:p.error});let f={componentName:t,status:u,lastChecked:n,latestMessage:i,error:a};return l.size>0&&(f.abnormalities=l),f}static determineOverallStatus(t){let r=[Ie.ERROR,Ie.WARNING,Ie.LOADING,Ie.UNKNOWN,Ie.HEALTHY];for(let n of r)if(t.has(n)&&t.get(n)>0)return n;return Ie.UNKNOWN}},gie=parseInt(process.env.COMPONENT_STATUS_TIMEOUT||"5000"),Hg=new Tp(gie)});var Xa,Gg=se(()=>{Hw();cd();Vw();kg();Xa=class e{static{o(this,"ComponentStatusRegistry")}statusMap=new Map;reset(){this.statusMap=new Map}setStatus(t,r,n,s){if(!t||typeof t!="string")throw new dd(String(t),"setStatus","Component name must be a non-empty string");if(!Object.values(Ie).includes(r))throw new dd(t,"setStatus",`Invalid status level: ${r}. Must be one of: ${Object.values(Ie).join(", ")}`);this.statusMap.set(t,new ld(r,n,s))}getStatus(t){return this.statusMap.get(t)}getAllStatuses(){return this.statusMap}reportHealthy(t,r){this.setStatus(t,Ie.HEALTHY,r)}reportError(t,r,n){this.setStatus(t,Ie.ERROR,n,r)}reportWarning(t,r){this.setStatus(t,Ie.WARNING,r)}initializeLoading(t,r){this.setStatus(t,Ie.LOADING,r||"Component is loading")}markLoaded(t,r){this.setStatus(t,Ie.HEALTHY,r||"Component loaded successfully")}markFailed(t,r,n){this.setStatus(t,Ie.ERROR,n,r)}getComponentsByStatus(t){let r=[];for(let[n,s]of this.statusMap)s.status===t&&r.push({name:n,status:s});return r}getStatusSummary(){let t={[Ie.HEALTHY]:0,[Ie.ERROR]:0,[Ie.WARNING]:0,[Ie.LOADING]:0,[Ie.UNKNOWN]:0};for(let r of this.statusMap.values())t[r.status]++;return t}static async getAggregatedFromAllThreads(t){let r=await Hg.collect(t);return fd.aggregate(r)}async getAggregatedStatusFor(t,r){r||(r=await e.getAggregatedFromAllThreads(this));let n=[],s=t+".",i=r.get(t);i&&n.push({key:t,...i});for(let[f,m]of r)f.startsWith(s)&&n.push({key:f,...m});if(n.length===0)return{status:Ie.UNKNOWN,message:"The component has not been loaded yet (may need a restart)",lastChecked:{workers:{}}};let a=n.some(f=>f.status===Ie.ERROR),c=n.some(f=>f.status===Ie.LOADING),l=a?Ie.ERROR:c?Ie.LOADING:Ie.HEALTHY,u="All components loaded successfully",d={};if(a||c){u=n.filter(m=>m.status===Ie.ERROR||m.status===Ie.LOADING).map(m=>`${m.key}: ${m.latestMessage||m.status}`).join("; ");for(let m of n)m.status!==Ie.HEALTHY&&(d[m.key]={status:m.status,message:m.latestMessage})}return{status:l,message:u,...Object.keys(d).length>0&&{details:d},lastChecked:n[0]?.lastChecked||{workers:{}}}}}});var mr,qg=se(()=>{Gg();mr=new Xa});function FH(e){let t=BH.get(e);return t||(t=new Kw(e),BH.set(e,t)),t}function kH(){mr.reset()}var Kw,BH,to,HH,GH=se(()=>{qg();cd();Kw=class{static{o(this,"ComponentStatusBuilder")}componentName;constructor(t){this.componentName=t}healthy(t){return mr.setStatus(this.componentName,Ie.HEALTHY,t),this}warning(t){return mr.setStatus(this.componentName,Ie.WARNING,t),this}error(t,r){return mr.setStatus(this.componentName,Ie.ERROR,t,r),this}loading(t){return mr.setStatus(this.componentName,Ie.LOADING,t||"Loading..."),this}unknown(t){return mr.setStatus(this.componentName,Ie.UNKNOWN,t),this}get(){return mr.getStatus(this.componentName)}},BH=new Map;o(FH,"statusForComponent");to={loading(e,t){mr.initializeLoading(e,t)},loaded(e,t){mr.markLoaded(e,t)},failed(e,t,r){mr.markFailed(e,t,r)}};o(kH,"reset");HH=Ie});var yp={};Re(yp,{AggregationError:()=>qw,COMPONENT_STATUS_LEVELS:()=>Ie,ComponentStatus:()=>ld,ComponentStatusError:()=>Qa,ComponentStatusOperationError:()=>dd,ComponentStatusRegistry:()=>Xa,CrossThreadCollectionError:()=>$w,CrossThreadStatusCollector:()=>Tp,CrossThreadTimeoutError:()=>Gw,ITCError:()=>ud,StatusAggregator:()=>fd,componentStatusRegistry:()=>mr,crossThreadCollector:()=>Hg,query:()=>Sie});var Sie,qH=se(()=>{qg();Gg();Hw();Gg();Vw();qg();kg();cd();Sie={get(e){return mr.getStatus(e)},all(){return mr.getAllStatuses()},byStatus(e){return mr.getComponentsByStatus(e)},summary(){return mr.getStatusSummary()},async allThreads(){return Xa.getAggregatedFromAllThreads(mr)}}});var Yw={};Re(Yw,{STATUS:()=>HH,internal:()=>yp,lifecycle:()=>to,reset:()=>kH,statusForComponent:()=>FH});var Rp=se(()=>{GH();qH()});var Ap=v((JDe,KH)=>{"use strict";var fs=Q(),gn=(q(),M(z)),Tie=u0(),yie=ds(),{validateEvent:Ww}=ss(),bp=as(),Rie=require("process"),{resetDatabases:bie}=(we(),M(ft)),Aie={[gn.ITC_EVENT_TYPES.SCHEMA]:Iie,[gn.ITC_EVENT_TYPES.USER]:VH,[gn.ITC_EVENT_TYPES.COMPONENT_STATUS_REQUEST]:Nie};async function Iie(e){let t=Ww(e);if(t){fs.error(t);return}fs.trace("ITC schemaHandler received schema event:",e),await Tie(e.message),await wie(e.message)}o(Iie,"schemaHandler");async function wie(e){try{bp.resetReadTxn(gn.SYSTEM_SCHEMA_NAME,gn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),bp.resetReadTxn(gn.SYSTEM_SCHEMA_NAME,gn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),bp.resetReadTxn(gn.SYSTEM_SCHEMA_NAME,gn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=bie();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){fs.error(t)}}o(wie,"syncSchemaMetadata");var $H=[];async function VH(e){try{try{bp.resetReadTxn(gn.SYSTEM_SCHEMA_NAME,gn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),bp.resetReadTxn(gn.SYSTEM_SCHEMA_NAME,gn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){fs.warn(r)}let t=Ww(e);if(t){fs.error(t);return}fs.trace(`ITC userHandler ${gn.HDB_ITC_CLIENT_PREFIX}${Rie.pid} received user event:`,e),await yie.setUsersWithRolesCache();for(let r of $H)r()}catch(t){fs.error(t)}}o(VH,"userHandler");VH.addListener=function(e){$H.push(e)};async function Nie(e){try{let t=Ww(e);if(t){fs.error(t);return}fs.trace("ITC componentStatusRequestHandler received request:",e);let{internal:r}=(Rp(),M(Yw)),{getWorkerIndex:n}=nt(),{sendItcEvent:s}=ss(),i=r.componentStatusRegistry.getAllStatuses(),a=Array.from(i.entries()),c=n(),l=c===void 0,u=e.message.originator,d={type:gn.ITC_EVENT_TYPES.COMPONENT_STATUS_RESPONSE,message:{requestId:e.message.requestId,statuses:a,workerIndex:c,isMainThread:l}};u!==void 0&&threads.sendToThread(u,d)?fs.trace(`Sent component status response directly to thread ${u}`):(u===void 0?fs.debug("No originator threadId, falling back to broadcast"):fs.warn(`Failed to send direct response to thread ${u}, falling back to broadcast`),await s(d))}catch(t){fs.error("Error handling component status request:",t)}}o(Nie,"componentStatusRequestHandler");KH.exports=Aie});var ss=v((nMe,WH)=>{"use strict";var ZDe=Q(),zw=ae(),Cie=(q(),M(z)),{ITC_ERRORS:Ip}=zr(),{parentPort:eMe,threadId:Oie,isMainThread:Pie,workerData:tMe}=require("worker_threads"),{onMessageFromWorkers:Lie,broadcast:rMe,broadcastWithAcknowledgement:Die}=nt();WH.exports={sendItcEvent:Mie,validateEvent:YH,SchemaEventMsg:vie,UserEventMsg:Uie};var $g;Lie(async(e,t)=>{$g=$g||Ap(),YH(e),$g[e.type]&&await $g[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function Mie(e){return!Pie&&e.message&&(e.message.originator=Oie),Die(e)}o(Mie,"sendItcEvent");function YH(e){if(typeof e!="object")return Ip.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||zw.isEmpty(e.type))return Ip.MISSING_TYPE;if(!e.hasOwnProperty("message")||zw.isEmpty(e.message))return Ip.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||zw.isEmpty(e.message.originator))return Ip.MISSING_ORIGIN;if(Cie.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Ip.INVALID_EVENT(e.type)}o(YH,"validateEvent");function vie(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}o(vie,"SchemaEventMsg");function Uie(e){this.originator=e}o(Uie,"UserEventMsg")});var Ho=v((oMe,JH)=>{"use strict";var zH=(q(),M(z)),iMe=ae(),Vg=Q(),jH=Yx(),md,{sendItcEvent:QH}=ss();function xie(e){try{Vg.debug("signalSchemaChange called with message:",e),md=md||Ap();let t=new jH(zH.ITC_EVENT_TYPES.SCHEMA,e);return md.schema(t),QH(t)}catch(t){Vg.error(t)}}o(xie,"signalSchemaChange");function Bie(e){try{Vg.trace("signalUserChange called with message:",e),md=md||Ap();let t=new jH(zH.ITC_EVENT_TYPES.USER,e);return md.user(t),QH(t)}catch(t){Vg.error(t)}}o(Bie,"signalUserChange");JH.exports={signalSchemaChange:xie,signalUserChange:Bie}});function wp(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 XH(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new Fs(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 Fs,Np=se(()=>{Fs=class extends Map{static{o(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 a=i[1];if(n)r=(typeof a=="string"?a:a.join(", "))+", "+r;else if(typeof a=="string")r=[a,r];else{a.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};o(wp,"appendHeader");o(XH,"mergeHeaders")});function Kg(e,t,r=kie){let n;return function(...i){return n?n.length*jw>r?t(...i):new Promise((a,c)=>{n.push({args:i,fn(){try{let l=e(...i);a(l)}catch(l){c(l)}}})}):(n=[],s(performance.now(),i),e(...i))};function s(i,a){setImmediate(()=>{let c=performance.now();jw=(jw*4+c-i)/5;let l=n.shift();if(l){let{args:u,fn:d}=l;d(),s(c,u)}else n=null})}}var tG,Fie,kie,ZH,Hie,Qw,eG,jw,Jw=se(()=>{tG=b(Xn()),Fie=3e3,kie=2e4,ZH=0,Hie=3e4,Qw=3e3,eG=performance.now()+Qw,jw=0;o(Kg,"throttle");setInterval(()=>{let e=performance.now();e-eG-Qw>Fie&&ZH+Hie<e&&(tG.default.warn?.("JavaScript execution has taken too long and is not allowing proper event queue cycling, consider using 'await new Promise(setImmediate)' in code that will execute for a long duration"),ZH=e),eG=e},Qw).unref()});var fG={};Re(fG,{EVICTED:()=>ka,INVALIDATED:()=>vn,coerceType:()=>Wg,makeTable:()=>jg});function jg(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:a,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:f,splitSegments:m,replicate:p}=e,{expirationMS:h,evictionMS:E,audit:g,trackDeletes:R}=e;E??=0;let{attributes:S}=e;S||(S=[]);let y=wA(i,n,l),C,I,k={},J=Promise.resolve(),G,H,X;for(let K of S)(K.assignCreatedTime||K.name==="__createdtime__")&&(G=K),(K.assignUpdatedTime||K.name==="__updatedtime__")&&(H=K),K.expiresAt&&(X=K),K.isPrimaryKey&&(k=K);let W,ue=[],ce=[],te=1,ye=2,Ae={},Ye={},qe=864e5,Ar=0,tr,Wr,vr,_u=!1,Fc,xt,ri,Na=Nl.get(F.REPLICATION_DATABASES);if(Array.isArray(Na)){for(let K of Na)if(K.name===c&&K.replicateTo>=0){ri=K.replicateTo;break}}let GE=i.getRange({start:!1,end:!1}).constructor,jf=10,qE=6;g&&em(),Cm(i.env.path,K=>{if(I)return Oa(K)});class Qf extends ml{static{o(this,"Updatable")}getUpdatedTime(){return Ba.get(this.getRecord())?.version}getExpiresAt(){return Ba.get(this.getRecord())?.expiresAt}addTo(_,T){if(typeof T=="number"||typeof T=="bigint")this.set(_,new ap(T));else throw new Error("Can not add or subtract a non-numeric value")}subtractFrom(_,T){return this.addTo(_,-T)}}class Pe extends Hr{#e;#t;#r;#n;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=a;static databaseName=c;static attributes=S;static replicate=p;static sealed=f;static splitSegments=m??!0;static createdTimeProperty=G;static updatedTimeProperty=H;static propertyResolvers;static userResolvers={};static sources=[];static getResidencyById;static get expirationMS(){return h}static dbisDB=d;static schemaDefined=u;static sourcedFrom(_,T){if(T&&(this.sourceOptions=T,(T.expiration||T.eviction||T.scanInterval)&&this.setTTLExpiration(T)),T?.intermediateSource)_.intermediateSource=!0,this.sources.unshift(_);else{if(this.sources.some(L=>!L.intermediateSource)){if(this.sources.some(L=>L.name===_.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(_)}I=I||_.get&&(!_.get.reliesOnPrototype||_.prototype.get),C=C||_.load;let N=o(L=>{let A=this.sources;if(A=A.filter(U=>U.intermediateSource&&U[L]&&(!U[L].reliesOnPrototype||U.prototype[L])),A.length>0)if(A.length===1){let U=A[0];return(w,D,$)=>{if(w?.source!==U)return U[L](D,$,w)}}else return(U,w,D)=>{let $=[];for(let Y of A){if(U?.source===Y)break;$.push(Y[L](w,D,U))}return Promise.all($)}},"getApplyToIntermediateSource"),P=this.sources[this.sources.length-1];P.intermediateSource&&(P={});let O=o(L=>{if(P[L]&&(!P[L].reliesOnPrototype||P.prototype[L]))return(A,U,w)=>{if(!A?.source)return P[L](U,w,A)}},"getApplyToCanonicalSource");Ae={put:O("put"),patch:O("patch"),delete:O("delete"),publish:O("publish")},Ye={put:N("put"),patch:N("patch"),delete:N("delete"),publish:N("publish"),invalidate:N("invalidate")};let x=P.shouldRevalidateEvents;return(async()=>{let L=!1,A,U=o(async(w,D)=>{let $=w.value,Y=w.table?De[c][w.table]:Pe;if(c===im&&(w.table===bu.ROLE_TABLE_NAME||w.table===bu.USER_TABLE_NAME)&&(L=!0),w.id===void 0&&(w.id=$[Y.primaryKey],w.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(w));w.source=_;let j={residencyId:kc(w.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:w.nodeId,async:!0},B=w.id,Ee=await Y.getResource(B,D,j);switch(w.finished&&await w.finished,w.type){case"put":return x?Ee._writeInvalidate(B,$,j):Ee._writeUpdate(B,$,!0,j);case"patch":return x?Ee._writeInvalidate(B,$,j):Ee._writeUpdate(B,$,!1,j);case"delete":return Ee._writeDelete(B,j);case"publish":case"message":return Ee._writePublish(B,$,j);case"invalidate":return Ee._writeInvalidate(B,$,j);case"relocate":return Ee._writeRelocate(B,j);default:Fe.default.error?.("Unknown operation",w.type,w.id)}},"writeUpdate");try{let w=_.subscribe;w&&R==null&&(R=!0);let D={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},$=_.subscribeOnThisThread?_.subscribeOnThisThread((0,wl.getWorkerIndex)(),D):(0,wl.getWorkerIndex)()===0,Y=w&&$&&await _.subscribe?.(D);if(Y){let j;for await(let B of Y)try{if(!(B.type==="transaction"?B.writes[0]:B)){Fe.default.error?.("Bad subscription event",B);continue}if(B.source=_,B.type==="end_txn"){if(j?.resolve(),B.localTime&&A!==B.localTime){if(B.remoteNodeIds?.length>0){let pe=[Symbol.for("seq"),B.remoteNodeIds[0]],ne=d.get(pe),ie=ne?.nodes;ie||(ie=[]);for(let de of B.remoteNodeIds.slice(1)){let oe=ie.find(ke=>ke.id===de);ie=ie.filter(ke=>ke.id!==de||ke===oe),oe||(oe={id:de,seqId:0},ie.push(oe)),oe.seqId=Math.max(ne?.seqId??1,B.localTime),de===j?.nodeId&&(oe.lastTxnTime=B.timestamp)}let xe=Math.max(ne?.seqId??1,B.localTime);Fe.default.trace?.("Received txn",c,xe,new Date(xe),B.localTime,new Date(B.localTime),B.remoteNodeIds),d.put(pe,{seqId:xe,nodes:ie})}A=B.localTime}B.onCommit&&j?.committed.then(B.onCommit);continue}if(j)if(B.beginTxn)j.resolve();else{j.write_promises.push(U(B,j));continue}!B.timestamp&&B.version&&(B.timestamp=B.version);let fe=bt(B,()=>{if(B.type==="transaction"){let pe=[];for(let ne of B.writes)try{pe.push(U(ne,B))}catch(ie){throw ie.message+=" writing "+JSON.stringify(ne)+" of event "+JSON.stringify(B),ie}return Promise.all(pe)}else if(B.type==="define_schema"){let pe=this.attributes.slice(0),ne=!1;for(let ie of B.attributes)pe.find(xe=>xe.name===ie.name)||(pe.push(ie),ne=!0);ne&&(Ze({table:s,database:c,attributes:pe,origin:"cluster"}),Op.signalSchemaChange(new Pp.SchemaEventMsg(process.pid,V.CREATE_TABLE,c,s)))}else return B.beginTxn?(j=B,j.write_promises=[U(B,B)],new Promise(pe=>{j.resolve=()=>pe(Promise.all(j.write_promises))})):U(B,B)});j&&(j.committed=fe),L&&fe&&!fe?.waitingForUserChange&&(fe.then(()=>Op.signalUserChange(new Pp.UserEventMsg(process.pid))),fe.waitingForUserChange=!0),B.onCommit&&(fe?fe.then(B.onCommit):B.onCommit())}catch(Ee){Fe.default.error?.("error in subscription handler",Ee)}}}catch(w){Fe.default.error?.(w)}})(),this}static get isCaching(){return I}static get shouldRevalidateEvents(){return this.prototype.get!==Pe.prototype.get}static getResource(_,T,N){let P=super.getResource(_,T,N);if(this.loadAsInstance===!1&&(T._freezeRecords=!0),_!=null&&this.loadAsInstance!==!1){Ui(_);try{if(P.getRecord?.())return P;if(typeof _=="object"&&_&&!Array.isArray(_))throw new Error(`Invalid id ${JSON.stringify(_)}`);let O=!N?.async||i.cache?.get?.(_),x=Ur(T),L=x.getReadTxn();if(L?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Io(_,T,{transaction:L,ensureLoaded:N?.ensureLoaded},O,A=>{if(A?Pe._updateResource(P,A):P.#e=null,T.onlyIfCached){if(!P.doesExist())throw new lt.ServerError("Entry is not cached",504)}else if(N?.ensureLoaded){let U=dn(_,A,T,P);if(U)return x?.disregardReadTxn(),P.#i=!0,T.loadedFromSource=!0,ks(U,w=>(Pe._updateResource(P,w),P))}return P})}catch(O){throw O.message.includes("Unable to serialize object")&&(O.message+=": "+JSON.stringify(_)),O}}return P}static _updateResource(_,T){_.#n=T,_.#e=T?.value??null,_.#r=T?.version}ensureLoaded(){let _=dn(this.getId(),this.#n,this.getContext());if(_)return this.#i=!0,this.getContext().loadedFromSource=!0,ks(_,T=>{this.#n=T,this.#e=T.value,this.#r=T.version})}static getNewId(){let _=k?.type;if(_==="String"||_==="ID")return super.getNewId();if(!xt){let O=i.getEntry(Symbol.for("id_allocation")),x=O?.value,L;if(x&&x.nodeName===server.hostname&&(!Xie(i)||x.pid===process.pid)){let A=x.start,U=x.end;L=A;for(let w of i.getKeys({start:U,end:A,limit:1,reverse:!0}))L=w}else x=P(O?.version??null),L=x.start;xt=new BigInt64Array([BigInt(L)+1n]),xt=new BigInt64Array(i.getUserSharedBuffer("id",xt.buffer)),xt.maxSafeId=x.end}let T=Number(Atomics.add(xt,0,1n)),N=_==="Int"?512:1048576;if(T+N>=xt.maxSafeId){let O=o(x=>{xt.maxSafeId=T+(_==="Int"?1023:4194303);let L=(_==="Int"?Math.pow(2,31):Math.pow(2,49))-1,A=x?void 0:i.useReadTransaction(),U=Number(xt[0]);for(let $ of i.getKeys({start:U+1,end:L,limit:1,transaction:A}))L=$;A?.done();let{value:w,version:D}=i.getEntry(Symbol.for("id_allocation"));if(xt.maxSafeId<L){if(w.end>xt.maxSafeId-100)return;Fe.default.info?.("New id allocation",T,xt.maxSafeId,D),i.put(Symbol.for("id_allocation"),{start:w.start,end:xt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),D)}else{Fe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${xt.maxSafeId}, but id of ${L} detected`);let $=P(D);$.alreadyUpdated||Atomics.store(xt,0,BigInt($.start+1)),xt.maxSafeId=$.end}},"updateEnd");T+N===xt.maxSafeId?setImmediate(O):T+100>=xt.maxSafeId&&(Fe.default.warn?.(`Synchronous id allocation required on table ${s}${_=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>O(!0)))}return T;function P(O){let x=(_==="Int"?Math.pow(2,31):Math.pow(2,49))-1,L=x/4,A,U,w=!1,D,$;do{D=Math.floor(Math.random()*x),$={start:D,end:D+(_==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},A=0;for(let Y of i.getKeys({start:D,limit:1,reverse:!0}))A=Y;U=x;for(let Y of i.getKeys({start:D+1,end:x,limit:1}))U=Y;L*=.875,L<1e3&&!w&&(w=!0,Fe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${_==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,D,A,U,L))}while(!(L<U-D&&(L<D-A||A===0)));return i.transactionSync(()=>{let Y=i.getEntry(Symbol.for("id_allocation"));return(Y?.version??null)==O?(Fe.default.info?.("Allocated new id range",$),i.put(Symbol.for("id_allocation"),$,Date.now()),$):(Fe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...Y.value})})}}static setTTLExpiration(_){if(typeof _=="number")h=_*1e3,E||(E=0);else if(_&&typeof _=="object")h=_.expiration*1e3,E=(_.eviction||0)*1e3,qe=_.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");qe=qe||(h+E)/4,Oa()}static getResidencyRecord(_){return d.get([Symbol.for("residency_by_id"),_])}static setResidency(_){Pe.getResidency=_&&((T,N)=>{try{return _(T,N)}catch(P){throw P.message+=` in residency function for table ${s}`,P}})}static setResidencyById(_){Pe.getResidencyById=_&&(T=>{try{return _(T)}catch(N){throw N.message+=` in residency function for table ${s}`,N}})}static getResidency(_,T){if(Pe.getResidencyById)return Pe.getResidencyById(_[t]);let N=ri;if(T.replicateTo!=null){if(Array.isArray(T.replicateTo))return T.replicateTo.includes(server.hostname)?T.replicateTo:[server.hostname,...T.replicateTo];T.replicateTo>=0&&(N=T.replicateTo)}if(N>=0&&server.nodes){let P=[server.hostname];if(T.previousResidency)P.push(...T.previousResidency.slice(0,N));else{let O=server.nodes.map(A=>A.name),x=Math.floor(O.length*Math.random());P.push(...O.slice(x,x+N));let L=x+N-O.length;L>0&&P.push(...O.slice(0,L))}return P}}static enableAuditing(){g||(g=!0,em(),Pe.audit=!0)}static coerceId(_){return _===""?null:Wg(_,k)}static async dropTable(){delete De[c][s];for(let _ of i.getRange({versions:!0,snapshot:!1,lazy:!0}))_.metadataFlags&Jr&&_.value&&va(_.value);if(c===a){for(let _ of S)d.remove(Pe.tableName+"/"+_.name),r[_.name]?.drop();d.remove(Pe.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),Zw.default.unlinkSync(i.env.path);Op.signalSchemaChange(new Pp.SchemaEventMsg(process.pid,V.DROP_TABLE,c,s))}get(_){let T=this.constructor;if(typeof _=="string"&&T.loadAsInstance!==!1)return this.getProperty(_);if(Jf(_))return this.search(_);if(_&&_.id===void 0&&!_.toString()){let N={records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:S,recordCount:void 0,estimatedRecordRange:void 0};return this.getContext()?.includeExpensiveRecordCountEstimates?Pe.getRecordCount().then(P=>(N.recordCount=P.recordCount,N.estimatedRecordRange=P.estimatedRange,N)):N}if(_!==void 0&&T.loadAsInstance===!1){let N=this.getContext(),P=Ur(N),O=P.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");let x=Os(_);Ui(x);let L=!0;return _.checkPermission&&(L=this.allowRead(N.user,_)),ks(ks(L,A=>{if(!A)throw new lt.AccessViolation(N.user);let U=!0;return Io(x,N,{transaction:O,ensureLoaded:U},!1,w=>{if(N.onlyIfCached){if(!w?.value)throw new lt.ServerError("Entry is not cached",504)}else if(U){let D=dn(x,w,N);if(D)return P?.disregardReadTxn(),N.loadedFromSource=!0,D.then($=>$?.value)}return w?.value})}),A=>{let U=_?.select;return U&&A!=null?Vu(U,this.constructor)(A):A})}if(_?.property)return this.getProperty(_.property);if(this.doesExist()||_?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(_,T){let N=On(_,T);if(N?.read){if(N.isSuperUser)return!0;let P=N.attribute_permissions,O=T?.select;if(P?.length>0||_u&&O){if(T||(T={}),O){let x=P?.length>0&&Xw(P,"read");T.select=O.map(L=>{let A=L.name||L;if(!x||x[A]){let U=vr[A]?.definition?.tableClass;if(U){if(L.name||(L={name:L}),!L.checkPermission&&T.checkPermission&&(L.checkPermission=T.checkPermission),!U.prototype.allowRead.call(null,_,L))return!1;if(!L.select)return L.name}return L}}).filter(Boolean)}else T.select=P.filter(x=>x.read&&!vr[x.attribute_name]).map(x=>x.attribute_name);return T}else return!0}}allowUpdate(_,T,N){let P=On(_,N);if(P?.update){let O=P.attribute_permissions;if(O?.length>0){let x=Xw(O,"update");for(let L in T)if(!x[L])return!1;for(let L of O){let A=L.attribute_name;!L.update&&!(A in T)&&(T[A]=this.getProperty(A))}}return Ca(this.getContext())}}allowCreate(_,T,N){if(this.isCollection){let P=On(_,N);if(P?.insert){let O=P.attribute_permissions;if(O?.length>0){let x=Xw(O,"insert");for(let L in T)if(!x[L])return!1;return Ca(this.getContext())}else return Ca(this.getContext())}}else return this.allowUpdate(_,{})}allowDelete(_,T){return On(_,T)?.delete&&Ca(this.getContext())}update(_,T){let N,P=typeof T=="boolean"||T===void 0&&(_==null||typeof _=="object"&&!(_ instanceof URLSearchParams)),O=!1;P?(O=T,T=_,N=this.getId()):N=Os(_);let x=this.getContext();if(!Ur(x))throw new Error("Can not update a table resource outside of a transaction");if(T===!1)return this;if(typeof T=="object"&&T)if(O)Object.isFrozen(T)&&(T={...T}),this.#e={},this.#t=T;else if(P){let A=this.#t;A&&(T=Object.assign(A,T)),this.#t=T}else{let A=!0;if(_==null)throw new TypeError("Can not put a record without a target");return _.checkPermission&&(A=this.allowUpdate(x.user,T,_)),ks(A,U=>{if(!U)throw new lt.AccessViolation(x.user);return ks(i.get(Os(_)),w=>{let D=new Qf(w);return D._setChanges(T),this._writeUpdate(N,D.getChanges(),!1),D})})}return this._writeUpdate(N,this.#t,O),this}addTo(_,T){if(typeof T=="number"||typeof T=="bigint")this.#s===nG?this.set(_,(+this.getProperty(_)||0)+T):(this.#s||this.update(),this.set(_,new ap(T)));else throw new Error("Can not add a non-numeric value")}subtractFrom(_,T){if(typeof T=="number")return this.addTo(_,-T);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#n}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(_){this.#t=_}setRecord(_){this.#e=_}invalidate(_){let T=!0,N=this.getContext();return _?.checkPermission&&(T=this.allowDelete(N.user,_,N)),ks(T,P=>{if(!P)throw new lt.AccessViolation(N.user);this._writeInvalidate(_?Os(_):this.getId())})}_writeInvalidate(_,T,N){let P=this.getContext();Ui(_),Ur(this.getContext()).addWrite({key:_,store:i,invalidated:!0,entry:this.#n,before:Ae.invalidate?.bind(this,P,_),beforeIntermediate:yu(T,Ye.invalidate?.bind(this,P,_)),commit:o((x,L)=>{if(!(xr(x,L,N?.nodeId)<=0)){T??=null;for(let A in r)T||(T={}),T[A]===void 0&&(T[A]=this.getProperty(A));Fe.default.trace?.(`Invalidating entry in ${s} id: ${_}, timestamp: ${new Date(x).toISOString()}`),y(_,T,L,x,vn,g,{user:P?.user,residencyId:N?.residencyId,nodeId:N?.nodeId,tableToTrack:s},"invalidate")}},"commit")})}_writeRelocate(_,T){let N=this.getContext();Ui(_),Ur(this.getContext()).addWrite({key:_,store:i,invalidated:!0,entry:this.#n,before:Ae.relocate?.bind(this,N,_),beforeIntermediate:Ye.relocate?.bind(this,N,_),commit:o((O,x)=>{if(xr(O,x,T?.nodeId)<=0)return;let L=Pe.getResidencyRecord(T.residencyId),A=0,U=null,w=x?.value;if(L&&!L.includes(server.hostname)){for(let D in r)U||(U={}),U[D]=w[D];A=vn}else U=w;Fe.default.trace?.(`Relocating entry id: ${_}, timestamp: ${new Date(O).toISOString()}`),y(_,U,x,O,A,g,{user:N.user,residencyId:T.residencyId,nodeId:T.nodeId,expiresAt:T.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(_,T){let N={previousResidency:this.getResidencyRecord(_.residencyId),isRelocation:!0},P=Pa(this.getResidency(T.value,N)),O;if(P){if(!P.includes(server.hostname))return!1;O=kc(P)}let x=0;Fe.default.debug?.("Performing a relocate of an entry",existing_entry.key,T.value,P);let L=y(_.key,T.value,_,_.version,x,!0,{residencyId:O,expiresAt:T.expiresAt},"relocate",!1,null);return!0}static evict(_,T,N){let P=this.Source,O;if(!((I||g)&&(!T||(O=i.getEntry(_),!O||!T)||O.version!==N))){if(I){if(i.hasLock(_,O.version))return;let x;for(let L in r)x||(x={}),x[L]=T[L];if(x)return y(_,x,O,N,ka,null,null,null,!0)}if(i.ifVersion(_,N,()=>{gu(_,T,null)}),g)return y(_,null,O,N,ka,null,null,null,!0);nl(i,O??i.getEntry(_),N)}}lock(){throw new Error("Not yet implemented")}static operation(_,T){return _.table||=s,_.schema||=c,global.operation(_,T)}put(_,T){if(T===void 0||T instanceof URLSearchParams)this.update(_,!0);else{let N=!0;if(_==null)throw new TypeError("Can not put a record without a target");let P=this.getContext();return _.checkPermission&&(N=this.allowUpdate(P.user,T,_)),ks(N,O=>{if(!O)throw new lt.AccessViolation(P.user);if(Array.isArray(T))for(let x of T){let L=x[t];this._writeUpdate(L,x,!0)}else{let x=Os(_);this._writeUpdate(x,T,!0)}})}}create(_,T){let N=!0,P=this.getContext();if(!T&&!(_ instanceof URLSearchParams)&&(T=_,_=void 0),!T||typeof T!="object"||Array.isArray(T))throw new TypeError("Can not create a record without an object");return _?.checkPermission&&(N=this.allowCreate(P.user,T,_)),ks(N,O=>{if(!O)throw new lt.AccessViolation(P.user);let x=Os(_)??T[t];if(x===void 0)x=this.constructor.getNewId();else if(i.get(x))throw new lt.ClientError("Record already exists",409);return this._writeUpdate(x,T,!0),T})}patch(_,T){if(T===void 0||T instanceof URLSearchParams)this.update(_,!1);else{let N=this.update(_,T);if(N?.then)return N.then(()=>{})}}_writeUpdate(_,T,N,P){let O=this.getContext(),x=Ur(O);Ui(_);let L=this.#n??i.getEntry(_);this.#s=N?nG:zie;let A=o(w=>N?w.put?()=>w.put(O,_,T):null:w.patch?()=>w.patch(O,_,T):w.put?()=>w.put(O,_,pl(this)):null,"writeToSources"),U={key:_,store:i,entry:L,nodeName:O?.nodeName,validate:o(w=>{T||(T=this.#t),N||T&&yg(this.#t===T?this:T)?O?.source||(x.checkOverloaded(),this.validate(T,!N),H&&(T[H.name]=H.type==="Date"?new Date(w):H.type==="String"?new Date(w).toISOString():w),N&&(t&&T[t]!==_&&(T[t]=_),G&&(L?.value?T[G.name]=L?.value[G.name]:T[G.name]=G.type==="Date"?new Date(w):G.type==="String"?new Date(w).toISOString():w),T=pl(T))):x.removeWrite(U)},"validate"),before:A(Ae),beforeIntermediate:yu(T,A(Ye)),commit:o((w,D,$)=>{if($){if(O&&D?.version>(O.lastModified||0)&&(O.lastModified=D.version),this.#n=D,D?.value&&D.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");N||(this.#e=D?.value??null)}this.#t=void 0,this.#r=w;let Y=D?.value,j;this.#s=0;let B=!1,Ee=xr(w,D,P?.nodeId),fe;if(Ee<=0){if(g){let de=D.localTime,oe=D.version;Fe.default.trace?.("Applying CRDT update to record with id: ",_,"txn time",new Date(w),"applying later update from:",new Date(oe),"local recorded time",new Date(de));let ke=[];for(;de>w||oe>=w&&de>0;){let Be=l.get(de);if(!Be)break;let Le=At(Be);if(oe=Le.version,oe>=w){if(oe===w){if(Ee=xr(w,{version:oe,localTime:de},P?.nodeId),Ee===0)return;if(Ee>0)continue}if(Le.type==="patch")ke.push(Le),fe=T;else if(Le.type==="put"||Le.type==="delete")return}de=Le.previousLocalTime}de||Fe.default.debug?.("No further audit history, applying incremental updates based on available history",_,"existing version preserved",D),ke.sort((Be,Le)=>Be.version-Le.version);for(let Be of ke){let Le=Be.getValue(i);if(Fe.default.debug?.("Rebuilding update with future patch:",new Date(Be.version),Le,Be),j=f_(j??T,Le,N),!j)return}}else{if(N)return;j=f_(j??T,Y,N),Fe.default.debug?.("Rebuilding update without audit:",j)}Fe.default.trace?.("Rebuilt record to save:",j," is full update:",N)}let pe;if(N&&!j?pe=T:this.constructor.loadAsInstance===!1?pe=pl(Y,j??T):(this.#e=Y,pe=pl(this,j??T)),this.#e=pe,pe&&pe.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let ne;if(P?.residencyId!=null)ne=P.residencyId;else{L?.residencyId&&(O.previousResidency=Pe.getResidencyRecord(L.residencyId));let de=Pa(Pe.getResidency(pe,O));if(de&&!de.includes(server.hostname))if(fe??=pe,B=!0,Pe.getResidencyById)pe=void 0;else{pe=null;for(let oe in r)pe||(pe={}),pe[oe]=fe[oe]}ne=kc(de)}N||(fe=T);let ie=O?.expiresAt??(h?h+Date.now():-1);Fe.default.trace?.(`Saving record with id: ${_}, timestamp: ${new Date(w).toISOString()}${ie?", expires at: "+new Date(ie).toISOString():""}${D?", replaces entry from: "+new Date(D.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(pe).slice(0,100)}catch{return""}})()),gu(_,Y,pe);let xe=N?"put":"patch";y(_,pe,D,w,B?vn:0,g,{omitLocalRecord:B,user:O?.user,residencyId:ne,expiresAt:ie,nodeId:P?.nodeId,originatingOperation:O?.originatingOperation,tableToTrack:c==="system"?null:s},xe,!1,fe),O.expiresAt&&Oa()},"commit")};x.addWrite(U)}async delete(_){if(Jf(_)){_.select=["$id"];for await(let T of this.search(_))this._writeDelete(T.$id);return!0}if(_){let T=!0,N=this.getContext();return _.checkPermission&&(T=this.allowDelete(N.user,_,N)),ks(T,P=>{if(!P)throw new lt.AccessViolation(N.user);let O=Os(_);return this._writeDelete(O),!0})}return this._writeDelete(this.getId()),!!this.#e}_writeDelete(_,T){let N=Ur(this.getContext());Ui(_);let P=this.getContext();return N.addWrite({key:_,store:i,entry:this.#n,nodeName:P?.nodeName,before:Ae.delete?.bind(this,P,_),beforeIntermediate:Ye.delete?.bind(this,P,_),commit:o((O,x,L)=>{let A=x?.value;L&&(P&&x?.version>(P.lastModified||0)&&(P.lastModified=x.version),Pe._updateResource(this,x)),!(xr(O,x,T?.nodeId)<=0)&&(gu(this.getId(),A),Fe.default.trace?.(`Deleting record with id: ${_}, txn timestamp: ${new Date(O).toISOString()}`),g||R?(y(_,null,x,O,0,g,{user:P?.user,nodeId:T?.nodeId,tableToTrack:s},"delete"),g||Oa()):nl(i,x))},"commit")}),!0}search(_){let T=this.getContext(),N=Ur(T);if(!_)throw new Error("No query provided");if(_.parseError)throw _.parseError;if(_.checkPermission&&!this.allowRead(T.user,_))throw new lt.AccessViolation(T.user);T&&(T.lastModified=Vie);let P=_.conditions;P?P.length===void 0&&(P=P[Symbol.iterator]?Array.from(P):[P]):P=Array.isArray(_)?_:_[Symbol.iterator]?Array.from(_):[];let O=_.id??this.getId();O&&(P=[{attribute:null,comparator:Array.isArray(O)?"prefix":"starts_with",value:O}].concat(P));let x,L={};function A(ie,xe){let de;switch(xe){case"and":case void 0:if(ie.length<1)throw new Error('An "and" operator requires at least one condition');de=!0;break;case"or":if(ie.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+xe)}for(let oe of ie){if(oe.conditions){oe.conditions=A(oe.conditions,oe.operator);continue}let ke=oe[0]??oe.attribute,Be=ke==null?k:qi(S,ke);if(Be)(Be.type||CA[oe.comparator])&&(oe[1]===void 0?oe.value=w(oe.value,Be):oe[1]=w(oe[1],Be));else if(ke!=null&&!_.allowConditionsOnDynamicAttributes)throw(0,lt.handleHDBError)(new Error,`${ke} is not a defined attribute`,404);if(oe.chainedConditions)if(oe.chainedConditions.length===1&&(!oe.operator||oe.operator=="and")){let Le=oe.chainedConditions[0],Me,pt;if(Le.comparator==="gt"||Le.comparator==="greater_than"||Le.comparator==="ge"||Le.comparator==="greater_than_equal"?(Me=oe,pt=Le):(Me=Le,pt=oe),Me.comparator!=="lt"&&Me.comparator!=="less_than"&&Me.comparator!=="le"&&Me.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let wt=pt.comparator==="ge"||pt.comparator==="greater_than_equal",Et=Me.comparator==="le"||Me.comparator==="less_than_equal";oe.comparator=(wt?"ge":"gt")+(Et?"le":"lt"),oe.value=[pt.value,Me.value]}else throw new Error("Multiple chained conditions are not currently supported")}return ie}o(A,"prepareConditions");function U(ie,xe){if(_.enforceExecutionOrder)return ie;for(let de of ie)de.conditions&&(de.conditions=U(de.conditions,de.operator));return ie.length>1&&xe!=="or"?Gie(ie,Q_(Pe)):ie}o(U,"orderConditions");function w(ie,xe){return Array.isArray(ie)?ie.map(de=>Wg(de,xe)):Wg(ie,xe)}o(w,"coerceTypedValues");let D=_.operator;(P.length>0||D)&&(P=A(P,D));let $=typeof _.sort=="object"&&_.sort,Y;if($&&D!=="or"){let ie=$.attribute;if(ie==null)throw new lt.ClientError("Sort requires an attribute");if(x=P.find(xe=>Gu(xe.attribute)===Gu(ie)),!x){let xe=qi(S,ie);if(!xe)throw(0,lt.handleHDBError)(new Error,`${Array.isArray(ie)?ie.join("."):ie} is not a defined attribute`,404);if(xe.indexed)x={...$,comparator:"sort"},P.push(x);else if(P.length===0&&!_.allowFullScan)throw(0,lt.handleHDBError)(new Error,`${Array.isArray(ie)?ie.join("."):ie} is not indexed and not combined with any other conditions`,404)}x&&(x.descending=!!$.descending)}P=U(P,D),$&&(x&&P[0]===x?$.next&&(Y={dbOrderedAttribute:$.attribute,attribute:$.next.attribute,descending:$.next.descending,next:$.next.next}):(x&&P.splice(P.indexOf(x),1),Y=$));let j=_.select;if(P.length===0&&(P=[{attribute:t,comparator:"greater_than",value:!0}]),_.explain)return{conditions:P,operator:D,postOrdering:Y,selectApplied:!!j};let B=N.useReadTxn(),Ee=OA(P,D,Pe,B,_,T,(ie,xe)=>Zf(ie,j,T,B,xe),L),fe=_.ensureLoaded!==!1,pe=Pe.transformEntryForSelect(j,T,B,L,fe,!0),ne=Pe.transformToOrderedSelect(Ee,j,Y,T,B,pe);return(_.offset||_.limit!==void 0)&&(ne=ne.slice(_.offset,_.limit!==void 0?(_.offset||0)+_.limit:void 0)),ne.onDone=()=>{ne.onDone=null,N.doneReadTxn()},ne.selectApplied=!0,ne.getColumns=()=>{if(j){let ie=[];for(let xe of j)xe==="*"?ie.push(...S.map(de=>de.name)):ie.push(xe.name||xe);return ie}return S.filter(ie=>!ie.computed&&!ie.relationship).map(ie=>ie.name)},ne}static transformToOrderedSelect(_,T,N,P,O,x){let L=new GE;if(N){_=Zf(_,T,P,O,null);let A;L.iterate=function(){let w,D=_[Symbol.asyncIterator]?_[Symbol.asyncIterator]():_[Symbol.iterator](),$,Y=N.dbOrderedAttribute,j,B,Ee=!0;function fe(ne){let ie=ne.next&&fe(ne.next),xe=ne.descending;return P.sort=ne,(de,oe)=>{let ke=Su(de,ne.attribute,P),Be=Su(oe,ne.attribute,P),Le=xe?(0,Cl.compareKeys)(Be,ke):(0,Cl.compareKeys)(ke,Be);return Le===0?ie?.(de,oe)||0:Le}}o(fe,"createComparator");let pe=fe(N);return{async next(){let ne;if(w)if(ne=w.next(),ne.done){if($)return L.onDone&&L.onDone(),ne}else return{value:await x.call(this,ne.value)};A=[],j&&A.push(j);do if(ne=await D.next(),ne.done){if($=!0,A.length)break;return L.onDone&&L.onDone(),ne}else{let ie=ne.value;if(ie?.then&&(ie=await ie),Y){let xe=Su(ie,Y,P);if(Ee)Ee=!1,B=xe;else if(xe!==B){B=xe,j=ie;break}}A.push(ie)}while(!0);return N.isGrouped,A.sort(pe),w=A[Symbol.iterator](),ne=w.next(),ne.done?(L.onDone&&L.onDone(),ne):{value:await x.call(this,ne.value)}},return(){return L.onDone&&L.onDone(),D.return()},throw(){return L.onDone&&L.onDone(),D.throw()}}};let U=o(w=>{if(typeof T=="object"&&Array.isArray(w.attribute))for(let D=0;D<T.length;D++){let $=T[D],Y;if($.name===w.attribute[0]){for(Y=$.sort||($.sort={});Y.next;)Y=Y.next;Y.attribute=w.attribute.slice(1),Y.descending=w.descending}else $===w.attribute[0]&&(T[D]=Y={name:$,sort:{attribute:w.attribute.slice(1),descending:w.descending}})}w.next&&U(w.next)},"applySortingOnSelect");U(N)}else L.iterate=(_[Symbol.asyncIterator]||_[Symbol.iterator]).bind(_),L=L.map(function(A){try{let U=x.call(this,A);return typeof U?.catch=="function"?U.catch(w=>{throw w.partialObject={[t]:A.key},w}):U}catch(U){throw U.partialObject={[t]:A.key},U}});return L}static transformEntryForSelect(_,T,N,P,O,x){let L;O&&I&&!(typeof _=="string"?[_]:_)?.every(w=>{let D;return typeof w=="object"?D=w.name:D=w,r[D]||D===t})&&(L=!0);let A,U=o(function(w){let D;if(T?.transaction?.stale&&(T.transaction.stale=!1),w!=null){if(D=w.deref?w.deref():w.value,!D&&(w.key===void 0||w.deref)||w.metadataFlags&vn){if(w.metadataFlags&vn&&T.replicateFrom===!1&&x&&w.residencyId)return ec.SKIP;if(w=Io(w.key??w,T,{transaction:N,lazy:_?.length<4,ensureLoaded:O},this?.isSync,$=>$),w?.then)return w.then(U.bind(this));D=w?.value}if(L&&w?.metadataFlags&(vn|ka)||w?.expiresAt!=null&&w?.expiresAt<Date.now()){if(T.onlyIfCached)return{[t]:w.key,message:"This entry has expired"};let $=dn(w.key??w,w,T);if($?.then)return $.then(U)}}if(D==null)return x?ec.SKIP:D;if(_&&!(_[0]==="*"&&_.length===1)){let $,Y=o((B,Ee)=>{let fe;typeof B=="object"?fe=B.name:fe=B;let pe=vr?.[fe],ne;if(pe){let ie=P?.[fe];if(ie)if(ie.hasMappings){let de=pe.from?D[pe.from]:Gu(w.key);ne=ie.get(de),ne||(ne=[])}else ne=ie.fromRecord?.(D);else ne=pe(D,T,w,!0);let xe=o(de=>{if(pe.directReturn)return Ee(de,fe);if(de&&typeof de=="object"){let oe=pe.definition?.tableClass||Pe;A||(A={});let ke=A[fe]||(A[fe]=oe.transformEntryForSelect(fe===B?null:B.select||(Array.isArray(B)?B:null),T,N,ie,O));if(Array.isArray(de)){let Be=[],Le=oe.transformToOrderedSelect(de,B.select,typeof B.sort=="object"&&B.sort,T,N,ke)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Me=o(wt=>{for(;!wt.done;){if(wt?.then)return wt.then(Me);Be.push(wt.value),wt=Le.next()}Ee(Be,fe)},"nextValue"),pt=Me(Le.next());pt&&($||($=[]),$.push(pt));return}else if(de=ke.call(this,de),de?.then){$||($=[]),$.push(de.then(Be=>Ee(Be,fe)));return}}Ee(de,fe)},"handleResolvedValue");ne?.then?($||($=[]),$.push(ne.then(xe))):xe(ne);return}else ne=D[fe],ne&&typeof ne=="object"&&fe!==B&&(ne=Pe.transformEntryForSelect(B.select||B,T,N,null)({value:ne}));Ee(ne,fe)},"selectAttribute"),j;if(typeof _=="string")Y(_,B=>{j=B});else if(Array.isArray(_))if(_.asArray)j=[],_.forEach((B,Ee)=>{B==="*"?_[Ee]=D:Y(B,fe=>j[Ee]=fe)});else{j={};let B=_.forceNulls;for(let Ee of _)if(Ee==="*")for(let fe in D)j[fe]=D[fe];else Y(Ee,(fe,pe)=>{fe===void 0&&B&&(fe=null),j[pe]=fe})}else throw new lt.ClientError("Invalid select"+_);return $?Promise.all($).then(()=>j):j}return D},"transform");return U}async subscribe(_){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||Ze({table:s,database:c,schemaDefined:u,attributes:S,audit:!0}),_||(_={});let T=!_.rawEvents,N=[],P=xA(Pe,this.getId()??null,function(L,A,U,w){try{let D=A.getValue?.(i,T),$=A.type;if(!D&&$==="patch"&&T){let j=i.getEntry(L);j?.version===A.version?D=j.value:D=A.getValue?.(i,!0,U),$="put"}let Y={id:L,localTime:U,value:D,version:A.version,type:$,beginTxn:w};N?N.push(Y):(c!=="system"&&Ve(A.size??1,"db-message",s,null),this.send(Y))}catch(D){Fe.default.error?.(D)}},_.startTime||0,_),O=(async()=>{this.isCollection&&(P.includeDescendants=!0,_.onlyChildren&&(P.onlyChildren=!0)),_.supportsTransactions&&(P.supportsTransactions=!0);let L=this.getId(),A=_.previousCount;A>1e3&&(A=1e3);let U=_.startTime;if(this.isCollection){if(U){if(A)throw new lt.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:w,value:D}of l.getRange({start:U,exclusiveStart:!0,snapshot:!1})){let $=At(D);if($.tableId!==n)continue;let Y=$.recordId;if(L==null||aG(L,Y)){let j=$.getValue(i,T,w);if(x({id:Y,localTime:w,value:j,version:$.version,type:$.type,size:$.size}),P.queue?.length>iG&&await P.waitForDrain()===!1)return}P.startTime=w}}else if(A){let w=[];for(let{key:D,value:$}of l.getRange({start:"z",end:!1,reverse:!0}))try{let Y=At($);if(Y.tableId!==n)continue;let j=Y.recordId;if(L==null||aG(L,j)){let B=Y.getValue(i,T,D);if(w.push({id:j,localTime:D,value:B,version:Y.version,type:Y.type}),--A<=0)break}}catch(Y){Fe.default.error("Error getting history entry",D,Y)}for(let D=w.length;D>0;)x(w[--D]);w[0]&&(P.startTime=w[0].localTime)}else if(!_.omitCurrent){for(let{key:w,value:D,version:$,localTime:Y,size:j}of i.getRange({start:L??!1,end:L==null?void 0:[L,Cl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(D&&(x({id:w,localTime:Y,value:D,version:$,type:"put",size:j}),P.queue?.length>iG&&await P.waitForDrain()===!1))return}}else{A&&!U&&(U=0);let w=this.#n?.localTime;if(w===IA&&(i.cache?.delete(L),this.#n=i.getEntry(L),Fe.default.trace?.("re-retrieved record",w,this.#n?.localTime),w=this.#n?.localTime),Fe.default.trace?.("Subscription from",U,"from",L,w),U<w){let D=[],$=w;do{let Y=l.get($);if(Y){_.omitCurrent=!0;let j=At(Y),B=j.getValue(i,T,$);T&&(j.type="put"),D.push({id:L,value:B,localTime:$,...j}),$=j.previousLocalTime}else break;A&&A--}while($>U&&A!==0);for(let Y=D.length;Y>0;)x(D[--Y]);P.startTime=w}!_.omitCurrent&&this.doesExist()&&x({id:L,localTime:w,value:this.#e,version:this.#r,type:"put"})}for(let w of N)x(w);N=null})();function x(L){c!=="system"&&Ve(L.size??1,"db-message",s,null),P.send(L)}return o(x,"send"),_.listener&&P.on("data",_.listener),P}static subscribeOnThisThread(_,T){return _===0||T?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(_,T,N){if(T===void 0||T instanceof URLSearchParams)this._writePublish(this.getId(),_,T);else{let P=!0,O=this.getContext();return _.checkPermission&&(P=this.allowCreate(O.user,_,O)),ks(P,x=>{if(!x)throw new lt.AccessViolation(O.user);let L=Os(_);this._writePublish(L,T,N)})}}_writePublish(_,T,N){let P=Ur(this.getContext());_??=null,_!==null&&Ui(_);let O=this.getContext();P.addWrite({key:_,store:i,entry:this.#n,nodeName:O?.nodeName,validate:o(()=>{O?.source||(P.checkOverloaded(),this.validate(T))},"validate"),before:Ae.publish?.bind(this,O,_,T),beforeIntermediate:yu(T,Ye.publish?.bind(this,O,_,T)),commit:o((x,L,A)=>{L===void 0&&R&&!g&&Oa(),Fe.default.trace?.(`Publishing message to id: ${_}, timestamp: ${new Date(x).toISOString()}`),y(_,L?.value??null,L,L?.version||x,0,!0,{user:O?.user,residencyId:N?.residencyId,expiresAt:O?.expiresAt,nodeId:N?.nodeId,tableToTrack:s},"message",!1,T)},"commit")})}validate(_,T){let N,P=o((O,x,L)=>{if(x.type&&O!=null)if(T&&O.__op__&&(O=O.value),x.properties){typeof O!="object"&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be an object${x.type?" ("+x.type+")":""}`);let A=x.properties;for(let U=0,w=A.length;U<w;U++){let D=A[U];if(D.relationship||D.computed){_.hasOwnProperty(D.name)&&(N||(N=[])).push(`Computed property ${L}.${D.name} may not be directly assigned a value`);continue}let $=P(O[D.name],D,L+"."+D.name);$&&(O[D.name]=$)}if(x.sealed&&O!=null&&typeof O=="object")for(let U in O)A.find(w=>w.name===U)||(N||(N=[])).push(`Property ${U} is not allowed within object in property ${L}`)}else switch(x.type){case"Int":(typeof O!="number"||O>>0!==O)&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof O!="number"||!(Math.floor(O)===O&&Math.abs(O)<=9007199254740992))&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof O!="number"&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a number`);break;case"ID":typeof O=="string"||O?.length>0&&O.every?.(A=>typeof A=="string")||(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a string, or an array of strings`);break;case"String":typeof O!="string"&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a string`);break;case"Boolean":typeof O!="boolean"&&(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a boolean`);break;case"Date":if(!(O instanceof Date)){if(typeof O=="string"||typeof O=="number")return new Date(O);(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a Date`)}break;case"BigInt":if(typeof O!="bigint"){if(typeof O=="string"||typeof O=="number")return BigInt(O);(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a bigint`)}break;case"Bytes":if(!(O instanceof Uint8Array)){if(typeof O=="string")return Buffer.from(O);(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(O instanceof Ls)){if(typeof O=="string"&&(O=Buffer.from(O)),O instanceof Buffer)return createBlob(O,{type:"text/plain"});(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be a Blob`)}break;case"array":if(Array.isArray(O)){if(x.elements)for(let A=0,U=O.length;A<U;A++){let w=O[A],D=P(w,x.elements,L+"[*]");D&&(O[A]=D)}}else(N||(N=[])).push(`Value ${Hs(O)} in property ${L} must be an Array`);break}x.nullable===!1&&O==null&&(N||(N=[])).push(`Property ${L} is required (and not does not allow null values)`)},"validateValue");for(let O=0,x=S.length;O<x;O++){let L=S[O];if(L.relationship||L.computed){Object.hasOwn(_,L.name)&&(N||(N=[])).push(`Computed property ${L.name} may not be directly assigned a value`);continue}if(!T||L.name in _){let A=P(_[L.name],L,L.name);A!==void 0&&(_[L.name]=A)}}if(f)for(let O in _)S.find(x=>x.name===O)||(N||(N=[])).push(`Property ${O} is not allowed`);if(N)throw new lt.ClientError(N.join(". "))}getUpdatedTime(){return this.#r}wasLoadedFromSource(){return I?!!this.#i:void 0}static async addAttributes(_){let T=S.slice(0);for(let N of _){if(!N.name)throw new lt.ClientError("Attribute name is required");if(N.name.match(/[`/]/))throw new lt.ClientError("Attribute names cannot include backticks or forward slashes");qie(N.name),T.push(N)}return Ze({table:s,database:c,schemaDefined:u,attributes:T}),Pe.indexingOperation}static async removeAttributes(_){let T=S.filter(N=>!_.includes(N.name));return Ze({table:s,database:c,schemaDefined:u,attributes:T}),Pe.indexingOperation}static getSize(){let _=i.getStats();return(_.treeBranchPageCount+_.treeLeafPageCount+_.overflowPages)*_.pageSize}static getAuditSize(){let _=l?.getStats();return _&&(_.treeBranchPageCount+_.treeLeafPageCount+_.overflowPages)*_.pageSize}static getStorageStats(){let _=i.env.path,T=Zw.default.statfsSync?.(_)??{};return{available:T.bavail*T.bsize,free:T.bfree*T.bsize,size:T.blocks*T.bsize}}static async getRecordCount(_){let T=i.getStats().entryCount,N=1e3/2,P=performance.now(),O=Math.floor(T/2),x=_?.exactCount,L=0,A=0,U;for(let{value:w}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(w!=null&&L++,A++,await Za(),!x&&A<O&&performance.now()-P>N){U=A;break}if(U){let w=L;L=0;for(let{value:ne}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:U,snapshot:!1}))ne!=null&&L++,await Za();let D=U*2,$=(L+w)/D,Y=Math.pow((L-w+1)/U/2,2)+$*(1-$)/D,j=Math.max(Math.sqrt(Y)*T,1),B=Math.round($*T),Ee=Math.max(B-1.96*j,L+w),fe=Math.min(B+1.96*j,T),pe=Math.pow(10,Math.round(Math.log10(j)));return pe>B&&(pe=pe/10),L=Math.round(B/pe)*pe,{recordCount:L,estimatedRange:[Math.round(Ee),Math.round(fe)]}}return{recordCount:L}}static updatedAttributes(){vr=this.propertyResolvers={$id:o((_,T,N)=>({value:N.key}),"$id"),$updatedtime:o((_,T,N)=>N.version,"$updatedtime"),$updatedTime:o((_,T,N)=>N.version,"$updatedTime"),$expiresAt:o((_,T,N)=>N.expiresAt,"$expiresAt"),$record:o((_,T,N)=>N?{value:_}:_,"$record"),$distance:o((_,T,N)=>N&&(N.distance??T?.vectorDistances?.get(N)),"$distance")};for(let _ of this.attributes){_.isPrimaryKey&&(k=_),_.resolve=null;let T=_.relationship,N=_.computed;if(T)if(_.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),N&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),_u=!0,T.to)_.elements?.definition?(vr[_.name]=_.resolve=(P,O,x,L)=>{let A=P[T.from?T.from:t],U=_.elements.definition.tableClass;return L?Hu({attribute:T.to,value:A},Ur(O).getReadTxn(),!1,U,!1).map(w=>w&&w.key!==void 0?w:U.primaryStore.getEntry(w,{transaction:Ur(O).getReadTxn()})).asArray:U.search([{attribute:T.to,value:A}],O).asArray},_.set=()=>{},_.resolve.definition=_.elements.definition,_.resolve.to=T.to,T.from&&(_.resolve.from=T.from)):console.error(`The one-to-many/many-to-many relationship property "${_.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(T.from){let P=_.definition||_.elements?.definition;P?(vr[_.name]=_.resolve=(O,x,L,A)=>{let U=O[T.from];if(U===void 0)return;if(_.elements){let D,$=U?.map(Y=>{let j=P.tableClass.primaryStore[A?"getEntry":"get"](Y,{transaction:Ur(x).getReadTxn()});return j?.then&&(D=!0),Pe.loadAsInstance===!1&&Object.freeze(A?j?.value:j),j});return T.filterMissing?D?Promise.all($).then(Y=>Y.filter(cG)):$.filter(cG):D?Promise.all($):$}let w=P.tableClass.primaryStore[A?"getEntry":"get"](U,{transaction:Ur(x).getReadTxn()});return Pe.loadAsInstance===!1&&Object.freeze(A?w?.value:w),w},_.set=(O,x)=>{if(Array.isArray(x)){let L=x.map(A=>A.getId?.()||A[P.tableClass.primaryKey]);O[T.from]=L}else{let L=x.getId?.()||x[P.tableClass.primaryKey];O[T.from]=L}},_.resolve.definition=_.definition||_.elements?.definition,_.resolve.from=T.from):console.error(`The relationship property "${_.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${_.name}" in table "${s}" must use either "from" or "to" arguments`);else if(N)typeof N.from=="function"&&this.setComputedAttribute(_.name,N.from),vr[_.name]=_.resolve=(P,O,x)=>{let L=typeof N.from=="string"?P[N.from]:P,A=this.userResolvers[_.name];if(A)return A(L,O,x);Fe.default.warn(`Computed attribute "${_.name}" does not have a function assigned to it. Please use setComputedAttribute('${_.name}', resolver) to assign a resolver function.`),this.userResolvers[_.name]=()=>{}},_.resolve.directReturn=!0;else if(r[_.name]?.customIndex?.propertyResolver){let P=r[_.name].customIndex;vr[_.name]=(O,x,L)=>{let A=O[_.name];return P.propertyResolver(A,x,L)},vr[_.name].directReturn=!0}}cp(this,this),cp(Qf,this,!0);for(let _ of S){let T=_.name;_.resolve&&Object.defineProperty(i.encoder.structPrototype,T,{get(){return _.resolve(this,$u.getStore())},set(N){return _.set(this,N)},configurable:!0})}}static setComputedAttribute(_,T){let N=qi(S,_);if(!N){console.error(`The attribute "${_}" does not exist in the table "${s}"`);return}if(!N.computed){console.error(`The attribute "${_}" is not defined as computed in the table "${s}"`);return}this.userResolvers[_]=T}static async deleteHistory(_=0,T=!1){let N;for(let{key:P,value:O}of l.getRange({start:0,end:_}))await Za(),At(O).tableId===n&&(N=v_(l,P,O));if(T)for(let P of i.getRange({start:0,versions:!0})){let{key:O,value:x,localTime:L}=P;await Za(),x===null&&L<_&&(N=nl(i,P))}await N}static async*getHistory(_=0,T=1/0){for(let{key:N,value:P}of l.getRange({start:_||1,end:T})){await Za();let O=At(P);O.tableId===n&&(yield{id:O.recordId,localTime:N,version:O.version,type:O.type,value:O.getValue(i,!0,N),user:O.user,operation:O.originatingOperation})}}static async getHistoryOfRecord(_){let T=[];if(_==null)throw new Error("An id is required");let N=i.getEntry(_);if(!N)return T;let P=N.localTime;if(!P)throw new Error("The entry does not have a local audit time");let O=0;do{await Za();let x=l.get(P);if(x){let L=At(x);T.push({id:L.recordId,localTime:P,version:L.version,type:L.type,value:L.getValue(i,!0,P),user:L.user}),P=L.previousLocalTime}else break}while(O<1e3&&P);return T.reverse()}static cleanup(){W?.remove()}}let $E=Kg(async(K,_,T)=>{for(let N of Pe.sources)if(N.get&&(!N.get.reliesOnPrototype||N.prototype.get)){if(N.available?.(T)===!1)continue;_.source=N;let P=await N.get(K,_);if(P)return P}},()=>{throw new lt.ServerError("Service unavailable, exceeded request queue limit for resolving cache record",503)});Pe.updatedAttributes();let cb=Pe.prototype;return h&&Pe.setTTLExpiration(h/1e3),X&&VE(),Pe;function gu(K,_,T){let N;for(let P in r){let O=r[P],x=O.isIndexing,L=vr[P],A=T&&(L?L(T):T[P]),U=_&&(L?L(_):_[P]);if(A===U&&!x)continue;if(O.customIndex){O.customIndex.index(K,A,U);continue}N=!0;let w=O.indexNulls,D=(0,Cp.getIndexedValues)(A,w),$=(0,Cp.getIndexedValues)(U,w);if($?.length>0){let Y=new Set($);if(D=D?D.filter(j=>{if(Y.has(j))Y.delete(j);else return!0}):[],$=Array.from(Y),($.length>0||D.length>0)&&rG){let j=$.concat(D).map(B=>({key:B,value:K}));O.prefetch(j,oG)}for(let j=0,B=$.length;j<B;j++)O.remove($[j],K)}else D?.length>0&&rG&&O.prefetch(D.map(Y=>({key:Y,value:K})),oG);if(D)for(let Y=0,j=D.length;Y<j;Y++)O.put(D[Y],K)}return N}o(gu,"updateIndices");function Ui(K){switch(typeof K){case"number":return!0;case"string":if(K.length<659)return!0;if(K.length>sG)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,Cl.writeKey)(K,jie,0)>sG)throw new Error("Primary key size is too large: "+K.length);return!0}o(Ui,"checkValidId");function Os(K){return typeof K=="object"&&K?K.id:K}o(Os,"requestTargetToId");function Jf(K){return typeof K=="object"&&K&&K.isCollection}o(Jf,"isSearchTarget");function Xf(K){}o(Xf,"isRequestTarget");function Io(K,_,T,N,P){if(Pe.getResidencyById&&T.ensureLoaded&&_?.replicateFrom!==!1){let x=Pa(Pe.getResidencyById(K));if(x&&!x.includes(server.hostname)&&C)return C({key:K,residency:x}).then(P)}let O=o(()=>{if(_?.transaction?.stale&&(_.transaction.stale=!1),T.transaction?.isDone)return P(null,K);let x=i.getEntry(K,T);return(c!=="system"||s==="hdb_analytics")&&(dG.default.trace?.("Recording db-read action for",`${c}.${s}`),Ve(x?.size??1,"db-read",s,null)),_?._freezeRecords&&Object.freeze(x?.value),x?.residencyId&&x.metadataFlags&vn&&C&&T.ensureLoaded&&_?.replicateFrom!==!1?C(x).then(L=>P(L,K),L=>(Fe.default.error?.("Error loading remote record",K,x,T,L),P(null,K))):(x&&_&&(x?.version>(_.lastModified||0)&&(_.lastModified=x.version),x?.localTime&&!_.lastRefreshed&&(_.lastRefreshed=x.localTime)),P(x,K))},"whenPrefetched");return N?O():te>0?(te--,O()):new Promise((x,L)=>{te===0?(te--,i.prefetch([K],()=>{A(),U()})):(ue.push(K),ce.push(U),ue.length>qE&&(te--,A()));function A(){if(ue.length>0){let w=ce;i.prefetch(ue,()=>{te===-1?A():te++;for(let D of w)D()}),ue=[],ce=[],ye>2&&ye--}else te=ye,ye<jf&&ye++}o(A,"prefetch");function U(){try{x(O())}catch(w){L(w)}}o(U,"load")})}o(Io,"loadLocalRecord");function On(K,_){let T=_?.checkPermission;if(typeof T!="object"){if(!K?.role)return;T=K.role.permission}if(T.super_user)return Qie;let N=T[c],P,O=N?.tables;if(O)return O[s];if(c==="data"&&(P=T[s])&&!P.tables)return P}o(On,"getTablePermissions");function dn(K,_,T,N){if(I){let P=!1;if(T.noCache?P=!0:(_?(!_.value||_.metadataFlags&(vn|ka)||_.expiresAt!=null&&_.expiresAt<Date.now())&&(P=!0):P=!0,Zr(!P,"cache-hit",s)),P){let O=Tu(K,_,T).then(x=>(x?.value&&x?.value.getRecord?.()&&Fe.default.error?.("Can not assign a record that is already a resource"),T&&(x?.version>(T.lastModified||0)&&(T.lastModified=x.version),T.lastRefreshed=Date.now()),x));if(T?.onlyIfCached||_?.value&&N?.allowStaleWhileRevalidate?.(_,K)){if(O.catch(x=>Fe.default.warn?.(x)),T?.onlyIfCached&&!N.doesExist())throw new lt.ServerError("Entry is not cached",504);return}else return O}}else if(_?.value&&_.expiresAt!=null&&_.expiresAt<Date.now())return Pe.evict(_.key,_.value,_.version),_.value=null,{then(P){return P(_)}}}o(dn,"ensureLoadedFromSource");function Ur(K){let _=K?.transaction;if(_){if(!_.lmdbDb)return _.lmdbDb=i,_;do{if(_.lmdbDb?.path===i.path)return _;let T=_.next;if(!T)return _=_.next=new No,_.lmdbDb=i,_;_=T}while(!0)}else return new u_}o(Ur,"txnForContext");function Su(K,_,T){if(!K)return;let N=(K.deref?K.deref():K.value)??i.getEntry(K.key)?.value;if(typeof _=="object"){let O=vr,x=N;for(let L=0,A=_.length;L<A;L++){let U=_[L],w=O?.[U];x=w&&x?w(x,T,K):x?.[U],K=null,O=w?.definition?.tableClass?.propertyResolvers}return x}let P=vr[_];return P?P(N,T,K):N[_]}o(Su,"getAttributeValue");function Zf(K,_,T,N,P){let O=P?.length,x={transaction:N,lazy:O>0||typeof _=="string"||_?.length<4,alwaysPrefetch:!0},L;function A(U,w){let D=U?.value;if(!D)return ec.SKIP;for(let $=0;$<O;$++)if(!L?.includes($)&&!P[$](D,U))return ec.SKIP;return w!==void 0&&(U.key=w),U}if(o(A,"processEntry"),O>0||!K.hasEntries){let U=K.map(w=>{if(L=null,typeof w=="object"&&w?.key!==void 0)return O>0?A(w):w;if(w==null)return ec.SKIP;for(let D=0;D<O;D++){let Y=P[D].idFilter;if(Y){if(!Y(w))return ec.SKIP;L||(L=[]),L.push(D)}}return Io(w,T,x,!1,A)});return Array.isArray(K)&&(U=U.filter(w=>w!==ec.SKIP)),U.hasEntries=!0,U}return K}o(Zf,"transformToEntries");function xr(K,_,T=server.replication?.getThisNodeId(l)){if(K<=_?.version){if(_?.version===K&&T!==void 0){let N=server.replication?.exportIdMapping(l),P=_.localTime,O=P&&l.get(P);if(O){let x,L,A=At(O);for(let U in N)N[U]===T&&(x=U),N[U]===A.nodeId&&(L=U);if(x>L)return 1;if(x===L)return 0}}return-1}return 1}o(xr,"precedesExistingVersion");async function Tu(K,_,T){let N=_?.metadataFlags,P=_?.version,O,x;if(!i.attemptLock(K,P,()=>{clearTimeout(x);let w=i.getEntry(K);!w||!w.value||w.metadataFlags&(vn|ka)?O(Tu(K,i.getEntry(K),T)):O(w)}))return new Promise(w=>{O=w,x=setTimeout(()=>{i.unlock(K,P)},Wie)});let L=_?.value,A={requestContext:T,replacingRecord:L,replacingEntry:_,replacingVersion:P,noCacheStore:!1,source:null,resourceCache:T?.resourceCache,transaction:void 0,expiresAt:void 0,lastModified:void 0},U=T?.responseHeaders;return new Promise((w,D)=>{let $;ks(bt(A,async Y=>{let j=performance.now(),B,Ee,fe;try{B=await $E(K,A,_),fe=N&vn;let ne=A.lastModified||fe&&P;Ee=fe||ne>P||!L,ne||(ne=(0,Cp.getNextMonotonicTime)());let ie=performance.now()-j;if(Ve(ie,"cache-resolution",s,null,"success"),U&&wp(U,"Server-Timing",`cache-resolve;dur=${ie.toFixed(2)}`,!0),Y.timestamp=ne,h&&A.expiresAt==null&&(A.expiresAt=Date.now()+h),B){if(typeof B!="object")throw new Error("Only objects can be cached and stored in tables");if(B.status>0&&B.headers)if(B.status>=300)if(B.status===304)B=L,ne=P;else throw new lt.ServerError(B.body||"Error from source",B.status);else B=B.body;typeof B.toJSON=="function"&&(B=B.toJSON()),t&&B[t]!==K&&(B[t]=K)}$=!0,w({key:K,version:ne,value:B})}catch(ne){ne.message+=` while resolving record ${K} for ${s}`,L&&((ne.code==="ECONNRESET"||ne.code==="ECONNREFUSED"||ne.code==="EAI_AGAIN")&&!T?.mustRevalidate||T?.staleIfError&&(ne.statusCode===500||ne.statusCode===502||ne.statusCode===503||ne.statusCode===504))?(w({key:K,version:P,value:L}),Fe.default.trace?.(ne.message,"(returned stale record)")):D(ne);let ie=performance.now()-j;Ve(ie,"cache-resolution",s,null,"fail"),U&&wp(U,"Server-Timing",`cache-resolve;dur=${ie.toFixed(2)}`,!0),A.transaction.abort();return}if(T?.noCacheStore||A.noCacheStore){A.transaction.abort();return}Ur(A).addWrite({key:K,store:i,entry:_,nodeName:"source",before:yu(B),commit:o((ne,ie)=>{if(ie?.version!==P)return;let xe=gu(K,L,B);if(B){Ye.put?.(A,K,B),ie&&(T.previousResidency=Pe.getResidencyRecord(ie.residencyId));let de,oe=!1,ke,Be=Pa(Pe.getResidency(B,T));if(Be){if(!Be.includes(server.hostname))if(de=B,oe=!0,Pe.getResidencyById)B=void 0;else{B=null;for(let Le in r)B||(B={}),B[Le]=de[Le]}ke=kc(Be)}Fe.default.trace?.(`Writing resolved record from source with id: ${K}, timestamp: ${new Date(ne).toISOString()}`),y(K,B,ie,ne,oe?vn:0,g&&(Ee||oe)||null,{user:A?.user,expiresAt:A.expiresAt,residencyId:ke,tableToTrack:s},"put",!!fe,de)}else ie&&(Ye.delete?.(A,K),Fe.default.trace?.(`Deleting resolved record from source with id: ${K}, timestamp: ${new Date(ne).toISOString()}`),g||R?y(K,null,ie,ne,0,g&&Ee||null,{user:A?.user,tableToTrack:s},"delete",!!fe):nl(i,ie,P))},"commit")})}),()=>{i.unlock(K,P)},Y=>{i.unlock(K,P),$&&Fe.default.error?.("Error committing cache update",Y)})})}o(Tu,"getFromSource");function Ca(K){if(!K||K.user?.role?.permission?.super_user)return!0;if(K.replicateTo)throw new lt.ClientError("Can not specify replication parameters without super user permissions",403);if(K.replicatedConfirmation)throw new lt.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}o(Ca,"checkContextPermissions");function Oa(K){let _=!1;if(K&&(K-Ar>1&&(_=!0),Ar=K),!(qe===tr&&!_)&&(tr=qe,(0,wl.getWorkerIndex)()===(0,wl.getWorkerCount)()-1))return Wr&&clearTimeout(Wr),qe?new Promise(T=>{let N=new Date;N.setMonth(0),N.setDate(1),N.setHours(0),N.setMinutes(0),N.setSeconds(0);let P=qe/(1+Ar),O=_?Date.now():Math.ceil((Date.now()-N.getTime())/P)*P+N.getTime(),x=o(L=>{Fe.default.trace?.(`Scheduled next cleanup scan at ${new Date(L)}`),Wr=setTimeout(()=>J=J.then(async()=>{if(x(Math.max(L+qe,Date.now())),i.rootStore.status!=="open"){clearTimeout(Wr);return}let A=50,U=new Array(A),w=0,D=Math.pow(Ar,8)*(Nl.get(F.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),$=E/Math.pow(Math.max(Ar,1),4);Fe.default.debug?.(`Starting cleanup scan for ${s}, evict threshold ${D}, adjusted eviction ${$}ms`);function Y(j,B,Ee,fe){let pe=j+$-Date.now();if(pe<0)return!0;if(Ar){let ne=i.lastSize;return Ee&Jr&&Wc(fe,ie=>{ie.size&&(ne+=ie.size)}),Fe.default.trace?.(`shouldEvict adjusted ${pe} ${ne}, ${pe*(j-B)/ne} < ${D}`),pe*(j-B)/ne<D}return!1}o(Y,"shouldEvict");try{let j=0;for(let B of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:Ee,value:fe,version:pe,expiresAt:ne,metadataFlags:ie}=B,xe;fe===null&&!g&&pe+Yie<Date.now()?xe=nl(i,B,pe):ne!=null&&Y(ne,pe,ie,fe)&&(xe=Pe.evict(Ee,fe,pe),j++),xe&&(await U[w],U[w]=xe.catch(de=>{Fe.default.error?.("Cleanup error",de)}),++w>=A&&(w=0)),await Za()}Fe.default.debug?.(`Finished cleanup scan for ${s}, evicted ${j} entries`)}catch(j){Fe.default.warn?.(`Error in cleanup scan for ${s}:`,j)}T(void 0),Ar=0}),Math.min(L-Date.now(),2147483647)).unref()},"startNextTimer");x(O)}):void 0}o(Oa,"scheduleCleanup");function em(){W=l?.addDeleteRemovalCallback(n,i,(K,_)=>{i.remove(K,_)})}o(em,"addDeleteRemoval");function VE(){(0,wl.getWorkerIndex)()===0&&setInterval(async()=>{if(!Fc){Fc=!0;try{let K=X.name,_=r[K];if(!_)throw new Error(`expiresAt attribute ${X} must be indexed`);for(let T of _.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let N of _.getValues(T)){let P=i.getEntry(N);P?.value?P.value[K]<Date.now()&&Pe.evict(N,P.value,P.version):i.ifVersion(N,P?.version,()=>_.remove(T,N))}await Za()}}catch(K){Fe.default.error?.("Error in evicting old records",K)}finally{Fc=!1}}},Kie).unref()}o(VE,"runRecordExpirationEviction");function Pa(K){if(K!=null){if(Array.isArray(K))return K;if(typeof K=="number"){if(K>=65536)throw new Error(`Shard id ${K} must be below 65536`);let _=server.shards?.get?.(K);if(_)return Fe.default.trace?.(`Shard ${K} mapped to ${_.map(T=>T.name).join(", ")}`),_.map(T=>T.name);throw new Error(`Shard ${K} is not defined`)}throw new Error(`Shard or residency list ${K} is not a valid type, must be a shard number or residency list of node hostnames`)}}o(Pa,"residencyFromFunction");function kc(K){if(K){let _=K.join(","),T=d.get([Symbol.for("residency_by_set"),_]);return T||(d.put([Symbol.for("residency_by_set"),_],T=Math.floor(Math.random()*2147418112)+65535),d.put([Symbol.for("residency_by_id"),T],K),T)}}o(kc,"getResidencyId");function yu(K,_){let T=Qb(K,i.rootStore);if(T){let N=_;return N?async()=>{await N(),await T}:()=>T}return _}o(yu,"preCommitBlobsForRecordBefore")}function Xw(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 oG(){}function Wg(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 Yg(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return Yg(+e);case"Float":return e==="null"?null:Yg(+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;Jie.test(e)||(e+="Z");let n=new Date(e);return Yg(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,zg.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function Yg(e){if(isNaN(e))throw new SyntaxError;return e}function aG(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 ks(e,t,r){return e?.then?e.then(t,r):t(e)}function cG(e){return e!=null}function Hs(e){try{return JSON.stringify(e)}catch{return e}}function Xie(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var ec,Cp,lG,uG,Nl,lt,Op,Pp,Fe,Cl,wl,zg,Zw,dG,Gie,qie,$ie,Vie,Kie,Yie,rG,Wie,nG,zie,vn,ka,jie,sG,iG,Qie,CMe,Jie,Za,Z_=se(()=>{q();ec=require("lmdb"),Cp=b(Ln()),lG=b(require("lodash")),uG=b(hm());Ha();_m();Nl=b(me());BA();lt=b(_e()),Op=b(Ho()),Pp=b(ss());we();X_();Fe=b(Xn());KI();Ma();Cl=require("ordered-binary"),wl=b(nt());Bi();zg=b(ae());el();es();m_();Np();Zw=b(require("node:fs"));Zn();P_();dG=b(Q());Jw();({sortBy:Gie}=lG.default),{validateAttribute:qie}=uG.default,$ie=new Uint8Array(9);$ie[8]=192;Vie=1/0,Kie=6e4,Yie=864e5;Nl.initSync();rG=Nl.get(F.STORAGE_PREFETCHWRITES),Wie=1e4,nG=1,zie=2,vn=1,ka=8,jie=Buffer.allocUnsafeSlow(8192),sG=1978,iG=100,Qie={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},CMe=(0,zg.convertToMS)(Nl.get(F.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;o(jg,"makeTable");o(Xw,"attributesAsObject");o(oG,"noop");Jie=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;o(Wg,"coerceType");o(Yg,"rejectNaN");o(aG,"isDescendantId");Za=o(()=>new Promise(setImmediate),"rest");o(ks,"when");o(cG,"exists");o(Hs,"stringify");o(Xie,"hasOtherProcesses")});function Qg(e,t){if(!Array.isArray(e)||!Array.isArray(t))throw new Error("Euclidean distance comparison requires an array");let r=0,n=Math.max(e.length,t.length);for(let s=0;s<n;s++){let i=e[s]||0,a=t[s]||0,c=i-a;r+=c*c}return r}function Jg(e,t){if(!Array.isArray(e)||!Array.isArray(t))throw new Error("Cosine distance comparison requires an array");let r=0,n=0,s=0,i=Math.max(e.length,t.length);for(let a=0;a<i;a++){let c=e[a]||0,l=t[a]||0;r+=c*l,n+=c*c,s+=l*l}return n=Math.sqrt(n),s=Math.sqrt(s),1-r/(n*s||1)}var mG=se(()=>{o(Qg,"euclideanDistance");o(Jg,"cosineDistance")});var pG,hG,hd,ro,pd,Zie,eoe,Xg,EG=se(()=>{mG();pG=require("msgpackr"),hG=b(Xn()),hd=b(_e()),ro=(0,hG.loggerWithTag)("HNSW"),pd=Symbol.for("entryPoint"),Zie=Symbol.for("key"),eoe=10,Xg=class{static{o(this,"HierarchicalNavigableSmallWorld")}static useObjectStore=!0;indexStore;M=16;efConstruction=100;efConstructionSearch=50;mL=1/Math.log(this.M);optimizeRouting=.5;nodesVisitedCount=0;idIncrementer;distance;constructor(t,r){this.indexStore=t,t&&(this.indexStore.encoder.useFloat32=pG.FLOAT32_OPTIONS.ALWAYS),this.distance=r?.distance==="euclidean"?Qg:Jg,r&&(r.M!==void 0&&(this.M=r.M,this.mL=1/Math.log(this.M)),r.efConstruction!==void 0&&(this.efConstruction=this.efConstructionSearch=r.efConstruction),r.efConstructionSearch!==void 0&&(this.efConstructionSearch=r.efConstructionSearch),r.mL!==void 0&&(this.mL=r.mL),r.optimizeRouting!==void 0&&(this.optimizeRouting=r.optimizeRouting))}index(t,r,n){let s=typeof t=="number"?[Zie,t]:t,i=this.indexStore.get(s);if(!i){if(!r)return;if(!this.idIncrementer){let f=0;for(let m of this.indexStore.getKeys({reverse:!0,limit:1,start:1/0,end:0}))typeof m=="number"&&(f=m);this.idIncrementer=new BigInt64Array([BigInt(f)+1n]),this.idIncrementer=new BigInt64Array(this.indexStore.getUserSharedBuffer("next-id",this.idIncrementer.buffer))}i=Number(Atomics.add(this.idIncrementer,0,1n)),this.indexStore.put(s,i)}let a=new Map,c,l=this.indexStore.get(pd);if(n?c={...this.indexStore.get(i)}:c={},r){let f=l&&this.indexStore.get(l);if(f===void 0){let E=Math.floor(-Math.log(Math.random())*this.mL),g={vector:r,level:E,primaryKey:t};for(let R=0;R<=E;R++)g[R]=[];if(this.indexStore.put(i,g),typeof i!="number")throw new Error("Invalid nodeId: "+i);ro.debug?.("setting entry point to",i),this.indexStore.put(pd,i);return}let m=c.level??Math.min(Math.floor(-Math.log(Math.random())*this.mL),eoe),p=f.level;if(m>=p){if(typeof i!="number")throw new Error("Invalid nodeId: "+i);ro.debug?.("setting entry point to",i),this.indexStore.put(pd,i)}for(;p>m;){let E=this.searchLayer(r,l,f,this.efConstruction,p);E.length>0&&(l=E[0].id,f=E[0].node),p--}let h=new Array(m+1);for(let E=0;E<=m;E++)h[E]=[];for(let E=Math.min(m,p);E>=0;E--){let g=this.searchLayer(r,l,f,this.efConstruction,E);g=g.slice(0,this.M<<1),g.length===0&&E===0&&ro.info?.("should not have zero connections for",l);let R=h[E];for(let S=0;S<g.length;S++){let{id:y,distance:C,node:I}=g[S];if(y===i)continue;let k=[];if(this.optimizeRouting){let H=!1,X=I[E],W=1+this.optimizeRouting*(1+.5*S/this.M);for(let ue=0;ue<X.length;ue++){let{id:ce,distance:te}=X[ue],ye=1+this.optimizeRouting*(1+.5*ue/this.M);for(let Ae=0;Ae<R.length;Ae++){let{id:Ye,distance:qe}=R[Ae];if(Ye===ce){C*W>qe+te?H=!0:te*ye>C+qe&&(k.push({fromId:Ye,toId:y}),k.push({fromId:y,toId:Ye}));break}}if(H)break}if(H)continue}else if(S>=(E>0?this.M:this.M<<1))continue;R.push({id:y,distance:C});for(let{fromId:H,toId:X}of k){let W=d(H);W||(W=d(H,this.indexStore.get(H)));for(let ue=0;ue<W[E].length;ue++)if(W[E][ue].id===X){Object.isFrozen(W[E])&&(W[E]=W[E].slice()),W[E].splice(ue,1);break}}let J=c[E],G=J?.find(({id:H})=>H===y);if(G){let H=J?.indexOf(G);J.copied||(J=[...J],J.copied=!0,c[E]=J),J.splice(H,1)}else this.addConnection(y,d(y,I),i,E,C,d)}}this.indexStore.put(i,{vector:r,level:m,primaryKey:t,...h})}else{if(l===i){let f=c.level??0;for(let m=f;m>=0&&(l=c[m][0]?.id,l===void 0);m--);if(l===void 0){let m=-1;for(let{key:p,value:h}of this.indexStore.getRange({start:0,end:1/0}))if(h.level>m){if(l=p,h.level===f)break;m=h.level}}if(l===void 0)this.indexStore.remove(pd);else{if(typeof l!="number")throw new Error("Invalid nodeId: "+l);ro.debug?.("setting entry point to",l),this.indexStore.put(pd,l)}}this.indexStore.remove(i)}let u=new Map;if(c.level!==void 0)for(let f=0;f<=c.level;f++){let m=c[f];for(let{id:p}of m){let h=d(p,this.indexStore.get(p));for(let E=0;E<=f;E++)h[E]=h[E]?.filter(({id:g})=>g!==i),h[E].length===0&&(ro.info?.("node was left orphaned, will reindex",p),u.set(h.primaryKey,h.vector))}}function d(f,m){let p=a.get(f);return!p&&m&&(p={...m},a.set(f,p)),p}o(d,"updateNode");for(let[f,m]of a)this.indexStore.put(f,m);for(let[f,m]of u)this.index(f,m,m);this.checkSymmetry(i,this.indexStore.get(i))}getEntryPoint(){let t=this.indexStore.get(pd);if(t===void 0)return;let r=this.indexStore.get(t);return{id:t,...r}}searchLayer(t,r,n,s,i,a=this.distance){let c=new Set([r]),l=[{id:r,distance:this.distance(t,n.vector),node:n}],u=[...l];for(;l.length>0;){l.sort((p,h)=>p.distance-h.distance);let d=l.shift(),f=u[u.length-1].distance;if(d.distance>f)break;let m=d.node;for(let{id:p}of m[i]||[]){if(c.has(p)||p===void 0)continue;c.add(p);let h=this.indexStore.get(p);if(!h)continue;this.nodesVisitedCount++;let E=a(t,h.vector);if(E<f||u.length<s){let g={id:p,distance:E,node:h};l.push(g),u.push(g)}}u.sort((p,h)=>p.distance-h.distance),u.length>s&&u.splice(s,u.length-s)}return u.visited=c.size,u}search({target:t,value:r,descending:n,distance:s,comparator:i}){let a=0;switch(i){case"lt":case"le":a=r;case"sort":break;default:throw new hd.ClientError(`Can not use "${i}" comparator with HNSW`)}if(n)throw new hd.ClientError("Can not use descending sort order with HNSW");let c;if(s==="cosine")c=Jg;else if(s==="euclidean")c=Qg;else{if(s)throw new hd.ClientError("Unknown distance function");c=this.distance}if(!t)throw new hd.ClientError("A target vector must be provided for an HNSW query");if(!Array.isArray(t))throw new hd.ClientError("The target vector must be an array");let l=this.getEntryPoint();if(!l)return[];let u=l.id,d=[];for(let f=l.level;f>=0;f--)if(d=this.searchLayer(t,u,l,this.efConstructionSearch,f,c),d.length>0){let m=d[0];l=m.node,u=m.id}return a&&(d=d.filter(f=>f.distance<a)),d.map(f=>({key:f.node.primaryKey,distance:f.distance}))}checkSymmetry(t,r){if(!r)return;let n=0,s;for(;(s=r[n])&&s.length!==0;){for(let{id:i}of s){let a=this.indexStore.get(i);if(!a){ro.info?.("could not find neighbor node",a);continue}a[n]?.find(({id:l})=>l==t)||ro.info?.("asymmetry detected",a[n])}n++}}addConnection(t,r,n,s,i,a){r[s]||(r[s]=[]);let c=s===0?this.M<<1:this.M;if(this.optimizeRouting&&(c<<=2),r[s].length>=c+(c>>2)){ro.warn?.("maxConnections reached, removing some connections",c);let l=[...r[s]];l.sort((f,m)=>f.distance-m.distance);let u=l.slice(0,c),d=l.slice(c);r[s]=u;for(let f of d){let m=a(f.id)??this.indexStore.get(f.id);m&&m[s]&&(m=a(f.id,m),m[s]=m[s].filter(({id:p})=>p!==t),s===0&&m[s].length===0&&ro.info?.("should not remove last connection",t,n))}}r[s].find(({id:l})=>l===n)?ro.debug?.("already connected",t,n):r[s]=[...r[s],{id:n,distance:i}]}validateConnectivity(t=0){let r=this.getEntryPoint(),n=new Set,s=[r.id];n.add(r.id);let i=0;for(;s.length>0;){let a=s.shift(),c=this.indexStore.get(a);for(let l=t;l<=c.level;l++)for(let{id:u}of c[l]||[])i++,n.has(u)||(n.add(u),s.push(u))}return n.size!==this.totalNodes&&console.log("visited",n.size,"total",this.totalNodes),{isFullyConnected:n.size===this.totalNodes,averageConnections:i/n.size}}get totalNodes(){return Array.from(this.indexStore.getKeys({start:0,end:1/0})).length}estimateCountAsSort(){return Math.sqrt(this.indexStore.getStats().entryCount*this.efConstructionSearch)}propertyResolver(t,r,n){let s=r?.sort;if(s){let i=s.vectorDistances;if(i){let l=i.get(n);if(l)return l}else i=r.vectorDistances=s.vectorDistances=new Map;let a=this.distance;s.type&&(a=s.distance==="euclidean"?Qg:Jg);let c=a(s.target,t);return i.set(n,c),c}return t}}});var eN,_G=se(()=>{EG();eN={HNSW:Xg}});var ft={};Re(ft,{NON_REPLICATING_SYSTEM_TABLES:()=>Zg,database:()=>td,databaseEnvs:()=>Ko,databases:()=>De,dropDatabase:()=>QI,dropTableMeta:()=>ooe,getDatabases:()=>at,getDefaultCompression:()=>oS,getTables:()=>roe,onRemovedDB:()=>Bp,onUpdatedTable:()=>Ol,readMetaDb:()=>Lp,resetDatabases:()=>Td,table:()=>Ze,tables:()=>Sn});function xp(e,t){let r=sS.OpenDBIObject??sS.default.OpenDBIObject;return new r(e,t)}function roe(){return nS||at(),Sn||{}}function at(){if(nS)return De;nS=!0,gd=new Map;let e=(0,zt.getHdbBasePath)()&&(0,Ht.join)((0,zt.getHdbBasePath)(),qc),t=(0,zt.get)(F.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,zt.get)(F.STORAGE_PATH)||e&&((0,ms.existsSync)(e)?e:(0,Ht.join)((0,zt.getHdbBasePath)(),XE)),!!e){if((0,ms.existsSync)(e))for(let r of(0,ms.readdirSync)(e,{withFileTypes:!0})){let n=(0,Ht.basename)(r.name,".mdb");r.isFile()&&(0,Ht.extname)(r.name).toLowerCase()===".mdb"&&!t[n]?.path&&Lp((0,Ht.join)(e,r.name),null,n)}if((0,ms.existsSync)((0,_d.getBaseSchemaPath)())){for(let r of(0,ms.readdirSync)((0,_d.getBaseSchemaPath)(),{withFileTypes:!0}))if(!r.isFile()){let n=(0,Ht.join)((0,_d.getBaseSchemaPath)(),r.name),s=(0,Ht.join)((0,_d.getTransactionAuditStoreBasePath)(),r.name);for(let i of(0,ms.readdirSync)(n,{withFileTypes:!0}))if(i.isFile()&&(0,Ht.extname)(i.name).toLowerCase()===".mdb"){let a=(0,Ht.join)(s,i.name);Lp((0,Ht.join)(n,i.name),(0,Ht.basename)(i.name,".mdb"),r.name,a,!0)}}}if(t)for(let r in t){let n=t[r],s=n.path;if((0,ms.existsSync)(s))for(let a of(0,ms.readdirSync)(s,{withFileTypes:!0}))a.isFile()&&(0,Ht.extname)(a.name).toLowerCase()===".mdb"&&Lp((0,Ht.join)(s,a.name),(0,Ht.basename)(a.name,".mdb"),r);let i=n.tables;if(i)for(let a in i){let c=i[a],l=(0,Ht.join)(c.path,(0,Ht.basename)(a+".mdb"));(0,ms.existsSync)(l)&&Lp(l,a,r,null,!0)}}for(let r in De){let n=gd.get(r);if(n){let s=De[r];r.includes("delete")&&Nr.trace(`defined tables ${Array.from(n.keys())}`);for(let i in s)n.has(i)||(Nr.trace(`delete table class ${i}`),delete s[i])}else if(delete De[r],r==="data"){for(let s in Sn)delete Sn[s];delete Sn[iS]}}if((0,zt.get)(F.ANALYTICS_REPLICATE)===!1?Zg.includes("hdb_analytics")||Zg.push("hdb_analytics"):(De.system?.hdb_analytics?.enableAuditing(),De.system?.hdb_analytics_hostname?.enableAuditing()),De.system)for(let r of Zg)De.system[r]&&(De.system[r].replicate=!1);return gd=null,De}}function Td(){nS=!1;for(let[,e]of Ko)e.needsDeletion=!0;at();for(let[e,t]of Ko)if(t.needsDeletion&&!e.endsWith("system.mdb")){t.close(),Ko.delete(e);let r=De[t.databaseName];for(let n in r)if(r[n].primaryStore.path===e){delete De[t.databaseName],Mp.forEach(i=>i(t.databaseName));break}}return De}function Lp(e,t,r=nN,n,s){let i=new tN.default(e,!1);try{let a=Ko.get(e);a?a.needsDeletion=!1:(a=(0,Sd.open)(i),Ko.set(e,a));let c=new xp(!1),l=a.dbisDb||(a.dbisDb=a.openDB(eS.INTERNAL_DBIS_NAME,c)),u=a.auditStore;u||(n?(0,ms.existsSync)(n)&&(i.path=n,u=(0,Sd.open)(i),u.isLegacy=!0):u=M_(a));let d=RG(r),f=d[iS],m=new Map;for(let{key:p,value:h}of l.getRange({start:!1})){let[E,g]=p.toString().split("/");g===""?g=h.name:g||(g=E,E=t,h.name||(h.name=g,h.indexed=!h.is_hash_attribute)),f?.add(E);let R=m.get(E);R||m.set(E,R={attributes:[]}),(g==null||h.is_hash_attribute)&&(R.primary=h),g!=null&&R.attributes.push(h),Object.defineProperty(h,"key",{value:p,configurable:!0})}for(let[p,h]of m){let{attributes:E,primary:g}=h;if(!g){for(let te of E)if(te.is_hash_attribute||te.isPrimaryKey){g=te;break}if(!g){Nr.warn(`Unable to find a primary key attribute on table ${p}, with attributes: ${JSON.stringify(E)}`);continue}}let R=d[p],S={},y=[],C,I,k=typeof g.audit=="boolean"?g.audit:(0,zt.get)(F.LOGGING_AUDITLOG),J=g.trackDeletes,G=g.expiration,H=g.eviction,X=g.sealed,W=g.splitSegments,ue=g.replicate;if(R)S=R.indices,y=R.attributes,R.schemaVersion++;else{C=g.tableId,C?C>=(l.get(Ed)||0)&&(l.putSync(Ed,C+1),Nr.info(`Updating next table id (it was out of sync) to ${C+1} for ${p}`)):(g.tableId=C=l.get(Ed),C||(C=1),Nr.debug("Table {tableName} missing an id, assigning {tableId}"),l.putSync(Ed,C+1),l.putSync(g.key,g));let te=new xp(!g.is_hash_attribute,g.is_hash_attribute);if(te.compression=g.compression,te.compression){let ye=(0,zt.get)(F.STORAGE_COMPRESSION_THRESHOLD)||yG;te.compression.threshold=ye}I=z_(a.openDB(g.key,te),a),a.databaseName=r,I.tableId=C}let ce;for(let te of E){te.attribute=te.name;try{if(!te.is_hash_attribute&&(te.indexed||te.attribute&&!te.name)){if(!S[te.name]){let Ae=AG(te.key,a,te);S[te.name]=Ae,S[te.name].indexNulls=te.indexNulls}let ye=y.find(Ae=>Ae.name===te.name);ye?y.splice(y.indexOf(ye),1,te):y.push(te),ce=!0}}catch(ye){Nr.error("Error trying to update attribute",te,y,S,ye)}}for(let te of y)if(!E.find(Ae=>Ae.name===te.name)){if(te.is_hash_attribute){Nr.error("Unable to remove existing primary key attribute",te);continue}te.indexed&&(y.splice(y.indexOf(te),1),ce=!0)}if(R)ce&&(R.schemaVersion++,R.updatedAttributes());else{R=bG(d,p,jg({primaryStore:I,auditStore:u,audit:k,sealed:X,splitSegments:W,replicate:ue,expirationMS:G&&G*1e3,evictionMS:H&&H*1e3,trackDeletes:J,tableName:p,tableId:C,primaryKey:g.name,databasePath:s?r+"/"+p:r,databaseName:r,indices:S,attributes:E,schemaDefined:g.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let te of Dp)te(R)}}return a}catch(a){throw a.message+=` opening database ${e}`,a}}function RG(e){let t=De[e];if(t||(e==="data"?t=De[e]=Sn:e==="system"?Object.defineProperty(De,"system",{value:t=Object.create(null),configurable:!0}):t=De[e]=Object.create(null)),gd&&!gd.has(e)){let r=new Set;t[iS]=r,gd.set(e,r)}return t}function bG(e,t,r){return e[t]=r,r}function td({database:e,table:t}){e||(e=nN),at();let r=RG(e),n=(0,Ht.join)((0,zt.getHdbBasePath)(),qc),s=(0,zt.get)(F.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,zt.get)(F.STORAGE_PATH)||((0,ms.existsSync)(n)?n:(0,Ht.join)((0,zt.getHdbBasePath)(),XE));let a=(0,Ht.join)(n,(i?t:e)+".mdb"),c=Ko.get(a);if(!c||c.status==="closed"){let l=new tN.default(a,!1);c=(0,Sd.open)(l),Ko.set(a,c)}return c.auditStore||(c.auditStore=M_(c)),c}async function QI(e){if(!De[e])throw new Error("Schema does not exist");let t=De[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Ko.delete(r.path),r.status==="open"&&(await r.close(),await vp.remove(r.path));if(r||(r=td({database:e,table:null}),r.status==="open"&&(await r.close(),await vp.remove(r.path))),e==="data"){for(let n in Sn)delete Sn[n];delete Sn[iS]}delete De[e],Mp.forEach(n=>n(e)),await jb(r)}function AG(e,t,r){let n=r.is_hash_attribute||r.indexed.type&&eN[r.indexed.type]?.useObjectStore,s=new xp(!n,n),i=t.openDB(e,s);if(r.indexed.type){let a=eN[r.indexed.type];a?i.customIndex=new a(i,r.indexed):Nr.error(`The indexing type '${r.indexed.type}' is unknown`)}return i}function Ze(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:a,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:f,schemaDefined:m,origin:p}=e;r||(r=nN);let h=td({database:r,table:t}),E=De[r];Nr.trace(`Defining ${t} in ${r}`);let g=E?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let R,S,y;m==null&&(m=!0);let C=new xp(!1);for(let W of a)W.attribute&&!W.name?(W.name=W.attribute,W.indexed=!0):W.attribute=W.name,W.expiresAt&&(W.indexed=!0);let I,k;if(g){if(R=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...a)}else{let W=h.auditStore;S=a.find(ye=>ye.isPrimaryKey)||{},R=S.name,S.is_hash_attribute=S.isPrimaryKey=!0,S.schemaDefined=m,S.compression=oS(),f&&(S.trackDeletes=!0),c=S.audit=typeof c=="boolean"?c:(0,zt.get)(F.LOGGING_AUDITLOG),n&&(S.expiration=n),s&&(S.eviction=s),u??=!1,S.splitSegments=u,typeof l=="boolean"&&(S.sealed=l),typeof d=="boolean"&&(S.replicate=d),p&&(S.origins?S.origins.includes(p)||S.origins.push(p):S.origins=[p]),Nr.trace(`${t} table loading, opening primary store`);let ue=new xp(!1,!0);ue.compression=S.compression;let ce=t+"/";if(y=h.dbisDb=h.openDB(eS.INTERNAL_DBIS_NAME,C),X(),y.get(ce))return k&&k(),Td(),Ze(e);let te=z_(h.openDB(ce,ue),h);h.databaseName=r,te.tableId=y.get(Ed),Nr.trace(`Assigning new table id ${te.tableId} for ${t}`),te.tableId||(te.tableId=1),y.put(Ed,te.tableId+1),S.tableId=te.tableId,g=bG(E,t,jg({primaryStore:te,auditStore:W,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:f,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:R,tableName:t,tableId:te.tableId,databasePath:r,databaseName:r,indices:{},attributes:a,schemaDefined:m,dbisDB:y})),g.schemaVersion=1,I=!0,y.put(ce,S)}let J=g.indices;y=y||(h.dbisDb=h.openDB(eS.INTERNAL_DBIS_NAME,C)),g.dbisDB=y;let G=[];for(let{key:W,value:ue}of y.getRange({start:!0})){let[ce,te]=W.toString().split("/");if(te===""&&(te=ue.name),te){if(ce!==t)continue}else continue;let ye=a.find(Ye=>Ye.name===te),Ae=!ye?.indexed&&ue.indexed&&!ue.isPrimaryKey;if((!ye||Ae)&&(X(),I=!0,ye||y.remove(W),Ae)){let Ye=g.indices[ce];Ye&&G.push(Ye)}}let H=[];try{for(let W of a||[]){if((W.relationship||W.computed)&&(I=!0,W.relationship))continue;let ue=t+"/"+(W.name||"");Object.defineProperty(W,"key",{value:ue,configurable:!0});let ce=y.get(ue);if(W.isPrimaryKey){if(ce=ce||y.get(ue=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||d!==void 0&&d!==g.replicate||(+n||void 0)!==(+ce.expiration||void 0)||(+s||void 0)!==(+ce.eviction||void 0)||W.type!==ce.type){let ye={...ce};typeof c=="boolean"&&(c&&g.enableAuditing(c),ye.audit=c),n&&(ye.expiration=+n),s&&(ye.eviction=+s),l!==void 0&&(ye.sealed=l),d!==void 0&&(ye.replicate=d),W.type&&(ye.type=W.type),I=!0,X(),y.put(ue,ye)}continue}ce?.attribute&&!ce.name&&(ce.indexed=!0);let te=!ce||ce.type!==W.type||JSON.stringify(ce.indexed)!==JSON.stringify(W.indexed)||ce.nullable!==W.nullable||ce.version!==W.version||JSON.stringify(ce.properties)!==JSON.stringify(W.properties)||JSON.stringify(ce.elements)!==JSON.stringify(W.elements);if(W.indexed){let ye=AG(ue,h,W);(te||ce.indexingPID&&ce.indexingPID!==process.pid||ce.restartNumber<Up.workerData?.restartNumber)&&(I=!0,X(),ce=y.get(ue),(te||ce.indexingPID&&ce.indexingPID!==process.pid||ce.restartNumber<Up.workerData?.restartNumber)&&(I=!0,W.indexNulls===void 0&&(W.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(W.lastIndexedKey=ce?.lastIndexedKey??void 0,W.indexingPID=process.pid,ye.isIndexing=!0,Object.defineProperty(W,"dbi",{value:ye}),H.push(W))),y.put(ue,W)),ce?.indexNulls&&W.indexNulls===void 0&&(W.indexNulls=!0),ye.indexNulls=W.indexNulls,J[W.name]=ye}else te&&(I=!0,X(),y.put(ue,W))}}finally{k&&k()}if(I&&(g.schemaVersion++,g.updatedAttributes()),Nr.trace(`${t} table loading, running index`),H.length>0||G.length>0?g.indexingOperation=ioe(g,H,G):I&&tS.signalSchemaChange(new rS.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=p,I)for(let W of Dp)W(g,p!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Nr.trace(`${t} table loaded`),g;function X(){k||h.transactionSync(()=>({then(W){k=W}}))}o(X,"startTxn")}async function ioe(e,t,r){try{Nr.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await tS.signalSchemaChange(new rS.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,a={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let f of t)(0,Sd.compareKeys)(f.lastIndexedKey,u)<0&&(u=f.lastIndexedKey),f.lastIndexedKey==null&&f.dbi.clearAsync();let d=0;for(let{key:f,value:m,version:p}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(m){if(d++,s=e.primaryStore.ifVersion(f,p,()=>{for(let h=0;h<l;h++){let E=t[h],g=E.name,R=E.dbi;try{let S=E.resolve,y=m&&(S?S(m):m[g]);if(R.customIndex){R.customIndex.index(f,y);continue}let C=(0,gG.getIndexedValues)(y);if(C)for(let I=0,k=C.length;I<k;I++)R.put(C[I],f)}catch(S){a[g]||(a[g]=!0,Nr.error(`Error indexing attribute ${g}`,S))}}}),s.then(()=>d--,h=>{d--,Nr.error(h)}),Up.workerData&&Up.workerData.restartNumber!==TG.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=f,e.dbisDB.put(h.key,h);if(i)return}d>noe?await s:d>soe&&await new Promise(h=>setImmediate(h))}for(let f of t)delete f.lastIndexedKey,delete f.indexingPID,f.dbi.isIndexing=!1,s=e.dbisDB.put(f.key,f)}await s,await tS.signalSchemaChange(new rS.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Nr.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Nr.error("Error in indexing",n)}}function ooe({table:e,database:t}){let r=td({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 Ol(e){return Dp.push(e),{remove(){let t=Dp.indexOf(e);t>-1&&Dp.splice(t,1)}}}function Bp(e){return Mp.push(e),{remove(){let t=Mp.indexOf(e);t>-1&&Mp.splice(t,1)}}}function oS(){let e=(0,zt.get)(F.STORAGE_COMPRESSION),t=(0,zt.get)(F.STORAGE_COMPRESSION_DICTIONARY),r=(0,zt.get)(F.STORAGE_COMPRESSION_THRESHOLD)||yG,n={startingOffset:32};return t&&(n.dictionary=vp.readFileSync(t)),r&&(n.threshold=r),e&&n}var zt,eS,Sd,Ht,ms,_d,tN,vp,rN,gG,tS,rS,Up,SG,TG,sS,toe,Nr,nN,iS,yG,Zg,Sn,De,Ed,Dp,Mp,nS,Ko,gd,noe,soe,we=se(()=>{zt=b(me()),eS=b(Yt()),Sd=require("lmdb"),Ht=require("path"),ms=require("fs"),_d=b(Rt());Z_();tN=b(Vm());q();vp=b(require("fs-extra")),rN=b(si()),gG=b(Ln()),tS=b(Ho()),rS=b(ss()),Up=require("worker_threads"),SG=b(Q()),TG=b(nt());Bi();el();Zn();_G();sS=b($m()),{forComponent:toe}=SG.default;o(xp,"OpenDBIObject");Nr=toe("storage"),nN="data",iS=Symbol("defined-tables"),yG=((0,zt.get)(F.STORAGE_PAGESIZE)||4096)-60;(0,zt.initSync)();Zg=["hdb_temp","hdb_certificate","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_info"],Sn=Object.create(null),De=Object.create(null);(0,rN._assignPackageExport)("databases",De);(0,rN._assignPackageExport)("tables",Sn);Ed=Symbol.for("next-table-id"),Dp=[],Mp=[],Ko=new Map;o(roe,"getTables");o(at,"getDatabases");o(Td,"resetDatabases");o(Lp,"readMetaDb");o(RG,"ensureDB");o(bG,"setTable");o(td,"database");o(QI,"dropDatabase");o(AG,"openIndex");o(Ze,"table");noe=1e3,soe=10;o(ioe,"runIndexing");o(ooe,"dropTableMeta");o(Ol,"onUpdatedTable");o(Bp,"onRemovedDB");o(oS,"getDefaultCompression")});var ae=v(be=>{"use strict";var tc=require("path"),OG=require("fs-extra"),$n=Q(),IG=require("fs-extra"),aS=require("os"),aoe=require("net"),coe=require("recursive-iterator"),Cr=(q(),M(z)),{PACKAGE_ROOT:loe}=Ct(),uoe=bb(),wG=require("papaparse"),cS=require("moment"),{inspect:doe}=require("util"),NG=require("is-number"),foe=require("minimist"),moe=require("https"),poe=require("http"),hoe=/^((\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)))$/,PG=require("util").promisify(setTimeout),Eoe=100,_oe=5,goe="",Soe=4,CG={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};be.isEmpty=ps;be.isEmptyOrZeroLength=no;be.arrayHasEmptyValues=Roe;be.arrayHasEmptyOrZeroLengthValues=boe;be.buildFolderPath=Aoe;be.isBoolean=LG;be.errorizeMessage=Toe;be.stripFileExtension=woe;be.autoCast=Noe;be.autoCastJSON=DG;be.autoCastJSONDeep=iN;be.removeDir=Coe;be.compareVersions=Ooe;be.isCompatibleDataVersion=Poe;be.escapeRawValue=Loe;be.unescapeValue=Doe;be.stringifyProps=Moe;be.timeoutPromise=Uoe;be.isClusterOperation=Boe;be.getClusterUser=koe;be.checkGlobalSchemaTable=Foe;be.getHomeDir=vG;be.getPropsFilePath=voe;be.promisifyPapaParse=Hoe;be.removeBOM=UG;be.createEventPromise=Goe;be.checkProcessRunning=qoe;be.checkSchemaTableExist=$oe;be.checkSchemaExists=xG;be.checkTableExists=BG;be.getStartOfTomorrowInSeconds=Voe;be.getLimitKey=Koe;be.isObject=Ioe;be.isNotEmptyAndHasValue=yoe;be.autoCasterIsNumberCheck=MG;be.backtickASTSchemaItems=Yoe;be.isPortTaken=xoe;be.createForkArgs=Woe;be.autoCastBoolean=zoe;be.asyncSetTimeout=PG;be.getTableHashAttribute=joe;be.doesSchemaExist=Qoe;be.doesTableExist=Joe;be.stringifyObj=Xoe;be.ms_to_time=Zoe;be.changeExtension=eae;be.getEnvCliRootPath=oN;be.noBootFile=tae;be.httpRequest=rae;be.transformReq=nae;be.convertToMS=sae;be.PACKAGE_ROOT=loe;function Toe(e){return e instanceof Error?e:new Error(e)}o(Toe,"errorizeMessage");function ps(e){return e==null}o(ps,"isEmpty");function yoe(e){return!ps(e)&&(e||e===0||e===""||LG(e))}o(yoe,"isNotEmptyAndHasValue");function no(e){return ps(e)||e.length===0||e.size===0}o(no,"isEmptyOrZeroLength");function Roe(e){if(ps(e))return!0;for(let t=0;t<e.length;t++)if(ps(e[t]))return!0;return!1}o(Roe,"arrayHasEmptyValues");function boe(e){if(no(e))return!0;for(let t=0;t<e.length;t++)if(no(e[t]))return!0;return!1}o(boe,"arrayHasEmptyOrZeroLengthValues");function Aoe(...e){try{return e.join(tc.sep)}catch{console.error(e)}}o(Aoe,"buildFolderPath");function LG(e){return ps(e)?!1:e===!0||e===!1}o(LG,"isBoolean");function Ioe(e){return ps(e)?!1:typeof e=="object"}o(Ioe,"isObject");function woe(e){return no(e)?goe:e.slice(0,-Soe)}o(woe,"stripFileExtension");function Noe(e){return ps(e)||e===""||typeof e!="string"?e:CG[e]!==void 0?CG[e]:MG(e)===!0?Number(e):hoe.test(e)?new Date(e):e}o(Noe,"autoCast");function DG(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}o(DG,"autoCastJSON");function iN(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=iN(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=iN(r);n!==r&&(e[t]=n)}return e}else return DG(e)}o(iN,"autoCastJSONDeep");function MG(e){if(e.startsWith("0.")&&NG(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&NG(e))}o(MG,"autoCasterIsNumberCheck");async function Coe(e){if(no(e))throw new Error(`Directory path: ${e} does not exist`);try{await IG.emptyDir(e),await IG.remove(e)}catch(t){throw $n.error(`Error removing files in ${e} -- ${t}`),t}}o(Coe,"removeDir");function Ooe(e,t){if(no(e)){$n.info("Invalid current version sent as parameter.");return}if(no(t)){$n.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,a=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(a.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(a[u],10)-parseInt(c[u],10),r)return r;return a.length-c.length}o(Ooe,"compareVersions");function Poe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}o(Poe,"isCompatibleDataVersion");function Loe(e){if(ps(e))return e;let t=String(e);return t==="."?Cr.UNICODE_PERIOD:t===".."?Cr.UNICODE_PERIOD+Cr.UNICODE_PERIOD:t.replace(Cr.FORWARD_SLASH_REGEX,Cr.UNICODE_FORWARD_SLASH)}o(Loe,"escapeRawValue");function Doe(e){if(ps(e))return e;let t=String(e);return t===Cr.UNICODE_PERIOD?".":t===Cr.UNICODE_PERIOD+Cr.UNICODE_PERIOD?"..":String(e).replace(Cr.ESCAPED_FORWARD_SLASH_REGEX,"/")}o(Doe,"unescapeValue");function Moe(e,t){if(ps(e))return $n.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let a of i)r+=";"+a+aS.EOL}!no(n)&&n[0]===";"?r+=" "+n+s+aS.EOL:no(n)||(r+=n+"="+s+aS.EOL)}catch{$n.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}o(Moe,"stringifyProps");function vG(){let e;try{e=aS.homedir()}catch{e=process.env.HOME}return e}o(vG,"getHomeDir");function voe(){let e=tc.join(vG(),Cr.HDB_HOME_DIR_NAME,Cr.BOOT_PROPS_FILE_NAME);return OG.existsSync(e)||(e=tc.join(__dirname,"../","hdb_boot_properties.file")),e}o(voe,"getPropsFilePath");function Uoe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:o(function(){clearTimeout(r)},"cancel")}}o(Uoe,"timeoutPromise");async function xoe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=aoe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}o(xoe,"isPortTaken");function Boe(e){try{return Cr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){$n.error(`Error checking operation against cluster ops ${t}`)}return!1}o(Boe,"isClusterOperation");function Foe(e,t){let r=(we(),M(ft)).getDatabases();if(!r[e])return lS.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return lS.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}o(Foe,"checkGlobalSchemaTable");function koe(e,t){if(ps(t)){$n.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ps(e)||no(e)){$n.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){$n.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){$n.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}o(koe,"getClusterUser");function Hoe(){wG.parsePromise=function(e,t,r){return new Promise(function(n,s){wG.parse(e,{header:!0,transformHeader:UG,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}o(Hoe,"promisifyPapaParse");function UG(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}o(UG,"removeBOM");function Goe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;$n.info(`Got cluster status event response: ${doe(s)}`);try{i.cancel()}catch{$n.error("Error trying to cancel timeout.")}n(s)})})}o(Goe,"createEventPromise");async function qoe(e){let t=!0,r=0;do await PG(Eoe*r++),(await uoe.findPs(e)).length>0&&(t=!1);while(t&&r<_oe);if(t)throw new Error(`process ${e} was not started`)}o(qoe,"checkProcessRunning");function $oe(e,t){let r=xG(e);if(r)return r;let n=BG(e,t);if(n)return n}o($oe,"checkSchemaTableExist");function xG(e){let{getDatabases:t}=(we(),M(ft));if(!t()[e])return lS.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}o(xG,"checkSchemaExists");function BG(e,t){let{getDatabases:r}=(we(),M(ft));if(!r()[e][t])return lS.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}o(BG,"checkTableExists");function Voe(){let e=cS().utc().add(1,"d").startOf("d").unix(),t=cS().utc().unix();return e-t}o(Voe,"getStartOfTomorrowInSeconds");function Koe(){return cS().utc().format("DD-MM-YYYY")}o(Koe,"getLimitKey");function Yoe(e){try{let t=new coe(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){$n.error("Got an error back ticking items."),$n.error(t)}}o(Yoe,"backtickASTSchemaItems");function Woe(e){return[e]}o(Woe,"createForkArgs");function zoe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}o(zoe,"autoCastBoolean");function joe(e,t){let{getDatabases:r}=(we(),M(ft)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}o(joe,"getTableHashAttribute");function Qoe(e){let{getDatabases:t}=(we(),M(ft));return t()[e]!==void 0}o(Qoe,"doesSchemaExist");function Joe(e,t){let{getDatabases:r}=(we(),M(ft));return r()[e]?.[t]!==void 0}o(Joe,"doesTableExist");function Xoe(e){try{return JSON.stringify(e)}catch{return e}}o(Xoe,"stringifyObj");function Zoe(e){let t=cS.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}o(Zoe,"ms_to_time");function eae(e,t){let r=tc.basename(e,tc.extname(e));return tc.join(tc.dirname(e),r+t)}o(eae,"changeExtension");function oN(){if(process.env[Cr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Cr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=foe(process.argv);if(e[Cr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Cr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}o(oN,"getEnvCliRootPath");var sN;function tae(){if(sN)return sN;let e=oN();if(oN()&&OG.pathExistsSync(tc.join(e,Cr.HDB_CONFIG_FILE)))return sN=!0,!0}o(tae,"noBootFile");function rae(e,t){let r;return e.protocol==="http:"?r=poe:r=moe,new Promise((n,s)=>{let i=r.request(e,a=>{a.setEncoding("utf8"),a.body="",a.on("data",c=>{a.body+=c}),a.on("end",()=>{n(a)})});i.on("error",a=>{s(a)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}o(rae,"httpRequest");function nae(e){if(!e.schema&&!e.database){e.schema=Cr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}o(nae,"transformReq");function sae(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}o(sae,"convertToMS");var lS=zr()});var $G=v((zMe,qG)=>{"use strict";var{promises:yd,createReadStream:iae,createWriteStream:oae}=require("fs"),{createGzip:aae}=require("zlib"),{promisify:cae}=require("util"),{pipeline:lae}=require("stream"),uae=cae(lae),cN=require("path"),GG=me();GG.initSync();var uS=Q(),{CONFIG_PARAMS:dae,ITC_EVENT_TYPES:YMe}=(q(),M(z)),{onMessageFromWorkers:WMe}=nt(),{convertToMS:FG}=ae(),{onStorageReclamation:fae}=(P_(),M(OU)),mae=6e4,pae="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",hae="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",aN,kG;qG.exports=Eae;function Eae({logger:e,maxSize:t,interval:r,retention:n,enabled:s,path:i,auditInterval:a}){if(s===!1)return;let c=0;if(fae(e.path,f=>{c=f},!0),!t&&!r)throw new Error(pae);if(!i)throw new Error(hae);let l;if(t){let f=t.slice(-1),m=t.slice(0,-1);f==="G"?l=m*1e9:f==="M"?l=m*1e6:l=m*1e3}let u;r&&(u=FG(r));let d;return aN=Date.now(),uS.trace("Log rotate enabled, maxSize:",t,"interval:",r),kG=setInterval(async()=>{if(l){let f;f=await yd.stat(e.path),f.size>=l&&(d=await HG(e.path,i))}if(u&&Date.now()-aN>=u&&(d=await HG(e.path,i),aN=Date.now()),n||c){let f=FG(n??"1M")/(1+c);c=0;let m=await yd.readdir(i);for(let p of m)try{let h=await yd.stat(cN.join(i,p));Date.now()-h.mtimeMs>f&&await yd.unlink(cN.join(i,p))}catch(h){uS.error("Error trying to remove log",p,h)}}},a??mae).unref(),{end(){clearInterval(kG)},getLastRotatedLogPath(){return d}}}o(Eae,"logRotator");async function HG(e,t){let r=GG.get(dae.LOGGING_ROTATION_COMPRESS),n=cN.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);return await yd.rename(e,n),r&&(e=n,n+=".gz",await uae(iae(e),aae(),oae(n)),await yd.unlink(e)),uS.closeLogFile(),uS.notify(`hdb.log rotated, old log moved to ${n}`),n}o(HG,"moveLogFile")});var zG={};Re(zG,{RootConfigWatcher:()=>lN});var VG,KG,YG,dS,WG,lN,jG=se(()=>{VG=b(require("chokidar")),KG=require("node:fs/promises"),YG=b(St()),dS=require("node:stream"),WG=require("yaml"),lN=class extends dS.EventEmitter{static{o(this,"RootConfigWatcher")}#e;#t;#r;ready;constructor(){super(),this.#e=(0,YG.getConfigFilePath)(),this.ready=(0,dS.once)(this,"ready"),this.#t=VG.default.watch(this.#e,{persistent:!1}).on("add",this.handleChange.bind(this)).on("change",this.handleChange.bind(this)).on("error",this.handleError.bind(this))}handleError(t){this.emit("error",t)}handleChange(){(0,KG.readFile)(this.#e,"utf-8").then(t=>{if(!t)return;let r=(0,WG.parse)(t);if(!this.#r){this.#r=r,this.emit("ready",this.#r);return}this.emit("change",this.#r=r)}).catch(t=>{})}close(){return this.#t.close(),this.#r=void 0,this.emit("close"),this.removeAllListeners(),this}get config(){return this.#r}}});var Q=v((ZMe,SS)=>{"use strict";var Yo=require("fs-extra"),{workerData:_ae,threadId:gae,isMainThread:tq}=require("worker_threads"),Hp=require("path"),rq=require("yaml"),nq=require("properties-reader"),$r=(q(),M(z)),QG=$c(),Sae=require("os"),{PACKAGE_ROOT:_N}=Ct(),{_assignPackageExport:Tae}=si(),{Console:yae}=require("console"),dN=process.env.IS_SCRIPTED_SERVICE?function(){}:process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),JG=new Map,{join:Wo}=Hp,XG=1e4,sr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},Rae={STDOUT:"stdOut",STDERR:"stdErr"},XMe=Wo(_N,"logs"),bae=Wo(_N,"config/yaml/",$r.HDB_DEFAULT_CONFIG_FILE),Aae=1e4,Gp,qp,fS,so,fN,uN,pS,Lt,hs,hS,ES,Rd,kp,Fp;function mS(e,t,r){e.rotation=t.rotation;let n=t.path;n?t.root||(t.root=Hp.dirname(n)):t.root?n=Wo(t.root,fN):(n=Lt.path,t.root||(t.root=Hp.dirname(n))),n?e.path=n:console.error("No path for logger",t),e.level=sr[t.level]??Lt?.level??sr.info,sq(e),e.logToStdstreams=t.stdStreams??!1,e.tag=t.tag??(Lt.path===e.path&&r)}o(mS,"updateLogger");function sq(e){let t=e.conditional??(e.conditional={});t.notify=sr.notify>=e.level?e.notify.bind(e):void 0,t.fatal=sr.fatal>=e.level?e.fatal.bind(e):void 0,t.error=sr.error>=e.level?e.error.bind(e):void 0,t.warn=sr.warn>=e.level?e.warn.bind(e):void 0,t.info=sr.info>=e.level?e.info.bind(e):void 0,t.debug=sr.debug>=e.level?e.debug.bind(e):void 0,t.trace=sr.trace>=e.level?e.trace.bind(e):void 0}o(sq,"updateConditional");async function mN(){Fp||(Fp=new Vae,await Fp.ready,Fp.on("change",mN));let e=Fp.config,t=e.logging??{};mS(Lt,t),pS=Lt.path,Gp=t.console??!1,t.external&&mS(hs,t.external);for(let r in e){let n=e[r];n.logging?mS(Lt.forComponent(r),n.logging,r):Lt.hasComponent(r)&&mS(Lt.forComponent(r),t,r)}}o(mN,"updateLogSettings");var pN=class extends yae{static{o(this,"HarperLogger")}constructor(t,r){t.stdout.removeListener=()=>{},t.stderr.removeListener=()=>{},t.stdout.listenerCount=()=>{},t.stderr.listenerCount=()=>{},super(t),this.level=r}trace(...t){Tn="trace",this.level<=sr.trace&&super.info(...t),Tn="info"}debug(...t){Tn="debug",this.level<=sr.debug&&super.info(...t),Tn="info"}info(...t){Tn="info",this.level<=sr.info&&super.info(...t),Tn="info"}warn(...t){Tn="warn",this.level<=sr.warn&&super.warn(...t),Tn="info"}error(...t){Tn="error",this.level<=sr.error&&super.error(...t),Tn="info"}fatal(...t){Rd=!0;try{Tn="fatal",this.level<=sr.fatal&&super.error(...t),Tn="info"}finally{Rd=!1}}notify(...t){Rd=!0;try{Tn="notify",this.level<=sr.notify&&super.info(...t),Tn="info"}finally{Rd=!1}}withTag(t){return oq(t,!0,this)}forComponent(t){return this}hasComponent(t){return!1}};kp===void 0&&iq();SS.exports={notify:Mae,fatal:vae,error:EN,warn:Uae,info:Pae,debug:Dae,trace:Lae,logLevel:so,loggerWithTag:oq,suppressLogging:Cae,initLogSettings:iq,logCustomLevel:xae,closeLogFile:aq,createLogger:gS,logsAtLevel:wae,getLogFilePath:o(()=>pS,"getLogFilePath"),forComponent:o(e=>Lt.forComponent(e),"forComponent"),setMainLogger:qae,setLogLevel:Fae,OUTPUTS:Rae,AuthAuditLog:$ae,start:mN,startOnMainThread:mN,errorToString:Gae,disableStdio:Iae};function Iae(){dN=o(function(){},"nativeStdWrite")}o(Iae,"disableStdio");SS.exports.externalLogger={notify(...e){hs.notify(...e)},fatal(...e){hs.fatal(...e)},error(...e){hs.error(...e)},warn(...e){hs.warn(...e)},info(...e){hs.info(...e)},debug(...e){hs.debug(...e)},trace(...e){hs.trace(...e)},withTag(e){return hs.withTag(e)}};Tae("logger",SS.exports.externalLogger);function wae(e){return sr[so]<=sr[e]}o(wae,"logsAtLevel");function iq(e=!1){try{if(kp===void 0||e){aq();let t=Bae(),r=QG(["ROOTPATH"]);try{kp=nq(t)}catch(s){if(!r.ROOTPATH||r.ROOTPATH&&!Yo.pathExistsSync(Wo(r.ROOTPATH,$r.HDB_CONFIG_FILE)))throw s}let n;if({level:so,configLogPath:uN,toFile:qp,logConsole:Gp,rotation:n,toStream:fS}=kae(r.ROOTPATH?Wo(r.ROOTPATH,$r.HDB_CONFIG_FILE):kp.get("settings_path")),fN=$r.LOG_NAMES.HDB,pS=Wo(uN,fN),Lt=gS({path:pS,level:so,stdStreams:fS,rotation:n}),hs=Lt.forComponent("external"),hs.tag=null,tq)try{require("segfault-handler").registerHandler(Wo(uN,"crash.log"))}catch{}}}catch(t){if(kp=void 0,t.code===$r.NODE_ERROR_CODES.ENOENT||t.code===$r.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=QG(Object.keys($r.CONFIG_PARAM_MAP),!0);for(let s in r){let i=$r.CONFIG_PARAM_MAP[s];i&&i.toLowerCase();let a=r[s];if(i===$r.CONFIG_PARAMS.LOGGING_LEVEL){so=a;continue}i===$r.CONFIG_PARAMS.LOGGING_CONSOLE&&(Gp=i)}let{defaultLevel:n}=Hae();qp=!1,fS=!0,so=so===void 0?n:so,Lt=gS({level:so}),hs=Lt.forComponent("external"),hs.tag=null;return}throw EN("Error initializing log settings"),EN(t),t}process.env.DEV_MODE&&(fS=!0),Nae()}o(iq,"initLogSettings");var rc=!0;function Nae(){qp&&(process.stdout.write=function(e){return typeof e=="string"&&rc&&Gp&&(e=e.toString(),e[e.length-1]===`
|
|
17
17
|
`&&(e=e.slice(0,-1)),ES(e)),dN.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&rc&&Gp&&(e[e.length-1]===`
|
|
18
18
|
`&&(e=e.slice(0,-1)),ES(e)),dN.apply(process.stderr,arguments)})}o(Nae,"stdioLogging");function oq(e,t,r=Lt){return e=e.replace(/ /g,"-"),{notify:n(r.notify,"notify"),fatal:n(r.fatal,"fatal"),error:n(r.error,"error"),warn:n(r.warn,"warn"),info:n(r.info,"info"),debug:n(r.debug,"debug"),trace:n(r.trace,"trace")};function n(s,i){return!t||r.level<=sr[i]?function(...a){_S=e;try{return s.call(r,...a)}finally{_S=void 0}}:null}o(n,"logWithTag")}o(oq,"loggerWithTag");function Cae(e){try{rc=!1,e()}finally{rc=!0}}o(Cae,"suppressLogging");var Oae=_ae?.name?.replace(/ /g,"-")||"main",Tn="info",hN,_S;function gS({path:e,level:t,stdStreams:r,rotation:n,isExternalInstance:s,writeToLog:i,component:a}){t||(t="info");let c=sr[t],l;function u(p){if(qp)if(l.logToStdstreams){f(p.replace(/\x1b\[[0-9;]*m/g,"")),rc=!1;try{process.stdout.write(p)}finally{rc=!0}}else f(p);else r&&process.stdout.write(p)}o(u,"logStdOut");function d(p){if(qp){if(f(p),r){rc=!1;try{process.stderr.write(p)}finally{rc=!0}}}else r&&process.stderr.write(p)}o(d,"logStdErr");let f=e&&eq(e,n,s);function m(p){return{write(h){let E=[Tn];E.unshift(hN||Oae+"/"+gae),_S&&E.push(_S),l.tag&&E.push(l.tag),p(`[${E.join("] [")}]: ${h}`)}}}if(o(m,"logPrepend"),s&&(ES=f),l=new pN({stdout:m(i??u),stderr:m(i??d),colorMode:r??!1},c),sq(l),l.path=e,Object.defineProperty(l,"path",{get(){return e},set(p){e=p,f=eq(e,l.rotation,s),s&&(ES=f)},enumerable:!0}),l.closeLogFile=f?.closeLogFile,l.logToStdstreams=r,!a){let p=new Map;l.forComponent=function(h){let E=p.get(h);return E||(E=gS({path:e,level:t,stdStreams:r,isExternalInstance:h==="external",rotation:n,writeToLog:i,component:!0}),p.set(h,E)),E},l.hasComponent=function(h){return p.has(h)}}return l}o(gS,"createLogger");var ZG=100;function eq(e,t,r){let n=JG.get(e),s,i,a,c,l=0;n||(n=d,n.closeLogFile=m,n.path=e,JG.set(e,n)),tq&&JSON.stringify(t)!==JSON.stringify(n.rotation)&&(n.rotation=t,setTimeout(()=>{if(n.rotator?.end(),!t)return;let h=$G();try{n.rotator=h({logger:n,...t})}catch(E){n("Error initializing log rotator",E)}},100));let u=0;return n;function d(h){u++;let E=`${new Date().toISOString()} ${h}${h.endsWith(`
|
|
19
19
|
`)?"":`
|
|
@@ -22,7 +22,7 @@ var tX=Object.create;var rm=Object.defineProperty;var rX=Object.getOwnPropertyDe
|
|
|
22
22
|
`,""));return r.replace(`
|
|
23
23
|
`,"")}o(fV,"runCommand");async function vue(){try{await uue.access(SC)}catch{return!1}let e=await fV(`${SC} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return due.eq(t,Due)}o(vue,"checkNATSServerInstalled");async function AC(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let a=await uV.getClusterUser();if(xl(a))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=a.username,r=a.decrypt_hash}_i.trace("create nats connection called");let i=await bue({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Kr.get(rt.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Kr.get(rt.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Kr.get(rt.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),_i.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(a=>{a&&_i.error("Error with Nats client connection, connection closed",a),i===Rn&&mV()}),i}o(AC,"createConnection");function mV(){Rn=void 0,Ml=void 0,vl=void 0,Ul=void 0}o(mV,"clearClientCache");async function Uue(){Rn&&(await Rn.drain(),Rn=void 0,Ml=void 0,vl=void 0,Ul=void 0)}o(Uue,"closeConnection");var Rn,Ul;async function ih(){return Ul||(Ul=AC(Kr.get(rt.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Rn=await Ul),Rn||Ul}o(ih,"getConnection");async function oh(){if(Ml)return Ml;xl(Rn)&&await ih();let{domain:e}=Bd(rt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(xl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ml=await Rn.jetstreamManager({domain:e,timeout:6e4}),Ml}o(oh,"getJetStreamManager");async function pV(){if(vl)return vl;xl(Rn)&&await ih();let{domain:e}=Bd(rt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(xl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return vl=Rn.jetstream({domain:e,timeout:6e4}),vl}o(pV,"getJetStream");async function ao(){let e=Rn||await ih(),t=Ml||await oh(),r=vl||await pV();return{connection:e,jsm:t,js:r}}o(ao,"getNATSReferences");async function xue(e){let t=Kr.get(rt.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await uV.getClusterUser(),s=await AC(t,r,n),i=bC(),a=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of a){let f=dV.decode(d.data);f.response_time=Date.now()-l,c.push(f)}})();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 nT.asyncSetTimeout(e),await a.drain(),await s.close(),await u,c}o(xue,"getServerList");async function IC(e,t){let{jsm:r}=await ao(),n=Kr.get(rt.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Kr.get(rt.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Kr.get(rt.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Aue.File,retention:Iue.Limits,subjects:t,discard:wue.Old,maxMsgs:s,maxBytes:i,maxAge:n})}o(IC,"createLocalStream");async function hV(){let{jsm:e}=await ao(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}o(hV,"listStreams");async function Bue(e){let{jsm:t}=await ao();await t.streams.delete(e)}o(Bue,"deleteLocalStream");async function Fue(e){let{connection:t}=await ao(),r=[],n=bC(),s=t.subscribe(n),i=(async()=>{for await(let a of s)r.push(dV.decode(a.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}o(Fue,"listRemoteStreams");async function kue(e,t=void 0,r=void 0){let{jsm:n,js:s}=await ao(),i=oV(),a={durable_name:i,ack_policy:yC.Explicit};t&&(a.deliver_policy=RC.StartTime,a.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,a);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let d of l){let f=TC(d.data),m={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:f};if(d.headers&&(m.origin=d.headers.get(nn.MSG_HEADERS.ORIGIN)),u.push(m),d.ack(),d.info.pending===0)break}return await c.delete(),u}o(kue,"viewStream");async function*Hue(e,t=void 0,r=void 0){let{jsm:n,js:s}=await ao(),i=oV(),a={durable_name:i,ack_policy:yC.Explicit};t&&(a.deliver_policy=RC.StartTime,a.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,a);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let d=TC(u.data);d[0]||(d=[d]);for(let f of d){let m={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:f};u.headers&&(m.origin=u.headers.get(nn.MSG_HEADERS.ORIGIN)),yield m}if(u.ack(),u.info.pending===0)break}await c.delete()}o(Hue,"viewStreamIterator");async function Gue(e,t,r,n){_i.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=EV(n,r);let{js:s}=await ao(),i=await iT(),a=`${e}.${i}`,c=await Pue(()=>n instanceof Uint8Array?n:lV.encode(n));try{_i.trace(`publishToStream publishing to subject: ${a}`),Oue(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(a,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return gV(async()=>{try{await s.publish(a,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){_i.trace(`publishToStream creating stream: ${t}`);let d=a.split(".");d[2]="*",await IC(t,[a]),await s.publish(a,c,{headers:r})}else throw l}});throw l}}o(Gue,"publishToStream");function EV(e,t){t===void 0&&(t=Cue());let r=Kr.get(rt.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(nn.MSG_HEADERS.ORIGIN)&&r&&t.append(nn.MSG_HEADERS.ORIGIN,r),t}o(EV,"addNatsMsgHeader");function Bd(e){e=e.toLowerCase();let t=sh.join(Kr.get(rt.CONFIG_PARAMS.ROOTPATH),Lue);if(e===rt.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return xl(gC)&&(gC={port:rh.getConfigFromFile(rt.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:rh.getConfigFromFile(rt.CONFIG_PARAMS.CLUSTERING_NODENAME)+nn.SERVER_SUFFIX.HUB,config_file:nn.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:sh.join(t,nn.PID_FILES.HUB),hdbNatsPath:t}),gC;if(e===rt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return xl(_C)&&(_C={port:rh.getConfigFromFile(rt.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:rh.getConfigFromFile(rt.CONFIG_PARAMS.CLUSTERING_NODENAME)+nn.SERVER_SUFFIX.LEAF,config_file:nn.NATS_CONFIG_FILES.LEAF_SERVER,domain:rh.getConfigFromFile(rt.CONFIG_PARAMS.CLUSTERING_NODENAME)+nn.SERVER_SUFFIX.LEAF,pid_file_path:sh.join(t,nn.PID_FILES.LEAF),hdbNatsPath:t}),_C;_i.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}o(Bd,"getServerConfig");async function _V(e,t,r,n){try{await e.consumers.add(t,{ack_policy:yC.Explicit,durable_name:r,deliver_policy:RC.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}o(_V,"createConsumer");async function que(e,t,r){await e.consumers.delete(t,r)}o(que,"removeConsumer");function $ue(e){return e.split(".")[1]}o($ue,"extractServerName");async function Vue(e,t,r=6e4,n=bC()){if(!nT.isObject(t))throw new Error("data param must be an object");let s=lV.encode(t),{connection:i}=await ao(),a={timeout:r};n&&(a.reply=n,a.noMux=!0);let c=await i.request(e,s,a);return TC(c.data)}o(Vue,"request");function wC(e){return new Promise(async(t,r)=>{let n=hue(SC,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",a=>{r(a)}),n.stdout.on("data",a=>{i+=a.toString()}),n.stderr.on("data",a=>{s+=a.toString()}),n.stderr.on("close",a=>{s&&r(s),t(i)})})}o(wC,"reloadNATS");async function Kue(){let{pid_file_path:e}=Bd(rt.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await wC(e)}o(Kue,"reloadNATSHub");async function Yue(){let{pid_file_path:e}=Bd(rt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await wC(e)}o(Yue,"reloadNATSLeaf");function Wue(e,t,r){let n;switch(e.code){case iV.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case iV.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}o(Wue,"requestErrorHandler");async function zue(e,t){let r=t+nn.SERVER_SUFFIX.LEAF,{connection:n}=await ao(),{jsm:s}=await rde(r),{schema:i,table:a}=e,c=sT.createNatsTableStreamName(i,a),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await gV(async()=>{if(e.subscribe===!0)await _V(s,c,n.info.server_name,l);else try{await que(s,c,n.info.server_name)}catch(u){_i.trace(u)}})}o(zue,"updateRemoteConsumer");async function jue(e,t,r,n){let s=sT.createNatsTableStreamName(e,t),i=r+nn.SERVER_SUFFIX.LEAF,a={type:rt.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!cV&&yue()<Kr.get(rt.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=EC();await c(a)}await Sue(a),n==="stop"&&await nT.asyncSetTimeout(1e3)}o(jue,"updateConsumerIterator");function gV(e){return gue.writeTransaction(rt.SYSTEM_SCHEMA_NAME,rt.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}o(gV,"exclusiveLock");async function SV(e,t){let r=sT.createNatsTableStreamName(e,t),n=await iT(),s=Zue(e,t,n);await IC(r,[s])}o(SV,"createLocalTableStream");async function Que(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await SV(n,s)}}o(Que,"createTableStreams");async function TV(e,t,r=void 0){if(Kr.get(rt.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=sT.createNatsTableStreamName(e,t),{domain:s}=Bd(rt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await ih()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")_i.warn(n);else throw n}}o(TV,"purgeTableStream");async function Jue(e,t){if(Kr.get(rt.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await TV(e,t[r])}o(Jue,"purgeSchemaTableStreams");async function Xue(e){return(await oh()).streams.info(e)}o(Xue,"getStreamInfo");function Zue(e,t,r){return`${nn.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}o(Zue,"createSubjectName");async function iT(){if(nh)return nh;if(nh=(await oh())?.nc?.info?.server_name,nh===void 0)throw new Error("Unable to get jetstream manager server name");return nh}o(iT,"getJsmServerName");async function ede(){let e=await oh(),t=await iT(),r=await hV();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let a=tde(n),c=i.split(".");if(c[c.length-1]===t&&!a||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let d=u.join(".");_i.trace(`Updating stream subject name from: ${i} to: ${d}`),s.subjects[0]=d,await e.streams.update(s.name,s)}}o(ede,"updateLocalStreams");function tde(e){let{config:t}=e,r=!1,n=Kr.get(rt.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Kr.get(rt.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Kr.get(rt.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}o(tde,"updateStreamLimits");async function rde(e){let t,r;try{t=await Rn.jetstream({domain:e}),r=await Rn.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw _i.error("Unable to connect to:",e),n}return{js:t,jsm:r}}o(rde,"connectToRemoteJS")});function NC(e){let t=e.get(oT),r=t?(0,Fd.unpack)(t):null;r||(r={remoteNameToId:{}});let n=it(),s=!1;r.nodeName=it();let i=r.remoteNameToId;if(i[n]!==0){let a=0,c;for(let l in i){let u=i[l];u===0?c=l:u>a&&(a=u)}if(c){a++,i[c]=a;let l=[Symbol.for("seq"),a];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:ch(e)??1,nodes:[]})})}i[n]=0,e.putSync(oT,(0,Fd.pack)(r))}return r}function ah(e){return NC(e).remoteNameToId}function bV(e,t){let r=NC(t),n=r.remoteNameToId,s=new Map,i=!1;for(let a in e){let c=e[a],l=n[a];if(l==null){let u=0;for(let d in n){let f=n[d];f>u&&(u=f)}l=u+1,n[a]=l,i=!0}s.set(c,l)}return i&&t.putSync(oT,(0,Fd.pack)(r)),s}function aT(e,t){let r=NC(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let a in n){let c=n[a];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(oT,(0,Fd.pack)(r))}return RV.trace?.("The remote node name map",e,n,s),s}var RV,Fd,oT,CC=se(()=>{RV=b(Xn());Es();Fd=require("msgpackr"),oT=Symbol.for("remote-ids");o(NC,"getIdMappingRecord");o(ah,"exportIdMapping");o(bV,"remoteToLocalNodeId");o(aT,"getIdOfRemoteNode")});var OV={};Re(OV,{commitsAwaitingReplication:()=>Hd,getHDBNodeTable:()=>jt,getReplicationSharedStatus:()=>Gd,iterateRoutes:()=>uh,shouldReplicateToNode:()=>lh,subscribeToNodeUpdates:()=>qd});function jt(){return AV||(AV=Ze({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Gd(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(64),n&&{callback:n}))}function qd(e){jt().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;CV.debug?.("adding node",n,"on node",it()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==it()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of jt().search({}))if(i.shard!=null){let a=s.get(i.shard);a||s.set(i.shard,a=[]),a.push(i)}server.shards=s,(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function lh(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&jt().primaryStore.get(it())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function nde(){qd(e=>{sc({},(t,r)=>{let n=e.name,s=IV.get(n);if(s||IV.set(n,s=new Map),s.has(r))return;let i;for(let a in t)if(i=t[a].auditStore,i)break;if(i){let a=Gd(i,r,n,()=>{let c=a[0],l=a.lastTime;for(let{txnTime:u,onConfirm:d}of Hd.get(r)||[])u>l&&u<=c&&d();a.lastTime=c});a.lastTime=0,s.set(r,a)}})})}function*uh(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=kd.default.get(F.REPLICATION_SECUREPORT)??(!kd.default.get(F.REPLICATION_PORT)&&kd.default.get(F.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||kd.default.get(F.REPLICATION_PORT)||kd.default.get(F.OPERATIONSAPI_NETWORK_PORT);let a=i?.lastIndexOf?.(":");a>0&&(i=+i.slice(a+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){wV.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,startTime:t.startTime,revoked_certificates:t.revokedCertificates}}}var wV,NV,kd,CV,AV,IV,Hd,$d=se(()=>{we();Es();_m();wV=require("worker_threads"),NV=b(_e()),kd=b(me());q();CV=b(Xn());server.nodes=[];o(jt,"getHDBNodeTable");o(Gd,"getReplicationSharedStatus");o(qd,"subscribeToNodeUpdates");o(lh,"shouldReplicateToNode");IV=new Map;Yv((e,t,r)=>{if(r>server.nodes.length)throw new NV.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);Hd||(Hd=new Map,nde());let n=Hd.get(e);return n||(n=[],Hd.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:o(()=>{++i===r&&s()},"onConfirm")})})});o(nde,"startSubscriptionToReplications");o(uh,"iterateRoutes")});var vV={};Re(vV,{connectedToNode:()=>Bl,disconnectedFromNode:()=>Kd,ensureNode:()=>Qo,requestClusterStatus:()=>MV,startOnMainThread:()=>OC});async function OC(e){let t=0,r=at();for(let i of Object.getOwnPropertyNames(r)){let a=r[i];for(let c in a){let l=a[c];if(l.auditStore){cT.set(i,ch(l.auditStore));break}}}lo.whenThreadsStarted.then(async()=>{let i=[];for await(let l of r.system.hdb_nodes?.search([])||[])i.push(l);let a=it();function c(){let l=jt().primaryStore.get(a);if(l!==null){let u=e.url??ic();if(l===void 0||l.url!==u||l.shard!==e.shard)return Qo(a,{name:a,url:u,shard:e.shard,replicates:!0})}}o(c,"ensureThisNode"),jt().primaryStore.get(a)&&c();for(let l of uh(e))try{let u=!l.subscriptions;if(u&&await c(),u&&l.replicates==null&&(l.replicates=!0),i.find(d=>d.url===l.url))continue;s(l)}catch(u){console.error(u)}qd(s)});let n;function s(i,a=i?.name){let c=it()&&a===it()||ic()&&i?.url===ic();if(c){let f=!!i?.replicates;if(n!==void 0&&n!==f)for(let m of jt().search([]))m.replicates&&m.name!==a&&s(m,m.name);n=f}if(ut.trace("Setting up node replication for",i),!i){for(let[f,m]of co){let p;for(let[h,{worker:E,nodes:g}]of m){let R=g[0];if(R&&R.name==a){p=!0;for(let[S,{worker:y}]of m)m.delete(S),ut.warn("Node was deleted, unsubscribing from node",a,S,f),y?.postMessage({type:"unsubscribe-from-node",node:a,database:S,url:f});break}}if(p){co.get(f).iterator.remove(),co.delete(f);return}}return}if(c)return;if(!i.url){ut.info(`Node ${i.name} is missing url`);return}let l=co.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ut.info(`Added node ${i.name} at ${i.url} for process ${it()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[f,m]of Vd)if(i.url===m.url){Vd.delete(f);break}Vd.set(i.name,i)}let u=at();if(l||(l=new Map,co.set(i.url,l)),l.iterator=sc(e,(f,m,p)=>{p?d(m,!0):d(m,!1)}),i.subscriptions)for(let f of i.subscriptions){let m=f.database||f.schema;u[m]||(ut.warn(`Database ${m} not found for node ${i.name}, making a subscription anyway`),d(m,!1))}function d(f,m){ut.trace("Setting up replication for database",f,"on node",i.name);let p=l.get(f),h,E=[{replicateByDefault:m,...i}];cT.has(f)&&dh.default.get(F.REPLICATION_FAILOVER)&&(E.push({replicateByDefault:m,name:it(),startTime:cT.get(f),endTime:Date.now(),replicates:!0}),cT.delete(f));let g=lh(i,f),R=lo.workers.filter(S=>S.name==="http");if(p?(h=p.worker,p.nodes=E):g&&(t=t%R.length,h=R[t++],l.set(f,{worker:h,nodes:E,url:i.url}),h?.on("exit",()=>{l.get(f)?.worker===h&&(l.delete(f),d(f,m))})),g)setTimeout(()=>{let S={type:"subscribe-to-node",database:f,nodes:E};h?h.postMessage(S):fh(S)},sde);else{ut.info("Node no longer should be used, unsubscribing from node",{replicates:i.replicates,databaseName:f,node:i,subscriptions:i.subscriptions,hasDatabase:!!u[f],thisReplicates:jt().primaryStore.get(it())?.replicates}),jt().primaryStore.get(it())?.replicates||(n=!1,ut.info("Disabling replication, this node name",it(),jt().primaryStore.get(it()),f));let S={type:"unsubscribe-from-node",database:f,url:i.url,name:i.name};h?h.postMessage(S):uT(S)}}o(d,"onDatabase")}o(s,"onNodeUpdate"),Kd=o(function(i){try{ut.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let a=Array.from(Vd.keys()),c=a.sort(),l=c.indexOf(i.name||gi(i.url));if(l===-1){ut.warn("Disconnected node not found in node map",i.name,a);return}let u=co.get(i.url),d=u?.get(i.database);if(!d){ut.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished||!dh.default.get(F.REPLICATION_FAILOVER))return;let f=d.nodes[0];if(!(f.replicates===!0||f.replicates?.sends||f.subscriptions?.length))return;let m=f.shard,p=(l+1)%c.length;for(;l!==p;){let h=c[p],E=Vd.get(h);u=co.get(E.url);let g=u?.get(i.database);if(!g||g.connected===!1||g.nodes[0].shard!==m){p=(p+1)%c.length;continue}let{worker:R,nodes:S}=g,y=!1;for(let C of d.nodes){if(S.some(I=>I.name===C.name)){ut.info(`Disconnected node is already failing over to ${h} for ${i.database}`);continue}C.endTime<Date.now()||(S.push(C),y=!0)}if(d.nodes=[d.nodes[0]],!y){ut.info(`Disconnected node ${i.name} has no nodes to fail over to ${h}`);return}ut.info(`Failing over ${i.database} from ${i.name} to ${h}`),R?R.postMessage({type:"subscribe-to-node",database:i.database,nodes:S}):fh({database:i.database,nodes:S});return}ut.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(a){ut.error("Error failing over node",a)}},"disconnectedFromNode"),Bl=o(function(i){let a=co.get(i.url),c=a?.get(i.database);if(!c){ut.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,a);return}c.connected=!0,c.latency=i.latency;let l=c.nodes[0];if(!l){ut.warn("Newly connected node has no node subscriptions",i.database,c);return}if(!l.name){ut.debug("Connected node is not named yet",i.database,c);return}if(!dh.default.get(F.REPLICATION_FAILOVER))return;c.nodes=[l];let u=!1;for(let d of co.values()){let f=d.get(i.database);if(!f||f==c)continue;let{worker:m,nodes:p,connected:h}=f;if(p)if(h===!1&&p[0].shard===l.shard)u=!0,c.nodes.push(p[0]);else{let E=p.filter(g=>g&&g.name!==l.name);E.length<p.length&&(f.nodes=E,m.postMessage({type:"subscribe-to-node",database:i.database,nodes:p}))}}u&&c.worker&&c.worker.postMessage({type:"subscribe-to-node",database:i.database,nodes:c.nodes})},"connectedToNode"),(0,lo.onMessageByType)("disconnected-from-node",Kd),(0,lo.onMessageByType)("connected-to-node",Bl),(0,lo.onMessageByType)("request-cluster-status",MV)}function MV(e,t){let r=[];for(let[n,s]of Vd)try{let i=co.get(s.url);ut.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let a=[];if(i){for(let[l,{worker:u,connected:d,nodes:f,latency:m}]of i)a.push({database:l,connected:d,latency:m,threadId:u?.threadId,nodes:f.filter(p=>!(p.endTime<Date.now())).map(p=>p.name)});let c=LV(s);c.database_sockets=a,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ut.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Qo(e,t){let r=jt();e=e??gi(t.url),t.name=e;try{if(t.ca){let s=new DV.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subjectAltName:s.subjectAltName,serialNumber:s.serialNumber,validFrom:s.validFrom,validTo:s.validTo}}}catch(s){ut.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ut.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.patch(t);else{t.replicates&&!dh.default.get(F.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],a=LV(n[s]);for(let c of t[s]){let l=!1;for(let u of a)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...a,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}ut.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var lo,lT,ut,PV,dh,DV,LV,sde,co,Kd,Bl,Vd,cT,mh=se(()=>{we();lo=b(nt());Es();lT=require("worker_threads");$d();ut=b(Q()),PV=b(require("lodash")),dh=b(me());q();DV=require("crypto"),{cloneDeep:LV}=PV.default,sde=200,co=new Map,Vd=new Map,cT=new Map;o(OC,"startOnMainThread");o(MV,"requestClusterStatus");lT.parentPort&&(Kd=o(e=>{lT.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Bl=o(e=>{lT.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,lo.onMessageByType)("subscribe-to-node",e=>{fh(e)}),(0,lo.onMessageByType)("unsubscribe-from-node",e=>{uT(e)}));o(Qo,"ensureNode")});var gs=v(Gt=>{"use strict";var Er=require("path"),{watch:ide}=require("chokidar"),Vn=require("fs-extra"),Yd=require("node-forge"),HV=require("net"),{generateKeyPair:PC,X509Certificate:Jo,createPrivateKey:GV,randomBytes:ode}=require("node:crypto"),ade=require("util");PC=ade.promisify(PC);var Dt=Yd.pki,Si=require("joi"),{v4:qV}=require("uuid"),{validateBySchema:vC}=mt(),{forComponent:cde}=Q(),_s=me(),qs=(q(),M(z)),{CONFIG_PARAMS:kl}=qs,Ti=Aw(),{ClientError:oc}=_e(),fT=require("node:tls"),{relative:$V,join:lde}=require("node:path"),{CERTIFICATE_VALUES:UV}=Ti,ude=$c(),LC=St(),{table:dde,getDatabases:fde,databases:dT}=(we(),M(ft)),{getJWTRSAKeys:xV}=(Dd(),M(Xp)),Qe=cde("tls").conditional;Gt.generateKeys=BC;Gt.updateConfigCert=JV;Gt.createCsr=Sde;Gt.signCertificate=Tde;Gt.setCertTable=Wd;Gt.loadCertificates=zV;Gt.reviewSelfSignedCert=kC;Gt.createTLSSelector=ZV;Gt.listCertificates=t1;Gt.addCertificate=wde;Gt.removeCertificate=Cde;Gt.createNatsCerts=bde;Gt.generateCertsKeys=Rde;Gt.getReplicationCert=hh;Gt.getReplicationCertAuth=gde;Gt.renewSelfSigned=Ade;Gt.hostnamesFromCert=GC;Gt.getKey=Ode;Gt.getHostnamesFromCertificate=Pde;Gt.getPrimaryHostName=HC;Gt.generateSerialNumber=hT;var{urlToNodeName:VV,getThisNodeUrl:mde,getThisNodeName:pT,clearThisNodeName:pde}=(Es(),M(Xo)),{readFileSync:hde,statSync:KV}=require("node:fs"),qUe=me(),{getTicketKeys:Ede,onMessageFromWorkers:_de}=nt(),{isMainThread:YV}=require("worker_threads"),{TLSSocket:WV,createSecureContext:$Ue}=require("node:tls"),UC=3650,ph=["127.0.0.1","localhost","::1"],xC=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];function hT(){let e=ode(8);return e[0]=e[0]&127|1,e.toString("hex")}o(hT,"generateSerialNumber");_de(async e=>{e.type===qs.ITC_EVENT_TYPES.RESTART&&(_s.initSync(!0),await kC())});var sn;function cc(){return sn||(sn=fde().system.hdb_certificate,sn||(sn=dde({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__"}]}))),sn}o(cc,"getCertTable");async function hh(){let e=ZV("operations-api"),t={secureContexts:null,setSecureContext:o(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(pT());if(!r)return;let n=new Jo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}o(hh,"getReplicationCert");async function gde(){cc();let e=(await hh()).options.cert,r=new Jo(e).issuer.match(/CN=(.*)/)?.[1];return sn.get(r)}o(gde,"getReplicationCertAuth");var BV,ac=new Map;function zV(){if(BV)return;BV=!0;let e=[{configKey:kl.TLS},{configKey:kl.OPERATIONSAPI_TLS}];cc();let t=Er.dirname(LC.getConfigFilePath()),r;for(let{configKey:n}of e){let s=LC.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let a=i.privateKey,c=a&&$V(lde(t,"keys"),a);c&&FV(a,l=>{ac.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&YV){let d;FV(u,f=>{if(UV.cert===f)return;let m=i.hostname??i.hostnames??i.host??i.hosts;m&&!Array.isArray(m)&&(m=[m]);let p=XV(u),h=new Jo(p),E;try{E=HC(h)}catch(y){Qe.error?.("error extracting host name from certificate",y);return}if(E==null){Qe.error?.("No host name found on certificate");return}if(h.checkIssued(new Jo(UV.cert)))return;let g=sn.primaryStore.get(E),R=KV(u).mtimeMs,S=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&R<=S){R<S&&Qe.info?.(`Certificate ${E} at ${u} is older (${new Date(R)}) than the certificate in the database (${S>1?new Date(S):"only self signed certificate available"})`);return}r=sn.put({name:E,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:p,private_key_name:c,is_authority:l,hostnames:m,fileTimestamp: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}o(zV,"loadCertificates");function FV(e,t,r){let n,s=o((i,a)=>{try{let c=a.mtimeMs;c&&c!==n&&(n&&YV&&Qe.warn?.(`Reloading ${r}:`,i),n=c,t(XV(i)))}catch(c){Qe.error?.(`Error loading ${r}:`,i,c)}},"loadFile");Vn.existsSync(e)?s(e,KV(e)):Qe.error?.(`${r} file not found:`,e),ide(e,{persistent:!1}).on("change",s)}o(FV,"loadAndWatch");function DC(){let e=mde();if(e==null){let t=ph[0];return Qe.info?.("replication url is missing from harperdb-config.yaml, using default host"+t),t}return VV(e)}o(DC,"getHost");function mT(){let e=pT();if(e==null){let t=ph[0];return Qe.info?.("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}o(mT,"getCommonName");async function Sde(){let e=await hh(),t=Dt.certificateFromPem(e.options.cert),r=Dt.privateKeyFromPem(e.options.key);Qe.info?.("Creating CSR with cert named:",e.name);let n=Dt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:mT()},...xC];Qe.info?.("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:jV()}];return Qe.info?.("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),Yd.pki.certificationRequestToPem(n)}o(Sde,"createCsr");function jV(){let e=ph.includes(mT())?ph:[...ph,mT()];return e.includes(DC())||e.push(DC()),[{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=>HV.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}o(jV,"certExtensions");async function Tde(e){let t={},r=Er.join(_s.getHdbBasePath(),qs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;cc();for await(let d of sn.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(ac.has(d.private_key_name)){n=ac.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await Vn.exists(Er.join(r,d.private_key_name))){n=Vn.readFile(Er.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await MC();s=d.ca,n=d.private_key}n=Dt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=Dt.certificateFromPem(s.certificate);Qe.info?.("Signing CSR with cert named",s.name);let a=Dt.certificationRequestFromPem(e.csr);try{a.verify()}catch(d){return Qe.error?.(d),new Error("Error verifying CSR: "+d.message)}let c=Yd.pki.createCertificate();c.serialNumber=hT(),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+UC),Qe.info?.("sign cert setting validity:",c.validity),Qe.info?.("sign cert setting subject from CSR:",a.subject.attributes),c.setSubject(a.subject.attributes),Qe.info?.("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=a.getAttribute({name:"extensionRequest"}).extensions;Qe.info?.("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=a.publicKey,c.sign(n,Yd.md.sha256.create()),t.certificate=Dt.certificateToPem(c)}else Qe.info?.("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}o(Tde,"signCertificate");async function yde(e,t){await Wd({name:pT(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await Wd({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})}o(yde,"createCertificateTable");async function Wd(e){let t;try{t=new Jo(e.certificate)}catch(r){Qe.error?.(`Failed to parse certificate for ${e.name}:`,r.message),Qe.debug?.("Certificate record details:",JSON.stringify(e,null,2));let n=new Error(`Invalid certificate format for ${e.name}: ${r.message}. This may be due to corrupted certificate data during transfer or encoding issues.`);throw n.code="INVALID_CERTIFICATE_FORMAT",n.cause=r,n}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},cc(),await sn.patch(e)}o(Wd,"setCertTable");async function BC(){let e=await PC("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{publicKey:Dt.publicKeyFromPem(e.publicKey),privateKey:Dt.privateKeyFromPem(e.privateKey)}}o(BC,"generateKeys");async function FC(e,t,r){let n=Dt.createCertificate();if(!t){let a=await hh();t=Dt.certificateFromPem(a.options.cert).publicKey}n.publicKey=t,n.serialNumber=hT(),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+UC);let i=[{name:"commonName",value:mT()},...xC];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(jV()),n.sign(e,Yd.md.sha256.create()),Dt.certificateToPem(n)}o(FC,"generateCertificates");async function MC(){let e=await t1(),t;for(let r of e){if(!r.is_authority)continue;let n=await e1(r.private_key_name);if(r.private_key_name&&n&&new Jo(r.certificate).checkPrivateKey(GV(n))){Qe.trace?.(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;Qe.trace?.("No CA found with matching private key")}o(MC,"getCertAuthority");async function QV(e,t,r=!0){let n=Dt.createCertificate();n.publicKey=t,n.serialNumber=hT(),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+UC);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${_s.get(kl.REPLICATION_HOSTNAME)??VV(_s.get(kl.REPLICATION_URL))??qV().split("-")[0]}`},...xC];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0},{name:"subjectKeyIdentifier"}]),n.sign(e,Yd.md.sha256.create());let a=Er.join(_s.getHdbBasePath(),qs.LICENSE_KEY_DIR_NAME),c=Er.join(a,Ti.PRIVATEKEY_PEM_NAME);return r&&await Vn.writeFile(c,Dt.privateKeyToPem(e)),n}o(QV,"generateCertAuthority");async function Rde(){let{privateKey:e,publicKey:t}=await BC(),r=await QV(e,t),n=await FC(e,t,r);await yde(n,r),JV()}o(Rde,"generateCertsKeys");async function bde(){let e=await FC(Dt.privateKeyFromPem(Ti.CERTIFICATE_VALUES.key),void 0,Dt.certificateFromPem(Ti.CERTIFICATE_VALUES.cert)),t=Er.join(_s.getHdbBasePath(),qs.LICENSE_KEY_DIR_NAME),r=Er.join(t,Ti.NATS_CERTIFICATE_PEM_NAME);await Vn.exists(r)||await Vn.writeFile(r,e);let n=Er.join(t,Ti.NATS_CA_PEM_NAME);await Vn.exists(n)||await Vn.writeFile(n,Ti.CERTIFICATE_VALUES.cert)}o(bde,"createNatsCerts");async function Ade(){cc();for await(let e of sn.search([{attribute:"is_self_signed",value:!0}]))await sn.delete(e.name);await kC()}o(Ade,"renewSelfSigned");async function kC(){pde(),await zV(),cc();let e=await MC();if(!e){Qe.notify?.("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=o(u=>{try{return{key:Dt.privateKeyFromPem(Vn.readFileSync(u)),keyPath:u}}catch(d){return Qe.warn?.(`Failed to parse private key from ${u}:`,d.message),{key:null,keyPath:u}}},"tryToParseKey"),n=_s.get(kl.TLS),s,i;if(Array.isArray(n)){for(let u of n)if(u.privateKey){let d=r(u.privateKey);if(s=d.key,i=d.keyPath,d.key)break}}else{let u=_s.get(kl.TLS_PRIVATEKEY),d=r(u);s=d.key,i=d.keyPath}let a=Er.join(_s.getHdbBasePath(),qs.LICENSE_KEY_DIR_NAME),c=$V(a,i);s||(Qe.warn?.("Unable to parse the TLS key",i,"A new key will be generated and used to create Certificate Authority"),{privateKey:s}=await BC(),Vn.existsSync(Er.join(a,Ti.PRIVATEKEY_PEM_NAME))&&(c=`privateKey${qV().split("-")[0]}.pem`),await Vn.writeFile(Er.join(a,c),Dt.privateKeyToPem(s)));let l=await QV(s,Dt.setRsaPublicKey(s.n,s.e),!1);await Wd({name:l.subject.getField("CN").value,uses:["https"],certificate:Dt.certificateToPem(l),private_key_name:c,is_authority:!0,is_self_signed:!0})}if(!await hh()){let r=pT();Qe.notify?.(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await MC();let n=Dt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await FC(Dt.privateKeyFromPem(e.private_key),s,n);await Wd({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}o(kC,"reviewSelfSignedCert");function JV(){let e=ude(Object.keys(qs.CONFIG_PARAM_MAP),!0),t=Er.join(_s.getHdbBasePath(),qs.LICENSE_KEY_DIR_NAME),r=Er.join(t,Ti.PRIVATEKEY_PEM_NAME),n=Er.join(t,Ti.NATS_CERTIFICATE_PEM_NAME),s=Er.join(t,Ti.NATS_CA_PEM_NAME),i=qs.CONFIG_PARAMS,a={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(a[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(a[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(a[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,a[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,a[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),LC.updateConfigValue(void 0,void 0,a,!1,!0)}o(JV,"updateConfigCert");function XV(e){return e.startsWith("-----BEGIN")?e:hde(e,"utf8")}o(XV,"readPEM");var kV=fT.createSecureContext;fT.createSecureContext=function(e){if(!e.cert||!e.key)return kV(e);let t={...e};delete t.key,delete t.cert;let r=kV(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var Ide=WV.prototype._init;WV.prototype._init=function(e,t){Ide.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,a)=>{this.sni_context=a?.context||a,this.certCbDone()})}};var Fl=new Map;function ZV(e,t){let r=new Map,n,s=!1;return i.initialize=a=>i.ready?i.ready:(a&&(a.secureContexts=r,a.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),Fl.clear();let d=0;if(dT===void 0){c();return}for await(let f of dT.system.hdb_certificate.search([])){let m=f.certificate,p=new Jo(m);f.is_authority&&(p.asString=m,Fl.set(p.subject,m))}for await(let f of dT.system.hdb_certificate.search([]))try{if(f.is_authority)continue;let m=e==="operations-api",p=f.is_self_signed?1:3;m&&f.uses?.includes?.("operations")&&(p+=1);let h=await e1(f.private_key_name),E=f.certificate,g=new Jo(E);if(Fl.has(g.issuer)&&(E+=`
|
|
24
24
|
`+Fl.get(g.issuer)),!h||!E)throw new Error("Missing private key or certificate for secure server");let R={ciphers:f.ciphers,ticketKeys:Ede(),availableCAs:Fl,ca:t&&Array.from(Fl.values()),cert:E,key:h,key_file:f.private_key_name,is_self_signed:f.is_self_signed};a&&(R.sessionIdContext=a.sessionIdContext);let S=f.hostnames??GC(g);Array.isArray(S)||(S=[S]);for(let I of S)I===DC()&&(p+=1);let y=fT.createSecureContext(R);y.name=f.name,y.options=R,y.quality=p,y.certificateAuthorities=Array.from(Fl),y.certStart=E.toString().slice(0,100);let C;for(let I of S)if(I){I[0]==="*"&&(s=!0,I=I.slice(1)),HV.isIP(I)&&(C=!0);let k=r.get(I)?.quality??0;Qe.trace?.("Assigning TLS for hostname",I,"if",p,">",k),p>k&&r.set(I,y)}else Qe.error?.("No hostname found for certificate at",fT.certificate);Qe.trace?.("Adding TLS",y.name,"for",a.ports||"client","cert named",f.name,"hostnames",S,"quality",p,"best quality",d),p>d&&(i.defaultContext=n=y,d=p,a&&(a.defaultContext=y))}catch(m){Qe.error?.("Error applying TLS for",f.name,m)}a?.secureContextsListeners.forEach(f=>f()),c(n)}catch(d){l(d)}}o(u,"updateTLS"),dT?.system.hdb_certificate.subscribe({listener:o(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(a,c){Qe.info?.("TLS requested for",a||"(no SNI)");let l=a;for(;;){let d=r.get(l);if(d)return Qe.debug?.("Found certificate for",a,d.certStart),d.updatedContext&&(d=d.updatedContext),c(null,d);if(s&&l){let f=l.indexOf(".",1);f<0?l="":l=l.slice(f)}else break}a?Qe.debug?.("No certificate found to match",a,"using the default certificate"):Qe.debug?.("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):Qe.info?.("No default certificate found"),c(null,u)}o(i,"SNICallback")}o(ZV,"createTLSSelector");async function e1(e){let t=ac.get(e);return!t&&e?await Vn.readFile(Er.join(_s.get(kl.ROOTPATH),qs.LICENSE_KEY_DIR_NAME,e),"utf8"):t}o(e1,"getPrivateKeyByName");async function t1(){cc();let e=[];for await(let t of sn.search([]))e.push(t);return e}o(t1,"listCertificates");async function wde(e){let t=vC(e,Si.object({name:Si.string().required(),certificate:Si.string().required(),is_authority:Si.boolean().required(),private_key:Si.string(),hosts:Si.array(),uses:Si.array()}));if(t)throw new oc(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,a=new Jo(n),c=!1,l=!1,u;for(let[p,h]of ac)!s&&!c&&a.checkPrivateKey(GV(h))&&(c=!0,u=p),s&&s===h&&(l=!0,u=p);if(!i&&!s&&!c)throw new oc("A suitable private key was not found for this certificate");let d;if(!r){try{d=HC(a)}catch(p){Qe.error?.(p)}if(d==null)throw new oc("Error extracting certificate host name, please provide a name parameter")}let f=Nde(r??d);s&&!c&&!l&&(await Vn.writeFile(Er.join(_s.getHdbBasePath(),qs.LICENSE_KEY_DIR_NAME,f+".pem"),s),ac.set(f,s));let m={name:r??d,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(m.private_key_name=u??f+".pem"),e.ciphers&&(m.ciphers=e.ciphers),await Wd(m),"Successfully added certificate: "+f}o(wde,"addCertificate");function Nde(e){return e.replace(/[^a-z0-9\.]/gi,"-")}o(Nde,"sanitizeName");async function Cde(e){let t=vC(e,Si.object({name:Si.string().required()}));if(t)throw new oc(t.message);let{name:r}=e;cc();let n=await sn.get(r);if(!n)throw new oc(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await sn.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(Qe.info?.("Removing private key named",s),await Vn.remove(Er.join(_s.getHdbBasePath(),qs.LICENSE_KEY_DIR_NAME,s)))}return await sn.delete(r),"Successfully removed "+r}o(Cde,"removeCertificate");function HC(e){let t=e.subject?.match(/CN=(.*)/)?.[1];return t||GC(e)[0]}o(HC,"getPrimaryHostName");function GC(e){if(e.subjectAltName)return e.subjectAltName.split(",").map(r=>{let n=r.indexOf(":");if(r=r.slice(n+1),r=r.trim(),r[0]==='"')try{r=JSON.parse(r)}catch{}return r.indexOf("=")>-1?r.match(/CN=([^,]*)/)?.[1]:r}).filter(r=>r);let t=e.subject?.match(/CN=(.*)/)?.[1];return t?[t]:[]}o(GC,"hostnamesFromCert");async function Ode(e){if(e.bypass_auth!==!0)throw new oc("Unauthorized","401");let t=vC(e,Si.object({name:Si.string().required()}));if(t)throw new oc(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await xV()).privateKey;if(r===".jwtPublic")return(await xV()).publicKey;if(ac.get(r))return ac.get(e.name);throw new oc("Key not found")}o(Ode,"getKey");function Pde(e){return[e.subject?.CN,...e.subjectaltname.split(",").filter(t=>t.trim().startsWith("DNS:")).map(t=>t.trim().substring(4))]}o(Pde,"getHostnamesFromCertificate")});var w1={};Re(w1,{BACK_PRESSURE_RATIO_POSITION:()=>b1,CONFIRMATION_STATUS_POSITION:()=>R1,LATENCY_POSITION:()=>RT,NodeReplicationConnection:()=>jd,OPERATION_REQUEST:()=>YC,RECEIVED_TIME_POSITION:()=>zC,RECEIVED_VERSION_POSITION:()=>WC,RECEIVING_STATUS_POSITION:()=>jC,RECEIVING_STATUS_RECEIVING:()=>I1,RECEIVING_STATUS_WAITING:()=>A1,SENDING_TIME_POSITION:()=>Eh,createWebSocket:()=>bT,databaseSubscriptions:()=>uc,replicateOverWS:()=>_h,tableUpdateListeners:()=>JC});async function bT(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=it(),i;if(e==null)throw new TypeError(`Invalid URL: Expected a string URL for node "${s}" but received ${e}`);if(e.includes("wss://")){if(!VC){let l=(0,_1.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),VC=u.secureContexts}if(i=VC.get(s),i&&le.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let a={};r&&(a.Authorization=r);let c={headers:a,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,S1.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(yT?.caCount!==Zo.size&&(yT=g1.createSecureContext({...i.options,ca:[...Zo,...i.options.availableCAs.values()]}),yT.caCount=Zo.size),c.secureContext=yT),new p1.WebSocket(e,"harperdb-replication-v1",c)}function _h(e,t,r){let n=t.port||t.securePort,s=Hl.pid%1e3+"-"+h1.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3);le.debug?.(s,"Initializing replication connection",r);let i=0,a=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(a.buffer,0,1024),u=t.database,d=t.databaseSubscriptions||uc,f,m,p=!1,h=t.subscription;h?.then&&h.then(A=>{h=A,h.auditStore&&(f=h.auditStore)});let E=t.tables||u&&at()[u],g,R=new Map,S=[];g=r.name,g&&t.connection&&(t.connection.nodeName=g);let y,C,I,k,J,G,H,X=6e4,W,ue=0,ce=0,te=0,ye=m1.default.get(F.REPLICATION_BLOBTIMEOUT)??12e4,Ae=new Map,Ye=[],qe=0,Ar;if(t.url){let A=o(()=>{J&&ce===e._socket?.bytesRead&&te===e._socket?.bytesWritten?e.terminate():(J=performance.now(),e.ping(),ce=e._socket?.bytesRead,te=e._socket?.bytesWritten)},"sendPing");I=setInterval(A,d1).unref(),A()}else tr();e._socket?.setMaxListeners(200);function tr(){clearTimeout(k),ce=e._socket?.bytesRead,te=e._socket?.bytesWritten,k=setTimeout(()=>{ce===e._socket?.bytesRead&&te===e._socket?.bytesWritten&&(le.warn?.(`Timeout waiting for ping from ${g}, terminating connection and reconnecting`),e.terminate())},d1*2).unref()}o(tr,"resetPingTimer");let Wr=0,vr=0,_u=!1,Fc=3e4;function xt(){if(dn?.length>0){let A=performance.now(),U=A-vr;Wr=(Wr*Fc+(_u?U:0))/(Fc+U),m[b1]=Wr,vr=A}}o(xt,"updateBackPressureRatio"),setInterval(xt,Fc).unref();function ri(){if(!(!g||!u))return m||(m=Gd(f,u,g)),m}o(ri,"getSharedStatus"),u&&kc(u);let Na,GE,jf=[],qE=[],Qf,Pe=[],$E=[],cb=[],gu=150,Ui=25,Os=0,Jf=0,Xf=!1,Io,On,dn,Ur;e.on("message",Su);async function Su(A){if(r=await r,!r){le.error?.(s,"No authorization provided"),xr(1008,"Unauthorized");return}Zf(A),e.off("message",Su),e.on("message",Zf)}o(Su,"onWSMessageWhenAuthorized");function Zf(A){ue=performance.now();try{let U=A.dataView=new Qc(A.buffer,A.byteOffset,A.byteLength);if(A[0]>127){let Y=(0,ot.decode)(A),[j,B,Ee]=Y;switch(j){case n1:{if(B){if(g){if(g!==B){le.error?.(s,`Node name mismatch, expecting to connect to ${g}, but peer reported name as ${B}, disconnecting`),e.send((0,ot.encode)([zd])),xr(1008,"Node name mismatch");return}}else if(g=B,t.connection?.tentativeNode){let de=t.connection.tentativeNode;de.name=g,t.connection.tentativeNode=null,Qo(g,de)}if(t.connection&&(t.connection.nodeName=g),le.debug?.(s,"received node name:",g,"db:",u??Y[2]),!u)try{kc(u=Y[2]),u==="system"&&(Na=sc(t,(de,oe)=>{Pa(oe)&&K(oe)}),e.on("close",()=>{Na?.remove()}))}catch(de){le.warn?.(s,"Error setting database",de),e.send((0,ot.encode)([zd])),xr(1008,de.message);return}em()}break}case l1:{le.debug?.(s,"Received table definitions for",B.map(de=>de.table));for(let de of B){let oe=Y[2];de.database=oe;let ke;if(Pa(oe)){if(u==="system")De[oe]?.[de.table]||(ke=L(de,De[oe]?.[de.table]));else{if(oe!=="data"&&!De[oe]){le.warn?.("Database not found",oe);return}ke=L(de,De[oe]?.[de.table])}f||(f=ke?.auditStore),E||(E=at()?.[oe])}}break}case zd:xr();break;case YC:try{let de=r?.replicates||r?.subscribers||r?.name;le.debug?.("Received operation request",B,"from",g),server.operation(B,{user:r},!de).then(oe=>{le.debug?.("Requested request from finished",g,oe),Array.isArray(oe)&&(oe={results:oe}),oe.requestId=B.requestId,e.send((0,ot.encode)([_T,oe]))},oe=>{le.debug?.("Failed requested operation from",g,oe),e.send((0,ot.encode)([_T,{requestId:B.requestId,error:qC(oe)}]))})}catch(de){e.send((0,ot.encode)([_T,{requestId:B.requestId,error:qC(de)}]))}break;case _T:let{resolve:fe,reject:pe}=R.get(B.requestId);le.debug?.("Received completed operation request",g,B),B.error?pe(new Error(B.error)):fe(B),R.delete(B.requestId);break;case $C:let ne=Y[3];if(!E){u?le.error?.(s,"No database found for",u):le.error?.(s,"Database name never received"),xr();return}let ie=E[ne];ie=L({table:ne,database:u,attributes:B.attributes,schemaDefined:B.schemaDefined},ie),jf[Ee]={name:ne,decoder:new ot.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:B.typedStructs,structures:B.structures}),getEntry(de){return ie.primaryStore.getEntry(de)},rootStore:ie.primaryStore.rootStore};break;case s1:Ur=f?bV(B,f):new Map,Qf=Y[2],le.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${Qf}`);break;case i1:let xe=Ee;cb[xe]=B;break;case c1:ri()[R1]=B,le.trace?.(s,"received and broadcasting committed update",B),ri().buffer.notify();break;case a1:y=B,h.send({type:"end_txn",localTime:y,remoteNodeIds:S});break;case gT:{let de=Y[1],{fileId:oe,size:ke,finished:Be,error:Le}=de,Me=Ae.get(oe);le.debug?.("Received blob",oe,"has stream",!!Me,"connectedToBlob",!!Me?.connectedToBlob,"length",Y[2].length,"finished",Be),Me||(Me=new KC.PassThrough,Me.expectedSize=ke,Ae.set(oe,Me)),Me.lastChunk=Date.now();let pt=Y[2];Ve(pt.byteLength,"bytes-received",`${g}.${u}`,"replication","blob");try{Be?(Le?(Me.on("error",()=>{}),Me.destroy(new Error("Blob error: "+Le+" for record "+(Me.recordId??"unknown")+" from "+remote_node_name))):Me.end(pt),Me.connectedToBlob&&Ae.delete(oe)):Me.write(pt)}catch(wt){le.error?.(`Error receiving blob for ${Me.recordId} from ${g} and streaming to storage`,wt),Ae.delete(oe)}break}case o1:{let de=B,oe;try{let ke=Y[3],Be=qE[Ee]||(qE[Ee]=E[Y[4]]);if(!Be)return le.warn?.("Unknown table id trying to handle record request",Ee);let Le=Be.primaryStore.getBinaryFast(Symbol.for("structures")),Me=Le?.length??0;if(Me>0&&Me!==Jf){Jf=Me;let wt=(0,ot.decode)(Le);e.send((0,ot.encode)([$C,{typedStructs:wt.typed,structures:wt.named},Ee,Be.tableName]))}let pt=Be.primaryStore.getBinaryFast(ke);if(pt){let wt=Be.primaryStore.decoder.decode(pt,{valueAsBuffer:!0}),Et=ct||{};Et.version=(0,T1.getLastVersion)(),ct&&ct[xu]&Jr&&(wt=Buffer.from(wt),Nm(()=>Be.primaryStore.decoder.decode(pt),KE=>Ca(KE,ke),Be.primaryStore.rootStore)),oe=(0,ot.encode)([ET,de,{value:wt,expiresAt:Et.expiresAt,version:Et.version,residencyId:Et.residencyId,nodeId:Et.nodeId,user:Et.user}])}else oe=(0,ot.encode)([ET,de])}catch(ke){oe=(0,ot.encode)([ET,de,{error:ke.message}])}e.send(oe);break}case ET:{let{resolve:de,reject:oe,tableId:ke,key:Be}=R.get(Y[1]),Le=Y[2];if(Le?.error)oe(new Error(Le.error));else if(Le){let Me;I_(()=>{let pt=jf[ke].decoder.decode(Le.value);Le.value=pt,Le.key=Be,de(Le)||Me&&setTimeout(()=>Me.forEach(R_),6e4).unref()},f?.rootStore,pt=>{let wt=Oa(pt,Be);return Me||(Me=[]),Me.push(wt),wt})}else de();R.delete(Y[1]);break}case r1:{dn=B;let de,oe,ke=!1;if(h){if(u!==h.databaseName&&!h.then){le.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=d.get(u);if(le.debug?.(s,"received subscription request for",u,"at",dn),!h){let Ce;h=new Promise(Kt=>{le.debug?.("Waiting for subscription to database "+u),Ce=Kt}),h.ready=Ce,uc.set(u,h)}if(r.name)oe=jt().subscribe(r.name),oe.then(async Ce=>{de=Ce;for await(let Kt of de){let Bt=Kt.value;if(!(Bt?.replicates===!0||Bt?.replicates?.receives||Bt?.subscriptions?.some(Br=>(Br.database||Br.schema)===u&&Br.publish!==!1))){ke=!0,e.send((0,ot.encode)([zd])),xr(1008,`Unauthorized database subscription to ${u}`);return}}},Ce=>{le.error?.(s,"Error subscribing to HDB nodes",Ce)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,ot.encode)([zd])),xr(1008,`Unauthorized database subscription to ${u}`);return}if(On&&(le.debug?.(s,"stopping previous subscription",u),On.emit("close")),dn.length===0)return;let Be=dn[0],Le=o(Ce=>{if(Ce&&(Be.replicateByDefault?!Be.tables.includes(Ce.tableName):Be.tables.includes(Ce.tableName)))return{table:Ce}},"tableToTableEntry"),Me={txnTime:0},pt,wt,Et=1/0,KE,YE=o((Ce,Kt)=>{if(Ce.type==="end_txn"){Me.txnTime&&(a[i]!==66&&le.error?.("Invalid encoding of message"),N(9),N(x_),O(KE=Kt),VM()),i=c,Me.txnTime=0;return}let Bt=Ce.nodeId,Br=Ce.tableId,Nt=wt[Br];if(!Nt&&(Nt=wt[Br]=Le(h.tableById[Br]),!Nt))return le.debug?.("Not subscribed to table",Br);let Ps=Nt.table,Ft=Ps.primaryStore,ni=Ft.encoder;(Ce.extendedType&W_||!ni.typedStructs)&&(ni._mergeStructures(ni.getStructures()),ni.typedStructs&&(ni.lastTypedStructuresLength=ni.typedStructs.length));let Ru=pt[Bt];if(!(Ru&&Ru.startTime<Kt&&(!Ru.endTime||Ru.endTime>Kt)))return TT&&le.trace?.(s,"skipping replication update",Ce.recordId,"to:",g,"from:",Bt,"subscribed:",pt),KM();TT&&le.trace?.(s,"sending replication update",Ce.recordId,"to:",g,"from:",Bt,"subscribed:",pt);let lb=Ce.version;Me.txnTime!==lb&&(Me.txnTime&&(TT&&le.trace?.(s,"new txn time, sending queued txn",Me.txnTime),a[i]!==66&&le.error?.("Invalid encoding of message"),VM()),Me.txnTime=lb,i=c,O(lb));let Hc=Ce.residencyId,ub=VE(Hc,Ps),WE;if(ub&&!ub.includes(g)){let xi=VE(Ce.previousResidencyId,Ps);if(xi&&!xi.includes(g)&&(Ce.type==="put"||Ce.type==="patch")||Ps.getResidencyById)return KM();let Gc=Ce.recordId;le.trace?.(s,"sending invalidation",Gc,g,"from",Bt);let tm=0;Hc&&(tm|=Jc),Ce.previousResidencyId&&(tm|=Xc);let mb,zE=null;for(let YM in Ps.indices){if(!zE){if(mb=Ce.getValue(Ft,!0),!mb)break;zE={}}zE[YM]=mb[YM]}WE=Zc(Ce.version,Br,Gc,null,Bt,Ce.user,Ce.type==="put"||Ce.type==="patch"?"invalidate":Ce.type,ni.encode(zE),tm,Hc,Ce.previousResidencyId,Ce.expiresAt)}function KM(){return le.trace?.(s,"skipping audit record",Ce.recordId),G||(G=setTimeout(()=>{G=null,(KE||0)+u1/2<Et&&(TT&&le.trace?.(s,"sending skipped sequence update",Et),e.send((0,ot.encode)([a1,Et])))},u1).unref()),new Promise(setImmediate)}o(KM,"skipAuditRecord");let db=ni.typedStructs,fb=ni.structures;if((db?.length!=Nt.typed_length||fb?.length!=Nt.structure_length)&&(Nt.typed_length=db?.length,Nt.structure_length=fb.length,le.debug?.(s,"send table struct",Nt.typed_length,Nt.structure_length),Nt.sentName||(Nt.sentName=!0),e.send((0,ot.encode)([$C,{typedStructs:db,structures:fb,attributes:Ps.attributes,schemaDefined:Ps.schemaDefined},Br,Nt.table.tableName]))),Hc&&!$E[Hc]&&(e.send((0,ot.encode)([i1,ub,Hc])),$E[Hc]=!0),WE)N(WE.length),P(WE);else{let xi=Ce.encoded;Ce.extendedType&Jr&&Nm(()=>Ce.getValue(Ft),tm=>Ca(tm,Ce.recordId),Ft.rootStore);let Gc=xi[0]===66?8:0;N(xi.length-Gc),P(xi,Gc),le.trace?.("wrote record",Ce.recordId,"length:",xi.length)}if(e._socket.writableNeedDrain){let xi=performance.now();return _u=!0,xt(),new Promise(Gc=>{le.debug?.(`Waiting for remote node ${g} to allow more commits ${e._socket.writableNeedDrain?"due to network backlog":"due to requested flow directive"}`),e._socket.once("drain",()=>{Gc(),_u=!1,xt()})})}else return qe>Ui?new Promise(xi=>{Ar=xi}):new Promise(setImmediate)},"sendAuditRecord"),VM=o(()=>{c-i>8?(e.send(a.subarray(i,c)),le.debug?.(s,"Sent message, size:",c-i),u!=="system"&&Ve(c-i,"bytes-sent",`${g}.${u}`,"replication","egress")):le.debug?.(s,"skipping empty transaction")},"sendQueuedData");On=new QC.EventEmitter,On.once("close",()=>{ke=!0,de?.end()});for(let{startTime:Ce}of dn)Ce<Et&&(Et=Ce);(oe||Promise.resolve()).then(async()=>{h=await h,f=h.auditStore,wt=h.tableById.map(Le),pt=[];for(let{name:Kt,startTime:Bt,endTime:Br}of dn){let Nt=aT(Kt,f);le.debug?.("subscription to",Kt,"using local id",Nt,"starting",Bt),pt[Nt]={startTime:Bt,endTime:Br}}K(u),Na||(Na=Ol(Kt=>{Kt.databaseName===u&&K(u)}),GE=Bp(Kt=>{Kt===u&&(e.send((0,ot.encode)([zd])),xr())}),e.on("close",()=>{Na?.remove(),GE?.remove()})),e.send((0,ot.encode)([s1,ah(h.auditStore),dn.map(({name:Kt})=>Kt)]));let Ce=!0;do{isFinite(Et)||(le.warn?.("Invalid sequence id "+Et),xr(1008,"Invalid sequence id"+Et));let Kt;if(Ce&&!ke&&(Ce=!1,Et===0)){le.info?.("Replicating all tables to",g);let Bt=Et,Br=AT(f);for(let Nt in E){if(!Le(Nt))continue;let Ps=E[Nt];for(let Ft of Ps.primaryStore.getRange({snapshot:!1,versions:!0})){if(ke)return;if(Ft.localTime>=Et){le.trace?.(s,"Copying record from",u,Nt,Ft.key,Ft.localTime),Bt=Math.max(Ft.localTime,Bt),Kt=!0,ri()[Eh]=1;let ni=Zc(Ft.version,Ps.tableId,Ft.key,null,Br,null,"put",Nm(()=>Ps.primaryStore.encoder.encode(Ft.value),Ru=>Ca(Ru,Ft.key)),Ft.metadataFlags&-256,Ft.residencyId,null,Ft.expiresAt);await YE({recordId:Ft.key,tableId:Ps.tableId,type:"put",getValue(){return Ft.value},encoded:ni,version:Ft.version,residencyId:Ft.residencyId,nodeId:Br,extendedType:Ft.metadataFlags},Ft.localTime)}}}Kt&&YE({type:"end_txn"},Et),ri()[Eh]=0,Et=Bt}for(let{key:Bt,value:Br}of f.getRange({start:Et||1,exclusiveStart:!0,snapshot:!1})){if(ke)return;let Nt=At(Br);le.debug?.("sending audit record",Bt,Nt.recordId),ri()[Eh]=Bt,Et=Bt,await YE(Nt,Bt),On.startTime=Bt,Kt=!0}Kt&&YE({type:"end_txn"},Et),ri()[Eh]=0,await Vx(f)}while(!ke)}).catch(Ce=>{le.error?.(s,"Error handling subscription to node",Ce),xr(1008,"Error handling subscription to node")});break}}return}U.position=8;let w=!0,D,$;do{ri();let Y=U.readInt();if(Y===9&&U.getUint8(U.position)==x_){U.position++,y=$=U.readFloat64(),m[WC]=y,m[zC]=Date.now(),m[jC]=A1,le.trace?.("received remote sequence update",y,u);break}let j=U.position,B=At(A,j,j+Y),Ee=jf[B.tableId];Ee||le.error?.(`No table found with an id of ${B.tableId}`);let fe;B.residencyId&&(fe=cb[B.residencyId],le.trace?.(s,"received residency list",fe,B.type,B.recordId));try{let pe=B.recordId;I_(()=>{D={table:Ee.name,id:B.recordId,type:B.type,nodeId:Ur.get(B.nodeId),residencyList:fe,timestamp:B.version,value:B.getValue(Ee),user:B.user,beginTxn:w,expiresAt:B.expiresAt}},f?.rootStore,ne=>Oa(ne,pe))}catch(pe){throw pe.message+="typed structures for current decoder"+JSON.stringify(Ee.decoder.typedStructs),pe}w=!1,le.debug?.(s,"received replication message",B.type,"id",D.id,"version",new Date(B.version),"nodeId",D.nodeId),m[WC]=B.version,m[zC]=Date.now(),m[jC]=I1,h.send(D),U.position=j+Y}while(U.position<A.byteLength);Os++,u!=="system"&&Ve(A.byteLength,"bytes-received",`${g}.${u}.${D?.table||"unknown_table"}`,"replication","ingest"),Os>gu&&!Xf&&(Xf=!0,e.pause(),le.debug?.(`Commit backlog causing replication back-pressure, requesting that ${g} pause replication`)),h.send({type:"end_txn",localTime:y,remoteNodeIds:S,async onCommit(){if(D){let Y=Date.now()-D.timestamp;u!=="system"&&Ve(Y,"replication-latency",g+"."+u+"."+D.table,D.type,"ingest")}Os--,Xf&&(Xf=!1,e.resume(),le.debug?.(`Replication resuming ${g}`)),Ye.length>0&&await Promise.all(Ye),le.trace?.("All blobs finished"),!C&&$&&(le.trace?.(s,"queuing confirmation of a commit at",$),setTimeout(()=>{e.send((0,ot.encode)([c1,C])),le.trace?.(s,"sent confirmation of a commit at",C),C=null},Mde)),C=$,le.debug?.("last sequence committed",new Date($),u)}})}catch(U){le.error?.(s,"Error handling incoming replication message",U)}}o(Zf,"onWSMessage"),e.on("ping",tr),e.on("pong",()=>{if(t.connection){let A=performance.now()-J;t.connection.latency=A,ri()&&(m[RT]=A),t.isSubscriptionConnection&&Bl({name:g,database:u,url:t.url,latency:A})}J=null}),e.on("close",(A,U)=>{clearInterval(I),clearTimeout(k),clearInterval(H),On&&On.emit("close"),Io&&Io.end();for(let[w,{reject:D}]of R)D(new Error(`Connection closed ${U?.toString()} ${A}`));le.debug?.(s,"closed",A,U?.toString())});function xr(A,U){try{e.isFinished=!0,le.debug?.(s,"closing",g,u,A,U),e.close(A,U),t.connection?.emit("finished")}catch(w){le.error?.(s,"Error closing connection",w)}}o(xr,"close");let Tu=new Set;async function Ca(A,U){let w=b_(A);if(Tu.has(w)){le.debug?.("Blob already being sent",w);return}Tu.add(w);try{let D;qe++;for await(let $ of A.stream())D&&(le.debug?.("Sending blob chunk",w,"length",D.length),e.send((0,ot.encode)([gT,{fileId:w,size:A.size},D]))),D=$,e._socket.writableNeedDrain&&(le.debug?.("draining",w),await new Promise(Y=>e._socket.once("drain",Y)),le.debug?.("drained",w)),Ve($.length,"bytes-sent",`${g}.${u}`,"replication","blob");le.debug?.("Sending final blob chunk",w,"length",D.length),e.send((0,ot.encode)([gT,{fileId:w,size:A.size,finished:!0},D]))}catch(D){le.warn?.("Error sending blob",D,"blob id",w,"for record",U),e.send((0,ot.encode)([gT,{fileId:w,finished:!0,error:qC(D)},Buffer.alloc(0)]))}finally{Tu.delete(w),qe--,qe<Ui&&Ar?.()}}o(Ca,"sendBlobs");function Oa(A,U){let w=b_(A),D=Ae.get(w);le.debug?.("Received transaction with blob",w,"has stream",!!D,"ended",!!D?.writableEnded),D?D.writableEnded&&Ae.delete(w):(D=new KC.PassThrough,Ae.set(w,D)),D.connectedToBlob=!0,D.lastChunk=Date.now(),D.recordId=U,A.size===void 0&&D.expectedSize&&(A.size=D.expectedSize);let $=D.blob??createBlob(D,A);D.blob=$;let Y=vo(()=>wm($).saving,h.auditStore?.rootStore);return Y&&(Y.blobId=w,Ye.push(Y),Y.finally(()=>{le.debug?.(`Finished receiving blob stream ${w}`),Ye.splice(Ye.indexOf(Y),1)})),$}o(Oa,"receiveBlobs");function em(){if(p||(p=!0,t.connection?.on("subscriptions-updated",em)),!f&&h&&(f=h.auditStore),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let A=new Map;f||(f=h?.auditStore);try{for(let D of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let $ of D.value.nodes||[])$.lastTxnTime>(A.get($.id)??0)&&A.set($.id,$.lastTxnTime)}catch(D){if(!D.message.includes("Can not re"))throw D}let U=t.connection?.nodeSubscriptions?.[0];S=[];let w=t.connection?.nodeSubscriptions.map((D,$)=>{let Y=[],{replicateByDefault:j}=D;if(D.subscriptions){for(let pe of D.subscriptions)if(pe.subscribe&&(pe.schema||pe.database)===u){let ne=pe.table;E?.[ne]?.replicate!==!1&&Y.push(ne)}j=!1}else for(let pe in E)(j?E[pe].replicate===!1:E[pe].replicate)&&Y.push(pe);let B=f&&aT(D.name,f),Ee=h?.dbisDB?.get([Symbol.for("seq"),B])??1,fe=Math.max(Ee?.seqId??1,(typeof D.startTime=="string"?new Date(D.startTime).getTime():D.startTime)??1);if(le.debug?.("Starting time recorded in db",D.name,B,u,Ee?.seqId,"start time:",fe,new Date(fe)),U!==D){let pe=f&&aT(U.name,f),ne=h?.dbisDB?.get([Symbol.for("seq"),pe])??1;for(let ie of ne?.nodes||[])ie.name===D.name&&(fe=ie.seqId,le.debug?.("Using sequence id from proxy node",U.name,fe))}if(B===void 0?le.warn("Starting subscription request from node",D,"but no node id found"):S.push(B),A.get(B)>fe&&(fe=A.get(B),le.debug?.("Updating start time from more recent txn recorded",U.name,fe)),fe===1&&ST)try{new URL(ST).hostname===D.name?(le.warn?.(`Requesting full copy of database ${u} from ${ST}`),fe=0):fe=Date.now()-6e4}catch(pe){le.error?.("Error parsing leader URL",ST,pe)}return le.trace?.(s,"defining subscription request",D.name,u,new Date(fe)),{name:D.name,replicateByDefault:j,tables:Y,startTime:fe,endTime:D.endTime}});if(w)if(le.debug?.(s,"sending subscription request",w,h?.dbisDB?.path),clearTimeout(W),w.length>0)e.send((0,ot.encode)([r1,w]));else{let D=o(()=>{let $=performance.now();W=setTimeout(()=>{ue<=$?xr(1008,"Connection has no subscriptions and is no longer used"):D()},X).unref()},"scheduleClose");D()}}o(em,"sendSubscriptionRequestUpdate");function VE(A,U){if(!A)return;let w=Pe[A];return w||(w=U.getResidencyRecord(A),Pe[A]=w),w}o(VE,"getResidence");function Pa(A){return!(lc&&lc!="*"&&!lc[A]&&!lc.includes?.(A)&&!lc.some?.(U=>U.name===A))}o(Pa,"checkDatabaseAccess");function kc(A){if(h=h||d.get(A),!Pa(A))throw new Error(`Access to database "${A}" is not permitted`);h||le.warn?.(`No database named "${A}" was declared and registered`),f=h?.auditStore,E||(E=at()?.[A]);let U=it();if(U===g)throw U?new Error("Should not connect to self",U):new Error("Node name not defined");return yu(U,A),!0}o(kc,"setDatabase");function yu(A,U){let w=at()?.[U],D=[];for(let $ in w){let Y=w[$];D.push({table:$,schemaDefined:Y.schemaDefined,attributes:Y.attributes.map(j=>({name:j.name,type:j.type,isPrimaryKey:j.isPrimaryKey}))})}le.trace?.("Sending database info for node",A,"database name",U),e.send((0,ot.encode)([n1,A,U,D]))}o(yu,"sendNodeDBName");function K(A){let U=at()?.[A],w=[];for(let D in U){if(dn&&!dn.some(Y=>Y.replicateByDefault?!Y.tables.includes(D):Y.tables.includes(D)))continue;let $=U[D];w.push({table:D,schemaDefined:$.schemaDefined,attributes:$.attributes.map(Y=>({name:Y.name,type:Y.type,isPrimaryKey:Y.isPrimaryKey}))})}e.send((0,ot.encode)([l1,w,A]))}o(K,"sendDBSchema"),H=setInterval(()=>{for(let[A,U]of Ae)U.lastChunk+ye<Date.now()&&(le.warn?.(`Timeout waiting for blob stream to finish ${A} for record ${U.recordId??"unknown"} from ${g}`),Ae.delete(A),U.end())},ye).unref();let _=1,T=[];return{end(){Io&&Io.end(),On&&On.emit("close")},getRecord(A){let U=_++;return new Promise((w,D)=>{let $=[o1,U,A.table.tableId,A.id];T[A.table.tableId]||($.push(A.table.tableName),T[A.table.tableId]=!0),e.send((0,ot.encode)($)),ue=performance.now(),R.set(U,{tableId:A.table.tableId,key:A.id,resolve(Y){let{table:j,entry:B}=A;if(w(Y),Y)return j._recordRelocate(B,Y)},reject:D})})},sendOperation(A){let U=_++;return A.requestId=U,e.send((0,ot.encode)([YC,A])),new Promise((w,D)=>{R.set(U,{resolve:w,reject:D})})}};function N(A){x(5),A<128?a[c++]=A:A<16384?(l.setUint16(c,A|32768),c+=2):A<1056964608?(l.setUint32(c,A|3221225472),c+=4):(a[c]=255,l.setUint32(c+1,A),c+=5)}function P(A,U=0,w=A.length){let D=w-U;x(D),A.copy(a,c,U,w),c+=D}function O(A){x(8),l.setFloat64(c,A),c+=8}function x(A){if(A+16>a.length-c){let U=Buffer.allocUnsafeSlow(c+A-i+65536>>10<<11);a.copy(U,0,i,c),c=c-i,i=0,a=U,l=new DataView(a.buffer,0,a.length)}}function L(A,U){let w=A.database??"data";U||(U={});let D=U.schemaDefined,$=!1,Y=A.schemaDefined,j=U.attributes||[];for(let B=0;B<A.attributes?.length;B++){let Ee=A.attributes[B],fe=j.find(pe=>pe.name===Ee.name);(!fe||fe.type!==Ee.type)&&(D?le.error?.(`Schema for '${u}.${A.table}' is defined locally, but attribute '${Ee.name}: ${Ee.type}' from '${g}' does not match local attribute ${fe?"'"+fe.name+": "+fe.type+"'":"which does not exist"}`):($=!0,Y||(Ee.indexed=!0),fe?j[j.indexOf(fe)]=Ee:j.push(Ee)))}return $?(le.debug?.("(Re)creating",A),Ze({table:A.table,database:A.database,schemaDefined:A.schemaDefined,attributes:j,...U})):U}}var m1,ot,p1,h1,E1,QC,_1,g1,Hl,S1,KC,T1,y1,Lde,qC,le,r1,n1,s1,zd,i1,$C,o1,ET,YC,_T,a1,c1,l1,gT,R1,WC,zC,Eh,RT,jC,b1,A1,I1,Dde,ST,JC,uc,TT,u1,Mde,d1,VC,yT,f1,jd,XC=se(()=>{we();Bi();CC();BA();Es();m1=b(me());q();el();ot=require("msgpackr"),p1=require("ws"),h1=require("worker_threads"),E1=b(Q());mh();QC=require("events"),_1=b(gs()),g1=b(require("node:tls"));$d();Hl=b(require("node:process")),S1=require("node:net");es();Zn();KC=require("node:stream"),T1=require("lmdb"),y1=b(require("minimist")),{forComponent:Lde,errorToString:qC}=E1.default,le=Lde("replication").conditional,r1=129,n1=140,s1=141,zd=142,i1=130,$C=132,o1=133,ET=134,YC=136,_T=137,a1=143,c1=144,l1=145,gT=146,R1=0,WC=1,zC=2,Eh=3,RT=4,jC=5,b1=6,A1=0,I1=1,Dde=(0,y1.default)(Hl.argv),ST=Dde.HDB_LEADER_URL??Hl.env.HDB_LEADER_URL,JC=new Map,uc=new Map,TT=!0,u1=300,Mde=2,d1=3e4;o(bT,"createWebSocket");f1=500,jd=class extends QC.EventEmitter{static{o(this,"NodeReplicationConnection")}socket;startTime;retryTime=f1;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions;latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;url;subscription;databaseName;nodeName;authorization;constructor(t,r,n,s,i){super(),this.url=t,this.subscription=r,this.databaseName=n,this.authorization=i,this.nodeName=this.nodeName??gi(t)}async connect(){this.session||this.resetSession();let t=[];this.socket=await bT(this.url,{serverName:this.nodeName,authorization:this.authorization});let r;le.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${Hl.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),le[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=f1,this.nodeSubscriptions&&Bl({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,r=_h(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this,isSubscriptionConnection:this.nodeSubscriptions!==void 0},{replicates:!0}),this.sessionResolve(r)}),this.socket.on("error",n=>{n.code==="SELF_SIGNED_CERT_IN_CHAIN"?(le.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),n.isHandled=!0):n.code!=="ECONNREFUSED"&&(n.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?le.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):le.error?.(`Error in connection to ${this.url} due to ${n.message}`)),this.sessionReject(n)}),this.socket.on("close",(n,s)=>{if(this.isConnected&&(this.nodeSubscriptions&&Kd({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.removeAllListeners("subscriptions-updated"),this.socket.isFinished){this.isFinished=!0,r?.end(),this.emit("finished");return}if(++this.retries%20===1){let i=s?.toString();le.warn?.(`${r?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${i?'"'+i+'" ':""}(code: ${n})`)}r=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>8})}resetSession(){this.session=new Promise((t,r)=>{this.sessionResolve=t,this.sessionReject=r})}subscribe(t,r){this.nodeSubscriptions=t,this.replicateTablesByDefault=r,this.emit("subscriptions-updated",t)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(t){return this.session.then(r=>r.getRecord(t))}};o(_h,"replicateOverWS")});function gh(e){return e===C1||e===vde}function Ude(e){return e===O1||e===P1}function ZC(e){return e===C1?O1:P1}function xde(){if(N1)return;N1=!0;let e=Gl.CryptoEngine.prototype,t=Gl.Certificate.prototype,r={getHashAlgorithm:e.getHashAlgorithm,getAlgorithmByOID:e.getAlgorithmByOID,getAlgorithmParameters:e.getAlgorithmParameters,verifyWithPublicKey:e.verifyWithPublicKey,certificateVerify:t.verify,getPublicKey:t.getPublicKey};e.getHashAlgorithm=function(...n){let[s]=n;return gh(s.algorithmId)?"UNUSED-EDDSA-BUILTIN-HASH":r.getHashAlgorithm.call(this,s)},e.getAlgorithmByOID=function(...n){let[s]=n;return gh(s)?{name:ZC(s)}:r.getAlgorithmByOID.call(this,...n)},e.getAlgorithmParameters=function(...n){let[s,i]=n;return Ude(s)?{algorithm:{name:s},usages:i==="sign"?["sign"]:["verify"]}:r.getAlgorithmParameters.call(this,...n)},t.getPublicKey=async function(...n){let[,s=Gl.getCrypto(!0)]=n,i=this.subjectPublicKeyInfo.algorithm.algorithmId;if(gh(i)){let a=ZC(i);return s.importKey("spki",this.subjectPublicKeyInfo.toSchema().toBER(!1),a,!0,["verify"])}return r.getPublicKey.call(this,...n)},t.verify=async function(...n){let[s]=n;if(gh(this.signatureAlgorithm.algorithmId))try{let i=this.toSchema().toBER(!1),a=s.toSchema().toBER(!1),c=new Sh.X509Certificate(Buffer.from(i)),l=new Sh.X509Certificate(Buffer.from(a));return c.verify(l.publicKey)}catch{return!1}return r.certificateVerify.call(this,...n)},r.verifyWithPublicKey&&(e.verifyWithPublicKey=async function(...n){let[s,i,a]=n,c=a.algorithm.algorithmId;if(gh(c)){let l=ZC(c);try{let u=this.crypto?.subtle||this.subtle||Gl.getCrypto(!0)?.subtle||Sh.webcrypto?.subtle;if(!u)throw new Error("No crypto.subtle available");let d=await u.importKey("spki",a.toSchema().toBER(!1),l,!1,["verify"]),f=i.valueBlock.valueHexView;return i.valueBlock.unusedBits>0&&(f=f.slice(0,f.length-1)),await u.verify(l,d,f,s)}catch{return!1}}return r.verifyWithPublicKey.call(this,...n)})}var Gl,Sh,C1,vde,O1,P1,N1,L1=se(()=>{Gl=b(require("pkijs")),Sh=require("node:crypto"),C1="1.3.101.112",vde="1.3.101.113",O1="Ed25519",P1="Ed448",N1=!1;o(gh,"isEd25519OrEd448");o(Ude,"isEdDSAAlgorithmName");o(ZC,"getEdDSAAlgorithmName");o(xde,"applyEd25519Patch");xde()});function Bde(){return IT||(IT=Ze({table:"hdb_certificate_cache",database:"system",attributes:[{name:"certificate_id",isPrimaryKey:!0},{name:"status"},{name:"reason"},{name:"checked_at"},{name:"expiresAt",expiresAt:!0,indexed:!0},{name:"method"}]}),IT.sourcedFrom(eO)),IT}function Fde(e){if(ht.trace?.("getCertificateVerificationConfig called with:",{mtlsConfig:e}),!e)return!1;if(e===!0)return ht.debug?.("mTLS enabled with default certificate verification"),{};let t=e.certificateVerification;return ht.trace?.("Certificate verification config:",{verificationConfig:t}),t==null?{}:t===!1?!1:t===!0?{}:t}async function Qd(e,t){ht.debug?.("verifyCertificate called for:",e.subject?.CN||"unknown");let r=Fde(t);if(r===!1)return ht.debug?.("Certificate verification disabled"),{valid:!0,status:"disabled",method:"disabled"};let n=Gde(e);return ht.trace?.("Certificate chain length:",n.length),n.length===1&&!n[0].issuer?(ht.debug?.("Certificate without issuer - cannot perform OCSP check"),{valid:!0,status:"no-issuer-cert",method:"disabled"}):n.length<2||!n[0].issuer?(ht.debug?.("Certificate chain too short for revocation checking"),{valid:!0,status:"insufficient-chain",method:"disabled"}):kde(n[0].cert,n[0].issuer,r)}async function kde(e,t,r){ht.debug?.("verifyOCSP called");try{Buffer.isBuffer(e)&&(e=D1(e,"CERTIFICATE")),Buffer.isBuffer(t)&&(t=D1(t,"CERTIFICATE"));let n={certPem:e,issuerPem:t,method:"ocsp"},i=`ocsp:${(0,M1.createHash)("sha256").update(JSON.stringify(n)).digest("hex")}`;ht.trace?.("OCSP cache key:",i);let c=await Bde().get(i,{certPem:e,issuerPem:t,config:r||{}});if(!c)return(r?.failureMode??ea.failureMode)==="fail-closed"?{valid:!1,status:"error",error:"Cache fetch failed",method:"ocsp"}:(ht.warn?.("OCSP cache fetch failed, allowing connection (fail-open mode)"),{valid:!0,status:"error-allowed",method:"ocsp"});let l=c,u=c.wasLoadedFromSource?.();if(ht.trace?.(`OCSP ${u?"source fetch":"cache hit"} for certificate`),l.status==="unknown"&&u&&(l.reason==="ocsp-error"||l.reason==="timeout"||l.reason==="OCSP timeout")){let m=(r?.failureMode??ea.failureMode)==="fail-closed";return m||ht.warn?.("OCSP check failed, allowing connection (fail-open mode)"),{valid:!m,status:m?l.status:"error-allowed",cached:!u,method:l.method||"ocsp"}}return{valid:l.status==="good",status:l.status,cached:!u,method:l.method||"ocsp"}}catch(n){return ht.error?.("OCSP verification error:",n),(r?.failureMode??ea.failureMode)==="fail-closed"?{valid:!1,status:"error",error:n.message,method:"ocsp"}:(ht.warn?.("OCSP check failed, allowing connection (fail-open mode)"),{valid:!0,status:"error-allowed",method:"ocsp"})}}async function Hde(e,t,r){ht.trace?.("Performing OCSP check with timeout:",r);try{(0,wT.getCertURLs)(e)}catch(n){return ht.debug?.("Certificate does not contain OCSP URL:",n.message),{status:"unknown",reason:"no-ocsp-url"}}try{let n=await(0,wT.getCertStatus)(e,{ca:t,timeout:r});switch(ht.debug?.("OCSP response:",n.status),n.status){case"good":return{status:"good"};case"revoked":return{status:"revoked",reason:n.revocationReason?.toString()||"unspecified"};default:return{status:"unknown",reason:"unknown-status"}}}catch(n){let s=n;return ht.debug?.("OCSP check failed:",s.message),{status:"unknown",reason:s.name==="AbortError"?"timeout":"ocsp-error"}}}function D1(e,t){let r=e.toString("base64"),n=[`-----BEGIN ${t}-----`];for(let s=0;s<r.length;s+=64)n.push(r.substring(s,s+64));return n.push(`-----END ${t}-----`),n.join(`
|
|
25
|
-
`)}function Gde(e){let t=[],r=e;for(;r?.raw;){let n={cert:r.raw};if(r.issuerCertificate&&r.issuerCertificate!==r&&r.issuerCertificate.raw&&(n.issuer=r.issuerCertificate.raw),t.push(n),r.issuerCertificate&&r.issuerCertificate!==r)r=r.issuerCertificate;else break}return t}var wT,M1,v1,ht,eO,ea,IT,NT=se(()=>{L1();wT=require("easy-ocsp"),M1=require("node:crypto"),v1=b(Xn());we();Ha();ht=(0,v1.loggerWithTag)("cert-verification"),eO=class extends Hr{static{o(this,"CertificateVerificationSource")}async get(t){ht.debug?.("CertificateVerificationSource.get called for:",t);let r=this.getContext(),n=r?.requestContext;if(!n||!n.certPem||!n.issuerPem)throw new Error(`No certificate data provided for cache key: ${t}`);let{certPem:s,issuerPem:i,config:a}=n;ht.trace?.("Performing OCSP check with config:",a);try{let c=a?.timeout??ea.timeout,l=await Promise.race([Hde(s,i,c),new Promise((m,p)=>setTimeout(()=>p(new Error("OCSP timeout")),c))]);if(ht.debug?.("OCSP check result:",l),l.status==="unknown"&&(l.reason==="ocsp-error"||l.reason==="timeout"||l.reason==="no-ocsp-url")){let m=a?.failureMode??ea.failureMode;if(ht.error?.("OCSP check failed:",l.reason),m==="fail-closed"){let p=a?.errorCacheTtl??ea.errorCacheTtl,h=Date.now()+p;return r&&(r.expiresAt=h),{certificate_id:t,status:l.status,reason:l.reason,checked_at:Date.now(),expiresAt:h,method:"ocsp"}}else return ht.warn?.("OCSP check failed, allowing connection (fail-open mode)"),null}let d=a?.cacheTtl??ea.cacheTtl,f=Date.now()+d;return r&&(r.expiresAt=f),{certificate_id:t,status:l.status,reason:l.reason,checked_at:Date.now(),expiresAt:f,method:"ocsp"}}catch(c){if(ht.error?.("OCSP verification error:",c),(a?.failureMode??ea.failureMode)==="fail-closed"){let u=a?.errorCacheTtl??ea.errorCacheTtl,d=Date.now()+u;return r&&(r.expiresAt=d),{certificate_id:t,status:"unknown",reason:c.message,checked_at:Date.now(),expiresAt:d,method:"ocsp"}}return ht.warn?.("OCSP check failed, allowing connection (fail-open mode)"),null}}},ea={timeout:5e3,cacheTtl:36e5,errorCacheTtl:3e5,failureMode:"fail-open"};o(Bde,"getCertificateCacheTable");o(Fde,"getCertificateVerificationConfig");o(Qd,"verifyCertificate");o(kde,"verifyOCSP");o(Hde,"performOCSPCheck");o(D1,"bufferToPem");o(Gde,"extractCertificateChain")});var Xo={};Re(Xo,{clearThisNodeName:()=>Qde,disableReplication:()=>Kde,enabledDatabases:()=>lc,forEachReplicatedDatabase:()=>sc,getThisNodeId:()=>AT,getThisNodeName:()=>it,getThisNodeUrl:()=>ic,hostnameToUrl:()=>LT,lastTimeInAuditStore:()=>ch,monitorNodeCAs:()=>$1,replicateOperation:()=>Xde,replicationCertificateAuthorities:()=>Zo,sendOperationToNode:()=>Th,servers:()=>$de,setReplicator:()=>K1,start:()=>Vde,startOnMainThread:()=>OC,subscribeToNode:()=>fh,unsubscribeFromNode:()=>uT,urlToNodeName:()=>gi});function Vde(e){if(!e.port&&!e.securePort&&(e.port=$s.default.get(F.OPERATIONSAPI_NETWORK_PORT),e.securePort=$s.default.get(F.OPERATIONSAPI_NETWORK_SECUREPORT)),!it())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let s of uh(e))t.set(gi(s.url),s);Yde(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=ve.ws(async(s,i,a,c)=>{if(It.debug("Incoming WS connection received "+i.url),i.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return c(s,i,a);s._socket.unref(),_h(s,e,a.then(()=>i?.user)),s.on("error",l=>{l.code!=="ECONNREFUSED"&&It.error("Error in connection to "+this.url,l.message)})},e);e.runFirst=!0,ve.http(async(s,i)=>{if(s.isWebSocket&&s.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){It.debug("Incoming replication WS connection received, authorized: "+s.authorized),!s.authorized&&s._nodeRequest.socket.authorizationError&&It.error(`Incoming client connection from ${s.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,s._nodeRequest.socket.authorizationError);let a=jt().primaryStore;if(s.authorized&&s.peerCertificate.subjectaltname){let c=(0,G1.getHostnamesFromCertificate)(s.peerCertificate),l;for(let u of c)if(l=u&&(a.get(u)||t.get(u)),l)break;if(l){let u=await Qd(s.peerCertificate,e);if(!u.valid){It.warn("Certificate verification failed:",u.status,"for node",l.name,"certificate serial number",s.peerCertificate.serialNumber);return}if(l?.revoked_certificates?.includes(s.peerCertificate.serialNumber)){It.warn("Revoked certificate used in attempt to connect to node",l.name,"certificate serial number",s.peerCertificate.serialNumber);return}else s.user=l}else It.warn(`No node found for certificate common name/SANs: ${c}, available nodes are ${Array.from(a.getRange({}).filter(({value:u})=>u).map(({key:u})=>u)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let c=a.get(s.ip)||t.get(s.ip);c?s.user=c:It.warn(`No node found for IP address ${s.ip}, available nodes are ${Array.from(new Set([...a.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return i(s)},e);let n=[];for(let s of r)if(s.secureContexts){let i=o(()=>{let a=new Set(s.secureContexts.values());s.defaultContext&&a.add(s.defaultContext);for(let c of a)try{let l=Array.from(Zo);c.options.availableCAs&&l.push(...c.options.availableCAs.values());let u={...c.options,ca:l};c.updatedContext=PT.createSecureContext(u)}catch(l){It.error("Error creating replication TLS config",l)}},"updateContexts");s.secureContextsListeners.push(i),n.push(i),$s.default.get(F.REPLICATION_ENABLEROOTCAS)!==!1&&i()}$1(()=>{for(let s of n)s()})}function $1(e){let t=0;qd(r=>{r?.ca&&(Zo.add(r.ca),Zo.size!==t&&(t=Zo.size,e?.()))})}function Kde(e=!0){q1=e}function Yde(e){q1||(at(),lc=e.databases,sc(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||uc;for(let[s,i]of OT){let a=i.get(r);a&&(a.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];K1(r,s,e),JC.get(s)?.forEach(i=>i(s))}}))}function K1(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 V1 extends Hr{static{o(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||uc,a=i.get(e),c=a?.tableById||[];c[t.tableId]=t;let l=a?.ready;if(It.trace("Setting up replicator subscription to database",e),!a?.auditStore)return this.subscription=a=new Jn,i.set(e,a),a.tableById=c,a.auditStore=t.auditStore,a.dbisDB=t.dbisDB,a.databaseName=e,l&&l(a),a;this.subscription=a}static subscribeOnThisThread(i,a){return!0}static async load(i){if(i){let a=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),a]);if(c){let l,u=new Set;do{let d,f="",m=1/0;for(let h of c){if(u.has(h)||h===ve.hostname)continue;let E=zde(h,V1.subscription,e);if(E?.isConnected){let g=Gd(t.auditStore,e,h)[RT];(!d||g<m)&&(d=E,f=h,m=g)}}if(!d)throw l||new k1.ServerError(`No connection to any other nodes are available: ${c}`,502);let p={requestId:qde++,table:t,entry:i,id:i.key};u.add(f);try{return await d.getRecord(p)}catch(h){if(d.isConnected)throw h;It.warn("Error in load from node",ql,h),l||(l=h)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function Wde(e,t,r,n,s){let i=OT.get(e);i||OT.set(e,i=new Map);let a=i.get(r);if(a)return a;if(t)return i.set(r,a=new jd(e,t,r,n,s)),a.connect(),a.once("finished",()=>i.delete(r)),a}function zde(e,t,r){let n=U1.get(ql);n||(n=new Map,U1.set(ql,n));let s=n.get(r);if(s)return s;let i=jt().primaryStore.get(e);return i?.url&&(s=new jd(i.url,t,r,ql,i.authorization),n.set(r,s),s.connect(),s.once("finished",()=>n.delete(r))),s}async function Th(e,t,r){r||(r={}),r.serverName=e.name;let n=await bT(e.url,r),s=_h(n,{},{});return new Promise((i,a)=>{n.on("open",()=>{It.debug("Sending operation connection to "+e.url+" opened",t),i(s.sendOperation(t))}),n.on("error",c=>{a(c)}),n.on("close",c=>{It.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function fh(e){try{H1.isMainThread&&It.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=uc.get(e.database);if(!t){let n;t=new Promise(s=>{It.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,uc.set(e.database,t)}let r=Wde(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>lh(n,e.database)),e.replicateByDefault)}catch(t){It.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function uT({name:e,url:t,database:r}){It.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(jt().primaryStore.getRange({})));let n=OT.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function jde(){if(tO!==void 0)return tO;let e=$s.default.get(F.OPERATIONSAPI_TLS_CERTIFICATE)||$s.default.get(F.TLS_CERTIFICATE);if(e)return tO=new B1.X509Certificate((0,F1.readFileSync)(e)).subject?.match(/CN=(.*)/)?.[1]??null}function it(){return ql||(ql=$s.default.get("replication_hostname")??gi($s.default.get("replication_url"))??jde()??x1("operationsapi_network_secureport")??x1("operationsapi_network_port")??"127.0.0.1")}function Qde(){ql=void 0}function x1(e){let t=$s.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function CT(e){let t=$s.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function AT(e){return ah(e)?.[it()]}function ic(){let e=$s.default.get("replication_url");return e||LT(it())}function LT(e){let t=CT("replication_port");if(t)return`ws://${e}:${t}`;if(t=CT("replication_secureport"),t)return`wss://${e}:${t}`;if(t=CT("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=CT("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function gi(e){if(e)return new URL(e).hostname}function sc(e,t){for(let n of Object.getOwnPropertyNames(De))r(n);return Bp(n=>{r(n)}),Ol((n,s)=>{r(n.databaseName)});function r(n){let s=De[n];It.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):Jde(n)&&t(s,n,!1)}o(r,"forDatabase")}function Jde(e){let t=De[e];for(let r in t)if(t[r].replicate)return!0}function ch(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function Xde(e){let t={message:""};if(e.replicated){e.replicated=!1,It.trace?.("Replicating operation",e.operation,"to nodes",ve.nodes.map(n=>n.name));let r=await Promise.allSettled(ve.nodes.map(n=>Th(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=ve.nodes[s]?.name,i})}return t}var $s,It,B1,F1,PT,k1,H1,G1,q1,qde,$de,Zo,lc,OT,U1,tO,ql,Es=se(()=>{we();Ha();wu();XC();Fr();$s=b(me()),It=b(Q()),B1=require("crypto");NT();F1=require("fs");mh();$d();q();CC();PT=b(require("node:tls")),k1=b(_e()),H1=require("worker_threads"),G1=b(gs()),qde=1,$de=[],Zo=$s.default.get(F.REPLICATION_ENABLEROOTCAS)!==!1?new Set(PT.rootCertificates):new Set;o(Vde,"start");o($1,"monitorNodeCAs");o(Kde,"disableReplication");o(Yde,"assignReplicationSource");o(K1,"setReplicator");OT=new Map;o(Wde,"getSubscriptionConnection");U1=new Map;o(zde,"getRetrievalConnectionByName");o(Th,"sendOperationToNode");o(fh,"subscribeToNode");o(uT,"unsubscribeFromNode");o(jde,"getCommonNameFromCert");o(it,"getThisNodeName");o(Qde,"clearThisNodeName");Object.defineProperty(ve,"hostname",{get(){return it()}});o(x1,"getHostFromListeningPort");o(CT,"getPortFromListeningPort");o(AT,"getThisNodeId");ve.replication={getThisNodeId:AT,exportIdMapping:ah};o(ic,"getThisNodeUrl");o(LT,"hostnameToUrl");o(gi,"urlToNodeName");o(sc,"forEachReplicatedDatabase");o(Jde,"hasExplicitlyReplicatedTable");o(ch,"lastTimeInAuditStore");o(Xde,"replicateOperation")});var xT=v((Rxe,Q1)=>{"use strict";var Jd=K$(),{validateBySchema:yh}=mt(),{commonValidators:Xd,schemaRegex:rO}=Vi(),_r=require("joi"),Zde=Q(),efe=require("uuid").v4,vT=Ho(),Zd=(q(),M(z)),tfe=require("util"),dc=as(),{handleHDBError:ta,hdbErrors:rfe,ClientError:$l}=_e(),{HDB_ERROR_MSGS:DT,HTTP_STATUS_CODES:ra}=rfe,{SchemaEventMsg:UT}=ss(),Y1=hr(),{getDatabases:nfe}=(we(),M(ft)),{transformReq:ef}=ae(),{replicateOperation:W1}=(Es(),M(Xo)),{cleanupOrphans:sfe}=(Zn(),M(w_)),MT=_r.string().min(1).max(Xd.schema_length.maximum).pattern(rO).messages({"string.pattern.base":"{:#label} "+Xd.schema_format.message}),ife=_r.string().min(1).max(Xd.schema_length.maximum).pattern(rO).messages({"string.pattern.base":"{:#label} "+Xd.schema_format.message}).required(),ofe=_r.string().min(1).max(Xd.schema_length.maximum).pattern(rO).messages({"string.pattern.base":"{:#label} "+Xd.schema_format.message,"any.required":"'primary_key' is required","string.base":"'primary_key' must be a string"}).required();Q1.exports={createSchema:afe,createSchemaStructure:z1,createTable:cfe,createTableStructure:j1,createAttribute:mfe,dropSchema:lfe,dropTable:ufe,dropAttribute:dfe,getBackup:pfe,cleanupOrphanBlobs:hfe};async function afe(e){let t=await z1(e);return vT.signalSchemaChange(new UT(process.pid,e.operation,e.schema)),t}o(afe,"createSchema");async function z1(e){let t=yh(e,_r.object({database:MT,schema:MT}));if(t)throw new $l(t.message);if(ef(e),!await Jd.checkSchemaExists(e.schema))throw ta(new Error,DT.SCHEMA_EXISTS_ERR(e.schema),ra.BAD_REQUEST,Zd.LOG_LEVELS.ERROR,DT.SCHEMA_EXISTS_ERR(e.schema),!0);return await dc.createSchema(e),`database '${e.schema}' successfully created`}o(z1,"createSchemaStructure");async function cfe(e){return ef(e),e.hash_attribute=e.primary_key??e.hash_attribute,await j1(e)}o(cfe,"createTable");async function j1(e){let t=yh(e,_r.object({database:MT,schema:MT,table:ife,residence:_r.array().items(_r.string().min(1)).optional(),hash_attribute:ofe}));if(t)throw new $l(t.message);if(!await Jd.checkSchemaTableExists(e.schema,e.table))throw ta(new Error,DT.TABLE_EXISTS_ERR(e.schema,e.table),ra.BAD_REQUEST,Zd.LOG_LEVELS.ERROR,DT.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:efe(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await dc.createTable(n,e);else throw ta(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",ra.BAD_REQUEST);else await dc.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}o(j1,"createTableStructure");async function lfe(e){let t=yh(e,_r.object({database:_r.string(),schema:_r.string()}).or("database","schema").messages({"object.missing":"'database' is required"}));if(t)throw new $l(t.message);ef(e);let r=await Jd.checkSchemaExists(e.schema);if(r)throw ta(new Error,r,ra.NOT_FOUND,Zd.LOG_LEVELS.ERROR,r,!0);let n=await Jd.schemaDescribe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await dc.dropSchema(e),vT.signalSchemaChange(new UT(process.pid,e.operation,e.schema)),await Y1.purgeSchemaTableStreams(e.schema,s);let i=await W1(e);return i.message=`successfully deleted '${e.schema}'`,i}o(lfe,"dropSchema");async function ufe(e){let t=yh(e,_r.object({database:_r.string(),schema:_r.string(),table:_r.string().required()}));if(t)throw new $l(t.message);ef(e);let r=await Jd.checkSchemaTableExists(e.schema,e.table);if(r)throw ta(new Error,r,ra.NOT_FOUND,Zd.LOG_LEVELS.ERROR,r,!0);await dc.dropTable(e),await Y1.purgeTableStream(e.schema,e.table);let n=await W1(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}o(ufe,"dropTable");async function dfe(e){let t=yh(e,_r.object({database:_r.string(),schema:_r.string(),table:_r.string().required(),attribute:_r.string().required()}));if(t)throw new $l(t.message);ef(e);let r=await Jd.checkSchemaTableExists(e.schema,e.table);if(r)throw ta(new Error,r,ra.NOT_FOUND,Zd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw ta(new Error,"You cannot drop a hash attribute",ra.BAD_REQUEST,void 0,void 0,!0);if(Zd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw ta(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,ra.BAD_REQUEST,void 0,void 0,!0);try{return await dc.dropAttribute(e),ffe(e),vT.signalSchemaChange(new UT(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Zde.error(`Got an error deleting attribute ${tfe.inspect(e)}.`),n}}o(dfe,"dropAttribute");function ffe(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)}o(ffe,"dropAttributeFromGlobal");async function mfe(e){ef(e);let t=nfe()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw ta(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,ra.BAD_REQUEST,void 0,void 0,!0);return await dc.createAttribute(e),vT.signalSchemaChange(new UT(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}o(mfe,"createAttribute");function pfe(e){return dc.getBackup(e)}o(pfe,"getBackup");function hfe(e){if(!e.database)throw new $l('Must provide "database" name for search for orphaned blobs');if(!databases[e.database])throw new $l(`Unknown database '${e.database}'`);return sfe(databases[e.database]),{message:"Orphaned blobs cleanup started, check logs for progress"}}o(hfe,"cleanupOrphanBlobs")});var X1=v((Axe,J1)=>{"use strict";var{OPERATIONS_ENUM:Efe}=(q(),M(z)),nO=class{static{o(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Efe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};J1.exports=nO});var sO=v((Nxe,nK)=>{"use strict";var _fe=as(),wxe=X1(),BT=ae(),FT=(q(),M(z)),gfe=me(),{handleHDBError:Z1,hdbErrors:Sfe}=_e(),{HDB_ERROR_MSGS:eK,HTTP_STATUS_CODES:tK}=Sfe,Tfe=Object.values(FT.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),rK="To use this operation audit log must be enabled in harperdb-config.yaml";nK.exports=yfe;async function yfe(e){if(BT.isEmpty(e.schema))throw new Error(eK.SCHEMA_REQUIRED_ERR);if(BT.isEmpty(e.table))throw new Error(eK.TABLE_REQUIRED_ERR);if(!gfe.get(FT.CONFIG_PARAMS.LOGGING_AUDITLOG))throw Z1(new Error,rK,tK.BAD_REQUEST,FT.LOG_LEVELS.ERROR,rK,!0);let t=BT.checkSchemaTableExist(e.schema,e.table);if(t)throw Z1(new Error,t,tK.NOT_FOUND,FT.LOG_LEVELS.ERROR,t,!0);if(!BT.isEmpty(e.search_type)&&Tfe.indexOf(e.search_type)<0)throw new Error(`Invalid searchType '${read_audit_log_object.search_type}'`);return await _fe.readAuditLog(e)}o(yfe,"readAuditLog")});var iK=v((Oxe,sK)=>{"use strict";var{OPERATIONS_ENUM:Rfe}=(q(),M(z)),iO=class{static{o(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Rfe.GET_BACKUP,this.schema=t,this.table=r}};sK.exports=iO});var cK=v((Mxe,aK)=>{"use strict";var bfe=as(),Lxe=iK(),oO=ae(),Afe=(q(),M(z)),Dxe=me(),{handleHDBError:Ife,hdbErrors:wfe}=_e(),{HDB_ERROR_MSGS:oK,HTTP_STATUS_CODES:Nfe}=wfe;aK.exports=Cfe;async function Cfe(e){if(oO.isEmpty(e.schema))throw new Error(oK.SCHEMA_REQUIRED_ERR);if(oO.isEmpty(e.table))throw new Error(oK.TABLE_REQUIRED_ERR);let t=oO.checkSchemaTableExist(e.schema,e.table);if(t)throw Ife(new Error,t,Nfe.NOT_FOUND,Afe.LOG_LEVELS.ERROR,t,!0);return await bfe.getBackup(readAuditLogObject)}o(Cfe,"getBackup")});var fK=v((Uxe,dK)=>{"use strict";var Ofe=me(),fc=require("joi"),Pfe=mt(),lK=require("moment"),Lfe=require("fs-extra"),aO=require("path"),Dfe=require("lodash"),Rh=(q(),M(z)),{LOG_LEVELS:Vl}=(q(),M(z)),Mfe="YYYY-MM-DD hh:mm:ss",vfe=aO.resolve(__dirname,"../logs");dK.exports=function(e){return Pfe.validateBySchema(e,Ufe)};var Ufe=fc.object({from:fc.custom(uK),until:fc.custom(uK),level:fc.valid(Vl.NOTIFY,Vl.FATAL,Vl.ERROR,Vl.WARN,Vl.INFO,Vl.DEBUG,Vl.TRACE),order:fc.valid("asc","desc"),limit:fc.number().min(1),start:fc.number().min(0),log_name:fc.custom(xfe)});function uK(e,t){if(lK(e,lK.ISO_8601).format(Mfe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}o(uK,"validateDatetime");function xfe(e,t){if(Dfe.invert(Rh.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Ofe.get(Rh.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Rh.LOG_NAMES.HDB:e,i=s===Rh.LOG_NAMES.INSTALL?aO.join(vfe,Rh.LOG_NAMES.INSTALL):aO.join(n,s);return Lfe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}o(xfe,"validateReadLogPath")});var lO=v((Bxe,pK)=>{"use strict";var kT=(q(),M(z)),Bfe=Q(),Ffe=me(),kfe=fK(),cO=require("path"),mK=require("fs-extra"),{once:Hfe}=require("events"),{handleHDBError:Gfe,hdbErrors:qfe}=_e(),{PACKAGE_ROOT:$fe}=Ct(),{replicateOperation:Vfe}=(Es(),M(Xo)),Kfe=cO.join($fe,"logs"),Yfe=1e3,Wfe=200;pK.exports=zfe;async function zfe(e){let t=kfe(e);if(t)throw Gfe(t,t.message,qfe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Vfe(e),n=Ffe.get(kT.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e.log_name===void 0?kT.LOG_NAMES.HDB:e.log_name,i=s===kT.LOG_NAMES.INSTALL?cO.join(Kfe,kT.LOG_NAMES.INSTALL):cO.join(n,s),a=e.level!==void 0,c=a?e.level:void 0,l=e.from!==void 0,u=l?new Date(e.from):void 0,d=e.until!==void 0,f=d?new Date(e.until):void 0,m=e.limit===void 0?Yfe:e.limit,p=e.order===void 0?void 0:e.order,h=e.start===void 0?0:e.start,E=h+m,g=0;p==="desc"&&!u&&!f&&(g=Math.max(mK.statSync(i).size-(E+5)*Wfe,0));let R=mK.createReadStream(i,{start:g});R.on("error",G=>{Bfe.error(G)});let S=0,y=[],C="",I;R.on("data",G=>{let H=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;G=C+G;let X=0,W;for(;(W=H.exec(G))&&!R.destroyed;){I&&(I.message=G.slice(X,W.index),k(I));let[ue,ce,te]=W,ye=te.split("] ["),Ae=ye[0],Ye=ye[1];ye.splice(0,2),I={timestamp:ce,thread:Ae,level:Ye,tags:ye,message:""},X=W.index+ue.length}C=G.slice(X)}),R.on("end",G=>{R.destroyed||I&&(I.message=C.trim(),k(I))}),R.resume();function k(G){let H,X,W;switch(!0){case(a&&l&&d):H=new Date(G.timestamp),X=new Date(u),W=new Date(f),G.level===c&&H>=X&&H<=W&&S<h?S++:G.level===c&&H>=X&&H<=W&&(uo(G,p,y),S++,S===E&&R.destroy());break;case(a&&l):H=new Date(G.timestamp),X=new Date(u),G.level===c&&H>=X&&S<h?S++:G.level===c&&H>=X&&(uo(G,p,y),S++,S===E&&R.destroy());break;case(a&&d):H=new Date(G.timestamp),W=new Date(f),G.level===c&&H<=W&&S<h?S++:G.level===c&&H<=W&&(uo(G,p,y),S++,S===E&&R.destroy());break;case(l&&d):H=new Date(G.timestamp),X=new Date(u),W=new Date(f),H>=X&&H<=W&&S<h?S++:H>=X&&H<=W&&(uo(G,p,y),S++,S===E&&R.destroy());break;case a:G.level===c&&S<h?S++:G.level===c&&(uo(G,p,y),S++,S===E&&R.destroy());break;case l:H=new Date(G.timestamp),X=new Date(u),H>=X&&S<h?S++:H>=X&&S>=h&&(uo(G,p,y),S++,S===E&&R.destroy());break;case d:H=new Date(G.timestamp),W=new Date(f),H<=W&&S<h?S++:H<=W&&S>=h&&(uo(G,p,y),S++,S===E&&R.destroy());break;default:S<h?S++:(uo(G,p,y),S++,S===E&&R.destroy())}}o(k,"onLogMessage"),await Hfe(R,"close");let J=await r;if(J.replicated){for(let G of y)G.node=server.hostname;for(let G of J.replicated){let H=G.node;if(G.status==="failed")uo({timestamp:new Date().toISOString(),level:"error",node:H,message:`Error retrieving logs: ${G.reason}`},p,y);else for(let X of G.results)X.node=H,uo(X,p,y)}}return y}o(zfe,"readLog");function uo(e,t,r){t==="desc"?jfe(e,r):t==="asc"?Qfe(e,r):r.push(e)}o(uo,"pushLineToResult");function jfe(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)}o(jfe,"insertDescending");function Qfe(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)}o(Qfe,"insertAscending")});var HT=v(($xe,gK)=>{"use strict";var uO=require("joi"),{string:tf,boolean:hK,date:Jfe}=uO.types(),Xfe=mt(),{validateSchemaExists:kxe,validateTableExists:Hxe,validateSchemaName:Gxe}=Vi(),Zfe=(q(),M(z)),eme=Ot(),EK=me();EK.initSync();var qxe=tf.invalid(EK.get(Zfe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(eme.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),_K={operation:tf.valid("add_node","update_node","set_node_replication"),node_name:tf.optional(),subscriptions:uO.array().items({table:tf.optional(),schema:tf.optional(),database:tf.optional(),subscribe:hK.required(),publish:hK.required().custom(rme),start_time:Jfe.iso()})};function tme(e){return Xfe.validateBySchema(e,uO.object(_K))}o(tme,"addUpdateNodeValidator");function rme(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`)}o(rme,"checkForFalsy");gK.exports={addUpdateNodeValidator:tme,validationSchema:_K}});var rf=v((Kxe,SK)=>{"use strict";var dO=class{static{o(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},fO=class{static{o(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};SK.exports={Node:dO,NodeSubscription:fO}});var yK=v((Wxe,TK)=>{"use strict";var nme=(q(),M(z)).OPERATIONS_ENUM,mO=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=nme.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};TK.exports=mO});var bh=v((jxe,RK)=>{"use strict";var pO=class{static{o(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},hO=class{static{o(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,a,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=a,c!==void 0&&(this.attributes=c)}};RK.exports={RemotePayloadObject:pO,RemotePayloadSubscription:hO}});var AK=v((Jxe,bK)=>{"use strict";var EO=class{static{o(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,a=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=a}};bK.exports=EO});var wK=v((n0e,IK)=>{"use strict";var sme=AK(),Zxe=Yt(),e0e=_t(),ime=Q(),{getSchemaPath:t0e,getTransactionAuditStorePath:r0e}=Rt(),{getDatabases:ome}=(we(),M(ft));IK.exports=ame;async function ame(e){let t=new sme;try{let r=ome()[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){ime.warn(`unable to stat table dbi due to ${r}`)}return t}o(ame,"lmdbGetTableSize")});var CK=v((i0e,NK)=>{"use strict";var _O=class{static{o(this,"SystemInformationObject")}constructor(t,r,n,s,i,a,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=a,this.harperdb_processes=c}};NK.exports=_O});var Ih=v((d0e,DK)=>{"use strict";var cme=require("fs-extra"),lme=require("path"),bn=require("systeminformation"),mc=Q(),OK=hr(),a0e=Ot(),nf=(q(),M(z)),ume=wK(),dme=Dl(),{getThreadInfo:PK}=nt(),Ah=me();Ah.initSync();var fme=CK(),{openEnvironment:c0e}=_t(),{getSchemaPath:l0e}=Rt(),{database:u0e,databases:gO}=(we(),M(ft)),GT;DK.exports={getHDBProcessInfo:RO,getNetworkInfo:AO,getDiskInfo:bO,getMemoryInfo:yO,getCPUInfo:TO,getTimeInfo:SO,getSystemInformation:IO,systemInformation:mme,getTableSize:wO,getMetrics:NO};function SO(){return bn.time()}o(SO,"getTimeInfo");async function TO(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:a,governor:c,socket:l,cache:u,...d}=await bn.cpu();d.cpu_speed=await bn.cpuCurrentSpeed();let{rawCurrentload:f,rawCurrentloadIdle:m,rawCurrentloadIrq:p,rawCurrentloadNice:h,rawCurrentloadSystem:E,rawCurrentloadUser:g,cpus:R,...S}=await bn.currentLoad();return S.cpus=[],R.forEach(y=>{let{rawLoad:C,rawLoadIdle:I,rawLoadIrq:k,rawLoadNice:J,rawLoadSystem:G,rawLoadUser:H,...X}=y;S.cpus.push(X)}),d.current_load=S,d}catch(e){return mc.error(`error in getCPUInfo: ${e}`),{}}}o(TO,"getCPUInfo");async function yO(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await bn.mem();return Object.assign(s,process.memoryUsage())}catch(e){return mc.error(`error in getMemoryInfo: ${e}`),{}}}o(yO,"getMemoryInfo");async function RO(){let e={core:[],clustering:[]};try{let t=await bn.processes(),r;try{r=Number.parseInt(await cme.readFile(lme.join(Ah.get(nf.CONFIG_PARAMS.ROOTPATH),nf.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===nf.NODE_ERROR_CODES.ENOENT)mc.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 mc.error(`error in getHDBProcessInfo: ${t}`),e}}o(RO,"getHDBProcessInfo");async function bO(){let e={};try{if(!Ah.get(nf.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await bn.disksIO();e.io=i;let{rxSec:a,txSec:c,wxSec:l,...u}=await bn.fsStats();return e.read_write=u,e.size=await bn.fsSize(),e}catch(t){return mc.error(`error in getDiskInfo: ${t}`),e}}o(bO,"getDiskInfo");async function AO(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Ah.get(nf.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await bn.networkInterfaceDefault(),e.latency=await bn.inetChecksite("google.com"),(await bn.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:a,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:d,carrierChanges:f,...m}=n;e.interfaces.push(m)}),(await bn.networkStats()).forEach(n=>{let{rxSec:s,txSec:i,ms:a,...c}=n;e.stats.push(c)})),e}catch(t){return mc.error(`error in getNetworkInfo: ${t}`),e}}o(AO,"getNetworkInfo");async function IO(){if(GT!==void 0)return GT;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:a,...c}=await bn.osInfo();e=c;let l=await bn.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,GT=e,GT}catch(t){return mc.error(`error in getSystemInformation: ${t}`),e}}o(IO,"getSystemInformation");async function wO(){let e=[],t=await dme.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await ume(n));return e}o(wO,"getTableSize");async function NO(){let e={};for(let t in gO){let r=e[t]={},n=r.tables={};for(let s in gO[t])try{let i=gO[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,d,f]=l.trim().split(" ");return{pid:u,thread:d,txnid:f}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:f,overflowPages:m}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:f,overflowPages:m}}let a=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=a[l];n[s]=c}catch(i){mc.notify(`Error getting stats for table ${s}: ${i}`)}}return e}o(NO,"getMetrics");async function LK(){if(Ah.get(nf.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await OK.getNATSReferences(),t=await OK.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 a={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(a)}return r}}o(LK,"getNatsStreamInfo");async function mme(e){let t=new fme;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await IO(),t.time=SO(),t.cpu=await TO(),t.memory=await yO(),t.disk=await bO(),t.network=await AO(),t.harperdb_processes=await RO(),t.table_size=await wO(),t.metrics=await NO(),t.threads=await PK(),t.replication=await LK(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await IO();break;case"time":t.time=SO();break;case"cpu":t.cpu=await TO();break;case"memory":t.memory=await yO();break;case"disk":t.disk=await bO();break;case"network":t.network=await AO();break;case"harperdb_processes":t.harperdb_processes=await RO();break;case"table_size":t.table_size=await wO();break;case"database_metrics":case"metrics":t.metrics=await NO();break;case"threads":t.threads=await PK();break;case"replication":t.replication=await LK();break;default:break}return t}o(mme,"systemInformation")});var na=v((E0e,xK)=>{"use strict";var pme=Hn(),CO=ae(),hme=require("util"),Kl=(q(),M(z)),MK=me();MK.initSync();var Eme=jN(),vK=hn(),{Node:m0e,NodeSubscription:p0e}=rf(),_me=Zu(),gme=yK(),{RemotePayloadObject:Sme,RemotePayloadSubscription:Tme}=bh(),{handleHDBError:yme,hdbErrors:Rme}=_e(),{HTTP_STATUS_CODES:bme,HDB_ERROR_MSGS:Ame}=Rme,Ime=ui(),wme=Ih(),{packageJson:Nme}=Ct(),{getDatabases:Cme}=(we(),M(ft)),h0e=hme.promisify(Eme.authorize),Ome=vK.searchByHash,Pme=vK.searchByValue;xK.exports={isEmpty:Lme,getNodeRecord:Dme,upsertNodeRecord:Mme,buildNodePayloads:vme,checkClusteringEnabled:Ume,getAllNodeRecords:xme,getSystemInfo:Bme,reverseSubscription:UK};function Lme(e){return e==null}o(Lme,"isEmpty");async function Dme(e){let t=new _me(Kl.SYSTEM_SCHEMA_NAME,Kl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Ome(t)}o(Dme,"getNodeRecord");async function Mme(e){let t=new gme(Kl.SYSTEM_SCHEMA_NAME,Kl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return pme.upsert(t)}o(Mme,"upsertNodeRecord");function UK(e){if(CO.isEmpty(e.subscribe)||CO.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}o(UK,"reverseSubscription");function vme(e,t,r,n){let s=[];for(let i=0,a=e.length;i<a;i++){let c=e[i],{schema:l,table:u}=c,d=CO.getTableHashAttribute(l,u),{subscribe:f,publish:m}=UK(c),p=Cme()[l]?.[u],h=new Tme(l,u,d,m,f,c.start_time,p.schemaDefined?p.attributes:void 0);s.push(h)}return new Sme(r,t,s,n)}o(vme,"buildNodePayloads");function Ume(){if(!MK.get(Kl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw yme(new Error,Ame.CLUSTERING_NOT_ENABLED,bme.BAD_REQUEST,void 0,void 0,!0)}o(Ume,"checkClusteringEnabled");async function xme(){let e=new Ime(Kl.SYSTEM_SCHEMA_NAME,Kl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Pme(e))}o(xme,"getAllNodeRecords");async function Bme(){let e=await wme.getSystemInformation();return{hdb_version:Nme.version,node_version:e.node_version,platform:e.platform}}o(Bme,"getSystemInfo")});var OO=v((g0e,VK)=>{"use strict";var qT=hr(),BK=ae(),FK=Ot(),kK=(q(),M(z)),$T=Q(),HK=xT(),Fme=np(),{RemotePayloadObject:kme}=bh(),{handleHDBError:GK,hdbErrors:Hme}=_e(),{HTTP_STATUS_CODES:qK}=Hme,{NodeSubscription:$K}=rf();VK.exports=Gme;async function Gme(e,t){let r;try{r=await qT.request(`${t}.${FK.REQUEST_SUFFIX}`,new kme(kK.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),$T.trace("Response from remote describe all request:",r)}catch(a){$T.error(`addNode received error from describe all request to remote node: ${a}`);let c=qT.requestErrorHandler(a,"add_node",t);throw GK(new Error,c,qK.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===FK.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let a=`Error returned from remote node ${t}: ${r.message}`;throw GK(new Error,a,qK.INTERNAL_SERVER_ERROR,"error",a)}let n=r.message,s=[],i=[];for(let a of e){let{table:c}=a,l=a.database??a.schema??"data";if(l===kK.SYSTEM_SCHEMA_NAME){await qT.createLocalTableStream(l,c);let h=new $K(l,c,a.publish,a.subscribe);h.start_time=a.start_time,i.push(h);continue}let u=BK.doesSchemaExist(l),d=n[l]!==void 0,f=c?BK.doesTableExist(l,c):!0,m=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!d||!f&&!m){s.push(a);continue}if(!u&&d&&($T.trace(`addNode creating schema: ${l}`),await HK.createSchema({operation:"create_schema",schema:l})),!f&&m){$T.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Fme(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await HK.createTable(h)}await qT.createLocalTableStream(l,c);let p=new $K(l,c,a.publish,a.subscribe);p.start_time=a.start_time,i.push(p)}return{added:i,skipped:s}}o(Gme,"reviewSubscriptions")});var sf={};Re(sf,{addNodeBack:()=>PO,removeNodeBack:()=>LO,setNode:()=>Kme});async function Kme(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=gi(t)):t=LT(r);let n=(0,YK.validateBySchema)(e,Vme);if(n)throw(0,sa.handleHDBError)(n,n.message,$me.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new sa.ClientError("url or hostname is required for remove_node operation");let p=r,h=jt(),E=await h.get(p);if(!E)throw new sa.ClientError(p+" does not exist");try{await Th({url:E.url},{operation:V.REMOVE_NODE_BACK,name:E?.subscriptions?.length>0?it():p},void 0)}catch(g){Ss.warn(`Error removing node from target node ${p}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await h.delete(p),`Successfully removed '${p}' from cluster`}if(!t)throw new sa.ClientError("url required for this operation");let s=ic();if(s==null)throw new sa.ClientError("replication url is missing from harperdb-config.yaml");let i,a,c;if(t?.startsWith("wss:")){i=await(0,Vs.getReplicationCert)();let p=await(0,Vs.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(a=await(0,Vs.createCsr)(),Ss.info("Sending CSR to target node:",t)):p&&(c=p.certificate,Ss.info("Sending CA named",p.name,"to target node",t))}let l={operation:V.ADD_NODE_BACK,hostname:(0,hc.get)(F.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:a,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if((0,hc.get)(F.REPLICATION_SHARD)!==void 0&&(l.shard=(0,hc.get)(F.REPLICATION_SHARD)),e.subscriptions?l.subscriptions=e.subscriptions.map(KK):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let p=KK(e);l.subscribe=p.subscribe,l.publish=p.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,d;try{u=await Th({url:t},l,e)}catch(p){p.message=`Error returned from ${t}: `+p.message,Ss.warn("Error adding node:",t,"to cluster:",p),d=p}if(a&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw d?(d.message+=" and connection was required to sign certificate",d):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);a&&(Ss.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Vs.setCertTable)({name:qme.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Vs.setCertTable)({name:it(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let f={url:t,ca:u?.usingCA};if(e.hostname&&(f.name=e.hostname),e.subscriptions?f.subscriptions=e.subscriptions:f.replicates=!0,e.start_time&&(f.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(f.authorization=e.authorization),e.revoked_certificates&&(f.revoked_certificates=e.revoked_certificates),u?.shard!==void 0?f.shard=u.shard:e.shard!==void 0&&(f.shard=e.shard),f.replicates){let p={url:s,ca:c,replicates:!0,subscriptions:null};(0,hc.get)(F.REPLICATION_SHARD)!==void 0&&(p.shard=(0,hc.get)(F.REPLICATION_SHARD)),e.retain_authorization&&(p.authorization=e.authorization),e.start_time&&(p.start_time=e.start_time),await Qo(it(),p)}await Qo(u?u.nodeName:f.name??gi(t),f);let m;return e.operation==="update_node"?m=`Successfully updated '${t}'`:m=`Successfully added '${t}' to cluster`,d&&(m+=" but there was an error updating target node: "+d.message),m}async function PO(e){Ss.trace("addNodeBack received request:",e);let t=await(0,Vs.signCertificate)(e),r;e.csr?(r=t.signingCA,Ss.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,Ss.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization),e.shard!==void 0&&(n.shard=e.shard);let s=await(0,Vs.getReplicationCertAuth)();if(n.replicates){let i={url:ic(),ca:s?.certificate,replicates:!0,subscriptions:null};(0,hc.get)(F.REPLICATION_SHARD)!==void 0&&(i.shard=(0,hc.get)(F.REPLICATION_SHARD),t.shard=i.shard),e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Qo(it(),i)}return await Qo(e.hostname,n),t.nodeName=it(),t.usingCA=s?.certificate,Ss.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function LO(e){Ss.trace("removeNodeBack received request:",e),await jt().delete(e.name)}function KK(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Vs,YK,pc,hc,Ss,sa,qme,$me,Vme,of=se(()=>{Vs=b(gs()),YK=b(mt()),pc=b(require("joi")),hc=b(me());q();mh();$d();Es();Ss=b(Q()),sa=b(_e()),{pki:qme}=require("node-forge"),{HTTP_STATUS_CODES:$me}=sa.hdbErrors,Vme=pc.default.object({hostname:pc.default.string(),verify_tls:pc.default.boolean(),replicates:pc.default.boolean(),subscriptions:pc.default.array(),revoked_certificates:pc.default.array(),shard:pc.default.number()});o(Kme,"setNode");o(PO,"addNodeBack");o(LO,"removeNodeBack");o(KK,"reverseSubscription")});var zT=v((N0e,zK)=>{"use strict";var{handleHDBError:VT,hdbErrors:Yme}=_e(),{HTTP_STATUS_CODES:KT}=Yme,{addUpdateNodeValidator:Wme}=HT(),YT=Q(),WT=(q(),M(z)),WK=Ot(),zme=ae(),wh=hr(),Nh=na(),DO=me(),jme=OO(),{Node:Qme,NodeSubscription:Jme}=rf(),{broadcast:Xme}=nt(),{setNode:Zme}=(of(),M(sf)),I0e=me(),w0e=(q(),M(z)),epe="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",tpe="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",rpe=DO.get(WT.CONFIG_PARAMS.CLUSTERING_NODENAME);zK.exports=npe;async function npe(e,t=!1){if(YT.trace("addNode called with:",e),DO.get(WT.CONFIG_PARAMS.REPLICATION_URL)||DO.get(WT.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Zme(e);Nh.checkClusteringEnabled();let r=Wme(e);if(r)throw VT(r,r.message,KT.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let f=await Nh.getNodeRecord(n);if(!zme.isEmptyOrZeroLength(f))throw VT(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,KT.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await jme(e.subscriptions,n),a={message:void 0,added:s,skipped:i};if(s.length===0)return a.message=epe,a;let c=Nh.buildNodePayloads(s,rpe,WT.OPERATIONS_ENUM.ADD_NODE,await Nh.getSystemInfo()),l=[];for(let f=0,m=s.length;f<m;f++){let p=s[f];s[f].start_time===void 0&&delete s[f].start_time,l.push(new Jme(p.schema,p.table,p.publish,p.subscribe))}YT.trace("addNode sending remote payload:",c);let u;try{u=await wh.request(`${n}.${WK.REQUEST_SUFFIX}`,c)}catch(f){YT.error(`addNode received error from request: ${f}`);for(let p=0,h=s.length;p<h;p++){let E=s[p];E.publish=!1,E.subscribe=!1,await wh.updateRemoteConsumer(E,n)}let m=wh.requestErrorHandler(f,"add_node",n);throw VT(new Error,m,KT.INTERNAL_SERVER_ERROR,"error",m)}if(u.status===WK.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${n}: ${u.message}`;throw VT(new Error,f,KT.INTERNAL_SERVER_ERROR,"error",f)}YT.trace(u);for(let f=0,m=s.length;f<m;f++){let p=s[f];await wh.updateRemoteConsumer(p,n),p.subscribe===!0&&await wh.updateConsumerIterator(p.schema,p.table,n,"start")}let d=new Qme(n,l,u.system_info);return await Nh.upsertNodeRecord(d),Xme({type:"nats_update"}),i.length>0?a.message=tpe:a.message=`Successfully added '${n}' to manifest`,a}o(npe,"addNode")});var xO=v((P0e,QK)=>{"use strict";var{handleHDBError:MO,hdbErrors:spe}=_e(),{HTTP_STATUS_CODES:vO}=spe,{addUpdateNodeValidator:ipe}=HT(),Ch=Q(),jT=(q(),M(z)),jK=Ot(),O0e=ae(),Oh=hr(),Ph=na(),UO=me(),{cloneDeep:ope}=require("lodash"),ape=OO(),{Node:cpe,NodeSubscription:lpe}=rf(),{broadcast:upe}=nt(),{setNode:dpe}=(of(),M(sf)),fpe="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",mpe="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",ppe=UO.get(jT.CONFIG_PARAMS.CLUSTERING_NODENAME);QK.exports=hpe;async function hpe(e){if(Ch.trace("updateNode called with:",e),UO.get(jT.CONFIG_PARAMS.REPLICATION_URL)??UO.get(jT.CONFIG_PARAMS.REPLICATION_HOSTNAME))return dpe(e);Ph.checkClusteringEnabled();let t=ipe(e);if(t)throw MO(t,t.message,vO.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Ph.getNodeRecord(r);s.length>0&&(n=ope(s));let{added:i,skipped:a}=await ape(e.subscriptions,r),c={message:void 0,updated:i,skipped:a};if(i.length===0)return c.message=fpe,c;let l=Ph.buildNodePayloads(i,ppe,jT.OPERATIONS_ENUM.UPDATE_NODE,await Ph.getSystemInfo());for(let d=0,f=i.length;d<f;d++){let m=i[d];Ch.trace(`updateNode updating work stream for node: ${r} subscription:`,m),i[d].start_time===void 0&&delete i[d].start_time}Ch.trace("updateNode sending remote payload:",l);let u;try{u=await Oh.request(`${r}.${jK.REQUEST_SUFFIX}`,l)}catch(d){Ch.error(`updateNode received error from request: ${d}`);let f=Oh.requestErrorHandler(d,"update_node",r);throw MO(new Error,f,vO.INTERNAL_SERVER_ERROR,"error",f)}if(u.status===jK.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${r}: ${u.message}`;throw MO(new Error,d,vO.INTERNAL_SERVER_ERROR,"error",d)}Ch.trace(u);for(let d=0,f=i.length;d<f;d++){let m=i[d];await Oh.updateRemoteConsumer(m,r),m.subscribe===!0?await Oh.updateConsumerIterator(m.schema,m.table,r,"start"):await Oh.updateConsumerIterator(m.schema,m.table,r,"stop")}return n||(n=[new cpe(r,[],u.system_info)]),await Epe(n[0],i,u.system_info),a.length>0?c.message=mpe:c.message=`Successfully updated '${r}'`,c}o(hpe,"updateNode");async function Epe(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let a=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let d=n.subscriptions[l];if(d.schema===a.schema&&d.table===a.table){d.publish=a.publish,d.subscribe=a.subscribe,c=!0;break}}c||n.subscriptions.push(new lpe(a.schema,a.table,a.publish,a.subscribe))}n.system_info=r,await Ph.upsertNodeRecord(n),upe({type:"nats_update"})}o(Epe,"updateNodeTable")});var tY=v((D0e,eY)=>{"use strict";var ZK=require("joi"),{string:JK}=ZK.types(),_pe=mt(),XK=(q(),M(z)),gpe=me(),Spe=Ot();eY.exports=Tpe;function Tpe(e){let t=JK.invalid(gpe.get(XK.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Spe.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=ZK.object({operation:JK.valid(XK.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return _pe.validateBySchema(e,r)}o(Tpe,"removeNodeValidator")});var QT=v((v0e,oY)=>{"use strict";var{handleHDBError:rY,hdbErrors:ype}=_e(),{HTTP_STATUS_CODES:nY}=ype,Rpe=tY(),Lh=Q(),sY=na(),bpe=ae(),af=(q(),M(z)),iY=Ot(),BO=hr(),FO=me(),{RemotePayloadObject:Ape}=bh(),{NodeSubscription:Ipe}=rf(),wpe=rp(),Npe=Sl(),{broadcast:Cpe}=nt(),{setNode:Ope}=(of(),M(sf)),Ppe=FO.get(af.CONFIG_PARAMS.CLUSTERING_NODENAME);oY.exports=Lpe;async function Lpe(e){if(Lh.trace("removeNode called with:",e),FO.get(af.CONFIG_PARAMS.REPLICATION_URL)??FO.get(af.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Ope(e);sY.checkClusteringEnabled();let t=Rpe(e);if(t)throw rY(t,t.message,nY.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await sY.getNodeRecord(r);if(bpe.isEmptyOrZeroLength(n))throw rY(new Error,`Node '${r}' was not found.`,nY.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Ape(af.OPERATIONS_ENUM.REMOVE_NODE,Ppe,[]),i,a=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let d=n.subscriptions[l];d.subscribe===!0&&await BO.updateConsumerIterator(d.schema,d.table,r,"stop");try{await BO.updateRemoteConsumer(new Ipe(d.schema,d.table,!1,!1),r)}catch(f){Lh.error(f)}}try{i=await BO.request(`${r}.${iY.REQUEST_SUFFIX}`,s),Lh.trace("Remove node reply from remote node:",r,i)}catch(l){Lh.error("removeNode received error from request:",l),a=!0}let c=new wpe(af.SYSTEM_SCHEMA_NAME,af.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Npe.deleteRecord(c),Cpe({type:"nats_update"}),i?.status===iY.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||a?(Lh.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`}o(Lpe,"removeNode")});var lY=v((x0e,cY)=>{"use strict";var aY=require("joi"),{string:Dpe,array:Mpe}=aY.types(),vpe=mt(),Upe=HT();cY.exports=xpe;function xpe(e){let t=aY.object({operation:Dpe.valid("configure_cluster").required(),connections:Mpe.items(Upe.validationSchema).required()});return vpe.validateBySchema(e,t)}o(xpe,"configureClusterValidator")});var kO=v((F0e,pY)=>{"use strict";var uY=(q(),M(z)),JT=Q(),Bpe=ae(),Fpe=me(),kpe=QT(),Hpe=zT(),Gpe=na(),qpe=lY(),{handleHDBError:dY,hdbErrors:$pe}=_e(),{HTTP_STATUS_CODES:fY}=$pe,Vpe="Configure cluster complete.",Kpe="Failed to configure the cluster. Check the logs for more details.",Ype="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";pY.exports=Wpe;async function Wpe(e){JT.trace("configure cluster called with:",e);let t=qpe(e);if(t)throw dY(t,t.message,fY.BAD_REQUEST,void 0,void 0,!0);let r=await Gpe.getAllNodeRecords(),n=[];if(Fpe.get(uY.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let d=0,f=r.length;d<f;d++){let m=await mY(kpe,{operation:uY.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[d].name},r[d].name);n.push(m)}JT.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let d=0;d<i;d++){let f=e.connections[d],m=await mY(Hpe,f,f.node_name);s.push(m)}JT.trace("All results from configure_cluster add node:",s);let a=[],c=[],l=!1,u=n.concat(s);for(let d=0,f=u.length;d<f;d++){let m=u[d];m.status==="rejected"&&(JT.error(m.node_name,m?.error?.message,m?.error?.stack),a.includes(m.node_name)||a.push(m.node_name)),(m?.result?.message?.includes?.("Successfully")||m?.result?.includes?.("Successfully"))&&(l=!0),!(typeof m.result=="string"&&m.result.includes("Successfully removed")||m.status==="rejected")&&c.push({node_name:m?.node_name,response:m?.result})}if(Bpe.isEmptyOrZeroLength(a))return{message:Vpe,connections:c};if(l)return{message:Ype,failed_nodes:a,connections:c};throw dY(new Error,Kpe,fY.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}o(Wpe,"configureCluster");async function mY(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}o(mY,"functionWrapper")});var gY=v((H0e,_Y)=>{"use strict";var Dh=require("joi"),zpe=mt(),{validateSchemaExists:hY,validateTableExists:jpe,validateSchemaName:EY}=Vi(),Qpe=Dh.object({operation:Dh.string().valid("purge_stream"),schema:Dh.string().custom(hY).custom(EY).optional(),database:Dh.string().custom(hY).custom(EY).optional(),table:Dh.string().custom(jpe).required()});function Jpe(e){return zpe.validateBySchema(e,Qpe)}o(Jpe,"purgeStreamValidator");_Y.exports=Jpe});var HO=v((q0e,SY)=>{"use strict";var{handleHDBError:Xpe,hdbErrors:Zpe}=_e(),{HTTP_STATUS_CODES:ehe}=Zpe,the=gY(),rhe=hr(),nhe=na();SY.exports=she;async function she(e){e.schema=e.schema??e.database;let t=the(e);if(t)throw Xpe(t,t.message,ehe.BAD_REQUEST,void 0,void 0,!0);nhe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await rhe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}o(she,"purgeStream")});var $O=v((V0e,NY)=>{"use strict";var qO=na(),ihe=hr(),ZT=me(),cf=(q(),M(z)),Yl=Ot(),ohe=ae(),GO=Q(),{RemotePayloadObject:ahe}=bh(),{ErrorCode:TY}=require("nats"),{parentPort:yY}=require("worker_threads"),{onMessageByType:che}=nt(),{getThisNodeName:lhe}=(Es(),M(Xo)),{requestClusterStatus:uhe}=(mh(),M(vV)),{getReplicationSharedStatus:dhe,getHDBNodeTable:fhe}=($d(),M(OV)),{CONFIRMATION_STATUS_POSITION:mhe,RECEIVED_VERSION_POSITION:RY,RECEIVED_TIME_POSITION:phe,SENDING_TIME_POSITION:hhe,RECEIVING_STATUS_POSITION:Ehe,RECEIVING_STATUS_RECEIVING:_he,BACK_PRESSURE_RATIO_POSITION:ghe}=(XC(),M(w1)),bY=ZT.get(cf.CONFIG_PARAMS.CLUSTERING_ENABLED),AY=ZT.get(cf.CONFIG_PARAMS.CLUSTERING_NODENAME);NY.exports={clusterStatus:She,buildNodeStatus:wY};var IY;che("cluster-status",async e=>{IY(e)});async function She(){if(ZT.get(cf.CONFIG_PARAMS.REPLICATION_URL)||ZT.get(cf.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(yY){yY.postMessage({type:"request-cluster-status"}),n=await new Promise(i=>{IY=i});for(let i of n.connections){let a=i.name;for(let c of i.database_sockets){let l=c.database,u;for(let f of Object.values(databases[l]||{}))if(u=f.auditStore,u)break;if(!u)continue;let d=dhe(u,l,a);c.lastCommitConfirmed=XT(d[mhe]),c.lastReceivedRemoteTime=XT(d[RY]),c.lastReceivedLocalTime=XT(d[phe]),c.lastReceivedVersion=d[RY],c.sendingMessage=XT(d[hhe]),c.backPressurePercent=d[ghe]*100,c.lastReceivedStatus=d[Ehe]===_he?"Receiving":"Waiting"}}}else n=uhe();n.node_name=lhe();let s=fhe().primaryStore.get(n.node_name);return s?.shard&&(n.shard=s.shard),s?.url&&(n.url=s.url),n.is_enabled=!0,n}let e={node_name:AY,is_enabled:bY,connections:[]};if(!bY)return e;let t=await qO.getAllNodeRecords();if(ohe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(wY(t[n],e.connections));return await Promise.allSettled(r),e}o(She,"clusterStatus");function XT(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}o(XT,"asDate");async function wY(e,t){let r=e.name,n=new ahe(cf.OPERATIONS_ENUM.CLUSTER_STATUS,AY,void 0,await qO.getSystemInfo()),s,i,a=Yl.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await ihe.request(Yl.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Yl.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(a=Yl.CLUSTER_STATUS_STATUSES.CLOSED,GO.error(`Error getting node status from ${r} `,s))}catch(l){GO.warn(`Error getting node status from ${r}`,l),l.code===TY.NoResponders?a=Yl.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===TY.Timeout?a=Yl.CLUSTER_STATUS_STATUSES.TIMEOUT:a=Yl.CLUSTER_STATUS_STATUSES.CLOSED}let c=new The(r,a,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!==cf.PRE_4_0_0_VERSION&&await qO.upsertNodeRecord(l)}catch(l){GO.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}o(wY,"buildNodeStatus");function The(e,t,r,n,s,i,a,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=a,this.system_info=c}o(The,"NodeStatusObject")});var KO=v((Y0e,CY)=>{"use strict";var{handleHDBError:yhe,hdbErrors:Rhe}=_e(),{HTTP_STATUS_CODES:bhe}=Rhe,Ahe=hr(),Ihe=na(),VO=ae(),ey=require("joi"),whe=mt(),Nhe=2e3,Che=ey.object({timeout:ey.number().min(1),connected_nodes:ey.boolean(),routes:ey.boolean()});CY.exports=Ohe;async function Ohe(e){Ihe.checkClusteringEnabled();let t=whe.validateBySchema(e,Che);if(t)throw yhe(t,t.message,bhe.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||VO.autoCastBoolean(n),a=s===void 0||VO.autoCastBoolean(s),c={nodes:[]},l=await Ahe.getServerList(r??Nhe),u={};if(i)for(let d=0,f=l.length;d<f;d++){let m=l[d].statsz;m&&(u[l[d].server.name]=m.routes)}for(let d=0,f=l.length;d<f;d++){if(l[d].statsz)continue;let m=l[d].server,p=l[d].data;if(m.name.endsWith("-hub")){let h={name:m.name.slice(0,-4),response_time:l[d].response_time};i&&(h.connected_nodes=[],u[m.name]&&u[m.name].forEach(E=>{h.connected_nodes.includes(E.name.slice(0,-4))||h.connected_nodes.push(E.name.slice(0,-4))})),a&&(h.routes=p.cluster?.urls?p.cluster?.urls.map(E=>({host:E.split(":")[0],port:VO.autoCast(E.split(":")[1])})):[]),c.nodes.push(h)}}return c}o(Ohe,"clusterNetwork")});var DY=v((z0e,LY)=>{"use strict";var YO=require("joi"),OY=mt(),{routeConstraints:PY}=ww();LY.exports={setRoutesValidator:Phe,deleteRoutesValidator:Lhe};function Phe(e){let t=YO.object({server:YO.valid("hub","leaf"),routes:PY.required()});return OY.validateBySchema(e,t)}o(Phe,"setRoutesValidator");function Lhe(e){let t=YO.object({routes:PY.required()});return OY.validateBySchema(e,t)}o(Lhe,"deleteRoutesValidator")});var ty=v((Q0e,kY)=>{"use strict";var ia=St(),WO=ae(),Ks=(q(),M(z)),lf=me(),MY=DY(),{handleHDBError:vY,hdbErrors:Dhe}=_e(),{HTTP_STATUS_CODES:UY}=Dhe,xY="cluster routes successfully set",BY="cluster routes successfully deleted";kY.exports={setRoutes:vhe,getRoutes:Uhe,deleteRoutes:xhe};function Mhe(e){let t=ia.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 a=0,c=e.routes.length;a<c;a++){let l=e.routes[a];l.port=WO.autoCast(l.port);let u=r.some(f=>f.host===l.host&&f.port===l.port),d=n.some(f=>f.host===l.host&&f.port===l.port);u||d?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?ia.updateConfigValue(Ks.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):ia.updateConfigValue(Ks.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:xY,set:i,skipped:s}}o(Mhe,"setRoutesNats");function vhe(e){let t=MY.setRoutesValidator(e);if(t)throw vY(t,t.message,UY.BAD_REQUEST,void 0,void 0,!0);if(lf.get(Ks.CONFIG_PARAMS.CLUSTERING_ENABLED))return Mhe(e);let r=[],n=[],s=lf.get(Ks.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{FY(s,i)?n.push(i):(s.push(i),r.push(i))}),ia.updateConfigValue(Ks.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:xY,set:r,skipped:n}}o(vhe,"setRoutes");function FY(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}o(FY,"existsInArray");function Uhe(){if(lf.get(Ks.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=ia.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return lf.get(Ks.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}o(Uhe,"getRoutes");function xhe(e){let t=MY.deleteRoutesValidator(e);if(t)throw vY(t,t.message,UY.BAD_REQUEST,void 0,void 0,!0);if(lf.get(Ks.CONFIG_PARAMS.CLUSTERING_ENABLED))return Bhe(e);let r=[],n=[],s=lf.get(Ks.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(a=>{FY(e.routes,a)?r.push(a):(i.push(a),n.push(a))}),ia.updateConfigValue(Ks.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:BY,deleted:r,skipped:n}}o(xhe,"deleteRoutes");function Bhe(e){let t=ia.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],a=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let d=e.routes[l],f=!1;for(let m=0,p=r.length;m<p;m++){let h=r[m];if(d.host===h.host&&d.port===h.port){r.splice(m,1),f=!0,a=!0,s.push(d);break}}if(!f){let m=!0;for(let p=0,h=n.length;p<h;p++){let E=n[p];if(d.host===E.host&&d.port===E.port){n.splice(p,1),c=!0,m=!1,s.push(d);break}}m&&i.push(d)}}return a&&(r=WO.isEmptyOrZeroLength(r)?null:r,ia.updateConfigValue(Ks.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=WO.isEmptyOrZeroLength(n)?null:n,ia.updateConfigValue(Ks.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:BY,deleted:s,skipped:i}}o(Bhe,"deleteRoutesNats")});var GY=v((X0e,HY)=>{"use strict";var Fhe=Ot(),zO=class{static{o(this,"HubConfigObject")}constructor(t,r,n,s,i,a,c,l,u,d,f,m,p,h){this.port=t,a===null&&(a=void 0),this.server_name=r+Fhe.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:a,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:a,insecure:c}},this.cluster={name:d,port:f,routes:m,tls:{cert_file:s,key_file:i,ca_file:a,insecure:c,verify:l}},this.accounts={SYS:{users:p},HDB:{users:h}},this.system_account="SYS"}};HY.exports=zO});var VY=v((eBe,$Y)=>{"use strict";var qY=Ot(),jO=class{static{o(this,"LeafConfigObject")}constructor(t,r,n,s,i,a,c,l,u,d,f){this.port=t,f===null&&(f=void 0),this.server_name=r+qY.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+qY.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:d,ca_file:f,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:f,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:f,insecure:!0},urls:a,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};$Y.exports=jO});var YY=v((rBe,KY)=>{"use strict";var QO=class{static{o(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};KY.exports=QO});var zY=v((sBe,WY)=>{"use strict";var khe=Ot(),JO=class{static{o(this,"SysUserObject")}constructor(t,r){this.user=t+khe.SERVER_SUFFIX.ADMIN,this.password=r}};WY.exports=JO});var iy=v((oBe,JY)=>{"use strict";var Wl=require("path"),zl=require("fs-extra"),Hhe=GY(),Ghe=VY(),qhe=YY(),$he=zY(),XO=ds(),df=ae(),Kn=St(),ny=(q(),M(z)),Mh=Ot(),{CONFIG_PARAMS:or}=ny,ff=Q(),vh=me(),jY=Ji(),ZO=hr(),Vhe=gs(),uf="clustering",Khe=1e4,QY=50;JY.exports={generateNatsConfig:Whe,removeNatsConfig:zhe,getHubConfigPath:Yhe};function Yhe(){let e=vh.get(or.ROOTPATH);return Wl.join(e,uf,Mh.NATS_CONFIG_FILES.HUB_SERVER)}o(Yhe,"getHubConfigPath");async function Whe(e=!1,t=void 0){console.error("Warning: NATS replication is deprecated and will be removed in version 5.0 of Harper");let r=vh.get(or.ROOTPATH);zl.ensureDirSync(Wl.join(r,"clustering","leaf")),vh.initSync();let n=Kn.getConfigFromFile(or.CLUSTERING_TLS_CERT_AUTH),s=Kn.getConfigFromFile(or.CLUSTERING_TLS_PRIVATEKEY),i=Kn.getConfigFromFile(or.CLUSTERING_TLS_CERTIFICATE);!await zl.exists(i)&&!await zl.exists(!n)&&await Vhe.createNatsCerts();let a=Wl.join(r,uf,Mh.PID_FILES.HUB),c=Wl.join(r,uf,Mh.PID_FILES.LEAF),l=Kn.getConfigFromFile(or.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Wl.join(r,uf,Mh.NATS_CONFIG_FILES.HUB_SERVER),d=Wl.join(r,uf,Mh.NATS_CONFIG_FILES.LEAF_SERVER),f=Kn.getConfigFromFile(or.CLUSTERING_TLS_INSECURE),m=Kn.getConfigFromFile(or.CLUSTERING_TLS_VERIFY),p=Kn.getConfigFromFile(or.CLUSTERING_NODENAME),h=Kn.getConfigFromFile(or.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await ZO.checkNATSServerInstalled()||sy("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let E=await XO.listUsers(),g=Kn.getConfigFromFile(or.CLUSTERING_USER),R=await XO.getClusterUser();(df.isEmpty(R)||R.active!==!0)&&sy(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await ry(or.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await ry(or.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await ry(or.CLUSTERING_HUBSERVER_NETWORK_PORT),await ry(or.CLUSTERING_LEAFSERVER_NETWORK_PORT));let S=[],y=[];for(let[X,W]of E.entries())W.role?.role===ny.ROLE_TYPES_ENUM.CLUSTER_USER&&W.active&&(S.push(new $he(W.username,jY.decrypt(W.hash))),y.push(new qhe(W.username,jY.decrypt(W.hash))));let C=[],{hub_routes:I}=Kn.getClusteringRoutes();if(!df.isEmptyOrZeroLength(I))for(let X of I)C.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${X.host}:${X.port}`);let k=new Hhe(Kn.getConfigFromFile(or.CLUSTERING_HUBSERVER_NETWORK_PORT),p,a,i,s,n,f,m,h,Kn.getConfigFromFile(or.CLUSTERING_HUBSERVER_CLUSTER_NAME),Kn.getConfigFromFile(or.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),C,S,y);n==null&&(delete k.tls.ca_file,delete k.leafnodes.tls.ca_file),t=df.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ny.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await zl.writeJson(u,k),ff.trace(`Hub server config written to ${u}`));let J=`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,G=`tls://${R.uri_encoded_name}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,H=new Ghe(Kn.getConfigFromFile(or.CLUSTERING_LEAFSERVER_NETWORK_PORT),p,c,l,[J],[G],S,y,i,s,n,f);n==null&&delete H.tls.ca_file,(t===void 0||t===ny.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await zl.writeJson(d,H),ff.trace(`Leaf server config written to ${d}`))}o(Whe,"generateNatsConfig");async function ry(e){let t=vh.get(e);return df.isEmpty(t)&&sy(`port undefined for '${e}'`),await df.isPortTaken(t)&&sy(`'${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}o(ry,"isPortAvailable");function sy(e){let t=`Error generating clustering config: ${e}`;ff.error(t),console.error(t),process.exit(1)}o(sy,"generateNatsConfigError");async function zhe(e){let{port:t,config_file:r}=ZO.getServerConfig(e),{username:n,decrypt_hash:s}=await XO.getClusterUser(),i=0,a=2e3;for(;i<QY;){try{let d=await ZO.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){ff.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=QY)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=a*(i*2);u>3e4&&ff.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await df.asyncSetTimeout(u)}let c="0".repeat(Khe),l=Wl.join(vh.get(or.ROOTPATH),uf,r);await zl.writeFile(l,c),await zl.remove(l),ff.notify(e,"started.")}o(zhe,"removeNatsConfig")});var nW=v((cBe,rW)=>{"use strict";var Ts=me(),Xe=(q(),M(z)),Uh=Ot(),oa=require("path"),{PACKAGE_ROOT:ay}=Ct(),XY=me(),oy=ae(),mf="/dev/null",jhe=oa.join(ay,"launchServiceScripts"),ZY=oa.join(ay,"utility/scripts"),Qhe=oa.join(ZY,Xe.HDB_RESTART_SCRIPT),eW=oa.resolve(ay,"dependencies",`${process.platform}-${process.arch}`,Uh.NATS_BINARY_NAME);function tW(){let e={[Xe.PROCESS_NAME_ENV_PROP]:Xe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0,...process.env};return oy.noBootFile()&&(e[Xe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=oy.getEnvCliRootPath()),{name:Xe.PROCESS_DESCRIPTORS.HDB,script:Xe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:e,execArgv:process.execArgv,cwd:ay}}o(tW,"generateMainServerConfig");var Jhe=9930;function Xhe(){Ts.initSync(!0);let e=Ts.get(Xe.CONFIG_PARAMS.ROOTPATH),t=oa.join(e,"clustering",Uh.NATS_CONFIG_FILES.HUB_SERVER),r=oa.join(Ts.get(Xe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Xe.LOG_NAMES.HDB),n=XY.get(Xe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Uh.LOG_LEVEL_FLAGS[Ts.get(Xe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Jhe?"-"+n:""),binFile:eW,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Xe.PROCESS_NAME_ENV_PROP]:Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Ts.get(Xe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=mf,i.error_file=mf),i}o(Xhe,"generateNatsHubServerConfig");var Zhe=9940;function eEe(){Ts.initSync(!0);let e=Ts.get(Xe.CONFIG_PARAMS.ROOTPATH),t=oa.join(e,"clustering",Uh.NATS_CONFIG_FILES.LEAF_SERVER),r=oa.join(Ts.get(Xe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Xe.LOG_NAMES.HDB),n=XY.get(Xe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Uh.LOG_LEVEL_FLAGS[Ts.get(Xe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Zhe?"-"+n:""),binFile:eW,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Xe.PROCESS_NAME_ENV_PROP]:Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Ts.get(Xe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=mf,i.error_file=mf),i}o(eEe,"generateNatsLeafServerConfig");function tEe(){Ts.initSync();let e=oa.join(Ts.get(Xe.CONFIG_PARAMS.LOGGING_ROOT),Xe.LOG_NAMES.HDB),t={name:Xe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,binFile:Xe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Xe.PROCESS_NAME_ENV_PROP]:Xe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:jhe,autorestart:!1};return Ts.get(Xe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=mf,t.error_file=mf),t}o(tEe,"generateClusteringUpgradeV4ServiceConfig");function rEe(){let e={[Xe.PROCESS_NAME_ENV_PROP]:Xe.PROCESS_DESCRIPTORS.RESTART_HDB};return oy.noBootFile()&&(e[Xe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=oy.getEnvCliRootPath()),{...{name:Xe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:ZY},script:Qhe}}o(rEe,"generateRestart");function nEe(){return{apps:[tW()]}}o(nEe,"generateAllServiceConfigs");rW.exports={generateAllServiceConfigs:nEe,generateMainServerConfig:tW,generateRestart:rEe,generateNatsHubServerConfig:Xhe,generateNatsLeafServerConfig:eEe,generateClusteringUpgradeV4ServiceConfig:tEe}});var pf=v((dBe,uW)=>{"use strict";var Or=(q(),M(z)),uBe=ae(),ca=iy(),cy=hr(),aa=Ot(),Ec=nW(),tP=me(),_c=Q(),sEe=na(),{startWorker:sW,onMessageFromWorkers:iEe}=nt(),iW=require("fs"),oEe=require("node:path"),aEe=(q(),M(z)),{setTimeout:cEe}=require("node:timers/promises"),{execFile:lEe,fork:uEe}=require("node:child_process");uW.exports={start:gc,restart:fEe,kill:EEe,startAllServices:_Ee,startService:aW,restartHdb:mEe,startClusteringProcesses:cW,startClusteringThreads:lW,isHdbRestartRunning:pEe,getHdbPid:hEe,cleanupChildrenProcesses:xh,reloadClustering:SEe,expectedRestartOfChildren:oW};iEe(e=>{e.type==="restart"&&tP.initSync(!0)});var fo=[],dEe=10,eP;function gc(e,t=!1){let r=typeof e.args=="string"?e.args.split(" "):e.args;e.silent=!0,e.detached=!0;let n=e.script?uEe(e.script,r,e):lEe(e.binFile,r,e);n.name=e.name,n.config=e,n.on("error",(a,c)=>{console.error(a,c)}),n.on("exit",async a=>{let c=fo.indexOf(n);c>-1&&fo.splice(c,1),!eP&&a!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<dEe&&(iW.existsSync(ca.getHubConfigPath())?gc(e):(await ca.generateNatsConfig(!0),gc(e),await new Promise(l=>setTimeout(l,3e3)),await ca.removeNatsConfig(Or.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ca.removeNatsConfig(Or.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let s={serviceName:e.name.replace(/ /g,"-")};function i(a){let c=tP.get(Or.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),l=/\[\d+][^\[]+\[(\w+)]/g,u,d=0,f;for(;u=l.exec(a);){if(u.index&&aa.LOG_LEVEL_HIERARCHY[c]>=aa.LOG_LEVEL_HIERARCHY[f||"info"]){let h=f===aa.LOG_LEVELS.ERR||f===aa.LOG_LEVELS.WRN?_c.OUTPUTS.STDERR:_c.OUTPUTS.STDOUT;_c.logCustomLevel(f||"info",h,s,a.slice(d,u.index).trim())}let[m,p]=u;d=u.index+m.length,f=aa.LOG_LEVELS[p]}if(aa.LOG_LEVEL_HIERARCHY[c]>=aa.LOG_LEVEL_HIERARCHY[f||"info"]){let m=f===aa.LOG_LEVELS.ERR||f===aa.LOG_LEVELS.WRN?_c.OUTPUTS.STDERR:_c.OUTPUTS.STDOUT;_c.logCustomLevel(f||"info",m,s,a.toString().slice(d).trim())}}o(i,"extractMessages"),n.stdout.on("data",i),n.stderr.on("data",i),n.unref(),fo.length===0&&(t||(process.on("exit",xh),process.on("SIGINT",xh),process.on("SIGQUIT",xh),process.on("SIGTERM",xh))),fo.push(n)}o(gc,"start");function xh(e=!0){if(!eP&&(eP=!0,fo.length!==0))if(_c.info("Killing child processes..."),fo.map(t=>t.kill()),e)process.exit(0);else return cEe(2e3)}o(xh,"cleanupChildrenProcesses");function fEe(e){oW();for(let t of fo)t.name===e&&t.kill()}o(fEe,"restart");function oW(){for(let e of fo)e.config&&(e.config.restarts=0)}o(oW,"expectedRestartOfChildren");async function mEe(){await gc(Ec.generateRestart())}o(mEe,"restartHdb");async function pEe(){let e=await list();for(let t in e)if(e[t].name===Or.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}o(pEe,"isHdbRestartRunning");function hEe(){let e=tP.getHdbBasePath();if(!e)return;let t=oEe.join(e,aEe.HDB_PID_FILE),r=TEe(t);if(!(!r||r===process.pid)&&yEe(r))return r}o(hEe,"getHdbPid");function EEe(){for(let e of fo)e.kill();fo=[]}o(EEe,"kill");async function _Ee(){await cW(),await lW(),await gc(Ec.generateAllServiceConfigs())}o(_Ee,"startAllServices");async function aW(e,t=!1){let r;switch(e=e.toLowerCase(),e){case Or.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ec.generateMainServerConfig();break;case Or.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ec.generateNatsIngestServiceConfig();break;case Or.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ec.generateNatsReplyServiceConfig();break;case Or.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ec.generateNatsHubServerConfig(),await gc(r,t),await ca.removeNatsConfig(e);return;case Or.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ec.generateNatsLeafServerConfig(),await gc(r,t),await ca.removeNatsConfig(e);return;case Or.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ec.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}gc(r,t)}o(aW,"startService");var gEe;async function cW(e=!1){for(let t in Or.CLUSTERING_PROCESSES){let r=Or.CLUSTERING_PROCESSES[t];await aW(r,e)}}o(cW,"startClusteringProcesses");async function lW(){gEe=sW(Or.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Or.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await cy.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await cy.updateLocalStreams();let e=await sEe.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Or.PRE_4_0_0_VERSION){_c.info("Starting clustering upgrade 4.0.0 process"),sW(Or.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}o(lW,"startClusteringThreads");async function SEe(){await ca.generateNatsConfig(!0),await cy.reloadNATSHub(),await cy.reloadNATSLeaf(),await ca.removeNatsConfig(Or.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await ca.removeNatsConfig(Or.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}o(SEe,"reloadClustering");function TEe(e){try{return Number.parseInt(iW.readFileSync(e,"utf8"),10)}catch{return null}}o(TEe,"readPidFile");function yEe(e){try{return process.kill(e,0),!0}catch(t){return t.code==="EPERM"}}o(yEe,"isProcessRunning")});var sP={};Re(sP,{compactOnStart:()=>REe,copyDb:()=>EW});async function REe(){Sc.notify("Running compact on start"),console.log("Running compact on start");let e=(0,rP.get)(F.ROOTPATH),t=new Map,r=at();(0,nP.updateConfigValue)(F.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,ly.join)(e,"backup",n+".mdb"),a=(0,ly.join)(e,qc,n+"-copy.mdb"),c=0;try{c=await dW(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Sc.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{dbPath:s,copyDest:a,backupDest:i,recordCount:c}),await EW(n,a),console.log("Backing up",n,"to",i);try{await(0,jl.move)(s,i,{overwrite:!0})}catch(l){console.log("Error moving database",s,"to",i,l)}}try{Td()}catch(n){Sc.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{dbPath:s,copyDest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,jl.move)(i,s,{overwrite:!0}),await(0,jl.remove)((0,ly.join)(e,qc,`${n}-copy.mdb-lock`));try{Td()}catch(n){Sc.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Sc.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,nP.updateConfigValue)(F.STORAGE_COMPACTONSTART,!1);for(let[s,{dbPath:i,backupDest:a}]of t){console.error("Moving backup database",a,"back to",i);try{await(0,jl.move)(a,i,{overwrite:!0})}catch(c){console.error(c)}}throw Td(),n}for(let[n,{backupDest:s,recordCount:i}]of t){let a=!0,c=await dW(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){a=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
25
|
+
`)}function Gde(e){let t=[],r=e;for(;r?.raw;){let n={cert:r.raw};if(r.issuerCertificate&&r.issuerCertificate!==r&&r.issuerCertificate.raw&&(n.issuer=r.issuerCertificate.raw),t.push(n),r.issuerCertificate&&r.issuerCertificate!==r)r=r.issuerCertificate;else break}return t}var wT,M1,v1,ht,eO,ea,IT,NT=se(()=>{L1();wT=require("easy-ocsp"),M1=require("node:crypto"),v1=b(Xn());we();Ha();ht=(0,v1.loggerWithTag)("cert-verification"),eO=class extends Hr{static{o(this,"CertificateVerificationSource")}async get(t){ht.debug?.("CertificateVerificationSource.get called for:",t);let r=this.getContext(),n=r?.requestContext;if(!n||!n.certPem||!n.issuerPem)throw new Error(`No certificate data provided for cache key: ${t}`);let{certPem:s,issuerPem:i,config:a}=n;ht.trace?.("Performing OCSP check with config:",a);try{let c=a?.timeout??ea.timeout,l=await Promise.race([Hde(s,i,c),new Promise((m,p)=>setTimeout(()=>p(new Error("OCSP timeout")),c))]);if(ht.debug?.("OCSP check result:",l),l.status==="unknown"&&(l.reason==="ocsp-error"||l.reason==="timeout"||l.reason==="no-ocsp-url")){let m=a?.failureMode??ea.failureMode;if(ht.error?.("OCSP check failed:",l.reason),m==="fail-closed"){let p=a?.errorCacheTtl??ea.errorCacheTtl,h=Date.now()+p;return r&&(r.expiresAt=h),{certificate_id:t,status:l.status,reason:l.reason,checked_at:Date.now(),expiresAt:h,method:"ocsp"}}else return ht.warn?.("OCSP check failed, allowing connection (fail-open mode)"),null}let d=a?.cacheTtl??ea.cacheTtl,f=Date.now()+d;return r&&(r.expiresAt=f),{certificate_id:t,status:l.status,reason:l.reason,checked_at:Date.now(),expiresAt:f,method:"ocsp"}}catch(c){if(ht.error?.("OCSP verification error:",c),(a?.failureMode??ea.failureMode)==="fail-closed"){let u=a?.errorCacheTtl??ea.errorCacheTtl,d=Date.now()+u;return r&&(r.expiresAt=d),{certificate_id:t,status:"unknown",reason:c.message,checked_at:Date.now(),expiresAt:d,method:"ocsp"}}return ht.warn?.("OCSP check failed, allowing connection (fail-open mode)"),null}}},ea={timeout:5e3,cacheTtl:36e5,errorCacheTtl:3e5,failureMode:"fail-open"};o(Bde,"getCertificateCacheTable");o(Fde,"getCertificateVerificationConfig");o(Qd,"verifyCertificate");o(kde,"verifyOCSP");o(Hde,"performOCSPCheck");o(D1,"bufferToPem");o(Gde,"extractCertificateChain")});var Xo={};Re(Xo,{clearThisNodeName:()=>Qde,disableReplication:()=>Kde,enabledDatabases:()=>lc,forEachReplicatedDatabase:()=>sc,getThisNodeId:()=>AT,getThisNodeName:()=>it,getThisNodeUrl:()=>ic,hostnameToUrl:()=>LT,lastTimeInAuditStore:()=>ch,monitorNodeCAs:()=>$1,replicateOperation:()=>Xde,replicationCertificateAuthorities:()=>Zo,sendOperationToNode:()=>Th,servers:()=>$de,setReplicator:()=>K1,start:()=>Vde,startOnMainThread:()=>OC,subscribeToNode:()=>fh,unsubscribeFromNode:()=>uT,urlToNodeName:()=>gi});function Vde(e){if(!e.port&&!e.securePort&&(e.port=$s.default.get(F.OPERATIONSAPI_NETWORK_PORT),e.securePort=$s.default.get(F.OPERATIONSAPI_NETWORK_SECUREPORT)),!it())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let s of uh(e))t.set(gi(s.url),s);Yde(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=ve.ws(async(s,i,a,c)=>{if(It.debug("Incoming WS connection received "+i.url),i.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return c(s,i,a);s._socket.unref(),_h(s,e,a.then(()=>i?.user)),s.on("error",l=>{l.code!=="ECONNREFUSED"&&It.error("Error in connection to "+this.url,l.message)})},e);e.runFirst=!0,ve.http(async(s,i)=>{if(s.isWebSocket&&s.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){It.debug("Incoming replication WS connection received, authorized: "+s.authorized),!s.authorized&&s._nodeRequest.socket.authorizationError&&It.error(`Incoming client connection from ${s.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,s._nodeRequest.socket.authorizationError);let a=jt().primaryStore;if(s.authorized&&s.peerCertificate.subjectaltname){let c=(0,G1.getHostnamesFromCertificate)(s.peerCertificate),l;for(let u of c)if(l=u&&(a.get(u)||t.get(u)),l)break;if(l){let u=await Qd(s.peerCertificate,e);if(!u.valid){It.warn("Certificate verification failed:",u.status,"for node",l.name,"certificate serial number",s.peerCertificate.serialNumber);return}if(l?.revoked_certificates?.includes(s.peerCertificate.serialNumber)){It.warn("Revoked certificate used in attempt to connect to node",l.name,"certificate serial number",s.peerCertificate.serialNumber);return}else s.user=l}else It.warn(`No node found for certificate common name/SANs: ${c}, available nodes are ${Array.from(a.getRange({}).filter(({value:u})=>u).map(({key:u})=>u)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let c=a.get(s.ip)||t.get(s.ip);c?s.user=c:It.warn(`No node found for IP address ${s.ip}, available nodes are ${Array.from(new Set([...a.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return i(s)},e);let n=[];for(let s of r)if(s.secureContexts){let i=o(()=>{let a=new Set(s.secureContexts.values());s.defaultContext&&a.add(s.defaultContext);for(let c of a)try{let l=Array.from(Zo);c.options.availableCAs&&l.push(...c.options.availableCAs.values());let u={...c.options,ca:l};c.updatedContext=PT.createSecureContext(u)}catch(l){It.error("Error creating replication TLS config",l)}},"updateContexts");s.secureContextsListeners.push(i),n.push(i),$s.default.get(F.REPLICATION_ENABLEROOTCAS)!==!1&&i()}$1(()=>{for(let s of n)s()})}function $1(e){let t=0;qd(r=>{r?.ca&&(Zo.add(r.ca),Zo.size!==t&&(t=Zo.size,e?.()))})}function Kde(e=!0){q1=e}function Yde(e){q1||(at(),lc=e.databases,sc(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||uc;for(let[s,i]of OT){let a=i.get(r);a&&(a.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];K1(r,s,e),JC.get(s)?.forEach(i=>i(s))}}))}function K1(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 V1 extends Hr{static{o(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||uc,a=i.get(e),c=a?.tableById||[];c[t.tableId]=t;let l=a?.ready;if(It.trace("Setting up replicator subscription to database",e),!a?.auditStore)return this.subscription=a=new Jn,i.set(e,a),a.tableById=c,a.auditStore=t.auditStore,a.dbisDB=t.dbisDB,a.databaseName=e,l&&l(a),a;this.subscription=a}static subscribeOnThisThread(i,a){return!0}static async load(i){if(i){let a=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),a]);if(c){let l,u=new Set;do{let d,f="",m=1/0;for(let h of c){if(u.has(h)||h===ve.hostname)continue;let E=zde(h,V1.subscription,e);if(E?.isConnected){let g=Gd(t.auditStore,e,h)[RT];(!d||g<m)&&(d=E,f=h,m=g)}}if(!d)throw l||new k1.ServerError(`No connection to any other nodes are available: ${c}`,502);let p={requestId:qde++,table:t,entry:i,id:i.key};u.add(f);try{return await d.getRecord(p)}catch(h){if(d.isConnected)throw h;It.warn("Error in load from node",ql,h),l||(l=h)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function Wde(e,t,r,n,s){let i=OT.get(e);i||OT.set(e,i=new Map);let a=i.get(r);if(a)return a;if(t)return i.set(r,a=new jd(e,t,r,n,s)),a.connect(),a.once("finished",()=>i.delete(r)),a}function zde(e,t,r){let n=U1.get(ql);n||(n=new Map,U1.set(ql,n));let s=n.get(r);if(s)return s;let i=jt().primaryStore.get(e);return i?.url&&(s=new jd(i.url,t,r,ql,i.authorization),n.set(r,s),s.connect(),s.once("finished",()=>n.delete(r))),s}async function Th(e,t,r){r||(r={}),r.serverName=e.name;let n=await bT(e.url,r),s=_h(n,{},{});return new Promise((i,a)=>{n.on("open",()=>{It.debug("Sending operation connection to "+e.url+" opened",t),i(s.sendOperation(t))}),n.on("error",c=>{a(c)}),n.on("close",c=>{It.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function fh(e){try{H1.isMainThread&&It.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=uc.get(e.database);if(!t){let n;t=new Promise(s=>{It.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,uc.set(e.database,t)}let r=Wde(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>lh(n,e.database)),e.replicateByDefault)}catch(t){It.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function uT({name:e,url:t,database:r}){It.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(jt().primaryStore.getRange({})));let n=OT.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function jde(){if(tO!==void 0)return tO;let e=$s.default.get(F.OPERATIONSAPI_TLS_CERTIFICATE)||$s.default.get(F.TLS_CERTIFICATE);if(e)return tO=new B1.X509Certificate((0,F1.readFileSync)(e)).subject?.match(/CN=(.*)/)?.[1]??null}function it(){return ql||(ql=$s.default.get("replication_hostname")??gi($s.default.get("replication_url"))??jde()??x1("operationsapi_network_secureport")??x1("operationsapi_network_port")??"127.0.0.1")}function Qde(){ql=void 0}function x1(e){let t=$s.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function CT(e){let t=$s.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function AT(e){return ah(e)?.[it()]}function ic(){let e=$s.default.get("replication_url");return e||LT(it())}function LT(e){let t=CT("replication_port");if(t)return`ws://${e}:${t}`;if(t=CT("replication_secureport"),t)return`wss://${e}:${t}`;if(t=CT("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=CT("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function gi(e){if(e)return new URL(e).hostname}function sc(e,t){for(let n of Object.getOwnPropertyNames(De))r(n);return Bp(n=>{r(n)}),Ol((n,s)=>{r(n.databaseName)});function r(n){let s=De[n];It.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):Jde(n)&&t(s,n,!1)}o(r,"forDatabase")}function Jde(e){let t=De[e];for(let r in t)if(t[r].replicate)return!0}function ch(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function Xde(e){let t={message:""};if(e.replicated){e.replicated=!1,It.trace?.("Replicating operation",e.operation,"to nodes",ve.nodes.map(n=>n.name));let r=await Promise.allSettled(ve.nodes.map(n=>Th(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=ve.nodes[s]?.name,i})}return t}var $s,It,B1,F1,PT,k1,H1,G1,q1,qde,$de,Zo,lc,OT,U1,tO,ql,Es=se(()=>{we();Ha();wu();XC();Fr();$s=b(me()),It=b(Q()),B1=require("crypto");NT();F1=require("fs");mh();$d();q();CC();PT=b(require("node:tls")),k1=b(_e()),H1=require("worker_threads"),G1=b(gs()),qde=1,$de=[],Zo=$s.default.get(F.REPLICATION_ENABLEROOTCAS)!==!1?new Set(PT.rootCertificates):new Set;o(Vde,"start");o($1,"monitorNodeCAs");o(Kde,"disableReplication");o(Yde,"assignReplicationSource");o(K1,"setReplicator");OT=new Map;o(Wde,"getSubscriptionConnection");U1=new Map;o(zde,"getRetrievalConnectionByName");o(Th,"sendOperationToNode");o(fh,"subscribeToNode");o(uT,"unsubscribeFromNode");o(jde,"getCommonNameFromCert");o(it,"getThisNodeName");o(Qde,"clearThisNodeName");Object.defineProperty(ve,"hostname",{get(){return it()}});o(x1,"getHostFromListeningPort");o(CT,"getPortFromListeningPort");o(AT,"getThisNodeId");ve.replication={getThisNodeId:AT,exportIdMapping:ah};o(ic,"getThisNodeUrl");o(LT,"hostnameToUrl");o(gi,"urlToNodeName");o(sc,"forEachReplicatedDatabase");o(Jde,"hasExplicitlyReplicatedTable");o(ch,"lastTimeInAuditStore");o(Xde,"replicateOperation")});var xT=v((Rxe,Q1)=>{"use strict";var Jd=K$(),{validateBySchema:yh}=mt(),{commonValidators:Xd,schemaRegex:rO}=Vi(),_r=require("joi"),Zde=Q(),efe=require("uuid").v4,vT=Ho(),Zd=(q(),M(z)),tfe=require("util"),dc=as(),{handleHDBError:ta,hdbErrors:rfe,ClientError:$l}=_e(),{HDB_ERROR_MSGS:DT,HTTP_STATUS_CODES:ra}=rfe,{SchemaEventMsg:UT}=ss(),Y1=hr(),{getDatabases:nfe}=(we(),M(ft)),{transformReq:ef}=ae(),{replicateOperation:W1}=(Es(),M(Xo)),{cleanupOrphans:sfe}=(Zn(),M(w_)),MT=_r.string().min(1).max(Xd.schema_length.maximum).pattern(rO).messages({"string.pattern.base":"{:#label} "+Xd.schema_format.message}),ife=_r.string().min(1).max(Xd.schema_length.maximum).pattern(rO).messages({"string.pattern.base":"{:#label} "+Xd.schema_format.message}).required(),ofe=_r.string().min(1).max(Xd.schema_length.maximum).pattern(rO).messages({"string.pattern.base":"{:#label} "+Xd.schema_format.message,"any.required":"'primary_key' is required","string.base":"'primary_key' must be a string"}).required();Q1.exports={createSchema:afe,createSchemaStructure:z1,createTable:cfe,createTableStructure:j1,createAttribute:mfe,dropSchema:lfe,dropTable:ufe,dropAttribute:dfe,getBackup:pfe,cleanupOrphanBlobs:hfe};async function afe(e){let t=await z1(e);return vT.signalSchemaChange(new UT(process.pid,e.operation,e.schema)),t}o(afe,"createSchema");async function z1(e){let t=yh(e,_r.object({database:MT,schema:MT}));if(t)throw new $l(t.message);if(ef(e),!await Jd.checkSchemaExists(e.schema))throw ta(new Error,DT.SCHEMA_EXISTS_ERR(e.schema),ra.BAD_REQUEST,Zd.LOG_LEVELS.ERROR,DT.SCHEMA_EXISTS_ERR(e.schema),!0);return await dc.createSchema(e),`database '${e.schema}' successfully created`}o(z1,"createSchemaStructure");async function cfe(e){return ef(e),e.hash_attribute=e.primary_key??e.hash_attribute,await j1(e)}o(cfe,"createTable");async function j1(e){let t=yh(e,_r.object({database:MT,schema:MT,table:ife,residence:_r.array().items(_r.string().min(1)).optional(),hash_attribute:ofe}));if(t)throw new $l(t.message);if(!await Jd.checkSchemaTableExists(e.schema,e.table))throw ta(new Error,DT.TABLE_EXISTS_ERR(e.schema,e.table),ra.BAD_REQUEST,Zd.LOG_LEVELS.ERROR,DT.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:efe(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await dc.createTable(n,e);else throw ta(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",ra.BAD_REQUEST);else await dc.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}o(j1,"createTableStructure");async function lfe(e){let t=yh(e,_r.object({database:_r.string(),schema:_r.string()}).or("database","schema").messages({"object.missing":"'database' is required"}));if(t)throw new $l(t.message);ef(e);let r=await Jd.checkSchemaExists(e.schema);if(r)throw ta(new Error,r,ra.NOT_FOUND,Zd.LOG_LEVELS.ERROR,r,!0);let n=await Jd.schemaDescribe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await dc.dropSchema(e),vT.signalSchemaChange(new UT(process.pid,e.operation,e.schema)),await Y1.purgeSchemaTableStreams(e.schema,s);let i=await W1(e);return i.message=`successfully deleted '${e.schema}'`,i}o(lfe,"dropSchema");async function ufe(e){let t=yh(e,_r.object({database:_r.string(),schema:_r.string(),table:_r.string().required()}));if(t)throw new $l(t.message);ef(e);let r=await Jd.checkSchemaTableExists(e.schema,e.table);if(r)throw ta(new Error,r,ra.NOT_FOUND,Zd.LOG_LEVELS.ERROR,r,!0);await dc.dropTable(e),await Y1.purgeTableStream(e.schema,e.table);let n=await W1(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}o(ufe,"dropTable");async function dfe(e){let t=yh(e,_r.object({database:_r.string(),schema:_r.string(),table:_r.string().required(),attribute:_r.string().required()}));if(t)throw new $l(t.message);ef(e);let r=await Jd.checkSchemaTableExists(e.schema,e.table);if(r)throw ta(new Error,r,ra.NOT_FOUND,Zd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw ta(new Error,"You cannot drop a hash attribute",ra.BAD_REQUEST,void 0,void 0,!0);if(Zd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw ta(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,ra.BAD_REQUEST,void 0,void 0,!0);try{return await dc.dropAttribute(e),ffe(e),vT.signalSchemaChange(new UT(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Zde.error(`Got an error deleting attribute ${tfe.inspect(e)}.`),n}}o(dfe,"dropAttribute");function ffe(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)}o(ffe,"dropAttributeFromGlobal");async function mfe(e){ef(e);let t=nfe()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw ta(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,ra.BAD_REQUEST,void 0,void 0,!0);return await dc.createAttribute(e),vT.signalSchemaChange(new UT(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}o(mfe,"createAttribute");function pfe(e){return dc.getBackup(e)}o(pfe,"getBackup");function hfe(e){if(!e.database)throw new $l('Must provide "database" name for search for orphaned blobs');if(!databases[e.database])throw new $l(`Unknown database '${e.database}'`);return sfe(databases[e.database]),{message:"Orphaned blobs cleanup started, check logs for progress"}}o(hfe,"cleanupOrphanBlobs")});var X1=v((Axe,J1)=>{"use strict";var{OPERATIONS_ENUM:Efe}=(q(),M(z)),nO=class{static{o(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Efe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};J1.exports=nO});var sO=v((Nxe,nK)=>{"use strict";var _fe=as(),wxe=X1(),BT=ae(),FT=(q(),M(z)),gfe=me(),{handleHDBError:Z1,hdbErrors:Sfe}=_e(),{HDB_ERROR_MSGS:eK,HTTP_STATUS_CODES:tK}=Sfe,Tfe=Object.values(FT.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),rK="To use this operation audit log must be enabled in harperdb-config.yaml";nK.exports=yfe;async function yfe(e){if(BT.isEmpty(e.schema))throw new Error(eK.SCHEMA_REQUIRED_ERR);if(BT.isEmpty(e.table))throw new Error(eK.TABLE_REQUIRED_ERR);if(!gfe.get(FT.CONFIG_PARAMS.LOGGING_AUDITLOG))throw Z1(new Error,rK,tK.BAD_REQUEST,FT.LOG_LEVELS.ERROR,rK,!0);let t=BT.checkSchemaTableExist(e.schema,e.table);if(t)throw Z1(new Error,t,tK.NOT_FOUND,FT.LOG_LEVELS.ERROR,t,!0);if(!BT.isEmpty(e.search_type)&&Tfe.indexOf(e.search_type)<0)throw new Error(`Invalid searchType '${read_audit_log_object.search_type}'`);return await _fe.readAuditLog(e)}o(yfe,"readAuditLog")});var iK=v((Oxe,sK)=>{"use strict";var{OPERATIONS_ENUM:Rfe}=(q(),M(z)),iO=class{static{o(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Rfe.GET_BACKUP,this.schema=t,this.table=r}};sK.exports=iO});var cK=v((Mxe,aK)=>{"use strict";var bfe=as(),Lxe=iK(),oO=ae(),Afe=(q(),M(z)),Dxe=me(),{handleHDBError:Ife,hdbErrors:wfe}=_e(),{HDB_ERROR_MSGS:oK,HTTP_STATUS_CODES:Nfe}=wfe;aK.exports=Cfe;async function Cfe(e){if(oO.isEmpty(e.schema))throw new Error(oK.SCHEMA_REQUIRED_ERR);if(oO.isEmpty(e.table))throw new Error(oK.TABLE_REQUIRED_ERR);let t=oO.checkSchemaTableExist(e.schema,e.table);if(t)throw Ife(new Error,t,Nfe.NOT_FOUND,Afe.LOG_LEVELS.ERROR,t,!0);return await bfe.getBackup(readAuditLogObject)}o(Cfe,"getBackup")});var fK=v((Uxe,dK)=>{"use strict";var Ofe=me(),fc=require("joi"),Pfe=mt(),lK=require("moment"),Lfe=require("fs-extra"),aO=require("path"),Dfe=require("lodash"),Rh=(q(),M(z)),{LOG_LEVELS:Vl}=(q(),M(z)),Mfe="YYYY-MM-DD hh:mm:ss",vfe=aO.resolve(__dirname,"../logs");dK.exports=function(e){return Pfe.validateBySchema(e,Ufe)};var Ufe=fc.object({from:fc.custom(uK),until:fc.custom(uK),level:fc.valid(Vl.NOTIFY,Vl.FATAL,Vl.ERROR,Vl.WARN,Vl.INFO,Vl.DEBUG,Vl.TRACE),order:fc.valid("asc","desc"),limit:fc.number().min(1),start:fc.number().min(0),log_name:fc.custom(xfe)});function uK(e,t){if(lK(e,lK.ISO_8601).format(Mfe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}o(uK,"validateDatetime");function xfe(e,t){if(Dfe.invert(Rh.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Ofe.get(Rh.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Rh.LOG_NAMES.HDB:e,i=s===Rh.LOG_NAMES.INSTALL?aO.join(vfe,Rh.LOG_NAMES.INSTALL):aO.join(n,s);return Lfe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}o(xfe,"validateReadLogPath")});var lO=v((Bxe,pK)=>{"use strict";var kT=(q(),M(z)),Bfe=Q(),Ffe=me(),kfe=fK(),cO=require("path"),mK=require("fs-extra"),{once:Hfe}=require("events"),{handleHDBError:Gfe,hdbErrors:qfe}=_e(),{PACKAGE_ROOT:$fe}=Ct(),{replicateOperation:Vfe}=(Es(),M(Xo)),Kfe=cO.join($fe,"logs"),Yfe=1e3,Wfe=200;pK.exports=zfe;async function zfe(e){let t=kfe(e);if(t)throw Gfe(t,t.message,qfe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Vfe(e),n=Ffe.get(kT.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e.log_name===void 0?kT.LOG_NAMES.HDB:e.log_name,i=s===kT.LOG_NAMES.INSTALL?cO.join(Kfe,kT.LOG_NAMES.INSTALL):cO.join(n,s),a=e.level!==void 0,c=a?e.level:void 0,l=e.from!==void 0,u=l?new Date(e.from):void 0,d=e.until!==void 0,f=d?new Date(e.until):void 0,m=e.limit===void 0?Yfe:e.limit,p=e.order===void 0?void 0:e.order,h=e.start===void 0?0:e.start,E=h+m,g=0;p==="desc"&&!u&&!f&&(g=Math.max(mK.statSync(i).size-(E+5)*Wfe,0));let R=mK.createReadStream(i,{start:g});R.on("error",G=>{Bfe.error(G)});let S=0,y=[],C="",I;R.on("data",G=>{let H=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;G=C+G;let X=0,W;for(;(W=H.exec(G))&&!R.destroyed;){I&&(I.message=G.slice(X,W.index),k(I));let[ue,ce,te]=W,ye=te.split("] ["),Ae=ye[0],Ye=ye[1];ye.splice(0,2),I={timestamp:ce,thread:Ae,level:Ye,tags:ye,message:""},X=W.index+ue.length}C=G.slice(X)}),R.on("end",G=>{R.destroyed||I&&(I.message=C.trim(),k(I))}),R.resume();function k(G){let H,X,W;switch(!0){case(a&&l&&d):H=new Date(G.timestamp),X=new Date(u),W=new Date(f),G.level===c&&H>=X&&H<=W&&S<h?S++:G.level===c&&H>=X&&H<=W&&(uo(G,p,y),S++,S===E&&R.destroy());break;case(a&&l):H=new Date(G.timestamp),X=new Date(u),G.level===c&&H>=X&&S<h?S++:G.level===c&&H>=X&&(uo(G,p,y),S++,S===E&&R.destroy());break;case(a&&d):H=new Date(G.timestamp),W=new Date(f),G.level===c&&H<=W&&S<h?S++:G.level===c&&H<=W&&(uo(G,p,y),S++,S===E&&R.destroy());break;case(l&&d):H=new Date(G.timestamp),X=new Date(u),W=new Date(f),H>=X&&H<=W&&S<h?S++:H>=X&&H<=W&&(uo(G,p,y),S++,S===E&&R.destroy());break;case a:G.level===c&&S<h?S++:G.level===c&&(uo(G,p,y),S++,S===E&&R.destroy());break;case l:H=new Date(G.timestamp),X=new Date(u),H>=X&&S<h?S++:H>=X&&S>=h&&(uo(G,p,y),S++,S===E&&R.destroy());break;case d:H=new Date(G.timestamp),W=new Date(f),H<=W&&S<h?S++:H<=W&&S>=h&&(uo(G,p,y),S++,S===E&&R.destroy());break;default:S<h?S++:(uo(G,p,y),S++,S===E&&R.destroy())}}o(k,"onLogMessage"),await Hfe(R,"close");let J=await r;if(J.replicated){for(let G of y)G.node=server.hostname;for(let G of J.replicated){let H=G.node;if(G.status==="failed")uo({timestamp:new Date().toISOString(),level:"error",node:H,message:`Error retrieving logs: ${G.reason}`},p,y);else for(let X of G.results)X.node=H,uo(X,p,y)}}return y}o(zfe,"readLog");function uo(e,t,r){t==="desc"?jfe(e,r):t==="asc"?Qfe(e,r):r.push(e)}o(uo,"pushLineToResult");function jfe(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)}o(jfe,"insertDescending");function Qfe(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)}o(Qfe,"insertAscending")});var HT=v(($xe,gK)=>{"use strict";var uO=require("joi"),{string:tf,boolean:hK,date:Jfe}=uO.types(),Xfe=mt(),{validateSchemaExists:kxe,validateTableExists:Hxe,validateSchemaName:Gxe}=Vi(),Zfe=(q(),M(z)),eme=Ot(),EK=me();EK.initSync();var qxe=tf.invalid(EK.get(Zfe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(eme.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),_K={operation:tf.valid("add_node","update_node","set_node_replication"),node_name:tf.optional(),subscriptions:uO.array().items({table:tf.optional(),schema:tf.optional(),database:tf.optional(),subscribe:hK.required(),publish:hK.required().custom(rme),start_time:Jfe.iso()})};function tme(e){return Xfe.validateBySchema(e,uO.object(_K))}o(tme,"addUpdateNodeValidator");function rme(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`)}o(rme,"checkForFalsy");gK.exports={addUpdateNodeValidator:tme,validationSchema:_K}});var rf=v((Kxe,SK)=>{"use strict";var dO=class{static{o(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},fO=class{static{o(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};SK.exports={Node:dO,NodeSubscription:fO}});var yK=v((Wxe,TK)=>{"use strict";var nme=(q(),M(z)).OPERATIONS_ENUM,mO=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=nme.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};TK.exports=mO});var bh=v((jxe,RK)=>{"use strict";var pO=class{static{o(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},hO=class{static{o(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,a,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=a,c!==void 0&&(this.attributes=c)}};RK.exports={RemotePayloadObject:pO,RemotePayloadSubscription:hO}});var AK=v((Jxe,bK)=>{"use strict";var EO=class{static{o(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,a=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=a}};bK.exports=EO});var wK=v((n0e,IK)=>{"use strict";var sme=AK(),Zxe=Yt(),e0e=_t(),ime=Q(),{getSchemaPath:t0e,getTransactionAuditStorePath:r0e}=Rt(),{getDatabases:ome}=(we(),M(ft));IK.exports=ame;async function ame(e){let t=new sme;try{let r=ome()[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){ime.warn(`unable to stat table dbi due to ${r}`)}return t}o(ame,"lmdbGetTableSize")});var CK=v((i0e,NK)=>{"use strict";var _O=class{static{o(this,"SystemInformationObject")}constructor(t,r,n,s,i,a,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=a,this.harperdb_processes=c}};NK.exports=_O});var Ih=v((d0e,DK)=>{"use strict";var cme=require("fs-extra"),lme=require("path"),bn=require("systeminformation"),mc=Q(),OK=hr(),a0e=Ot(),nf=(q(),M(z)),ume=wK(),dme=Dl(),{getThreadInfo:PK}=nt(),Ah=me();Ah.initSync();var fme=CK(),{openEnvironment:c0e}=_t(),{getSchemaPath:l0e}=Rt(),{database:u0e,databases:gO}=(we(),M(ft)),GT;DK.exports={getHDBProcessInfo:RO,getNetworkInfo:AO,getDiskInfo:bO,getMemoryInfo:yO,getCPUInfo:TO,getTimeInfo:SO,getSystemInformation:IO,systemInformation:mme,getTableSize:wO,getMetrics:NO};function SO(){return bn.time()}o(SO,"getTimeInfo");async function TO(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:a,governor:c,socket:l,cache:u,...d}=await bn.cpu();d.cpu_speed=await bn.cpuCurrentSpeed();let{rawCurrentload:f,rawCurrentloadIdle:m,rawCurrentloadIrq:p,rawCurrentloadNice:h,rawCurrentloadSystem:E,rawCurrentloadUser:g,cpus:R,...S}=await bn.currentLoad();return S.cpus=[],R.forEach(y=>{let{rawLoad:C,rawLoadIdle:I,rawLoadIrq:k,rawLoadNice:J,rawLoadSystem:G,rawLoadUser:H,...X}=y;S.cpus.push(X)}),d.current_load=S,d}catch(e){return mc.error(`error in getCPUInfo: ${e}`),{}}}o(TO,"getCPUInfo");async function yO(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await bn.mem();return Object.assign(s,process.memoryUsage())}catch(e){return mc.error(`error in getMemoryInfo: ${e}`),{}}}o(yO,"getMemoryInfo");async function RO(){let e={core:[],clustering:[]};try{let t=await bn.processes(),r;try{r=Number.parseInt(await cme.readFile(lme.join(Ah.get(nf.CONFIG_PARAMS.ROOTPATH),nf.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===nf.NODE_ERROR_CODES.ENOENT)mc.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 mc.error(`error in getHDBProcessInfo: ${t}`),e}}o(RO,"getHDBProcessInfo");async function bO(){let e={};try{if(!Ah.get(nf.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await bn.disksIO();e.io=i;let{rxSec:a,txSec:c,wxSec:l,...u}=await bn.fsStats();return e.read_write=u,e.size=await bn.fsSize(),e}catch(t){return mc.error(`error in getDiskInfo: ${t}`),e}}o(bO,"getDiskInfo");async function AO(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Ah.get(nf.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await bn.networkInterfaceDefault(),e.latency=await bn.inetChecksite("google.com"),(await bn.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:a,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:d,carrierChanges:f,...m}=n;e.interfaces.push(m)}),(await bn.networkStats()).forEach(n=>{let{rxSec:s,txSec:i,ms:a,...c}=n;e.stats.push(c)})),e}catch(t){return mc.error(`error in getNetworkInfo: ${t}`),e}}o(AO,"getNetworkInfo");async function IO(){if(GT!==void 0)return GT;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:a,...c}=await bn.osInfo();e=c;let l=await bn.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,GT=e,GT}catch(t){return mc.error(`error in getSystemInformation: ${t}`),e}}o(IO,"getSystemInformation");async function wO(){let e=[],t=await dme.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await ume(n));return e}o(wO,"getTableSize");async function NO(){let e={};for(let t in gO){let r=e[t]={},n=r.tables={};for(let s in gO[t])try{let i=gO[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,d,f]=l.trim().split(" ");return{pid:u,thread:d,txnid:f}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:f,overflowPages:m}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:f,overflowPages:m}}let a=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=a[l];n[s]=c}catch(i){mc.notify(`Error getting stats for table ${s}: ${i}`)}}return e}o(NO,"getMetrics");async function LK(){if(Ah.get(nf.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await OK.getNATSReferences(),t=await OK.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 a={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(a)}return r}}o(LK,"getNatsStreamInfo");async function mme(e){let t=new fme;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await IO(),t.time=SO(),t.cpu=await TO(),t.memory=await yO(),t.disk=await bO(),t.network=await AO(),t.harperdb_processes=await RO(),t.table_size=await wO(),t.metrics=await NO(),t.threads=await PK(),t.replication=await LK(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await IO();break;case"time":t.time=SO();break;case"cpu":t.cpu=await TO();break;case"memory":t.memory=await yO();break;case"disk":t.disk=await bO();break;case"network":t.network=await AO();break;case"harperdb_processes":t.harperdb_processes=await RO();break;case"table_size":t.table_size=await wO();break;case"database_metrics":case"metrics":t.metrics=await NO();break;case"threads":t.threads=await PK();break;case"replication":t.replication=await LK();break;default:break}return t}o(mme,"systemInformation")});var na=v((E0e,xK)=>{"use strict";var pme=Hn(),CO=ae(),hme=require("util"),Kl=(q(),M(z)),MK=me();MK.initSync();var Eme=jN(),vK=hn(),{Node:m0e,NodeSubscription:p0e}=rf(),_me=Zu(),gme=yK(),{RemotePayloadObject:Sme,RemotePayloadSubscription:Tme}=bh(),{handleHDBError:yme,hdbErrors:Rme}=_e(),{HTTP_STATUS_CODES:bme,HDB_ERROR_MSGS:Ame}=Rme,Ime=ui(),wme=Ih(),{packageJson:Nme}=Ct(),{getDatabases:Cme}=(we(),M(ft)),h0e=hme.promisify(Eme.authorize),Ome=vK.searchByHash,Pme=vK.searchByValue;xK.exports={isEmpty:Lme,getNodeRecord:Dme,upsertNodeRecord:Mme,buildNodePayloads:vme,checkClusteringEnabled:Ume,getAllNodeRecords:xme,getSystemInfo:Bme,reverseSubscription:UK};function Lme(e){return e==null}o(Lme,"isEmpty");async function Dme(e){let t=new _me(Kl.SYSTEM_SCHEMA_NAME,Kl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Ome(t)}o(Dme,"getNodeRecord");async function Mme(e){let t=new gme(Kl.SYSTEM_SCHEMA_NAME,Kl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return pme.upsert(t)}o(Mme,"upsertNodeRecord");function UK(e){if(CO.isEmpty(e.subscribe)||CO.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}o(UK,"reverseSubscription");function vme(e,t,r,n){let s=[];for(let i=0,a=e.length;i<a;i++){let c=e[i],{schema:l,table:u}=c,d=CO.getTableHashAttribute(l,u),{subscribe:f,publish:m}=UK(c),p=Cme()[l]?.[u],h=new Tme(l,u,d,m,f,c.start_time,p.schemaDefined?p.attributes:void 0);s.push(h)}return new Sme(r,t,s,n)}o(vme,"buildNodePayloads");function Ume(){if(!MK.get(Kl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw yme(new Error,Ame.CLUSTERING_NOT_ENABLED,bme.BAD_REQUEST,void 0,void 0,!0)}o(Ume,"checkClusteringEnabled");async function xme(){let e=new Ime(Kl.SYSTEM_SCHEMA_NAME,Kl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Pme(e))}o(xme,"getAllNodeRecords");async function Bme(){let e=await wme.getSystemInformation();return{hdb_version:Nme.version,node_version:e.node_version,platform:e.platform}}o(Bme,"getSystemInfo")});var OO=v((g0e,VK)=>{"use strict";var qT=hr(),BK=ae(),FK=Ot(),kK=(q(),M(z)),$T=Q(),HK=xT(),Fme=np(),{RemotePayloadObject:kme}=bh(),{handleHDBError:GK,hdbErrors:Hme}=_e(),{HTTP_STATUS_CODES:qK}=Hme,{NodeSubscription:$K}=rf();VK.exports=Gme;async function Gme(e,t){let r;try{r=await qT.request(`${t}.${FK.REQUEST_SUFFIX}`,new kme(kK.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),$T.trace("Response from remote describe all request:",r)}catch(a){$T.error(`addNode received error from describe all request to remote node: ${a}`);let c=qT.requestErrorHandler(a,"add_node",t);throw GK(new Error,c,qK.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===FK.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let a=`Error returned from remote node ${t}: ${r.message}`;throw GK(new Error,a,qK.INTERNAL_SERVER_ERROR,"error",a)}let n=r.message,s=[],i=[];for(let a of e){let{table:c}=a,l=a.database??a.schema??"data";if(l===kK.SYSTEM_SCHEMA_NAME){await qT.createLocalTableStream(l,c);let h=new $K(l,c,a.publish,a.subscribe);h.start_time=a.start_time,i.push(h);continue}let u=BK.doesSchemaExist(l),d=n[l]!==void 0,f=c?BK.doesTableExist(l,c):!0,m=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!d||!f&&!m){s.push(a);continue}if(!u&&d&&($T.trace(`addNode creating schema: ${l}`),await HK.createSchema({operation:"create_schema",schema:l})),!f&&m){$T.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Fme(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await HK.createTable(h)}await qT.createLocalTableStream(l,c);let p=new $K(l,c,a.publish,a.subscribe);p.start_time=a.start_time,i.push(p)}return{added:i,skipped:s}}o(Gme,"reviewSubscriptions")});var sf={};Re(sf,{addNodeBack:()=>PO,removeNodeBack:()=>LO,setNode:()=>Kme});async function Kme(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=gi(t)):t=LT(r);let n=(0,YK.validateBySchema)(e,Vme);if(n)throw(0,sa.handleHDBError)(n,n.message,$me.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new sa.ClientError("url or hostname is required for remove_node operation");let p=r,h=jt(),E=await h.get(p);if(!E)throw new sa.ClientError(p+" does not exist");try{await Th({url:E.url},{operation:V.REMOVE_NODE_BACK,name:E?.subscriptions?.length>0?it():p},void 0)}catch(g){Ss.warn(`Error removing node from target node ${p}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await h.delete(p),`Successfully removed '${p}' from cluster`}if(!t)throw new sa.ClientError("url required for this operation");let s=ic();if(s==null)throw new sa.ClientError("replication url is missing from harperdb-config.yaml");let i,a,c;if(t?.startsWith("wss:")){i=await(0,Vs.getReplicationCert)();let p=await(0,Vs.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(a=await(0,Vs.createCsr)(),Ss.info("Sending CSR to target node:",t)):p&&(c=p.certificate,Ss.info("Sending CA named",p.name,"to target node",t))}let l={operation:V.ADD_NODE_BACK,hostname:(0,hc.get)(F.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:a,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if((0,hc.get)(F.REPLICATION_SHARD)!==void 0&&(l.shard=(0,hc.get)(F.REPLICATION_SHARD)),e.subscriptions?l.subscriptions=e.subscriptions.map(KK):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let p=KK(e);l.subscribe=p.subscribe,l.publish=p.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,d;try{u=await Th({url:t},l,e)}catch(p){p.message=`Error returned from ${t}: `+p.message,Ss.warn("Error adding node:",t,"to cluster:",p),d=p}if(a&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw d?(d.message+=" and connection was required to sign certificate",d):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);a&&(Ss.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Vs.setCertTable)({name:qme.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Vs.setCertTable)({name:it(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let f={url:t,ca:u?.usingCA};if(e.hostname&&(f.name=e.hostname),e.subscriptions?f.subscriptions=e.subscriptions:f.replicates=!0,e.start_time&&(f.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(f.authorization=e.authorization),e.revoked_certificates&&(f.revoked_certificates=e.revoked_certificates),u?.shard!==void 0?f.shard=u.shard:e.shard!==void 0&&(f.shard=e.shard),f.replicates){let p={url:s,ca:c,replicates:!0,subscriptions:null};(0,hc.get)(F.REPLICATION_SHARD)!==void 0&&(p.shard=(0,hc.get)(F.REPLICATION_SHARD)),e.retain_authorization&&(p.authorization=e.authorization),e.start_time&&(p.start_time=e.start_time),await Qo(it(),p)}await Qo(u?u.nodeName:f.name??gi(t),f);let m;return e.operation==="update_node"?m=`Successfully updated '${t}'`:m=`Successfully added '${t}' to cluster`,d&&(m+=" but there was an error updating target node: "+d.message),m}async function PO(e){Ss.trace("addNodeBack received request:",e);let t=await(0,Vs.signCertificate)(e),r;e.csr?(r=t.signingCA,Ss.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,Ss.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization),e.shard!==void 0&&(n.shard=e.shard);let s=await(0,Vs.getReplicationCertAuth)();if(n.replicates){let i={url:ic(),ca:s?.certificate,replicates:!0,subscriptions:null};(0,hc.get)(F.REPLICATION_SHARD)!==void 0&&(i.shard=(0,hc.get)(F.REPLICATION_SHARD),t.shard=i.shard),e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Qo(it(),i)}return await Qo(e.hostname,n),t.nodeName=it(),t.usingCA=s?.certificate,Ss.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function LO(e){Ss.trace("removeNodeBack received request:",e),await jt().delete(e.name)}function KK(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Vs,YK,pc,hc,Ss,sa,qme,$me,Vme,of=se(()=>{Vs=b(gs()),YK=b(mt()),pc=b(require("joi")),hc=b(me());q();mh();$d();Es();Ss=b(Q()),sa=b(_e()),{pki:qme}=require("node-forge"),{HTTP_STATUS_CODES:$me}=sa.hdbErrors,Vme=pc.default.object({hostname:pc.default.string(),verify_tls:pc.default.boolean(),replicates:pc.default.boolean(),subscriptions:pc.default.array(),revoked_certificates:pc.default.array(),shard:pc.default.number()});o(Kme,"setNode");o(PO,"addNodeBack");o(LO,"removeNodeBack");o(KK,"reverseSubscription")});var zT=v((N0e,zK)=>{"use strict";var{handleHDBError:VT,hdbErrors:Yme}=_e(),{HTTP_STATUS_CODES:KT}=Yme,{addUpdateNodeValidator:Wme}=HT(),YT=Q(),WT=(q(),M(z)),WK=Ot(),zme=ae(),wh=hr(),Nh=na(),DO=me(),jme=OO(),{Node:Qme,NodeSubscription:Jme}=rf(),{broadcast:Xme}=nt(),{setNode:Zme}=(of(),M(sf)),I0e=me(),w0e=(q(),M(z)),epe="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",tpe="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",rpe=DO.get(WT.CONFIG_PARAMS.CLUSTERING_NODENAME);zK.exports=npe;async function npe(e,t=!1){if(YT.trace("addNode called with:",e),DO.get(WT.CONFIG_PARAMS.REPLICATION_URL)||DO.get(WT.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Zme(e);Nh.checkClusteringEnabled();let r=Wme(e);if(r)throw VT(r,r.message,KT.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let f=await Nh.getNodeRecord(n);if(!zme.isEmptyOrZeroLength(f))throw VT(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,KT.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await jme(e.subscriptions,n),a={message:void 0,added:s,skipped:i};if(s.length===0)return a.message=epe,a;let c=Nh.buildNodePayloads(s,rpe,WT.OPERATIONS_ENUM.ADD_NODE,await Nh.getSystemInfo()),l=[];for(let f=0,m=s.length;f<m;f++){let p=s[f];s[f].start_time===void 0&&delete s[f].start_time,l.push(new Jme(p.schema,p.table,p.publish,p.subscribe))}YT.trace("addNode sending remote payload:",c);let u;try{u=await wh.request(`${n}.${WK.REQUEST_SUFFIX}`,c)}catch(f){YT.error(`addNode received error from request: ${f}`);for(let p=0,h=s.length;p<h;p++){let E=s[p];E.publish=!1,E.subscribe=!1,await wh.updateRemoteConsumer(E,n)}let m=wh.requestErrorHandler(f,"add_node",n);throw VT(new Error,m,KT.INTERNAL_SERVER_ERROR,"error",m)}if(u.status===WK.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${n}: ${u.message}`;throw VT(new Error,f,KT.INTERNAL_SERVER_ERROR,"error",f)}YT.trace(u);for(let f=0,m=s.length;f<m;f++){let p=s[f];await wh.updateRemoteConsumer(p,n),p.subscribe===!0&&await wh.updateConsumerIterator(p.schema,p.table,n,"start")}let d=new Qme(n,l,u.system_info);return await Nh.upsertNodeRecord(d),Xme({type:"nats_update"}),i.length>0?a.message=tpe:a.message=`Successfully added '${n}' to manifest`,a}o(npe,"addNode")});var xO=v((P0e,QK)=>{"use strict";var{handleHDBError:MO,hdbErrors:spe}=_e(),{HTTP_STATUS_CODES:vO}=spe,{addUpdateNodeValidator:ipe}=HT(),Ch=Q(),jT=(q(),M(z)),jK=Ot(),O0e=ae(),Oh=hr(),Ph=na(),UO=me(),{cloneDeep:ope}=require("lodash"),ape=OO(),{Node:cpe,NodeSubscription:lpe}=rf(),{broadcast:upe}=nt(),{setNode:dpe}=(of(),M(sf)),fpe="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",mpe="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",ppe=UO.get(jT.CONFIG_PARAMS.CLUSTERING_NODENAME);QK.exports=hpe;async function hpe(e){if(Ch.trace("updateNode called with:",e),UO.get(jT.CONFIG_PARAMS.REPLICATION_URL)??UO.get(jT.CONFIG_PARAMS.REPLICATION_HOSTNAME))return dpe(e);Ph.checkClusteringEnabled();let t=ipe(e);if(t)throw MO(t,t.message,vO.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Ph.getNodeRecord(r);s.length>0&&(n=ope(s));let{added:i,skipped:a}=await ape(e.subscriptions,r),c={message:void 0,updated:i,skipped:a};if(i.length===0)return c.message=fpe,c;let l=Ph.buildNodePayloads(i,ppe,jT.OPERATIONS_ENUM.UPDATE_NODE,await Ph.getSystemInfo());for(let d=0,f=i.length;d<f;d++){let m=i[d];Ch.trace(`updateNode updating work stream for node: ${r} subscription:`,m),i[d].start_time===void 0&&delete i[d].start_time}Ch.trace("updateNode sending remote payload:",l);let u;try{u=await Oh.request(`${r}.${jK.REQUEST_SUFFIX}`,l)}catch(d){Ch.error(`updateNode received error from request: ${d}`);let f=Oh.requestErrorHandler(d,"update_node",r);throw MO(new Error,f,vO.INTERNAL_SERVER_ERROR,"error",f)}if(u.status===jK.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${r}: ${u.message}`;throw MO(new Error,d,vO.INTERNAL_SERVER_ERROR,"error",d)}Ch.trace(u);for(let d=0,f=i.length;d<f;d++){let m=i[d];await Oh.updateRemoteConsumer(m,r),m.subscribe===!0?await Oh.updateConsumerIterator(m.schema,m.table,r,"start"):await Oh.updateConsumerIterator(m.schema,m.table,r,"stop")}return n||(n=[new cpe(r,[],u.system_info)]),await Epe(n[0],i,u.system_info),a.length>0?c.message=mpe:c.message=`Successfully updated '${r}'`,c}o(hpe,"updateNode");async function Epe(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let a=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let d=n.subscriptions[l];if(d.schema===a.schema&&d.table===a.table){d.publish=a.publish,d.subscribe=a.subscribe,c=!0;break}}c||n.subscriptions.push(new lpe(a.schema,a.table,a.publish,a.subscribe))}n.system_info=r,await Ph.upsertNodeRecord(n),upe({type:"nats_update"})}o(Epe,"updateNodeTable")});var tY=v((D0e,eY)=>{"use strict";var ZK=require("joi"),{string:JK}=ZK.types(),_pe=mt(),XK=(q(),M(z)),gpe=me(),Spe=Ot();eY.exports=Tpe;function Tpe(e){let t=JK.invalid(gpe.get(XK.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Spe.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=ZK.object({operation:JK.valid(XK.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return _pe.validateBySchema(e,r)}o(Tpe,"removeNodeValidator")});var QT=v((v0e,oY)=>{"use strict";var{handleHDBError:rY,hdbErrors:ype}=_e(),{HTTP_STATUS_CODES:nY}=ype,Rpe=tY(),Lh=Q(),sY=na(),bpe=ae(),af=(q(),M(z)),iY=Ot(),BO=hr(),FO=me(),{RemotePayloadObject:Ape}=bh(),{NodeSubscription:Ipe}=rf(),wpe=rp(),Npe=Sl(),{broadcast:Cpe}=nt(),{setNode:Ope}=(of(),M(sf)),Ppe=FO.get(af.CONFIG_PARAMS.CLUSTERING_NODENAME);oY.exports=Lpe;async function Lpe(e){if(Lh.trace("removeNode called with:",e),FO.get(af.CONFIG_PARAMS.REPLICATION_URL)??FO.get(af.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Ope(e);sY.checkClusteringEnabled();let t=Rpe(e);if(t)throw rY(t,t.message,nY.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await sY.getNodeRecord(r);if(bpe.isEmptyOrZeroLength(n))throw rY(new Error,`Node '${r}' was not found.`,nY.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Ape(af.OPERATIONS_ENUM.REMOVE_NODE,Ppe,[]),i,a=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let d=n.subscriptions[l];d.subscribe===!0&&await BO.updateConsumerIterator(d.schema,d.table,r,"stop");try{await BO.updateRemoteConsumer(new Ipe(d.schema,d.table,!1,!1),r)}catch(f){Lh.error(f)}}try{i=await BO.request(`${r}.${iY.REQUEST_SUFFIX}`,s),Lh.trace("Remove node reply from remote node:",r,i)}catch(l){Lh.error("removeNode received error from request:",l),a=!0}let c=new wpe(af.SYSTEM_SCHEMA_NAME,af.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Npe.deleteRecord(c),Cpe({type:"nats_update"}),i?.status===iY.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||a?(Lh.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`}o(Lpe,"removeNode")});var lY=v((x0e,cY)=>{"use strict";var aY=require("joi"),{string:Dpe,array:Mpe}=aY.types(),vpe=mt(),Upe=HT();cY.exports=xpe;function xpe(e){let t=aY.object({operation:Dpe.valid("configure_cluster").required(),connections:Mpe.items(Upe.validationSchema).required()});return vpe.validateBySchema(e,t)}o(xpe,"configureClusterValidator")});var kO=v((F0e,pY)=>{"use strict";var uY=(q(),M(z)),JT=Q(),Bpe=ae(),Fpe=me(),kpe=QT(),Hpe=zT(),Gpe=na(),qpe=lY(),{handleHDBError:dY,hdbErrors:$pe}=_e(),{HTTP_STATUS_CODES:fY}=$pe,Vpe="Configure cluster complete.",Kpe="Failed to configure the cluster. Check the logs for more details.",Ype="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";pY.exports=Wpe;async function Wpe(e){JT.trace("configure cluster called with:",e);let t=qpe(e);if(t)throw dY(t,t.message,fY.BAD_REQUEST,void 0,void 0,!0);let r=await Gpe.getAllNodeRecords(),n=[];if(Fpe.get(uY.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let d=0,f=r.length;d<f;d++){let m=await mY(kpe,{operation:uY.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[d].name},r[d].name);n.push(m)}JT.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let d=0;d<i;d++){let f=e.connections[d],m=await mY(Hpe,f,f.node_name);s.push(m)}JT.trace("All results from configure_cluster add node:",s);let a=[],c=[],l=!1,u=n.concat(s);for(let d=0,f=u.length;d<f;d++){let m=u[d];m.status==="rejected"&&(JT.error(m.node_name,m?.error?.message,m?.error?.stack),a.includes(m.node_name)||a.push(m.node_name)),(m?.result?.message?.includes?.("Successfully")||m?.result?.includes?.("Successfully"))&&(l=!0),!(typeof m.result=="string"&&m.result.includes("Successfully removed")||m.status==="rejected")&&c.push({node_name:m?.node_name,response:m?.result})}if(Bpe.isEmptyOrZeroLength(a))return{message:Vpe,connections:c};if(l)return{message:Ype,failed_nodes:a,connections:c};throw dY(new Error,Kpe,fY.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}o(Wpe,"configureCluster");async function mY(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}o(mY,"functionWrapper")});var gY=v((H0e,_Y)=>{"use strict";var Dh=require("joi"),zpe=mt(),{validateSchemaExists:hY,validateTableExists:jpe,validateSchemaName:EY}=Vi(),Qpe=Dh.object({operation:Dh.string().valid("purge_stream"),schema:Dh.string().custom(hY).custom(EY).optional(),database:Dh.string().custom(hY).custom(EY).optional(),table:Dh.string().custom(jpe).required()});function Jpe(e){return zpe.validateBySchema(e,Qpe)}o(Jpe,"purgeStreamValidator");_Y.exports=Jpe});var HO=v((q0e,SY)=>{"use strict";var{handleHDBError:Xpe,hdbErrors:Zpe}=_e(),{HTTP_STATUS_CODES:ehe}=Zpe,the=gY(),rhe=hr(),nhe=na();SY.exports=she;async function she(e){e.schema=e.schema??e.database;let t=the(e);if(t)throw Xpe(t,t.message,ehe.BAD_REQUEST,void 0,void 0,!0);nhe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await rhe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}o(she,"purgeStream")});var $O=v((V0e,NY)=>{"use strict";var qO=na(),ihe=hr(),ZT=me(),cf=(q(),M(z)),Yl=Ot(),ohe=ae(),GO=Q(),{RemotePayloadObject:ahe}=bh(),{ErrorCode:TY}=require("nats"),{parentPort:yY}=require("worker_threads"),{onMessageByType:che}=nt(),{getThisNodeName:lhe}=(Es(),M(Xo)),{requestClusterStatus:uhe}=(mh(),M(vV)),{getReplicationSharedStatus:dhe,getHDBNodeTable:fhe}=($d(),M(OV)),{CONFIRMATION_STATUS_POSITION:mhe,RECEIVED_VERSION_POSITION:RY,RECEIVED_TIME_POSITION:phe,SENDING_TIME_POSITION:hhe,RECEIVING_STATUS_POSITION:Ehe,RECEIVING_STATUS_RECEIVING:_he,BACK_PRESSURE_RATIO_POSITION:ghe}=(XC(),M(w1)),bY=ZT.get(cf.CONFIG_PARAMS.CLUSTERING_ENABLED),AY=ZT.get(cf.CONFIG_PARAMS.CLUSTERING_NODENAME);NY.exports={clusterStatus:She,buildNodeStatus:wY};var IY;che("cluster-status",async e=>{IY(e)});async function She(){if(ZT.get(cf.CONFIG_PARAMS.REPLICATION_URL)||ZT.get(cf.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;yY?(yY.postMessage({type:"request-cluster-status"}),n=await new Promise(i=>{IY=i})):n=uhe();for(let i of n.connections){let a=i.name;for(let c of i.database_sockets){let l=c.database,u;for(let f of Object.values(databases[l]||{}))if(u=f.auditStore,u)break;if(!u)continue;let d=dhe(u,l,a);c.lastCommitConfirmed=XT(d[mhe]),c.lastReceivedRemoteTime=XT(d[RY]),c.lastReceivedLocalTime=XT(d[phe]),c.lastReceivedVersion=d[RY],c.sendingMessage=XT(d[hhe]),c.backPressurePercent=d[ghe]*100,c.lastReceivedStatus=d[Ehe]===_he?"Receiving":"Waiting"}}n.node_name=lhe();let s=fhe().primaryStore.get(n.node_name);return s?.shard&&(n.shard=s.shard),s?.url&&(n.url=s.url),n.is_enabled=!0,n}let e={node_name:AY,is_enabled:bY,connections:[]};if(!bY)return e;let t=await qO.getAllNodeRecords();if(ohe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(wY(t[n],e.connections));return await Promise.allSettled(r),e}o(She,"clusterStatus");function XT(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}o(XT,"asDate");async function wY(e,t){let r=e.name,n=new ahe(cf.OPERATIONS_ENUM.CLUSTER_STATUS,AY,void 0,await qO.getSystemInfo()),s,i,a=Yl.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await ihe.request(Yl.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Yl.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(a=Yl.CLUSTER_STATUS_STATUSES.CLOSED,GO.error(`Error getting node status from ${r} `,s))}catch(l){GO.warn(`Error getting node status from ${r}`,l),l.code===TY.NoResponders?a=Yl.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===TY.Timeout?a=Yl.CLUSTER_STATUS_STATUSES.TIMEOUT:a=Yl.CLUSTER_STATUS_STATUSES.CLOSED}let c=new The(r,a,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!==cf.PRE_4_0_0_VERSION&&await qO.upsertNodeRecord(l)}catch(l){GO.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}o(wY,"buildNodeStatus");function The(e,t,r,n,s,i,a,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=a,this.system_info=c}o(The,"NodeStatusObject")});var KO=v((Y0e,CY)=>{"use strict";var{handleHDBError:yhe,hdbErrors:Rhe}=_e(),{HTTP_STATUS_CODES:bhe}=Rhe,Ahe=hr(),Ihe=na(),VO=ae(),ey=require("joi"),whe=mt(),Nhe=2e3,Che=ey.object({timeout:ey.number().min(1),connected_nodes:ey.boolean(),routes:ey.boolean()});CY.exports=Ohe;async function Ohe(e){Ihe.checkClusteringEnabled();let t=whe.validateBySchema(e,Che);if(t)throw yhe(t,t.message,bhe.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||VO.autoCastBoolean(n),a=s===void 0||VO.autoCastBoolean(s),c={nodes:[]},l=await Ahe.getServerList(r??Nhe),u={};if(i)for(let d=0,f=l.length;d<f;d++){let m=l[d].statsz;m&&(u[l[d].server.name]=m.routes)}for(let d=0,f=l.length;d<f;d++){if(l[d].statsz)continue;let m=l[d].server,p=l[d].data;if(m.name.endsWith("-hub")){let h={name:m.name.slice(0,-4),response_time:l[d].response_time};i&&(h.connected_nodes=[],u[m.name]&&u[m.name].forEach(E=>{h.connected_nodes.includes(E.name.slice(0,-4))||h.connected_nodes.push(E.name.slice(0,-4))})),a&&(h.routes=p.cluster?.urls?p.cluster?.urls.map(E=>({host:E.split(":")[0],port:VO.autoCast(E.split(":")[1])})):[]),c.nodes.push(h)}}return c}o(Ohe,"clusterNetwork")});var DY=v((z0e,LY)=>{"use strict";var YO=require("joi"),OY=mt(),{routeConstraints:PY}=ww();LY.exports={setRoutesValidator:Phe,deleteRoutesValidator:Lhe};function Phe(e){let t=YO.object({server:YO.valid("hub","leaf"),routes:PY.required()});return OY.validateBySchema(e,t)}o(Phe,"setRoutesValidator");function Lhe(e){let t=YO.object({routes:PY.required()});return OY.validateBySchema(e,t)}o(Lhe,"deleteRoutesValidator")});var ty=v((Q0e,kY)=>{"use strict";var ia=St(),WO=ae(),Ks=(q(),M(z)),lf=me(),MY=DY(),{handleHDBError:vY,hdbErrors:Dhe}=_e(),{HTTP_STATUS_CODES:UY}=Dhe,xY="cluster routes successfully set",BY="cluster routes successfully deleted";kY.exports={setRoutes:vhe,getRoutes:Uhe,deleteRoutes:xhe};function Mhe(e){let t=ia.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 a=0,c=e.routes.length;a<c;a++){let l=e.routes[a];l.port=WO.autoCast(l.port);let u=r.some(f=>f.host===l.host&&f.port===l.port),d=n.some(f=>f.host===l.host&&f.port===l.port);u||d?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?ia.updateConfigValue(Ks.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):ia.updateConfigValue(Ks.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:xY,set:i,skipped:s}}o(Mhe,"setRoutesNats");function vhe(e){let t=MY.setRoutesValidator(e);if(t)throw vY(t,t.message,UY.BAD_REQUEST,void 0,void 0,!0);if(lf.get(Ks.CONFIG_PARAMS.CLUSTERING_ENABLED))return Mhe(e);let r=[],n=[],s=lf.get(Ks.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{FY(s,i)?n.push(i):(s.push(i),r.push(i))}),ia.updateConfigValue(Ks.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:xY,set:r,skipped:n}}o(vhe,"setRoutes");function FY(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}o(FY,"existsInArray");function Uhe(){if(lf.get(Ks.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=ia.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return lf.get(Ks.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}o(Uhe,"getRoutes");function xhe(e){let t=MY.deleteRoutesValidator(e);if(t)throw vY(t,t.message,UY.BAD_REQUEST,void 0,void 0,!0);if(lf.get(Ks.CONFIG_PARAMS.CLUSTERING_ENABLED))return Bhe(e);let r=[],n=[],s=lf.get(Ks.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(a=>{FY(e.routes,a)?r.push(a):(i.push(a),n.push(a))}),ia.updateConfigValue(Ks.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:BY,deleted:r,skipped:n}}o(xhe,"deleteRoutes");function Bhe(e){let t=ia.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],a=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let d=e.routes[l],f=!1;for(let m=0,p=r.length;m<p;m++){let h=r[m];if(d.host===h.host&&d.port===h.port){r.splice(m,1),f=!0,a=!0,s.push(d);break}}if(!f){let m=!0;for(let p=0,h=n.length;p<h;p++){let E=n[p];if(d.host===E.host&&d.port===E.port){n.splice(p,1),c=!0,m=!1,s.push(d);break}}m&&i.push(d)}}return a&&(r=WO.isEmptyOrZeroLength(r)?null:r,ia.updateConfigValue(Ks.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=WO.isEmptyOrZeroLength(n)?null:n,ia.updateConfigValue(Ks.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:BY,deleted:s,skipped:i}}o(Bhe,"deleteRoutesNats")});var GY=v((X0e,HY)=>{"use strict";var Fhe=Ot(),zO=class{static{o(this,"HubConfigObject")}constructor(t,r,n,s,i,a,c,l,u,d,f,m,p,h){this.port=t,a===null&&(a=void 0),this.server_name=r+Fhe.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:a,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:a,insecure:c}},this.cluster={name:d,port:f,routes:m,tls:{cert_file:s,key_file:i,ca_file:a,insecure:c,verify:l}},this.accounts={SYS:{users:p},HDB:{users:h}},this.system_account="SYS"}};HY.exports=zO});var VY=v((eBe,$Y)=>{"use strict";var qY=Ot(),jO=class{static{o(this,"LeafConfigObject")}constructor(t,r,n,s,i,a,c,l,u,d,f){this.port=t,f===null&&(f=void 0),this.server_name=r+qY.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+qY.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:d,ca_file:f,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:f,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:f,insecure:!0},urls:a,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};$Y.exports=jO});var YY=v((rBe,KY)=>{"use strict";var QO=class{static{o(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};KY.exports=QO});var zY=v((sBe,WY)=>{"use strict";var khe=Ot(),JO=class{static{o(this,"SysUserObject")}constructor(t,r){this.user=t+khe.SERVER_SUFFIX.ADMIN,this.password=r}};WY.exports=JO});var iy=v((oBe,JY)=>{"use strict";var Wl=require("path"),zl=require("fs-extra"),Hhe=GY(),Ghe=VY(),qhe=YY(),$he=zY(),XO=ds(),df=ae(),Kn=St(),ny=(q(),M(z)),Mh=Ot(),{CONFIG_PARAMS:or}=ny,ff=Q(),vh=me(),jY=Ji(),ZO=hr(),Vhe=gs(),uf="clustering",Khe=1e4,QY=50;JY.exports={generateNatsConfig:Whe,removeNatsConfig:zhe,getHubConfigPath:Yhe};function Yhe(){let e=vh.get(or.ROOTPATH);return Wl.join(e,uf,Mh.NATS_CONFIG_FILES.HUB_SERVER)}o(Yhe,"getHubConfigPath");async function Whe(e=!1,t=void 0){console.error("Warning: NATS replication is deprecated and will be removed in version 5.0 of Harper");let r=vh.get(or.ROOTPATH);zl.ensureDirSync(Wl.join(r,"clustering","leaf")),vh.initSync();let n=Kn.getConfigFromFile(or.CLUSTERING_TLS_CERT_AUTH),s=Kn.getConfigFromFile(or.CLUSTERING_TLS_PRIVATEKEY),i=Kn.getConfigFromFile(or.CLUSTERING_TLS_CERTIFICATE);!await zl.exists(i)&&!await zl.exists(!n)&&await Vhe.createNatsCerts();let a=Wl.join(r,uf,Mh.PID_FILES.HUB),c=Wl.join(r,uf,Mh.PID_FILES.LEAF),l=Kn.getConfigFromFile(or.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Wl.join(r,uf,Mh.NATS_CONFIG_FILES.HUB_SERVER),d=Wl.join(r,uf,Mh.NATS_CONFIG_FILES.LEAF_SERVER),f=Kn.getConfigFromFile(or.CLUSTERING_TLS_INSECURE),m=Kn.getConfigFromFile(or.CLUSTERING_TLS_VERIFY),p=Kn.getConfigFromFile(or.CLUSTERING_NODENAME),h=Kn.getConfigFromFile(or.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await ZO.checkNATSServerInstalled()||sy("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let E=await XO.listUsers(),g=Kn.getConfigFromFile(or.CLUSTERING_USER),R=await XO.getClusterUser();(df.isEmpty(R)||R.active!==!0)&&sy(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await ry(or.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await ry(or.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await ry(or.CLUSTERING_HUBSERVER_NETWORK_PORT),await ry(or.CLUSTERING_LEAFSERVER_NETWORK_PORT));let S=[],y=[];for(let[X,W]of E.entries())W.role?.role===ny.ROLE_TYPES_ENUM.CLUSTER_USER&&W.active&&(S.push(new $he(W.username,jY.decrypt(W.hash))),y.push(new qhe(W.username,jY.decrypt(W.hash))));let C=[],{hub_routes:I}=Kn.getClusteringRoutes();if(!df.isEmptyOrZeroLength(I))for(let X of I)C.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${X.host}:${X.port}`);let k=new Hhe(Kn.getConfigFromFile(or.CLUSTERING_HUBSERVER_NETWORK_PORT),p,a,i,s,n,f,m,h,Kn.getConfigFromFile(or.CLUSTERING_HUBSERVER_CLUSTER_NAME),Kn.getConfigFromFile(or.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),C,S,y);n==null&&(delete k.tls.ca_file,delete k.leafnodes.tls.ca_file),t=df.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ny.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await zl.writeJson(u,k),ff.trace(`Hub server config written to ${u}`));let J=`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,G=`tls://${R.uri_encoded_name}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,H=new Ghe(Kn.getConfigFromFile(or.CLUSTERING_LEAFSERVER_NETWORK_PORT),p,c,l,[J],[G],S,y,i,s,n,f);n==null&&delete H.tls.ca_file,(t===void 0||t===ny.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await zl.writeJson(d,H),ff.trace(`Leaf server config written to ${d}`))}o(Whe,"generateNatsConfig");async function ry(e){let t=vh.get(e);return df.isEmpty(t)&&sy(`port undefined for '${e}'`),await df.isPortTaken(t)&&sy(`'${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}o(ry,"isPortAvailable");function sy(e){let t=`Error generating clustering config: ${e}`;ff.error(t),console.error(t),process.exit(1)}o(sy,"generateNatsConfigError");async function zhe(e){let{port:t,config_file:r}=ZO.getServerConfig(e),{username:n,decrypt_hash:s}=await XO.getClusterUser(),i=0,a=2e3;for(;i<QY;){try{let d=await ZO.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){ff.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=QY)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=a*(i*2);u>3e4&&ff.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await df.asyncSetTimeout(u)}let c="0".repeat(Khe),l=Wl.join(vh.get(or.ROOTPATH),uf,r);await zl.writeFile(l,c),await zl.remove(l),ff.notify(e,"started.")}o(zhe,"removeNatsConfig")});var nW=v((cBe,rW)=>{"use strict";var Ts=me(),Xe=(q(),M(z)),Uh=Ot(),oa=require("path"),{PACKAGE_ROOT:ay}=Ct(),XY=me(),oy=ae(),mf="/dev/null",jhe=oa.join(ay,"launchServiceScripts"),ZY=oa.join(ay,"utility/scripts"),Qhe=oa.join(ZY,Xe.HDB_RESTART_SCRIPT),eW=oa.resolve(ay,"dependencies",`${process.platform}-${process.arch}`,Uh.NATS_BINARY_NAME);function tW(){let e={[Xe.PROCESS_NAME_ENV_PROP]:Xe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0,...process.env};return oy.noBootFile()&&(e[Xe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=oy.getEnvCliRootPath()),{name:Xe.PROCESS_DESCRIPTORS.HDB,script:Xe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:e,execArgv:process.execArgv,cwd:ay}}o(tW,"generateMainServerConfig");var Jhe=9930;function Xhe(){Ts.initSync(!0);let e=Ts.get(Xe.CONFIG_PARAMS.ROOTPATH),t=oa.join(e,"clustering",Uh.NATS_CONFIG_FILES.HUB_SERVER),r=oa.join(Ts.get(Xe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Xe.LOG_NAMES.HDB),n=XY.get(Xe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Uh.LOG_LEVEL_FLAGS[Ts.get(Xe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Jhe?"-"+n:""),binFile:eW,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Xe.PROCESS_NAME_ENV_PROP]:Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Ts.get(Xe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=mf,i.error_file=mf),i}o(Xhe,"generateNatsHubServerConfig");var Zhe=9940;function eEe(){Ts.initSync(!0);let e=Ts.get(Xe.CONFIG_PARAMS.ROOTPATH),t=oa.join(e,"clustering",Uh.NATS_CONFIG_FILES.LEAF_SERVER),r=oa.join(Ts.get(Xe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Xe.LOG_NAMES.HDB),n=XY.get(Xe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Uh.LOG_LEVEL_FLAGS[Ts.get(Xe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Zhe?"-"+n:""),binFile:eW,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Xe.PROCESS_NAME_ENV_PROP]:Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Ts.get(Xe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=mf,i.error_file=mf),i}o(eEe,"generateNatsLeafServerConfig");function tEe(){Ts.initSync();let e=oa.join(Ts.get(Xe.CONFIG_PARAMS.LOGGING_ROOT),Xe.LOG_NAMES.HDB),t={name:Xe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,binFile:Xe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Xe.PROCESS_NAME_ENV_PROP]:Xe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:jhe,autorestart:!1};return Ts.get(Xe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=mf,t.error_file=mf),t}o(tEe,"generateClusteringUpgradeV4ServiceConfig");function rEe(){let e={[Xe.PROCESS_NAME_ENV_PROP]:Xe.PROCESS_DESCRIPTORS.RESTART_HDB};return oy.noBootFile()&&(e[Xe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=oy.getEnvCliRootPath()),{...{name:Xe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:ZY},script:Qhe}}o(rEe,"generateRestart");function nEe(){return{apps:[tW()]}}o(nEe,"generateAllServiceConfigs");rW.exports={generateAllServiceConfigs:nEe,generateMainServerConfig:tW,generateRestart:rEe,generateNatsHubServerConfig:Xhe,generateNatsLeafServerConfig:eEe,generateClusteringUpgradeV4ServiceConfig:tEe}});var pf=v((dBe,uW)=>{"use strict";var Or=(q(),M(z)),uBe=ae(),ca=iy(),cy=hr(),aa=Ot(),Ec=nW(),tP=me(),_c=Q(),sEe=na(),{startWorker:sW,onMessageFromWorkers:iEe}=nt(),iW=require("fs"),oEe=require("node:path"),aEe=(q(),M(z)),{setTimeout:cEe}=require("node:timers/promises"),{execFile:lEe,fork:uEe}=require("node:child_process");uW.exports={start:gc,restart:fEe,kill:EEe,startAllServices:_Ee,startService:aW,restartHdb:mEe,startClusteringProcesses:cW,startClusteringThreads:lW,isHdbRestartRunning:pEe,getHdbPid:hEe,cleanupChildrenProcesses:xh,reloadClustering:SEe,expectedRestartOfChildren:oW};iEe(e=>{e.type==="restart"&&tP.initSync(!0)});var fo=[],dEe=10,eP;function gc(e,t=!1){let r=typeof e.args=="string"?e.args.split(" "):e.args;e.silent=!0,e.detached=!0;let n=e.script?uEe(e.script,r,e):lEe(e.binFile,r,e);n.name=e.name,n.config=e,n.on("error",(a,c)=>{console.error(a,c)}),n.on("exit",async a=>{let c=fo.indexOf(n);c>-1&&fo.splice(c,1),!eP&&a!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<dEe&&(iW.existsSync(ca.getHubConfigPath())?gc(e):(await ca.generateNatsConfig(!0),gc(e),await new Promise(l=>setTimeout(l,3e3)),await ca.removeNatsConfig(Or.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ca.removeNatsConfig(Or.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let s={serviceName:e.name.replace(/ /g,"-")};function i(a){let c=tP.get(Or.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),l=/\[\d+][^\[]+\[(\w+)]/g,u,d=0,f;for(;u=l.exec(a);){if(u.index&&aa.LOG_LEVEL_HIERARCHY[c]>=aa.LOG_LEVEL_HIERARCHY[f||"info"]){let h=f===aa.LOG_LEVELS.ERR||f===aa.LOG_LEVELS.WRN?_c.OUTPUTS.STDERR:_c.OUTPUTS.STDOUT;_c.logCustomLevel(f||"info",h,s,a.slice(d,u.index).trim())}let[m,p]=u;d=u.index+m.length,f=aa.LOG_LEVELS[p]}if(aa.LOG_LEVEL_HIERARCHY[c]>=aa.LOG_LEVEL_HIERARCHY[f||"info"]){let m=f===aa.LOG_LEVELS.ERR||f===aa.LOG_LEVELS.WRN?_c.OUTPUTS.STDERR:_c.OUTPUTS.STDOUT;_c.logCustomLevel(f||"info",m,s,a.toString().slice(d).trim())}}o(i,"extractMessages"),n.stdout.on("data",i),n.stderr.on("data",i),n.unref(),fo.length===0&&(t||(process.on("exit",xh),process.on("SIGINT",xh),process.on("SIGQUIT",xh),process.on("SIGTERM",xh))),fo.push(n)}o(gc,"start");function xh(e=!0){if(!eP&&(eP=!0,fo.length!==0))if(_c.info("Killing child processes..."),fo.map(t=>t.kill()),e)process.exit(0);else return cEe(2e3)}o(xh,"cleanupChildrenProcesses");function fEe(e){oW();for(let t of fo)t.name===e&&t.kill()}o(fEe,"restart");function oW(){for(let e of fo)e.config&&(e.config.restarts=0)}o(oW,"expectedRestartOfChildren");async function mEe(){await gc(Ec.generateRestart())}o(mEe,"restartHdb");async function pEe(){let e=await list();for(let t in e)if(e[t].name===Or.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}o(pEe,"isHdbRestartRunning");function hEe(){let e=tP.getHdbBasePath();if(!e)return;let t=oEe.join(e,aEe.HDB_PID_FILE),r=TEe(t);if(!(!r||r===process.pid)&&yEe(r))return r}o(hEe,"getHdbPid");function EEe(){for(let e of fo)e.kill();fo=[]}o(EEe,"kill");async function _Ee(){await cW(),await lW(),await gc(Ec.generateAllServiceConfigs())}o(_Ee,"startAllServices");async function aW(e,t=!1){let r;switch(e=e.toLowerCase(),e){case Or.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ec.generateMainServerConfig();break;case Or.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ec.generateNatsIngestServiceConfig();break;case Or.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ec.generateNatsReplyServiceConfig();break;case Or.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ec.generateNatsHubServerConfig(),await gc(r,t),await ca.removeNatsConfig(e);return;case Or.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ec.generateNatsLeafServerConfig(),await gc(r,t),await ca.removeNatsConfig(e);return;case Or.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ec.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}gc(r,t)}o(aW,"startService");var gEe;async function cW(e=!1){for(let t in Or.CLUSTERING_PROCESSES){let r=Or.CLUSTERING_PROCESSES[t];await aW(r,e)}}o(cW,"startClusteringProcesses");async function lW(){gEe=sW(Or.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Or.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await cy.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await cy.updateLocalStreams();let e=await sEe.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Or.PRE_4_0_0_VERSION){_c.info("Starting clustering upgrade 4.0.0 process"),sW(Or.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}o(lW,"startClusteringThreads");async function SEe(){await ca.generateNatsConfig(!0),await cy.reloadNATSHub(),await cy.reloadNATSLeaf(),await ca.removeNatsConfig(Or.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await ca.removeNatsConfig(Or.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}o(SEe,"reloadClustering");function TEe(e){try{return Number.parseInt(iW.readFileSync(e,"utf8"),10)}catch{return null}}o(TEe,"readPidFile");function yEe(e){try{return process.kill(e,0),!0}catch(t){return t.code==="EPERM"}}o(yEe,"isProcessRunning")});var sP={};Re(sP,{compactOnStart:()=>REe,copyDb:()=>EW});async function REe(){Sc.notify("Running compact on start"),console.log("Running compact on start");let e=(0,rP.get)(F.ROOTPATH),t=new Map,r=at();(0,nP.updateConfigValue)(F.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,ly.join)(e,"backup",n+".mdb"),a=(0,ly.join)(e,qc,n+"-copy.mdb"),c=0;try{c=await dW(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Sc.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{dbPath:s,copyDest:a,backupDest:i,recordCount:c}),await EW(n,a),console.log("Backing up",n,"to",i);try{await(0,jl.move)(s,i,{overwrite:!0})}catch(l){console.log("Error moving database",s,"to",i,l)}}try{Td()}catch(n){Sc.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{dbPath:s,copyDest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,jl.move)(i,s,{overwrite:!0}),await(0,jl.remove)((0,ly.join)(e,qc,`${n}-copy.mdb-lock`));try{Td()}catch(n){Sc.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Sc.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,nP.updateConfigValue)(F.STORAGE_COMPACTONSTART,!1);for(let[s,{dbPath:i,backupDest:a}]of t){console.error("Moving backup database",a,"back to",i);try{await(0,jl.move)(a,i,{overwrite:!0})}catch(c){console.error(c)}}throw Td(),n}for(let[n,{backupDest:s,recordCount:i}]of t){let a=!0,c=await dW(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){a=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
26
26
|
Total record count before compaction: ${i}, total after: ${c}.
|
|
27
27
|
Database backup has not been removed and can be found here: ${s}`;Sc.error(l),console.error(l)}(0,rP.get)(F.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||a===!1||(console.log("Removing backup",s),await(0,jl.remove)(s))}}async function dW(e){let t=await(0,hW.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}function hf(){}async function EW(e,t){console.log(`Copying database ${e} to ${t}`);let r=at()[e];if(!r)throw new Error(`Source database not found: ${e}`);let n;for(let f in r){let m=r[f];m.primaryStore.put=hf,m.primaryStore.remove=hf;for(let p in m.indices){let h=m.indices[p];h.put=hf,h.remove=hf}m.auditStore&&(m.auditStore.put=hf,m.auditStore.remove=hf),n=m.primaryStore.rootStore}if(!n)throw new Error(`Source database does not have any tables: ${e}`);let s=n.dbisDb,i=n.auditStore,a=(0,fW.open)(new mW.default(t)),c=a.openDB(uy.INTERNAL_DBIS_NAME),l,u=0,d=s.useReadTransaction();try{for(let{key:m,value:p}of s.getRange({transaction:d})){let h=p.is_hash_attribute||p.isPrimaryKey,E,g;if(h&&(E=p.compression,g=oS(),g?p.compression=g:delete p.compression,E?.dictionary?.toString()===g?.dictionary?.toString()&&(E=null,g=null)),c.put(m,p),!(h||p.indexed))continue;let R=new pW.OpenDBIObject(!h,h);R.encoding="binary",R.compression=E;let S=n.openDB(m,R);S.decoder=null,S.decoderCopies=!1,S.encoding="binary",R.compression=g;let y=a.openDB(m,R);y.encoder=null,console.log("copying",m,"from",e,"to",t),await f(S,y,h,d)}if(i){let m=n.openDB(uy.AUDIT_STORE_NAME,Lm);console.log("copying audit log for",e,"to",t),f(i,m,!1,d)}async function f(m,p,h,E){let g=0,R=0,S=1e7,y=null;for(;S-- >0;)try{for(let C of m.getKeys({start:y,transaction:E}))try{y=C;let{value:I,version:k}=m.getEntry(C,{transaction:E});l=p.put(C,I,h?k:void 0),g++,E.openTimer&&(E.openTimer=0),R+=(C?.length||10)+I.length,u++>5e3&&(await l,console.log("copied",g,"entries",R,"bytes"),u=0)}catch(I){console.error("Error copying record",typeof C=="symbol"?"symbol":C,"from",e,"to",t,I)}console.log("finish copying, copied",g,"entries",R,"bytes");return}catch{if(typeof y=="string"){if(y==="z")return console.error("Reached end of dbi",y,"for",e,"to",t);y=y.slice(0,-2)+"z"}else if(typeof y=="number")y++;else return console.error("Unknown key type",y,"for",e,"to",t)}}o(f,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{d.done(),a.close()}}var fW,ly,jl,rP,mW,pW,uy,hW,nP,Sc,iP=se(()=>{we();fW=require("lmdb"),ly=require("path"),jl=require("fs-extra"),rP=b(me()),mW=b(Vm()),pW=b($m()),uy=b(Yt());q();Bi();hW=b(Dl()),nP=b(St()),Sc=b(Q());o(REe,"compactOnStart");o(dW,"getTotalDBRecordCount");o(hf,"noop");o(EW,"copyDb")});var aP=v((_Be,_W)=>{"use strict";var Bh=me();Bh.initSync();var Ef=require("fs-extra"),oP=require("path"),_f=(q(),M(z)),bEe=require("crypto"),AEe=require("uuid").v4;_W.exports=IEe;function IEe(){if(Bh.getHdbBasePath()!==void 0){let e=oP.join(Bh.getHdbBasePath(),_f.LICENSE_KEY_DIR_NAME,_f.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=oP.join(Bh.getHdbBasePath(),_f.LICENSE_KEY_DIR_NAME,_f.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=oP.join(Bh.getHdbBasePath(),_f.LICENSE_KEY_DIR_NAME,_f.JWT_ENUM.JWT_PASSPHRASE_NAME);try{Ef.accessSync(r),Ef.accessSync(e),Ef.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=AEe(),i=bEe.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});Ef.writeFileSync(r,s),Ef.writeFileSync(e,i.privateKey),Ef.writeFileSync(t,i.publicKey)}else throw n}}}o(IEe,"checkJWTTokenExist")});var SW=v((SBe,gW)=>{"use strict";var cP=class{static{o(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};gW.exports={HdbInfoInsertObject:cP}});var RW=v((yBe,yW)=>{"use strict";var TW=(q(),M(z)),lP=class{static{o(this,"UpgradeObject")}constructor(t,r){this[TW.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[TW.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};yW.exports={UpgradeObject:lP}});var dy=v((bBe,AW)=>{"use strict";var Ys=require("prompt"),gf=require("chalk"),bW=Q(),yi=require("os"),uP=$c(),dP=["yes","y"];async function wEe(e){let t=`${yi.EOL}`+gf.bold.green("Your current HarperDB version requires that we complete an update process.")+`${yi.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${yi.EOL}${yi.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${yi.EOL}`;Ys.override=uP(["CONFIRM_UPGRADE"]),Ys.start(),Ys.message=t;let r={properties:{CONFIRM_UPGRADE:{description:gf.magenta(`${yi.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 bW.error("There was an error when prompting user about an upgrade."),bW.error(s),!1}return dP.includes(n.CONFIRM_UPGRADE)}o(wEe,"forceUpdatePrompt");async function NEe(e){let t=`${yi.EOL}`+gf.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.${yi.EOL}`);Ys.override=uP(["CONFIRM_DOWNGRADE"]),Ys.start(),Ys.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:gf.magenta(`${yi.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 dP.includes(n.CONFIRM_DOWNGRADE)}o(NEe,"forceDowngradePrompt");async function CEe(){let e=`${yi.EOL}`+gf.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=uP(["GENERATE_CERTS"]),Ys.start(),Ys.message=e;let t={properties:{GENERATE_CERTS:{description:gf.magenta(`${yi.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 dP.includes(r.GENERATE_CERTS)}o(CEe,"upgradeCertsPrompt");AW.exports={forceUpdatePrompt:wEe,forceDowngradePrompt:NEe,upgradeCertsPrompt:CEe}});var fy=v((IBe,IW)=>{"use strict";var fP=class{static{o(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};IW.exports=fP});var NW=v((LBe,wW)=>{"use strict";var OEe=ae(),PEe=St(),NBe=Q(),CBe=require("path"),OBe=require("fs"),PBe=(q(),M(z));wW.exports={getOldPropsValue:LEe};function LEe(e,t,r=!1){let n=t.getRaw(e);return OEe.isNotEmptyAndHasValue(n)?n:r?PEe.getDefaultConfig(e):""}o(LEe,"getOldPropsValue")});var LW=v((MBe,PW)=>{"use strict";var Tc=require("path"),yc=require("fs-extra"),DEe=require("properties-reader"),MEe=fy(),gr=Q(),{getOldPropsValue:Tt}=NW(),{HDB_SETTINGS_NAMES:Se,CONFIG_PARAMS:Ql}=(q(),M(z)),Jl=St(),my=me(),CW=ae(),mo=(q(),M(z)),mP=new MEe("3.1.0"),OW=[];function vEe(){let e=DEe(my.get(Se.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),gr.info(t);let r=` ;Settings for the HarperDB process.
|
|
28
28
|
|
|
@@ -125,7 +125,7 @@ Host ${s}
|
|
|
125
125
|
`)}catch{d=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}a&&await Oe.appendFile(Ea,a);let f=await Ii(e);return f.message=`Added ssh key: ${r}${d}`,f}o(HTe,"addSSHKey");async function GTe(e){let t=Wn.updateSSHKeyValidator(e);if(t)throw Jt(t,t.message,Xt.BAD_REQUEST);let{name:r,key:n}=e;Qt.trace("updating ssh key",r);let s=$e.join(Dc,r+".key");if(!await Oe.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Oe.outputFile(s,n);let i=await Ii(e);return i.message=`Updated ssh key: ${r}`,i}o(GTe,"updateSSHKey");async function qTe(e){let t=Wn.deleteSSHKeyValidator(e);if(t)throw Jt(t,t.message,Xt.BAD_REQUEST);let{name:r}=e;Qt.trace("deleting ssh key",r);let n=$e.join(Dc,r+".key"),s=$e.join(Dc,"config");if(!await Oe.pathExists(n))throw new Error("Key does not exist");let i=await Oe.readFile(s,"utf8"),a=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(a,""),await Oe.outputFile(s,i),Oe.removeSync(n);let c=await Ii(e);return c.message=`Deleted ssh key: ${r}`,c}o(qTe,"deleteSSHKey");async function $Te(e){let t=[];return await Oe.pathExists(Dc)&&(await Oe.readdir(Dc)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}o($Te,"listSSHKeys");async function VTe(e){let t=Wn.setSSHKnownHostsValidator(e);if(t)throw Jt(t,t.message,Xt.BAD_REQUEST);let{known_hosts:r}=e;await Oe.outputFile(Ea,r);let n=await Ii(e);return n.message="Known hosts successfully set",n}o(VTe,"setSSHKnownHosts");async function KTe(e){return await Oe.pathExists(Ea)?{known_hosts:await Oe.readFile(Ea,"utf8")}:{known_hosts:null}}o(KTe,"getSSHKnownHosts");cr.customFunctionsStatus=wTe;cr.getCustomFunctions=NTe;cr.getCustomFunction=CTe;cr.setCustomFunction=OTe;cr.dropCustomFunction=PTe;cr.addComponent=LTe;cr.dropCustomFunctionProject=DTe;cr.packageComponent=MTe;cr.deployComponent=vTe;cr.getComponents=xTe;cr.getComponentFile=BTe;cr.setComponentFile=FTe;cr.dropComponent=kTe;cr.addSSHKey=HTe;cr.updateSSHKey=GTe;cr.deleteSSHKey=qTe;cr.listSSHKeys=$Te;cr.setSSHKnownHosts=VTe;cr.getSSHKnownHosts=KTe});var tL=v((FFe,Lj)=>{"use strict";var js=require("joi"),Pj=mt();Lj.exports={readTransactionLogValidator:YTe,deleteTransactionLogsBeforeValidator:WTe};function YTe(e){let t=js.object({schema:js.string(),database:js.string(),table:js.string().required(),from:js.date().timestamp(),to:js.date().timestamp(),limit:js.number().min(1)});return Pj.validateBySchema(e,t)}o(YTe,"readTransactionLogValidator");function WTe(e){let t=js.object({schema:js.string(),database:js.string(),table:js.string().required(),timestamp:js.date().timestamp().required()});return Pj.validateBySchema(e,t)}o(WTe,"deleteTransactionLogsBeforeValidator")});var qy=v((HFe,Bj)=>{"use strict";var rL=(q(),M(z)),tE=hr(),Dj=ae(),Mj=me(),vj=Ji(),Uj=Q(),{handleHDBError:Hy,hdbErrors:zTe}=_e(),{HTTP_STATUS_CODES:Gy}=zTe,{readTransactionLogValidator:jTe,deleteTransactionLogsBeforeValidator:QTe}=tL(),xj=as(),JTe="Logs successfully deleted from transaction log.",XTe="All logs successfully deleted from transaction log.";Bj.exports={readTransactionLog:ZTe,deleteTransactionLogsBefore:tye};async function ZTe(e){let t=jTe(e);if(t)throw Hy(t,t.message,Gy.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=Dj.checkSchemaTableExist(e.database,e.table);if(r)throw Hy(new Error,r,Gy.NOT_FOUND,void 0,void 0,!0);return Mj.get(rL.CONFIG_PARAMS.CLUSTERING_ENABLED)?await eye(e):(Uj.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)),xj.readAuditLog(e))}o(ZTe,"readTransactionLog");async function*eye(e){let t=vj.createNatsTableStreamName(e.database,e.table),r=await tE.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===rL.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}o(eye,"readTransactionLogNats");async function tye(e){let t=QTe(e);if(t)throw Hy(t,t.message,Gy.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!Mj.get(rL.CONFIG_PARAMS.CLUSTERING_ENABLED))return Uj.info("Delete transaction logs called for Plexus"),xj.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=Dj.checkSchemaTableExist(r,n);if(i)throw Hy(new Error,i,Gy.NOT_FOUND,void 0,void 0,!0);let a=vj.createNatsTableStreamName(r,n),{jsm:c}=await tE.getNATSReferences(),l=await tE.getStreamInfo(a),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let d=JTe,f,m=new Date(l.state.last_ts).getTime();return s>m?(f=l.state.last_seq+1,d=XTe):f=(await tE.viewStream(a,parseInt(s),1))[0].nats_sequence,await tE.purgeTableStream(r,n,{seq:f}),d}o(tye,"deleteTransactionLogsBefore")});var nL=v((qFe,kj)=>{"use strict";var $y=require("joi"),rye=require("path"),{handleHDBError:nye,hdbErrors:sye}=_e(),{HTTP_STATUS_CODES:iye}=sye,oye=mt(),Fj=Q();kj.exports={installModules:uye};var{CONFIG_PARAMS:aye}=(q(),M(z)),{getConfigValue:cye}=St(),{nonInteractiveSpawn:lye}=(By(),M(xy));async function uye(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Fj.warn(t,e.projects);let r=fye(e);if(r)throw nye(r,r.message,iye.BAD_REQUEST);let{projects:n,dryRun:s}=e,i=cye(aye.COMPONENTSROOT),a={},c=["install","--force","--omit=dev","--json"];s&&c.push("--dry-run");for(let l of n){a[l]={npm_output:null,npm_error:null};let u=rye.join(i,l);try{let{stdout:d,stderr:f}=lye(l,"npm",c,u);d=d?d.replace(`
|
|
126
126
|
`,""):null,f=f?f.replace(`
|
|
127
127
|
`,""):null;try{a[l].npm_output=JSON.parse(d)}catch{a[l].npm_output=d}try{a[l].npm_error=JSON.parse(f)}catch{a[l].npm_error=f}}catch(d){d.stderr?a[l].npm_error=dye(d.stderr):a[l].npm_error=d.message;continue}}return Fj.info(`finished installModules with response ${a}`),a.warning=t,a}o(uye,"installModules");function dye(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
|
|
128
|
-
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}o(dye,"parseNPMStdErr");function fye(e){let t=$y.object({projects:$y.array().min(1).items($y.string()).required(),dry_run:$y.boolean().default(!1)});return oye.validateBySchema(e,t)}o(fye,"modulesValidator")});var aL={};Re(aL,{describeMetric:()=>Kj,describeMetricOp:()=>oL,get:()=>$j,getOp:()=>sL,listMetrics:()=>Vj,listMetricsOp:()=>iL});async function pye(e){return(await B_().get(e)).hostname}function Hj(e,t){return e.length===0||e.includes(t)}function sL(e){return rE.trace?.("get_analytics request:",e),$j(e.metric,e.get_attributes,e.start_time,e.end_time,e.conditions)}function qj(e){return"conditions"in e?{...e,conditions:e.conditions.map(qj)}:{attribute:e.search_attribute??e.attribute,comparator:e.search_type??e.comparator,value:e.search_value??e.value}}async function $j(e,t,r,n,s){let i=[{attribute:"metric",comparator:"equals",value:e}];s&&i.push(...s.map(qj));let a=t??[];Hj(a,"id")||a.push("id"),r&&i.push({attribute:"id",comparator:"greater_than_equal",value:r}),n&&i.push({attribute:"id",comparator:"less_than",value:n});let c={conditions:i};return a.length>0&&(c.select=a),rE.trace?.("get_analytics hdb_analytics.search request:",JSON.stringify(c)),(await databases.system.hdb_analytics.search(c)).map(async u=>{let d=u.id[1];return u.id=u.id[0],Hj(a,"node")&&(rE.trace?.(`get_analytics lookup hostname for nodeId: ${d}`),u.node=await pye(d)),rE.trace?.("get_analytics result:",JSON.stringify(u)),u})}function iL(e){return Vj(e.metric_types)}async function Vj(e=["builtin"]){let t=[],r=Object.values(Uo);if(e.includes("builtin")&&(t=r),e.includes("custom")){let n=r.map(c=>({attribute:"metric",comparator:"not_equal",value:c})),s={select:["metric"],conditions:n},i=new Set,a=await databases.system.hdb_analytics.search(s);for await(let c of a)i.add(c.metric);t.push(...Array.from(i.values()))}return t}function oL(e){return Kj(e.metric)}async function Kj(e){let t={conditions:[{attribute:"metric",comparator:"equals",value:e}],sort:{attribute:"id",descending:!0},limit:1},r=databases.system.hdb_analytics.search(t),n=[{name:"node",type:"string"}];for await(let s of r){for(let a in s)n.push({name:a,type:typeof s[a]});let i={attributes:n};return rE.trace?.("describe_metric result:",JSON.stringify(i)),i}return{}}var Gj,mye,rE,cL=se(()=>{Gj=b(Q());uA();dA();({forComponent:mye}=Gj.default),rE=mye("analytics").conditional;o(pye,"lookupHostname");o(Hj,"isSelected");o(sL,"getOp");o(qj,"conformCondition");o($j,"get");o(iL,"listMetricsOp");o(Vj,"listMetrics");o(oL,"describeMetricOp");o(Kj,"describeMetric")});var Vy,Ky,nE,Yy=se(()=>{Vy={primary:{allowedValues:null},maintenance:{allowedValues:null},availability:{allowedValues:["Available","Unavailable"]}},Ky=Object.keys(Vy),nE="primary"});function Wj(e){return Yj.validateBySchema(e,gye)}var sE,Yj,hye,Eye,_ye,gye,zj=se(()=>{sE=b(require("joi")),Yj=b(mt());Yy();hye=Ky,Eye=Object.entries(Vy).reduce((e,[t,r])=>(r.allowedValues&&(e[t]=`Status "${t}" only accepts these values: ${r.allowedValues.join(", ")}`),e),{}),_ye=o(()=>{let e=sE.default.string().min(1).max(512);return Object.entries(Vy).forEach(([t,r])=>{r.allowedValues&&(e=e.when("id",{is:t,then:sE.default.string().valid(...r.allowedValues).messages({"any.only":Eye[t]})}))}),e.required()},"createStatusValidationSchema"),gye=sE.default.object({id:sE.default.string().valid(...hye).required(),status:_ye()});o(Wj,"validateStatus")});function jj(){lL||(lL=_a.primaryStore.getUserSharedBuffer("restart-needed",new ArrayBuffer(1)),uL=new Uint8Array(lL))}function Qj(){jj(),uL[0]=1}function Jj(){return jj(),uL[0]===1}var lL,uL,dL=se(()=>{iE();o(jj,"ensureInitialized");o(Qj,"requestRestart");o(Jj,"restartNeeded")});var EL={};Re(EL,{DEFAULT_STATUS_ID:()=>nE,STATUS_IDS:()=>Ky,Status:()=>_a,clear:()=>mL,get:()=>pL,set:()=>hL});function aE(){return fL||(fL=Ze({database:"system",table:"hdb_status",replicate:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"status"},{name:"__createdtime__"},{name:"__updatedtime__"}]})),fL}function mL({id:e}){return oE.debug?.("clearStatus",e),aE().delete(e)}async function Tye(){oE.debug?.("getAllStatus");let e=aE().get({}),t=await yp.query.allThreads(),r=Array.from(t.entries()).map(([s,i])=>({name:s,...i})),n=Jj();return{systemStatus:e,componentStatus:r,restartRequired:n}}function pL({id:e}){return e?(oE.debug?.("getStatus",e),aE().get(e)):(oE.debug?.("getStatus","all"),Tye())}function hL({status:e,id:t=nE}){let r=Wj({status:e,id:t});if(r)throw(0,Wy.handleHDBError)(r,r.message,Sye.BAD_REQUEST);return oE.debug?.("setStatus",t,e),aE().put(t,{status:e})}var Wy,Xj,Sye,fL,_a,oE,iE=se(()=>{we();Wy=b(_e()),Xj=b(Xn());zj();Yy();Rp();dL();Yy();({HTTP_STATUS_CODES:Sye}=Wy.hdbErrors);o(aE,"getStatusTable");_a={get primaryStore(){return aE().primaryStore}},oE=(0,Xj.loggerWithTag)("status");o(mL,"clearStatus");o(Tye,"getAllStatus");o(pL,"getStatus");o(hL,"setStatus")});function Rye(e){if(typeof e!="string")throw new zy(`License must be a string; received ${typeof e}: ${e}`);let t;try{t=e.split(".")}catch(l){let u=new zy(`Unable to split license into components; license must be a string with three dot-separated parts; got: ${e}`);throw u.cause=l,u}if(t.length!==3)throw new wf(`License must have three dot-separated parts; got ${t.length}`);let[r,n,s]=t,i=yye.getKey();if(!(0,Qy.verify)(null,Buffer.from(r+"."+n,"utf8"),i,Buffer.from(s,"base64url")))throw new gL("License signature is invalid");return{header:c(r),payload:c(n),signature:c(s)};function c(l){return Buffer.from(l,"base64url").toString("utf8")}}function bye(e){if(e?.typ!=="Harper-License")throw new cE(`Invalid license header; typ must be 'Harper-License'; got: ${e?.typ}`);if(e?.alg!=="EdDSA")throw new cE(`Invalid license header; alg must be 'EdDSA'; got: ${e?.alg}`)}function Aye(e,t){return e.required?typeof t===e.type:typeof t>"u"||typeof t===e.type}function Iye(e){let t={id:{required:!0,type:"string"},region:{required:!1,type:"string"},expiration:{required:!0,type:"string"},level:{required:!0,type:"number"},reads:{required:!0,type:"number"},writes:{required:!0,type:"number"},readBytes:{required:!0,type:"number"},writeBytes:{required:!0,type:"number"},realTimeMessages:{required:!0,type:"number"},realTimeBytes:{required:!0,type:"number"},cpuTime:{required:!0,type:"number"},storage:{required:!0,type:"number"},autoRenew:{required:!1,type:"boolean"}};for(let r in t){let{required:n,type:s}=t[r],i=n?`required attribute '${r}'`:`optional attribute '${r}', when present,`;if(!Aye(t[r],e[r]))throw new jy(`Invalid license payload; ${i} must be a ${s}; got: ${typeof e[r]}`)}}function e4(e){let{header:t,payload:r}=Rye(e),n;try{n=JSON.parse(t)}catch(i){let a=new cE;throw a.cause=i,a}bye(n);let s;try{s=JSON.parse(r)}catch(i){let a=new jy;throw a.cause=i,a}return Iye(s),s}var Qy,Zj,_L,zy,wf,gL,cE,jy,yye,t4=se(()=>{Qy=require("node:crypto"),Zj=b(me());q();_L=class{static{o(this,"PublicKey")}pem;constructor(t){t&&(t==="test"||t==="development")?this.pem=`-----BEGIN PUBLIC KEY-----
|
|
128
|
+
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}o(dye,"parseNPMStdErr");function fye(e){let t=$y.object({projects:$y.array().min(1).items($y.string()).required(),dry_run:$y.boolean().default(!1)});return oye.validateBySchema(e,t)}o(fye,"modulesValidator")});var aL={};Re(aL,{describeMetric:()=>Kj,describeMetricOp:()=>oL,get:()=>$j,getOp:()=>sL,listMetrics:()=>Vj,listMetricsOp:()=>iL});async function pye(e){return(await B_().get(e)).hostname}function Hj(e,t){return e.length===0||e.includes(t)}function sL(e){return rE.trace?.("get_analytics request:",e),$j(e.metric,e.get_attributes,e.start_time,e.end_time,e.conditions)}function qj(e){return"conditions"in e?{...e,conditions:e.conditions.map(qj)}:{attribute:e.search_attribute??e.attribute,comparator:e.search_type??e.comparator,value:e.search_value??e.value}}async function $j(e,t,r,n,s){let i=[{attribute:"metric",comparator:"equals",value:e}];s&&i.push(...s.map(qj));let a=t??[];Hj(a,"id")||a.push("id"),r&&i.push({attribute:"id",comparator:"greater_than_equal",value:r}),n&&i.push({attribute:"id",comparator:"less_than",value:n});let c={conditions:i,allowConditionsOnDynamicAttributes:!0};return a.length>0&&(c.select=a),rE.trace?.("get_analytics hdb_analytics.search request:",JSON.stringify(c)),(await databases.system.hdb_analytics.search(c)).map(async u=>{let d=u.id[1];return u.id=u.id[0],Hj(a,"node")&&(rE.trace?.(`get_analytics lookup hostname for nodeId: ${d}`),u.node=await pye(d)),rE.trace?.("get_analytics result:",JSON.stringify(u)),u})}function iL(e){return Vj(e.metric_types)}async function Vj(e=["builtin"]){let t=[],r=Object.values(Uo);if(e.includes("builtin")&&(t=r),e.includes("custom")){let n=r.map(c=>({attribute:"metric",comparator:"not_equal",value:c})),s={select:["metric"],conditions:n},i=new Set,a=await databases.system.hdb_analytics.search(s);for await(let c of a)i.add(c.metric);t.push(...Array.from(i.values()))}return t}function oL(e){return Kj(e.metric)}async function Kj(e){let t={conditions:[{attribute:"metric",comparator:"equals",value:e}],sort:{attribute:"id",descending:!0},limit:1},r=databases.system.hdb_analytics.search(t),n=[{name:"node",type:"string"}];for await(let s of r){for(let a in s)n.push({name:a,type:typeof s[a]});let i={attributes:n};return rE.trace?.("describe_metric result:",JSON.stringify(i)),i}return{}}var Gj,mye,rE,cL=se(()=>{Gj=b(Q());uA();dA();({forComponent:mye}=Gj.default),rE=mye("analytics").conditional;o(pye,"lookupHostname");o(Hj,"isSelected");o(sL,"getOp");o(qj,"conformCondition");o($j,"get");o(iL,"listMetricsOp");o(Vj,"listMetrics");o(oL,"describeMetricOp");o(Kj,"describeMetric")});var Vy,Ky,nE,Yy=se(()=>{Vy={primary:{allowedValues:null},maintenance:{allowedValues:null},availability:{allowedValues:["Available","Unavailable"]}},Ky=Object.keys(Vy),nE="primary"});function Wj(e){return Yj.validateBySchema(e,gye)}var sE,Yj,hye,Eye,_ye,gye,zj=se(()=>{sE=b(require("joi")),Yj=b(mt());Yy();hye=Ky,Eye=Object.entries(Vy).reduce((e,[t,r])=>(r.allowedValues&&(e[t]=`Status "${t}" only accepts these values: ${r.allowedValues.join(", ")}`),e),{}),_ye=o(()=>{let e=sE.default.string().min(1).max(512);return Object.entries(Vy).forEach(([t,r])=>{r.allowedValues&&(e=e.when("id",{is:t,then:sE.default.string().valid(...r.allowedValues).messages({"any.only":Eye[t]})}))}),e.required()},"createStatusValidationSchema"),gye=sE.default.object({id:sE.default.string().valid(...hye).required(),status:_ye()});o(Wj,"validateStatus")});function jj(){lL||(lL=_a.primaryStore.getUserSharedBuffer("restart-needed",new ArrayBuffer(1)),uL=new Uint8Array(lL))}function Qj(){jj(),uL[0]=1}function Jj(){return jj(),uL[0]===1}var lL,uL,dL=se(()=>{iE();o(jj,"ensureInitialized");o(Qj,"requestRestart");o(Jj,"restartNeeded")});var EL={};Re(EL,{DEFAULT_STATUS_ID:()=>nE,STATUS_IDS:()=>Ky,Status:()=>_a,clear:()=>mL,get:()=>pL,set:()=>hL});function aE(){return fL||(fL=Ze({database:"system",table:"hdb_status",replicate:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"status"},{name:"__createdtime__"},{name:"__updatedtime__"}]})),fL}function mL({id:e}){return oE.debug?.("clearStatus",e),aE().delete(e)}async function Tye(){oE.debug?.("getAllStatus");let e=aE().get({}),t=await yp.query.allThreads(),r=Array.from(t.entries()).map(([s,i])=>({name:s,...i})),n=Jj();return{systemStatus:e,componentStatus:r,restartRequired:n}}function pL({id:e}){return e?(oE.debug?.("getStatus",e),aE().get(e)):(oE.debug?.("getStatus","all"),Tye())}function hL({status:e,id:t=nE}){let r=Wj({status:e,id:t});if(r)throw(0,Wy.handleHDBError)(r,r.message,Sye.BAD_REQUEST);return oE.debug?.("setStatus",t,e),aE().put(t,{status:e})}var Wy,Xj,Sye,fL,_a,oE,iE=se(()=>{we();Wy=b(_e()),Xj=b(Xn());zj();Yy();Rp();dL();Yy();({HTTP_STATUS_CODES:Sye}=Wy.hdbErrors);o(aE,"getStatusTable");_a={get primaryStore(){return aE().primaryStore}},oE=(0,Xj.loggerWithTag)("status");o(mL,"clearStatus");o(Tye,"getAllStatus");o(pL,"getStatus");o(hL,"setStatus")});function Rye(e){if(typeof e!="string")throw new zy(`License must be a string; received ${typeof e}: ${e}`);let t;try{t=e.split(".")}catch(l){let u=new zy(`Unable to split license into components; license must be a string with three dot-separated parts; got: ${e}`);throw u.cause=l,u}if(t.length!==3)throw new wf(`License must have three dot-separated parts; got ${t.length}`);let[r,n,s]=t,i=yye.getKey();if(!(0,Qy.verify)(null,Buffer.from(r+"."+n,"utf8"),i,Buffer.from(s,"base64url")))throw new gL("License signature is invalid");return{header:c(r),payload:c(n),signature:c(s)};function c(l){return Buffer.from(l,"base64url").toString("utf8")}}function bye(e){if(e?.typ!=="Harper-License")throw new cE(`Invalid license header; typ must be 'Harper-License'; got: ${e?.typ}`);if(e?.alg!=="EdDSA")throw new cE(`Invalid license header; alg must be 'EdDSA'; got: ${e?.alg}`)}function Aye(e,t){return e.required?typeof t===e.type:typeof t>"u"||typeof t===e.type}function Iye(e){let t={id:{required:!0,type:"string"},region:{required:!1,type:"string"},expiration:{required:!0,type:"string"},level:{required:!0,type:"number"},reads:{required:!0,type:"number"},writes:{required:!0,type:"number"},readBytes:{required:!0,type:"number"},writeBytes:{required:!0,type:"number"},realTimeMessages:{required:!0,type:"number"},realTimeBytes:{required:!0,type:"number"},cpuTime:{required:!0,type:"number"},storage:{required:!0,type:"number"},autoRenew:{required:!1,type:"boolean"}};for(let r in t){let{required:n,type:s}=t[r],i=n?`required attribute '${r}'`:`optional attribute '${r}', when present,`;if(!Aye(t[r],e[r]))throw new jy(`Invalid license payload; ${i} must be a ${s}; got: ${typeof e[r]}`)}}function e4(e){let{header:t,payload:r}=Rye(e),n;try{n=JSON.parse(t)}catch(i){let a=new cE;throw a.cause=i,a}bye(n);let s;try{s=JSON.parse(r)}catch(i){let a=new jy;throw a.cause=i,a}return Iye(s),s}var Qy,Zj,_L,zy,wf,gL,cE,jy,yye,t4=se(()=>{Qy=require("node:crypto"),Zj=b(me());q();_L=class{static{o(this,"PublicKey")}pem;constructor(t){t&&(t==="test"||t==="development")?this.pem=`-----BEGIN PUBLIC KEY-----
|
|
129
129
|
MCowBQYDK2VwAyEAO301jvpO12znGdK/Izrre518pgmQNk9hSMXf4wDMucM=
|
|
130
130
|
-----END PUBLIC KEY-----
|
|
131
131
|
`:this.pem=`-----BEGIN PUBLIC KEY-----
|