harperdb 4.6.15 → 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 +255 -255
- package/package.json +2 -2
- 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.4c114774.js → main.f935ef10.js} +2 -2
- package/utility/scripts/restartHdb.js +3 -3
- /package/studio/build-local/static/js/{main.4c114774.js.LICENSE.txt → main.f935ef10.js.LICENSE.txt} +0 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "harperdb",
|
|
3
|
-
"version": "4.6.
|
|
3
|
+
"version": "4.6.17",
|
|
4
4
|
"description": "HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"database",
|
|
@@ -82,7 +82,7 @@
|
|
|
82
82
|
"json2csv": "5.0.7",
|
|
83
83
|
"jsonata": "1.8.7",
|
|
84
84
|
"jsonwebtoken": "9.0.2",
|
|
85
|
-
"lmdb": "3.4.
|
|
85
|
+
"lmdb": "3.4.4",
|
|
86
86
|
"lodash": "4.17.21",
|
|
87
87
|
"mathjs": "11.12.0",
|
|
88
88
|
"micromatch": "^4.0.8",
|
|
@@ -15,9 +15,9 @@
|
|
|
15
15
|
`,""));return r.replace(`
|
|
16
16
|
`,"")}o(fq,"runCommand");async function xae(){try{await fae.access(pw)}catch{return!1}let e=await fq(`${pw} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return mae.eq(t,vae)}o(xae,"checkNATSServerInstalled");async function Tw(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let a=await uq.getClusterUser();if(Ll(a))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=a.username,r=a.decrypt_hash}hi.trace("create nats connection called");let i=await Iae({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:kr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:kr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:kr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),hi.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(a=>{a&&hi.error("Error with Nats client connection, connection closed",a),i===fn&&mq()}),i}o(Tw,"createConnection");function mq(){fn=void 0,Ol=void 0,Cl=void 0,Pl=void 0}o(mq,"clearClientCache");async function Bae(){fn&&(await fn.drain(),fn=void 0,Ol=void 0,Cl=void 0,Pl=void 0)}o(Bae,"closeConnection");var fn,Pl;async function Uh(){return Pl||(Pl=Tw(kr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),fn=await Pl),fn||Pl}o(Uh,"getConnection");async function xh(){if(Ol)return Ol;Ll(fn)&&await Uh();let{domain:e}=yd(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ol=await fn.jetstreamManager({domain:e,timeout:6e4}),Ol}o(xh,"getJetStreamManager");async function hq(){if(Cl)return Cl;Ll(fn)&&await Uh();let{domain:e}=yd(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Cl=fn.jetstream({domain:e,timeout:6e4}),Cl}o(hq,"getJetStream");async function Ji(){let e=fn||await Uh(),t=Ol||await xh(),r=Cl||await hq();return{connection:e,jsm:t,js:r}}o(Ji,"getNATSReferences");async function Fae(e){let t=kr.get(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await uq.getClusterUser(),s=await Tw(t,r,n),i=Sw(),a=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of a){let f=dq.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(Fae,"getServerList");async function Rw(e,t){let{jsm:r}=await Ji(),n=kr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=kr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=kr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Nae.File,retention:wae.Limits,subjects:t,discard:Oae.Old,maxMsgs:s,maxBytes:i,maxAge:n})}o(Rw,"createLocalStream");async function pq(){let{jsm:e}=await Ji(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}o(pq,"listStreams");async function Hae(e){let{jsm:t}=await Ji();await t.streams.delete(e)}o(Hae,"deleteLocalStream");async function kae(e){let{connection:t}=await Ji(),r=[],n=Sw(),s=t.subscribe(n),i=(async()=>{for await(let a of s)r.push(dq.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(kae,"listRemoteStreams");async function Gae(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ji(),i=oq(),a={durable_name:i,ack_policy:_w.Explicit};t&&(a.deliver_policy=gw.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=Ew(d.data),m={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:f};if(d.headers&&(m.origin=d.headers.get(Qr.MSG_HEADERS.ORIGIN)),u.push(m),d.ack(),d.info.pending===0)break}return await c.delete(),u}o(Gae,"viewStream");async function*qae(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ji(),i=oq(),a={durable_name:i,ack_policy:_w.Explicit};t&&(a.deliver_policy=gw.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=Ew(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(Qr.MSG_HEADERS.ORIGIN)),yield m}if(u.ack(),u.info.pending===0)break}await c.delete()}o(qae,"viewStreamIterator");async function $ae(e,t,r,n){hi.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Eq(n,r);let{js:s}=await Ji(),i=await pS(),a=`${e}.${i}`,c=await Dae(()=>n instanceof Uint8Array?n:lq.encode(n));try{hi.trace(`publishToStream publishing to subject: ${a}`),Lae(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 gq(async()=>{try{await s.publish(a,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){hi.trace(`publishToStream creating stream: ${t}`);let d=a.split(".");d[2]="*",await Rw(t,[a]),await s.publish(a,c,{headers:r})}else throw l}});throw l}}o($ae,"publishToStream");function Eq(e,t){t===void 0&&(t=Pae());let r=kr.get(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Qr.MSG_HEADERS.ORIGIN)&&r&&t.append(Qr.MSG_HEADERS.ORIGIN,r),t}o(Eq,"addNatsMsgHeader");function yd(e){e=e.toLowerCase();let t=vh.join(kr.get(Qe.CONFIG_PARAMS.ROOTPATH),Mae);if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return Ll(hw)&&(hw={port:Dh.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:Dh.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Qr.SERVER_SUFFIX.HUB,config_file:Qr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:vh.join(t,Qr.PID_FILES.HUB),hdbNatsPath:t}),hw;if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return Ll(mw)&&(mw={port:Dh.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:Dh.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Qr.SERVER_SUFFIX.LEAF,config_file:Qr.NATS_CONFIG_FILES.LEAF_SERVER,domain:Dh.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Qr.SERVER_SUFFIX.LEAF,pid_file_path:vh.join(t,Qr.PID_FILES.LEAF),hdbNatsPath:t}),mw;hi.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}o(yd,"getServerConfig");async function _q(e,t,r,n){try{await e.consumers.add(t,{ack_policy:_w.Explicit,durable_name:r,deliver_policy:gw.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}o(_q,"createConsumer");async function Vae(e,t,r){await e.consumers.delete(t,r)}o(Vae,"removeConsumer");function Kae(e){return e.split(".")[1]}o(Kae,"extractServerName");async function Yae(e,t,r=6e4,n=Sw()){if(!mS.isObject(t))throw new Error("data param must be an object");let s=lq.encode(t),{connection:i}=await Ji(),a={timeout:r};n&&(a.reply=n,a.noMux=!0);let c=await i.request(e,s,a);return Ew(c.data)}o(Yae,"request");function yw(e){return new Promise(async(t,r)=>{let n=_ae(pw,["--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(yw,"reloadNATS");async function Wae(){let{pid_file_path:e}=yd(Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await yw(e)}o(Wae,"reloadNATSHub");async function zae(){let{pid_file_path:e}=yd(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await yw(e)}o(zae,"reloadNATSLeaf");function jae(e,t,r){let n;switch(e.code){case iq.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case iq.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}o(jae,"requestErrorHandler");async function Qae(e,t){let r=t+Qr.SERVER_SUFFIX.LEAF,{connection:n}=await Ji(),{jsm:s}=await sce(r),{schema:i,table:a}=e,c=hS.createNatsTableStreamName(i,a),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await gq(async()=>{if(e.subscribe===!0)await _q(s,c,n.info.server_name,l);else try{await Vae(s,c,n.info.server_name)}catch(u){hi.trace(u)}})}o(Qae,"updateRemoteConsumer");async function Jae(e,t,r,n){let s=hS.createNatsTableStreamName(e,t),i=r+Qr.SERVER_SUFFIX.LEAF,a={type:Qe.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!cq&&Aae()<kr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=fw();await c(a)}await Rae(a),n==="stop"&&await mS.asyncSetTimeout(1e3)}o(Jae,"updateConsumerIterator");function gq(e){return Tae.writeTransaction(Qe.SYSTEM_SCHEMA_NAME,Qe.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}o(gq,"exclusiveLock");async function Sq(e,t){let r=hS.createNatsTableStreamName(e,t),n=await pS(),s=tce(e,t,n);await Rw(r,[s])}o(Sq,"createLocalTableStream");async function Xae(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await Sq(n,s)}}o(Xae,"createTableStreams");async function Tq(e,t,r=void 0){if(kr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=hS.createNatsTableStreamName(e,t),{domain:s}=yd(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await Uh()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")hi.warn(n);else throw n}}o(Tq,"purgeTableStream");async function Zae(e,t){if(kr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await Tq(e,t[r])}o(Zae,"purgeSchemaTableStreams");async function ece(e){return(await xh()).streams.info(e)}o(ece,"getStreamInfo");function tce(e,t,r){return`${Qr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}o(tce,"createSubjectName");async function pS(){if(Mh)return Mh;if(Mh=(await xh())?.nc?.info?.server_name,Mh===void 0)throw new Error("Unable to get jetstream manager server name");return Mh}o(pS,"getJsmServerName");async function rce(){let e=await xh(),t=await pS(),r=await pq();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let a=nce(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(".");hi.trace(`Updating stream subject name from: ${i} to: ${d}`),s.subjects[0]=d,await e.streams.update(s.name,s)}}o(rce,"updateLocalStreams");function nce(e){let{config:t}=e,r=!1,n=kr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=kr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=kr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}o(nce,"updateStreamLimits");async function sce(e){let t,r;try{t=await fn.jetstream({domain:e}),r=await fn.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw hi.error("Unable to connect to:",e),n}return{js:t,jsm:r}}o(sce,"connectToRemoteJS")});function Aw(e){let t=e.get(ES),r=t?(0,Ad.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:Fh(e)??1,nodes:[]})})}i[n]=0,e.putSync(ES,(0,Ad.pack)(r))}return r}function Bh(e){return Aw(e).remoteNameToId}function Aq(e,t){let r=Aw(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(ES,(0,Ad.pack)(r)),s}function _S(e,t){let r=Aw(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(ES,(0,Ad.pack)(r))}return yq.trace?.("The remote node name map",e,n,s),s}var yq,Ad,ES,bw=ue(()=>{yq=w(ri());ss();Ad=require("msgpackr"),ES=Symbol.for("remote-ids");o(Aw,"getIdMappingRecord");o(Bh,"exportIdMapping");o(Aq,"remoteToLocalNodeId");o(_S,"getIdOfRemoteNode")});var Iw={};Oe(Iw,{commitsAwaitingReplication:()=>bd,getHDBNodeTable:()=>Kt,getReplicationSharedStatus:()=>Id,iterateRoutes:()=>kh,shouldReplicateToNode:()=>Hh,subscribeToNodeUpdates:()=>Nd});function Kt(){return bq||(bq=je({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 Id(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(48),n&&{callback:n}))}function Nd(e){Kt().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;Oq.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 Kt().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 Hh(e,t){let r=Ka.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===Ka.default.get(U.REPLICATION_SHARD))))&&Kt().primaryStore.get(Ze())?.replicates||e.subscriptions?.some(n=>(n.database||n.schema)===t&&n.subscribe)}function ice(){Nd(e=>{Ya({},(t,r)=>{let n=e.name,s=Iq.get(n);if(s||Iq.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=Id(i,r,n,()=>{let c=a[0],l=a.lastTime;for(let{txnTime:u,onConfirm:d}of bd.get(r)||[])u>l&&u<=c&&d();a.lastTime=c});a.lastTime=0,s.set(r,a)}})})}function*kh(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=Ka.default.get(U.REPLICATION_SECUREPORT)??(!Ka.default.get(U.REPLICATION_PORT)&&Ka.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||Ka.default.get(U.REPLICATION_PORT)||Ka.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){Nq.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 Nq,wq,Ka,Oq,bq,Iq,bd,Dl=ue(()=>{De();ss();am();Nq=require("worker_threads"),wq=w(ge()),Ka=w(oe());k();Oq=w(ri());server.nodes=[];o(Kt,"getHDBNodeTable");o(Id,"getReplicationSharedStatus");o(Nd,"subscribeToNodeUpdates");o(Hh,"shouldReplicateToNode");Iq=new Map;bv((e,t,r)=>{if(r>server.nodes.length)throw new wq.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);bd||(bd=new Map,ice());let n=bd.get(e);return n||(n=[],bd.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:o(()=>{++i===r&&s()},"onConfirm")})})});o(ice,"startSubscriptionToReplications");o(kh,"iterateRoutes")});var Lq={};Oe(Lq,{connectedToNode:()=>Ml,disconnectedFromNode:()=>Od,ensureNode:()=>Bo,requestClusterStatus:()=>Pq,startOnMainThread:()=>Ow});async function Ow(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,Fh(l.auditStore));break}}}Zi.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=Kt().primaryStore.get(a);if(l!==null){let u=e.url??Wa();if(l===void 0||l.url!==u||l.shard!==e.shard)return Bo(a,{name:a,url:u,shard:e.shard,replicates:!0})}}o(c,"ensureThisNode"),Kt().primaryStore.get(a)&&c();for(let l of kh(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)}Nd(s)});let n;function s(i,a=i?.name){let c=Ze()&&a===Ze()||Wa()&&i?.url===Wa();if(c){let f=!!i?.replicates;if(n!==void 0&&n!==f)for(let m of Kt().search([]))m.replicates&&m.name!==a&&s(m,m.name);n=f}if(at.trace("Setting up node replication for",i),!i){for(let[f,m]of Xi){let h;for(let[p,{worker:_,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),at.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){Xi.get(f).iterator.remove(),Xi.delete(f);return}}return}if(c)return;if(!i.url){at.info(`Node ${i.name} is missing url`);return}let l=Xi.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(at.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 wd)if(i.url===m.url){wd.delete(f);break}wd.set(i.name,i)}let u=st();if(l||(l=new Map,Xi.set(i.url,l)),l.iterator=Ya(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]||(at.warn(`Database ${m} not found for node ${i.name}, making a subscription anyway`),d(m,!1))}function d(f,m){at.trace("Setting up replication for database",f,"on node",i.name);let h=l.get(f),p,_=[{replicateByDefault:m,...i}];gS.has(f)&&(_.push({replicateByDefault:m,name:Ze(),startTime:gS.get(f),endTime:Date.now(),replicates:!0}),gS.delete(f));let g=Hh(i,f),y=Zi.workers.filter(T=>T.name==="http");if(h?(p=h.worker,h.nodes=_):g&&(t=t%y.length,p=y[t++],l.set(f,{worker:p,nodes:_,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:_};p?p.postMessage(T):Gh(T)},oce);else{at.info("Node no longer should be used, unsubscribing from node",{replicates:i.replicates,databaseName:f,node:i,subscriptions:i.subscriptions,hasDatabase:!!u[f],thisReplicates:Kt().primaryStore.get(Ze())?.replicates}),Kt().primaryStore.get(Ze())?.replicates||(n=!1,at.info("Disabling replication, this node name",Ze(),Kt().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"),Od=o(function(i){try{at.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let a=Array.from(wd.keys()),c=a.sort(),l=c.indexOf(i.name||pi(i.url));if(l===-1){at.warn("Disconnected node not found in node map",i.name,a);return}let u=Xi.get(i.url),d=u?.get(i.database);if(!d){at.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished||!ww.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],_=wd.get(p);u=Xi.get(_.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)){at.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){at.info(`Disconnected node ${i.name} has no nodes to fail over to ${p}`);return}at.info(`Failing over ${i.database} from ${i.name} to ${p}`),y?y.postMessage({type:"subscribe-to-node",database:i.database,nodes:T}):Gh({database:i.database,nodes:T});return}at.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(a){at.error("Error failing over node",a)}},"disconnectedFromNode"),Ml=o(function(i){let a=Xi.get(i.url),c=a?.get(i.database);if(!c){at.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){at.warn("Newly connected node has no node subscriptions",i.database,c);return}if(!l.name){at.debug("Connected node is not named yet",i.database,c);return}c.nodes=[l];let u=!1;for(let d of Xi.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 _=h.filter(g=>g&&g.name!==l.name);_.length<h.length&&(f.nodes=_,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,Zi.onMessageByType)("disconnected-from-node",Od),(0,Zi.onMessageByType)("connected-to-node",Ml),(0,Zi.onMessageByType)("request-cluster-status",Pq)}function Pq(e,t){let r=[];for(let[n,s]of wd)try{let i=Xi.get(s.url);at.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,Nw.cloneDeep)(s);c.database_sockets=a,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){at.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Bo(e,t){let r=Kt();e=e??pi(t.url),t.name=e;try{if(t.ca){let s=new Cq.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){at.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(at.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.patch(t);else{t.replicates&&!ww.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,Nw.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])]}at.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Zi,SS,at,Nw,ww,Cq,oce,Xi,Od,Ml,wd,gS,qh=ue(()=>{De();Zi=w(nt());ss();SS=require("worker_threads");Dl();at=w(Q()),Nw=require("lodash"),ww=w(oe());k();Cq=require("crypto"),oce=200,Xi=new Map,wd=new Map,gS=new Map;o(Ow,"startOnMainThread");o(Pq,"requestClusterStatus");SS.parentPort&&(Od=o(e=>{SS.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Ml=o(e=>{SS.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Zi.onMessageByType)("subscribe-to-node",e=>{Gh(e)}),(0,Zi.onMessageByType)("unsubscribe-from-node",e=>{TS(e)}));o(Bo,"ensureNode")});var os=M(Yt=>{"use strict";var hr=require("path"),{watch:ace}=require("chokidar"),xn=require("fs-extra"),Cd=require("node-forge"),Bq=require("net"),{generateKeyPair:Cw,X509Certificate:Fo,createPrivateKey:Fq}=require("crypto"),cce=require("util");Cw=cce.promisify(Cw);var wt=Cd.pki,Ei=require("joi"),{v4:Hq}=require("uuid"),{validateBySchema:Mw}=lt(),{forComponent:lce}=Q(),is=oe(),Ds=(k(),v(W)),{CONFIG_PARAMS:Ul}=Ds,_i=rA(),{ClientError:ja}=ge(),yS=require("node:tls"),{relative:kq,join:uce}=require("node:path"),{CERT_PREFERENCE_APP:VMe,CERTIFICATE_VALUES:Dq}=_i,dce=xc(),Pw=yt(),{table:fce,getDatabases:mce,databases:RS}=(De(),v(mt)),{getJWTRSAKeys:Mq}=(gd(),v(Ph)),ht=lce("tls");Yt.generateKeys=xw;Yt.updateConfigCert=zq;Yt.createCsr=Tce;Yt.signCertificate=Rce;Yt.setCertTable=Pd;Yt.loadCertificates=Kq;Yt.reviewSelfSignedCert=Fw;Yt.createTLSSelector=Qq;Yt.listCertificates=Xq;Yt.addCertificate=wce;Yt.removeCertificate=Cce;Yt.createNatsCerts=bce;Yt.generateCertsKeys=Ace;Yt.getReplicationCert=Vh;Yt.getReplicationCertAuth=Sce;Yt.renewSelfSigned=Ice;Yt.hostnamesFromCert=kw;Yt.getKey=Pce;Yt.getHostnamesFromCertificate=Lce;Yt.getPrimaryHostName=Hw;var{urlToNodeName:Gq,getThisNodeUrl:hce,getThisNodeName:bS,clearThisNodeName:pce}=(ss(),v(Ho)),{readFileSync:Ece,statSync:qq}=require("node:fs"),KMe=oe(),{getTicketKeys:_ce,onMessageFromWorkers:gce}=nt(),za=Q(),{isMainThread:$q}=require("worker_threads"),{TLSSocket:Vq,createSecureContext:YMe}=require("node:tls"),vw=3650,$h=["127.0.0.1","localhost","::1"],Uw=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];gce(async e=>{e.type===Ds.ITC_EVENT_TYPES.RESTART&&(is.initSync(!0),await Fw())});var Jr;function Ja(){return Jr||(Jr=mce().system.hdb_certificate,Jr||(Jr=fce({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__"}]}))),Jr}o(Ja,"getCertTable");async function Vh(){let e=Qq("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 Fo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}o(Vh,"getReplicationCert");async function Sce(){Ja();let e=(await Vh()).options.cert,r=new Fo(e).issuer.match(/CN=(.*)/)?.[1];return Jr.get(r)}o(Sce,"getReplicationCertAuth");var vq,Qa=new Map;function Kq(){if(vq)return;vq=!0;let e=[{configKey:Ul.TLS},{configKey:Ul.OPERATIONSAPI_TLS}];Ja();let t=hr.dirname(Pw.getConfigFilePath()),r;for(let{configKey:n}of e){let s=Pw.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let a=i.privateKey,c=a&&kq(uce(t,"keys"),a);c&&Uq(a,l=>{Qa.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&$q){let d;Uq(u,f=>{if(Dq.cert===f)return;let m=i.hostname??i.hostnames??i.host??i.hosts;m&&!Array.isArray(m)&&(m=[m]);let h=jq(u),p=new Fo(h),_;try{_=Hw(p)}catch(R){ht.error("error extracting host name from certificate",R);return}if(_==null){ht.error("No host name found on certificate");return}if(p.checkIssued(new Fo(Dq.cert)))return;let g=Jr.primaryStore.get(_),y=qq(u).mtimeMs,T=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&y<=T){y<T&&ht.info(`Certificate ${_} 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=Jr.put({name:_,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(Kq,"loadCertificates");function Uq(e,t,r){let n,s=o((i,a)=>{try{let c=a.mtimeMs;c&&c!==n&&(n&&$q&&ht.warn(`Reloading ${r}:`,i),n=c,t(jq(i)))}catch(c){ht.error(`Error loading ${r}:`,i,c)}},"loadFile");xn.existsSync(e)?s(e,qq(e)):ht.error(`${r} file not found:`,e),ace(e,{persistent:!1}).on("change",s)}o(Uq,"loadAndWatch");function Lw(){let e=hce();if(e==null){let t=$h[0];return ht.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return Gq(e)}o(Lw,"getHost");function AS(){let e=bS();if(e==null){let t=$h[0];return ht.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}o(AS,"getCommonName");async function Tce(){let e=await Vh(),t=wt.certificateFromPem(e.options.cert),r=wt.privateKeyFromPem(e.options.key);ht.info("Creating CSR with cert named:",e.name);let n=wt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:AS()},...Uw];ht.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:Yq()}];return ht.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),Cd.pki.certificationRequestToPem(n)}o(Tce,"createCsr");function Yq(){let e=$h.includes(AS())?$h:[...$h,AS()];return e.includes(Lw())||e.push(Lw()),[{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=>Bq.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}o(Yq,"certExtensions");async function Rce(e){let t={},r=hr.join(is.getHdbBasePath(),Ds.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;Ja();for await(let d of Jr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(Qa.has(d.private_key_name)){n=Qa.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await xn.exists(hr.join(r,d.private_key_name))){n=xn.readFile(hr.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await Dw();s=d.ca,n=d.private_key}n=wt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=wt.certificateFromPem(s.certificate);ht.info("Signing CSR with cert named",s.name);let a=wt.certificationRequestFromPem(e.csr);try{a.verify()}catch(d){return ht.error(d),new Error("Error verifying CSR: "+d.message)}let c=Cd.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()+vw),ht.info("sign cert setting validity:",c.validity),ht.info("sign cert setting subject from CSR:",a.subject.attributes),c.setSubject(a.subject.attributes),ht.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=a.getAttribute({name:"extensionRequest"}).extensions;ht.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=a.publicKey,c.sign(n,Cd.md.sha256.create()),t.certificate=wt.certificateToPem(c)}else ht.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}o(Rce,"signCertificate");async function yce(e,t){await Pd({name:bS(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await Pd({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(yce,"createCertificateTable");async function Pd(e){let t=new Fo(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},Ja(),await Jr.patch(e)}o(Pd,"setCertTable");async function xw(){let e=await Cw("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 Bw(e,t,r){let n=wt.createCertificate();if(!t){let a=await Vh();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()+vw);let i=[{name:"commonName",value:AS()},...Uw];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(Yq()),n.sign(e,Cd.md.sha256.create()),wt.certificateToPem(n)}o(Bw,"generateCertificates");async function Dw(){let e=await Xq(),t;for(let r of e){if(!r.is_authority)continue;let n=await Jq(r.private_key_name);if(r.private_key_name&&n&&new Fo(r.certificate).checkPrivateKey(Fq(n))){ht.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;ht.trace("No CA found with matching private key")}o(Dw,"getCertAuthority");async function Wq(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()+vw);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${is.get(Ul.REPLICATION_HOSTNAME)??Gq(is.get(Ul.REPLICATION_URL))??Hq().split("-")[0]}`},...Uw];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,Cd.md.sha256.create());let a=hr.join(is.getHdbBasePath(),Ds.LICENSE_KEY_DIR_NAME),c=hr.join(a,_i.PRIVATEKEY_PEM_NAME);return r&&await xn.writeFile(c,wt.privateKeyToPem(e)),n}o(Wq,"generateCertAuthority");async function Ace(){let{privateKey:e,publicKey:t}=await xw(),r=await Wq(e,t),n=await Bw(e,t,r);await yce(n,r),zq()}o(Ace,"generateCertsKeys");async function bce(){let e=await Bw(wt.privateKeyFromPem(_i.CERTIFICATE_VALUES.key),void 0,wt.certificateFromPem(_i.CERTIFICATE_VALUES.cert)),t=hr.join(is.getHdbBasePath(),Ds.LICENSE_KEY_DIR_NAME),r=hr.join(t,_i.NATS_CERTIFICATE_PEM_NAME);await xn.exists(r)||await xn.writeFile(r,e);let n=hr.join(t,_i.NATS_CA_PEM_NAME);await xn.exists(n)||await xn.writeFile(n,_i.CERTIFICATE_VALUES.cert)}o(bce,"createNatsCerts");async function Ice(){Ja();for await(let e of Jr.search([{attribute:"is_self_signed",value:!0}]))await Jr.delete(e.name);await Fw()}o(Ice,"renewSelfSigned");async function Fw(){pce(),await Kq(),Ja();let e=await Dw();if(!e){ht.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(xn.readFileSync(u)),keyPath:u}}catch(d){return ht.warn(`Failed to parse private key from ${u}:`,d.message),{key:null,keyPath:u}}},"tryToParseKey"),n=is.get(Ul.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=is.get(Ul.TLS_PRIVATEKEY),d=r(u);s=d.key,i=d.keyPath}let a=hr.join(is.getHdbBasePath(),Ds.LICENSE_KEY_DIR_NAME),c=kq(a,i);s||(ht.warn("Unable to parse the TLS key",i,"A new key will be generated and used to create Certificate Authority"),{privateKey:s}=await xw(),xn.existsSync(hr.join(a,_i.PRIVATEKEY_PEM_NAME))&&(c=`privateKey${Hq().split("-")[0]}.pem`),await xn.writeFile(hr.join(a,c),wt.privateKeyToPem(s)));let l=await Wq(s,wt.setRsaPublicKey(s.n,s.e),!1);await Pd({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 Vh()){let r=bS();ht.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await Dw();let n=wt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await Bw(wt.privateKeyFromPem(e.private_key),s,n);await Pd({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}o(Fw,"reviewSelfSignedCert");function zq(){let e=dce(Object.keys(Ds.CONFIG_PARAM_MAP),!0),t=hr.join(is.getHdbBasePath(),Ds.LICENSE_KEY_DIR_NAME),r=hr.join(t,_i.PRIVATEKEY_PEM_NAME),n=hr.join(t,_i.NATS_CERTIFICATE_PEM_NAME),s=hr.join(t,_i.NATS_CA_PEM_NAME),i=Ds.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),Pw.updateConfigValue(void 0,void 0,a,!1,!0)}o(zq,"updateConfigCert");function jq(e){return e.startsWith("-----BEGIN")?e:Ece(e,"utf8")}o(jq,"readPEM");var xq=yS.createSecureContext;yS.createSecureContext=function(e){if(!e.cert||!e.key)return xq(e);let t={...e};delete t.key,delete t.cert;let r=xq(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var Nce=Vq.prototype._init;Vq.prototype._init=function(e,t){Nce.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 vl=new Map;function Qq(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(),vl.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 Fo(m);f.is_authority&&(h.asString=m,vl.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 Jq(f.private_key_name),_=f.certificate,g=new Fo(_);if(vl.has(g.issuer)&&(_+=`
|
|
17
17
|
`+vl.get(g.issuer)),!p||!_)throw new Error("Missing private key or certificate for secure server");let y={ciphers:f.ciphers,ticketKeys:_ce(),availableCAs:vl,ca:t&&Array.from(vl.values()),cert:_,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(vl),T.certStart=_.toString().slice(0,100);let R=f.hostnames??kw(g);Array.isArray(R)||(R=[R]);let N;for(let O of R)if(O){O[0]==="*"&&(s=!0,O=O.slice(1)),O===Lw()&&(h+=2),Bq.isIP(O)&&(N=!0);let F=r.get(O)?.quality??0;h>F&&r.set(O,T)}else za.error("No hostname found for certificate at",yS.certificate);za.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){za.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){za.info("TLS requested for",a||"(no SNI)");let l=a;for(;;){let d=r.get(l);if(d)return za.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?za.debug("No certificate found to match",a,"using the default certificate"):za.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):za.info("No default certificate found"),c(null,u)}o(i,"SNICallback")}o(Qq,"createTLSSelector");async function Jq(e){let t=Qa.get(e);return!t&&e?await xn.readFile(hr.join(is.get(Ul.ROOTPATH),Ds.LICENSE_KEY_DIR_NAME,e),"utf8"):t}o(Jq,"getPrivateKeyByName");async function Xq(){Ja();let e=[];for await(let t of Jr.search([]))e.push(t);return e}o(Xq,"listCertificates");async function wce(e){let t=Mw(e,Ei.object({name:Ei.string().required(),certificate:Ei.string().required(),is_authority:Ei.boolean().required(),private_key:Ei.string(),hosts:Ei.array(),uses:Ei.array()}));if(t)throw new ja(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,a=new Fo(n),c=!1,l=!1,u;for(let[h,p]of Qa)!s&&!c&&a.checkPrivateKey(Fq(p))&&(c=!0,u=h),s&&s===p&&(l=!0,u=h);if(!i&&!s&&!c)throw new ja("A suitable private key was not found for this certificate");let d;if(!r){try{d=Hw(a)}catch(h){ht.error(h)}if(d==null)throw new ja("Error extracting certificate host name, please provide a name parameter")}let f=Oce(r??d);s&&!c&&!l&&(await xn.writeFile(hr.join(is.getHdbBasePath(),Ds.LICENSE_KEY_DIR_NAME,f+".pem"),s),Qa.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 Pd(m),"Successfully added certificate: "+f}o(wce,"addCertificate");function Oce(e){return e.replace(/[^a-z0-9\.]/gi,"-")}o(Oce,"sanitizeName");async function Cce(e){let t=Mw(e,Ei.object({name:Ei.string().required()}));if(t)throw new ja(t.message);let{name:r}=e;Ja();let n=await Jr.get(r);if(!n)throw new ja(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Jr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(ht.info("Removing private key named",s),await xn.remove(hr.join(is.getHdbBasePath(),Ds.LICENSE_KEY_DIR_NAME,s)))}return await Jr.delete(r),"Successfully removed "+r}o(Cce,"removeCertificate");function Hw(e){let t=e.subject?.match(/CN=(.*)/)?.[1];return t||kw(e)[0]}o(Hw,"getPrimaryHostName");function kw(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(kw,"hostnamesFromCert");async function Pce(e){if(e.bypass_auth!==!0)throw new ja("Unauthorized","401");let t=Mw(e,Ei.object({name:Ei.string().required()}));if(t)throw new ja(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await Mq()).privateKey;if(r===".jwtPublic")return(await Mq()).publicKey;if(Qa.get(r))return Qa.get(e.name);throw new ja("Key not found")}o(Pce,"getKey");function Lce(e){return[e.subject?.CN,...e.subjectaltname.split(",").filter(t=>t.trim().startsWith("DNS:")).map(t=>t.trim().substring(4))]}o(Lce,"getHostnamesFromCertificate")});var R$={};Oe(R$,{CONFIRMATION_STATUS_POSITION:()=>g$,LATENCY_POSITION:()=>LS,NodeReplicationConnection:()=>Md,OPERATION_REQUEST:()=>Vw,RECEIVED_TIME_POSITION:()=>Yw,RECEIVED_VERSION_POSITION:()=>Kw,RECEIVING_STATUS_POSITION:()=>Ww,RECEIVING_STATUS_RECEIVING:()=>T$,RECEIVING_STATUS_WAITING:()=>S$,SENDING_TIME_POSITION:()=>Kh,createWebSocket:()=>DS,databaseSubscriptions:()=>Za,replicateOverWS:()=>Yh,tableUpdateListeners:()=>jw});async function DS(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(!qw){let l=(0,m$.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),qw=u.secureContexts}if(i=qw.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,p$.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(PS?.caCount!==ko.size&&(PS=h$.createSecureContext({...i.options,ca:[...ko,...i.options.availableCAs.values()]}),PS.caCount=ko.size),c.secureContext=PS),new d$.WebSocket(e,"harperdb-replication-v1",c)}function Yh(e,t,r){let n=t.port||t.securePort,s=xl.pid%1e3+"-"+f$.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||Za,f,m,h=!1,p=t.subscription;p?.then&&p.then(E=>{p=E,p.auditStore&&(f=p.auditStore)});let _=t.tables||u&&st()[u],g;if(!r){ae.error?.(s,"No authorization provided"),Ss(1008,"Unauthorized");return}let y=new Map,T=[];g=r.name,g&&t.connection&&(t.connection.nodeName=g);let R,N,O,F,Z,G,Y,q=6e4,K,ce=0,le=0,se=0,pe=u$.default.get(U.REPLICATION_BLOBTIMEOUT)??12e4,Ne=new Map,Ue=[],xe=0,Rr;if(t.url){let E=o(()=>{Z&&le===e._socket?.bytesRead&&se===e._socket?.bytesWritten?e.terminate():(Z=performance.now(),e.ping(),le=e._socket?.bytesRead,se=e._socket?.bytesWritten)},"sendPing");O=setInterval(E,c$).unref(),E()}else Jt();e._socket?.setMaxListeners(200);function Jt(){clearTimeout(F),le=e._socket?.bytesRead,se=e._socket?.bytesWritten,F=setTimeout(()=>{le===e._socket?.bytesRead&&se===e._socket?.bytesWritten&&(ae.warn?.(`Timeout waiting for ping from ${g}, terminating connection and reconnecting`),e.terminate())},c$*2).unref()}o(Jt,"resetPingTimer");function kt(){if(!(!g||!u))return m||(m=Id(f,u,g)),m}o(kt,"getSharedStatus"),u&&ga(u);let Xt,vf,Pc=[],Gt=[],Uf,xf=[],NE=[],wE=[],Hy=150,Bf=25,Pe=0,OE=0,Ff=!1,po,Lr,yr,Hf;e.on("message",E=>{ce=performance.now();try{let S=E.dataView=new Wc(E.buffer,E.byteOffset,E.byteLength);if(E[0]>127){let P=(0,et.decode)(E),[L,D,H]=P;switch(L){case e$:{if(D){if(g){if(g!==D){ae.error?.(s,`Node name mismatch, expecting to connect to ${g}, but peer reported name as ${D}, disconnecting`),e.send((0,et.encode)([Ld])),Ss(1008,"Node name mismatch");return}}else if(g=D,t.connection?.tentativeNode){let B=t.connection.tentativeNode;B.name=g,t.connection.tentativeNode=null,Bo(g,B)}if(t.connection&&(t.connection.nodeName=g),ae.debug?.(s,"received node name:",g,"db:",u??P[2]),!u)try{ga(u=P[2]),u==="system"&&(Xt=Ya(t,(B,de)=>{pu(de)&&Sa(de)}),e.on("close",()=>{Xt?.remove()}))}catch(B){ae.warn?.(s,"Error setting database",B),e.send((0,et.encode)([Ld])),Ss(1008,B.message);return}Dr()}break}case o$:{ae.debug?.(s,"Received table definitions for",D.map(B=>B.table));for(let B of D){let de=P[2];B.database=de;let me;pu(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),_||(_=st()?.[de]))}break}case Ld:Ss();break;case Vw:try{let B=r?.replicates||r?.subscribers||r?.name;ae.debug?.("Received operation request",D,"from",g),server.operation(D,{user:r},!B).then(de=>{Array.isArray(de)&&(de={results:de}),de.requestId=D.requestId,e.send((0,et.encode)([NS,de]))},de=>{e.send((0,et.encode)([NS,{requestId:D.requestId,error:(0,Dd.errorToString)(de)}]))})}catch(B){e.send((0,et.encode)([NS,{requestId:D.requestId,error:(0,Dd.errorToString)(B)}]))}break;case NS:let{resolve:C,reject:x}=y.get(D.requestId);D.error?x(new Error(D.error)):C(D),y.delete(D.requestId);break;case Gw:let z=P[3];if(!_){u?ae.error?.(s,"No database found for",u):ae.error?.(s,"Database name never received"),Ss();return}let ne=_[z];ne=V({table:z,database:u,attributes:D.attributes,schemaDefined:D.schemaDefined},ne),Pc[H]={name:z,decoder:new et.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:D.typedStructs,structures:D.structures}),getEntry(B){return ne.primaryStore.getEntry(B)},rootStore:ne.primaryStore.rootStore};break;case t$:Hf=f?Aq(D,f):new Map,Uf=P[2],ae.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${Uf}`);break;case r$:let re=H;wE[re]=D;break;case i$:kt()[g$]=D,ae.trace?.(s,"received and broadcasting committed update",D),kt().buffer.notify();break;case s$:R=D,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 $w.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 n$:{let B=D,de;try{let me=P[3],Se=Gt[H]||(Gt[H]=_[P[4]]);if(!Se)return ae.warn?.("Unknown table id trying to handle record request",H);let ee=Se.primaryStore.getBinaryFast(Symbol.for("structures")),j=ee?.length??0;if(j>0&&j!==OE){OE=j;let Te=(0,et.decode)(ee);e.send((0,et.encode)([Gw,{typedStructs:Te.typed,structures:Te.named},H,Se.tableName]))}let he=Se.primaryStore.getBinaryFast(me);if(he){let Te=Se.primaryStore.decoder.decode(he,{valueAsBuffer:!0}),fe=ut||{};fe.version=(0,E$.getLastVersion)(),ut&&ut[Pu]&Vr&&(Te=Buffer.from(Te),_m(()=>Se.primaryStore.decoder.decode(he),We=>_a(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;f_(()=>{let he=Pc[me].decoder.decode(ee.value);ee.value=he,ee.key=Se,B(ee)||j&&setTimeout(()=>j.forEach(l_),6e4).unref()},f?.rootStore,he=>{let Te=Lc(he,Se);return j||(j=[]),j.push(Te),Te})}else B();y.delete(P[1]);break}case Zq:{yr=D;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",yr),!p){let Ee;p=new Promise(tt=>{ae.debug?.("Waiting for subscription to database "+u),Ee=tt}),p.ready=Ee,Za.set(u,p)}if(r.name)de=Kt().subscribe(r.name),de.then(async Ee=>{B=Ee;for await(let tt of B){let rt=tt.value;if(!(rt?.replicates===!0||rt?.replicates?.receives||rt?.subscriptions?.some(lr=>(lr.database||lr.schema)===u&&lr.publish!==!1))){me=!0,e.send((0,et.encode)([Ld])),Ss(1008,`Unauthorized database subscription to ${u}`);return}}},Ee=>{ae.error?.(s,"Error subscribing to HDB nodes",Ee)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,et.encode)([Ld])),Ss(1008,`Unauthorized database subscription to ${u}`);return}if(Lr&&(ae.debug?.(s,"stopping previous subscription",u),Lr.emit("close")),yr.length===0)return;let Se=yr[0],ee=o(Ee=>{if(Ee&&(Se.replicateByDefault?!Se.tables.includes(Ee.tableName):Se.tables.includes(Ee.tableName)))return{table:Ee}},"tableToTableEntry"),j={txnTime:0},he,Te,fe=1/0,We,Et=o((Ee,tt)=>{if(Ee.type==="end_txn"){j.txnTime&&(a[i]!==66&&ae.error?.("Invalid encoding of message"),Eu(9),Eu(A_),Mc(We=tt),dt()),i=c,j.txnTime=0;return}let rt=Ee.nodeId,lr=Ee.tableId,Mt=Te[lr];if(!Mt&&(Mt=Te[lr]=ee(p.tableById[lr]),!Mt))return ae.debug?.("Not subscribed to table",lr);let Ts=Mt.table,vt=Ts.primaryStore,Js=vt.encoder;(Ee.extendedType&O_||!Js.typedStructs)&&(Js._mergeStructures(Js.getStructures()),Js.typedStructs&&(Js.lastTypedStructuresLength=Js.typedStructs.length));let _u=he[rt];if(!(_u&&_u.startTime<tt&&(!_u.endTime||_u.endTime>tt)))return CS&&ae.trace?.(s,"skipping replication update",Ee.recordId,"to:",g,"from:",rt,"subscribed:",he),rM();CS&&ae.trace?.(s,"sending replication update",Ee.recordId,"to:",g,"from:",rt,"subscribed:",he);let ky=Ee.version;j.txnTime!==ky&&(j.txnTime&&(CS&&ae.trace?.(s,"new txn time, sending queued txn",j.txnTime),a[i]!==66&&ae.error?.("Invalid encoding of message"),dt()),j.txnTime=ky,i=c,Mc(ky));let vc=Ee.residencyId,Gy=hu(vc,Ts),PE;if(Gy&&!Gy.includes(g)){let Xs=hu(Ee.previousResidencyId,Ts);if(Xs&&!Xs.includes(g)&&(Ee.type==="put"||Ee.type==="patch")||Ts.getResidencyById)return rM();let Gf=Ee.recordId;ae.trace?.(s,"sending invalidation",Gf,g,"from",rt);let qf=0;vc&&(qf|=zc),Ee.previousResidencyId&&(qf|=jc);let Vy,LE=null;for(let nM in Ts.indices){if(!LE){if(Vy=Ee.getValue(vt,!0),!Vy)break;LE={}}LE[nM]=Vy[nM]}PE=Qc(Ee.version,lr,Gf,null,rt,Ee.user,Ee.type==="put"||Ee.type==="patch"?"invalidate":Ee.type,Js.encode(LE),qf,vc,Ee.previousResidencyId,Ee.expiresAt)}function rM(){return ae.trace?.(s,"skipping audit record",Ee.recordId),G||(G=setTimeout(()=>{G=null,(We||0)+a$/2<fe&&(CS&&ae.trace?.(s,"sending skipped sequence update",fe),e.send((0,et.encode)([s$,fe])))},a$).unref()),new Promise(setImmediate)}o(rM,"skipAuditRecord");let qy=Js.typedStructs,$y=Js.structures;if((qy?.length!=Mt.typed_length||$y?.length!=Mt.structure_length)&&(Mt.typed_length=qy?.length,Mt.structure_length=$y.length,ae.debug?.(s,"send table struct",Mt.typed_length,Mt.structure_length),Mt.sentName||(Mt.sentName=!0),e.send((0,et.encode)([Gw,{typedStructs:qy,structures:$y,attributes:Ts.attributes,schemaDefined:Ts.schemaDefined},lr,Mt.table.tableName]))),vc&&!NE[vc]&&(e.send((0,et.encode)([r$,Gy,vc])),NE[vc]=!0),PE)Eu(PE.length),Dc(PE);else{let Xs=Ee.encoded;Ee.extendedType&Vr&&_m(()=>Ee.getValue(vt),qf=>_a(qf,Ee.recordId),vt.rootStore);let Gf=Xs[0]===66?8:0;Eu(Xs.length-Gf),Dc(Xs,Gf),ae.trace?.("wrote record",Ee.recordId,"length:",Xs.length)}return e._socket.writableNeedDrain?new Promise(Xs=>{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",Xs)}):xe>Bf?new Promise(Xs=>{Rr=Xs}):new Promise(setImmediate)},"sendAuditRecord"),dt=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");Lr=new zw.EventEmitter,Lr.once("close",()=>{me=!0,B?.end()});for(let{startTime:Ee}of yr)Ee<fe&&(fe=Ee);(de||Promise.resolve()).then(async()=>{p=await p,f=p.auditStore,Te=p.tableById.map(ee),he=[];for(let{name:tt,startTime:rt,endTime:lr}of yr){let Mt=_S(tt,f);ae.debug?.("subscription to",tt,"using local id",Mt,"starting",rt),he[Mt]={startTime:rt,endTime:lr}}Sa(u),Xt||(Xt=Nl(tt=>{tt.databaseName===u&&Sa(u)}),vf=yh(tt=>{tt===u&&(e.send((0,et.encode)([Ld])),Ss())}),e.on("close",()=>{Xt?.remove(),vf?.remove()})),e.send((0,et.encode)([t$,Bh(p.auditStore),yr.map(({name:tt})=>tt)]));let Ee=!0;do{isFinite(fe)||(ae.warn?.("Invalid sequence id "+fe),Ss(1008,"Invalid sequence id"+fe));let tt;if(Ee&&!me&&(Ee=!1,fe===0)){ae.info?.("Replicating all tables to",g);let rt=fe,lr=MS(f);for(let Mt in _){if(!ee(Mt))continue;let Ts=_[Mt];for(let vt of Ts.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,kt()[Kh]=1;let Js=Qc(vt.version,Ts.tableId,vt.key,null,lr,null,"put",_m(()=>Ts.primaryStore.encoder.encode(vt.value),_u=>_a(_u,vt.key)),vt.metadataFlags&-256,vt.residencyId,null,vt.expiresAt);await Et({recordId:vt.key,tableId:Ts.tableId,type:"put",getValue(){return vt.value},encoded:Js,version:vt.version,residencyId:vt.residencyId,nodeId:lr,extendedType:vt.metadataFlags},vt.localTime)}}}tt&&Et({type:"end_txn"},fe),kt()[Kh]=0,fe=rt}for(let{key:rt,value:lr}of f.getRange({start:fe||1,exclusiveStart:!0,snapshot:!1})){if(me)return;let Mt=bt(lr);ae.debug?.("sending audit record",new Date(rt)),kt()[Kh]=rt,fe=rt,await Et(Mt,rt),Lr.startTime=rt,tt=!0}tt&&Et({type:"end_txn"},fe),kt()[Kh]=0,await qU(f)}while(!me)}).catch(Ee=>{ae.error?.(s,"Error handling subscription to node",Ee),Ss(1008,"Error handling subscription to node")});break}}return}S.position=8;let A=!0,b,I;do{kt();let P=S.readInt();if(P===9&&S.getUint8(S.position)==A_){S.position++,R=I=S.readFloat64(),m[Kw]=R,m[Yw]=Date.now(),m[Ww]=S$,ae.trace?.("received remote sequence update",R,u);break}let L=S.position,D=bt(E,L,L+P),H=Pc[D.tableId];H||ae.error?.(`No table found with an id of ${D.tableId}`);let C;D.residencyId&&(C=wE[D.residencyId],ae.trace?.(s,"received residency list",C,D.type,D.recordId));try{let x=D.recordId;f_(()=>{b={table:H.name,id:D.recordId,type:D.type,nodeId:Hf.get(D.nodeId),residencyList:C,timestamp:D.version,value:D.getValue(H),user:D.user,beginTxn:A,expiresAt:D.expiresAt}},f?.rootStore,z=>Lc(z,x))}catch(x){throw x.message+="typed structures for current decoder"+JSON.stringify(H.decoder.typedStructs),x}A=!1,ae.trace?.(s,"received replication message",D.type,"id",b.id,"version",new Date(D.version),"nodeId",b.nodeId),m[Kw]=D.version,m[Yw]=Date.now(),m[Ww]=T$,p.send(b),S.position=L+P}while(S.position<E.byteLength);Pe++,it(E.byteLength,"bytes-received",`${g}.${u}.${b?.table||"unknown_table"}`,"replication","ingest"),Pe>Hy&&!Ff&&(Ff=!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--,Ff&&(Ff=!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)([i$,N])),ae.trace?.(s,"sent confirmation of a commit at",N),N=null},Mce)),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",Jt),e.on("pong",()=>{if(t.connection){let E=performance.now()-Z;t.connection.latency=E,kt()&&(m[LS]=E),t.isSubscriptionConnection&&Ml({name:g,database:u,url:t.url,latency:E})}Z=null}),e.on("close",(E,S)=>{clearInterval(O),clearTimeout(F),clearInterval(Y),Lr&&Lr.emit("close"),po&&po.end();for(let[A,{reject:b}]of y)b(new Error(`Connection closed ${S?.toString()} ${E}`));ae.debug?.(s,"closed",E,S?.toString())});function Ss(E,S){try{e.isFinished=!0,ae.debug?.(s,"closing",g,u,E,S),e.close(E,S),t.connection?.emit("finished")}catch(A){ae.error?.(s,"Error closing connection",A)}}o(Ss,"close");let Ea=new Set;async function _a(E,S){let A=u_(E);if(Ea.has(A)){ae.debug?.("Blob already being sent",A);return}Ea.add(A);try{let b;xe++;for await(let I of E.stream())b&&(ae.debug?.("Sending blob chunk",A,"length",b.length),e.send((0,et.encode)([wS,{fileId:A,size:E.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:E.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,Dd.errorToString)(b)},Buffer.alloc(0)]))}finally{Ea.delete(A),xe--,xe<Bf&&Rr?.()}}o(_a,"sendBlobs");function Lc(E,S){let A=u_(E),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 $w.PassThrough,Ne.set(A,b)),b.connectedToBlob=!0,b.lastChunk=Date.now(),b.recordId=S,E.size===void 0&&b.expectedSize&&(E.size=b.expectedSize);let I=b.blob??createBlob(b,E);b.blob=I;let P=bo(()=>Em(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(Lc,"receiveBlobs");function Dr(){if(h||(h=!0,t.connection?.on("subscriptions-updated",Dr)),!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 E=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>(E.get(I.id)??0)&&E.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:L}=b;if(b.subscriptions){for(let x of b.subscriptions)if(x.subscribe&&(x.schema||x.database)===u){let z=x.table;_?.[z]?.replicate!==!1&&P.push(z)}L=!1}else for(let x in _)(L?_[x].replicate===!1:_[x].replicate)&&P.push(x);let D=f&&_S(b.name,f),H=p?.dbisDB?.get([Symbol.for("seq"),D])??1,C=Math.max(H?.seqId??1,(typeof b.startTime=="string"?new Date(b.startTime).getTime():b.startTime)??1);if(ae.debug?.("Starting time recorded in db",b.name,D,u,H?.seqId,"start time:",C,new Date(C)),S!==b){let x=f&&_S(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(D===void 0?ae.warn("Starting subscription request from node",b,"but no node id found"):T.push(D),E.get(D)>C&&(C=E.get(D),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:L,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)([Zq,A]));else{let b=o(()=>{let I=performance.now();K=setTimeout(()=>{ce<=I?Ss(1008,"Connection has no subscriptions and is no longer used"):b()},q).unref()},"scheduleClose");b()}}o(Dr,"sendSubscriptionRequestUpdate");function hu(E,S){if(!E)return;let A=xf[E];return A||(A=S.getResidencyRecord(E),xf[E]=A),A}o(hu,"getResidence");function pu(E){return!(Xa&&Xa!="*"&&!Xa[E]&&!Xa.includes?.(E)&&!Xa.some?.(S=>S.name===E))}o(pu,"checkDatabaseAccess");function ga(E){if(p=p||d.get(E),!pu(E))throw new Error(`Access to database "${E}" is not permitted`);p||ae.warn?.(`No database named "${E}" was declared and registered`),f=p?.auditStore,_||(_=st()?.[E]);let S=Ze();if(S===g)throw S?new Error("Should not connect to self",S):new Error("Node name not defined");return CE(S,E),!0}o(ga,"setDatabase");function CE(E,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(L=>({name:L.name,type:L.type,isPrimaryKey:L.isPrimaryKey}))})}ae.trace?.("Sending database info for node",E,"database name",S),e.send((0,et.encode)([e$,E,S,b]))}o(CE,"sendNodeDBName");function Sa(E){let S=st()?.[E],A=[];for(let b in S){if(yr&&!yr.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)([o$,A,E]))}o(Sa,"sendDBSchema"),Y=setInterval(()=>{for(let[E,S]of Ne)S.lastChunk+pe<Date.now()&&(ae.warn?.(`Timeout waiting for blob stream to finish ${E} for record ${S.recordId??"unknown"} from ${g}`),Ne.delete(E),S.end())},pe).unref();let Ta=1,kf=[];return{end(){po&&po.end(),Lr&&Lr.emit("close")},getRecord(E){let S=Ta++;return new Promise((A,b)=>{let I=[n$,S,E.table.tableId,E.id];kf[E.table.tableId]||(I.push(E.table.tableName),kf[E.table.tableId]=!0),e.send((0,et.encode)(I)),ce=performance.now(),y.set(S,{tableId:E.table.tableId,key:E.id,resolve(P){let{table:L,entry:D}=E;if(A(P),P)return L._recordRelocate(D,P)},reject:b})})},sendOperation(E){let S=Ta++;return E.requestId=S,e.send((0,et.encode)([Vw,E])),new Promise((A,b)=>{y.set(S,{resolve:A,reject:b})})}};function Eu(E){Ra(5),E<128?a[c++]=E:E<16384?(l.setUint16(c,E|32768),c+=2):E<1056964608?(l.setUint32(c,E|3221225472),c+=4):(a[c]=255,l.setUint32(c+1,E),c+=5)}function Dc(E,S=0,A=E.length){let b=A-S;Ra(b),E.copy(a,c,S,A),c+=b}function Mc(E){Ra(8),l.setFloat64(c,E),c+=8}function Ra(E){if(E+16>a.length-c){let S=Buffer.allocUnsafeSlow(c+E-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(E,S){let A=E.database??"data";if(A!=="data"&&!ke[A]){ae.warn?.("Database not found",E.database);return}S||(S={});let b=S.schemaDefined,I=!1,P=E.schemaDefined,L=S.attributes||[];for(let D=0;D<E.attributes?.length;D++){let H=E.attributes[D],C=L.find(x=>x.name===H.name);(!C||C.type!==H.type)&&(b?ae.error?.(`Schema for '${u}.${E.table}' is defined locally, but attribute '${H.name}: ${H.type}' from '${g}' does not match local attribute ${C?"'"+C.name+": "+C.type+"'":"which does not exist"}`):(I=!0,P||(H.indexed=!0),C?L[L.indexOf(C)]=H:L.push(H)))}return I?(ae.debug?.("(Re)creating",E),je({table:E.table,database:E.database,schemaDefined:E.schemaDefined,attributes:L,...S})):S}}var u$,et,d$,f$,Dd,zw,m$,h$,xl,p$,$w,E$,_$,ae,Zq,e$,t$,Ld,r$,Gw,n$,IS,Vw,NS,s$,i$,o$,wS,g$,Kw,Yw,Kh,LS,Ww,S$,T$,Dce,OS,jw,Za,CS,a$,Mce,c$,qw,PS,l$,Md,Qw=ue(()=>{De();Di();bw();lb();ss();u$=w(oe());k();Jc();et=require("msgpackr"),d$=require("ws"),f$=require("worker_threads"),Dd=w(Q());qh();zw=require("events"),m$=w(os()),h$=w(require("node:tls"));Dl();xl=w(require("node:process")),p$=require("node:net");Wi();zn();$w=require("node:stream"),E$=require("lmdb"),_$=w(require("minimist")),ae=(0,Dd.forComponent)("replication").conditional,Zq=129,e$=140,t$=141,Ld=142,r$=130,Gw=132,n$=133,IS=134,Vw=136,NS=137,s$=143,i$=144,o$=145,wS=146,g$=0,Kw=1,Yw=2,Kh=3,LS=4,Ww=5,S$=0,T$=1,Dce=(0,_$.default)(xl.argv),OS=Dce.HDB_LEADER_URL??xl.env.HDB_LEADER_URL,jw=new Map,Za=new Map,CS=!0,a$=300,Mce=2,c$=3e4;o(DS,"createWebSocket");l$=500,Md=class extends zw.EventEmitter{static{o(this,"NodeReplicationConnection")}socket;startTime;retryTime=l$;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??pi(t)}async connect(){this.session||this.resetSession();let t=[];this.socket=await DS(this.url,{serverName:this.nodeName,authorization:this.authorization});let r;ae.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${xl.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=l$,this.nodeSubscriptions&&Ml({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,r=Yh(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&&Od({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(Yh,"replicateOverWS")});var Ho={};Oe(Ho,{clearThisNodeName:()=>qce,disableReplication:()=>Bce,enabledDatabases:()=>Xa,forEachReplicatedDatabase:()=>Ya,getThisNodeId:()=>MS,getThisNodeName:()=>Ze,getThisNodeUrl:()=>Wa,hostnameToUrl:()=>FS,lastTimeInAuditStore:()=>Fh,monitorNodeCAs:()=>P$,replicateOperation:()=>Vce,replicationCertificateAuthorities:()=>ko,sendOperationToNode:()=>Wh,servers:()=>Uce,setReplicator:()=>D$,start:()=>xce,startOnMainThread:()=>Ow,subscribeToNode:()=>Gh,unsubscribeFromNode:()=>TS,urlToNodeName:()=>pi});function xce(e){if(!e.port&&!e.securePort&&(e.port=Ms.default.get(U.OPERATIONSAPI_NETWORK_PORT),e.securePort=Ms.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 kh(e))t.set(pi(s.url),s);Fce(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(),Yh(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=Kt().primaryStore;if(s.authorized&&s.peerCertificate.subjectaltname){let c=(0,O$.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(ko);c.options.availableCAs&&l.push(...c.options.availableCAs.values());let u={...c.options,ca:l};c.updatedContext=BS.createSecureContext(u)}catch(l){Ot.error("Error creating replication TLS config",l)}},"updateContexts");s.secureContextsListeners.push(i),n.push(i),Ms.default.get(U.REPLICATION_ENABLEROOTCAS)!==!1&&i()}P$(()=>{for(let s of n)s()})}function P$(e){let t=0;Nd(r=>{r?.ca&&(ko.add(r.ca),ko.size!==t&&(t=ko.size,e?.()))})}function Bce(e=!0){C$=e}function Fce(e){C$||(st(),Xa=e.databases,Ya(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Za;for(let[s,i]of US){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];D$(r,s,e),jw.get(s)?.forEach(i=>i(s))}}))}function D$(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 L$ extends xr{static{o(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Za,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 Wn,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 _=kce(p,L$.subscription,e);if(_?.isConnected){let g=Id(t.auditStore,e,p)[LS];(!d||g<m)&&(d=_,f=p,m=g)}}if(!d)throw l||new N$.ServerError(`No connection to any other nodes are available: ${c}`,502);let h={requestId:vce++,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",xS,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function Hce(e,t,r,n,s){let i=US.get(e);i||US.set(e,i=new Map);let a=i.get(r);if(a)return a;if(t)return i.set(r,a=new Md(e,t,r,n,s)),a.connect(),a.once("finished",()=>i.delete(r)),a}function kce(e,t,r){let n=y$.get(e);n||(n=new Map,y$.set(e,n));let s=n.get(r);if(s)return s;let i=Kt().primaryStore.get(e);return i?.url&&(s=new Md(i.url,t,r,e,i.authorization),n.set(r,s),s.connect(),s.once("finished",()=>n.delete(r))),s}async function Wh(e,t,r){r||(r={}),r.serverName=e.name;let n=await DS(e.url,r),s=Yh(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 Gh(e){try{w$.isMainThread&&Ot.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Za.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,Za.set(e.database,t)}let r=Hce(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=>Hh(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(Kt().primaryStore.getRange({})));let n=US.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Gce(){if(Jw!==void 0)return Jw;let e=Ms.default.get(U.OPERATIONSAPI_TLS_CERTIFICATE)||Ms.default.get(U.TLS_CERTIFICATE);if(e)return Jw=new b$.X509Certificate((0,I$.readFileSync)(e)).subject?.match(/CN=(.*)/)?.[1]??null}function Ze(){return xS||(xS=Ms.default.get("replication_hostname")??pi(Ms.default.get("replication_url"))??Gce()??A$("operationsapi_network_secureport")??A$("operationsapi_network_port")??"127.0.0.1")}function qce(){xS=void 0}function A$(e){let t=Ms.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function vS(e){let t=Ms.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function MS(e){return Bh(e)?.[Ze()]}function Wa(){let e=Ms.default.get("replication_url");return e||FS(Ze())}function FS(e){let t=vS("replication_port");if(t)return`ws://${e}:${t}`;if(t=vS("replication_secureport"),t)return`wss://${e}:${t}`;if(t=vS("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=vS("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function pi(e){if(e)return new URL(e).hostname}function Ya(e,t){for(let n of Object.getOwnPropertyNames(ke))r(n);return yh(n=>{r(n)}),Nl((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):$ce(n)&&t(s,n,!1)}o(r,"forDatabase")}function $ce(e){let t=ke[e];for(let r in t)if(t[r].replicate)return!0}function Fh(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function Vce(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=>Wh(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 Ms,Ot,b$,I$,BS,N$,w$,O$,C$,vce,Uce,ko,Xa,US,y$,Jw,xS,ss=ue(()=>{De();Da();Au();Qw();Mr();Ms=w(oe()),Ot=w(Q()),b$=require("crypto"),I$=require("fs");qh();Dl();k();bw();BS=w(require("node:tls")),N$=w(ge()),w$=require("worker_threads"),O$=w(os()),vce=1,Uce=[],ko=Ms.default.get(U.REPLICATION_ENABLEROOTCAS)!==!1?new Set(BS.rootCertificates):new Set;o(xce,"start");o(P$,"monitorNodeCAs");o(Bce,"disableReplication");o(Fce,"assignReplicationSource");o(D$,"setReplicator");US=new Map;o(Hce,"getSubscriptionConnection");y$=new Map;o(kce,"getRetrievalConnectionByName");o(Wh,"sendOperationToNode");o(Gh,"subscribeToNode");o(TS,"unsubscribeFromNode");o(Gce,"getCommonNameFromCert");o(Ze,"getThisNodeName");o(qce,"clearThisNodeName");Object.defineProperty(Le,"hostname",{get(){return Ze()}});o(A$,"getHostFromListeningPort");o(vS,"getPortFromListeningPort");o(MS,"getThisNodeId");Le.replication={getThisNodeId:MS,exportIdMapping:Bh};o(Wa,"getThisNodeUrl");o(FS,"hostnameToUrl");o(pi,"urlToNodeName");o(Ya,"forEachReplicatedDatabase");o($ce,"hasExplicitlyReplicatedTable");o(Fh,"lastTimeInAuditStore");o(Vce,"replicateOperation")});var jh=M((gve,B$)=>{"use strict";var vd=YG(),{validateBySchema:zh}=lt(),{commonValidators:Ud,schemaRegex:Xw}=ki(),pr=require("joi"),Kce=Q(),Yce=require("uuid").v4,GS=Po(),xd=(k(),v(W)),Wce=require("util"),ec=es(),{handleHDBError:Go,hdbErrors:zce,ClientError:Bl}=ge(),{HDB_ERROR_MSGS:HS,HTTP_STATUS_CODES:qo}=zce,{SchemaEventMsg:qS}=ai(),M$=rr(),{getDatabases:jce}=(De(),v(mt)),{transformReq:Bd}=ie(),{replicateOperation:v$}=(ss(),v(Ho)),{cleanupOrphans:Qce}=(zn(),v(m_)),kS=pr.string().min(1).max(Ud.schema_length.maximum).pattern(Xw).messages({"string.pattern.base":"{:#label} "+Ud.schema_format.message}),Jce=pr.string().min(1).max(Ud.schema_length.maximum).pattern(Xw).messages({"string.pattern.base":"{:#label} "+Ud.schema_format.message}).required(),Xce=pr.string().min(1).max(Ud.schema_length.maximum).pattern(Xw).messages({"string.pattern.base":"{:#label} "+Ud.schema_format.message,"any.required":"'primary_key' is required","string.base":"'primary_key' must be a string"}).required();B$.exports={createSchema:Zce,createSchemaStructure:U$,createTable:ele,createTableStructure:x$,createAttribute:ile,dropSchema:tle,dropTable:rle,dropAttribute:nle,getBackup:ole,cleanupOrphanBlobs:ale};async function Zce(e){let t=await U$(e);return GS.signalSchemaChange(new qS(process.pid,e.operation,e.schema)),t}o(Zce,"createSchema");async function U$(e){let t=zh(e,pr.object({database:kS,schema:kS}));if(t)throw new Bl(t.message);if(Bd(e),!await vd.checkSchemaExists(e.schema))throw Go(new Error,HS.SCHEMA_EXISTS_ERR(e.schema),qo.BAD_REQUEST,xd.LOG_LEVELS.ERROR,HS.SCHEMA_EXISTS_ERR(e.schema),!0);return await ec.createSchema(e),`database '${e.schema}' successfully created`}o(U$,"createSchemaStructure");async function ele(e){return Bd(e),e.hash_attribute=e.primary_key??e.hash_attribute,await x$(e)}o(ele,"createTable");async function x$(e){let t=zh(e,pr.object({database:kS,schema:kS,table:Jce,residence:pr.array().items(pr.string().min(1)).optional(),hash_attribute:Xce}));if(t)throw new Bl(t.message);if(!await vd.checkSchemaTableExists(e.schema,e.table))throw Go(new Error,HS.TABLE_EXISTS_ERR(e.schema,e.table),qo.BAD_REQUEST,xd.LOG_LEVELS.ERROR,HS.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Yce(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ec.createTable(n,e);else throw Go(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",qo.BAD_REQUEST);else await ec.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}o(x$,"createTableStructure");async function tle(e){let t=zh(e,pr.object({database:pr.string(),schema:pr.string()}).or("database","schema").messages({"object.missing":"'database' is required"}));if(t)throw new Bl(t.message);Bd(e);let r=await vd.checkSchemaExists(e.schema);if(r)throw Go(new Error,r,qo.NOT_FOUND,xd.LOG_LEVELS.ERROR,r,!0);let n=await vd.schemaDescribe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await ec.dropSchema(e),GS.signalSchemaChange(new qS(process.pid,e.operation,e.schema)),await M$.purgeSchemaTableStreams(e.schema,s);let i=await v$(e);return i.message=`successfully deleted '${e.schema}'`,i}o(tle,"dropSchema");async function rle(e){let t=zh(e,pr.object({database:pr.string(),schema:pr.string(),table:pr.string().required()}));if(t)throw new Bl(t.message);Bd(e);let r=await vd.checkSchemaTableExists(e.schema,e.table);if(r)throw Go(new Error,r,qo.NOT_FOUND,xd.LOG_LEVELS.ERROR,r,!0);await ec.dropTable(e),await M$.purgeTableStream(e.schema,e.table);let n=await v$(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}o(rle,"dropTable");async function nle(e){let t=zh(e,pr.object({database:pr.string(),schema:pr.string(),table:pr.string().required(),attribute:pr.string().required()}));if(t)throw new Bl(t.message);Bd(e);let r=await vd.checkSchemaTableExists(e.schema,e.table);if(r)throw Go(new Error,r,qo.NOT_FOUND,xd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Go(new Error,"You cannot drop a hash attribute",qo.BAD_REQUEST,void 0,void 0,!0);if(xd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Go(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,qo.BAD_REQUEST,void 0,void 0,!0);try{return await ec.dropAttribute(e),sle(e),GS.signalSchemaChange(new qS(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Kce.error(`Got an error deleting attribute ${Wce.inspect(e)}.`),n}}o(nle,"dropAttribute");function sle(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(sle,"dropAttributeFromGlobal");async function ile(e){Bd(e);let t=jce()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Go(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,qo.BAD_REQUEST,void 0,void 0,!0);return await ec.createAttribute(e),GS.signalSchemaChange(new qS(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}o(ile,"createAttribute");function ole(e){return ec.getBackup(e)}o(ole,"getBackup");function ale(e){if(!e.database)throw new Bl('Must provide "database" name for search for orphaned blobs');if(!databases[e.database])throw new Bl(`Unknown database '${e.database}'`);return Qce(databases[e.database],e.database),{message:"Orphaned blobs cleanup started, check logs for progress"}}o(ale,"cleanupOrphanBlobs")});var H$=M((Tve,F$)=>{"use strict";var{OPERATIONS_ENUM:cle}=(k(),v(W)),Zw=class{static{o(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=cle.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};F$.exports=Zw});var eO=M((Ave,V$)=>{"use strict";var lle=es(),yve=H$(),$S=ie(),VS=(k(),v(W)),ule=oe(),{handleHDBError:k$,hdbErrors:dle}=ge(),{HDB_ERROR_MSGS:G$,HTTP_STATUS_CODES:q$}=dle,fle=Object.values(VS.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),$$="To use this operation audit log must be enabled in harperdb-config.yaml";V$.exports=mle;async function mle(e){if($S.isEmpty(e.schema))throw new Error(G$.SCHEMA_REQUIRED_ERR);if($S.isEmpty(e.table))throw new Error(G$.TABLE_REQUIRED_ERR);if(!ule.get(VS.CONFIG_PARAMS.LOGGING_AUDITLOG))throw k$(new Error,$$,q$.BAD_REQUEST,VS.LOG_LEVELS.ERROR,$$,!0);let t=$S.checkSchemaTableExist(e.schema,e.table);if(t)throw k$(new Error,t,q$.NOT_FOUND,VS.LOG_LEVELS.ERROR,t,!0);if(!$S.isEmpty(e.search_type)&&fle.indexOf(e.search_type)<0)throw new Error(`Invalid searchType '${read_audit_log_object.search_type}'`);return await lle.readAuditLog(e)}o(mle,"readAuditLog")});var Y$=M((Ive,K$)=>{"use strict";var{OPERATIONS_ENUM:hle}=(k(),v(W)),tO=class{static{o(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=hle.GET_BACKUP,this.schema=t,this.table=r}};K$.exports=tO});var j$=M((Cve,z$)=>{"use strict";var ple=es(),wve=Y$(),rO=ie(),Ele=(k(),v(W)),Ove=oe(),{handleHDBError:_le,hdbErrors:gle}=ge(),{HDB_ERROR_MSGS:W$,HTTP_STATUS_CODES:Sle}=gle;z$.exports=Tle;async function Tle(e){if(rO.isEmpty(e.schema))throw new Error(W$.SCHEMA_REQUIRED_ERR);if(rO.isEmpty(e.table))throw new Error(W$.TABLE_REQUIRED_ERR);let t=rO.checkSchemaTableExist(e.schema,e.table);if(t)throw _le(new Error,t,Sle.NOT_FOUND,Ele.LOG_LEVELS.ERROR,t,!0);return await ple.getBackup(readAuditLogObject)}o(Tle,"getBackup")});var Z$=M((Lve,X$)=>{"use strict";var Rle=oe(),tc=require("joi"),yle=lt(),Q$=require("moment"),Ale=require("fs-extra"),nO=require("path"),ble=require("lodash"),Qh=(k(),v(W)),{LOG_LEVELS:Fl}=(k(),v(W)),Ile="YYYY-MM-DD hh:mm:ss",Nle=nO.resolve(__dirname,"../logs");X$.exports=function(e){return yle.validateBySchema(e,wle)};var wle=tc.object({from:tc.custom(J$),until:tc.custom(J$),level:tc.valid(Fl.NOTIFY,Fl.FATAL,Fl.ERROR,Fl.WARN,Fl.INFO,Fl.DEBUG,Fl.TRACE),order:tc.valid("asc","desc"),limit:tc.number().min(1),start:tc.number().min(0),log_name:tc.custom(Ole)});function J$(e,t){if(Q$(e,Q$.ISO_8601).format(Ile)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}o(J$,"validateDatetime");function Ole(e,t){if(ble.invert(Qh.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Rle.get(Qh.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Qh.LOG_NAMES.HDB:e,i=s===Qh.LOG_NAMES.INSTALL?nO.join(Nle,Qh.LOG_NAMES.INSTALL):nO.join(n,s);return Ale.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}o(Ole,"validateReadLogPath")});var iO=M((Mve,tV)=>{"use strict";var KS=(k(),v(W)),Cle=Q(),Ple=oe(),Lle=Z$(),sO=require("path"),eV=require("fs-extra"),{once:Dle}=require("events"),{handleHDBError:Mle,hdbErrors:vle}=ge(),{PACKAGE_ROOT:Ule}=Rt(),{replicateOperation:xle}=(ss(),v(Ho)),Ble=sO.join(Ule,"logs"),Fle=1e3,Hle=200;tV.exports=kle;async function kle(e){let t=Lle(e);if(t)throw Mle(t,t.message,vle.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=xle(e),n=Ple.get(KS.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e.log_name===void 0?KS.LOG_NAMES.HDB:e.log_name,i=s===KS.LOG_NAMES.INSTALL?sO.join(Ble,KS.LOG_NAMES.INSTALL):sO.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?Fle:e.limit,h=e.order===void 0?void 0:e.order,p=e.start===void 0?0:e.start,_=p+m,g=0;h==="desc"&&!u&&!f&&(g=Math.max(eV.statSync(i).size-(_+5)*Hle,0));let y=eV.createReadStream(i,{start:g});y.on("error",G=>{Cle.error(G)});let T=0,R=[],N="",O;y.on("data",G=>{let Y=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;G=N+G;let q=0,K;for(;(K=Y.exec(G))&&!y.destroyed;){O&&(O.message=G.slice(q,K.index),F(O));let[ce,le,se]=K,pe=se.split("] ["),Ne=pe[0],Ue=pe[1];pe.splice(0,2),O={timestamp:le,thread:Ne,level:Ue,tags:pe,message:""},q=K.index+ce.length}N=G.slice(q)}),y.on("end",G=>{y.destroyed||O&&(O.message=N.trim(),F(O))}),y.resume();function F(G){let Y,q,K;switch(!0){case(a&&l&&d):Y=new Date(G.timestamp),q=new Date(u),K=new Date(f),G.level===c&&Y>=q&&Y<=K&&T<p?T++:G.level===c&&Y>=q&&Y<=K&&(eo(G,h,R),T++,T===_&&y.destroy());break;case(a&&l):Y=new Date(G.timestamp),q=new Date(u),G.level===c&&Y>=q&&T<p?T++:G.level===c&&Y>=q&&(eo(G,h,R),T++,T===_&&y.destroy());break;case(a&&d):Y=new Date(G.timestamp),K=new Date(f),G.level===c&&Y<=K&&T<p?T++:G.level===c&&Y<=K&&(eo(G,h,R),T++,T===_&&y.destroy());break;case(l&&d):Y=new Date(G.timestamp),q=new Date(u),K=new Date(f),Y>=q&&Y<=K&&T<p?T++:Y>=q&&Y<=K&&(eo(G,h,R),T++,T===_&&y.destroy());break;case a:G.level===c&&T<p?T++:G.level===c&&(eo(G,h,R),T++,T===_&&y.destroy());break;case l:Y=new Date(G.timestamp),q=new Date(u),Y>=q&&T<p?T++:Y>=q&&T>=p&&(eo(G,h,R),T++,T===_&&y.destroy());break;case d:Y=new Date(G.timestamp),K=new Date(f),Y<=K&&T<p?T++:Y<=K&&T>=p&&(eo(G,h,R),T++,T===_&&y.destroy());break;default:T<p?T++:(eo(G,h,R),T++,T===_&&y.destroy())}}o(F,"onLogMessage"),await Dle(y,"close");let Z=await r;if(Z.replicated){for(let G of R)G.node=server.hostname;for(let G of Z.replicated){let Y=G.node;if(G.status==="failed")eo({timestamp:new Date().toISOString(),level:"error",node:Y,message:`Error retrieving logs: ${G.reason}`},h,R);else for(let q of G.results)q.node=Y,eo(q,h,R)}}return R}o(kle,"readLog");function eo(e,t,r){t==="desc"?Gle(e,r):t==="asc"?qle(e,r):r.push(e)}o(eo,"pushLineToResult");function Gle(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(Gle,"insertDescending");function qle(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(qle,"insertAscending")});var YS=M((Hve,iV)=>{"use strict";var oO=require("joi"),{string:Fd,boolean:rV,date:$le}=oO.types(),Vle=lt(),{validateSchemaExists:Uve,validateTableExists:xve,validateSchemaName:Bve}=ki(),Kle=(k(),v(W)),Yle=Nt(),nV=oe();nV.initSync();var Fve=Fd.invalid(nV.get(Kle.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(Yle.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),sV={operation:Fd.valid("add_node","update_node","set_node_replication"),node_name:Fd.optional(),subscriptions:oO.array().items({table:Fd.optional(),schema:Fd.optional(),database:Fd.optional(),subscribe:rV.required(),publish:rV.required().custom(zle),start_time:$le.iso()})};function Wle(e){return Vle.validateBySchema(e,oO.object(sV))}o(Wle,"addUpdateNodeValidator");function zle(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(zle,"checkForFalsy");iV.exports={addUpdateNodeValidator:Wle,validationSchema:sV}});var Hd=M((Gve,oV)=>{"use strict";var aO=class{static{o(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},cO=class{static{o(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};oV.exports={Node:aO,NodeSubscription:cO}});var cV=M(($ve,aV)=>{"use strict";var jle=(k(),v(W)).OPERATIONS_ENUM,lO=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=jle.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};aV.exports=lO});var Jh=M((Kve,lV)=>{"use strict";var uO=class{static{o(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},dO=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)}};lV.exports={RemotePayloadObject:uO,RemotePayloadSubscription:dO}});var dV=M((Wve,uV)=>{"use strict";var fO=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}};uV.exports=fO});var mV=M((Zve,fV)=>{"use strict";var Qle=dV(),jve=qt(),Qve=gt(),Jle=Q(),{getSchemaPath:Jve,getTransactionAuditStorePath:Xve}=At(),{getDatabases:Xle}=(De(),v(mt));fV.exports=Zle;async function Zle(e){let t=new Qle;try{let r=Xle()[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){Jle.warn(`unable to stat table dbi due to ${r}`)}return t}o(Zle,"lmdbGetTableSize")});var pV=M((tUe,hV)=>{"use strict";var mO=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}};hV.exports=mO});var Gd=M((aUe,SV)=>{"use strict";var eue=require("fs-extra"),tue=require("path"),mn=require("systeminformation"),rc=Q(),EV=rr(),nUe=Nt(),kd=(k(),v(W)),rue=mV(),nue=Ba(),{getThreadInfo:_V}=nt(),Xh=oe();Xh.initSync();var sue=pV(),{openEnvironment:sUe}=gt(),{getSchemaPath:iUe}=At(),{database:oUe,databases:hO}=(De(),v(mt)),WS;SV.exports={getHDBProcessInfo:gO,getNetworkInfo:TO,getDiskInfo:SO,getMemoryInfo:_O,getCPUInfo:EO,getTimeInfo:pO,getSystemInformation:RO,systemInformation:iue,getTableSize:yO,getMetrics:AO};function pO(){return mn.time()}o(pO,"getTimeInfo");async function EO(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:a,governor:c,socket:l,cache:u,...d}=await mn.cpu();d.cpu_speed=await mn.cpuCurrentSpeed();let{rawCurrentload:f,rawCurrentloadIdle:m,rawCurrentloadIrq:h,rawCurrentloadNice:p,rawCurrentloadSystem:_,rawCurrentloadUser:g,cpus:y,...T}=await mn.currentLoad();return T.cpus=[],y.forEach(R=>{let{rawLoad:N,rawLoadIdle:O,rawLoadIrq:F,rawLoadNice:Z,rawLoadSystem:G,rawLoadUser:Y,...q}=R;T.cpus.push(q)}),d.current_load=T,d}catch(e){return rc.error(`error in getCPUInfo: ${e}`),{}}}o(EO,"getCPUInfo");async function _O(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await mn.mem();return Object.assign(s,process.memoryUsage())}catch(e){return rc.error(`error in getMemoryInfo: ${e}`),{}}}o(_O,"getMemoryInfo");async function gO(){let e={core:[],clustering:[]};try{let t=await mn.processes(),r;try{r=Number.parseInt(await eue.readFile(tue.join(Xh.get(kd.CONFIG_PARAMS.ROOTPATH),kd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===kd.NODE_ERROR_CODES.ENOENT)rc.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 rc.error(`error in getHDBProcessInfo: ${t}`),e}}o(gO,"getHDBProcessInfo");async function SO(){let e={};try{if(!Xh.get(kd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await mn.disksIO();e.io=i;let{rxSec:a,txSec:c,wxSec:l,...u}=await mn.fsStats();return e.read_write=u,e.size=await mn.fsSize(),e}catch(t){return rc.error(`error in getDiskInfo: ${t}`),e}}o(SO,"getDiskInfo");async function TO(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Xh.get(kd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await mn.networkInterfaceDefault(),e.latency=await mn.inetChecksite("google.com"),(await mn.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 mn.networkStats()).forEach(n=>{let{rxSec:s,txSec:i,ms:a,...c}=n;e.stats.push(c)})),e}catch(t){return rc.error(`error in getNetworkInfo: ${t}`),e}}o(TO,"getNetworkInfo");async function RO(){if(WS!==void 0)return WS;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:a,...c}=await mn.osInfo();e=c;let l=await mn.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,WS=e,WS}catch(t){return rc.error(`error in getSystemInformation: ${t}`),e}}o(RO,"getSystemInformation");async function yO(){let e=[],t=await nue.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await rue(n));return e}o(yO,"getTableSize");async function AO(){let e={};for(let t in hO){let r=e[t]={},n=r.tables={};for(let s in hO[t])try{let i=hO[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){rc.notify(`Error getting stats for table ${s}: ${i}`)}}return e}o(AO,"getMetrics");async function gV(){if(Xh.get(kd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await EV.getNATSReferences(),t=await EV.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(gV,"getNatsStreamInfo");async function iue(e){let t=new sue;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await RO(),t.time=pO(),t.cpu=await EO(),t.memory=await _O(),t.disk=await SO(),t.network=await TO(),t.harperdb_processes=await gO(),t.table_size=await yO(),t.metrics=await AO(),t.threads=await _V(),t.replication=await gV(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await RO();break;case"time":t.time=pO();break;case"cpu":t.cpu=await EO();break;case"memory":t.memory=await _O();break;case"disk":t.disk=await SO();break;case"network":t.network=await TO();break;case"harperdb_processes":t.harperdb_processes=await gO();break;case"table_size":t.table_size=await yO();break;case"database_metrics":case"metrics":t.metrics=await AO();break;case"threads":t.threads=await _V();break;case"replication":t.replication=await gV();break;default:break}return t}o(iue,"systemInformation")});var $o=M((fUe,AV)=>{"use strict";var oue=vn(),bO=ie(),aue=require("util"),Hl=(k(),v(W)),TV=oe();TV.initSync();var cue=nw(),RV=cn(),{Node:lUe,NodeSubscription:uUe}=Hd(),lue=Wu(),uue=cV(),{RemotePayloadObject:due,RemotePayloadSubscription:fue}=Jh(),{handleHDBError:mue,hdbErrors:hue}=ge(),{HTTP_STATUS_CODES:pue,HDB_ERROR_MSGS:Eue}=hue,_ue=ci(),gue=Gd(),{packageJson:Sue}=Rt(),{getDatabases:Tue}=(De(),v(mt)),dUe=aue.promisify(cue.authorize),Rue=RV.searchByHash,yue=RV.searchByValue;AV.exports={isEmpty:Aue,getNodeRecord:bue,upsertNodeRecord:Iue,buildNodePayloads:Nue,checkClusteringEnabled:wue,getAllNodeRecords:Oue,getSystemInfo:Cue,reverseSubscription:yV};function Aue(e){return e==null}o(Aue,"isEmpty");async function bue(e){let t=new lue(Hl.SYSTEM_SCHEMA_NAME,Hl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Rue(t)}o(bue,"getNodeRecord");async function Iue(e){let t=new uue(Hl.SYSTEM_SCHEMA_NAME,Hl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return oue.upsert(t)}o(Iue,"upsertNodeRecord");function yV(e){if(bO.isEmpty(e.subscribe)||bO.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(yV,"reverseSubscription");function Nue(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=bO.getTableHashAttribute(l,u),{subscribe:f,publish:m}=yV(c),h=Tue()[l]?.[u],p=new fue(l,u,d,m,f,c.start_time,h.schemaDefined?h.attributes:void 0);s.push(p)}return new due(r,t,s,n)}o(Nue,"buildNodePayloads");function wue(){if(!TV.get(Hl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw mue(new Error,Eue.CLUSTERING_NOT_ENABLED,pue.BAD_REQUEST,void 0,void 0,!0)}o(wue,"checkClusteringEnabled");async function Oue(){let e=new _ue(Hl.SYSTEM_SCHEMA_NAME,Hl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await yue(e))}o(Oue,"getAllNodeRecords");async function Cue(){let e=await gue.getSystemInformation();return{hdb_version:Sue.version,node_version:e.node_version,platform:e.platform}}o(Cue,"getSystemInfo")});var IO=M((hUe,LV)=>{"use strict";var zS=rr(),bV=ie(),IV=Nt(),NV=(k(),v(W)),jS=Q(),wV=jh(),Pue=Km(),{RemotePayloadObject:Lue}=Jh(),{handleHDBError:OV,hdbErrors:Due}=ge(),{HTTP_STATUS_CODES:CV}=Due,{NodeSubscription:PV}=Hd();LV.exports=Mue;async function Mue(e,t){let r;try{r=await zS.request(`${t}.${IV.REQUEST_SUFFIX}`,new Lue(NV.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),jS.trace("Response from remote describe all request:",r)}catch(a){jS.error(`addNode received error from describe all request to remote node: ${a}`);let c=zS.requestErrorHandler(a,"add_node",t);throw OV(new Error,c,CV.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===IV.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let a=`Error returned from remote node ${t}: ${r.message}`;throw OV(new Error,a,CV.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===NV.SYSTEM_SCHEMA_NAME){await zS.createLocalTableStream(l,c);let p=new PV(l,c,a.publish,a.subscribe);p.start_time=a.start_time,i.push(p);continue}let u=bV.doesSchemaExist(l),d=n[l]!==void 0,f=c?bV.doesTableExist(l,c):!0,m=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!d||!f&&!m){s.push(a);continue}if(!u&&d&&(jS.trace(`addNode creating schema: ${l}`),await wV.createSchema({operation:"create_schema",schema:l})),!f&&m){jS.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let p=new Pue(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(p.attributes=n[l][c].attributes),await wV.createTable(p)}await zS.createLocalTableStream(l,c);let h=new PV(l,c,a.publish,a.subscribe);h.start_time=a.start_time,i.push(h)}return{added:i,skipped:s}}o(Mue,"reviewSubscriptions")});var qd={};Oe(qd,{addNodeBack:()=>NO,removeNodeBack:()=>wO,setNode:()=>Bue});async function Bue(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=pi(t)):t=FS(r);let n=(0,MV.validateBySchema)(e,xue);if(n)throw(0,Vo.handleHDBError)(n,n.message,Uue.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Vo.ClientError("url or hostname is required for remove_node operation");let h=r,p=Kt(),_=await p.get(h);if(!_)throw new Vo.ClientError(h+" does not exist");try{await Wh({url:_.url},{operation:$.REMOVE_NODE_BACK,name:_?.subscriptions?.length>0?Ze():h},void 0)}catch(g){as.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 Vo.ClientError("url required for this operation");let s=Wa();if(s==null)throw new Vo.ClientError("replication url is missing from harperdb-config.yaml");let i,a,c;if(t?.startsWith("wss:")){i=await(0,vs.getReplicationCert)();let h=await(0,vs.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(a=await(0,vs.createCsr)(),as.info("Sending CSR to target node:",t)):h&&(c=h.certificate,as.info("Sending CA named",h.name,"to target node",t))}let l={operation:$.ADD_NODE_BACK,hostname:(0,sc.get)(U.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:a,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if((0,sc.get)(U.REPLICATION_SHARD)!==void 0&&(l.shard=(0,sc.get)(U.REPLICATION_SHARD)),e.subscriptions?l.subscriptions=e.subscriptions.map(DV):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let h=DV(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 Wh({url:t},l,e)}catch(h){h.message=`Error returned from ${t}: `+h.message,as.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&&(as.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,vs.setCertTable)({name:vue.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,vs.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,sc.get)(U.REPLICATION_SHARD)!==void 0&&(h.shard=(0,sc.get)(U.REPLICATION_SHARD)),e.retain_authorization&&(h.authorization=e.authorization),e.start_time&&(h.start_time=e.start_time),await Bo(Ze(),h)}await Bo(u?u.nodeName:f.name??pi(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 NO(e){as.trace("addNodeBack received request:",e);let t=await(0,vs.signCertificate)(e),r;e.csr?(r=t.signingCA,as.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,as.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization),e.shard!==void 0&&(n.shard=e.shard);let s=await(0,vs.getReplicationCertAuth)();if(n.replicates){let i={url:Wa(),ca:s?.certificate,replicates:!0,subscriptions:null};(0,sc.get)(U.REPLICATION_SHARD)!==void 0&&(i.shard=(0,sc.get)(U.REPLICATION_SHARD),t.shard=i.shard),e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Bo(Ze(),i)}return await Bo(e.hostname,n),t.nodeName=Ze(),t.usingCA=s?.certificate,as.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function wO(e){as.trace("removeNodeBack received request:",e),await Kt().delete(e.name)}function DV(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var vs,MV,nc,sc,as,Vo,vue,Uue,xue,$d=ue(()=>{vs=w(os()),MV=w(lt()),nc=w(require("joi")),sc=w(oe());k();qh();Dl();ss();as=w(Q()),Vo=w(ge()),{pki:vue}=require("node-forge"),{HTTP_STATUS_CODES:Uue}=Vo.hdbErrors,xue=nc.default.object({hostname:nc.default.string(),verify_tls:nc.default.boolean(),replicates:nc.default.boolean(),subscriptions:nc.default.array(),revoked_certificates:nc.default.array(),shard:nc.default.number()});o(Bue,"setNode");o(NO,"addNodeBack");o(wO,"removeNodeBack");o(DV,"reverseSubscription")});var eT=M((AUe,UV)=>{"use strict";var{handleHDBError:QS,hdbErrors:Fue}=ge(),{HTTP_STATUS_CODES:JS}=Fue,{addUpdateNodeValidator:Hue}=YS(),XS=Q(),ZS=(k(),v(W)),vV=Nt(),kue=ie(),Zh=rr(),ep=$o(),OO=oe(),Gue=IO(),{Node:que,NodeSubscription:$ue}=Hd(),{broadcast:Vue}=nt(),{setNode:Kue}=($d(),v(qd)),RUe=oe(),yUe=(k(),v(W)),Yue="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Wue="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",zue=OO.get(ZS.CONFIG_PARAMS.CLUSTERING_NODENAME);UV.exports=jue;async function jue(e,t=!1){if(XS.trace("addNode called with:",e),OO.get(ZS.CONFIG_PARAMS.REPLICATION_URL)||OO.get(ZS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Kue(e);ep.checkClusteringEnabled();let r=Hue(e);if(r)throw QS(r,r.message,JS.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let f=await ep.getNodeRecord(n);if(!kue.isEmptyOrZeroLength(f))throw QS(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,JS.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Gue(e.subscriptions,n),a={message:void 0,added:s,skipped:i};if(s.length===0)return a.message=Yue,a;let c=ep.buildNodePayloads(s,zue,ZS.OPERATIONS_ENUM.ADD_NODE,await ep.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 $ue(h.schema,h.table,h.publish,h.subscribe))}XS.trace("addNode sending remote payload:",c);let u;try{u=await Zh.request(`${n}.${vV.REQUEST_SUFFIX}`,c)}catch(f){XS.error(`addNode received error from request: ${f}`);for(let h=0,p=s.length;h<p;h++){let _=s[h];_.publish=!1,_.subscribe=!1,await Zh.updateRemoteConsumer(_,n)}let m=Zh.requestErrorHandler(f,"add_node",n);throw QS(new Error,m,JS.INTERNAL_SERVER_ERROR,"error",m)}if(u.status===vV.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${n}: ${u.message}`;throw QS(new Error,f,JS.INTERNAL_SERVER_ERROR,"error",f)}XS.trace(u);for(let f=0,m=s.length;f<m;f++){let h=s[f];await Zh.updateRemoteConsumer(h,n),h.subscribe===!0&&await Zh.updateConsumerIterator(h.schema,h.table,n,"start")}let d=new que(n,l,u.system_info);return await ep.upsertNodeRecord(d),Vue({type:"nats_update"}),i.length>0?a.message=Wue:a.message=`Successfully added '${n}' to manifest`,a}o(jue,"addNode")});var DO=M((NUe,BV)=>{"use strict";var{handleHDBError:CO,hdbErrors:Que}=ge(),{HTTP_STATUS_CODES:PO}=Que,{addUpdateNodeValidator:Jue}=YS(),tp=Q(),tT=(k(),v(W)),xV=Nt(),IUe=ie(),rp=rr(),np=$o(),LO=oe(),{cloneDeep:Xue}=require("lodash"),Zue=IO(),{Node:ede,NodeSubscription:tde}=Hd(),{broadcast:rde}=nt(),{setNode:nde}=($d(),v(qd)),sde="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",ide="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",ode=LO.get(tT.CONFIG_PARAMS.CLUSTERING_NODENAME);BV.exports=ade;async function ade(e){if(tp.trace("updateNode called with:",e),LO.get(tT.CONFIG_PARAMS.REPLICATION_URL)??LO.get(tT.CONFIG_PARAMS.REPLICATION_HOSTNAME))return nde(e);np.checkClusteringEnabled();let t=Jue(e);if(t)throw CO(t,t.message,PO.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await np.getNodeRecord(r);s.length>0&&(n=Xue(s));let{added:i,skipped:a}=await Zue(e.subscriptions,r),c={message:void 0,updated:i,skipped:a};if(i.length===0)return c.message=sde,c;let l=np.buildNodePayloads(i,ode,tT.OPERATIONS_ENUM.UPDATE_NODE,await np.getSystemInfo());for(let d=0,f=i.length;d<f;d++){let m=i[d];tp.trace(`updateNode updating work stream for node: ${r} subscription:`,m),i[d].start_time===void 0&&delete i[d].start_time}tp.trace("updateNode sending remote payload:",l);let u;try{u=await rp.request(`${r}.${xV.REQUEST_SUFFIX}`,l)}catch(d){tp.error(`updateNode received error from request: ${d}`);let f=rp.requestErrorHandler(d,"update_node",r);throw CO(new Error,f,PO.INTERNAL_SERVER_ERROR,"error",f)}if(u.status===xV.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${r}: ${u.message}`;throw CO(new Error,d,PO.INTERNAL_SERVER_ERROR,"error",d)}tp.trace(u);for(let d=0,f=i.length;d<f;d++){let m=i[d];await rp.updateRemoteConsumer(m,r),m.subscribe===!0?await rp.updateConsumerIterator(m.schema,m.table,r,"start"):await rp.updateConsumerIterator(m.schema,m.table,r,"stop")}return n||(n=[new ede(r,[],u.system_info)]),await cde(n[0],i,u.system_info),a.length>0?c.message=ide:c.message=`Successfully updated '${r}'`,c}o(ade,"updateNode");async function cde(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 tde(a.schema,a.table,a.publish,a.subscribe))}n.system_info=r,await np.upsertNodeRecord(n),rde({type:"nats_update"})}o(cde,"updateNodeTable")});var qV=M((OUe,GV)=>{"use strict";var kV=require("joi"),{string:FV}=kV.types(),lde=lt(),HV=(k(),v(W)),ude=oe(),dde=Nt();GV.exports=fde;function fde(e){let t=FV.invalid(ude.get(HV.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(dde.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=kV.object({operation:FV.valid(HV.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return lde.validateBySchema(e,r)}o(fde,"removeNodeValidator")});var rT=M((PUe,WV)=>{"use strict";var{handleHDBError:$V,hdbErrors:mde}=ge(),{HTTP_STATUS_CODES:VV}=mde,hde=qV(),sp=Q(),KV=$o(),pde=ie(),Vd=(k(),v(W)),YV=Nt(),MO=rr(),vO=oe(),{RemotePayloadObject:Ede}=Jh(),{NodeSubscription:_de}=Hd(),gde=Vm(),Sde=Sl(),{broadcast:Tde}=nt(),{setNode:Rde}=($d(),v(qd)),yde=vO.get(Vd.CONFIG_PARAMS.CLUSTERING_NODENAME);WV.exports=Ade;async function Ade(e){if(sp.trace("removeNode called with:",e),vO.get(Vd.CONFIG_PARAMS.REPLICATION_URL)??vO.get(Vd.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Rde(e);KV.checkClusteringEnabled();let t=hde(e);if(t)throw $V(t,t.message,VV.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await KV.getNodeRecord(r);if(pde.isEmptyOrZeroLength(n))throw $V(new Error,`Node '${r}' was not found.`,VV.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Ede(Vd.OPERATIONS_ENUM.REMOVE_NODE,yde,[]),i,a=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let d=n.subscriptions[l];d.subscribe===!0&&await MO.updateConsumerIterator(d.schema,d.table,r,"stop");try{await MO.updateRemoteConsumer(new _de(d.schema,d.table,!1,!1),r)}catch(f){sp.error(f)}}try{i=await MO.request(`${r}.${YV.REQUEST_SUFFIX}`,s),sp.trace("Remove node reply from remote node:",r,i)}catch(l){sp.error("removeNode received error from request:",l),a=!0}let c=new gde(Vd.SYSTEM_SCHEMA_NAME,Vd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Sde.deleteRecord(c),Tde({type:"nats_update"}),i?.status===YV.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||a?(sp.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(Ade,"removeNode")});var QV=M((DUe,jV)=>{"use strict";var zV=require("joi"),{string:bde,array:Ide}=zV.types(),Nde=lt(),wde=YS();jV.exports=Ode;function Ode(e){let t=zV.object({operation:bde.valid("configure_cluster").required(),connections:Ide.items(wde.validationSchema).required()});return Nde.validateBySchema(e,t)}o(Ode,"configureClusterValidator")});var UO=M((vUe,t1)=>{"use strict";var JV=(k(),v(W)),nT=Q(),Cde=ie(),Pde=oe(),Lde=rT(),Dde=eT(),Mde=$o(),vde=QV(),{handleHDBError:XV,hdbErrors:Ude}=ge(),{HTTP_STATUS_CODES:ZV}=Ude,xde="Configure cluster complete.",Bde="Failed to configure the cluster. Check the logs for more details.",Fde="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";t1.exports=Hde;async function Hde(e){nT.trace("configure cluster called with:",e);let t=vde(e);if(t)throw XV(t,t.message,ZV.BAD_REQUEST,void 0,void 0,!0);let r=await Mde.getAllNodeRecords(),n=[];if(Pde.get(JV.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let d=0,f=r.length;d<f;d++){let m=await e1(Lde,{operation:JV.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[d].name},r[d].name);n.push(m)}nT.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 e1(Dde,f,f.node_name);s.push(m)}nT.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"&&(nT.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(Cde.isEmptyOrZeroLength(a))return{message:xde,connections:c};if(l)return{message:Fde,failed_nodes:a,connections:c};throw XV(new Error,Bde,ZV.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}o(Hde,"configureCluster");async function e1(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}o(e1,"functionWrapper")});var i1=M((xUe,s1)=>{"use strict";var ip=require("joi"),kde=lt(),{validateSchemaExists:r1,validateTableExists:Gde,validateSchemaName:n1}=ki(),qde=ip.object({operation:ip.string().valid("purge_stream"),schema:ip.string().custom(r1).custom(n1).optional(),database:ip.string().custom(r1).custom(n1).optional(),table:ip.string().custom(Gde).required()});function $de(e){return kde.validateBySchema(e,qde)}o($de,"purgeStreamValidator");s1.exports=$de});var xO=M((FUe,o1)=>{"use strict";var{handleHDBError:Vde,hdbErrors:Kde}=ge(),{HTTP_STATUS_CODES:Yde}=Kde,Wde=i1(),zde=rr(),jde=$o();o1.exports=Qde;async function Qde(e){e.schema=e.schema??e.database;let t=Wde(e);if(t)throw Vde(t,t.message,Yde.BAD_REQUEST,void 0,void 0,!0);jde.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await zde.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}o(Qde,"purgeStream")});var HO=M((kUe,m1)=>{"use strict";var FO=$o(),Jde=rr(),iT=oe(),Kd=(k(),v(W)),kl=Nt(),Xde=ie(),BO=Q(),{RemotePayloadObject:Zde}=Jh(),{ErrorCode:a1}=require("nats"),{parentPort:c1}=require("worker_threads"),{onMessageByType:efe}=nt(),{getThisNodeName:tfe}=(ss(),v(Ho)),{requestClusterStatus:rfe}=(qh(),v(Lq)),{getReplicationSharedStatus:nfe,getHDBNodeTable:sfe}=(Dl(),v(Iw)),{CONFIRMATION_STATUS_POSITION:ife,RECEIVED_VERSION_POSITION:ofe,RECEIVED_TIME_POSITION:afe,SENDING_TIME_POSITION:cfe,RECEIVING_STATUS_POSITION:lfe,RECEIVING_STATUS_RECEIVING:ufe}=(Qw(),v(R$)),l1=iT.get(Kd.CONFIG_PARAMS.CLUSTERING_ENABLED),u1=iT.get(Kd.CONFIG_PARAMS.CLUSTERING_NODENAME);m1.exports={clusterStatus:dfe,buildNodeStatus:f1};var d1;efe("cluster-status",async e=>{d1(e)});async function dfe(){if(iT.get(Kd.CONFIG_PARAMS.REPLICATION_URL)||iT.get(Kd.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(c1){c1.postMessage({type:"request-cluster-status"}),n=await new Promise(i=>{d1=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=nfe(u,l,a);c.lastCommitConfirmed=sT(d[ife]),c.lastReceivedRemoteTime=sT(d[ofe]),c.lastReceivedLocalTime=sT(d[afe]),c.sendingMessage=sT(d[cfe]),c.lastReceivedStatus=d[lfe]===ufe?"Receiving":"Waiting"}}}else n=rfe();n.node_name=tfe();let s=sfe().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:u1,is_enabled:l1,connections:[]};if(!l1)return e;let t=await FO.getAllNodeRecords();if(Xde.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(f1(t[n],e.connections));return await Promise.allSettled(r),e}o(dfe,"clusterStatus");function sT(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}o(sT,"asDate");async function f1(e,t){let r=e.name,n=new Zde(Kd.OPERATIONS_ENUM.CLUSTER_STATUS,u1,void 0,await FO.getSystemInfo()),s,i,a=kl.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await Jde.request(kl.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===kl.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(a=kl.CLUSTER_STATUS_STATUSES.CLOSED,BO.error(`Error getting node status from ${r} `,s))}catch(l){BO.warn(`Error getting node status from ${r}`,l),l.code===a1.NoResponders?a=kl.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===a1.Timeout?a=kl.CLUSTER_STATUS_STATUSES.TIMEOUT:a=kl.CLUSTER_STATUS_STATUSES.CLOSED}let c=new ffe(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!==Kd.PRE_4_0_0_VERSION&&await FO.upsertNodeRecord(l)}catch(l){BO.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}o(f1,"buildNodeStatus");function ffe(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(ffe,"NodeStatusObject")});var GO=M((qUe,h1)=>{"use strict";var{handleHDBError:mfe,hdbErrors:hfe}=ge(),{HTTP_STATUS_CODES:pfe}=hfe,Efe=rr(),_fe=$o(),kO=ie(),oT=require("joi"),gfe=lt(),Sfe=2e3,Tfe=oT.object({timeout:oT.number().min(1),connected_nodes:oT.boolean(),routes:oT.boolean()});h1.exports=Rfe;async function Rfe(e){_fe.checkClusteringEnabled();let t=gfe.validateBySchema(e,Tfe);if(t)throw mfe(t,t.message,pfe.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||kO.autoCastBoolean(n),a=s===void 0||kO.autoCastBoolean(s),c={nodes:[]},l=await Efe.getServerList(r??Sfe),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(_=>{p.connected_nodes.includes(_.name.slice(0,-4))||p.connected_nodes.push(_.name.slice(0,-4))})),a&&(p.routes=h.cluster?.urls?h.cluster?.urls.map(_=>({host:_.split(":")[0],port:kO.autoCast(_.split(":")[1])})):[]),c.nodes.push(p)}}return c}o(Rfe,"clusterNetwork")});var g1=M((VUe,_1)=>{"use strict";var qO=require("joi"),p1=lt(),{routeConstraints:E1}=sA();_1.exports={setRoutesValidator:yfe,deleteRoutesValidator:Afe};function yfe(e){let t=qO.object({server:qO.valid("hub","leaf"),routes:E1.required()});return p1.validateBySchema(e,t)}o(yfe,"setRoutesValidator");function Afe(e){let t=qO.object({routes:E1.required()});return p1.validateBySchema(e,t)}o(Afe,"deleteRoutesValidator")});var aT=M((YUe,I1)=>{"use strict";var Ko=yt(),$O=ie(),Us=(k(),v(W)),Yd=oe(),S1=g1(),{handleHDBError:T1,hdbErrors:bfe}=ge(),{HTTP_STATUS_CODES:R1}=bfe,y1="cluster routes successfully set",A1="cluster routes successfully deleted";I1.exports={setRoutes:Nfe,getRoutes:wfe,deleteRoutes:Ofe};function Ife(e){let t=Ko.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=$O.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"?Ko.updateConfigValue(Us.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):Ko.updateConfigValue(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:y1,set:i,skipped:s}}o(Ife,"setRoutesNats");function Nfe(e){let t=S1.setRoutesValidator(e);if(t)throw T1(t,t.message,R1.BAD_REQUEST,void 0,void 0,!0);if(Yd.get(Us.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ife(e);let r=[],n=[],s=Yd.get(Us.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{b1(s,i)?n.push(i):(s.push(i),r.push(i))}),Ko.updateConfigValue(Us.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:y1,set:r,skipped:n}}o(Nfe,"setRoutes");function b1(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(b1,"existsInArray");function wfe(){if(Yd.get(Us.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=Ko.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Yd.get(Us.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}o(wfe,"getRoutes");function Ofe(e){let t=S1.deleteRoutesValidator(e);if(t)throw T1(t,t.message,R1.BAD_REQUEST,void 0,void 0,!0);if(Yd.get(Us.CONFIG_PARAMS.CLUSTERING_ENABLED))return Cfe(e);let r=[],n=[],s=Yd.get(Us.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(a=>{b1(e.routes,a)?r.push(a):(i.push(a),n.push(a))}),Ko.updateConfigValue(Us.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:A1,deleted:r,skipped:n}}o(Ofe,"deleteRoutes");function Cfe(e){let t=Ko.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 _=n[h];if(d.host===_.host&&d.port===_.port){n.splice(h,1),c=!0,m=!1,s.push(d);break}}m&&i.push(d)}}return a&&(r=$O.isEmptyOrZeroLength(r)?null:r,Ko.updateConfigValue(Us.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=$O.isEmptyOrZeroLength(n)?null:n,Ko.updateConfigValue(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:A1,deleted:s,skipped:i}}o(Cfe,"deleteRoutesNats")});var w1=M((zUe,N1)=>{"use strict";var op=require("alasql"),Gl=require("recursive-iterator"),gi=Q(),Pfe=ie(),ap=(k(),v(W)),VO=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,Dfe(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=>ap.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=>!ap.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][ap.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[a].attribute_permissions.length>0?c=Lfe(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=>!ap.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let d=new op.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 Lfe(e){return e.filter(t=>t[ap.PERMS_CRUD_ENUM.READ])}o(Lfe,"filterReadRestrictedAttrs");function Dfe(e,t,r,n,s){Mfe(e,t,r,n,s)}o(Dfe,"interpretAST");function cp(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(cp,"addSchemaTableToMap");function Mfe(e,t,r,n,s){if(!e){gi.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof op.yy.Insert?Bfe(e,t,r):e instanceof op.yy.Select?vfe(e,t,r,n,s):e instanceof op.yy.Update?Ufe(e,t,r):e instanceof op.yy.Delete?xfe(e,t,r):gi.error("AST in getRecordAttributesAST() is not a valid SQL type.")}o(Mfe,"getRecordAttributesAST");function vfe(e,t,r,n,s){if(!e){gi.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Pfe.isEmptyOrZeroLength(i)){gi.error("No schema specified");return}e.from.forEach(c=>{cp(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),cp(c.table,t,r,n,s)});let a=new Gl(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{gi.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 Gl(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{gi.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 Gl(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{gi.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 Gl(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{gi.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(vfe,"getSelectAttributes");function Ufe(e,t,r){if(!e){gi.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Gl(e.columns),s=e.table.databaseid;cp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&KO(e.table.tableid,s,i.columnid,t,r)}o(Ufe,"getUpdateAttributes");function xfe(e,t,r){if(!e){gi.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Gl(e.where),s=e.table.databaseid;cp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&KO(e.table.tableid,s,i.columnid,t,r)}o(xfe,"getDeleteAttributes");function Bfe(e,t,r){if(!e){gi.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Gl(e.columns),s=e.into.databaseid;cp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&KO(e.into.tableid,s,i.columnid,t,r)}o(Bfe,"getInsertAttributes");function KO(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(KO,"pushAttribute");N1.exports=VO});var C1=M((QUe,O1)=>{"use strict";var cT=(k(),v(W)),lT=class{static{o(this,"BaseLicense")}constructor(t=0,r=cT.RAM_ALLOCATION_ENUM.DEFAULT,n=cT.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},YO=class extends lT{static{o(this,"ExtendedLicense")}constructor(t=0,r=cT.RAM_ALLOCATION_ENUM.DEFAULT,n=cT.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};O1.exports={BaseLicense:lT,ExtendedLicense:YO}});var jd=M((XUe,U1)=>{"use strict";var zd=require("fs-extra"),uT=(Tg(),v(Sg)),L1=require("crypto"),Ffe=require("moment"),Hfe=require("uuid").v4,hn=Q(),zO=require("path"),kfe=ie(),ql=(k(),v(W)),{totalmem:P1}=require("os"),Gfe=C1().ExtendedLicense,Wd="invalid license key format",qfe="061183",$fe="mofi25",Vfe="aes-256-cbc",Kfe=16,Yfe=32,D1=oe(),{resolvePath:M1}=yt();D1.initSync();var WO;U1.exports={validateLicense:v1,generateFingerPrint:zfe,licenseSearch:JO,getLicense:Jfe,checkMemoryLimit:Xfe};function jO(){return zO.join(D1.getHdbBasePath(),ql.LICENSE_KEY_DIR_NAME,ql.LICENSE_FILE_NAME)}o(jO,"getLicenseDirPath");function Wfe(){let e=jO();return M1(zO.join(e,ql.LICENSE_FILE_NAME))}o(Wfe,"getLicenseFilePath");function QO(){let e=jO();return M1(zO.join(e,ql.REG_KEY_FILE_NAME))}o(QO,"getFingerPrintFilePath");async function zfe(){let e=QO();try{return await zd.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await jfe();throw hn.error(`Error writing fingerprint file to ${e}`),hn.error(t),new Error("There was an error generating the fingerprint")}}o(zfe,"generateFingerPrint");async function jfe(){let e=Hfe(),t=uT.hash(e,uT.HASH_FUNCTION.MD5),r=QO();try{await zd.mkdirp(jO()),await zd.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw hn.error(`Error writing fingerprint file to ${r}`),hn.error(n),new Error("There was an error generating the fingerprint")}return t}o(jfe,"writeFingerprint");function v1(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:ql.RAM_ALLOCATION_ENUM.DEFAULT,version:ql.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return hn.error("empty license key passed to validate."),r;let n=QO(),s=!1;try{s=zd.statSync(n)}catch(i){hn.error(i)}if(s){let i;try{i=zd.readFileSync(n,"utf8")}catch{hn.error("error validating this machine in the license"),r.valid_machine=!1;return}let a=e.split($fe),c=a[1];c=Buffer.concat([Buffer.from(c)],Kfe);let l=Buffer.concat([Buffer.from(i)],Yfe),u=L1.createDecipheriv(Vfe,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=Qfe(a[0],i);if(h)d=h;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Wd),hn.error(Wd),new Error(Wd)}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(Wd),hn.error(Wd),new Error(Wd)}else r.exp_date=d;r.exp_date<Ffe().valueOf()&&(r.valid_date=!1),uT.validate(a[1],`${qfe}${i}${t}`,uT.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||hn.error("Invalid licence"),r}o(v1,"validateLicense");function Qfe(e,t){try{let r=L1.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{hn.warn("Check old license failed")}}o(Qfe,"checkOldLicense");function JO(){let e=new Gfe,t=[];try{t=zd.readFileSync(Wfe(),"utf-8").split(`\r
|
|
18
|
-
`)}catch(r){r.code==="ENOENT"?hn.debug("no license file found"):hn.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(kfe.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=v1(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){hn.error("There was an error parsing the license string."),hn.error(s),e.ram_allocation=ql.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return WO=e,e}o(JO,"licenseSearch");async function Jfe(){return WO||await JO(),WO}o(Jfe,"getLicense");function Xfe(){let e=JO().ram_allocation,t=process.constrainedMemory?.()||P1();if(t=Math.round(Math.min(t,P1())/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(Xfe,"checkMemoryLimit")});var eC=M((e0e,H1)=>{var dT=jd(),x1=require("chalk"),cs=Q(),B1=require("prompt"),{promisify:Zfe}=require("util"),XO=(k(),v(W)),eme=require("fs-extra"),tme=require("path"),rme=ie(),{packageJson:nme}=Rt(),F1=oe();F1.initSync();var sme=require("moment"),ime=Zfe(B1.get),ome=tme.join(F1.getHdbBasePath(),XO.LICENSE_KEY_DIR_NAME,XO.LICENSE_FILE_NAME,XO.LICENSE_FILE_NAME);H1.exports={getFingerprint:cme,setLicense:ame,parseLicense:ZO,register:lme,getRegistrationInfo:dme};async function ame(e){if(e&&e.key&&e.company){try{cs.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await ZO(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw cs.error(r),cs.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}o(ame,"setLicense");async function cme(){let e={};try{e=await dT.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw cs.error(r),cs.error(t),new Error(r)}return e}o(cme,"getFingerprint");async function ZO(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");cs.info("Validating license input...");let r=dT.validateLicense(e,t);if(cs.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(cs.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(cs.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{cs.info("writing license to disk"),await eme.writeFile(ome,JSON.stringify({license_key:e,company:t}))}catch(n){throw cs.error("Failed to write License"),n}return"Registration successful."}o(ZO,"parseLicense");async function lme(){let e=await ume();return ZO(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}o(lme,"register");async function ume(){let e=await dT.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:x1.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:x1.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{B1.start()}catch(n){cs.error(n)}let r;try{r=await ime(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}o(ume,"promptForRegistration");async function dme(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await dT.getLicense()}catch(r){throw cs.error(`There was an error when searching licenses due to: ${r.message}`),r}if(rme.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=nme.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=sme.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}o(dme,"getRegistrationInfo")});var G1=M((r0e,k1)=>{"use strict";var fme=Nt(),tC=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+fme.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"}};k1.exports=tC});var V1=M((s0e,$1)=>{"use strict";var q1=Nt(),rC=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+q1.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+q1.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"}};$1.exports=rC});var Y1=M((o0e,K1)=>{"use strict";var nC=class{static{o(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};K1.exports=nC});var z1=M((c0e,W1)=>{"use strict";var mme=Nt(),sC=class{static{o(this,"SysUserObject")}constructor(t,r){this.user=t+mme.SERVER_SUFFIX.ADMIN,this.password=r}};W1.exports=sC});var pT=M((u0e,J1)=>{"use strict";var $l=require("path"),Vl=require("fs-extra"),hme=G1(),pme=V1(),Eme=Y1(),_me=z1(),iC=Un(),Jd=ie(),Bn=yt(),mT=(k(),v(W)),lp=Nt(),{CONFIG_PARAMS:nr}=mT,Xd=Q(),up=oe(),j1=Vi(),oC=rr(),gme=os(),Qd="clustering",Sme=1e4,Q1=50;J1.exports={generateNatsConfig:Rme,removeNatsConfig:yme,getHubConfigPath:Tme};function Tme(){let e=up.get(nr.ROOTPATH);return $l.join(e,Qd,lp.NATS_CONFIG_FILES.HUB_SERVER)}o(Tme,"getHubConfigPath");async function Rme(e=!1,t=void 0){console.error("Warning: NATS replication is deprecated and will be removed in version 5.0 of Harper");let r=up.get(nr.ROOTPATH);Vl.ensureDirSync($l.join(r,"clustering","leaf")),up.initSync();let n=Bn.getConfigFromFile(nr.CLUSTERING_TLS_CERT_AUTH),s=Bn.getConfigFromFile(nr.CLUSTERING_TLS_PRIVATEKEY),i=Bn.getConfigFromFile(nr.CLUSTERING_TLS_CERTIFICATE);!await Vl.exists(i)&&!await Vl.exists(!n)&&await gme.createNatsCerts();let a=$l.join(r,Qd,lp.PID_FILES.HUB),c=$l.join(r,Qd,lp.PID_FILES.LEAF),l=Bn.getConfigFromFile(nr.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=$l.join(r,Qd,lp.NATS_CONFIG_FILES.HUB_SERVER),d=$l.join(r,Qd,lp.NATS_CONFIG_FILES.LEAF_SERVER),f=Bn.getConfigFromFile(nr.CLUSTERING_TLS_INSECURE),m=Bn.getConfigFromFile(nr.CLUSTERING_TLS_VERIFY),h=Bn.getConfigFromFile(nr.CLUSTERING_NODENAME),p=Bn.getConfigFromFile(nr.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await oC.checkNATSServerInstalled()||hT("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let _=await iC.listUsers(),g=Bn.getConfigFromFile(nr.CLUSTERING_USER),y=await iC.getClusterUser();(Jd.isEmpty(y)||y.active!==!0)&&hT(`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 fT(nr.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await fT(nr.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await fT(nr.CLUSTERING_HUBSERVER_NETWORK_PORT),await fT(nr.CLUSTERING_LEAFSERVER_NETWORK_PORT));let T=[],R=[];for(let[q,K]of _.entries())K.role?.role===mT.ROLE_TYPES_ENUM.CLUSTER_USER&&K.active&&(T.push(new _me(K.username,j1.decrypt(K.hash))),R.push(new Eme(K.username,j1.decrypt(K.hash))));let N=[],{hub_routes:O}=Bn.getClusteringRoutes();if(!Jd.isEmptyOrZeroLength(O))for(let q of O)N.push(`tls://${y.sys_name_encoded}:${y.uri_encoded_d_hash}@${q.host}:${q.port}`);let F=new hme(Bn.getConfigFromFile(nr.CLUSTERING_HUBSERVER_NETWORK_PORT),h,a,i,s,n,f,m,p,Bn.getConfigFromFile(nr.CLUSTERING_HUBSERVER_CLUSTER_NAME),Bn.getConfigFromFile(nr.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),N,T,R);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=Jd.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===mT.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Vl.writeJson(u,F),Xd.trace(`Hub server config written to ${u}`));let Z=`tls://${y.sys_name_encoded}:${y.uri_encoded_d_hash}@0.0.0.0:${p}`,G=`tls://${y.uri_encoded_name}:${y.uri_encoded_d_hash}@0.0.0.0:${p}`,Y=new pme(Bn.getConfigFromFile(nr.CLUSTERING_LEAFSERVER_NETWORK_PORT),h,c,l,[Z],[G],T,R,i,s,n,f);n==null&&delete Y.tls.ca_file,(t===void 0||t===mT.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Vl.writeJson(d,Y),Xd.trace(`Leaf server config written to ${d}`))}o(Rme,"generateNatsConfig");async function fT(e){let t=up.get(e);return Jd.isEmpty(t)&&hT(`port undefined for '${e}'`),await Jd.isPortTaken(t)&&hT(`'${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(fT,"isPortAvailable");function hT(e){let t=`Error generating clustering config: ${e}`;Xd.error(t),console.error(t),process.exit(1)}o(hT,"generateNatsConfigError");async function yme(e){let{port:t,config_file:r}=oC.getServerConfig(e),{username:n,decrypt_hash:s}=await iC.getClusterUser(),i=0,a=2e3;for(;i<Q1;){try{let d=await oC.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){Xd.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=Q1)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&&Xd.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Jd.asyncSetTimeout(u)}let c="0".repeat(Sme),l=$l.join(up.get(nr.ROOTPATH),Qd,r);await Vl.writeFile(l,c),await Vl.remove(l),Xd.notify(e,"started.")}o(yme,"removeNatsConfig")});var nK=M((f0e,rK)=>{"use strict";var ls=oe(),Ame=jd(),Ke=(k(),v(W)),dp=Nt(),Yo=require("path"),{PACKAGE_ROOT:_T}=Rt(),X1=oe(),ET=ie(),Zd="/dev/null",bme=Yo.join(_T,"launchServiceScripts"),Z1=Yo.join(_T,"utility/scripts"),Ime=Yo.join(Z1,Ke.HDB_RESTART_SCRIPT),eK=Yo.resolve(_T,"dependencies",`${process.platform}-${process.arch}`,dp.NATS_BINARY_NAME);function tK(){let t=Ame.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 ET.noBootFile()&&(n[Ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=ET.getEnvCliRootPath()),{name:Ke.PROCESS_DESCRIPTORS.HDB,script:Ke.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:_T}}o(tK,"generateMainServerConfig");var Nme=9930;function wme(){ls.initSync(!0);let e=ls.get(Ke.CONFIG_PARAMS.ROOTPATH),t=Yo.join(e,"clustering",dp.NATS_CONFIG_FILES.HUB_SERVER),r=Yo.join(ls.get(Ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ke.LOG_NAMES.HDB),n=X1.get(Ke.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=dp.LOG_LEVEL_FLAGS[ls.get(Ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ke.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Nme?"-"+n:""),script:eK,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 ls.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Zd,i.error_file=Zd),i}o(wme,"generateNatsHubServerConfig");var Ome=9940;function Cme(){ls.initSync(!0);let e=ls.get(Ke.CONFIG_PARAMS.ROOTPATH),t=Yo.join(e,"clustering",dp.NATS_CONFIG_FILES.LEAF_SERVER),r=Yo.join(ls.get(Ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ke.LOG_NAMES.HDB),n=X1.get(Ke.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=dp.LOG_LEVEL_FLAGS[ls.get(Ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ke.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Ome?"-"+n:""),script:eK,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 ls.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Zd,i.error_file=Zd),i}o(Cme,"generateNatsLeafServerConfig");function Pme(){ls.initSync();let e=Yo.join(ls.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:bme,autorestart:!1};return ls.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Zd,t.error_file=Zd),t}o(Pme,"generateClusteringUpgradeV4ServiceConfig");function Lme(){let e={[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.RESTART_HDB};return ET.noBootFile()&&(e[Ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=ET.getEnvCliRootPath()),{...{name:Ke.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:Z1},script:Ime}}o(Lme,"generateRestart");function Dme(){return{apps:[tK()]}}o(Dme,"generateAllServiceConfigs");rK.exports={generateAllServiceConfigs:Dme,generateMainServerConfig:tK,generateRestart:Lme,generateNatsHubServerConfig:wme,generateNatsLeafServerConfig:Cme,generateClusteringUpgradeV4ServiceConfig:Pme}});var mp=M((p0e,_K)=>{"use strict";var ct=(k(),v(W)),Mme=ie(),zo=pT(),gT=rr(),Wo=Nt(),ic=nK(),ST=oe(),Kl=Q(),vme=$o(),{startWorker:sK,onMessageFromWorkers:Ume}=nt(),xme=Gd(),h0e=require("util"),Bme=require("child_process"),Fme=require("fs"),{execFile:Hme}=Bme,Je;_K.exports={enterPM2Mode:kme,start:oc,stop:aC,reload:oK,restart:aK,list:cC,describe:uK,connect:jo,kill:Kme,startAllServices:Yme,startService:lC,getUniqueServicesList:dK,restartAllServices:Wme,isServiceRegistered:fK,reloadStopStart:mK,restartHdb:lK,deleteProcess:$me,startClusteringProcesses:pK,startClusteringThreads:EK,isHdbRestartRunning:Vme,isClusteringRunning:jme,stopClustering:zme,reloadClustering:Qme,expectedRestartOfChildren:cK};var fp=!1;Ume(e=>{e.type==="restart"&&ST.initSync(!0)});function kme(){fp=!0}o(kme,"enterPM2Mode");function jo(){return Je||(Je=require("pm2")),new Promise((e,t)=>{Je.connect((r,n)=>{r&&t(r),e(n)})})}o(jo,"connect");var pn,Gme=10,iK;function oc(e,t=!1){if(fp)return qme(e);let r=Hme(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let a=pn.indexOf(r);a>-1&&pn.splice(a,1),!iK&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Gme&&(Fme.existsSync(zo.getHubConfigPath())?oc(e):(await zo.generateNatsConfig(!0),oc(e),await new Promise(c=>setTimeout(c,3e3)),await zo.removeNatsConfig(ct.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await zo.removeNatsConfig(ct.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let a=ST.get(ct.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,d;for(;l=c.exec(i);){if(l.index&&Wo.LOG_LEVEL_HIERARCHY[a]>=Wo.LOG_LEVEL_HIERARCHY[d||"info"]){let h=d===Wo.LOG_LEVELS.ERR||d===Wo.LOG_LEVELS.WRN?Kl.OUTPUTS.STDERR:Kl.OUTPUTS.STDOUT;Kl.logCustomLevel(d||"info",h,n,i.slice(u,l.index).trim())}let[f,m]=l;u=l.index+f.length,d=Wo.LOG_LEVELS[m]}if(Wo.LOG_LEVEL_HIERARCHY[a]>=Wo.LOG_LEVEL_HIERARCHY[d||"info"]){let f=d===Wo.LOG_LEVELS.ERR||d===Wo.LOG_LEVELS.WRN?Kl.OUTPUTS.STDERR:Kl.OUTPUTS.STDOUT;Kl.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(),!pn&&(pn=[],!t)){let i=o(()=>{iK=!0,pn&&(pn.map(a=>a.kill()),process.exit(0))},"killChildren");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}pn.push(r)}o(oc,"start");function qme(e){return new Promise(async(t,r)=>{try{await jo()}catch(n){r(n)}Je.start(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(qme,"startWithPM2");function aC(e){if(!fp){for(let t of pn||[])t.name===e&&(pn.splice(pn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await jo()}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(aC,"stop");function oK(e){return new Promise(async(t,r)=>{try{await jo()}catch(n){r(n)}Je.reload(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(oK,"reload");function aK(e){if(!fp){cK();for(let t of pn||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await jo()}catch(n){r(n)}Je.restart(e,(n,s)=>{Je.disconnect(),t(s)})})}o(aK,"restart");function cK(){for(let e of pn||[])e.config&&(e.config.restarts=0)}o(cK,"expectedRestartOfChildren");function $me(e){return new Promise(async(t,r)=>{try{await jo()}catch(n){r(n)}Je.delete(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o($me,"deleteProcess");async function lK(){await oc(ic.generateRestart())}o(lK,"restartHdb");async function Vme(){let e=await cC();for(let t in e)if(e[t].name===ct.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}o(Vme,"isHdbRestartRunning");function cC(){return new Promise(async(e,t)=>{try{await jo()}catch(r){t(r)}Je.list((r,n)=>{r&&(Je.disconnect(),t(r)),Je.disconnect(),e(n)})})}o(cC,"list");function uK(e){return new Promise(async(t,r)=>{try{await jo()}catch(n){r(n)}Je.describe(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(uK,"describe");function Kme(){if(!fp){for(let e of pn||[])e.kill();pn=[];return}return new Promise(async(e,t)=>{try{await jo()}catch(r){t(r)}Je.killDaemon((r,n)=>{r&&(Je.disconnect(),t(r)),Je.disconnect(),e(n)})})}o(Kme,"kill");async function Yme(){try{await pK(),await EK(),await oc(ic.generateAllServiceConfigs())}catch(e){throw Je?.disconnect(),e}}o(Yme,"startAllServices");async function lC(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case ct.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=ic.generateMainServerConfig();break;case ct.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=ic.generateNatsIngestServiceConfig();break;case ct.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=ic.generateNatsReplyServiceConfig();break;case ct.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=ic.generateNatsHubServerConfig(),await oc(r,t),await zo.removeNatsConfig(e);return;case ct.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=ic.generateNatsLeafServerConfig(),await oc(r,t),await zo.removeNatsConfig(e);return;case ct.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=ic.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await oc(r)}catch(r){throw Je?.disconnect(),r}}o(lC,"startService");async function dK(){try{let e=await cC(),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(dK,"getUniqueServicesList");async function Wme(e=[]){try{let t=!1,r=await dK();for(let n=0,s=Object.values(r).length;n<s;n++){let a=Object.values(r)[n].name;e.includes(a)||(a===ct.PROCESS_DESCRIPTORS.HDB?t=!0:await aK(a))}t&&await mK(ct.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Je?.disconnect(),t}}o(Wme,"restartAllServices");async function fK(e){if(pn?.find(r=>r.name===e))return!0;let t=await xme.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}o(fK,"isServiceRegistered");async function mK(e){let t=ST.get(ct.CONFIG_PARAMS.THREADS_COUNT)??ST.get(ct.CONFIG_PARAMS.THREADS),r=await uK(e),n=Mme.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await aC(e),await lC(e)):e===ct.PROCESS_DESCRIPTORS.HDB?await lK():await oK(e)}o(mK,"reloadStopStart");var hK;async function pK(e=!1){for(let t in ct.CLUSTERING_PROCESSES){let r=ct.CLUSTERING_PROCESSES[t];await lC(r,e)}}o(pK,"startClusteringProcesses");async function EK(){hK=sK(ct.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:ct.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await gT.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await gT.updateLocalStreams();let e=await vme.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===ct.PRE_4_0_0_VERSION){Kl.info("Starting clustering upgrade 4.0.0 process"),sK(ct.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}o(EK,"startClusteringThreads");async function zme(){for(let e in ct.CLUSTERING_PROCESSES)if(e!==ct.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===ct.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await hK.terminate();else{let t=ct.CLUSTERING_PROCESSES[e];await aC(t)}}o(zme,"stopClustering");async function jme(){for(let e in ct.CLUSTERING_PROCESSES){let t=ct.CLUSTERING_PROCESSES[e];if(await fK(t)===!1)return!1}return!0}o(jme,"isClusteringRunning");async function Qme(){await zo.generateNatsConfig(!0),await gT.reloadNATSHub(),await gT.reloadNATSLeaf(),await zo.removeNatsConfig(ct.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await zo.removeNatsConfig(ct.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}o(Qme,"reloadClustering")});var fC={};Oe(fC,{compactOnStart:()=>Jme,copyDb:()=>AK});async function Jme(){ac.notify("Running compact on start"),console.log("Running compact on start");let e=(0,uC.get)(U.ROOTPATH),t=new Map,r=st();(0,dC.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,TT.join)(e,"backup",n+".mdb"),a=(0,TT.join)(e,Uc,n+"-copy.mdb"),c=0;try{c=await gK(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){ac.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 AK(n,a),console.log("Backing up",n,"to",i);try{await(0,Yl.move)(s,i,{overwrite:!0})}catch(l){console.log("Error moving database",s,"to",i,l)}}try{ld()}catch(n){ac.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,Yl.move)(i,s,{overwrite:!0}),await(0,Yl.remove)((0,TT.join)(e,Uc,`${n}-copy.mdb-lock`));try{ld()}catch(n){ac.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){ac.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,dC.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,Yl.move)(a,i,{overwrite:!0})}catch(c){console.error(c)}}throw ld(),n}for(let[n,{backupDest:s,recordCount:i}]of t){let a=!0,c=await gK(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}.
|
|
19
|
-
Total record count before compaction: ${i}, total after: ${
|
|
20
|
-
Database backup has not been removed and can be found here: ${s}`;ac.error(
|
|
18
|
+
`)}catch(r){r.code==="ENOENT"?hn.debug("no license file found"):hn.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(kfe.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=v1(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){hn.error("There was an error parsing the license string."),hn.error(s),e.ram_allocation=ql.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return WO=e,e}o(JO,"licenseSearch");async function Jfe(){return WO||await JO(),WO}o(Jfe,"getLicense");function Xfe(){let e=JO().ram_allocation,t=process.constrainedMemory?.()||P1();if(t=Math.round(Math.min(t,P1())/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(Xfe,"checkMemoryLimit")});var eC=M((e0e,H1)=>{var dT=jd(),x1=require("chalk"),cs=Q(),B1=require("prompt"),{promisify:Zfe}=require("util"),XO=(k(),v(W)),eme=require("fs-extra"),tme=require("path"),rme=ie(),{packageJson:nme}=Rt(),F1=oe();F1.initSync();var sme=require("moment"),ime=Zfe(B1.get),ome=tme.join(F1.getHdbBasePath(),XO.LICENSE_KEY_DIR_NAME,XO.LICENSE_FILE_NAME,XO.LICENSE_FILE_NAME);H1.exports={getFingerprint:cme,setLicense:ame,parseLicense:ZO,register:lme,getRegistrationInfo:dme};async function ame(e){if(e&&e.key&&e.company){try{cs.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await ZO(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw cs.error(r),cs.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}o(ame,"setLicense");async function cme(){let e={};try{e=await dT.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw cs.error(r),cs.error(t),new Error(r)}return e}o(cme,"getFingerprint");async function ZO(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");cs.info("Validating license input...");let r=dT.validateLicense(e,t);if(cs.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(cs.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(cs.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{cs.info("writing license to disk"),await eme.writeFile(ome,JSON.stringify({license_key:e,company:t}))}catch(n){throw cs.error("Failed to write License"),n}return"Registration successful."}o(ZO,"parseLicense");async function lme(){let e=await ume();return ZO(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}o(lme,"register");async function ume(){let e=await dT.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:x1.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:x1.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{B1.start()}catch(n){cs.error(n)}let r;try{r=await ime(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}o(ume,"promptForRegistration");async function dme(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await dT.getLicense()}catch(r){throw cs.error(`There was an error when searching licenses due to: ${r.message}`),r}if(rme.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=nme.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=sme.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}o(dme,"getRegistrationInfo")});var G1=M((r0e,k1)=>{"use strict";var fme=Nt(),tC=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+fme.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"}};k1.exports=tC});var V1=M((s0e,$1)=>{"use strict";var q1=Nt(),rC=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+q1.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+q1.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"}};$1.exports=rC});var Y1=M((o0e,K1)=>{"use strict";var nC=class{static{o(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};K1.exports=nC});var z1=M((c0e,W1)=>{"use strict";var mme=Nt(),sC=class{static{o(this,"SysUserObject")}constructor(t,r){this.user=t+mme.SERVER_SUFFIX.ADMIN,this.password=r}};W1.exports=sC});var pT=M((u0e,J1)=>{"use strict";var $l=require("path"),Vl=require("fs-extra"),hme=G1(),pme=V1(),Eme=Y1(),_me=z1(),iC=Un(),Jd=ie(),Bn=yt(),mT=(k(),v(W)),lp=Nt(),{CONFIG_PARAMS:nr}=mT,Xd=Q(),up=oe(),j1=Vi(),oC=rr(),gme=os(),Qd="clustering",Sme=1e4,Q1=50;J1.exports={generateNatsConfig:Rme,removeNatsConfig:yme,getHubConfigPath:Tme};function Tme(){let e=up.get(nr.ROOTPATH);return $l.join(e,Qd,lp.NATS_CONFIG_FILES.HUB_SERVER)}o(Tme,"getHubConfigPath");async function Rme(e=!1,t=void 0){console.error("Warning: NATS replication is deprecated and will be removed in version 5.0 of Harper");let r=up.get(nr.ROOTPATH);Vl.ensureDirSync($l.join(r,"clustering","leaf")),up.initSync();let n=Bn.getConfigFromFile(nr.CLUSTERING_TLS_CERT_AUTH),s=Bn.getConfigFromFile(nr.CLUSTERING_TLS_PRIVATEKEY),i=Bn.getConfigFromFile(nr.CLUSTERING_TLS_CERTIFICATE);!await Vl.exists(i)&&!await Vl.exists(!n)&&await gme.createNatsCerts();let a=$l.join(r,Qd,lp.PID_FILES.HUB),c=$l.join(r,Qd,lp.PID_FILES.LEAF),l=Bn.getConfigFromFile(nr.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=$l.join(r,Qd,lp.NATS_CONFIG_FILES.HUB_SERVER),d=$l.join(r,Qd,lp.NATS_CONFIG_FILES.LEAF_SERVER),f=Bn.getConfigFromFile(nr.CLUSTERING_TLS_INSECURE),m=Bn.getConfigFromFile(nr.CLUSTERING_TLS_VERIFY),h=Bn.getConfigFromFile(nr.CLUSTERING_NODENAME),p=Bn.getConfigFromFile(nr.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await oC.checkNATSServerInstalled()||hT("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let _=await iC.listUsers(),g=Bn.getConfigFromFile(nr.CLUSTERING_USER),y=await iC.getClusterUser();(Jd.isEmpty(y)||y.active!==!0)&&hT(`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 fT(nr.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await fT(nr.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await fT(nr.CLUSTERING_HUBSERVER_NETWORK_PORT),await fT(nr.CLUSTERING_LEAFSERVER_NETWORK_PORT));let T=[],R=[];for(let[q,K]of _.entries())K.role?.role===mT.ROLE_TYPES_ENUM.CLUSTER_USER&&K.active&&(T.push(new _me(K.username,j1.decrypt(K.hash))),R.push(new Eme(K.username,j1.decrypt(K.hash))));let N=[],{hub_routes:O}=Bn.getClusteringRoutes();if(!Jd.isEmptyOrZeroLength(O))for(let q of O)N.push(`tls://${y.sys_name_encoded}:${y.uri_encoded_d_hash}@${q.host}:${q.port}`);let F=new hme(Bn.getConfigFromFile(nr.CLUSTERING_HUBSERVER_NETWORK_PORT),h,a,i,s,n,f,m,p,Bn.getConfigFromFile(nr.CLUSTERING_HUBSERVER_CLUSTER_NAME),Bn.getConfigFromFile(nr.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),N,T,R);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=Jd.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===mT.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Vl.writeJson(u,F),Xd.trace(`Hub server config written to ${u}`));let Z=`tls://${y.sys_name_encoded}:${y.uri_encoded_d_hash}@0.0.0.0:${p}`,G=`tls://${y.uri_encoded_name}:${y.uri_encoded_d_hash}@0.0.0.0:${p}`,Y=new pme(Bn.getConfigFromFile(nr.CLUSTERING_LEAFSERVER_NETWORK_PORT),h,c,l,[Z],[G],T,R,i,s,n,f);n==null&&delete Y.tls.ca_file,(t===void 0||t===mT.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Vl.writeJson(d,Y),Xd.trace(`Leaf server config written to ${d}`))}o(Rme,"generateNatsConfig");async function fT(e){let t=up.get(e);return Jd.isEmpty(t)&&hT(`port undefined for '${e}'`),await Jd.isPortTaken(t)&&hT(`'${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(fT,"isPortAvailable");function hT(e){let t=`Error generating clustering config: ${e}`;Xd.error(t),console.error(t),process.exit(1)}o(hT,"generateNatsConfigError");async function yme(e){let{port:t,config_file:r}=oC.getServerConfig(e),{username:n,decrypt_hash:s}=await iC.getClusterUser(),i=0,a=2e3;for(;i<Q1;){try{let d=await oC.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){Xd.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=Q1)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&&Xd.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Jd.asyncSetTimeout(u)}let c="0".repeat(Sme),l=$l.join(up.get(nr.ROOTPATH),Qd,r);await Vl.writeFile(l,c),await Vl.remove(l),Xd.notify(e,"started.")}o(yme,"removeNatsConfig")});var nK=M((f0e,rK)=>{"use strict";var ls=oe(),Ame=jd(),Ke=(k(),v(W)),dp=Nt(),Yo=require("path"),{PACKAGE_ROOT:_T}=Rt(),X1=oe(),ET=ie(),Zd="/dev/null",bme=Yo.join(_T,"launchServiceScripts"),Z1=Yo.join(_T,"utility/scripts"),Ime=Yo.join(Z1,Ke.HDB_RESTART_SCRIPT),eK=Yo.resolve(_T,"dependencies",`${process.platform}-${process.arch}`,dp.NATS_BINARY_NAME);function tK(){let t=Ame.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 ET.noBootFile()&&(n[Ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=ET.getEnvCliRootPath()),{name:Ke.PROCESS_DESCRIPTORS.HDB,script:Ke.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:_T}}o(tK,"generateMainServerConfig");var Nme=9930;function wme(){ls.initSync(!0);let e=ls.get(Ke.CONFIG_PARAMS.ROOTPATH),t=Yo.join(e,"clustering",dp.NATS_CONFIG_FILES.HUB_SERVER),r=Yo.join(ls.get(Ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ke.LOG_NAMES.HDB),n=X1.get(Ke.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=dp.LOG_LEVEL_FLAGS[ls.get(Ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ke.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Nme?"-"+n:""),script:eK,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 ls.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Zd,i.error_file=Zd),i}o(wme,"generateNatsHubServerConfig");var Ome=9940;function Cme(){ls.initSync(!0);let e=ls.get(Ke.CONFIG_PARAMS.ROOTPATH),t=Yo.join(e,"clustering",dp.NATS_CONFIG_FILES.LEAF_SERVER),r=Yo.join(ls.get(Ke.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ke.LOG_NAMES.HDB),n=X1.get(Ke.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=dp.LOG_LEVEL_FLAGS[ls.get(Ke.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ke.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Ome?"-"+n:""),script:eK,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 ls.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Zd,i.error_file=Zd),i}o(Cme,"generateNatsLeafServerConfig");function Pme(){ls.initSync();let e=Yo.join(ls.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:bme,autorestart:!1};return ls.get(Ke.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Zd,t.error_file=Zd),t}o(Pme,"generateClusteringUpgradeV4ServiceConfig");function Lme(){let e={[Ke.PROCESS_NAME_ENV_PROP]:Ke.PROCESS_DESCRIPTORS.RESTART_HDB};return ET.noBootFile()&&(e[Ke.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=ET.getEnvCliRootPath()),{...{name:Ke.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:Z1},script:Ime}}o(Lme,"generateRestart");function Dme(){return{apps:[tK()]}}o(Dme,"generateAllServiceConfigs");rK.exports={generateAllServiceConfigs:Dme,generateMainServerConfig:tK,generateRestart:Lme,generateNatsHubServerConfig:wme,generateNatsLeafServerConfig:Cme,generateClusteringUpgradeV4ServiceConfig:Pme}});var mp=M((p0e,_K)=>{"use strict";var ct=(k(),v(W)),Mme=ie(),zo=pT(),gT=rr(),Wo=Nt(),ic=nK(),ST=oe(),Kl=Q(),vme=$o(),{startWorker:sK,onMessageFromWorkers:Ume}=nt(),xme=Gd(),h0e=require("util"),Bme=require("child_process"),Fme=require("fs"),{execFile:Hme}=Bme,Je;_K.exports={enterPM2Mode:kme,start:oc,stop:aC,reload:oK,restart:aK,list:cC,describe:uK,connect:jo,kill:Kme,startAllServices:Yme,startService:lC,getUniqueServicesList:dK,restartAllServices:Wme,isServiceRegistered:fK,reloadStopStart:mK,restartHdb:lK,deleteProcess:$me,startClusteringProcesses:pK,startClusteringThreads:EK,isHdbRestartRunning:Vme,isClusteringRunning:jme,stopClustering:zme,reloadClustering:Qme,expectedRestartOfChildren:cK};var fp=!1;Ume(e=>{e.type==="restart"&&ST.initSync(!0)});function kme(){fp=!0}o(kme,"enterPM2Mode");function jo(){return Je||(Je=require("pm2")),new Promise((e,t)=>{Je.connect((r,n)=>{r&&t(r),e(n)})})}o(jo,"connect");var pn,Gme=10,iK;function oc(e,t=!1){if(fp)return qme(e);let r=Hme(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let a=pn.indexOf(r);a>-1&&pn.splice(a,1),!iK&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Gme&&(Fme.existsSync(zo.getHubConfigPath())?oc(e):(await zo.generateNatsConfig(!0),oc(e),await new Promise(c=>setTimeout(c,3e3)),await zo.removeNatsConfig(ct.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await zo.removeNatsConfig(ct.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let a=ST.get(ct.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,d;for(;l=c.exec(i);){if(l.index&&Wo.LOG_LEVEL_HIERARCHY[a]>=Wo.LOG_LEVEL_HIERARCHY[d||"info"]){let h=d===Wo.LOG_LEVELS.ERR||d===Wo.LOG_LEVELS.WRN?Kl.OUTPUTS.STDERR:Kl.OUTPUTS.STDOUT;Kl.logCustomLevel(d||"info",h,n,i.slice(u,l.index).trim())}let[f,m]=l;u=l.index+f.length,d=Wo.LOG_LEVELS[m]}if(Wo.LOG_LEVEL_HIERARCHY[a]>=Wo.LOG_LEVEL_HIERARCHY[d||"info"]){let f=d===Wo.LOG_LEVELS.ERR||d===Wo.LOG_LEVELS.WRN?Kl.OUTPUTS.STDERR:Kl.OUTPUTS.STDOUT;Kl.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(),!pn&&(pn=[],!t)){let i=o(()=>{iK=!0,pn&&(pn.map(a=>a.kill()),process.exit(0))},"killChildren");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}pn.push(r)}o(oc,"start");function qme(e){return new Promise(async(t,r)=>{try{await jo()}catch(n){r(n)}Je.start(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(qme,"startWithPM2");function aC(e){if(!fp){for(let t of pn||[])t.name===e&&(pn.splice(pn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await jo()}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(aC,"stop");function oK(e){return new Promise(async(t,r)=>{try{await jo()}catch(n){r(n)}Je.reload(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(oK,"reload");function aK(e){if(!fp){cK();for(let t of pn||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await jo()}catch(n){r(n)}Je.restart(e,(n,s)=>{Je.disconnect(),t(s)})})}o(aK,"restart");function cK(){for(let e of pn||[])e.config&&(e.config.restarts=0)}o(cK,"expectedRestartOfChildren");function $me(e){return new Promise(async(t,r)=>{try{await jo()}catch(n){r(n)}Je.delete(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o($me,"deleteProcess");async function lK(){await oc(ic.generateRestart())}o(lK,"restartHdb");async function Vme(){let e=await cC();for(let t in e)if(e[t].name===ct.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}o(Vme,"isHdbRestartRunning");function cC(){return new Promise(async(e,t)=>{try{await jo()}catch(r){t(r)}Je.list((r,n)=>{r&&(Je.disconnect(),t(r)),Je.disconnect(),e(n)})})}o(cC,"list");function uK(e){return new Promise(async(t,r)=>{try{await jo()}catch(n){r(n)}Je.describe(e,(n,s)=>{n&&(Je.disconnect(),r(n)),Je.disconnect(),t(s)})})}o(uK,"describe");function Kme(){if(!fp){for(let e of pn||[])e.kill();pn=[];return}return new Promise(async(e,t)=>{try{await jo()}catch(r){t(r)}Je.killDaemon((r,n)=>{r&&(Je.disconnect(),t(r)),Je.disconnect(),e(n)})})}o(Kme,"kill");async function Yme(){try{await pK(),await EK(),await oc(ic.generateAllServiceConfigs())}catch(e){throw Je?.disconnect(),e}}o(Yme,"startAllServices");async function lC(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case ct.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=ic.generateMainServerConfig();break;case ct.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=ic.generateNatsIngestServiceConfig();break;case ct.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=ic.generateNatsReplyServiceConfig();break;case ct.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=ic.generateNatsHubServerConfig(),await oc(r,t),await zo.removeNatsConfig(e);return;case ct.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=ic.generateNatsLeafServerConfig(),await oc(r,t),await zo.removeNatsConfig(e);return;case ct.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=ic.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await oc(r)}catch(r){throw Je?.disconnect(),r}}o(lC,"startService");async function dK(){try{let e=await cC(),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(dK,"getUniqueServicesList");async function Wme(e=[]){try{let t=!1,r=await dK();for(let n=0,s=Object.values(r).length;n<s;n++){let a=Object.values(r)[n].name;e.includes(a)||(a===ct.PROCESS_DESCRIPTORS.HDB?t=!0:await aK(a))}t&&await mK(ct.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Je?.disconnect(),t}}o(Wme,"restartAllServices");async function fK(e){if(pn?.find(r=>r.name===e))return!0;let t=await xme.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}o(fK,"isServiceRegistered");async function mK(e){let t=ST.get(ct.CONFIG_PARAMS.THREADS_COUNT)??ST.get(ct.CONFIG_PARAMS.THREADS),r=await uK(e),n=Mme.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await aC(e),await lC(e)):e===ct.PROCESS_DESCRIPTORS.HDB?await lK():await oK(e)}o(mK,"reloadStopStart");var hK;async function pK(e=!1){for(let t in ct.CLUSTERING_PROCESSES){let r=ct.CLUSTERING_PROCESSES[t];await lC(r,e)}}o(pK,"startClusteringProcesses");async function EK(){hK=sK(ct.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:ct.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await gT.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await gT.updateLocalStreams();let e=await vme.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===ct.PRE_4_0_0_VERSION){Kl.info("Starting clustering upgrade 4.0.0 process"),sK(ct.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}o(EK,"startClusteringThreads");async function zme(){for(let e in ct.CLUSTERING_PROCESSES)if(e!==ct.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===ct.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await hK.terminate();else{let t=ct.CLUSTERING_PROCESSES[e];await aC(t)}}o(zme,"stopClustering");async function jme(){for(let e in ct.CLUSTERING_PROCESSES){let t=ct.CLUSTERING_PROCESSES[e];if(await fK(t)===!1)return!1}return!0}o(jme,"isClusteringRunning");async function Qme(){await zo.generateNatsConfig(!0),await gT.reloadNATSHub(),await gT.reloadNATSLeaf(),await zo.removeNatsConfig(ct.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await zo.removeNatsConfig(ct.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}o(Qme,"reloadClustering")});var fC={};Oe(fC,{compactOnStart:()=>Jme,copyDb:()=>AK});async function Jme(){ac.notify("Running compact on start"),console.log("Running compact on start");let e=(0,uC.get)(U.ROOTPATH),t=new Map,r=st();(0,dC.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,TT.join)(e,"backup",n+".mdb"),a=(0,TT.join)(e,Uc,n+"-copy.mdb"),c=0;try{c=await gK(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){ac.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 AK(n,a),console.log("Backing up",n,"to",i);try{await(0,Yl.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,Yl.move)(a,s,{overwrite:!0}),await(0,Yl.remove)((0,TT.join)(e,Uc,`${n}-copy.mdb-lock`))}try{ld()}catch(n){ac.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}try{ld()}catch(n){ac.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){ac.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,dC.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,Yl.move)(a,i,{overwrite:!0})}catch(c){console.error(c)}}throw ld(),n}for(let[n,{backupDest:s,recordCount:i}]of t){let a=await gK(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}.
|
|
19
|
+
Total record count before compaction: ${i}, total after: ${a}.
|
|
20
|
+
Database backup has not been removed and can be found here: ${s}`;ac.error(c),console.error(c)}(0,uC.get)(U.STORAGE_COMPACTONSTARTKEEPBACKUP)!==!0&&(console.log("Removing backup",s),await(0,Yl.remove)(s))}}async function gK(e){let t=await(0,yK.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}function ef(){}async function AK(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=ef,m.primaryStore.remove=ef;for(let h in m.indices){let p=m.indices[h];p.put=ef,p.remove=ef}m.auditStore&&(m.auditStore.put=ef,m.auditStore.remove=ef),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,SK.open)(new TK.default(t)),c=a.openDB(RT.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,_,g;if(p&&(_=h.compression,g=Vg(),g?h.compression=g:delete h.compression,_?.dictionary?.toString()===g?.dictionary?.toString()&&(_=null,g=null)),c.put(m,h),!(p||h.indexed))continue;let y=new RK.default(!p,p);y.encoding="binary",y.compression=_;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(RT.AUDIT_STORE_NAME,Rm);console.log("copying audit log for",e,"to",t),f(i,m,!1,d)}async function f(m,h,p,_){let g=0,y=0,T=0,R=1e7,N=null;for(;R-- >0;)try{for(let O of m.getKeys({start:N,transaction:_}))try{N=O;let{value:F,version:Z}=m.getEntry(O,{transaction:_});if(F?.length<14&&p){T++;continue}l=h.put(O,F,p?Z:void 0),g++,_.openTimer&&(_.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 SK,TT,Yl,uC,TK,RK,RT,yK,dC,ac,mC=ue(()=>{De();SK=require("lmdb"),TT=require("path"),Yl=require("fs-extra"),uC=w(oe()),TK=w(Lm()),RK=w(Pm()),RT=w(qt());k();Di();yK=w(Ba()),dC=w(yt()),ac=w(Q());o(Jme,"compactOnStart");o(gK,"getTotalDBRecordCount");o(ef,"noop");o(AK,"copyDb")});var rf=M((b0e,PK)=>{"use strict";var Xme=require("minimist"),{isMainThread:pC,parentPort:pp,threadId:R0e}=require("worker_threads"),ft=(k(),v(W)),to=Q(),EC=ie(),AT=pT(),yT=rr(),y0e=Nt(),wK=yt(),Si=mp(),bK=Gd(),{compactOnStart:Zme}=(mC(),v(fC)),ehe=xc(),{restartWorkers:bT,onMessageByType:the}=nt(),{handleHDBError:rhe,hdbErrors:nhe}=ge(),{HTTP_STATUS_CODES:she}=nhe,Ep=oe(),{sendOperationToNode:IK,getThisNodeName:ihe,monitorNodeCAs:ohe}=(ss(),v(Ho)),{getHDBNodeTable:A0e}=(Dl(),v(Iw));Ep.initSync();var hp=`Restarting HarperDB. This may take up to ${ft.RESTART_TIMEOUT_MS/1e3} seconds.`,ahe="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",NK="Clustering is not enabled so cannot be restarted",che="Invalid service",tf,xs;PK.exports={restart:OK,restartService:_C};pC&&the(ft.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await _C({service:e.workerType}):OK({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function OK(e){xs=Object.keys(e).length===0,tf=await Si.isServiceRegistered(ft.PROCESS_DESCRIPTORS.HDB);let t=Xme(process.argv);if(t.service){await _C(t);return}if(xs&&!tf){console.error(ahe);return}if(xs&&console.log(hp),tf){Si.enterPM2Mode(),to.notify(hp);let r=ehe(Object.keys(ft.CONFIG_PARAM_MAP),!0);return EC.isEmptyOrZeroLength(Object.keys(r))||wK.updateConfigValue(void 0,void 0,r,!0,!0),lhe(),hp}return pC?(to.notify(hp),Ep.get(ft.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Zme(),process.env.HARPER_EXIT_ON_RESTART&&process.exit(0),setTimeout(()=>{bT()},50)):pp.postMessage({type:ft.ITC_EVENT_TYPES.RESTART}),hp}o(OK,"restart");async function _C(e){let{service:t}=e;if(ft.HDB_PROCESS_SERVICES[t]===void 0)throw rhe(new Error,che,she.BAD_REQUEST,void 0,void 0,!0);if(Si.expectedRestartOfChildren(),tf=await Si.isServiceRegistered(ft.PROCESS_DESCRIPTORS.HDB),!pC){e.replicated&&ohe(),pp.postMessage({type:ft.ITC_EVENT_TYPES.RESTART,workerType:t}),pp.ref(),await new Promise(s=>{pp.on("message",i=>{i.type==="restart-complete"&&(s(),pp.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===ihe())continue;let i;try{({job_id:i}=await IK(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 IK(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 ft.HDB_PROCESS_SERVICES.clustering:if(!Ep.get(ft.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=NK;break}xs&&console.log("Restarting clustering"),to.notify("Restarting clustering"),await CK();break;case ft.HDB_PROCESS_SERVICES.clustering_config:case ft.HDB_PROCESS_SERVICES["clustering config"]:if(!Ep.get(ft.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=NK;break}xs&&console.log("Restarting clusteringConfig"),to.notify("Restarting clustering_config"),await Si.reloadClustering();break;case"custom_functions":case"custom functions":case ft.HDB_PROCESS_SERVICES.harperdb:case ft.HDB_PROCESS_SERVICES.http_workers:case ft.HDB_PROCESS_SERVICES.http:if(xs&&!tf){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}xs&&console.log("Restarting httpWorkers"),to.notify("Restarting http_workers"),xs?await Si.restart(ft.PROCESS_DESCRIPTORS.HDB):await bT("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(to.error(r),xs&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}o(_C,"restartService");async function lhe(){await CK(),await Si.restart(ft.PROCESS_DESCRIPTORS.HDB),await EC.asyncSetTimeout(2e3),Ep.get(ft.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await hC(),xs&&(await yT.closeConnection(),process.exit(0))}o(lhe,"restartPM2Mode");async function CK(){if(!wK.getConfigFromFile(ft.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await bK.getHDBProcessInfo()).clustering.length===0)to.trace("Clustering not running, restart will start clustering services"),await AT.generateNatsConfig(!0),await Si.startClusteringProcesses(),await Si.startClusteringThreads(),await hC(),xs&&await yT.closeConnection();else{await AT.generateNatsConfig(!0),tf?(to.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await Si.restart(ft.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Si.restart(ft.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await bK.getHDBProcessInfo()).clustering.forEach(s=>{to.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await EC.asyncSetTimeout(3e3),await hC(),await yT.updateLocalStreams(),xs&&await yT.closeConnection(),to.trace("Restart clustering restarting ingest and reply service threads");let t=bT(ft.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=bT(ft.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}o(CK,"restartClustering");async function hC(){await AT.removeNatsConfig(ft.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await AT.removeNatsConfig(ft.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}o(hC,"removeNatsConfig")});var GK=M((w0e,kK)=>{"use strict";var N0e=require("lodash"),Fn=(k(),v(W)),{handleHDBError:LK,hdbErrors:uhe}=ge(),{HDB_ERROR_MSGS:dhe,HTTP_STATUS_CODES:fhe}=uhe,gC=Q();kK.exports={getRolePermissions:hhe};var Wl=Object.create(null),mhe=o(e=>({key:e,perms:{}}),"permsTemplateObj"),UK=o((e=!1)=>({describe:e,tables:{}}),"schemaPermsTemplate"),xK=o((e=!1,t=!1,r=!1,n=!1)=>({[Fn.PERMS_CRUD_ENUM.READ]:e,[Fn.PERMS_CRUD_ENUM.INSERT]:t,[Fn.PERMS_CRUD_ENUM.UPDATE]:r,[Fn.PERMS_CRUD_ENUM.DELETE]:n}),"permissionsTemplate"),SC=o((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...xK(t,r,n,s)}),"tablePermsTemplate"),DK=o((e,t=xK())=>({attribute_name:e,describe:HK(t),[_p]:t[_p],[TC]:t[TC],[RC]:t[RC]}),"attrPermsTemplate"),MK=o((e,t=!1)=>({attribute_name:e,describe:t,[_p]:t}),"timestampAttrPermsTemplate"),{READ:_p,INSERT:TC,UPDATE:RC}=Fn.PERMS_CRUD_ENUM,BK=Object.values(Fn.PERMS_CRUD_ENUM),FK=[_p,TC,RC];function hhe(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[Fn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Wl[t]&&Wl[t].key===n)return Wl[t].perms;let s=phe(e,r);return Wl[t]?Wl[t].key=n:Wl[t]=mhe(n),Wl[t].perms=s,s}catch(r){if(!e[Fn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Fn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Fn.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 gC.error(n),gC.debug(r),LK(new Error,dhe.OUTDATED_PERMS_TRANSLATION_ERROR,fhe.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
21
21
|
${r.stack}`;throw gC.error(n),LK(new Error)}}}o(hhe,"getRolePermissions");function phe(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Fn.SYSTEM_SCHEMA_NAME]=n[Fn.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]=Ehe(t[i]);return}r[i]=UK(),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=_he(c,l);r[i].describe||BK.forEach(d=>{u[d]&&(r[i].describe=!0)}),r[i].tables[a]=u}else r[i].tables[a]=SC()})):Object.keys(t[i]).forEach(a=>{r[i].tables[a]=SC()})}),r}o(phe,"translateRolePermissions");function Ehe(e){let t=UK(!0);return Object.keys(e).forEach(r=>{t.tables[r]=SC(!0,!0,!0,!0,!0)}),t}o(Ehe,"createStructureUserPermissions");function _he(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 Fn.TIME_STAMP_NAMES.includes(f)&&(m=MK(f,d[_p])),u[f]=m,u},{}),a=t.primaryKey||t.hash_attribute,c=!!i[a],l=DK(a);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let d=i[u];d.describe=HK(d),s.attribute_permissions.push(d),c||ghe(d,l)}else if(u!==a){let d;Fn.TIME_STAMP_NAMES.includes(u)?d=MK(u):d=DK(u),s.attribute_permissions.push(d)}}),c||s.attribute_permissions.push(l),s.describe=vK(s),s}else return e.describe=vK(e),e}o(_he,"getTableAttrPerms");function vK(e){return BK.filter(t=>e[t]).length>0}o(vK,"getSchemaTableDescribePerm");function HK(e){return FK.filter(t=>e[t]).length>0}o(HK,"getAttributeDescribePerm");function ghe(e,t){FK.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}o(ghe,"checkForHashPerms")});var gp={};Oe(gp,{authentication:()=>jK,bypassAuth:()=>whe,login:()=>bC,logout:()=>IC,start:()=>Ohe});function whe(){zK=!0}async function jK(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,a=[];try{if(i){let h=e.isOperationsServer?Ahe?yhe:[]:Rhe?The:[];if(h.includes(i)||h.includes("*")){if(e.method==="OPTIONS"){let p=En.get(U.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",_=new Cs([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",p],["Access-Control-Allow-Origin",i]]);return IT&&_.set("Access-Control-Allow-Credentials","true"),{status:200,headers:_}}a.push("Access-Control-Allow-Origin",i),IT&&a.push("Access-Control-Allow-Credentials","true")}}let l,u;if(IT){i||(i=r.host);let h=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",p=s?.split(/;\s+/)||[];for(let _ of p)if(_.startsWith(h)){let g=_.indexOf(";");l=_.slice(h.length,g===-1?_.length:g),u=await qK.get(l);break}e.session=u||(u={})}let d=o((h,p,_)=>{let g=new NT.AuthAuditLog(h,p,ya.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=_,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),p===Zs.SUCCESS?yC.notify(g):yC.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&yC.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,Zs.SUCCESS,"mTLS")):She("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let f;if(!e.user)if(n){if(f=zl.get(n),!f){let h=n.indexOf(" "),p=n.slice(0,h),_=n.slice(h+1),g,y;try{switch(p){case"Basic":let T=atob(_),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 rw(_)}catch(N){if(N.message==="invalid token")try{return await iS(_),c({status:-1})}catch{throw N}}break}}catch(T){return Ihe&&(zl.get(_)||(zl.set(_,_),d(g,Zs.FAILURE,p))),c({status:401,body:Na({error:T.message},e)})}zl.set(n,f),bhe&&d(f.username,Zs.SUCCESS,p)}e.user=f}else u?.user?e.user=await Le.getUser(u.user,null,e):(zK&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,VK.getSuperUser)());IT&&(e.session.update=function(h){let p=En.get(U.AUTHENTICATION_COOKIE_EXPIRES),_=e.protocol==="https"||r.host?.startsWith("localhost:")||r.host?.startsWith("127.0.0.1:")||r.host?.startsWith("::1");if(!l){l=(0,KK.v4)();let g=En.get(U.AUTHENTICATION_COOKIE_DOMAINS),y=p?new Date(Date.now()+(0,AC.convertToMS)(p)).toUTCString():Nhe,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}`),_&&(N+="; SameSite=None; Secure"),a?a.push("Set-Cookie",N):m?.headers?.set&&m.headers.set("Set-Cookie",N)}return _&&(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,qK.put(h,{expiresAt:p?Date.now()+(0,AC.convertToMS)(p):void 0})},e.login=async function(h,p){let _=e.user=await Le.authenticateUser(h,p,e);e.session.update({user:_&&(_.getId?.()??_.username)})});let m=await t(e);return m&&(m.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Is.loginPath?(m.status=302,m.headers.set("Location",Is.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 Cs);for(let f=0;f<u;){let m=a[f++];d.set(m,a[f++])}}return a=null,l}o(c,"applyResponseHeaders")}function Ohe({server:e,port:t,securePort:r}){e.http(jK,t||r?{port:t,securePort:r}:{port:"all"}),$K||($K=!0,setInterval(()=>{zl=new Map},En.get(U.AUTHENTICATION_CACHETTL)).unref(),YK.user.addListener(()=>{zl=new Map}))}async function bC(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 IC(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var VK,KK,En,NT,YK,AC,WK,She,yC,The,Rhe,yhe,Ahe,qK,IT,zK,bhe,Ihe,Nhe,zl,$K,wT=ue(()=>{VK=w(Un());Mr();ku();gd();De();KK=require("uuid"),En=w(oe());k();NT=w(Q()),YK=w(ah());mh();AC=w(ie());yo();WK=(0,NT.forComponent)("authentication"),{debug:She}=WK,yC=WK.withTag("auth-event");En.initSync();The=En.get(U.HTTP_CORSACCESSLIST),Rhe=En.get(U.HTTP_CORS),yhe=En.get(U.OPERATIONSAPI_NETWORK_CORSACCESSLIST),Ahe=En.get(U.OPERATIONSAPI_NETWORK_CORS),qK=je({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),IT=En.get(U.AUTHENTICATION_ENABLESESSIONS)??!0,zK=process.env.AUTHENTICATION_AUTHORIZELOCAL??En.get(U.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,bhe=En.get(U.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ihe=En.get(U.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Nhe="Tue, 01 Oct 8307 19:33:20 GMT",zl=new Map;Le.onInvalidatedUser(()=>{zl=new Map});o(whe,"bypassAuth");o(jK,"authentication");o(Ohe,"start");o(bC,"login");o(IC,"logout")});var rY=M((B0e,tY)=>{"use strict";var we=require("joi"),QK=require("fs-extra"),JK=require("path"),us=lt(),XK=oe(),ZK=(k(),v(W)),eY=Q(),{hdbErrors:Che}=ge(),{HDB_ERROR_MSGS:_n}=Che,Qo=/^[a-zA-Z0-9-_]+$/,Phe=/^[a-zA-Z0-9-_]+$/;tY.exports={getDropCustomFunctionValidator:Dhe,setCustomFunctionValidator:Mhe,addComponentValidator:Bhe,dropCustomFunctionProjectValidator:Fhe,packageComponentValidator:Hhe,deployComponentValidator:khe,setComponentFileValidator:vhe,getComponentFileValidator:xhe,dropComponentFileValidator:Uhe,addSSHKeyValidator:Ghe,updateSSHKeyValidator:qhe,deleteSSHKeyValidator:$he,setSSHKnownHostsValidator:Vhe};function OT(e,t,r){try{let n=XK.get(ZK.CONFIG_PARAMS.COMPONENTSROOT),s=JK.join(n,t);return QK.existsSync(s)?e?t:r.message(_n.PROJECT_EXISTS):e?r.message(_n.NO_PROJECT):t}catch(n){return eY.error(n),r.message(_n.VALIDATION_ERR)}}o(OT,"checkProjectExists");function Sp(e,t){return e.includes("..")?t.message("Invalid file path"):e}o(Sp,"checkFilePath");function Lhe(e,t,r,n){try{let s=XK.get(ZK.CONFIG_PARAMS.COMPONENTSROOT),i=JK.join(s,e,t,r+".js");return QK.existsSync(i)?r:n.message(_n.NO_FILE)}catch(s){return eY.error(s),n.message(_n.VALIDATION_ERR)}}o(Lhe,"checkFileExists");function Dhe(e){let t=we.object({project:we.string().pattern(Qo).custom(OT.bind(null,!0)).required().messages({"string.pattern.base":_n.BAD_PROJECT_NAME}),type:we.string().valid("helpers","routes").required(),file:we.string().pattern(Qo).custom(Lhe.bind(null,e.project,e.type)).custom(Sp).required().messages({"string.pattern.base":_n.BAD_FILE_NAME})});return us.validateBySchema(e,t)}o(Dhe,"getDropCustomFunctionValidator");function Mhe(e){let t=we.object({project:we.string().pattern(Qo).custom(OT.bind(null,!0)).required().messages({"string.pattern.base":_n.BAD_PROJECT_NAME}),type:we.string().valid("helpers","routes").required(),file:we.string().custom(Sp).required(),function_content:we.string().required()});return us.validateBySchema(e,t)}o(Mhe,"setCustomFunctionValidator");function vhe(e){let t=we.object({project:we.string().pattern(Qo).required().messages({"string.pattern.base":_n.BAD_PROJECT_NAME}),file:we.string().custom(Sp).required(),payload:we.string().allow("").optional(),encoding:we.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return us.validateBySchema(e,t)}o(vhe,"setComponentFileValidator");function Uhe(e){let t=we.object({project:we.string().pattern(Qo).required().messages({"string.pattern.base":_n.BAD_PROJECT_NAME}),file:we.string().custom(Sp).optional()});return us.validateBySchema(e,t)}o(Uhe,"dropComponentFileValidator");function xhe(e){let t=we.object({project:we.string().required(),file:we.string().custom(Sp).required(),encoding:we.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return us.validateBySchema(e,t)}o(xhe,"getComponentFileValidator");function Bhe(e){let t=we.object({project:we.string().pattern(Qo).custom(OT.bind(null,!1)).required().messages({"string.pattern.base":_n.BAD_PROJECT_NAME})});return us.validateBySchema(e,t)}o(Bhe,"addComponentValidator");function Fhe(e){let t=we.object({project:we.string().pattern(Qo).custom(OT.bind(null,!0)).required().messages({"string.pattern.base":_n.BAD_PROJECT_NAME})});return us.validateBySchema(e,t)}o(Fhe,"dropCustomFunctionProjectValidator");function Hhe(e){let t=we.object({project:we.string().pattern(Qo).required().messages({"string.pattern.base":_n.BAD_PROJECT_NAME}),skip_node_modules:we.boolean(),skip_symlinks:we.boolean()});return us.validateBySchema(e,t)}o(Hhe,"packageComponentValidator");function khe(e){let t=we.object({project:we.string().pattern(Qo).required().messages({"string.pattern.base":_n.BAD_PROJECT_NAME}),package:we.string().optional(),restart:we.alternatives().try(we.boolean(),we.string().valid("rolling")).optional()});return us.validateBySchema(e,t)}o(khe,"deployComponentValidator");function Ghe(e){let t=we.object({name:we.string().pattern(Phe).required().messages({"string.pattern.base":_n.BAD_SSH_KEY_NAME}),key:we.string().required(),host:we.string().required(),hostname:we.string().required(),known_hosts:we.string().optional()});return us.validateBySchema(e,t)}o(Ghe,"addSSHKeyValidator");function qhe(e){let t=we.object({name:we.string().required(),key:we.string().required()});return us.validateBySchema(e,t)}o(qhe,"updateSSHKeyValidator");function $he(e){let t=we.object({name:we.string().required()});return us.validateBySchema(e,t)}o($he,"deleteSSHKeyValidator");function Vhe(e){let t=we.object({known_hosts:we.string().required()});return us.validateBySchema(e,t)}o(Vhe,"setSSHKnownHostsValidator")});var yp=M((H0e,aY)=>{"use strict";var CT=require("joi"),cc=require("path"),nf=require("fs-extra"),{exec:Khe,spawn:Yhe}=require("child_process"),Whe=require("util"),zhe=Whe.promisify(Khe),sf=(k(),v(W)),{PACKAGE_ROOT:jhe}=Rt(),{handleHDBError:Tp,hdbErrors:Qhe}=ge(),{HTTP_STATUS_CODES:Rp}=Qhe,jl=oe(),Jhe=lt(),lc=Q(),{once:Xhe}=require("events");jl.initSync();var NC=jl.get(sf.CONFIG_PARAMS.COMPONENTSROOT),nY="npm install --force --omit=dev --json",Zhe=`${nY} --dry-run`,epe=jl.get(sf.CONFIG_PARAMS.ROOTPATH),PT=cc.join(epe,"ssh");aY.exports={installModules:spe,auditModules:ipe,installAllRootModules:tpe,uninstallRootModule:rpe,linkHarperdb:npe,runCommand:of};async function tpe(e=!1,t=jl.get(sf.CONFIG_PARAMS.ROOTPATH)){await LT();let r=!1,n=process.env;nf.pathExistsSync(PT)&&nf.readdirSync(PT).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+cc.join(PT,"config")+" -o UserKnownHostsFile="+cc.join(PT,"known_hosts"),...process.env},r=!0)});try{let s=jl.get(sf.CONFIG_PARAMS.ROOTPATH),i=cc.join(s,"node_modules","harperdb");nf.lstatSync(i).isSymbolicLink()&&nf.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&lc.error("Error removing symlink:",s)}await of(e?"npm install --force --ignore-scripts":"npm install --force",t,n)}o(tpe,"installAllRootModules");async function rpe(e){await of(`npm uninstall ${e}`,jl.get(sf.CONFIG_PARAMS.ROOTPATH))}o(rpe,"uninstallRootModule");async function npe(){await LT(),await of(`npm link ${jhe}`,jl.get(sf.CONFIG_PARAMS.ROOTPATH))}o(npe,"linkHarperdb");async function of(e,t=void 0,r=process.env){lc.debug({tagName:"npm_run_command"},`running command: \`${e}\``);let n=Yhe(e,{shell:!0,cwd:t,env:r,stdio:["ignore","pipe","pipe"]}),s="",i="";n.stdout.on("data",c=>{let l=c.toString();lc.debug({tagName:"npm_run_command:stdout"},l),s+=l}),n.stderr.on("data",c=>{let l=c.toString();lc.error({tagName:"npm_run_command:stderr"},l),i+=l});let[a]=await Xhe(n,"close");if(a!==0)throw new Error(`Command \`${e}\` exited with code ${a}.${i===""?"":` Error: ${i}`}`);return s||void 0}o(of,"runCommand");async function spe(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";lc.warn(t,e.projects);let r=oY(e);if(r)throw Tp(r,r.message,Rp.BAD_REQUEST);let{projects:n,dryRun:s}=e,i=s===!0?Zhe:nY;await LT(),await iY(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=cc.join(NC,u),f,m=null;try{let{stdout:h,stderr:p}=await zhe(i,{cwd:d});f=h?h.replace(`
|
|
22
22
|
`,""):null,m=p?p.replace(`
|
|
23
23
|
`,""):null}catch(h){h.stderr?a[u].npm_error=sY(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 lc.info(`finished installModules with response ${a}`),a.warning=t,a}o(spe,"installModules");function sY(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
|