harperdb 4.6.16 → 4.6.17
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 +3 -3
- 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 +214 -214
- package/package.json +1 -1
- package/server/jobs/jobProcess.js +3 -3
- package/server/threads/threadServer.js +3 -3
- package/studio/build-local/asset-manifest.json +2 -2
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{main.7a55c447.js → main.f935ef10.js} +2 -2
- package/utility/scripts/restartHdb.js +3 -3
- /package/studio/build-local/static/js/{main.7a55c447.js.LICENSE.txt → main.f935ef10.js.LICENSE.txt} +0 -0
package/README.md
CHANGED
package/bin/harperdb.js
CHANGED
|
@@ -17,9 +17,9 @@
|
|
|
17
17
|
`,""));return r.replace(`
|
|
18
18
|
`,"")}o(dG,"runCommand");async function Mce(){try{await lce.access(ww)}catch{return!1}let e=await dG(`${ww} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return uce.eq(t,Dce)}o(Mce,"checkNATSServerInstalled");async function Lw(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let a=await lG.getClusterUser();if(Fl(a))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=a.username,r=a.decrypt_hash}Ni.trace("create nats connection called");let i=await yce({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:qr.get(je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:qr.get(je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:qr.get(je.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Ni.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(a=>{a&&Ni.error("Error with Nats client connection, connection closed",a),i===pn&&fG()}),i}o(Lw,"createConnection");function fG(){pn=void 0,Ul=void 0,xl=void 0,Bl=void 0}o(fG,"clearClientCache");async function vce(){pn&&(await pn.drain(),pn=void 0,Ul=void 0,xl=void 0,Bl=void 0)}o(vce,"closeConnection");var pn,Bl;async function Vh(){return Bl||(Bl=Lw(qr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),pn=await Bl),pn||Bl}o(Vh,"getConnection");async function Kh(){if(Ul)return Ul;Fl(pn)&&await Vh();let{domain:e}=Pd(je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Fl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ul=await pn.jetstreamManager({domain:e,timeout:6e4}),Ul}o(Kh,"getJetStreamManager");async function mG(){if(xl)return xl;Fl(pn)&&await Vh();let{domain:e}=Pd(je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Fl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return xl=pn.jetstream({domain:e,timeout:6e4}),xl}o(mG,"getJetStream");async function ao(){let e=pn||await Vh(),t=Ul||await Kh(),r=xl||await mG();return{connection:e,jsm:t,js:r}}o(ao,"getNATSReferences");async function Uce(e){let t=qr.get(je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await lG.getClusterUser(),s=await Lw(t,r,n),i=Dw(),a=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of a){let f=uG.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 mS.asyncSetTimeout(e),await a.drain(),await s.close(),await u,c}o(Uce,"getServerList");async function Mw(e,t){let{jsm:r}=await ao(),n=qr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=qr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=qr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Ace.File,retention:bce.Limits,subjects:t,discard:Ice.Old,maxMsgs:s,maxBytes:i,maxAge:n})}o(Mw,"createLocalStream");async function hG(){let{jsm:e}=await ao(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}o(hG,"listStreams");async function xce(e){let{jsm:t}=await ao();await t.streams.delete(e)}o(xce,"deleteLocalStream");async function Bce(e){let{connection:t}=await ao(),r=[],n=Dw(),s=t.subscribe(n),i=(async()=>{for await(let a of s)r.push(uG.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(Bce,"listRemoteStreams");async function Fce(e,t=void 0,r=void 0){let{jsm:n,js:s}=await ao(),i=iG(),a={durable_name:i,ack_policy:Cw.Explicit};t&&(a.deliver_policy=Pw.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=Ow(d.data),m={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:f};if(d.headers&&(m.origin=d.headers.get(Xr.MSG_HEADERS.ORIGIN)),u.push(m),d.ack(),d.info.pending===0)break}return await c.delete(),u}o(Fce,"viewStream");async function*Hce(e,t=void 0,r=void 0){let{jsm:n,js:s}=await ao(),i=iG(),a={durable_name:i,ack_policy:Cw.Explicit};t&&(a.deliver_policy=Pw.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=Ow(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(Xr.MSG_HEADERS.ORIGIN)),yield m}if(u.ack(),u.info.pending===0)break}await c.delete()}o(Hce,"viewStreamIterator");async function kce(e,t,r,n){Ni.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=pG(n,r);let{js:s}=await ao(),i=await pS(),a=`${e}.${i}`,c=await Cce(()=>n instanceof Uint8Array?n:cG.encode(n));try{Ni.trace(`publishToStream publishing to subject: ${a}`),Oce(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 EG(async()=>{try{await s.publish(a,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){Ni.trace(`publishToStream creating stream: ${t}`);let d=a.split(".");d[2]="*",await Mw(t,[a]),await s.publish(a,c,{headers:r})}else throw l}});throw l}}o(kce,"publishToStream");function pG(e,t){t===void 0&&(t=wce());let r=qr.get(je.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Xr.MSG_HEADERS.ORIGIN)&&r&&t.append(Xr.MSG_HEADERS.ORIGIN,r),t}o(pG,"addNatsMsgHeader");function Pd(e){e=e.toLowerCase();let t=$h.join(qr.get(je.CONFIG_PARAMS.ROOTPATH),Pce);if(e===je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return Fl(Nw)&&(Nw={port:qh.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:qh.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Xr.SERVER_SUFFIX.HUB,config_file:Xr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:$h.join(t,Xr.PID_FILES.HUB),hdbNatsPath:t}),Nw;if(e===je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return Fl(Iw)&&(Iw={port:qh.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:qh.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Xr.SERVER_SUFFIX.LEAF,config_file:Xr.NATS_CONFIG_FILES.LEAF_SERVER,domain:qh.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Xr.SERVER_SUFFIX.LEAF,pid_file_path:$h.join(t,Xr.PID_FILES.LEAF),hdbNatsPath:t}),Iw;Ni.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}o(Pd,"getServerConfig");async function _G(e,t,r,n){try{await e.consumers.add(t,{ack_policy:Cw.Explicit,durable_name:r,deliver_policy:Pw.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}o(_G,"createConsumer");async function qce(e,t,r){await e.consumers.delete(t,r)}o(qce,"removeConsumer");function Gce(e){return e.split(".")[1]}o(Gce,"extractServerName");async function $ce(e,t,r=6e4,n=Dw()){if(!mS.isObject(t))throw new Error("data param must be an object");let s=cG.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 Ow(c.data)}o($ce,"request");function vw(e){return new Promise(async(t,r)=>{let n=hce(ww,["--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(vw,"reloadNATS");async function Vce(){let{pid_file_path:e}=Pd(je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await vw(e)}o(Vce,"reloadNATSHub");async function Kce(){let{pid_file_path:e}=Pd(je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await vw(e)}o(Kce,"reloadNATSLeaf");function Yce(e,t,r){let n;switch(e.code){case sG.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case sG.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}o(Yce,"requestErrorHandler");async function Wce(e,t){let r=t+Xr.SERVER_SUFFIX.LEAF,{connection:n}=await ao(),{jsm:s}=await tle(r),{schema:i,table:a}=e,c=hS.createNatsTableStreamName(i,a),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await EG(async()=>{if(e.subscribe===!0)await _G(s,c,n.info.server_name,l);else try{await qce(s,c,n.info.server_name)}catch(u){Ni.trace(u)}})}o(Wce,"updateRemoteConsumer");async function zce(e,t,r,n){let s=hS.createNatsTableStreamName(e,t),i=r+Xr.SERVER_SUFFIX.LEAF,a={type:je.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!aG&&Tce()<qr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=bw();await c(a)}await gce(a),n==="stop"&&await mS.asyncSetTimeout(1e3)}o(zce,"updateConsumerIterator");function EG(e){return Ece.writeTransaction(je.SYSTEM_SCHEMA_NAME,je.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}o(EG,"exclusiveLock");async function gG(e,t){let r=hS.createNatsTableStreamName(e,t),n=await pS(),s=Xce(e,t,n);await Mw(r,[s])}o(gG,"createLocalTableStream");async function jce(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await gG(n,s)}}o(jce,"createTableStreams");async function SG(e,t,r=void 0){if(qr.get(je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=hS.createNatsTableStreamName(e,t),{domain:s}=Pd(je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await Vh()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")Ni.warn(n);else throw n}}o(SG,"purgeTableStream");async function Jce(e,t){if(qr.get(je.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await SG(e,t[r])}o(Jce,"purgeSchemaTableStreams");async function Qce(e){return(await Kh()).streams.info(e)}o(Qce,"getStreamInfo");function Xce(e,t,r){return`${Xr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}o(Xce,"createSubjectName");async function pS(){if(Gh)return Gh;if(Gh=(await Kh())?.nc?.info?.server_name,Gh===void 0)throw new Error("Unable to get jetstream manager server name");return Gh}o(pS,"getJsmServerName");async function Zce(){let e=await Kh(),t=await pS(),r=await hG();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let a=ele(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(".");Ni.trace(`Updating stream subject name from: ${i} to: ${d}`),s.subjects[0]=d,await e.streams.update(s.name,s)}}o(Zce,"updateLocalStreams");function ele(e){let{config:t}=e,r=!1,n=qr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=qr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=qr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}o(ele,"updateStreamLimits");async function tle(e){let t,r;try{t=await pn.jetstream({domain:e}),r=await pn.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw Ni.error("Unable to connect to:",e),n}return{js:t,jsm:r}}o(tle,"connectToRemoteJS")});function Uw(e){let t=e.get(_S),r=t?(0,Dd.unpack)(t):null;r||(r={remoteNameToId:{}});let n=Ze(),s=!1;r.nodeName=Ze();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:Wh(e)??1,nodes:[]})})}i[n]=0,e.putSync(_S,(0,Dd.pack)(r))}return r}function Yh(e){return Uw(e).remoteNameToId}function yG(e,t){let r=Uw(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(_S,(0,Dd.pack)(r)),s}function ES(e,t){let r=Uw(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(_S,(0,Dd.pack)(r))}return RG.trace?.("The remote node name map",e,n,s),s}var RG,Dd,_S,xw=ue(()=>{RG=w(hi());qn();Dd=require("msgpackr"),_S=Symbol.for("remote-ids");o(Uw,"getIdMappingRecord");o(Yh,"exportIdMapping");o(yG,"remoteToLocalNodeId");o(ES,"getIdOfRemoteNode")});function Hw(e,t,r,n,s){let i=e.primaryStore.env.path,a=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=bG,rle(e.primaryStore,e.auditStore)):(c=AG,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{IG(AG[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[a];u||(u=l[a]=new Map,u.envs=l,u.tableId=a,u.store=e.primaryStore),t=Zu(t);let d=new Fw(r);d.startTime=n;let f=u.get(t);return f?f.push(d):(u.set(t,f=[d]),f.tables=u,f.key=t),d.subscriptions=f,d}function IG(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),NG(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=bt(s),a=e[i.tableId];if(!a)continue;let c=i.recordId,l=Zu(c),u=0;do{let d=a.get(l);if(d){for(let m of d)if(!(u>0&&!(m.includeDescendants&&!(m.onlyChildren&&u>1)))){if(m.startTime>=n){(0,Bw.info)("omitting",c,m.startTime,n);continue}try{let h;m.supportsTransactions&&m.txnInProgress!==i.version&&(h=!0,m.txnInProgress||(r?r.push(m):r=[m]),m.txnInProgress=i.version),m.listener(c,i,n,h)}catch(h){console.error(h),(0,Bw.info)(h)}}}if(l==null)break;let f=l.lastIndexOf?.("/",l.length-2);f!==l.length-1&&u++,f>-1?l=l.slice(0,f+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function rle(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:a,txnId:c})=>{let l=bG[s];if(!l)return;let u=o(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{IG(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function NG(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function wG(e){return e.nextTransaction||(Hw({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),NG(e)),e.nextTransaction}var Bw,AG,bG,Fw,kw=ue(()=>{Bw=w(j());Wu();ed();Yi();AG=Object.create(null),bG=Object.create(null);o(Hw,"addSubscription");Fw=class extends es{static{o(this,"Subscription")}listener;subscriptions;startTime;includeDescendants;supportsTransactions;onlyChildren;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};o(IG,"notifyFromTransactionData");o(rle,"listenToCommits");o(NG,"nextTransaction");o(wG,"whenNextTransaction")});var qw={};Oe(qw,{commitsAwaitingReplication:()=>Ld,getHDBNodeTable:()=>Vt,getReplicationSharedStatus:()=>Md,iterateRoutes:()=>jh,shouldReplicateToNode:()=>zh,subscribeToNodeUpdates:()=>vd});function Vt(){return OG||(OG=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 Md(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(48),n&&{callback:n}))}function vd(e){Vt().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;LG.debug?.("adding node",n,"on node",Ze()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==Ze()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of Vt().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 zh(e,t){let r=ic.default.get(U.REPLICATION_DATABASES);return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&(r==="*"||r?.find?.(n=>n.name===t&&(!n.sharded||e.shard===ic.default.get(U.REPLICATION_SHARD))))&&Vt().primaryStore.get(Ze())?.replicates||e.subscriptions?.some(n=>(n.database||n.schema)===t&&n.subscribe)}function nle(){vd(e=>{oc({},(t,r)=>{let n=e.name,s=CG.get(n);if(s||CG.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=Md(i,r,n,()=>{let c=a[0],l=a.lastTime;for(let{txnTime:u,onConfirm:d}of Ld.get(r)||[])u>l&&u<=c&&d();a.lastTime=c});a.lastTime=0,s.set(r,a)}})})}function*jh(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=ic.default.get(U.REPLICATION_SECUREPORT)??(!ic.default.get(U.REPLICATION_PORT)&&ic.default.get(U.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||ic.default.get(U.REPLICATION_PORT)||ic.default.get(U.OPERATIONSAPI_NETWORK_PORT);let a=i?.lastIndexOf?.(":");a>0&&(i=+i.slice(a+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){PG.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 PG,DG,ic,LG,OG,CG,Ld,Hl=ue(()=>{De();qn();vm();PG=require("worker_threads"),DG=w(ge()),ic=w(oe());H();LG=w(hi());server.nodes=[];o(Vt,"getHDBNodeTable");o(Md,"getReplicationSharedStatus");o(vd,"subscribeToNodeUpdates");o(zh,"shouldReplicateToNode");CG=new Map;uU((e,t,r)=>{if(r>server.nodes.length)throw new DG.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);Ld||(Ld=new Map,nle());let n=Ld.get(e);return n||(n=[],Ld.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:o(()=>{++i===r&&s()},"onConfirm")})})});o(nle,"startSubscriptionToReplications");o(jh,"iterateRoutes")});var UG={};Oe(UG,{connectedToNode:()=>kl,disconnectedFromNode:()=>xd,ensureNode:()=>zo,requestClusterStatus:()=>vG,startOnMainThread:()=>Vw});async function Vw(e){let t=0,r=st();for(let i of Object.getOwnPropertyNames(r)){let a=r[i];for(let c in a){let l=a[c];if(l.auditStore){gS.set(i,Wh(l.auditStore));break}}}lo.whenThreadsStarted.then(async()=>{let i=[];for await(let l of r.system.hdb_nodes?.search([])||[])i.push(l);let a=Ze();function c(){let l=Vt().primaryStore.get(a);if(l!==null){let u=e.url??ac();if(l===void 0||l.url!==u||l.shard!==e.shard)return zo(a,{name:a,url:u,shard:e.shard,replicates:!0})}}o(c,"ensureThisNode"),Vt().primaryStore.get(a)&&c();for(let l of jh(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)}vd(s)});let n;function s(i,a=i?.name){let c=Ze()&&a===Ze()||ac()&&i?.url===ac();if(c){let f=!!i?.replicates;if(n!==void 0&&n!==f)for(let m of Vt().search([]))m.replicates&&m.name!==a&&s(m,m.name);n=f}if(ot.trace("Setting up node replication for",i),!i){for(let[f,m]of co){let h;for(let[p,{worker:E,nodes:g}]of m){let y=g[0];if(y&&y.name==a){h=!0;for(let[T,{worker:R}]of m)m.delete(T),ot.warn("Node was deleted, unsubscribing from node",a,T,f),R?.postMessage({type:"unsubscribe-from-node",node:a,database:T,url:f});break}}if(h){co.get(f).iterator.remove(),co.delete(f);return}}return}if(c)return;if(!i.url){ot.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(ot.info(`Added node ${i.name} at ${i.url} for process ${Ze()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[f,m]of Ud)if(i.url===m.url){Ud.delete(f);break}Ud.set(i.name,i)}let u=st();if(l||(l=new Map,co.set(i.url,l)),l.iterator=oc(e,(f,m,h)=>{h?d(m,!0):d(m,!1)}),i.subscriptions)for(let f of i.subscriptions){let m=f.database||f.schema;u[m]||(ot.warn(`Database ${m} not found for node ${i.name}, making a subscription anyway`),d(m,!1))}function d(f,m){ot.trace("Setting up replication for database",f,"on node",i.name);let h=l.get(f),p,E=[{replicateByDefault:m,...i}];gS.has(f)&&(E.push({replicateByDefault:m,name:Ze(),startTime:gS.get(f),endTime:Date.now(),replicates:!0}),gS.delete(f));let g=zh(i,f),y=lo.workers.filter(T=>T.name==="http");if(h?(p=h.worker,h.nodes=E):g&&(t=t%y.length,p=y[t++],l.set(f,{worker:p,nodes:E,url:i.url}),p?.on("exit",()=>{l.get(f)?.worker===p&&(l.delete(f),d(f,m))})),g)setTimeout(()=>{let T={type:"subscribe-to-node",database:f,nodes:E};p?p.postMessage(T):Jh(T)},sle);else{ot.info("Node no longer should be used, unsubscribing from node",{replicates:i.replicates,databaseName:f,node:i,subscriptions:i.subscriptions,hasDatabase:!!u[f],thisReplicates:Vt().primaryStore.get(Ze())?.replicates}),Vt().primaryStore.get(Ze())?.replicates||(n=!1,ot.info("Disabling replication, this node name",Ze(),Vt().primaryStore.get(Ze()),f));let T={type:"unsubscribe-from-node",database:f,url:i.url,name:i.name};p?p.postMessage(T):TS(T)}}o(d,"onDatabase")}o(s,"onNodeUpdate"),xd=o(function(i){try{ot.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let a=Array.from(Ud.keys()),c=a.sort(),l=c.indexOf(i.name||wi(i.url));if(l===-1){ot.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){ot.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished||!$w.default.get(U.REPLICATION_FAILOVER))return;let f=d.nodes[0];if(!(f.replicates===!0||f.replicates?.sends||f.subscriptions?.length))return;let m=f.shard,h=(l+1)%c.length;for(;l!==h;){let p=c[h],E=Ud.get(p);u=co.get(E.url);let g=u?.get(i.database);if(!g||g.connected===!1||g.nodes[0].shard!==m){h=(h+1)%c.length;continue}let{worker:y,nodes:T}=g,R=!1;for(let N of d.nodes){if(T.some(O=>O.name===N.name)){ot.info(`Disconnected node is already failing over to ${p} for ${i.database}`);continue}N.endTime<Date.now()||(T.push(N),R=!0)}if(d.nodes=[d.nodes[0]],!R){ot.info(`Disconnected node ${i.name} has no nodes to fail over to ${p}`);return}ot.info(`Failing over ${i.database} from ${i.name} to ${p}`),y?y.postMessage({type:"subscribe-to-node",database:i.database,nodes:T}):Jh({database:i.database,nodes:T});return}ot.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(a){ot.error("Error failing over node",a)}},"disconnectedFromNode"),kl=o(function(i){let a=co.get(i.url),c=a?.get(i.database);if(!c){ot.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,a);return}c.connected=!0,c.latency=i.latency;let l=c.nodes[0];if(!l){ot.warn("Newly connected node has no node subscriptions",i.database,c);return}if(!l.name){ot.debug("Connected node is not named yet",i.database,c);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:h,connected:p}=f;if(h)if(p===!1&&h[0].shard===l.shard)u=!0,c.nodes.push(h[0]);else{let E=h.filter(g=>g&&g.name!==l.name);E.length<h.length&&(f.nodes=E,m.postMessage({type:"subscribe-to-node",database:i.database,nodes:h}))}}u&&c.worker&&c.worker.postMessage({type:"subscribe-to-node",database:i.database,nodes:c.nodes})},"connectedToNode"),(0,lo.onMessageByType)("disconnected-from-node",xd),(0,lo.onMessageByType)("connected-to-node",kl),(0,lo.onMessageByType)("request-cluster-status",vG)}function vG(e,t){let r=[];for(let[n,s]of Ud)try{let i=co.get(s.url);ot.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(h=>!(h.endTime<Date.now())).map(h=>h.name)});let c=(0,Gw.cloneDeep)(s);c.database_sockets=a,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ot.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function zo(e,t){let r=Vt();e=e??wi(t.url),t.name=e;try{if(t.ca){let s=new MG.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){ot.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ot.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.patch(t);else{t.replicates&&!$w.default.get(U.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],a=(0,Gw.cloneDeep)(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])]}ot.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var lo,SS,ot,Gw,$w,MG,sle,co,xd,kl,Ud,gS,Qh=ue(()=>{De();lo=w(nt());qn();SS=require("worker_threads");Hl();ot=w(j()),Gw=require("lodash"),$w=w(oe());H();MG=require("crypto"),sle=200,co=new Map,Ud=new Map,gS=new Map;o(Vw,"startOnMainThread");o(vG,"requestClusterStatus");SS.parentPort&&(xd=o(e=>{SS.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),kl=o(e=>{SS.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,lo.onMessageByType)("subscribe-to-node",e=>{Jh(e)}),(0,lo.onMessageByType)("unsubscribe-from-node",e=>{TS(e)}));o(zo,"ensureNode")});var _n=M(Kt=>{"use strict";var _r=require("path"),{watch:ile}=require("chokidar"),Gn=require("fs-extra"),Bd=require("node-forge"),qG=require("net"),{generateKeyPair:Kw,X509Certificate:jo,createPrivateKey:GG}=require("crypto"),ole=require("util");Kw=ole.promisify(Kw);var wt=Bd.pki,Oi=require("joi"),{v4:$G}=require("uuid"),{validateBySchema:jw}=lt(),{forComponent:ale}=j(),ds=oe(),Fs=(H(),v(W)),{CONFIG_PARAMS:Gl}=Fs,Ci=AI(),{ClientError:lc}=ge(),yS=require("node:tls"),{relative:VG,join:cle}=require("node:path"),{CERT_PREFERENCE_APP:FUe,CERTIFICATE_VALUES:xG}=Ci,lle=qa(),Yw=pt(),{table:ule,getDatabases:dle,databases:RS}=(De(),v(ut)),{getJWTRSAKeys:BG}=(Nd(),v(Hh)),_t=ale("tls");Kt.generateKeys=Xw;Kt.updateConfigCert=XG;Kt.createCsr=gle;Kt.signCertificate=Sle;Kt.setCertTable=Fd;Kt.loadCertificates=jG;Kt.reviewSelfSignedCert=eO;Kt.createTLSSelector=e$;Kt.listCertificates=r$;Kt.addCertificate=Ile;Kt.removeCertificate=wle;Kt.createNatsCerts=yle;Kt.generateCertsKeys=Rle;Kt.getReplicationCert=Zh;Kt.getReplicationCertAuth=Ele;Kt.renewSelfSigned=Ale;Kt.hostnamesFromCert=rO;Kt.getKey=Ole;Kt.getHostnamesFromCertificate=Cle;Kt.getPrimaryHostName=tO;var{urlToNodeName:KG,getThisNodeUrl:fle,getThisNodeName:bS,clearThisNodeName:mle}=(qn(),v(uo)),{readFileSync:hle,statSync:YG}=require("node:fs"),HUe=oe(),{getTicketKeys:ple,onMessageFromWorkers:_le}=nt(),cc=j(),{isMainThread:WG}=require("worker_threads"),{TLSSocket:zG,createSecureContext:kUe}=require("node:tls"),Jw=3650,Xh=["127.0.0.1","localhost","::1"],Qw=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];_le(async e=>{e.type===Fs.ITC_EVENT_TYPES.RESTART&&(ds.initSync(!0),await eO())});var Zr;function dc(){return Zr||(Zr=dle().system.hdb_certificate,Zr||(Zr=ule({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__"}]}))),Zr}o(dc,"getCertTable");async function Zh(){let e=e$("operations-api"),t={secureContexts:null,setSecureContext:o(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(bS());if(!r)return;let n=new jo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}o(Zh,"getReplicationCert");async function Ele(){dc();let e=(await Zh()).options.cert,r=new jo(e).issuer.match(/CN=(.*)/)?.[1];return Zr.get(r)}o(Ele,"getReplicationCertAuth");var FG,uc=new Map;function jG(){if(FG)return;FG=!0;let e=[{configKey:Gl.TLS},{configKey:Gl.OPERATIONSAPI_TLS}];dc();let t=_r.dirname(Yw.getConfigFilePath()),r;for(let{configKey:n}of e){let s=Yw.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let a=i.privateKey,c=a&&VG(cle(t,"keys"),a);c&&HG(a,l=>{uc.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&WG){let d;HG(u,f=>{if(xG.cert===f)return;let m=i.hostname??i.hostnames??i.host??i.hosts;m&&!Array.isArray(m)&&(m=[m]);let h=ZG(u),p=new jo(h),E;try{E=tO(p)}catch(R){_t.error("error extracting host name from certificate",R);return}if(E==null){_t.error("No host name found on certificate");return}if(p.checkIssued(new jo(xG.cert)))return;let g=Zr.primaryStore.get(E),y=YG(u).mtimeMs,T=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&y<=T){y<T&&_t.info(`Certificate ${E} at ${u} is older (${new Date(y)}) than the certificate in the database (${T>1?new Date(T):"only self signed certificate available"})`);return}r=Zr.put({name:E,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:h,private_key_name:c,is_authority:l,hostnames:m,fileTimestamp:y,details:{issuer:p.issuer.replace(/\n/g," "),subject:p.subject?.replace(/\n/g," "),subject_alt_name:p.subjectAltName,serial_number:p.serialNumber,valid_from:p.validFrom,valid_to:p.validTo}})},l?"certificate authority":"certificate")}}}}}return r}o(jG,"loadCertificates");function HG(e,t,r){let n,s=o((i,a)=>{try{let c=a.mtimeMs;c&&c!==n&&(n&&WG&&_t.warn(`Reloading ${r}:`,i),n=c,t(ZG(i)))}catch(c){_t.error(`Error loading ${r}:`,i,c)}},"loadFile");Gn.existsSync(e)?s(e,YG(e)):_t.error(`${r} file not found:`,e),ile(e,{persistent:!1}).on("change",s)}o(HG,"loadAndWatch");function Ww(){let e=fle();if(e==null){let t=Xh[0];return _t.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return KG(e)}o(Ww,"getHost");function AS(){let e=bS();if(e==null){let t=Xh[0];return _t.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}o(AS,"getCommonName");async function gle(){let e=await Zh(),t=wt.certificateFromPem(e.options.cert),r=wt.privateKeyFromPem(e.options.key);_t.info("Creating CSR with cert named:",e.name);let n=wt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:AS()},...Qw];_t.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:JG()}];return _t.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),Bd.pki.certificationRequestToPem(n)}o(gle,"createCsr");function JG(){let e=Xh.includes(AS())?Xh:[...Xh,AS()];return e.includes(Ww())||e.push(Ww()),[{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=>qG.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}o(JG,"certExtensions");async function Sle(e){let t={},r=_r.join(ds.getHdbBasePath(),Fs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;dc();for await(let d of Zr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(uc.has(d.private_key_name)){n=uc.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await Gn.exists(_r.join(r,d.private_key_name))){n=Gn.readFile(_r.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await zw();s=d.ca,n=d.private_key}n=wt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=wt.certificateFromPem(s.certificate);_t.info("Signing CSR with cert named",s.name);let a=wt.certificationRequestFromPem(e.csr);try{a.verify()}catch(d){return _t.error(d),new Error("Error verifying CSR: "+d.message)}let c=Bd.pki.createCertificate();c.serialNumber="0"+Math.random().toString().slice(2,9),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+Jw),_t.info("sign cert setting validity:",c.validity),_t.info("sign cert setting subject from CSR:",a.subject.attributes),c.setSubject(a.subject.attributes),_t.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=a.getAttribute({name:"extensionRequest"}).extensions;_t.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=a.publicKey,c.sign(n,Bd.md.sha256.create()),t.certificate=wt.certificateToPem(c)}else _t.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}o(Sle,"signCertificate");async function Tle(e,t){await Fd({name:bS(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await Fd({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:wt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}o(Tle,"createCertificateTable");async function Fd(e){let t=new jo(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject?.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},dc(),await Zr.patch(e)}o(Fd,"setCertTable");async function Xw(){let e=await Kw("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{publicKey:wt.publicKeyFromPem(e.publicKey),privateKey:wt.privateKeyFromPem(e.privateKey)}}o(Xw,"generateKeys");async function Zw(e,t,r){let n=wt.createCertificate();if(!t){let a=await Zh();t=wt.certificateFromPem(a.options.cert).publicKey}n.publicKey=t,n.serialNumber="0"+Math.random().toString().slice(2,9),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Jw);let i=[{name:"commonName",value:AS()},...Qw];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(JG()),n.sign(e,Bd.md.sha256.create()),wt.certificateToPem(n)}o(Zw,"generateCertificates");async function zw(){let e=await r$(),t;for(let r of e){if(!r.is_authority)continue;let n=await t$(r.private_key_name);if(r.private_key_name&&n&&new jo(r.certificate).checkPrivateKey(GG(n))){_t.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;_t.trace("No CA found with matching private key")}o(zw,"getCertAuthority");async function QG(e,t,r=!0){let n=wt.createCertificate();n.publicKey=t,n.serialNumber="0"+Math.random().toString().slice(2,9),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Jw);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ds.get(Gl.REPLICATION_HOSTNAME)??KG(ds.get(Gl.REPLICATION_URL))??$G().split("-")[0]}`},...Qw];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,Bd.md.sha256.create());let a=_r.join(ds.getHdbBasePath(),Fs.LICENSE_KEY_DIR_NAME),c=_r.join(a,Ci.PRIVATEKEY_PEM_NAME);return r&&await Gn.writeFile(c,wt.privateKeyToPem(e)),n}o(QG,"generateCertAuthority");async function Rle(){let{privateKey:e,publicKey:t}=await Xw(),r=await QG(e,t),n=await Zw(e,t,r);await Tle(n,r),XG()}o(Rle,"generateCertsKeys");async function yle(){let e=await Zw(wt.privateKeyFromPem(Ci.CERTIFICATE_VALUES.key),void 0,wt.certificateFromPem(Ci.CERTIFICATE_VALUES.cert)),t=_r.join(ds.getHdbBasePath(),Fs.LICENSE_KEY_DIR_NAME),r=_r.join(t,Ci.NATS_CERTIFICATE_PEM_NAME);await Gn.exists(r)||await Gn.writeFile(r,e);let n=_r.join(t,Ci.NATS_CA_PEM_NAME);await Gn.exists(n)||await Gn.writeFile(n,Ci.CERTIFICATE_VALUES.cert)}o(yle,"createNatsCerts");async function Ale(){dc();for await(let e of Zr.search([{attribute:"is_self_signed",value:!0}]))await Zr.delete(e.name);await eO()}o(Ale,"renewSelfSigned");async function eO(){mle(),await jG(),dc();let e=await zw();if(!e){_t.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=o(u=>{try{return{key:wt.privateKeyFromPem(Gn.readFileSync(u)),keyPath:u}}catch(d){return _t.warn(`Failed to parse private key from ${u}:`,d.message),{key:null,keyPath:u}}},"tryToParseKey"),n=ds.get(Gl.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=ds.get(Gl.TLS_PRIVATEKEY),d=r(u);s=d.key,i=d.keyPath}let a=_r.join(ds.getHdbBasePath(),Fs.LICENSE_KEY_DIR_NAME),c=VG(a,i);s||(_t.warn("Unable to parse the TLS key",i,"A new key will be generated and used to create Certificate Authority"),{privateKey:s}=await Xw(),Gn.existsSync(_r.join(a,Ci.PRIVATEKEY_PEM_NAME))&&(c=`privateKey${$G().split("-")[0]}.pem`),await Gn.writeFile(_r.join(a,c),wt.privateKeyToPem(s)));let l=await QG(s,wt.setRsaPublicKey(s.n,s.e),!1);await Fd({name:l.subject.getField("CN").value,uses:["https"],certificate:wt.certificateToPem(l),private_key_name:c,is_authority:!0,is_self_signed:!0})}if(!await Zh()){let r=bS();_t.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await zw();let n=wt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await Zw(wt.privateKeyFromPem(e.private_key),s,n);await Fd({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}o(eO,"reviewSelfSignedCert");function XG(){let e=lle(Object.keys(Fs.CONFIG_PARAM_MAP),!0),t=_r.join(ds.getHdbBasePath(),Fs.LICENSE_KEY_DIR_NAME),r=_r.join(t,Ci.PRIVATEKEY_PEM_NAME),n=_r.join(t,Ci.NATS_CERTIFICATE_PEM_NAME),s=_r.join(t,Ci.NATS_CA_PEM_NAME),i=Fs.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),Yw.updateConfigValue(void 0,void 0,a,!1,!0)}o(XG,"updateConfigCert");function ZG(e){return e.startsWith("-----BEGIN")?e:hle(e,"utf8")}o(ZG,"readPEM");var kG=yS.createSecureContext;yS.createSecureContext=function(e){if(!e.cert||!e.key)return kG(e);let t={...e};delete t.key,delete t.cert;let r=kG(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var ble=zG.prototype._init;zG.prototype._init=function(e,t){ble.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 ql=new Map;function e$(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(),ql.clear();let d=0;if(RS===void 0){c();return}for await(let f of RS.system.hdb_certificate.search([])){let m=f.certificate,h=new jo(m);f.is_authority&&(h.asString=m,ql.set(h.subject,m))}for await(let f of RS.system.hdb_certificate.search([]))try{if(f.is_authority)continue;let m=e==="operations-api",h=f.is_self_signed?1:2;m&&f.uses?.includes?.("operations")&&(h+=1);let p=await t$(f.private_key_name),E=f.certificate,g=new jo(E);if(ql.has(g.issuer)&&(E+=`
|
|
19
19
|
`+ql.get(g.issuer)),!p||!E)throw new Error("Missing private key or certificate for secure server");let y={ciphers:f.ciphers,ticketKeys:ple(),availableCAs:ql,ca:t&&Array.from(ql.values()),cert:E,key:p,key_file:f.private_key_name,is_self_signed:f.is_self_signed};a&&(y.sessionIdContext=a.sessionIdContext);let T=yS.createSecureContext(y);T.name=f.name,T.options=y,T.quality=h,T.certificateAuthorities=Array.from(ql),T.certStart=E.toString().slice(0,100);let R=f.hostnames??rO(g);Array.isArray(R)||(R=[R]);let N;for(let O of R)if(O){O[0]==="*"&&(s=!0,O=O.slice(1)),O===Ww()&&(h+=2),qG.isIP(O)&&(N=!0);let F=r.get(O)?.quality??0;h>F&&r.set(O,T)}else cc.error("No hostname found for certificate at",yS.certificate);cc.trace("Adding TLS",T.name,"for",a.ports||"client","cert named",f.name,"hostnames",R,"quality",h,"best quality",d),h>d&&(i.defaultContext=n=T,d=h,a&&(a.defaultContext=T))}catch(m){cc.error("Error applying TLS for",f.name,m)}a?.secureContextsListeners.forEach(f=>f()),c(n)}catch(d){l(d)}}o(u,"updateTLS"),RS?.system.hdb_certificate.subscribe({listener:o(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(a,c){cc.info("TLS requested for",a||"(no SNI)");let l=a;for(;;){let d=r.get(l);if(d)return cc.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?cc.debug("No certificate found to match",a,"using the default certificate"):cc.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):cc.info("No default certificate found"),c(null,u)}o(i,"SNICallback")}o(e$,"createTLSSelector");async function t$(e){let t=uc.get(e);return!t&&e?await Gn.readFile(_r.join(ds.get(Gl.ROOTPATH),Fs.LICENSE_KEY_DIR_NAME,e),"utf8"):t}o(t$,"getPrivateKeyByName");async function r$(){dc();let e=[];for await(let t of Zr.search([]))e.push(t);return e}o(r$,"listCertificates");async function Ile(e){let t=jw(e,Oi.object({name:Oi.string().required(),certificate:Oi.string().required(),is_authority:Oi.boolean().required(),private_key:Oi.string(),hosts:Oi.array(),uses:Oi.array()}));if(t)throw new lc(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[h,p]of uc)!s&&!c&&a.checkPrivateKey(GG(p))&&(c=!0,u=h),s&&s===p&&(l=!0,u=h);if(!i&&!s&&!c)throw new lc("A suitable private key was not found for this certificate");let d;if(!r){try{d=tO(a)}catch(h){_t.error(h)}if(d==null)throw new lc("Error extracting certificate host name, please provide a name parameter")}let f=Nle(r??d);s&&!c&&!l&&(await Gn.writeFile(_r.join(ds.getHdbBasePath(),Fs.LICENSE_KEY_DIR_NAME,f+".pem"),s),uc.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 Fd(m),"Successfully added certificate: "+f}o(Ile,"addCertificate");function Nle(e){return e.replace(/[^a-z0-9\.]/gi,"-")}o(Nle,"sanitizeName");async function wle(e){let t=jw(e,Oi.object({name:Oi.string().required()}));if(t)throw new lc(t.message);let{name:r}=e;dc();let n=await Zr.get(r);if(!n)throw new lc(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Zr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(_t.info("Removing private key named",s),await Gn.remove(_r.join(ds.getHdbBasePath(),Fs.LICENSE_KEY_DIR_NAME,s)))}return await Zr.delete(r),"Successfully removed "+r}o(wle,"removeCertificate");function tO(e){let t=e.subject?.match(/CN=(.*)/)?.[1];return t||rO(e)[0]}o(tO,"getPrimaryHostName");function rO(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=certObj.subject?.match(/CN=(.*)/)?.[1];return t?[t]:[]}o(rO,"hostnamesFromCert");async function Ole(e){if(e.bypass_auth!==!0)throw new lc("Unauthorized","401");let t=jw(e,Oi.object({name:Oi.string().required()}));if(t)throw new lc(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await BG()).privateKey;if(r===".jwtPublic")return(await BG()).publicKey;if(uc.get(r))return uc.get(e.name);throw new lc("Key not found")}o(Ole,"getKey");function Cle(e){return[e.subject?.CN,...e.subjectaltname.split(",").filter(t=>t.trim().startsWith("DNS:")).map(t=>t.trim().substring(4))]}o(Cle,"getHostnamesFromCertificate")});var I$={};Oe(I$,{CONFIRMATION_STATUS_POSITION:()=>y$,LATENCY_POSITION:()=>LS,NodeReplicationConnection:()=>qd,OPERATION_REQUEST:()=>oO,RECEIVED_TIME_POSITION:()=>cO,RECEIVED_VERSION_POSITION:()=>aO,RECEIVING_STATUS_POSITION:()=>lO,RECEIVING_STATUS_RECEIVING:()=>b$,RECEIVING_STATUS_WAITING:()=>A$,SENDING_TIME_POSITION:()=>ep,createWebSocket:()=>MS,databaseSubscriptions:()=>mc,replicateOverWS:()=>tp,tableUpdateListeners:()=>dO});async function MS(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Ze(),i;if(e==null)throw new TypeError(`Invalid URL: Expected a string URL for node "${s}" but received ${e}`);if(e.includes("wss://")){if(!sO){let l=(0,E$.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),sO=u.secureContexts}if(i=sO.get(s),i&&ae.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,S$.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(PS?.caCount!==Jo.size&&(PS=g$.createSecureContext({...i.options,ca:[...Jo,...i.options.availableCAs.values()]}),PS.caCount=Jo.size),c.secureContext=PS),new p$.WebSocket(e,"harperdb-replication-v1",c)}function tp(e,t,r){let n=t.port||t.securePort,s=Vl.pid%1e3+"-"+_$.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3);ae.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||mc,f,m,h=!1,p=t.subscription;p?.then&&p.then(_=>{p=_,p.auditStore&&(f=p.auditStore)});let E=t.tables||u&&st()[u],g;if(!r){ae.error?.(s,"No authorization provided"),Cs(1008,"Unauthorized");return}let y=new Map,T=[];g=r.name,g&&t.connection&&(t.connection.nodeName=g);let R,N,O,F,Z,q,Y,G=6e4,K,ce=0,le=0,ie=0,pe=h$.default.get(U.REPLICATION_BLOBTIMEOUT)??12e4,Ne=new Map,Ue=[],xe=0,Ar;if(t.url){let _=o(()=>{Z&&le===e._socket?.bytesRead&&ie===e._socket?.bytesWritten?e.terminate():(Z=performance.now(),e.ping(),le=e._socket?.bytesRead,ie=e._socket?.bytesWritten)},"sendPing");O=setInterval(_,f$).unref(),_()}else Zt();e._socket?.setMaxListeners(200);function Zt(){clearTimeout(F),le=e._socket?.bytesRead,ie=e._socket?.bytesWritten,F=setTimeout(()=>{le===e._socket?.bytesRead&&ie===e._socket?.bytesWritten&&(ae.warn?.(`Timeout waiting for ping from ${g}, terminating connection and reconnecting`),e.terminate())},f$*2).unref()}o(Zt,"resetPingTimer");function qt(){if(!(!g||!u))return m||(m=Md(f,u,g)),m}o(qt,"getSharedStatus"),u&&xa(u);let er,fm,Zc=[],Gt=[],mm,hm=[],cE=[],lE=[],LA=150,pm=25,Pe=0,uE=0,_m=!1,Po,Mr,br,Em;e.on("message",_=>{ce=performance.now();try{let S=_.dataView=new Wl(_.buffer,_.byteOffset,_.byteLength);if(_[0]>127){let P=(0,et.decode)(_),[D,L,k]=P;switch(D){case s$:{if(L){if(g){if(g!==L){ae.error?.(s,`Node name mismatch, expecting to connect to ${g}, but peer reported name as ${L}, disconnecting`),e.send((0,et.encode)([Hd])),Cs(1008,"Node name mismatch");return}}else if(g=L,t.connection?.tentativeNode){let B=t.connection.tentativeNode;B.name=g,t.connection.tentativeNode=null,zo(g,B)}if(t.connection&&(t.connection.nodeName=g),ae.debug?.(s,"received node name:",g,"db:",u??P[2]),!u)try{xa(u=P[2]),u==="system"&&(er=oc(t,(B,de)=>{qu(de)&&Ba(de)}),e.on("close",()=>{er?.remove()}))}catch(B){ae.warn?.(s,"Error setting database",B),e.send((0,et.encode)([Hd])),Cs(1008,B.message);return}vr()}break}case u$:{ae.debug?.(s,"Received table definitions for",L.map(B=>B.table));for(let B of L){let de=P[2];B.database=de;let me;qu(de)&&(de==="system"?ke[de]?.[B.table]||(me=V(B,ke[de]?.[B.table])):me=V(B,ke[de]?.[B.table]),f||(f=me?.auditStore),E||(E=st()?.[de]))}break}case Hd:Cs();break;case oO:try{let B=r?.replicates||r?.subscribers||r?.name;ae.debug?.("Received operation request",L,"from",g),server.operation(L,{user:r},!B).then(de=>{Array.isArray(de)&&(de={results:de}),de.requestId=L.requestId,e.send((0,et.encode)([NS,de]))},de=>{e.send((0,et.encode)([NS,{requestId:L.requestId,error:(0,kd.errorToString)(de)}]))})}catch(B){e.send((0,et.encode)([NS,{requestId:L.requestId,error:(0,kd.errorToString)(B)}]))}break;case NS:let{resolve:C,reject:x}=y.get(L.requestId);L.error?x(new Error(L.error)):C(L),y.delete(L.requestId);break;case nO:let z=P[3];if(!E){u?ae.error?.(s,"No database found for",u):ae.error?.(s,"Database name never received"),Cs();return}let ne=E[z];ne=V({table:z,database:u,attributes:L.attributes,schemaDefined:L.schemaDefined},ne),Zc[k]={name:z,decoder:new et.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:L.typedStructs,structures:L.structures}),getEntry(B){return ne.primaryStore.getEntry(B)},rootStore:ne.primaryStore.rootStore};break;case i$:Em=f?yG(L,f):new Map,mm=P[2],ae.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${mm}`);break;case o$:let re=k;lE[re]=L;break;case l$:qt()[y$]=L,ae.trace?.(s,"received and broadcasting committed update",L),qt().buffer.notify();break;case c$:R=L,p.send({type:"end_txn",localTime:R,remoteNodeIds:T});break;case wS:{let B=P[1],{fileId:de,size:me,finished:Se,error:ee}=B,J=Ne.get(de);ae.debug?.("Received blob",de,"has stream",!!J,"connectedToBlob",!!J?.connectedToBlob,"length",P[2].length,"finished",Se),J||(J=new iO.PassThrough,J.expectedSize=me,Ne.set(de,J)),J.lastChunk=Date.now();let he=P[2];it(he.byteLength,"bytes-received",`${g}.${u}`,"replication","blob");try{Se?(ee?(J.on("error",()=>{}),J.destroy(new Error("Blob error: "+ee+" for record "+(J.recordId??"unknown")+" from "+g))):J.end(he),J.connectedToBlob&&Ne.delete(de)):J.write(he)}catch(Te){ae.error?.(`Error receiving blob for ${J.recordId} from ${g} and streaming to storage`,Te),Ne.delete(de)}break}case a$:{let B=L,de;try{let me=P[3],Se=Gt[k]||(Gt[k]=E[P[4]]);if(!Se)return ae.warn?.("Unknown table id trying to handle record request",k);let ee=Se.primaryStore.getBinaryFast(Symbol.for("structures")),J=ee?.length??0;if(J>0&&J!==uE){uE=J;let Te=(0,et.decode)(ee);e.send((0,et.encode)([nO,{typedStructs:Te.typed,structures:Te.named},k,Se.tableName]))}let he=Se.primaryStore.getBinaryFast(me);if(he){let Te=Se.primaryStore.decoder.decode(he,{valueAsBuffer:!0}),fe=dt||{};fe.version=(0,T$.getLastVersion)(),dt&&dt[Gd]&Wr&&(Te=Buffer.from(Te),qm(()=>Se.primaryStore.decoder.decode(he),We=>Ua(We,me),Se.primaryStore.rootStore)),de=(0,et.encode)([IS,B,{value:Te,expiresAt:fe.expiresAt,version:fe.version,residencyId:fe.residencyId,nodeId:fe.nodeId,user:fe.user}])}else de=(0,et.encode)([IS,B])}catch(me){de=(0,et.encode)([IS,B,{error:me.message}])}e.send(de);break}case IS:{let{resolve:B,reject:de,tableId:me,key:Se}=y.get(P[1]),ee=P[2];if(ee?.error)de(new Error(ee.error));else if(ee){let J;BE(()=>{let he=Zc[me].decoder.decode(ee.value);ee.value=he,ee.key=Se,B(ee)||J&&setTimeout(()=>J.forEach(vE),6e4).unref()},f?.rootStore,he=>{let Te=el(he,Se);return J||(J=[]),J.push(Te),Te})}else B();y.delete(P[1]);break}case n$:{br=L;let B,de,me=!1;if(p){if(u!==p.databaseName&&!p.then){ae.error?.("Subscription request for wrong database",u,p.databaseName);return}}else p=d.get(u);if(ae.debug?.(s,"received subscription request for",u,"at",br),!p){let _e;p=new Promise(tt=>{ae.debug?.("Waiting for subscription to database "+u),_e=tt}),p.ready=_e,mc.set(u,p)}if(r.name)de=Vt().subscribe(r.name),de.then(async _e=>{B=_e;for await(let tt of B){let rt=tt.value;if(!(rt?.replicates===!0||rt?.replicates?.receives||rt?.subscriptions?.some(dr=>(dr.database||dr.schema)===u&&dr.publish!==!1))){me=!0,e.send((0,et.encode)([Hd])),Cs(1008,`Unauthorized database subscription to ${u}`);return}}},_e=>{ae.error?.(s,"Error subscribing to HDB nodes",_e)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,et.encode)([Hd])),Cs(1008,`Unauthorized database subscription to ${u}`);return}if(Mr&&(ae.debug?.(s,"stopping previous subscription",u),Mr.emit("close")),br.length===0)return;let Se=br[0],ee=o(_e=>{if(_e&&(Se.replicateByDefault?!Se.tables.includes(_e.tableName):Se.tables.includes(_e.tableName)))return{table:_e}},"tableToTableEntry"),J={txnTime:0},he,Te,fe=1/0,We,gt=o((_e,tt)=>{if(_e.type==="end_txn"){J.txnTime&&(a[i]!==66&&ae.error?.("Invalid encoding of message"),Gu(9),Gu(DS),rl(We=tt),ft()),i=c,J.txnTime=0;return}let rt=_e.nodeId,dr=_e.tableId,Mt=Te[dr];if(!Mt&&(Mt=Te[dr]=ee(p.tableById[dr]),!Mt))return ae.debug?.("Not subscribed to table",dr);let Ps=Mt.table,vt=Ps.primaryStore,ui=vt.encoder;(_e.extendedType&US||!ui.typedStructs)&&(ui._mergeStructures(ui.getStructures()),ui.typedStructs&&(ui.lastTypedStructuresLength=ui.typedStructs.length));let $u=he[rt];if(!($u&&$u.startTime<tt&&(!$u.endTime||$u.endTime>tt)))return CS&&ae.trace?.(s,"skipping replication update",_e.recordId,"to:",g,"from:",rt,"subscribed:",he),uv();CS&&ae.trace?.(s,"sending replication update",_e.recordId,"to:",g,"from:",rt,"subscribed:",he);let MA=_e.version;J.txnTime!==MA&&(J.txnTime&&(CS&&ae.trace?.(s,"new txn time, sending queued txn",J.txnTime),a[i]!==66&&ae.error?.("Invalid encoding of message"),ft()),J.txnTime=MA,i=c,rl(MA));let nl=_e.residencyId,vA=ku(nl,Ps),fE;if(vA&&!vA.includes(g)){let di=ku(_e.previousResidencyId,Ps);if(di&&!di.includes(g)&&(_e.type==="put"||_e.type==="patch")||Ps.getResidencyById)return uv();let Sm=_e.recordId;ae.trace?.(s,"sending invalidation",Sm,g,"from",rt);let Tm=0;nl&&(Tm|=Kl),_e.previousResidencyId&&(Tm|=Yl);let BA,mE=null;for(let dv in Ps.indices){if(!mE){if(BA=_e.getValue(vt,!0),!BA)break;mE={}}mE[dv]=BA[dv]}fE=$l(_e.version,dr,Sm,null,rt,_e.user,_e.type==="put"||_e.type==="patch"?"invalidate":_e.type,ui.encode(mE),Tm,nl,_e.previousResidencyId,_e.expiresAt)}function uv(){return ae.trace?.(s,"skipping audit record",_e.recordId),q||(q=setTimeout(()=>{q=null,(We||0)+d$/2<fe&&(CS&&ae.trace?.(s,"sending skipped sequence update",fe),e.send((0,et.encode)([c$,fe])))},d$).unref()),new Promise(setImmediate)}o(uv,"skipAuditRecord");let UA=ui.typedStructs,xA=ui.structures;if((UA?.length!=Mt.typed_length||xA?.length!=Mt.structure_length)&&(Mt.typed_length=UA?.length,Mt.structure_length=xA.length,ae.debug?.(s,"send table struct",Mt.typed_length,Mt.structure_length),Mt.sentName||(Mt.sentName=!0),e.send((0,et.encode)([nO,{typedStructs:UA,structures:xA,attributes:Ps.attributes,schemaDefined:Ps.schemaDefined},dr,Mt.table.tableName]))),nl&&!cE[nl]&&(e.send((0,et.encode)([o$,vA,nl])),cE[nl]=!0),fE)Gu(fE.length),tl(fE);else{let di=_e.encoded;_e.extendedType&Wr&&qm(()=>_e.getValue(vt),Tm=>Ua(Tm,_e.recordId),vt.rootStore);let Sm=di[0]===66?8:0;Gu(di.length-Sm),tl(di,Sm),ae.trace?.("wrote record",_e.recordId,"length:",di.length)}return e._socket.writableNeedDrain?new Promise(di=>{ae.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",di)}):xe>pm?new Promise(di=>{Ar=di}):new Promise(setImmediate)},"sendAuditRecord"),ft=o(()=>{c-i>8?(e.send(a.subarray(i,c)),ae.debug?.(s,"Sent message, size:",c-i),it(c-i,"bytes-sent",`${g}.${u}`,"replication","egress")):ae.debug?.(s,"skipping empty transaction")},"sendQueuedData");Mr=new uO.EventEmitter,Mr.once("close",()=>{me=!0,B?.end()});for(let{startTime:_e}of br)_e<fe&&(fe=_e);(de||Promise.resolve()).then(async()=>{p=await p,f=p.auditStore,Te=p.tableById.map(ee),he=[];for(let{name:tt,startTime:rt,endTime:dr}of br){let Mt=ES(tt,f);ae.debug?.("subscription to",tt,"using local id",Mt,"starting",rt),he[Mt]={startTime:rt,endTime:dr}}Ba(u),er||(er=zl(tt=>{tt.databaseName===u&&Ba(u)}),fm=rp(tt=>{tt===u&&(e.send((0,et.encode)([Hd])),Cs())}),e.on("close",()=>{er?.remove(),fm?.remove()})),e.send((0,et.encode)([i$,Yh(p.auditStore),br.map(({name:tt})=>tt)]));let _e=!0;do{isFinite(fe)||(ae.warn?.("Invalid sequence id "+fe),Cs(1008,"Invalid sequence id"+fe));let tt;if(_e&&!me&&(_e=!1,fe===0)){ae.info?.("Replicating all tables to",g);let rt=fe,dr=vS(f);for(let Mt in E){if(!ee(Mt))continue;let Ps=E[Mt];for(let vt of Ps.primaryStore.getRange({snapshot:!1,versions:!0})){if(me)return;if(vt.localTime>=fe){ae.trace?.(s,"Copying record from",u,Mt,vt.key,vt.localTime),rt=Math.max(vt.localTime,rt),tt=!0,qt()[ep]=1;let ui=$l(vt.version,Ps.tableId,vt.key,null,dr,null,"put",qm(()=>Ps.primaryStore.encoder.encode(vt.value),$u=>Ua($u,vt.key)),vt.metadataFlags&-256,vt.residencyId,null,vt.expiresAt);await gt({recordId:vt.key,tableId:Ps.tableId,type:"put",getValue(){return vt.value},encoded:ui,version:vt.version,residencyId:vt.residencyId,nodeId:dr,extendedType:vt.metadataFlags},vt.localTime)}}}tt&>({type:"end_txn"},fe),qt()[ep]=0,fe=rt}for(let{key:rt,value:dr}of f.getRange({start:fe||1,exclusiveStart:!0,snapshot:!1})){if(me)return;let Mt=bt(dr);ae.debug?.("sending audit record",new Date(rt)),qt()[ep]=rt,fe=rt,await gt(Mt,rt),Mr.startTime=rt,tt=!0}tt&>({type:"end_txn"},fe),qt()[ep]=0,await wG(f)}while(!me)}).catch(_e=>{ae.error?.(s,"Error handling subscription to node",_e),Cs(1008,"Error handling subscription to node")});break}}return}S.position=8;let A=!0,b,I;do{qt();let P=S.readInt();if(P===9&&S.getUint8(S.position)==DS){S.position++,R=I=S.readFloat64(),m[aO]=R,m[cO]=Date.now(),m[lO]=A$,ae.trace?.("received remote sequence update",R,u);break}let D=S.position,L=bt(_,D,D+P),k=Zc[L.tableId];k||ae.error?.(`No table found with an id of ${L.tableId}`);let C;L.residencyId&&(C=lE[L.residencyId],ae.trace?.(s,"received residency list",C,L.type,L.recordId));try{let x=L.recordId;BE(()=>{b={table:k.name,id:L.recordId,type:L.type,nodeId:Em.get(L.nodeId),residencyList:C,timestamp:L.version,value:L.getValue(k),user:L.user,beginTxn:A,expiresAt:L.expiresAt}},f?.rootStore,z=>el(z,x))}catch(x){throw x.message+="typed structures for current decoder"+JSON.stringify(k.decoder.typedStructs),x}A=!1,ae.trace?.(s,"received replication message",L.type,"id",b.id,"version",new Date(L.version),"nodeId",b.nodeId),m[aO]=L.version,m[cO]=Date.now(),m[lO]=b$,p.send(b),S.position=D+P}while(S.position<_.byteLength);Pe++,it(_.byteLength,"bytes-received",`${g}.${u}.${b?.table||"unknown_table"}`,"replication","ingest"),Pe>LA&&!_m&&(_m=!0,e.pause(),ae.debug?.(`Commit backlog causing replication back-pressure, requesting that ${g} pause replication`)),p.send({type:"end_txn",localTime:R,remoteNodeIds:T,async onCommit(){if(b){let P=Date.now()-b.timestamp;it(P,"replication-latency",g+"."+u+"."+b.table,b.type,"ingest")}Pe--,_m&&(_m=!1,e.resume(),ae.debug?.(`Replication resuming ${g}`)),Ue.length>0&&await Promise.all(Ue),ae.trace?.("All blobs finished"),!N&&I&&(ae.trace?.(s,"queuing confirmation of a commit at",I),setTimeout(()=>{e.send((0,et.encode)([l$,N])),ae.trace?.(s,"sent confirmation of a commit at",N),N=null},Dle)),N=I,ae.debug?.("last sequence committed",new Date(I),u)}})}catch(S){ae.error?.(s,"Error handling incoming replication message",S)}}),e.on("ping",Zt),e.on("pong",()=>{if(t.connection){let _=performance.now()-Z;t.connection.latency=_,qt()&&(m[LS]=_),t.isSubscriptionConnection&&kl({name:g,database:u,url:t.url,latency:_})}Z=null}),e.on("close",(_,S)=>{clearInterval(O),clearTimeout(F),clearInterval(Y),Mr&&Mr.emit("close"),Po&&Po.end();for(let[A,{reject:b}]of y)b(new Error(`Connection closed ${S?.toString()} ${_}`));ae.debug?.(s,"closed",_,S?.toString())});function Cs(_,S){try{e.isFinished=!0,ae.debug?.(s,"closing",g,u,_,S),e.close(_,S),t.connection?.emit("finished")}catch(A){ae.error?.(s,"Error closing connection",A)}}o(Cs,"close");let va=new Set;async function Ua(_,S){let A=UE(_);if(va.has(A)){ae.debug?.("Blob already being sent",A);return}va.add(A);try{let b;xe++;for await(let I of _.stream())b&&(ae.debug?.("Sending blob chunk",A,"length",b.length),e.send((0,et.encode)([wS,{fileId:A,size:_.size},b]))),b=I,e._socket.writableNeedDrain&&(ae.debug?.("draining",A),await new Promise(P=>e._socket.once("drain",P)),ae.debug?.("drained",A)),it(I.length,"bytes-sent",`${g}.${u}`,"replication","blob");ae.debug?.("Sending final blob chunk",A,"length",b.length),e.send((0,et.encode)([wS,{fileId:A,size:_.size,finished:!0},b]))}catch(b){ae.warn?.("Error sending blob",b,"blob id",A,"for record",S),e.send((0,et.encode)([wS,{fileId:A,finished:!0,error:(0,kd.errorToString)(b)},Buffer.alloc(0)]))}finally{va.delete(A),xe--,xe<pm&&Ar?.()}}o(Ua,"sendBlobs");function el(_,S){let A=UE(_),b=Ne.get(A);ae.debug?.("Received transaction with blob",A,"has stream",!!b,"ended",!!b?.writableEnded),b?b.writableEnded&&Ne.delete(A):(b=new iO.PassThrough,Ne.set(A,b)),b.connectedToBlob=!0,b.lastChunk=Date.now(),b.recordId=S,_.size===void 0&&b.expectedSize&&(_.size=b.expectedSize);let I=b.blob??createBlob(b,_);b.blob=I;let P=vo(()=>km(I).saving,p.auditStore?.rootStore);return P&&(P.blobId=A,Ue.push(P),P.finally(()=>{ae.debug?.(`Finished receiving blob stream ${A}`),Ue.splice(Ue.indexOf(P),1)})),I}o(el,"receiveBlobs");function vr(){if(h||(h=!0,t.connection?.on("subscriptions-updated",vr)),!f&&p&&(f=p.auditStore),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let _=new Map;f||(f=p?.auditStore);try{for(let b of p?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let I of b.value.nodes||[])I.lastTxnTime>(_.get(I.id)??0)&&_.set(I.id,I.lastTxnTime)}catch(b){if(!b.message.includes("Can not re"))throw b}let S=t.connection?.nodeSubscriptions?.[0];T=[];let A=t.connection?.nodeSubscriptions.map((b,I)=>{let P=[],{replicateByDefault:D}=b;if(b.subscriptions){for(let x of b.subscriptions)if(x.subscribe&&(x.schema||x.database)===u){let z=x.table;E?.[z]?.replicate!==!1&&P.push(z)}D=!1}else for(let x in E)(D?E[x].replicate===!1:E[x].replicate)&&P.push(x);let L=f&&ES(b.name,f),k=p?.dbisDB?.get([Symbol.for("seq"),L])??1,C=Math.max(k?.seqId??1,(typeof b.startTime=="string"?new Date(b.startTime).getTime():b.startTime)??1);if(ae.debug?.("Starting time recorded in db",b.name,L,u,k?.seqId,"start time:",C,new Date(C)),S!==b){let x=f&&ES(S.name,f),z=p?.dbisDB?.get([Symbol.for("seq"),x])??1;for(let ne of z?.nodes||[])ne.name===b.name&&(C=ne.seqId,ae.debug?.("Using sequence id from proxy node",S.name,C))}if(L===void 0?ae.warn("Starting subscription request from node",b,"but no node id found"):T.push(L),_.get(L)>C&&(C=_.get(L),ae.debug?.("Updating start time from more recent txn recorded",S.name,C)),C===1&&OS)try{new URL(OS).hostname===b.name?(ae.warn?.(`Requesting full copy of database ${u} from ${OS}`),C=0):C=Date.now()-6e4}catch(x){ae.error?.("Error parsing leader URL",OS,x)}return ae.trace?.(s,"defining subscription request",b.name,u,new Date(C)),{name:b.name,replicateByDefault:D,tables:P,startTime:C,endTime:b.endTime}});if(A)if(ae.debug?.(s,"sending subscription request",A,p?.dbisDB?.path),clearTimeout(K),A.length>0)e.send((0,et.encode)([n$,A]));else{let b=o(()=>{let I=performance.now();K=setTimeout(()=>{ce<=I?Cs(1008,"Connection has no subscriptions and is no longer used"):b()},G).unref()},"scheduleClose");b()}}o(vr,"sendSubscriptionRequestUpdate");function ku(_,S){if(!_)return;let A=hm[_];return A||(A=S.getResidencyRecord(_),hm[_]=A),A}o(ku,"getResidence");function qu(_){return!(fc&&fc!="*"&&!fc[_]&&!fc.includes?.(_)&&!fc.some?.(S=>S.name===_))}o(qu,"checkDatabaseAccess");function xa(_){if(p=p||d.get(_),!qu(_))throw new Error(`Access to database "${_}" is not permitted`);p||ae.warn?.(`No database named "${_}" was declared and registered`),f=p?.auditStore,E||(E=st()?.[_]);let S=Ze();if(S===g)throw S?new Error("Should not connect to self",S):new Error("Node name not defined");return dE(S,_),!0}o(xa,"setDatabase");function dE(_,S){let A=st()?.[S],b=[];for(let I in A){let P=A[I];b.push({table:I,schemaDefined:P.schemaDefined,attributes:P.attributes.map(D=>({name:D.name,type:D.type,isPrimaryKey:D.isPrimaryKey}))})}ae.trace?.("Sending database info for node",_,"database name",S),e.send((0,et.encode)([s$,_,S,b]))}o(dE,"sendNodeDBName");function Ba(_){let S=st()?.[_],A=[];for(let b in S){if(br&&!br.some(P=>P.replicateByDefault?!P.tables.includes(b):P.tables.includes(b)))continue;let I=S[b];A.push({table:b,schemaDefined:I.schemaDefined,attributes:I.attributes.map(P=>({name:P.name,type:P.type,isPrimaryKey:P.isPrimaryKey}))})}e.send((0,et.encode)([u$,A,_]))}o(Ba,"sendDBSchema"),Y=setInterval(()=>{for(let[_,S]of Ne)S.lastChunk+pe<Date.now()&&(ae.warn?.(`Timeout waiting for blob stream to finish ${_} for record ${S.recordId??"unknown"} from ${g}`),Ne.delete(_),S.end())},pe).unref();let Fa=1,gm=[];return{end(){Po&&Po.end(),Mr&&Mr.emit("close")},getRecord(_){let S=Fa++;return new Promise((A,b)=>{let I=[a$,S,_.table.tableId,_.id];gm[_.table.tableId]||(I.push(_.table.tableName),gm[_.table.tableId]=!0),e.send((0,et.encode)(I)),ce=performance.now(),y.set(S,{tableId:_.table.tableId,key:_.id,resolve(P){let{table:D,entry:L}=_;if(A(P),P)return D._recordRelocate(L,P)},reject:b})})},sendOperation(_){let S=Fa++;return _.requestId=S,e.send((0,et.encode)([oO,_])),new Promise((A,b)=>{y.set(S,{resolve:A,reject:b})})}};function Gu(_){Ha(5),_<128?a[c++]=_:_<16384?(l.setUint16(c,_|32768),c+=2):_<1056964608?(l.setUint32(c,_|3221225472),c+=4):(a[c]=255,l.setUint32(c+1,_),c+=5)}function tl(_,S=0,A=_.length){let b=A-S;Ha(b),_.copy(a,c,S,A),c+=b}function rl(_){Ha(8),l.setFloat64(c,_),c+=8}function Ha(_){if(_+16>a.length-c){let S=Buffer.allocUnsafeSlow(c+_-i+65536>>10<<11);a.copy(S,0,i,c),c=c-i,i=0,a=S,l=new DataView(a.buffer,0,a.length)}}function V(_,S){let A=_.database??"data";if(A!=="data"&&!ke[A]){ae.warn?.("Database not found",_.database);return}S||(S={});let b=S.schemaDefined,I=!1,P=_.schemaDefined,D=S.attributes||[];for(let L=0;L<_.attributes?.length;L++){let k=_.attributes[L],C=D.find(x=>x.name===k.name);(!C||C.type!==k.type)&&(b?ae.error?.(`Schema for '${u}.${_.table}' is defined locally, but attribute '${k.name}: ${k.type}' from '${g}' does not match local attribute ${C?"'"+C.name+": "+C.type+"'":"which does not exist"}`):(I=!0,P||(k.indexed=!0),C?D[D.indexOf(C)]=k:D.push(k)))}return I?(ae.debug?.("(Re)creating",_),ze({table:_.table,database:_.database,schemaDefined:_.schemaDefined,attributes:D,...S})):S}}var h$,et,p$,_$,kd,uO,E$,g$,Vl,S$,iO,T$,R$,ae,n$,s$,i$,Hd,o$,nO,a$,IS,oO,NS,c$,l$,u$,wS,y$,aO,cO,ep,LS,lO,A$,b$,Ple,OS,dO,mc,CS,d$,Dle,f$,sO,PS,m$,qd,fO=ue(()=>{De();Yi();xw();kw();qn();h$=w(oe());H();fl();et=require("msgpackr"),p$=require("ws"),_$=require("worker_threads"),kd=w(j());Qh();uO=require("events"),E$=w(_n()),g$=w(require("node:tls"));Hl();Vl=w(require("node:process")),S$=require("node:net");io();ts();iO=require("node:stream"),T$=require("lmdb"),R$=w(require("minimist")),ae=(0,kd.forComponent)("replication").conditional,n$=129,s$=140,i$=141,Hd=142,o$=130,nO=132,a$=133,IS=134,oO=136,NS=137,c$=143,l$=144,u$=145,wS=146,y$=0,aO=1,cO=2,ep=3,LS=4,lO=5,A$=0,b$=1,Ple=(0,R$.default)(Vl.argv),OS=Ple.HDB_LEADER_URL??Vl.env.HDB_LEADER_URL,dO=new Map,mc=new Map,CS=!0,d$=300,Dle=2,f$=3e4;o(MS,"createWebSocket");m$=500,qd=class extends uO.EventEmitter{static{o(this,"NodeReplicationConnection")}socket;startTime;retryTime=m$;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??wi(t)}async connect(){this.session||this.resetSession();let t=[];this.socket=await MS(this.url,{serverName:this.nodeName,authorization:this.authorization});let r;ae.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${Vl.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),ae[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=m$,this.nodeSubscriptions&&kl({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,r=tp(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"?(ae.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"?ae.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`):ae.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&&xd({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();ae.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(tp,"replicateOverWS")});var uo={};Oe(uo,{clearThisNodeName:()=>kle,disableReplication:()=>Ule,enabledDatabases:()=>fc,forEachReplicatedDatabase:()=>oc,getThisNodeId:()=>vS,getThisNodeName:()=>Ze,getThisNodeUrl:()=>ac,hostnameToUrl:()=>kS,lastTimeInAuditStore:()=>Wh,monitorNodeCAs:()=>v$,replicateOperation:()=>Gle,replicationCertificateAuthorities:()=>Jo,sendOperationToNode:()=>np,servers:()=>Mle,setReplicator:()=>x$,start:()=>vle,startOnMainThread:()=>Vw,subscribeToNode:()=>Jh,unsubscribeFromNode:()=>TS,urlToNodeName:()=>wi});function vle(e){if(!e.port&&!e.securePort&&(e.port=Hs.default.get(U.OPERATIONSAPI_NETWORK_PORT),e.securePort=Hs.default.get(U.OPERATIONSAPI_NETWORK_SECUREPORT)),!Ze())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let s of jh(e))t.set(wi(s.url),s);xle(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=Le.ws(async(s,i,a,c)=>{if(Ot.debug("Incoming WS connection received "+i.url),i.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return c(s,i,a);await a,s._socket.unref(),tp(s,e,i?.user),s.on("error",l=>{l.code!=="ECONNREFUSED"&&Ot.error("Error in connection to "+this.url,l.message)})},e);e.runFirst=!0,Le.http((s,i)=>{if(s.isWebSocket&&s.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){Ot.debug("Incoming replication WS connection received, authorized: "+s.authorized),!s.authorized&&s._nodeRequest.socket.authorizationError&&Ot.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=Vt().primaryStore;if(s.authorized&&s.peerCertificate.subjectaltname){let c=(0,L$.getHostnamesFromCertificate)(s.peerCertificate),l;for(let u of c)if(l=u&&(a.get(u)||t.get(u)),l)break;if(l)if(l?.revoked_certificates?.includes(s.peerCertificate.serialNumber)){Ot.warn("Revoked certificate used in attempt to connect to node",l.name,"certificate serial number",s.peerCertificate.serialNumber);return}else s.user=l;else Ot.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:Ot.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(Jo);c.options.availableCAs&&l.push(...c.options.availableCAs.values());let u={...c.options,ca:l};c.updatedContext=HS.createSecureContext(u)}catch(l){Ot.error("Error creating replication TLS config",l)}},"updateContexts");s.secureContextsListeners.push(i),n.push(i),Hs.default.get(U.REPLICATION_ENABLEROOTCAS)!==!1&&i()}v$(()=>{for(let s of n)s()})}function v$(e){let t=0;vd(r=>{r?.ca&&(Jo.add(r.ca),Jo.size!==t&&(t=Jo.size,e?.()))})}function Ule(e=!0){M$=e}function xle(e){M$||(st(),fc=e.databases,oc(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||mc;for(let[s,i]of BS){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];x$(r,s,e),dO.get(s)?.forEach(i=>i(s))}}))}function x$(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 U$ extends kr{static{o(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||mc,a=i.get(e),c=a?.tableById||[];c[t.tableId]=t;let l=a?.ready;if(Ot.trace("Setting up replicator subscription to database",e),!a?.auditStore)return this.subscription=a=new es,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 p of c){if(u.has(p)||p===Le.hostname)continue;let E=Fle(p,U$.subscription,e);if(E?.isConnected){let g=Md(t.auditStore,e,p)[LS];(!d||g<m)&&(d=E,f=p,m=g)}}if(!d)throw l||new P$.ServerError(`No connection to any other nodes are available: ${c}`,502);let h={requestId:Lle++,table:t,entry:i,id:i.key};u.add(f);try{return await d.getRecord(h)}catch(p){if(d.isConnected)throw p;Ot.warn("Error in load from node",FS,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function Ble(e,t,r,n,s){let i=BS.get(e);i||BS.set(e,i=new Map);let a=i.get(r);if(a)return a;if(t)return i.set(r,a=new qd(e,t,r,n,s)),a.connect(),a.once("finished",()=>i.delete(r)),a}function Fle(e,t,r){let n=N$.get(e);n||(n=new Map,N$.set(e,n));let s=n.get(r);if(s)return s;let i=Vt().primaryStore.get(e);return i?.url&&(s=new qd(i.url,t,r,e,i.authorization),n.set(r,s),s.connect(),s.once("finished",()=>n.delete(r))),s}async function np(e,t,r){r||(r={}),r.serverName=e.name;let n=await MS(e.url,r),s=tp(n,{},{});return new Promise((i,a)=>{n.on("open",()=>{Ot.debug("Sending operation connection to "+e.url+" opened",t),i(s.sendOperation(t))}),n.on("error",c=>{a(c)}),n.on("close",c=>{Ot.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function Jh(e){try{D$.isMainThread&&Ot.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=mc.get(e.database);if(!t){let n;t=new Promise(s=>{Ot.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,mc.set(e.database,t)}let r=Ble(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=>zh(n,e.database)),e.replicateByDefault)}catch(t){Ot.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function TS({name:e,url:t,database:r}){Ot.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(Vt().primaryStore.getRange({})));let n=BS.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Hle(){if(mO!==void 0)return mO;let e=Hs.default.get(U.OPERATIONSAPI_TLS_CERTIFICATE)||Hs.default.get(U.TLS_CERTIFICATE);if(e)return mO=new O$.X509Certificate((0,C$.readFileSync)(e)).subject?.match(/CN=(.*)/)?.[1]??null}function Ze(){return FS||(FS=Hs.default.get("replication_hostname")??wi(Hs.default.get("replication_url"))??Hle()??w$("operationsapi_network_secureport")??w$("operationsapi_network_port")??"127.0.0.1")}function kle(){FS=void 0}function w$(e){let t=Hs.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function xS(e){let t=Hs.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function vS(e){return Yh(e)?.[Ze()]}function ac(){let e=Hs.default.get("replication_url");return e||kS(Ze())}function kS(e){let t=xS("replication_port");if(t)return`ws://${e}:${t}`;if(t=xS("replication_secureport"),t)return`wss://${e}:${t}`;if(t=xS("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=xS("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function wi(e){if(e)return new URL(e).hostname}function oc(e,t){for(let n of Object.getOwnPropertyNames(ke))r(n);return rp(n=>{r(n)}),zl((n,s)=>{r(n.databaseName)});function r(n){let s=ke[n];Ot.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):qle(n)&&t(s,n,!1)}o(r,"forDatabase")}function qle(e){let t=ke[e];for(let r in t)if(t[r].replicate)return!0}function Wh(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function Gle(e){let t={message:""};if(e.replicated){e.replicated=!1,Ot.trace?.("Replicating operation",e.operation,"to nodes",Le.nodes.map(n=>n.name));let r=await Promise.allSettled(Le.nodes.map(n=>np(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=Le.nodes[s]?.name,i})}return t}var Hs,Ot,O$,C$,HS,P$,D$,L$,M$,Lle,Mle,Jo,fc,BS,N$,mO,FS,qn=ue(()=>{De();tc();Wu();fO();Ur();Hs=w(oe()),Ot=w(j()),O$=require("crypto"),C$=require("fs");Qh();Hl();H();xw();HS=w(require("node:tls")),P$=w(ge()),D$=require("worker_threads"),L$=w(_n()),Lle=1,Mle=[],Jo=Hs.default.get(U.REPLICATION_ENABLEROOTCAS)!==!1?new Set(HS.rootCertificates):new Set;o(vle,"start");o(v$,"monitorNodeCAs");o(Ule,"disableReplication");o(xle,"assignReplicationSource");o(x$,"setReplicator");BS=new Map;o(Ble,"getSubscriptionConnection");N$=new Map;o(Fle,"getRetrievalConnectionByName");o(np,"sendOperationToNode");o(Jh,"subscribeToNode");o(TS,"unsubscribeFromNode");o(Hle,"getCommonNameFromCert");o(Ze,"getThisNodeName");o(kle,"clearThisNodeName");Object.defineProperty(Le,"hostname",{get(){return Ze()}});o(w$,"getHostFromListeningPort");o(xS,"getPortFromListeningPort");o(vS,"getThisNodeId");Le.replication={getThisNodeId:vS,exportIdMapping:Yh};o(ac,"getThisNodeUrl");o(kS,"hostnameToUrl");o(wi,"urlToNodeName");o(oc,"forEachReplicatedDatabase");o(qle,"hasExplicitlyReplicatedTable");o(Wh,"lastTimeInAuditStore");o(Gle,"replicateOperation")});var ip=M((f0e,q$)=>{"use strict";var $d=Kq(),{validateBySchema:sp}=lt(),{commonValidators:Vd,schemaRegex:hO}=Ji(),Er=require("joi"),$le=j(),Vle=require("uuid").v4,$S=Vo(),Kd=(H(),v(W)),Kle=require("util"),hc=is(),{handleHDBError:Qo,hdbErrors:Yle,ClientError:jl}=ge(),{HDB_ERROR_MSGS:qS,HTTP_STATUS_CODES:Xo}=Yle,{SchemaEventMsg:VS}=Ti(),B$=sr(),{getDatabases:Wle}=(De(),v(ut)),{transformReq:Yd}=se(),{replicateOperation:F$}=(qn(),v(uo)),{cleanupOrphans:zle}=(ts(),v(FE)),GS=Er.string().min(1).max(Vd.schema_length.maximum).pattern(hO).messages({"string.pattern.base":"{:#label} "+Vd.schema_format.message}),jle=Er.string().min(1).max(Vd.schema_length.maximum).pattern(hO).messages({"string.pattern.base":"{:#label} "+Vd.schema_format.message}).required(),Jle=Er.string().min(1).max(Vd.schema_length.maximum).pattern(hO).messages({"string.pattern.base":"{:#label} "+Vd.schema_format.message,"any.required":"'primary_key' is required","string.base":"'primary_key' must be a string"}).required();q$.exports={createSchema:Qle,createSchemaStructure:H$,createTable:Xle,createTableStructure:k$,createAttribute:nue,dropSchema:Zle,dropTable:eue,dropAttribute:tue,getBackup:sue,cleanupOrphanBlobs:iue};async function Qle(e){let t=await H$(e);return $S.signalSchemaChange(new VS(process.pid,e.operation,e.schema)),t}o(Qle,"createSchema");async function H$(e){let t=sp(e,Er.object({database:GS,schema:GS}));if(t)throw new jl(t.message);if(Yd(e),!await $d.checkSchemaExists(e.schema))throw Qo(new Error,qS.SCHEMA_EXISTS_ERR(e.schema),Xo.BAD_REQUEST,Kd.LOG_LEVELS.ERROR,qS.SCHEMA_EXISTS_ERR(e.schema),!0);return await hc.createSchema(e),`database '${e.schema}' successfully created`}o(H$,"createSchemaStructure");async function Xle(e){return Yd(e),e.hash_attribute=e.primary_key??e.hash_attribute,await k$(e)}o(Xle,"createTable");async function k$(e){let t=sp(e,Er.object({database:GS,schema:GS,table:jle,residence:Er.array().items(Er.string().min(1)).optional(),hash_attribute:Jle}));if(t)throw new jl(t.message);if(!await $d.checkSchemaTableExists(e.schema,e.table))throw Qo(new Error,qS.TABLE_EXISTS_ERR(e.schema,e.table),Xo.BAD_REQUEST,Kd.LOG_LEVELS.ERROR,qS.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Vle(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await hc.createTable(n,e);else throw Qo(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Xo.BAD_REQUEST);else await hc.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}o(k$,"createTableStructure");async function Zle(e){let t=sp(e,Er.object({database:Er.string(),schema:Er.string()}).or("database","schema").messages({"object.missing":"'database' is required"}));if(t)throw new jl(t.message);Yd(e);let r=await $d.checkSchemaExists(e.schema);if(r)throw Qo(new Error,r,Xo.NOT_FOUND,Kd.LOG_LEVELS.ERROR,r,!0);let n=await $d.schemaDescribe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await hc.dropSchema(e),$S.signalSchemaChange(new VS(process.pid,e.operation,e.schema)),await B$.purgeSchemaTableStreams(e.schema,s);let i=await F$(e);return i.message=`successfully deleted '${e.schema}'`,i}o(Zle,"dropSchema");async function eue(e){let t=sp(e,Er.object({database:Er.string(),schema:Er.string(),table:Er.string().required()}));if(t)throw new jl(t.message);Yd(e);let r=await $d.checkSchemaTableExists(e.schema,e.table);if(r)throw Qo(new Error,r,Xo.NOT_FOUND,Kd.LOG_LEVELS.ERROR,r,!0);await hc.dropTable(e),await B$.purgeTableStream(e.schema,e.table);let n=await F$(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}o(eue,"dropTable");async function tue(e){let t=sp(e,Er.object({database:Er.string(),schema:Er.string(),table:Er.string().required(),attribute:Er.string().required()}));if(t)throw new jl(t.message);Yd(e);let r=await $d.checkSchemaTableExists(e.schema,e.table);if(r)throw Qo(new Error,r,Xo.NOT_FOUND,Kd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Qo(new Error,"You cannot drop a hash attribute",Xo.BAD_REQUEST,void 0,void 0,!0);if(Kd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Qo(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Xo.BAD_REQUEST,void 0,void 0,!0);try{return await hc.dropAttribute(e),rue(e),$S.signalSchemaChange(new VS(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw $le.error(`Got an error deleting attribute ${Kle.inspect(e)}.`),n}}o(tue,"dropAttribute");function rue(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(rue,"dropAttributeFromGlobal");async function nue(e){Yd(e);let t=Wle()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Qo(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Xo.BAD_REQUEST,void 0,void 0,!0);return await hc.createAttribute(e),$S.signalSchemaChange(new VS(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}o(nue,"createAttribute");function sue(e){return hc.getBackup(e)}o(sue,"getBackup");function iue(e){if(!e.database)throw new jl('Must provide "database" name for search for orphaned blobs');if(!databases[e.database])throw new jl(`Unknown database '${e.database}'`);return zle(databases[e.database],e.database),{message:"Orphaned blobs cleanup started, check logs for progress"}}o(iue,"cleanupOrphanBlobs")});var $$=M((h0e,G$)=>{"use strict";var{OPERATIONS_ENUM:oue}=(H(),v(W)),pO=class{static{o(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=oue.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};G$.exports=pO});var _O=M((E0e,z$)=>{"use strict";var aue=is(),_0e=$$(),KS=se(),YS=(H(),v(W)),cue=oe(),{handleHDBError:V$,hdbErrors:lue}=ge(),{HDB_ERROR_MSGS:K$,HTTP_STATUS_CODES:Y$}=lue,uue=Object.values(YS.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),W$="To use this operation audit log must be enabled in harperdb-config.yaml";z$.exports=due;async function due(e){if(KS.isEmpty(e.schema))throw new Error(K$.SCHEMA_REQUIRED_ERR);if(KS.isEmpty(e.table))throw new Error(K$.TABLE_REQUIRED_ERR);if(!cue.get(YS.CONFIG_PARAMS.LOGGING_AUDITLOG))throw V$(new Error,W$,Y$.BAD_REQUEST,YS.LOG_LEVELS.ERROR,W$,!0);let t=KS.checkSchemaTableExist(e.schema,e.table);if(t)throw V$(new Error,t,Y$.NOT_FOUND,YS.LOG_LEVELS.ERROR,t,!0);if(!KS.isEmpty(e.search_type)&&uue.indexOf(e.search_type)<0)throw new Error(`Invalid searchType '${read_audit_log_object.search_type}'`);return await aue.readAuditLog(e)}o(due,"readAuditLog")});var J$=M((S0e,j$)=>{"use strict";var{OPERATIONS_ENUM:fue}=(H(),v(W)),EO=class{static{o(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=fue.GET_BACKUP,this.schema=t,this.table=r}};j$.exports=EO});var Z$=M((A0e,X$)=>{"use strict";var mue=is(),R0e=J$(),gO=se(),hue=(H(),v(W)),y0e=oe(),{handleHDBError:pue,hdbErrors:_ue}=ge(),{HDB_ERROR_MSGS:Q$,HTTP_STATUS_CODES:Eue}=_ue;X$.exports=gue;async function gue(e){if(gO.isEmpty(e.schema))throw new Error(Q$.SCHEMA_REQUIRED_ERR);if(gO.isEmpty(e.table))throw new Error(Q$.TABLE_REQUIRED_ERR);let t=gO.checkSchemaTableExist(e.schema,e.table);if(t)throw pue(new Error,t,Eue.NOT_FOUND,hue.LOG_LEVELS.ERROR,t,!0);return await mue.getBackup(readAuditLogObject)}o(gue,"getBackup")});var nV=M((I0e,rV)=>{"use strict";var Sue=oe(),pc=require("joi"),Tue=lt(),eV=require("moment"),Rue=require("fs-extra"),SO=require("path"),yue=require("lodash"),op=(H(),v(W)),{LOG_LEVELS:Jl}=(H(),v(W)),Aue="YYYY-MM-DD hh:mm:ss",bue=SO.resolve(__dirname,"../logs");rV.exports=function(e){return Tue.validateBySchema(e,Iue)};var Iue=pc.object({from:pc.custom(tV),until:pc.custom(tV),level:pc.valid(Jl.NOTIFY,Jl.FATAL,Jl.ERROR,Jl.WARN,Jl.INFO,Jl.DEBUG,Jl.TRACE),order:pc.valid("asc","desc"),limit:pc.number().min(1),start:pc.number().min(0),log_name:pc.custom(Nue)});function tV(e,t){if(eV(e,eV.ISO_8601).format(Aue)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}o(tV,"validateDatetime");function Nue(e,t){if(yue.invert(op.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Sue.get(op.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?op.LOG_NAMES.HDB:e,i=s===op.LOG_NAMES.INSTALL?SO.join(bue,op.LOG_NAMES.INSTALL):SO.join(n,s);return Rue.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}o(Nue,"validateReadLogPath")});var RO=M((w0e,iV)=>{"use strict";var WS=(H(),v(W)),wue=j(),Oue=oe(),Cue=nV(),TO=require("path"),sV=require("fs-extra"),{once:Pue}=require("events"),{handleHDBError:Due,hdbErrors:Lue}=ge(),{PACKAGE_ROOT:Mue}=mt(),{replicateOperation:vue}=(qn(),v(uo)),Uue=TO.join(Mue,"logs"),xue=1e3,Bue=200;iV.exports=Fue;async function Fue(e){let t=Cue(e);if(t)throw Due(t,t.message,Lue.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=vue(e),n=Oue.get(WS.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e.log_name===void 0?WS.LOG_NAMES.HDB:e.log_name,i=s===WS.LOG_NAMES.INSTALL?TO.join(Uue,WS.LOG_NAMES.INSTALL):TO.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?xue:e.limit,h=e.order===void 0?void 0:e.order,p=e.start===void 0?0:e.start,E=p+m,g=0;h==="desc"&&!u&&!f&&(g=Math.max(sV.statSync(i).size-(E+5)*Bue,0));let y=sV.createReadStream(i,{start:g});y.on("error",q=>{wue.error(q)});let T=0,R=[],N="",O;y.on("data",q=>{let Y=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;q=N+q;let G=0,K;for(;(K=Y.exec(q))&&!y.destroyed;){O&&(O.message=q.slice(G,K.index),F(O));let[ce,le,ie]=K,pe=ie.split("] ["),Ne=pe[0],Ue=pe[1];pe.splice(0,2),O={timestamp:le,thread:Ne,level:Ue,tags:pe,message:""},G=K.index+ce.length}N=q.slice(G)}),y.on("end",q=>{y.destroyed||O&&(O.message=N.trim(),F(O))}),y.resume();function F(q){let Y,G,K;switch(!0){case(a&&l&&d):Y=new Date(q.timestamp),G=new Date(u),K=new Date(f),q.level===c&&Y>=G&&Y<=K&&T<p?T++:q.level===c&&Y>=G&&Y<=K&&(fo(q,h,R),T++,T===E&&y.destroy());break;case(a&&l):Y=new Date(q.timestamp),G=new Date(u),q.level===c&&Y>=G&&T<p?T++:q.level===c&&Y>=G&&(fo(q,h,R),T++,T===E&&y.destroy());break;case(a&&d):Y=new Date(q.timestamp),K=new Date(f),q.level===c&&Y<=K&&T<p?T++:q.level===c&&Y<=K&&(fo(q,h,R),T++,T===E&&y.destroy());break;case(l&&d):Y=new Date(q.timestamp),G=new Date(u),K=new Date(f),Y>=G&&Y<=K&&T<p?T++:Y>=G&&Y<=K&&(fo(q,h,R),T++,T===E&&y.destroy());break;case a:q.level===c&&T<p?T++:q.level===c&&(fo(q,h,R),T++,T===E&&y.destroy());break;case l:Y=new Date(q.timestamp),G=new Date(u),Y>=G&&T<p?T++:Y>=G&&T>=p&&(fo(q,h,R),T++,T===E&&y.destroy());break;case d:Y=new Date(q.timestamp),K=new Date(f),Y<=K&&T<p?T++:Y<=K&&T>=p&&(fo(q,h,R),T++,T===E&&y.destroy());break;default:T<p?T++:(fo(q,h,R),T++,T===E&&y.destroy())}}o(F,"onLogMessage"),await Pue(y,"close");let Z=await r;if(Z.replicated){for(let q of R)q.node=server.hostname;for(let q of Z.replicated){let Y=q.node;if(q.status==="failed")fo({timestamp:new Date().toISOString(),level:"error",node:Y,message:`Error retrieving logs: ${q.reason}`},h,R);else for(let G of q.results)G.node=Y,fo(G,h,R)}}return R}o(Fue,"readLog");function fo(e,t,r){t==="desc"?Hue(e,r):t==="asc"?kue(e,r):r.push(e)}o(fo,"pushLineToResult");function Hue(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(Hue,"insertDescending");function kue(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(kue,"insertAscending")});var zS=M((M0e,lV)=>{"use strict";var yO=require("joi"),{string:Wd,boolean:oV,date:que}=yO.types(),Gue=lt(),{validateSchemaExists:C0e,validateTableExists:P0e,validateSchemaName:D0e}=Ji(),$ue=(H(),v(W)),Vue=It(),aV=oe();aV.initSync();var L0e=Wd.invalid(aV.get($ue.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(Vue.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),cV={operation:Wd.valid("add_node","update_node","set_node_replication"),node_name:Wd.optional(),subscriptions:yO.array().items({table:Wd.optional(),schema:Wd.optional(),database:Wd.optional(),subscribe:oV.required(),publish:oV.required().custom(Yue),start_time:que.iso()})};function Kue(e){return Gue.validateBySchema(e,yO.object(cV))}o(Kue,"addUpdateNodeValidator");function Yue(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(Yue,"checkForFalsy");lV.exports={addUpdateNodeValidator:Kue,validationSchema:cV}});var zd=M((U0e,uV)=>{"use strict";var AO=class{static{o(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},bO=class{static{o(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};uV.exports={Node:AO,NodeSubscription:bO}});var fV=M((B0e,dV)=>{"use strict";var Wue=(H(),v(W)).OPERATIONS_ENUM,IO=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Wue.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};dV.exports=IO});var ap=M((H0e,mV)=>{"use strict";var NO=class{static{o(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},wO=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)}};mV.exports={RemotePayloadObject:NO,RemotePayloadSubscription:wO}});var pV=M((q0e,hV)=>{"use strict";var OO=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}};hV.exports=OO});var EV=M((W0e,_V)=>{"use strict";var zue=pV(),$0e=$t(),V0e=St(),jue=j(),{getSchemaPath:K0e,getTransactionAuditStorePath:Y0e}=At(),{getDatabases:Jue}=(De(),v(ut));_V.exports=Que;async function Que(e){let t=new zue;try{let r=Jue()[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){jue.warn(`unable to stat table dbi due to ${r}`)}return t}o(Que,"lmdbGetTableSize")});var SV=M((j0e,gV)=>{"use strict";var CO=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}};gV.exports=CO});var Zo=M((txe,AV)=>{"use strict";var Xue=require("fs-extra"),Zue=require("path"),En=require("systeminformation"),_c=j(),TV=sr(),Q0e=It(),jd=(H(),v(W)),ede=EV(),tde=za(),{getThreadInfo:RV}=nt(),cp=oe();cp.initSync();var rde=SV(),{openEnvironment:X0e}=St(),{getSchemaPath:Z0e}=At(),{database:exe,databases:PO}=(De(),v(ut)),jS;AV.exports={getHDBProcessInfo:vO,getNetworkInfo:xO,getDiskInfo:UO,getMemoryInfo:MO,getCPUInfo:LO,getTimeInfo:DO,getSystemInformation:BO,systemInformation:nde,getTableSize:FO,getMetrics:HO};function DO(){return En.time()}o(DO,"getTimeInfo");async function LO(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:a,governor:c,socket:l,cache:u,...d}=await En.cpu();d.cpu_speed=await En.cpuCurrentSpeed();let{rawCurrentload:f,rawCurrentloadIdle:m,rawCurrentloadIrq:h,rawCurrentloadNice:p,rawCurrentloadSystem:E,rawCurrentloadUser:g,cpus:y,...T}=await En.currentLoad();return T.cpus=[],y.forEach(R=>{let{rawLoad:N,rawLoadIdle:O,rawLoadIrq:F,rawLoadNice:Z,rawLoadSystem:q,rawLoadUser:Y,...G}=R;T.cpus.push(G)}),d.current_load=T,d}catch(e){return _c.error(`error in getCPUInfo: ${e}`),{}}}o(LO,"getCPUInfo");async function MO(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await En.mem();return Object.assign(s,process.memoryUsage())}catch(e){return _c.error(`error in getMemoryInfo: ${e}`),{}}}o(MO,"getMemoryInfo");async function vO(){let e={core:[],clustering:[]};try{let t=await En.processes(),r;try{r=Number.parseInt(await Xue.readFile(Zue.join(cp.get(jd.CONFIG_PARAMS.ROOTPATH),jd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===jd.NODE_ERROR_CODES.ENOENT)_c.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 _c.error(`error in getHDBProcessInfo: ${t}`),e}}o(vO,"getHDBProcessInfo");async function UO(){let e={};try{if(!cp.get(jd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await En.disksIO();e.io=i;let{rxSec:a,txSec:c,wxSec:l,...u}=await En.fsStats();return e.read_write=u,e.size=await En.fsSize(),e}catch(t){return _c.error(`error in getDiskInfo: ${t}`),e}}o(UO,"getDiskInfo");async function xO(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return cp.get(jd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await En.networkInterfaceDefault(),e.latency=await En.inetChecksite("google.com"),(await En.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:a,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:d,carrierChanges:f,...m}=n;e.interfaces.push(m)}),(await En.networkStats()).forEach(n=>{let{rxSec:s,txSec:i,ms:a,...c}=n;e.stats.push(c)})),e}catch(t){return _c.error(`error in getNetworkInfo: ${t}`),e}}o(xO,"getNetworkInfo");async function BO(){if(jS!==void 0)return jS;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:a,...c}=await En.osInfo();e=c;let l=await En.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,jS=e,jS}catch(t){return _c.error(`error in getSystemInformation: ${t}`),e}}o(BO,"getSystemInformation");async function FO(){let e=[],t=await tde.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await ede(n));return e}o(FO,"getTableSize");async function HO(){let e={};for(let t in PO){let r=e[t]={},n=r.tables={};for(let s in PO[t])try{let i=PO[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){_c.notify(`Error getting stats for table ${s}: ${i}`)}}return e}o(HO,"getMetrics");async function yV(){if(cp.get(jd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await TV.getNATSReferences(),t=await TV.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(yV,"getNatsStreamInfo");async function nde(e){let t=new rde;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await BO(),t.time=DO(),t.cpu=await LO(),t.memory=await MO(),t.disk=await UO(),t.network=await xO(),t.harperdb_processes=await vO(),t.table_size=await FO(),t.metrics=await HO(),t.threads=await RV(),t.replication=await yV(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await BO();break;case"time":t.time=DO();break;case"cpu":t.cpu=await LO();break;case"memory":t.memory=await MO();break;case"disk":t.disk=await UO();break;case"network":t.network=await xO();break;case"harperdb_processes":t.harperdb_processes=await vO();break;case"table_size":t.table_size=await FO();break;case"database_metrics":case"metrics":t.metrics=await HO();break;case"threads":t.threads=await RV();break;case"replication":t.replication=await yV();break;default:break}return t}o(nde,"systemInformation")});var ea=M((oxe,wV)=>{"use strict";var sde=Fn(),kO=se(),ide=require("util"),Ql=(H(),v(W)),bV=oe();bV.initSync();var ode=pw(),IV=cn(),{Node:nxe,NodeSubscription:sxe}=zd(),ade=hd(),cde=fV(),{RemotePayloadObject:lde,RemotePayloadSubscription:ude}=ap(),{handleHDBError:dde,hdbErrors:fde}=ge(),{HTTP_STATUS_CODES:mde,HDB_ERROR_MSGS:hde}=fde,pde=Ri(),_de=Zo(),{packageJson:Ede}=mt(),{getDatabases:gde}=(De(),v(ut)),ixe=ide.promisify(ode.authorize),Sde=IV.searchByHash,Tde=IV.searchByValue;wV.exports={isEmpty:Rde,getNodeRecord:yde,upsertNodeRecord:Ade,buildNodePayloads:bde,checkClusteringEnabled:Ide,getAllNodeRecords:Nde,getSystemInfo:wde,reverseSubscription:NV};function Rde(e){return e==null}o(Rde,"isEmpty");async function yde(e){let t=new ade(Ql.SYSTEM_SCHEMA_NAME,Ql.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Sde(t)}o(yde,"getNodeRecord");async function Ade(e){let t=new cde(Ql.SYSTEM_SCHEMA_NAME,Ql.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return sde.upsert(t)}o(Ade,"upsertNodeRecord");function NV(e){if(kO.isEmpty(e.subscribe)||kO.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(NV,"reverseSubscription");function bde(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=kO.getTableHashAttribute(l,u),{subscribe:f,publish:m}=NV(c),h=gde()[l]?.[u],p=new ude(l,u,d,m,f,c.start_time,h.schemaDefined?h.attributes:void 0);s.push(p)}return new lde(r,t,s,n)}o(bde,"buildNodePayloads");function Ide(){if(!bV.get(Ql.CONFIG_PARAMS.CLUSTERING_ENABLED))throw dde(new Error,hde.CLUSTERING_NOT_ENABLED,mde.BAD_REQUEST,void 0,void 0,!0)}o(Ide,"checkClusteringEnabled");async function Nde(){let e=new pde(Ql.SYSTEM_SCHEMA_NAME,Ql.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Tde(e))}o(Nde,"getAllNodeRecords");async function wde(){let e=await _de.getSystemInformation();return{hdb_version:Ede.version,node_version:e.node_version,platform:e.platform}}o(wde,"getSystemInfo")});var qO=M((cxe,UV)=>{"use strict";var JS=sr(),OV=se(),CV=It(),PV=(H(),v(W)),QS=j(),DV=ip(),Ode=Rh(),{RemotePayloadObject:Cde}=ap(),{handleHDBError:LV,hdbErrors:Pde}=ge(),{HTTP_STATUS_CODES:MV}=Pde,{NodeSubscription:vV}=zd();UV.exports=Dde;async function Dde(e,t){let r;try{r=await JS.request(`${t}.${CV.REQUEST_SUFFIX}`,new Cde(PV.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),QS.trace("Response from remote describe all request:",r)}catch(a){QS.error(`addNode received error from describe all request to remote node: ${a}`);let c=JS.requestErrorHandler(a,"add_node",t);throw LV(new Error,c,MV.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===CV.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let a=`Error returned from remote node ${t}: ${r.message}`;throw LV(new Error,a,MV.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===PV.SYSTEM_SCHEMA_NAME){await JS.createLocalTableStream(l,c);let p=new vV(l,c,a.publish,a.subscribe);p.start_time=a.start_time,i.push(p);continue}let u=OV.doesSchemaExist(l),d=n[l]!==void 0,f=c?OV.doesTableExist(l,c):!0,m=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!d||!f&&!m){s.push(a);continue}if(!u&&d&&(QS.trace(`addNode creating schema: ${l}`),await DV.createSchema({operation:"create_schema",schema:l})),!f&&m){QS.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let p=new Ode(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(p.attributes=n[l][c].attributes),await DV.createTable(p)}await JS.createLocalTableStream(l,c);let h=new vV(l,c,a.publish,a.subscribe);h.start_time=a.start_time,i.push(h)}return{added:i,skipped:s}}o(Dde,"reviewSubscriptions")});var Jd={};Oe(Jd,{addNodeBack:()=>GO,removeNodeBack:()=>$O,setNode:()=>Ude});async function Ude(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=wi(t)):t=kS(r);let n=(0,BV.validateBySchema)(e,vde);if(n)throw(0,ta.handleHDBError)(n,n.message,Mde.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new ta.ClientError("url or hostname is required for remove_node operation");let h=r,p=Vt(),E=await p.get(h);if(!E)throw new ta.ClientError(h+" does not exist");try{await np({url:E.url},{operation:$.REMOVE_NODE_BACK,name:E?.subscriptions?.length>0?Ze():h},void 0)}catch(g){fs.warn(`Error removing node from target node ${h}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await p.delete(h),`Successfully removed '${h}' from cluster`}if(!t)throw new ta.ClientError("url required for this operation");let s=ac();if(s==null)throw new ta.ClientError("replication url is missing from harperdb-config.yaml");let i,a,c;if(t?.startsWith("wss:")){i=await(0,ks.getReplicationCert)();let h=await(0,ks.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(a=await(0,ks.createCsr)(),fs.info("Sending CSR to target node:",t)):h&&(c=h.certificate,fs.info("Sending CA named",h.name,"to target node",t))}let l={operation:$.ADD_NODE_BACK,hostname:(0,gc.get)(U.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:a,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if((0,gc.get)(U.REPLICATION_SHARD)!==void 0&&(l.shard=(0,gc.get)(U.REPLICATION_SHARD)),e.subscriptions?l.subscriptions=e.subscriptions.map(xV):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let h=xV(e);l.subscribe=h.subscribe,l.publish=h.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 np({url:t},l,e)}catch(h){h.message=`Error returned from ${t}: `+h.message,fs.warn("Error adding node:",t,"to cluster:",h),d=h}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&&(fs.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,ks.setCertTable)({name:Lde.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,ks.setCertTable)({name:Ze(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let 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 h={url:s,ca:c,replicates:!0,subscriptions:null};(0,gc.get)(U.REPLICATION_SHARD)!==void 0&&(h.shard=(0,gc.get)(U.REPLICATION_SHARD)),e.retain_authorization&&(h.authorization=e.authorization),e.start_time&&(h.start_time=e.start_time),await zo(Ze(),h)}await zo(u?u.nodeName:f.name??wi(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 GO(e){fs.trace("addNodeBack received request:",e);let t=await(0,ks.signCertificate)(e),r;e.csr?(r=t.signingCA,fs.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,fs.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,ks.getReplicationCertAuth)();if(n.replicates){let i={url:ac(),ca:s?.certificate,replicates:!0,subscriptions:null};(0,gc.get)(U.REPLICATION_SHARD)!==void 0&&(i.shard=(0,gc.get)(U.REPLICATION_SHARD),t.shard=i.shard),e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await zo(Ze(),i)}return await zo(e.hostname,n),t.nodeName=Ze(),t.usingCA=s?.certificate,fs.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function $O(e){fs.trace("removeNodeBack received request:",e),await Vt().delete(e.name)}function xV(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var ks,BV,Ec,gc,fs,ta,Lde,Mde,vde,Qd=ue(()=>{ks=w(_n()),BV=w(lt()),Ec=w(require("joi")),gc=w(oe());H();Qh();Hl();qn();fs=w(j()),ta=w(ge()),{pki:Lde}=require("node-forge"),{HTTP_STATUS_CODES:Mde}=ta.hdbErrors,vde=Ec.default.object({hostname:Ec.default.string(),verify_tls:Ec.default.boolean(),replicates:Ec.default.boolean(),subscriptions:Ec.default.array(),revoked_certificates:Ec.default.array(),shard:Ec.default.number()});o(Ude,"setNode");o(GO,"addNodeBack");o($O,"removeNodeBack");o(xV,"reverseSubscription")});var Xd=M((Exe,HV)=>{"use strict";var{handleHDBError:XS,hdbErrors:xde}=ge(),{HTTP_STATUS_CODES:ZS}=xde,{addUpdateNodeValidator:Bde}=zS(),eT=j(),tT=(H(),v(W)),FV=It(),Fde=se(),lp=sr(),up=ea(),VO=oe(),Hde=qO(),{Node:kde,NodeSubscription:qde}=zd(),{broadcast:Gde}=nt(),{setNode:$de}=(Qd(),v(Jd)),pxe=oe(),_xe=(H(),v(W)),Vde="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Kde="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Yde=VO.get(tT.CONFIG_PARAMS.CLUSTERING_NODENAME);HV.exports=Wde;async function Wde(e,t=!1){if(eT.trace("addNode called with:",e),VO.get(tT.CONFIG_PARAMS.REPLICATION_URL)||VO.get(tT.CONFIG_PARAMS.REPLICATION_HOSTNAME))return $de(e);up.checkClusteringEnabled();let r=Bde(e);if(r)throw XS(r,r.message,ZS.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let f=await up.getNodeRecord(n);if(!Fde.isEmptyOrZeroLength(f))throw XS(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,ZS.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Hde(e.subscriptions,n),a={message:void 0,added:s,skipped:i};if(s.length===0)return a.message=Vde,a;let c=up.buildNodePayloads(s,Yde,tT.OPERATIONS_ENUM.ADD_NODE,await up.getSystemInfo()),l=[];for(let f=0,m=s.length;f<m;f++){let h=s[f];s[f].start_time===void 0&&delete s[f].start_time,l.push(new qde(h.schema,h.table,h.publish,h.subscribe))}eT.trace("addNode sending remote payload:",c);let u;try{u=await lp.request(`${n}.${FV.REQUEST_SUFFIX}`,c)}catch(f){eT.error(`addNode received error from request: ${f}`);for(let h=0,p=s.length;h<p;h++){let E=s[h];E.publish=!1,E.subscribe=!1,await lp.updateRemoteConsumer(E,n)}let m=lp.requestErrorHandler(f,"add_node",n);throw XS(new Error,m,ZS.INTERNAL_SERVER_ERROR,"error",m)}if(u.status===FV.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${n}: ${u.message}`;throw XS(new Error,f,ZS.INTERNAL_SERVER_ERROR,"error",f)}eT.trace(u);for(let f=0,m=s.length;f<m;f++){let h=s[f];await lp.updateRemoteConsumer(h,n),h.subscribe===!0&&await lp.updateConsumerIterator(h.schema,h.table,n,"start")}let d=new kde(n,l,u.system_info);return await up.upsertNodeRecord(d),Gde({type:"nats_update"}),i.length>0?a.message=Kde:a.message=`Successfully added '${n}' to manifest`,a}o(Wde,"addNode")});var zO=M((Txe,qV)=>{"use strict";var{handleHDBError:KO,hdbErrors:zde}=ge(),{HTTP_STATUS_CODES:YO}=zde,{addUpdateNodeValidator:jde}=zS(),dp=j(),rT=(H(),v(W)),kV=It(),Sxe=se(),fp=sr(),mp=ea(),WO=oe(),{cloneDeep:Jde}=require("lodash"),Qde=qO(),{Node:Xde,NodeSubscription:Zde}=zd(),{broadcast:efe}=nt(),{setNode:tfe}=(Qd(),v(Jd)),rfe="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",nfe="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",sfe=WO.get(rT.CONFIG_PARAMS.CLUSTERING_NODENAME);qV.exports=ife;async function ife(e){if(dp.trace("updateNode called with:",e),WO.get(rT.CONFIG_PARAMS.REPLICATION_URL)??WO.get(rT.CONFIG_PARAMS.REPLICATION_HOSTNAME))return tfe(e);mp.checkClusteringEnabled();let t=jde(e);if(t)throw KO(t,t.message,YO.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await mp.getNodeRecord(r);s.length>0&&(n=Jde(s));let{added:i,skipped:a}=await Qde(e.subscriptions,r),c={message:void 0,updated:i,skipped:a};if(i.length===0)return c.message=rfe,c;let l=mp.buildNodePayloads(i,sfe,rT.OPERATIONS_ENUM.UPDATE_NODE,await mp.getSystemInfo());for(let d=0,f=i.length;d<f;d++){let m=i[d];dp.trace(`updateNode updating work stream for node: ${r} subscription:`,m),i[d].start_time===void 0&&delete i[d].start_time}dp.trace("updateNode sending remote payload:",l);let u;try{u=await fp.request(`${r}.${kV.REQUEST_SUFFIX}`,l)}catch(d){dp.error(`updateNode received error from request: ${d}`);let f=fp.requestErrorHandler(d,"update_node",r);throw KO(new Error,f,YO.INTERNAL_SERVER_ERROR,"error",f)}if(u.status===kV.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${r}: ${u.message}`;throw KO(new Error,d,YO.INTERNAL_SERVER_ERROR,"error",d)}dp.trace(u);for(let d=0,f=i.length;d<f;d++){let m=i[d];await fp.updateRemoteConsumer(m,r),m.subscribe===!0?await fp.updateConsumerIterator(m.schema,m.table,r,"start"):await fp.updateConsumerIterator(m.schema,m.table,r,"stop")}return n||(n=[new Xde(r,[],u.system_info)]),await ofe(n[0],i,u.system_info),a.length>0?c.message=nfe:c.message=`Successfully updated '${r}'`,c}o(ife,"updateNode");async function ofe(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 Zde(a.schema,a.table,a.publish,a.subscribe))}n.system_info=r,await mp.upsertNodeRecord(n),efe({type:"nats_update"})}o(ofe,"updateNodeTable")});var YV=M((yxe,KV)=>{"use strict";var VV=require("joi"),{string:GV}=VV.types(),afe=lt(),$V=(H(),v(W)),cfe=oe(),lfe=It();KV.exports=ufe;function ufe(e){let t=GV.invalid(cfe.get($V.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(lfe.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=VV.object({operation:GV.valid($V.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return afe.validateBySchema(e,r)}o(ufe,"removeNodeValidator")});var nT=M((bxe,QV)=>{"use strict";var{handleHDBError:WV,hdbErrors:dfe}=ge(),{HTTP_STATUS_CODES:zV}=dfe,ffe=YV(),hp=j(),jV=ea(),mfe=se(),Zd=(H(),v(W)),JV=It(),jO=sr(),JO=oe(),{RemotePayloadObject:hfe}=ap(),{NodeSubscription:pfe}=zd(),_fe=Th(),Efe=Tl(),{broadcast:gfe}=nt(),{setNode:Sfe}=(Qd(),v(Jd)),Tfe=JO.get(Zd.CONFIG_PARAMS.CLUSTERING_NODENAME);QV.exports=Rfe;async function Rfe(e){if(hp.trace("removeNode called with:",e),JO.get(Zd.CONFIG_PARAMS.REPLICATION_URL)??JO.get(Zd.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Sfe(e);jV.checkClusteringEnabled();let t=ffe(e);if(t)throw WV(t,t.message,zV.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await jV.getNodeRecord(r);if(mfe.isEmptyOrZeroLength(n))throw WV(new Error,`Node '${r}' was not found.`,zV.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new hfe(Zd.OPERATIONS_ENUM.REMOVE_NODE,Tfe,[]),i,a=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let d=n.subscriptions[l];d.subscribe===!0&&await jO.updateConsumerIterator(d.schema,d.table,r,"stop");try{await jO.updateRemoteConsumer(new pfe(d.schema,d.table,!1,!1),r)}catch(f){hp.error(f)}}try{i=await jO.request(`${r}.${JV.REQUEST_SUFFIX}`,s),hp.trace("Remove node reply from remote node:",r,i)}catch(l){hp.error("removeNode received error from request:",l),a=!0}let c=new _fe(Zd.SYSTEM_SCHEMA_NAME,Zd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Efe.deleteRecord(c),gfe({type:"nats_update"}),i?.status===JV.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||a?(hp.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(Rfe,"removeNode")});var e1=M((Nxe,ZV)=>{"use strict";var XV=require("joi"),{string:yfe,array:Afe}=XV.types(),bfe=lt(),Ife=zS();ZV.exports=Nfe;function Nfe(e){let t=XV.object({operation:yfe.valid("configure_cluster").required(),connections:Afe.items(Ife.validationSchema).required()});return bfe.validateBySchema(e,t)}o(Nfe,"configureClusterValidator")});var QO=M((Oxe,i1)=>{"use strict";var t1=(H(),v(W)),sT=j(),wfe=se(),Ofe=oe(),Cfe=nT(),Pfe=Xd(),Dfe=ea(),Lfe=e1(),{handleHDBError:r1,hdbErrors:Mfe}=ge(),{HTTP_STATUS_CODES:n1}=Mfe,vfe="Configure cluster complete.",Ufe="Failed to configure the cluster. Check the logs for more details.",xfe="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";i1.exports=Bfe;async function Bfe(e){sT.trace("configure cluster called with:",e);let t=Lfe(e);if(t)throw r1(t,t.message,n1.BAD_REQUEST,void 0,void 0,!0);let r=await Dfe.getAllNodeRecords(),n=[];if(Ofe.get(t1.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let d=0,f=r.length;d<f;d++){let m=await s1(Cfe,{operation:t1.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[d].name},r[d].name);n.push(m)}sT.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 s1(Pfe,f,f.node_name);s.push(m)}sT.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"&&(sT.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(wfe.isEmptyOrZeroLength(a))return{message:vfe,connections:c};if(l)return{message:xfe,failed_nodes:a,connections:c};throw r1(new Error,Ufe,n1.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}o(Bfe,"configureCluster");async function s1(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}o(s1,"functionWrapper")});var l1=M((Pxe,c1)=>{"use strict";var pp=require("joi"),Ffe=lt(),{validateSchemaExists:o1,validateTableExists:Hfe,validateSchemaName:a1}=Ji(),kfe=pp.object({operation:pp.string().valid("purge_stream"),schema:pp.string().custom(o1).custom(a1).optional(),database:pp.string().custom(o1).custom(a1).optional(),table:pp.string().custom(Hfe).required()});function qfe(e){return Ffe.validateBySchema(e,kfe)}o(qfe,"purgeStreamValidator");c1.exports=qfe});var XO=M((Lxe,u1)=>{"use strict";var{handleHDBError:Gfe,hdbErrors:$fe}=ge(),{HTTP_STATUS_CODES:Vfe}=$fe,Kfe=l1(),Yfe=sr(),Wfe=ea();u1.exports=zfe;async function zfe(e){e.schema=e.schema??e.database;let t=Kfe(e);if(t)throw Gfe(t,t.message,Vfe.BAD_REQUEST,void 0,void 0,!0);Wfe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await Yfe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}o(zfe,"purgeStream")});var aT=M((vxe,E1)=>{"use strict";var eC=ea(),jfe=sr(),oT=oe(),ef=(H(),v(W)),Xl=It(),Jfe=se(),ZO=j(),{RemotePayloadObject:Qfe}=ap(),{ErrorCode:d1}=require("nats"),{parentPort:f1}=require("worker_threads"),{onMessageByType:Xfe}=nt(),{getThisNodeName:Zfe}=(qn(),v(uo)),{requestClusterStatus:eme}=(Qh(),v(UG)),{getReplicationSharedStatus:tme,getHDBNodeTable:rme}=(Hl(),v(qw)),{CONFIRMATION_STATUS_POSITION:nme,RECEIVED_VERSION_POSITION:sme,RECEIVED_TIME_POSITION:ime,SENDING_TIME_POSITION:ome,RECEIVING_STATUS_POSITION:ame,RECEIVING_STATUS_RECEIVING:cme}=(fO(),v(I$)),m1=oT.get(ef.CONFIG_PARAMS.CLUSTERING_ENABLED),h1=oT.get(ef.CONFIG_PARAMS.CLUSTERING_NODENAME);E1.exports={clusterStatus:lme,buildNodeStatus:_1};var p1;Xfe("cluster-status",async e=>{p1(e)});async function lme(){if(oT.get(ef.CONFIG_PARAMS.REPLICATION_URL)||oT.get(ef.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(f1){f1.postMessage({type:"request-cluster-status"}),n=await new Promise(i=>{p1=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=tme(u,l,a);c.lastCommitConfirmed=iT(d[nme]),c.lastReceivedRemoteTime=iT(d[sme]),c.lastReceivedLocalTime=iT(d[ime]),c.sendingMessage=iT(d[ome]),c.lastReceivedStatus=d[ame]===cme?"Receiving":"Waiting"}}}else n=eme();n.node_name=Zfe();let s=rme().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:h1,is_enabled:m1,connections:[]};if(!m1)return e;let t=await eC.getAllNodeRecords();if(Jfe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(_1(t[n],e.connections));return await Promise.allSettled(r),e}o(lme,"clusterStatus");function iT(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}o(iT,"asDate");async function _1(e,t){let r=e.name,n=new Qfe(ef.OPERATIONS_ENUM.CLUSTER_STATUS,h1,void 0,await eC.getSystemInfo()),s,i,a=Xl.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await jfe.request(Xl.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Xl.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(a=Xl.CLUSTER_STATUS_STATUSES.CLOSED,ZO.error(`Error getting node status from ${r} `,s))}catch(l){ZO.warn(`Error getting node status from ${r}`,l),l.code===d1.NoResponders?a=Xl.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===d1.Timeout?a=Xl.CLUSTER_STATUS_STATUSES.TIMEOUT:a=Xl.CLUSTER_STATUS_STATUSES.CLOSED}let c=new ume(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!==ef.PRE_4_0_0_VERSION&&await eC.upsertNodeRecord(l)}catch(l){ZO.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}o(_1,"buildNodeStatus");function ume(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(ume,"NodeStatusObject")});var lT=M((xxe,g1)=>{"use strict";var{handleHDBError:dme,hdbErrors:fme}=ge(),{HTTP_STATUS_CODES:mme}=fme,hme=sr(),pme=ea(),tC=se(),cT=require("joi"),_me=lt(),Eme=2e3,gme=cT.object({timeout:cT.number().min(1),connected_nodes:cT.boolean(),routes:cT.boolean()});g1.exports=Sme;async function Sme(e){pme.checkClusteringEnabled();let t=_me.validateBySchema(e,gme);if(t)throw dme(t,t.message,mme.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||tC.autoCastBoolean(n),a=s===void 0||tC.autoCastBoolean(s),c={nodes:[]},l=await hme.getServerList(r??Eme),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,h=l[d].data;if(m.name.endsWith("-hub")){let p={name:m.name.slice(0,-4),response_time:l[d].response_time};i&&(p.connected_nodes=[],u[m.name]&&u[m.name].forEach(E=>{p.connected_nodes.includes(E.name.slice(0,-4))||p.connected_nodes.push(E.name.slice(0,-4))})),a&&(p.routes=h.cluster?.urls?h.cluster?.urls.map(E=>({host:E.split(":")[0],port:tC.autoCast(E.split(":")[1])})):[]),c.nodes.push(p)}}return c}o(Sme,"clusterNetwork")});var y1=M((Fxe,R1)=>{"use strict";var rC=require("joi"),S1=lt(),{routeConstraints:T1}=II();R1.exports={setRoutesValidator:Tme,deleteRoutesValidator:Rme};function Tme(e){let t=rC.object({server:rC.valid("hub","leaf"),routes:T1.required()});return S1.validateBySchema(e,t)}o(Tme,"setRoutesValidator");function Rme(e){let t=rC.object({routes:T1.required()});return S1.validateBySchema(e,t)}o(Rme,"deleteRoutesValidator")});var uT=M((kxe,C1)=>{"use strict";var ra=pt(),nC=se(),qs=(H(),v(W)),tf=oe(),A1=y1(),{handleHDBError:b1,hdbErrors:yme}=ge(),{HTTP_STATUS_CODES:I1}=yme,N1="cluster routes successfully set",w1="cluster routes successfully deleted";C1.exports={setRoutes:bme,getRoutes:Ime,deleteRoutes:Nme};function Ame(e){let t=ra.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=nC.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"?ra.updateConfigValue(qs.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):ra.updateConfigValue(qs.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:N1,set:i,skipped:s}}o(Ame,"setRoutesNats");function bme(e){let t=A1.setRoutesValidator(e);if(t)throw b1(t,t.message,I1.BAD_REQUEST,void 0,void 0,!0);if(tf.get(qs.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ame(e);let r=[],n=[],s=tf.get(qs.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{O1(s,i)?n.push(i):(s.push(i),r.push(i))}),ra.updateConfigValue(qs.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:N1,set:r,skipped:n}}o(bme,"setRoutes");function O1(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(O1,"existsInArray");function Ime(){if(tf.get(qs.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=ra.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return tf.get(qs.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}o(Ime,"getRoutes");function Nme(e){let t=A1.deleteRoutesValidator(e);if(t)throw b1(t,t.message,I1.BAD_REQUEST,void 0,void 0,!0);if(tf.get(qs.CONFIG_PARAMS.CLUSTERING_ENABLED))return wme(e);let r=[],n=[],s=tf.get(qs.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(a=>{O1(e.routes,a)?r.push(a):(i.push(a),n.push(a))}),ra.updateConfigValue(qs.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:w1,deleted:r,skipped:n}}o(Nme,"deleteRoutes");function wme(e){let t=ra.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,h=r.length;m<h;m++){let p=r[m];if(d.host===p.host&&d.port===p.port){r.splice(m,1),f=!0,a=!0,s.push(d);break}}if(!f){let m=!0;for(let h=0,p=n.length;h<p;h++){let E=n[h];if(d.host===E.host&&d.port===E.port){n.splice(h,1),c=!0,m=!1,s.push(d);break}}m&&i.push(d)}}return a&&(r=nC.isEmptyOrZeroLength(r)?null:r,ra.updateConfigValue(qs.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=nC.isEmptyOrZeroLength(n)?null:n,ra.updateConfigValue(qs.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:w1,deleted:s,skipped:i}}o(wme,"deleteRoutesNats")});var D1=M((Gxe,P1)=>{"use strict";var _p=require("alasql"),Zl=require("recursive-iterator"),Pi=j(),Ome=se(),Ep=(H(),v(W)),sC=class{static{o(this,"sqlStatementBucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,Pme(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>Ep.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!Ep.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,a=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[a]&&t[i].tables[a][Ep.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[a].attribute_permissions.length>0?c=Cme(t[i].tables[a].attribute_permissions):c=global.hdb_schema[i][a].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(a).filter(u=>!Ep.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let d=new _p.yy.Column({columnid:u});s.tableid&&(d.tableid=s.tableid),this.ast.columns.push(d),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(a,l)}}),this.ast}};function Cme(e){return e.filter(t=>t[Ep.PERMS_CRUD_ENUM.READ])}o(Cme,"filterReadRestrictedAttrs");function Pme(e,t,r,n,s){Dme(e,t,r,n,s)}o(Pme,"interpretAST");function gp(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,a=e.tableid;e.as&&(a=e.as),s.set(a,i)}}o(gp,"addSchemaTableToMap");function Dme(e,t,r,n,s){if(!e){Pi.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof _p.yy.Insert?Ume(e,t,r):e instanceof _p.yy.Select?Lme(e,t,r,n,s):e instanceof _p.yy.Update?Mme(e,t,r):e instanceof _p.yy.Delete?vme(e,t,r):Pi.error("AST in getRecordAttributesAST() is not a valid SQL type.")}o(Dme,"getRecordAttributesAST");function Lme(e,t,r,n,s){if(!e){Pi.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Ome.isEmptyOrZeroLength(i)){Pi.error("No schema specified");return}e.from.forEach(c=>{gp(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),gp(c.table,t,r,n,s)});let a=new Zl(e.columns);for(let{node:c}of a)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{Pi.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Zl(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let d=u.tableid?u.tableid:l;if(!t.get(i).has(d))if(r.has(d))d=r.get(d);else{Pi.info(`table specified as ${d} not found.`);continue}t.get(i).get(d).indexOf(u.columnid)<0&&t.get(i).get(d).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Zl(c.on);for(let{node:u}of l)if(u&&u.columnid){let d=u.tableid,f=s.get(d);if(!t.get(f).has(d))if(r.has(d))d=r.get(d);else{Pi.info(`table specified as ${d} not found.`);continue}t.get(f).get(d).indexOf(u.columnid)<0&&t.get(f).get(d).push(u.columnid)}}),e.order){let c=new Zl(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,d=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Pi.info(`table specified as ${u} not found.`);return}t.get(d).get(u).indexOf(l.columnid)<0&&t.get(d).get(u).push(l.columnid)}}}o(Lme,"getSelectAttributes");function Mme(e,t,r){if(!e){Pi.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Zl(e.columns),s=e.table.databaseid;gp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&iC(e.table.tableid,s,i.columnid,t,r)}o(Mme,"getUpdateAttributes");function vme(e,t,r){if(!e){Pi.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Zl(e.where),s=e.table.databaseid;gp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&iC(e.table.tableid,s,i.columnid,t,r)}o(vme,"getDeleteAttributes");function Ume(e,t,r){if(!e){Pi.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Zl(e.columns),s=e.into.databaseid;gp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&iC(e.into.tableid,s,i.columnid,t,r)}o(Ume,"getInsertAttributes");function iC(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}o(iC,"pushAttribute");P1.exports=sC});var M1=M((Vxe,L1)=>{"use strict";var dT=(H(),v(W)),fT=class{static{o(this,"BaseLicense")}constructor(t=0,r=dT.RAM_ALLOCATION_ENUM.DEFAULT,n=dT.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},oC=class extends fT{static{o(this,"ExtendedLicense")}constructor(t=0,r=dT.RAM_ALLOCATION_ENUM.DEFAULT,n=dT.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};L1.exports={BaseLicense:fT,ExtendedLicense:oC}});var sf=M((Yxe,H1)=>{"use strict";var nf=require("fs-extra"),mT=(ag(),v(og)),U1=require("crypto"),xme=require("moment"),Bme=require("uuid").v4,gn=j(),cC=require("path"),Fme=se(),eu=(H(),v(W)),{totalmem:v1}=require("os"),Hme=M1().ExtendedLicense,rf="invalid license key format",kme="061183",qme="mofi25",Gme="aes-256-cbc",$me=16,Vme=32,x1=oe(),{resolvePath:B1}=pt();x1.initSync();var aC;H1.exports={validateLicense:F1,generateFingerPrint:Yme,licenseSearch:dC,getLicense:jme,checkMemoryLimit:Jme};function lC(){return cC.join(x1.getHdbBasePath(),eu.LICENSE_KEY_DIR_NAME,eu.LICENSE_FILE_NAME)}o(lC,"getLicenseDirPath");function Kme(){let e=lC();return B1(cC.join(e,eu.LICENSE_FILE_NAME))}o(Kme,"getLicenseFilePath");function uC(){let e=lC();return B1(cC.join(e,eu.REG_KEY_FILE_NAME))}o(uC,"getFingerPrintFilePath");async function Yme(){let e=uC();try{return await nf.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Wme();throw gn.error(`Error writing fingerprint file to ${e}`),gn.error(t),new Error("There was an error generating the fingerprint")}}o(Yme,"generateFingerPrint");async function Wme(){let e=Bme(),t=mT.hash(e,mT.HASH_FUNCTION.MD5),r=uC();try{await nf.mkdirp(lC()),await nf.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw gn.error(`Error writing fingerprint file to ${r}`),gn.error(n),new Error("There was an error generating the fingerprint")}return t}o(Wme,"writeFingerprint");function F1(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:eu.RAM_ALLOCATION_ENUM.DEFAULT,version:eu.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return gn.error("empty license key passed to validate."),r;let n=uC(),s=!1;try{s=nf.statSync(n)}catch(i){gn.error(i)}if(s){let i;try{i=nf.readFileSync(n,"utf8")}catch{gn.error("error validating this machine in the license"),r.valid_machine=!1;return}let a=e.split(qme),c=a[1];c=Buffer.concat([Buffer.from(c)],$me);let l=Buffer.concat([Buffer.from(i)],Vme),u=U1.createDecipheriv(Gme,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let d=null;try{d=u.update(a[0],"hex","utf8"),d.trim(),d+=u.final("utf8")}catch{let h=zme(a[0],i);if(h)d=h;else throw r.valid_license=!1,r.valid_machine=!1,console.error(rf),gn.error(rf),new Error(rf)}let f;if(isNaN(d))try{f=JSON.parse(d),r.version=f.version,r.exp_date=f.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),f.ram_allocation&&(r.ram_allocation=f.ram_allocation)}catch{throw console.error(rf),gn.error(rf),new Error(rf)}else r.exp_date=d;r.exp_date<xme().valueOf()&&(r.valid_date=!1),mT.validate(a[1],`${kme}${i}${t}`,mT.HASH_FUNCTION.MD5)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||gn.error("Invalid licence"),r}o(F1,"validateLicense");function zme(e,t){try{let r=U1.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{gn.warn("Check old license failed")}}o(zme,"checkOldLicense");function dC(){let e=new Hme,t=[];try{t=nf.readFileSync(Kme(),"utf-8").split(`\r
|
|
20
|
-
`)}catch(r){r.code==="ENOENT"?gn.debug("no license file found"):gn.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(Fme.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=F1(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){gn.error("There was an error parsing the license string."),gn.error(s),e.ram_allocation=eu.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return aC=e,e}o(dC,"licenseSearch");async function jme(){return aC||await dC(),aC}o(jme,"getLicense");function Jme(){let e=dC().ram_allocation,t=process.constrainedMemory?.()||v1();if(t=Math.round(Math.min(t,v1())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}o(Jme,"checkMemoryLimit")});var pT=M((zxe,$1)=>{var hT=sf(),k1=require("chalk"),ms=j(),q1=require("prompt"),{promisify:Qme}=require("util"),fC=(H(),v(W)),Xme=require("fs-extra"),Zme=require("path"),ehe=se(),{packageJson:the}=mt(),G1=oe();G1.initSync();var rhe=require("moment"),nhe=Qme(q1.get),she=Zme.join(G1.getHdbBasePath(),fC.LICENSE_KEY_DIR_NAME,fC.LICENSE_FILE_NAME,fC.LICENSE_FILE_NAME);$1.exports={getFingerprint:ohe,setLicense:ihe,parseLicense:mC,register:ahe,getRegistrationInfo:lhe};async function ihe(e){if(e&&e.key&&e.company){try{ms.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await mC(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ms.error(r),ms.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}o(ihe,"setLicense");async function ohe(){let e={};try{e=await hT.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ms.error(r),ms.error(t),new Error(r)}return e}o(ohe,"getFingerprint");async function mC(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ms.info("Validating license input...");let r=hT.validateLicense(e,t);if(ms.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(ms.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(ms.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ms.info("writing license to disk"),await Xme.writeFile(she,JSON.stringify({license_key:e,company:t}))}catch(n){throw ms.error("Failed to write License"),n}return"Registration successful."}o(mC,"parseLicense");async function ahe(){let e=await che();return mC(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}o(ahe,"register");async function che(){let e=await hT.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:k1.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:k1.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{q1.start()}catch(n){ms.error(n)}let r;try{r=await nhe(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}o(che,"promptForRegistration");async function lhe(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await hT.getLicense()}catch(r){throw ms.error(`There was an error when searching licenses due to: ${r.message}`),r}if(ehe.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=the.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=rhe.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}o(lhe,"getRegistrationInfo")});var K1=M((Jxe,V1)=>{"use strict";var uhe=It(),hC=class{static{o(this,"HubConfigObject")}constructor(t,r,n,s,i,a,c,l,u,d,f,m,h,p){this.port=t,a===null&&(a=void 0),this.server_name=r+uhe.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:h},HDB:{users:p}},this.system_account="SYS"}};V1.exports=hC});var z1=M((Xxe,W1)=>{"use strict";var Y1=It(),pC=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+Y1.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+Y1.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"}};W1.exports=pC});var J1=M((eBe,j1)=>{"use strict";var _C=class{static{o(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};j1.exports=_C});var X1=M((rBe,Q1)=>{"use strict";var dhe=It(),EC=class{static{o(this,"SysUserObject")}constructor(t,r){this.user=t+dhe.SERVER_SUFFIX.ADMIN,this.password=r}};Q1.exports=EC});var ST=M((sBe,tK)=>{"use strict";var tu=require("path"),ru=require("fs-extra"),fhe=K1(),mhe=z1(),hhe=J1(),phe=X1(),gC=Bn(),af=se(),$n=pt(),ET=(H(),v(W)),Sp=It(),{CONFIG_PARAMS:ir}=ET,cf=j(),Tp=oe(),Z1=Zi(),SC=sr(),_he=_n(),of="clustering",Ehe=1e4,eK=50;tK.exports={generateNatsConfig:She,removeNatsConfig:The,getHubConfigPath:ghe};function ghe(){let e=Tp.get(ir.ROOTPATH);return tu.join(e,of,Sp.NATS_CONFIG_FILES.HUB_SERVER)}o(ghe,"getHubConfigPath");async function She(e=!1,t=void 0){console.error("Warning: NATS replication is deprecated and will be removed in version 5.0 of Harper");let r=Tp.get(ir.ROOTPATH);ru.ensureDirSync(tu.join(r,"clustering","leaf")),Tp.initSync();let n=$n.getConfigFromFile(ir.CLUSTERING_TLS_CERT_AUTH),s=$n.getConfigFromFile(ir.CLUSTERING_TLS_PRIVATEKEY),i=$n.getConfigFromFile(ir.CLUSTERING_TLS_CERTIFICATE);!await ru.exists(i)&&!await ru.exists(!n)&&await _he.createNatsCerts();let a=tu.join(r,of,Sp.PID_FILES.HUB),c=tu.join(r,of,Sp.PID_FILES.LEAF),l=$n.getConfigFromFile(ir.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=tu.join(r,of,Sp.NATS_CONFIG_FILES.HUB_SERVER),d=tu.join(r,of,Sp.NATS_CONFIG_FILES.LEAF_SERVER),f=$n.getConfigFromFile(ir.CLUSTERING_TLS_INSECURE),m=$n.getConfigFromFile(ir.CLUSTERING_TLS_VERIFY),h=$n.getConfigFromFile(ir.CLUSTERING_NODENAME),p=$n.getConfigFromFile(ir.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await SC.checkNATSServerInstalled()||gT("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let E=await gC.listUsers(),g=$n.getConfigFromFile(ir.CLUSTERING_USER),y=await gC.getClusterUser();(af.isEmpty(y)||y.active!==!0)&&gT(`Invalid cluster user '${cluster_username}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await _T(ir.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await _T(ir.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await _T(ir.CLUSTERING_HUBSERVER_NETWORK_PORT),await _T(ir.CLUSTERING_LEAFSERVER_NETWORK_PORT));let T=[],R=[];for(let[G,K]of E.entries())K.role?.role===ET.ROLE_TYPES_ENUM.CLUSTER_USER&&K.active&&(T.push(new phe(K.username,Z1.decrypt(K.hash))),R.push(new hhe(K.username,Z1.decrypt(K.hash))));let N=[],{hub_routes:O}=$n.getClusteringRoutes();if(!af.isEmptyOrZeroLength(O))for(let G of O)N.push(`tls://${y.sys_name_encoded}:${y.uri_encoded_d_hash}@${G.host}:${G.port}`);let F=new fhe($n.getConfigFromFile(ir.CLUSTERING_HUBSERVER_NETWORK_PORT),h,a,i,s,n,f,m,p,$n.getConfigFromFile(ir.CLUSTERING_HUBSERVER_CLUSTER_NAME),$n.getConfigFromFile(ir.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),N,T,R);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=af.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ET.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await ru.writeJson(u,F),cf.trace(`Hub server config written to ${u}`));let Z=`tls://${y.sys_name_encoded}:${y.uri_encoded_d_hash}@0.0.0.0:${p}`,q=`tls://${y.uri_encoded_name}:${y.uri_encoded_d_hash}@0.0.0.0:${p}`,Y=new mhe($n.getConfigFromFile(ir.CLUSTERING_LEAFSERVER_NETWORK_PORT),h,c,l,[Z],[q],T,R,i,s,n,f);n==null&&delete Y.tls.ca_file,(t===void 0||t===ET.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await ru.writeJson(d,Y),cf.trace(`Leaf server config written to ${d}`))}o(She,"generateNatsConfig");async function _T(e){let t=Tp.get(e);return af.isEmpty(t)&&gT(`port undefined for '${e}'`),await af.isPortTaken(t)&&gT(`'${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(_T,"isPortAvailable");function gT(e){let t=`Error generating clustering config: ${e}`;cf.error(t),console.error(t),process.exit(1)}o(gT,"generateNatsConfigError");async function The(e){let{port:t,config_file:r}=SC.getServerConfig(e),{username:n,decrypt_hash:s}=await gC.getClusterUser(),i=0,a=2e3;for(;i<eK;){try{let d=await SC.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){cf.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=eK)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&&cf.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await af.asyncSetTimeout(u)}let c="0".repeat(Ehe),l=tu.join(Tp.get(ir.ROOTPATH),of,r);await ru.writeFile(l,c),await ru.remove(l),cf.notify(e,"started.")}o(The,"removeNatsConfig")});var aK=M((oBe,oK)=>{"use strict";var hs=oe(),Rhe=sf(),Ke=(H(),v(W)),Rp=It(),na=require("path"),{PACKAGE_ROOT:RT}=mt(),rK=oe(),TT=se(),lf="/dev/null",yhe=na.join(RT,"launchServiceScripts"),nK=na.join(RT,"utility/scripts"),Ahe=na.join(nK,Ke.HDB_RESTART_SCRIPT),sK=na.resolve(RT,"dependencies",`${process.platform}-${process.arch}`,Rp.NATS_BINARY_NAME);function iK(){let t=Rhe.licenseSearch().ram_allocation||Ke.RAM_ALLOCATION_ENUM.DEFAULT,r=Ke.MEM_SETTING_KEY+t,n={[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return TT.noBootFile()&&(n[Ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TT.getEnvCliRootPath()),{name:Ke.PROCESS_DESCRIPTORS.HDB,script:Ke.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:RT}}o(iK,"generateMainServerConfig");var bhe=9930;function Ihe(){hs.initSync(!0);let e=hs.get(Ke.CONFIG_PARAMS.ROOTPATH),t=na.join(e,"clustering",Rp.NATS_CONFIG_FILES.HUB_SERVER),r=na.join(hs.get(Ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ke.LOG_NAMES.HDB),n=rK.get(Ke.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Rp.LOG_LEVEL_FLAGS[hs.get(Ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ke.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==bhe?"-"+n:""),script:sK,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return hs.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=lf,i.error_file=lf),i}o(Ihe,"generateNatsHubServerConfig");var Nhe=9940;function whe(){hs.initSync(!0);let e=hs.get(Ke.CONFIG_PARAMS.ROOTPATH),t=na.join(e,"clustering",Rp.NATS_CONFIG_FILES.LEAF_SERVER),r=na.join(hs.get(Ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ke.LOG_NAMES.HDB),n=rK.get(Ke.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Rp.LOG_LEVEL_FLAGS[hs.get(Ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ke.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Nhe?"-"+n:""),script:sK,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return hs.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=lf,i.error_file=lf),i}o(whe,"generateNatsLeafServerConfig");function Ohe(){hs.initSync();let e=na.join(hs.get(Ke.CONFIG_PARAMS.LOGGING_ROOT),Ke.LOG_NAMES.HDB),t={name:Ke.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ke.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:yhe,autorestart:!1};return hs.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=lf,t.error_file=lf),t}o(Ohe,"generateClusteringUpgradeV4ServiceConfig");function Che(){let e={[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.RESTART_HDB};return TT.noBootFile()&&(e[Ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TT.getEnvCliRootPath()),{...{name:Ke.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:nK},script:Ahe}}o(Che,"generateRestart");function Phe(){return{apps:[iK()]}}o(Phe,"generateAllServiceConfigs");oK.exports={generateAllServiceConfigs:Phe,generateMainServerConfig:iK,generateRestart:Che,generateNatsHubServerConfig:Ihe,generateNatsLeafServerConfig:whe,generateClusteringUpgradeV4ServiceConfig:Ohe}});var uf=M((lBe,RK)=>{"use strict";var at=(H(),v(W)),Dhe=se(),ia=ST(),yT=sr(),sa=It(),Sc=aK(),AT=oe(),nu=j(),Lhe=ea(),{startWorker:cK,onMessageFromWorkers:Mhe}=nt(),vhe=Zo(),cBe=require("util"),Uhe=require("child_process"),xhe=require("fs"),{execFile:Bhe}=Uhe,Je;RK.exports={enterPM2Mode:Fhe,start:Tc,stop:TC,reload:uK,restart:dK,list:RC,describe:hK,connect:oa,kill:$he,startAllServices:Vhe,startService:yC,getUniqueServicesList:pK,restartAllServices:Khe,isServiceRegistered:_K,reloadStopStart:EK,restartHdb:mK,deleteProcess:qhe,startClusteringProcesses:SK,startClusteringThreads:TK,isHdbRestartRunning:Ghe,isClusteringRunning:Whe,stopClustering:Yhe,reloadClustering:zhe,expectedRestartOfChildren:fK};var yp=!1;Mhe(e=>{e.type==="restart"&&AT.initSync(!0)});function Fhe(){yp=!0}o(Fhe,"enterPM2Mode");function oa(){return Je||(Je=require("pm2")),new Promise((e,t)=>{Je.connect((r,n)=>{r&&t(r),e(n)})})}o(oa,"connect");var Sn,Hhe=10,lK;function Tc(e,t=!1){if(yp)return khe(e);let r=Bhe(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let a=Sn.indexOf(r);a>-1&&Sn.splice(a,1),!lK&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Hhe&&(xhe.existsSync(ia.getHubConfigPath())?Tc(e):(await ia.generateNatsConfig(!0),Tc(e),await new Promise(c=>setTimeout(c,3e3)),await ia.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ia.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let a=AT.get(at.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,d;for(;l=c.exec(i);){if(l.index&&sa.LOG_LEVEL_HIERARCHY[a]>=sa.LOG_LEVEL_HIERARCHY[d||"info"]){let h=d===sa.LOG_LEVELS.ERR||d===sa.LOG_LEVELS.WRN?nu.OUTPUTS.STDERR:nu.OUTPUTS.STDOUT;nu.logCustomLevel(d||"info",h,n,i.slice(u,l.index).trim())}let[f,m]=l;u=l.index+f.length,d=sa.LOG_LEVELS[m]}if(sa.LOG_LEVEL_HIERARCHY[a]>=sa.LOG_LEVEL_HIERARCHY[d||"info"]){let f=d===sa.LOG_LEVELS.ERR||d===sa.LOG_LEVELS.WRN?nu.OUTPUTS.STDERR:nu.OUTPUTS.STDOUT;nu.logCustomLevel(d||"info",f,n,i.slice(u).trim())}}if(o(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!Sn&&(Sn=[],!t)){let i=o(()=>{lK=!0,Sn&&(Sn.map(a=>a.kill()),process.exit(0))},"killChildren");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}Sn.push(r)}o(Tc,"start");function khe(e){return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.start(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(khe,"startWithPM2");function TC(e){if(!yp){for(let t of Sn||[])t.name===e&&(Sn.splice(Sn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.stop(e,async(n,s)=>{n&&(Je.disconnect(),r(n)),Je.delete(e,(i,a)=>{i&&(Je.disconnect(),r(n)),Je.disconnect(),t(a)})})})}o(TC,"stop");function uK(e){return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.reload(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(uK,"reload");function dK(e){if(!yp){fK();for(let t of Sn||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.restart(e,(n,s)=>{Je.disconnect(),t(s)})})}o(dK,"restart");function fK(){for(let e of Sn||[])e.config&&(e.config.restarts=0)}o(fK,"expectedRestartOfChildren");function qhe(e){return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.delete(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(qhe,"deleteProcess");async function mK(){await Tc(Sc.generateRestart())}o(mK,"restartHdb");async function Ghe(){let e=await RC();for(let t in e)if(e[t].name===at.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}o(Ghe,"isHdbRestartRunning");function RC(){return new Promise(async(e,t)=>{try{await oa()}catch(r){t(r)}Je.list((r,n)=>{r&&(Je.disconnect(),t(r)),Je.disconnect(),e(n)})})}o(RC,"list");function hK(e){return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.describe(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(hK,"describe");function $he(){if(!yp){for(let e of Sn||[])e.kill();Sn=[];return}return new Promise(async(e,t)=>{try{await oa()}catch(r){t(r)}Je.killDaemon((r,n)=>{r&&(Je.disconnect(),t(r)),Je.disconnect(),e(n)})})}o($he,"kill");async function Vhe(){try{await SK(),await TK(),await Tc(Sc.generateAllServiceConfigs())}catch(e){throw Je?.disconnect(),e}}o(Vhe,"startAllServices");async function yC(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case at.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Sc.generateMainServerConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Sc.generateNatsIngestServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Sc.generateNatsReplyServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Sc.generateNatsHubServerConfig(),await Tc(r,t),await ia.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Sc.generateNatsLeafServerConfig(),await Tc(r,t),await ia.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Sc.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Tc(r)}catch(r){throw Je?.disconnect(),r}}o(yC,"startService");async function pK(){try{let e=await RC(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Je?.disconnect(),e}}o(pK,"getUniqueServicesList");async function Khe(e=[]){try{let t=!1,r=await pK();for(let n=0,s=Object.values(r).length;n<s;n++){let a=Object.values(r)[n].name;e.includes(a)||(a===at.PROCESS_DESCRIPTORS.HDB?t=!0:await dK(a))}t&&await EK(at.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Je?.disconnect(),t}}o(Khe,"restartAllServices");async function _K(e){if(Sn?.find(r=>r.name===e))return!0;let t=await vhe.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}o(_K,"isServiceRegistered");async function EK(e){let t=AT.get(at.CONFIG_PARAMS.THREADS_COUNT)??AT.get(at.CONFIG_PARAMS.THREADS),r=await hK(e),n=Dhe.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await TC(e),await yC(e)):e===at.PROCESS_DESCRIPTORS.HDB?await mK():await uK(e)}o(EK,"reloadStopStart");var gK;async function SK(e=!1){for(let t in at.CLUSTERING_PROCESSES){let r=at.CLUSTERING_PROCESSES[t];await yC(r,e)}}o(SK,"startClusteringProcesses");async function TK(){gK=cK(at.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await yT.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await yT.updateLocalStreams();let e=await Lhe.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===at.PRE_4_0_0_VERSION){nu.info("Starting clustering upgrade 4.0.0 process"),cK(at.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}o(TK,"startClusteringThreads");async function Yhe(){for(let e in at.CLUSTERING_PROCESSES)if(e!==at.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===at.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await gK.terminate();else{let t=at.CLUSTERING_PROCESSES[e];await TC(t)}}o(Yhe,"stopClustering");async function Whe(){for(let e in at.CLUSTERING_PROCESSES){let t=at.CLUSTERING_PROCESSES[e];if(await _K(t)===!1)return!1}return!0}o(Whe,"isClusteringRunning");async function zhe(){await ia.generateNatsConfig(!0),await yT.reloadNATSHub(),await yT.reloadNATSLeaf(),await ia.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await ia.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}o(zhe,"reloadClustering")});var NT={};Oe(NT,{compactOnStart:()=>jhe,copyDb:()=>wK});async function jhe(){Rc.notify("Running compact on start"),console.log("Running compact on start");let e=(0,AC.get)(U.ROOTPATH),t=new Map,r=st();(0,bC.updateConfigValue)(U.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,bT.join)(e,"backup",n+".mdb"),a=(0,bT.join)(e,sl,n+"-copy.mdb"),c=0;try{c=await yK(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Rc.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 wK(n,a),console.log("Backing up",n,"to",i);try{await(0,su.move)(s,i,{overwrite:!0})}catch(l){console.log("Error moving database",s,"to",i,l)}}try{ff()}catch(n){Rc.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,su.move)(i,s,{overwrite:!0}),await(0,su.remove)((0,bT.join)(e,sl,`${n}-copy.mdb-lock`));try{ff()}catch(n){Rc.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Rc.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,bC.updateConfigValue)(U.STORAGE_COMPACTONSTART,!1);for(let[s,{dbPath:i,backupDest:a}]of t){console.error("Moving backup database",a,"back to",i);try{await(0,su.move)(a,i,{overwrite:!0})}catch(c){console.error(c)}}throw ff(),n}for(let[n,{backupDest:s,recordCount:i}]of t){let a=!0,c=await yK(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}.
|
|
21
|
-
Total record count before compaction: ${i}, total after: ${
|
|
22
|
-
Database backup has not been removed and can be found here: ${s}`;Rc.error(
|
|
20
|
+
`)}catch(r){r.code==="ENOENT"?gn.debug("no license file found"):gn.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(Fme.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=F1(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){gn.error("There was an error parsing the license string."),gn.error(s),e.ram_allocation=eu.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return aC=e,e}o(dC,"licenseSearch");async function jme(){return aC||await dC(),aC}o(jme,"getLicense");function Jme(){let e=dC().ram_allocation,t=process.constrainedMemory?.()||v1();if(t=Math.round(Math.min(t,v1())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}o(Jme,"checkMemoryLimit")});var pT=M((zxe,$1)=>{var hT=sf(),k1=require("chalk"),ms=j(),q1=require("prompt"),{promisify:Qme}=require("util"),fC=(H(),v(W)),Xme=require("fs-extra"),Zme=require("path"),ehe=se(),{packageJson:the}=mt(),G1=oe();G1.initSync();var rhe=require("moment"),nhe=Qme(q1.get),she=Zme.join(G1.getHdbBasePath(),fC.LICENSE_KEY_DIR_NAME,fC.LICENSE_FILE_NAME,fC.LICENSE_FILE_NAME);$1.exports={getFingerprint:ohe,setLicense:ihe,parseLicense:mC,register:ahe,getRegistrationInfo:lhe};async function ihe(e){if(e&&e.key&&e.company){try{ms.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await mC(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ms.error(r),ms.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}o(ihe,"setLicense");async function ohe(){let e={};try{e=await hT.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ms.error(r),ms.error(t),new Error(r)}return e}o(ohe,"getFingerprint");async function mC(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ms.info("Validating license input...");let r=hT.validateLicense(e,t);if(ms.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(ms.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(ms.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ms.info("writing license to disk"),await Xme.writeFile(she,JSON.stringify({license_key:e,company:t}))}catch(n){throw ms.error("Failed to write License"),n}return"Registration successful."}o(mC,"parseLicense");async function ahe(){let e=await che();return mC(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}o(ahe,"register");async function che(){let e=await hT.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:k1.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:k1.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{q1.start()}catch(n){ms.error(n)}let r;try{r=await nhe(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}o(che,"promptForRegistration");async function lhe(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await hT.getLicense()}catch(r){throw ms.error(`There was an error when searching licenses due to: ${r.message}`),r}if(ehe.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=the.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=rhe.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}o(lhe,"getRegistrationInfo")});var K1=M((Jxe,V1)=>{"use strict";var uhe=It(),hC=class{static{o(this,"HubConfigObject")}constructor(t,r,n,s,i,a,c,l,u,d,f,m,h,p){this.port=t,a===null&&(a=void 0),this.server_name=r+uhe.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:h},HDB:{users:p}},this.system_account="SYS"}};V1.exports=hC});var z1=M((Xxe,W1)=>{"use strict";var Y1=It(),pC=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+Y1.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+Y1.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"}};W1.exports=pC});var J1=M((eBe,j1)=>{"use strict";var _C=class{static{o(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};j1.exports=_C});var X1=M((rBe,Q1)=>{"use strict";var dhe=It(),EC=class{static{o(this,"SysUserObject")}constructor(t,r){this.user=t+dhe.SERVER_SUFFIX.ADMIN,this.password=r}};Q1.exports=EC});var ST=M((sBe,tK)=>{"use strict";var tu=require("path"),ru=require("fs-extra"),fhe=K1(),mhe=z1(),hhe=J1(),phe=X1(),gC=Bn(),af=se(),$n=pt(),ET=(H(),v(W)),Sp=It(),{CONFIG_PARAMS:ir}=ET,cf=j(),Tp=oe(),Z1=Zi(),SC=sr(),_he=_n(),of="clustering",Ehe=1e4,eK=50;tK.exports={generateNatsConfig:She,removeNatsConfig:The,getHubConfigPath:ghe};function ghe(){let e=Tp.get(ir.ROOTPATH);return tu.join(e,of,Sp.NATS_CONFIG_FILES.HUB_SERVER)}o(ghe,"getHubConfigPath");async function She(e=!1,t=void 0){console.error("Warning: NATS replication is deprecated and will be removed in version 5.0 of Harper");let r=Tp.get(ir.ROOTPATH);ru.ensureDirSync(tu.join(r,"clustering","leaf")),Tp.initSync();let n=$n.getConfigFromFile(ir.CLUSTERING_TLS_CERT_AUTH),s=$n.getConfigFromFile(ir.CLUSTERING_TLS_PRIVATEKEY),i=$n.getConfigFromFile(ir.CLUSTERING_TLS_CERTIFICATE);!await ru.exists(i)&&!await ru.exists(!n)&&await _he.createNatsCerts();let a=tu.join(r,of,Sp.PID_FILES.HUB),c=tu.join(r,of,Sp.PID_FILES.LEAF),l=$n.getConfigFromFile(ir.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=tu.join(r,of,Sp.NATS_CONFIG_FILES.HUB_SERVER),d=tu.join(r,of,Sp.NATS_CONFIG_FILES.LEAF_SERVER),f=$n.getConfigFromFile(ir.CLUSTERING_TLS_INSECURE),m=$n.getConfigFromFile(ir.CLUSTERING_TLS_VERIFY),h=$n.getConfigFromFile(ir.CLUSTERING_NODENAME),p=$n.getConfigFromFile(ir.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await SC.checkNATSServerInstalled()||gT("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let E=await gC.listUsers(),g=$n.getConfigFromFile(ir.CLUSTERING_USER),y=await gC.getClusterUser();(af.isEmpty(y)||y.active!==!0)&&gT(`Invalid cluster user '${cluster_username}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await _T(ir.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await _T(ir.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await _T(ir.CLUSTERING_HUBSERVER_NETWORK_PORT),await _T(ir.CLUSTERING_LEAFSERVER_NETWORK_PORT));let T=[],R=[];for(let[G,K]of E.entries())K.role?.role===ET.ROLE_TYPES_ENUM.CLUSTER_USER&&K.active&&(T.push(new phe(K.username,Z1.decrypt(K.hash))),R.push(new hhe(K.username,Z1.decrypt(K.hash))));let N=[],{hub_routes:O}=$n.getClusteringRoutes();if(!af.isEmptyOrZeroLength(O))for(let G of O)N.push(`tls://${y.sys_name_encoded}:${y.uri_encoded_d_hash}@${G.host}:${G.port}`);let F=new fhe($n.getConfigFromFile(ir.CLUSTERING_HUBSERVER_NETWORK_PORT),h,a,i,s,n,f,m,p,$n.getConfigFromFile(ir.CLUSTERING_HUBSERVER_CLUSTER_NAME),$n.getConfigFromFile(ir.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),N,T,R);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=af.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ET.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await ru.writeJson(u,F),cf.trace(`Hub server config written to ${u}`));let Z=`tls://${y.sys_name_encoded}:${y.uri_encoded_d_hash}@0.0.0.0:${p}`,q=`tls://${y.uri_encoded_name}:${y.uri_encoded_d_hash}@0.0.0.0:${p}`,Y=new mhe($n.getConfigFromFile(ir.CLUSTERING_LEAFSERVER_NETWORK_PORT),h,c,l,[Z],[q],T,R,i,s,n,f);n==null&&delete Y.tls.ca_file,(t===void 0||t===ET.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await ru.writeJson(d,Y),cf.trace(`Leaf server config written to ${d}`))}o(She,"generateNatsConfig");async function _T(e){let t=Tp.get(e);return af.isEmpty(t)&&gT(`port undefined for '${e}'`),await af.isPortTaken(t)&&gT(`'${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(_T,"isPortAvailable");function gT(e){let t=`Error generating clustering config: ${e}`;cf.error(t),console.error(t),process.exit(1)}o(gT,"generateNatsConfigError");async function The(e){let{port:t,config_file:r}=SC.getServerConfig(e),{username:n,decrypt_hash:s}=await gC.getClusterUser(),i=0,a=2e3;for(;i<eK;){try{let d=await SC.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){cf.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=eK)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&&cf.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await af.asyncSetTimeout(u)}let c="0".repeat(Ehe),l=tu.join(Tp.get(ir.ROOTPATH),of,r);await ru.writeFile(l,c),await ru.remove(l),cf.notify(e,"started.")}o(The,"removeNatsConfig")});var aK=M((oBe,oK)=>{"use strict";var hs=oe(),Rhe=sf(),Ke=(H(),v(W)),Rp=It(),na=require("path"),{PACKAGE_ROOT:RT}=mt(),rK=oe(),TT=se(),lf="/dev/null",yhe=na.join(RT,"launchServiceScripts"),nK=na.join(RT,"utility/scripts"),Ahe=na.join(nK,Ke.HDB_RESTART_SCRIPT),sK=na.resolve(RT,"dependencies",`${process.platform}-${process.arch}`,Rp.NATS_BINARY_NAME);function iK(){let t=Rhe.licenseSearch().ram_allocation||Ke.RAM_ALLOCATION_ENUM.DEFAULT,r=Ke.MEM_SETTING_KEY+t,n={[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return TT.noBootFile()&&(n[Ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TT.getEnvCliRootPath()),{name:Ke.PROCESS_DESCRIPTORS.HDB,script:Ke.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:RT}}o(iK,"generateMainServerConfig");var bhe=9930;function Ihe(){hs.initSync(!0);let e=hs.get(Ke.CONFIG_PARAMS.ROOTPATH),t=na.join(e,"clustering",Rp.NATS_CONFIG_FILES.HUB_SERVER),r=na.join(hs.get(Ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ke.LOG_NAMES.HDB),n=rK.get(Ke.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Rp.LOG_LEVEL_FLAGS[hs.get(Ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ke.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==bhe?"-"+n:""),script:sK,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return hs.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=lf,i.error_file=lf),i}o(Ihe,"generateNatsHubServerConfig");var Nhe=9940;function whe(){hs.initSync(!0);let e=hs.get(Ke.CONFIG_PARAMS.ROOTPATH),t=na.join(e,"clustering",Rp.NATS_CONFIG_FILES.LEAF_SERVER),r=na.join(hs.get(Ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ke.LOG_NAMES.HDB),n=rK.get(Ke.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Rp.LOG_LEVEL_FLAGS[hs.get(Ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ke.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Nhe?"-"+n:""),script:sK,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return hs.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=lf,i.error_file=lf),i}o(whe,"generateNatsLeafServerConfig");function Ohe(){hs.initSync();let e=na.join(hs.get(Ke.CONFIG_PARAMS.LOGGING_ROOT),Ke.LOG_NAMES.HDB),t={name:Ke.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ke.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:yhe,autorestart:!1};return hs.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=lf,t.error_file=lf),t}o(Ohe,"generateClusteringUpgradeV4ServiceConfig");function Che(){let e={[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.RESTART_HDB};return TT.noBootFile()&&(e[Ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TT.getEnvCliRootPath()),{...{name:Ke.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:nK},script:Ahe}}o(Che,"generateRestart");function Phe(){return{apps:[iK()]}}o(Phe,"generateAllServiceConfigs");oK.exports={generateAllServiceConfigs:Phe,generateMainServerConfig:iK,generateRestart:Che,generateNatsHubServerConfig:Ihe,generateNatsLeafServerConfig:whe,generateClusteringUpgradeV4ServiceConfig:Ohe}});var uf=M((lBe,RK)=>{"use strict";var at=(H(),v(W)),Dhe=se(),ia=ST(),yT=sr(),sa=It(),Sc=aK(),AT=oe(),nu=j(),Lhe=ea(),{startWorker:cK,onMessageFromWorkers:Mhe}=nt(),vhe=Zo(),cBe=require("util"),Uhe=require("child_process"),xhe=require("fs"),{execFile:Bhe}=Uhe,Je;RK.exports={enterPM2Mode:Fhe,start:Tc,stop:TC,reload:uK,restart:dK,list:RC,describe:hK,connect:oa,kill:$he,startAllServices:Vhe,startService:yC,getUniqueServicesList:pK,restartAllServices:Khe,isServiceRegistered:_K,reloadStopStart:EK,restartHdb:mK,deleteProcess:qhe,startClusteringProcesses:SK,startClusteringThreads:TK,isHdbRestartRunning:Ghe,isClusteringRunning:Whe,stopClustering:Yhe,reloadClustering:zhe,expectedRestartOfChildren:fK};var yp=!1;Mhe(e=>{e.type==="restart"&&AT.initSync(!0)});function Fhe(){yp=!0}o(Fhe,"enterPM2Mode");function oa(){return Je||(Je=require("pm2")),new Promise((e,t)=>{Je.connect((r,n)=>{r&&t(r),e(n)})})}o(oa,"connect");var Sn,Hhe=10,lK;function Tc(e,t=!1){if(yp)return khe(e);let r=Bhe(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let a=Sn.indexOf(r);a>-1&&Sn.splice(a,1),!lK&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Hhe&&(xhe.existsSync(ia.getHubConfigPath())?Tc(e):(await ia.generateNatsConfig(!0),Tc(e),await new Promise(c=>setTimeout(c,3e3)),await ia.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ia.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let a=AT.get(at.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,d;for(;l=c.exec(i);){if(l.index&&sa.LOG_LEVEL_HIERARCHY[a]>=sa.LOG_LEVEL_HIERARCHY[d||"info"]){let h=d===sa.LOG_LEVELS.ERR||d===sa.LOG_LEVELS.WRN?nu.OUTPUTS.STDERR:nu.OUTPUTS.STDOUT;nu.logCustomLevel(d||"info",h,n,i.slice(u,l.index).trim())}let[f,m]=l;u=l.index+f.length,d=sa.LOG_LEVELS[m]}if(sa.LOG_LEVEL_HIERARCHY[a]>=sa.LOG_LEVEL_HIERARCHY[d||"info"]){let f=d===sa.LOG_LEVELS.ERR||d===sa.LOG_LEVELS.WRN?nu.OUTPUTS.STDERR:nu.OUTPUTS.STDOUT;nu.logCustomLevel(d||"info",f,n,i.slice(u).trim())}}if(o(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!Sn&&(Sn=[],!t)){let i=o(()=>{lK=!0,Sn&&(Sn.map(a=>a.kill()),process.exit(0))},"killChildren");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}Sn.push(r)}o(Tc,"start");function khe(e){return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.start(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(khe,"startWithPM2");function TC(e){if(!yp){for(let t of Sn||[])t.name===e&&(Sn.splice(Sn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.stop(e,async(n,s)=>{n&&(Je.disconnect(),r(n)),Je.delete(e,(i,a)=>{i&&(Je.disconnect(),r(n)),Je.disconnect(),t(a)})})})}o(TC,"stop");function uK(e){return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.reload(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(uK,"reload");function dK(e){if(!yp){fK();for(let t of Sn||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.restart(e,(n,s)=>{Je.disconnect(),t(s)})})}o(dK,"restart");function fK(){for(let e of Sn||[])e.config&&(e.config.restarts=0)}o(fK,"expectedRestartOfChildren");function qhe(e){return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.delete(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(qhe,"deleteProcess");async function mK(){await Tc(Sc.generateRestart())}o(mK,"restartHdb");async function Ghe(){let e=await RC();for(let t in e)if(e[t].name===at.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}o(Ghe,"isHdbRestartRunning");function RC(){return new Promise(async(e,t)=>{try{await oa()}catch(r){t(r)}Je.list((r,n)=>{r&&(Je.disconnect(),t(r)),Je.disconnect(),e(n)})})}o(RC,"list");function hK(e){return new Promise(async(t,r)=>{try{await oa()}catch(n){r(n)}Je.describe(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(hK,"describe");function $he(){if(!yp){for(let e of Sn||[])e.kill();Sn=[];return}return new Promise(async(e,t)=>{try{await oa()}catch(r){t(r)}Je.killDaemon((r,n)=>{r&&(Je.disconnect(),t(r)),Je.disconnect(),e(n)})})}o($he,"kill");async function Vhe(){try{await SK(),await TK(),await Tc(Sc.generateAllServiceConfigs())}catch(e){throw Je?.disconnect(),e}}o(Vhe,"startAllServices");async function yC(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case at.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Sc.generateMainServerConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Sc.generateNatsIngestServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Sc.generateNatsReplyServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Sc.generateNatsHubServerConfig(),await Tc(r,t),await ia.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Sc.generateNatsLeafServerConfig(),await Tc(r,t),await ia.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Sc.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Tc(r)}catch(r){throw Je?.disconnect(),r}}o(yC,"startService");async function pK(){try{let e=await RC(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Je?.disconnect(),e}}o(pK,"getUniqueServicesList");async function Khe(e=[]){try{let t=!1,r=await pK();for(let n=0,s=Object.values(r).length;n<s;n++){let a=Object.values(r)[n].name;e.includes(a)||(a===at.PROCESS_DESCRIPTORS.HDB?t=!0:await dK(a))}t&&await EK(at.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Je?.disconnect(),t}}o(Khe,"restartAllServices");async function _K(e){if(Sn?.find(r=>r.name===e))return!0;let t=await vhe.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}o(_K,"isServiceRegistered");async function EK(e){let t=AT.get(at.CONFIG_PARAMS.THREADS_COUNT)??AT.get(at.CONFIG_PARAMS.THREADS),r=await hK(e),n=Dhe.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await TC(e),await yC(e)):e===at.PROCESS_DESCRIPTORS.HDB?await mK():await uK(e)}o(EK,"reloadStopStart");var gK;async function SK(e=!1){for(let t in at.CLUSTERING_PROCESSES){let r=at.CLUSTERING_PROCESSES[t];await yC(r,e)}}o(SK,"startClusteringProcesses");async function TK(){gK=cK(at.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await yT.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await yT.updateLocalStreams();let e=await Lhe.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===at.PRE_4_0_0_VERSION){nu.info("Starting clustering upgrade 4.0.0 process"),cK(at.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}o(TK,"startClusteringThreads");async function Yhe(){for(let e in at.CLUSTERING_PROCESSES)if(e!==at.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===at.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await gK.terminate();else{let t=at.CLUSTERING_PROCESSES[e];await TC(t)}}o(Yhe,"stopClustering");async function Whe(){for(let e in at.CLUSTERING_PROCESSES){let t=at.CLUSTERING_PROCESSES[e];if(await _K(t)===!1)return!1}return!0}o(Whe,"isClusteringRunning");async function zhe(){await ia.generateNatsConfig(!0),await yT.reloadNATSHub(),await yT.reloadNATSLeaf(),await ia.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await ia.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}o(zhe,"reloadClustering")});var NT={};Oe(NT,{compactOnStart:()=>jhe,copyDb:()=>wK});async function jhe(){Rc.notify("Running compact on start"),console.log("Running compact on start");let e=(0,AC.get)(U.ROOTPATH),t=new Map,r=st();(0,bC.updateConfigValue)(U.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,bT.join)(e,"backup",n+".mdb"),a=(0,bT.join)(e,sl,n+"-copy.mdb"),c=0;try{c=await yK(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Rc.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 wK(n,a),console.log("Backing up",n,"to",i);try{await(0,su.move)(s,i,{overwrite:!0})}catch(l){console.log("Error moving database",s,"to",i,l)}console.log("Moving copy compacted",n,"to",s),await(0,su.move)(a,s,{overwrite:!0}),await(0,su.remove)((0,bT.join)(e,sl,`${n}-copy.mdb-lock`))}try{ff()}catch(n){Rc.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}try{ff()}catch(n){Rc.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Rc.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,bC.updateConfigValue)(U.STORAGE_COMPACTONSTART,!1);for(let[s,{dbPath:i,backupDest:a}]of t){console.error("Moving backup database",a,"back to",i);try{await(0,su.move)(a,i,{overwrite:!0})}catch(c){console.error(c)}}throw ff(),n}for(let[n,{backupDest:s,recordCount:i}]of t){let a=await yK(n);if(console.log("Database",n,"after compact has a total record count of",a),i!==a){let c=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
21
|
+
Total record count before compaction: ${i}, total after: ${a}.
|
|
22
|
+
Database backup has not been removed and can be found here: ${s}`;Rc.error(c),console.error(c)}(0,AC.get)(U.STORAGE_COMPACTONSTARTKEEPBACKUP)!==!0&&(console.log("Removing backup",s),await(0,su.remove)(s))}}async function yK(e){let t=await(0,NK.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}function df(){}async function wK(e,t){console.log(`Copying database ${e} to ${t}`);let r=st()[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=df,m.primaryStore.remove=df;for(let h in m.indices){let p=m.indices[h];p.put=df,p.remove=df}m.auditStore&&(m.auditStore.put=df,m.auditStore.remove=df),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,AK.open)(new bK.default(t)),c=a.openDB(IT.INTERNAL_DBIS_NAME),l,u=0,d=s.useReadTransaction();try{for(let{key:m,value:h}of s.getRange({transaction:d})){let p=h.is_hash_attribute||h.isPrimaryKey,E,g;if(p&&(E=h.compression,g=OT(),g?h.compression=g:delete h.compression,E?.dictionary?.toString()===g?.dictionary?.toString()&&(E=null,g=null)),c.put(m,h),!(p||h.indexed))continue;let y=new IK.default(!p,p);y.encoding="binary",y.compression=E;let T=n.openDB(m,y);T.decoder=null,T.decoderCopies=!1,T.encoding="binary",y.compression=g;let R=a.openDB(m,y);R.encoder=null,console.log("copying",m,"from",e,"to",t),await f(T,R,p,d)}if(i){let m=n.openDB(IT.AUDIT_STORE_NAME,Ap);console.log("copying audit log for",e,"to",t),f(i,m,!1,d)}async function f(m,h,p,E){let g=0,y=0,T=0,R=1e7,N=null;for(;R-- >0;)try{for(let O of m.getKeys({start:N,transaction:E}))try{N=O;let{value:F,version:Z}=m.getEntry(O,{transaction:E});if(F?.length<14&&p){T++;continue}l=h.put(O,F,p?Z:void 0),g++,E.openTimer&&(E.openTimer=0),y+=(O?.length||10)+F.length,u++>5e3&&(await l,console.log("copied",g,"entries",T,"delete records,",y,"bytes"),u=0)}catch(F){console.error("Error copying record",typeof O=="symbol"?"symbol":O,"from",e,"to",t,F)}console.log("finish copying, copied",g,"entries",T,"delete records,",y,"bytes");return}catch{if(typeof N=="string"){if(N==="z")return console.error("Reached end of dbi",N,"for",e,"to",t);N=N.slice(0,-2)+"z"}else if(typeof N=="number")N++;else return console.error("Unknown key type",N,"for",e,"to",t)}}o(f,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{d.done(),a.close()}}var AK,bT,su,AC,bK,IK,IT,NK,bC,Rc,wT=ue(()=>{De();AK=require("lmdb"),bT=require("path"),su=require("fs-extra"),AC=w(oe()),bK=w(Wm()),IK=w(Ym()),IT=w($t());H();Yi();NK=w(za()),bC=w(pt()),Rc=w(j());o(jhe,"compactOnStart");o(yK,"getTotalDBRecordCount");o(df,"noop");o(wK,"copyDb")});var yc=M((gBe,vK)=>{"use strict";var Jhe=require("minimist"),{isMainThread:NC,parentPort:Ip,threadId:pBe}=require("worker_threads"),ht=(H(),v(W)),mo=j(),wC=se(),PT=ST(),CT=sr(),_Be=It(),DK=pt(),Di=uf(),OK=Zo(),{compactOnStart:Qhe}=(wT(),v(NT)),Xhe=qa(),{restartWorkers:DT,onMessageByType:Zhe}=nt(),{handleHDBError:epe,hdbErrors:tpe}=ge(),{HTTP_STATUS_CODES:rpe}=tpe,Np=oe(),{sendOperationToNode:CK,getThisNodeName:npe,monitorNodeCAs:spe}=(qn(),v(uo)),{getHDBNodeTable:EBe}=(Hl(),v(qw));Np.initSync();var bp=`Restarting HarperDB. This may take up to ${ht.RESTART_TIMEOUT_MS/1e3} seconds.`,ipe="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",PK="Clustering is not enabled so cannot be restarted",ope="Invalid service",mf,Gs;vK.exports={restart:LK,restartService:OC};NC&&Zhe(ht.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await OC({service:e.workerType}):LK({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function LK(e){Gs=Object.keys(e).length===0,mf=await Di.isServiceRegistered(ht.PROCESS_DESCRIPTORS.HDB);let t=Jhe(process.argv);if(t.service){await OC(t);return}if(Gs&&!mf){console.error(ipe);return}if(Gs&&console.log(bp),mf){Di.enterPM2Mode(),mo.notify(bp);let r=Xhe(Object.keys(ht.CONFIG_PARAM_MAP),!0);return wC.isEmptyOrZeroLength(Object.keys(r))||DK.updateConfigValue(void 0,void 0,r,!0,!0),ape(),bp}return NC?(mo.notify(bp),Np.get(ht.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Qhe(),process.env.HARPER_EXIT_ON_RESTART&&process.exit(0),setTimeout(()=>{DT()},50)):Ip.postMessage({type:ht.ITC_EVENT_TYPES.RESTART}),bp}o(LK,"restart");async function OC(e){let{service:t}=e;if(ht.HDB_PROCESS_SERVICES[t]===void 0)throw epe(new Error,ope,rpe.BAD_REQUEST,void 0,void 0,!0);if(Di.expectedRestartOfChildren(),mf=await Di.isServiceRegistered(ht.PROCESS_DESCRIPTORS.HDB),!NC){e.replicated&&spe(),Ip.postMessage({type:ht.ITC_EVENT_TYPES.RESTART,workerType:t}),Ip.ref(),await new Promise(s=>{Ip.on("message",i=>{i.type==="restart-complete"&&(s(),Ip.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===npe())continue;let i;try{({job_id:i}=await CK(s,e))}catch(a){n.push({node:s.name,message:a.message});continue}n.push(await new Promise((a,c)=>{let u=2400,d=setInterval(async()=>{if(u--<=0){clearInterval(d);let h=new Error("Timed out waiting for restart job to complete");h.replicated=n,c(h)}let m=(await CK(s,{operation:"get_job",id:i})).results[0];if(m.status==="COMPLETE"&&(clearInterval(d),a({node:s.name,message:m.message})),m.status==="ERROR"){clearInterval(d);let h=new Error(m.message);h.replicated=n,c(h)}},250)}))}return{replicated:n}}return}let r;switch(t){case ht.HDB_PROCESS_SERVICES.clustering:if(!Np.get(ht.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=PK;break}Gs&&console.log("Restarting clustering"),mo.notify("Restarting clustering"),await MK();break;case ht.HDB_PROCESS_SERVICES.clustering_config:case ht.HDB_PROCESS_SERVICES["clustering config"]:if(!Np.get(ht.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=PK;break}Gs&&console.log("Restarting clusteringConfig"),mo.notify("Restarting clustering_config"),await Di.reloadClustering();break;case"custom_functions":case"custom functions":case ht.HDB_PROCESS_SERVICES.harperdb:case ht.HDB_PROCESS_SERVICES.http_workers:case ht.HDB_PROCESS_SERVICES.http:if(Gs&&!mf){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Gs&&console.log("Restarting httpWorkers"),mo.notify("Restarting http_workers"),Gs?await Di.restart(ht.PROCESS_DESCRIPTORS.HDB):await DT("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(mo.error(r),Gs&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}o(OC,"restartService");async function ape(){await MK(),await Di.restart(ht.PROCESS_DESCRIPTORS.HDB),await wC.asyncSetTimeout(2e3),Np.get(ht.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await IC(),Gs&&(await CT.closeConnection(),process.exit(0))}o(ape,"restartPM2Mode");async function MK(){if(!DK.getConfigFromFile(ht.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await OK.getHDBProcessInfo()).clustering.length===0)mo.trace("Clustering not running, restart will start clustering services"),await PT.generateNatsConfig(!0),await Di.startClusteringProcesses(),await Di.startClusteringThreads(),await IC(),Gs&&await CT.closeConnection();else{await PT.generateNatsConfig(!0),mf?(mo.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await Di.restart(ht.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Di.restart(ht.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await OK.getHDBProcessInfo()).clustering.forEach(s=>{mo.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await wC.asyncSetTimeout(3e3),await IC(),await CT.updateLocalStreams(),Gs&&await CT.closeConnection(),mo.trace("Restart clustering restarting ingest and reply service threads");let t=DT(ht.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=DT(ht.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}o(MK,"restartClustering");async function IC(){await PT.removeNatsConfig(ht.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await PT.removeNatsConfig(ht.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}o(IC,"removeNatsConfig")});var KK=M((RBe,VK)=>{"use strict";var TBe=require("lodash"),Vn=(H(),v(W)),{handleHDBError:UK,hdbErrors:cpe}=ge(),{HDB_ERROR_MSGS:lpe,HTTP_STATUS_CODES:upe}=cpe,CC=j();VK.exports={getRolePermissions:fpe};var iu=Object.create(null),dpe=o(e=>({key:e,perms:{}}),"permsTemplateObj"),HK=o((e=!1)=>({describe:e,tables:{}}),"schemaPermsTemplate"),kK=o((e=!1,t=!1,r=!1,n=!1)=>({[Vn.PERMS_CRUD_ENUM.READ]:e,[Vn.PERMS_CRUD_ENUM.INSERT]:t,[Vn.PERMS_CRUD_ENUM.UPDATE]:r,[Vn.PERMS_CRUD_ENUM.DELETE]:n}),"permissionsTemplate"),PC=o((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...kK(t,r,n,s)}),"tablePermsTemplate"),xK=o((e,t=kK())=>({attribute_name:e,describe:$K(t),[wp]:t[wp],[DC]:t[DC],[LC]:t[LC]}),"attrPermsTemplate"),BK=o((e,t=!1)=>({attribute_name:e,describe:t,[wp]:t}),"timestampAttrPermsTemplate"),{READ:wp,INSERT:DC,UPDATE:LC}=Vn.PERMS_CRUD_ENUM,qK=Object.values(Vn.PERMS_CRUD_ENUM),GK=[wp,DC,LC];function fpe(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[Vn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(iu[t]&&iu[t].key===n)return iu[t].perms;let s=mpe(e,r);return iu[t]?iu[t].key=n:iu[t]=dpe(n),iu[t].perms=s,s}catch(r){if(!e[Vn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Vn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Vn.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${role_name}' must be updated to align with new structure from the 2.2.0 release.`;throw CC.error(n),CC.debug(r),UK(new Error,lpe.OUTDATED_PERMS_TRANSLATION_ERROR,upe.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
23
23
|
${r.stack}`;throw CC.error(n),UK(new Error)}}}o(fpe,"getRolePermissions");function mpe(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Vn.SYSTEM_SCHEMA_NAME]=n[Vn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=hpe(t[i]);return}r[i]=HK(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(a=>{if(n[i].tables[a]){let c=n[i].tables[a],l=t[i][a],u=ppe(c,l);r[i].describe||qK.forEach(d=>{u[d]&&(r[i].describe=!0)}),r[i].tables[a]=u}else r[i].tables[a]=PC()})):Object.keys(t[i]).forEach(a=>{r[i].tables[a]=PC()})}),r}o(mpe,"translateRolePermissions");function hpe(e){let t=HK(!0);return Object.keys(e).forEach(r=>{t.tables[r]=PC(!0,!0,!0,!0,!0)}),t}o(hpe,"createStructureUserPermissions");function ppe(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,d)=>{let{attribute_name:f}=d,m=d;return Vn.TIME_STAMP_NAMES.includes(f)&&(m=BK(f,d[wp])),u[f]=m,u},{}),a=t.primaryKey||t.hash_attribute,c=!!i[a],l=xK(a);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let d=i[u];d.describe=$K(d),s.attribute_permissions.push(d),c||_pe(d,l)}else if(u!==a){let d;Vn.TIME_STAMP_NAMES.includes(u)?d=BK(u):d=xK(u),s.attribute_permissions.push(d)}}),c||s.attribute_permissions.push(l),s.describe=FK(s),s}else return e.describe=FK(e),e}o(ppe,"getTableAttrPerms");function FK(e){return qK.filter(t=>e[t]).length>0}o(FK,"getSchemaTableDescribePerm");function $K(e){return GK.filter(t=>e[t]).length>0}o($K,"getAttributeDescribePerm");function _pe(e,t){GK.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}o(_pe,"checkForHashPerms")});var Op={};Oe(Op,{authentication:()=>ZK,bypassAuth:()=>Ipe,login:()=>UC,logout:()=>xC,start:()=>Npe});function Ipe(){XK=!0}async function ZK(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,a=[];try{if(i){let h=e.isOperationsServer?Rpe?Tpe:[]:Spe?gpe:[];if(h.includes(i)||h.includes("*")){if(e.method==="OPTIONS"){let p=Tn.get(U.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",E=new Bs([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",p],["Access-Control-Allow-Origin",i]]);return LT&&E.set("Access-Control-Allow-Credentials","true"),{status:200,headers:E}}a.push("Access-Control-Allow-Origin",i),LT&&a.push("Access-Control-Allow-Credentials","true")}}let l,u;if(LT){i||(i=r.host);let h=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",p=s?.split(/;\s+/)||[];for(let E of p)if(E.startsWith(h)){let g=E.indexOf(";");l=E.slice(h.length,g===-1?E.length:g),u=await YK.get(l);break}e.session=u||(u={})}let d=o((h,p,E)=>{let g=new MT.AuthAuditLog(h,p,ka.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=E,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),p===fi.SUCCESS?MC.notify(g):MC.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&MC.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let h=e.mtlsConfig.user;h!==null?((h===void 0||h==="Common Name"||h==="CN")&&(h=e.peerCertificate.subject.CN),e.user=await Le.getUser(h,null,e),d(h,fi.SUCCESS,"mTLS")):Epe("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let f;if(!e.user)if(n){if(f=ou.get(n),!f){let h=n.indexOf(" "),p=n.slice(0,h),E=n.slice(h+1),g,y;try{switch(p){case"Basic":let T=atob(E),R=T.indexOf(":");g=T.slice(0,R),y=T.slice(R+1),f=g||y?await Le.getUser(g,y,e):null;break;case"Bearer":try{f=await hw(E)}catch(N){if(N.message==="invalid token")try{return await iS(E),c({status:-1})}catch{throw N}}break}}catch(T){return Ape&&(ou.get(E)||(ou.set(E,E),d(g,fi.FAILURE,p))),c({status:401,body:Ka({error:T.message},e)})}ou.set(n,f),ype&&d(f.username,fi.SUCCESS,p)}e.user=f}else u?.user?e.user=await Le.getUser(u.user,null,e):(XK&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,zK.getSuperUser)());LT&&(e.session.update=function(h){let p=Tn.get(U.AUTHENTICATION_COOKIE_EXPIRES),E=e.protocol==="https"||r.host?.startsWith("localhost:")||r.host?.startsWith("127.0.0.1:")||r.host?.startsWith("::1");if(!l){l=(0,jK.v4)();let g=Tn.get(U.AUTHENTICATION_COOKIE_DOMAINS),y=p?new Date(Date.now()+(0,vC.convertToMS)(p)).toUTCString():bpe,T=g?.find(O=>r.host?.endsWith(O)),N=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=${y}; HttpOnly`;T&&(N+=`; Domain=${T}`),E&&(N+="; SameSite=None; Secure"),a?a.push("Set-Cookie",N):m?.headers?.set&&m.headers.set("Set-Cookie",N)}return E&&(a?(i&&a.push("Access-Control-Expose-Headers","X-Hdb-Session"),a.push("X-Hdb-Session","Secure")):m?.headers?.set&&(i&&m.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),m.headers.set("X-Hdb-Session","Secure"))),h.id=l,YK.put(h,{expiresAt:p?Date.now()+(0,vC.convertToMS)(p):void 0})},e.login=async function(h,p){let E=e.user=await Le.authenticateUser(h,p,e);e.session.update({user:E&&(E.getId?.()??E.username)})});let m=await t(e);return m&&(m.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Ls.loginPath?(m.status=302,m.headers.set("Location",Ls.loginPath(e))):m.headers.set("WWW-Authenticate","Basic")),c(m))}catch(l){throw c(l)}function c(l){let u=a.length;if(u>0){let d=l.headers;d||(l.headers=d=new Bs);for(let f=0;f<u;){let m=a[f++];d.set(m,a[f++])}}return a=null,l}o(c,"applyResponseHeaders")}function Npe({server:e,port:t,securePort:r}){e.http(ZK,t||r?{port:t,securePort:r}:{port:"all"}),WK||(WK=!0,setInterval(()=>{ou=new Map},Tn.get(U.AUTHENTICATION_CACHETTL)).unref(),JK.user.addListener(()=>{ou=new Map}))}async function UC(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password??""),"Login successful"}async function xC(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var zK,jK,Tn,MT,JK,vC,QK,Epe,MC,gpe,Spe,Tpe,Rpe,YK,LT,XK,ype,Ape,bpe,ou,WK,vT=ue(()=>{zK=w(Bn());Ur();ed();Nd();De();jK=require("uuid"),Tn=w(oe());H();MT=w(j()),JK=w(dh());vh();vC=w(se());Uo();QK=(0,MT.forComponent)("authentication"),{debug:Epe}=QK,MC=QK.withTag("auth-event");Tn.initSync();gpe=Tn.get(U.HTTP_CORSACCESSLIST),Spe=Tn.get(U.HTTP_CORS),Tpe=Tn.get(U.OPERATIONSAPI_NETWORK_CORSACCESSLIST),Rpe=Tn.get(U.OPERATIONSAPI_NETWORK_CORS),YK=ze({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),LT=Tn.get(U.AUTHENTICATION_ENABLESESSIONS)??!0,XK=process.env.AUTHENTICATION_AUTHORIZELOCAL??Tn.get(U.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,ype=Tn.get(U.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ape=Tn.get(U.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,bpe="Tue, 01 Oct 8307 19:33:20 GMT",ou=new Map;Le.onInvalidatedUser(()=>{ou=new Map});o(Ipe,"bypassAuth");o(ZK,"authentication");o(Npe,"start");o(UC,"login");o(xC,"logout")});var oY=M((DBe,iY)=>{"use strict";var we=require("joi"),eY=require("fs-extra"),tY=require("path"),ps=lt(),rY=oe(),nY=(H(),v(W)),sY=j(),{hdbErrors:wpe}=ge(),{HDB_ERROR_MSGS:Rn}=wpe,aa=/^[a-zA-Z0-9-_]+$/,Ope=/^[a-zA-Z0-9-_]+$/;iY.exports={getDropCustomFunctionValidator:Ppe,setCustomFunctionValidator:Dpe,addComponentValidator:Upe,dropCustomFunctionProjectValidator:xpe,packageComponentValidator:Bpe,deployComponentValidator:Fpe,setComponentFileValidator:Lpe,getComponentFileValidator:vpe,dropComponentFileValidator:Mpe,addSSHKeyValidator:Hpe,updateSSHKeyValidator:kpe,deleteSSHKeyValidator:qpe,setSSHKnownHostsValidator:Gpe};function UT(e,t,r){try{let n=rY.get(nY.CONFIG_PARAMS.COMPONENTSROOT),s=tY.join(n,t);return eY.existsSync(s)?e?t:r.message(Rn.PROJECT_EXISTS):e?r.message(Rn.NO_PROJECT):t}catch(n){return sY.error(n),r.message(Rn.VALIDATION_ERR)}}o(UT,"checkProjectExists");function Cp(e,t){return e.includes("..")?t.message("Invalid file path"):e}o(Cp,"checkFilePath");function Cpe(e,t,r,n){try{let s=rY.get(nY.CONFIG_PARAMS.COMPONENTSROOT),i=tY.join(s,e,t,r+".js");return eY.existsSync(i)?r:n.message(Rn.NO_FILE)}catch(s){return sY.error(s),n.message(Rn.VALIDATION_ERR)}}o(Cpe,"checkFileExists");function Ppe(e){let t=we.object({project:we.string().pattern(aa).custom(UT.bind(null,!0)).required().messages({"string.pattern.base":Rn.BAD_PROJECT_NAME}),type:we.string().valid("helpers","routes").required(),file:we.string().pattern(aa).custom(Cpe.bind(null,e.project,e.type)).custom(Cp).required().messages({"string.pattern.base":Rn.BAD_FILE_NAME})});return ps.validateBySchema(e,t)}o(Ppe,"getDropCustomFunctionValidator");function Dpe(e){let t=we.object({project:we.string().pattern(aa).custom(UT.bind(null,!0)).required().messages({"string.pattern.base":Rn.BAD_PROJECT_NAME}),type:we.string().valid("helpers","routes").required(),file:we.string().custom(Cp).required(),function_content:we.string().required()});return ps.validateBySchema(e,t)}o(Dpe,"setCustomFunctionValidator");function Lpe(e){let t=we.object({project:we.string().pattern(aa).required().messages({"string.pattern.base":Rn.BAD_PROJECT_NAME}),file:we.string().custom(Cp).required(),payload:we.string().allow("").optional(),encoding:we.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ps.validateBySchema(e,t)}o(Lpe,"setComponentFileValidator");function Mpe(e){let t=we.object({project:we.string().pattern(aa).required().messages({"string.pattern.base":Rn.BAD_PROJECT_NAME}),file:we.string().custom(Cp).optional()});return ps.validateBySchema(e,t)}o(Mpe,"dropComponentFileValidator");function vpe(e){let t=we.object({project:we.string().required(),file:we.string().custom(Cp).required(),encoding:we.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ps.validateBySchema(e,t)}o(vpe,"getComponentFileValidator");function Upe(e){let t=we.object({project:we.string().pattern(aa).custom(UT.bind(null,!1)).required().messages({"string.pattern.base":Rn.BAD_PROJECT_NAME})});return ps.validateBySchema(e,t)}o(Upe,"addComponentValidator");function xpe(e){let t=we.object({project:we.string().pattern(aa).custom(UT.bind(null,!0)).required().messages({"string.pattern.base":Rn.BAD_PROJECT_NAME})});return ps.validateBySchema(e,t)}o(xpe,"dropCustomFunctionProjectValidator");function Bpe(e){let t=we.object({project:we.string().pattern(aa).required().messages({"string.pattern.base":Rn.BAD_PROJECT_NAME}),skip_node_modules:we.boolean(),skip_symlinks:we.boolean()});return ps.validateBySchema(e,t)}o(Bpe,"packageComponentValidator");function Fpe(e){let t=we.object({project:we.string().pattern(aa).required().messages({"string.pattern.base":Rn.BAD_PROJECT_NAME}),package:we.string().optional(),restart:we.alternatives().try(we.boolean(),we.string().valid("rolling")).optional()});return ps.validateBySchema(e,t)}o(Fpe,"deployComponentValidator");function Hpe(e){let t=we.object({name:we.string().pattern(Ope).required().messages({"string.pattern.base":Rn.BAD_SSH_KEY_NAME}),key:we.string().required(),host:we.string().required(),hostname:we.string().required(),known_hosts:we.string().optional()});return ps.validateBySchema(e,t)}o(Hpe,"addSSHKeyValidator");function kpe(e){let t=we.object({name:we.string().required(),key:we.string().required()});return ps.validateBySchema(e,t)}o(kpe,"updateSSHKeyValidator");function qpe(e){let t=we.object({name:we.string().required()});return ps.validateBySchema(e,t)}o(qpe,"deleteSSHKeyValidator");function Gpe(e){let t=we.object({known_hosts:we.string().required()});return ps.validateBySchema(e,t)}o(Gpe,"setSSHKnownHostsValidator")});var Lp=M((MBe,dY)=>{"use strict";var xT=require("joi"),Ac=require("path"),hf=require("fs-extra"),{exec:$pe,spawn:Vpe}=require("child_process"),Kpe=require("util"),Ype=Kpe.promisify($pe),pf=(H(),v(W)),{PACKAGE_ROOT:Wpe}=mt(),{handleHDBError:Pp,hdbErrors:zpe}=ge(),{HTTP_STATUS_CODES:Dp}=zpe,au=oe(),jpe=lt(),bc=j(),{once:Jpe}=require("events");au.initSync();var BC=au.get(pf.CONFIG_PARAMS.COMPONENTSROOT),aY="npm install --force --omit=dev --json",Qpe=`${aY} --dry-run`,Xpe=au.get(pf.CONFIG_PARAMS.ROOTPATH),BT=Ac.join(Xpe,"ssh");dY.exports={installModules:r_e,auditModules:n_e,installAllRootModules:Zpe,uninstallRootModule:e_e,linkHarperdb:t_e,runCommand:_f};async function Zpe(e=!1,t=au.get(pf.CONFIG_PARAMS.ROOTPATH)){await FT();let r=!1,n=process.env;hf.pathExistsSync(BT)&&hf.readdirSync(BT).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+Ac.join(BT,"config")+" -o UserKnownHostsFile="+Ac.join(BT,"known_hosts"),...process.env},r=!0)});try{let s=au.get(pf.CONFIG_PARAMS.ROOTPATH),i=Ac.join(s,"node_modules","harperdb");hf.lstatSync(i).isSymbolicLink()&&hf.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&bc.error("Error removing symlink:",s)}await _f(e?"npm install --force --ignore-scripts":"npm install --force",t,n)}o(Zpe,"installAllRootModules");async function e_e(e){await _f(`npm uninstall ${e}`,au.get(pf.CONFIG_PARAMS.ROOTPATH))}o(e_e,"uninstallRootModule");async function t_e(){await FT(),await _f(`npm link ${Wpe}`,au.get(pf.CONFIG_PARAMS.ROOTPATH))}o(t_e,"linkHarperdb");async function _f(e,t=void 0,r=process.env){bc.debug({tagName:"npm_run_command"},`running command: \`${e}\``);let n=Vpe(e,{shell:!0,cwd:t,env:r,stdio:["ignore","pipe","pipe"]}),s="",i="";n.stdout.on("data",c=>{let l=c.toString();bc.debug({tagName:"npm_run_command:stdout"},l),s+=l}),n.stderr.on("data",c=>{let l=c.toString();bc.error({tagName:"npm_run_command:stderr"},l),i+=l});let[a]=await Jpe(n,"close");if(a!==0)throw new Error(`Command \`${e}\` exited with code ${a}.${i===""?"":` Error: ${i}`}`);return s||void 0}o(_f,"runCommand");async function r_e(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";bc.warn(t,e.projects);let r=uY(e);if(r)throw Pp(r,r.message,Dp.BAD_REQUEST);let{projects:n,dryRun:s}=e,i=s===!0?Qpe:aY;await FT(),await lY(n);let a={};for(let c=0,l=n.length;c<l;c++){let u=n[c];a[u]={npm_output:null,npm_error:null};let d=Ac.join(BC,u),f,m=null;try{let{stdout:h,stderr:p}=await Ype(i,{cwd:d});f=h?h.replace(`
|
|
24
24
|
`,""):null,m=p?p.replace(`
|
|
25
25
|
`,""):null}catch(h){h.stderr?a[u].npm_error=cY(h.stderr):a[u].npm_error=h.message;continue}try{a[u].npm_output=JSON.parse(f)}catch{a[u].npm_output=f}try{a[u].npm_error=JSON.parse(m)}catch{a[u].npm_error=m}}return bc.info(`finished installModules with response ${a}`),a.warning=t,a}o(r_e,"installModules");function cY(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
|