@interopio/gateway
Version:
[](https://www.npmjs.com/package/@interopio/gateway)
4 lines • 144 kB
JavaScript
"use strict";var Bc=Object.create;var jt=Object.defineProperty;var Kc=Object.getOwnPropertyDescriptor;var Vc=Object.getOwnPropertyNames;var zc=Object.getPrototypeOf,Qc=Object.prototype.hasOwnProperty;var we=(t,e)=>()=>(t&&(e=t(t=0)),e);var Ee=(t,e)=>{for(var r in e)jt(t,r,{get:e[r],enumerable:!0})},Li=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Vc(e))!Qc.call(t,i)&&i!==r&&jt(t,i,{get:()=>e[i],enumerable:!(n=Kc(e,i))||n.enumerable});return t};var Ji=(t,e,r)=>(r=t!=null?Bc(zc(t)):{},Li(e||!t||!t.__esModule?jt(r,"default",{value:t,enumerable:!0}):r,t)),Yc=t=>Li(jt({},"__esModule",{value:!0}),t);var en={};Ee(en,{regexify:()=>Bt,valueMatches:()=>je,valuesMatch:()=>Zr});function td(t){return typeof t=="string"}function je(t,e){return td(t)?t===e:typeof e=="string"?t.test(e):!1}function Zr(t,e){for(let r of t)if(je(r,e))return!0;return!1}function Bt(t){if(typeof t=="string"){let e=nd.exec(t)?.groups;if(e??=rd.exec(t)?.groups,e?.pattern)return new RegExp(e.pattern,e.flags??"")}return t}var rd,nd,Kt=we(()=>{"use strict";rd=/^#(\(\?(?<flags>[im]*)\))?(?<pattern>.*)$/,nd=/^\/(?<pattern>(?:[^/\\]|\\.)+)\/(?<flags>[gimsuyd]*)$/});function g(t){return Zi.getLogger(t)}var Zi,$=we(()=>{"use strict";Zi=Ji(require("@interopio/gateway/logging/core"),1)});function lo(t,e){return e.reduce((r,n)=>n===t?r:r.concat(n),[])}function yo(t,e){return t[e]?t:(0,mo.produce)(t,r=>{r[e]={}})}function $e(t){return t instanceof Set?Array.from(t).map($e):t instanceof Array?t.map($e):t instanceof Map?$e(Object.fromEntries(t)):t instanceof Object?Object.keys(t).reduce((e,r)=>(e[r]=$e(t[r]),e),{}):t}function pd(t){let e=new Map;return function(r,n){let i=e.get(this)+(Array.isArray(this)?`[${r}]`:`.${r}`);return n===Object(n)&&e.set(n,i),n instanceof RegExp&&(n=`#${n.source}`),t.call(this,r,n,i.replace(/undefined\.\.?/,""))}}function ct(...t){return pd((e,r,n)=>t.indexOf(n)!==-1?"******":r)}function dt(t){return JSON.stringify(t,Object.keys(t).sort(md))}function le(t){return!!t}var mo,md,ye=we(()=>{"use strict";mo=require("immer");md=(t,e)=>t.localeCompare(e)});function nm(t,e){for(let[r,n]of Object.entries(t)){let i=e[r];if(!je(n,i))return!1}return!0}function Ya(t,e){return Zr(t,e)}function Gt(t,e,r){let n=r?.publishers?.reduce((o,s)=>{if(nm(s.identity,t)){let a=s.metrics.block??s.metrics.blacklist??[];if(a.length>0&&Ya(a,e))return!1;{let c=s.metrics.allow??s.metrics.whitelist??[];return o||Ya(c,e)}}return o},void 0);if(n!==void 0)return n;let i=r?.non_matched??"allow";return i==="allow"||i==="whitelist"}var li=we(()=>{"use strict";Kt()});function ym(t){if(t&&Object.keys(t).length>0)return t}function ec(t){return typeof t=="object"?{value:Object.entries(t).reduce((r,[n,i])=>(r[n]=ec(i),r),{})}:typeof t=="string"?{value:t}:{value:t}}function fm(t){return{timestamp:t.timestamp??Date.now(),value:ec(t.value)}}function gm(t,e){return Array.from(t).reduce((r,n)=>{let i=e(n),o=r.get(i)??[];return o.length===0&&r.set(i,o),o.push(n),r},new Map)}function*St(t,e){Za.enabledFor("trace")&&Za.debug(`conflating ${JSON.stringify(e)}`);let r=gm(e,i=>dt(i.identity)),n;for(let[,i]of r){for(let o of i)if(o.status){let{identity:s,status:a,metadata:c}=o;n&&(yield n),yield{identity:s,status:a,metrics:void 0,metadata:ym(c)},n=void 0}else{let{metric:s,identity:a,datapoint:c}=o,d=s?.name;n||(n={identity:a}),n.metrics=n.metrics??{},n.metrics[d]=n.metrics[d]??{definition:{...s},datapoints:[]},delete n.metrics[d].definition.name,n.metrics[d].datapoints.push(fm(c))}n&&(yield n)}}var Za,_r=we(()=>{"use strict";$();ye();Za=g("gateway.metrics.common")});var nc={};Ee(nc,{NodeWorker:()=>bi});var tc,hi,rc,bi,ic=we(()=>{"use strict";tc=require("child_process"),hi=require("events"),rc=require("url"),bi=class{events=new hi.EventEmitter;ps;constructor(e,r,n){this.events=new hi.EventEmitter;let i=(0,rc.fileURLToPath)(e);this.ps=(0,tc.fork)(i,r,n),this.ps.on("message",o=>{let s;try{s=JSON.parse(o),s?.type===void 0&&this.events.emit("messageerror",new Error(`Invalid message: ${o}`))}catch(a){this.events.emit("messageerror",a);return}s.type==="error"?this.events.emit("error",new Error(s.message)):this.events.emit("message",{data:s.data})}),this.ps.stdout?.on("data",o=>{console.log(o)}),this.ps.stderr?.on("data",o=>{console.error(o)}),this.ps.on("error",o=>{this.events.emit("error",o)}),this.events.on("message",o=>{this.onmessage&&this.onmessage(o)}),this.events.on("error",o=>{this.onerror&&this.onerror(o)}),this.events.on("messageerror",o=>{this.onmessageerror&&this.onmessageerror(o)})}onerror=null;onmessage=null;onmessageerror=null;postMessage(e){this.ps.send({data:e},r=>{r&&this.events.emit("error",r)})}terminate(){this.ps.kill()}addEventListener(e,r,n){this.events.addListener(e,r)}removeEventListener(e,r,n){this.events.removeListener(e,r)}dispatchEvent(e){return this.events.emit(e.type,e)}}});async function hm(t,e,r){let{NodeWorker:n}=await Promise.resolve().then(()=>(ic(),nc)),i=Object.entries(e??{}).map(([o,s])=>`--${o}=${s}`);return new n(t,i,r)}async function bm(t,e,r){return Object.entries(e??{}).forEach(([n,i])=>t.searchParams.append(n,i)),new Worker(t,r)}function oc({url:t,parameters:e,options:r}){return typeof process<"u"?hm(t,e,r):bm(t,e,r)}var sc=we(()=>{"use strict"});function xi(t,e,r){let n={identity:t,status:{...e,"updated-at":e.updated,"expires-at":e.expires}};return r&&(n.metadata=r),n}async function wt(t,e,r){oe.info(`creating publisher with configuration
${JSON.stringify(t,ct("authentication.password"))}`);let n=t?.worker;if(n===void 0)throw new Error("in proc publishing is not supported. please provide worker configuration");let i=t?Object.fromEntries(Object.entries(t).filter(([o])=>o!=="worker")):{};try{return await xm(r,i,e,n)}catch(o){throw oe.error("Failed to create basic publisher",o),o}}async function xm(t,e,r,n){let i=new wi(await oc(n),e);await i.start(t);let o=s=>{for(let a of r([s]))i.next(a)};return o.close=async()=>{await i.stop()},o.on=s=>{i.on(s)},o}function It(t,e){return new Si(t,e)}var Or,vi,oe,Ri,Si,wi,Nr=we(()=>{"use strict";sc();Or=require("@interopio/gateway/logging/core"),vi=require("serialize-error");ye();li();oe=(0,Or.getLogger)("gateway.metrics.publisher");Ri=class{constructor(e,r,n,i,o){this.publisher=e;this.filters=r;this.repoId=n;this.heartbeatInterval=i;this.metadata=o}running=!0;latestStatus={initial:!0,stopped:!1,status:{state:0,updated:Date.now(),description:"Running"}};heartbeatCleanup;metrics=new Map;start(){oe.info(`starting repository for ${JSON.stringify(this.repoId)} with heartbeat interval ${this.heartbeatInterval}ms`);let e=Date.now();if(this.latestStatus.stopped&&(this.latestStatus.status.state=0,this.latestStatus.status.description="Running",this.latestStatus.status.updated=e,this.latestStatus.initial=!0,this.latestStatus.stopped=!1),this.heartbeatInterval>=0){let n={...this.latestStatus.status,timestamp:e,expires:e+3*this.heartbeatInterval},i=xi(this.repoId,n,this.metadata);this.publisher(i)}this.running=!0,this.heartbeatInterval>0&&(this.heartbeatCleanup=setInterval(()=>{if(!this.running)return;let r=Date.now(),i={...this.latestStatus.status,timestamp:r,expires:r+3*this.heartbeatInterval},o=xi(this.repoId,i,this.metadata);this.publisher(o)},this.heartbeatInterval))}stop(){oe.info(`stopping repository for ${JSON.stringify(this.repoId)}`),this.running=!1,this.heartbeatCleanup&&clearInterval(this.heartbeatCleanup);let e=Date.now();this.latestStatus.stopped=!0,this.status({state:-1,timestamp:e,updated:e,expires:e,description:"Repository Stopped"})}add(e){for(let r of e){let n=r.name;this.metrics.has(n)||!(this.filters===void 0||Gt(this.repoId,n,this.filters))||this.metrics.set(n,r)}}publish(e){if(this.running&&e.length>0)for(let r of e){let n=this.metrics.get(r.name);if(n){let i={identity:this.repoId,metric:n,datapoint:{...r}};delete i.datapoint.name,this.publisher(i)}}}status(e){let r={...this.latestStatus};Object.assign(r.status,e),r.timestamp=e.timestamp,r.expires=e.expires;let n=r.status.state!==this.latestStatus.status.state;if((this.latestStatus.initial||n)&&(r.status.updated=e.timestamp),r.initial=!1,Object.assign(this.latestStatus,r),this.running||r.stopped){let i=xi(this.repoId,e,this.metadata);this.publisher(i)}}},Si=class{constructor(e,r){this.config=e;this.publisher=r}repository(e,r){let n=r?.metadata,i=this.config?.heartbeats??0;return new Ri(this.publisher,this.config?.filters,e,i,n)}async shutdown(){await this.publisher.close()}on(e){this.publisher.on(e)}};wi=class{maxQueueSize;cfg;worker;lastId;processing;promises;listeners;constructor(e,r){let{buffer_size:n}=r;this.maxQueueSize=n??1e3,this.cfg=r,this.lastId=0,this.worker=e,this.processing=new Map,this.promises=new Map,this.listeners=[]}async start(e){await new Promise(r=>{this.worker.onerror=n=>{oe.error(`error from worker: ${n.message}`)},this.worker.onmessageerror=n=>{oe.error(`error receiving message: ${n.data}`)},this.worker.onmessage=n=>{if(n.data.ready){r();return}if(n.data.id){let{id:i,result:o,error:s}=n.data,a=this.processing.get(i);if(a){let{resolver:c}=a;try{s?c.reject((0,vi.deserializeError)(s)):c.resolve(o)}finally{this.processing.delete(i)}}else oe.error(`unknown message id: ${i}`)}else if(n.data.log){let{level:i,time:o,name:s,message:a,data:c}=n.data.log;(0,Or.logEvent)({level:i,time:new Date(o),name:s,message:a,data:c.map(d=>(0,vi.deserializeError)(d))})}else n.data.event&&this.listeners.forEach(i=>i(n.data.event))}});try{await this.enqueue("start",{cfg:this.cfg,publishFn:e})[1],oe.info(`publisher worker [${e}] started`)}catch(r){throw oe.error(`error starting publisher worker [${e}]: ${r}`),this.worker.terminate(),r}}enqueue(e,r){this.processing.size>=this.maxQueueSize&&oe.warn(`processing queue is full. dropping cmd: ${JSON.stringify(e)}`);let n=++this.lastId;return[n,new Promise((i,o)=>{this.processing.set(n,{resolver:{resolve:i,reject:o}});let s={id:n,cmd:e,arg:r};this.worker.postMessage(s)})]}next(e){let[r,n]=this.enqueue("update",e);n.catch(i=>{oe.warn(`update [${r}] error`,i)}).finally(()=>{this.promises.delete(r)})}async stop(e=!1,r=1e3){oe.info(`stopping publisher worker rejectProcessing: ${e}, timeout: ${r}, promises: ${this.promises.size}`);let n=i=>{this.processing.forEach(({resolver:o})=>{o.reject(new Error(`reject on stop: ${i}`))})};try{e&&n("now");let i=Promise.allSettled(this.promises),o=this.enqueue("stop",void 0)[1];await new Promise((s,a)=>{let c=setTimeout(()=>{n("timeout"),a(new Error("timeout"))},r);i.then(d=>{clearTimeout(c);for(let u of d)u.status==="rejected"&&oe.error(`Pending future failed with ${u.reason} on stop`);s()})}),await o,this.promises.size>0&&oe.error(`uncleared promises: ${this.promises.size}`),oe.info("publisher worker stopped")}finally{this.worker.terminate()}}on(e){this.listeners.push(e)}}});var dc={};Ee(dc,{restPublisher:()=>cc,restRepositoryFactory:()=>vm});async function cc(t){let e=t?.conflation?.["max-datapoints-repo"]??50;return await wt(t,r=>St(e,r),t?.publishFn??"@interopio/gateway/metrics/publisher/rest")}async function vm(t){return It(t,await cc(t))}var uc=we(()=>{"use strict";Nr();_r()});var pc={};Ee(pc,{fileRepositoryFactory:()=>wm});async function Sm(t){let e=t.conflation?.["max-datapoints-repo"]??50;return Rm.info(`will record metrics to ${t.location}`),await wt(t,r=>St(e??1,r),t?.publishFn??"@interopio/gateway/metrics/publisher/file")}async function wm(t){return It(t,await Sm(t))}var Rm,mc=we(()=>{"use strict";Nr();_r();$();Rm=g("gateway.metrics.file")});var ey={};Ee(ey,{IOGateway:()=>Hi,default:()=>Zl});module.exports=Yc(ey);var Hi={};Ee(Hi,{Encoding:()=>rt,Factory:()=>Fi,Filtering:()=>en,Logging:()=>Xr});var rt={};Ee(rt,{direct:()=>Yr,json:()=>Qr,transit:()=>zr});var Ie=Ji(require("transit-js"),1),Br=class{map;reverse=new Map;constructor(e){if(e)for(let[r,n]of e)this.reverse.set(n,r);else e=this.reverse;this.map=e}get(e){return this.map.get(e)}rev(e){return this.reverse.get(e)}};function ji(t,e){let r=t.indexOf("/");if(r===-1)return Ie.default.keyword(t);let n=t.substring(0,r),i=e?.get(n)??n;return Ie.default.keyword(i+t.substring(r))}function Wi(t,e){let r=t.name(),n=t.namespace();return n===null?r:(e.rev(n)??n)+"/"+r}function Ki(t,e,r,n=""){if(t instanceof Array)return t.map(i=>i);if(t instanceof Object){let i=Ie.default.map();for(let o in t){let s=r?.get(n),a=s===null?o:ji(o,e),c=t[o],d=`${n}/${o}`,u=r?.get(d);if(u!==void 0&&typeof c=="string"&&(u==="*"||u?.has(c)))i.set(a,ji(c,e));else{s===null&&!r?.has(d)&&r?.set(d,null);let m=Ki(c,e,r,d);i.set(a,m)}}return i}else return t}function Kr(t,e){if(Ie.default.isKeyword(t))return Wi(t,e);if(Ie.default.isMap(t)){let r={};for(let[n,i]of t){let o=Ie.default.isKeyword(n)?Wi(n,e):n;r[o]=Kr(i,e)}return r}else if(Ie.default.isList(t)||t instanceof Array){let r=[];for(let n of t)r.push(Kr(n,e));return r}return t}function zr(t){let e=t?.verbose?"json-verbose":"json",r=new Br(t?.namespaces);return{encode:n=>{let i=Ki(n,r,t?.keywordize);return Ie.default.writer(e).write(i)},decode:n=>{let i;try{i=Ie.default.reader(e).read(n)}catch(o){throw new Error(`"${n}" is not valid TRANSIT`,{cause:o})}return Kr(i,r)}}}function Qr(){return{encode:JSON.stringify,decode:JSON.parse}}function Bi(t){return t}function Vr(t){return t instanceof Array||Array.isArray(t)?t.map(Vr):t?.constructor===Object?Object.keys(t).reduce((e,r)=>(e[r]=Vr(t[r]),e),{}):t===void 0?null:t}function Yr(t){return{encode:Bi,decode:t?.cljs??!1?Vr:Bi}}var Xr={};Ee(Xr,{ROOT_LOGGER_NAME:()=>it,configure:()=>ed,getLogger:()=>Xi,logEvent:()=>Xc});var nt=(a=>(a[a.off=0]="off",a[a.error=200]="error",a[a.warn=300]="warn",a[a.info=400]="info",a[a.debug=500]="debug",a[a.trace=600]="trace",a[a.all=Number.MAX_SAFE_INTEGER]="all",a))(nt||{}),Vi=Object.create(null),Te={},it="gateway";Te[it]=600;var Wt=t=>{console[t.level](`${t.time.toISOString()} ${t.level.toUpperCase()} [${t.name}] - ${t.message}`,...t.data)};function Xc(t){let{name:e,level:r}=t;Yi(e),Qi(r,e)&&Wt(t)}function zi(t,e,r,...n){this.enabledFor(e)&&Wt({time:new Date,level:e,name:t,message:r,data:n})}function Qi(t,e){let r=nt[t];return Te[e]>=r}function Zc(t){Yi(t);let e=function(n,i,...o){zi.call(e,t,n,i,...o)};function r(n){return isNaN(Number(n))}for(let n of Object.keys(nt).filter(r))e[n]=function(i,...o){zi.call(e,t,n,i,...o)};return e.enabledFor=function(n){return Qi(n,t)},e.child=function(n){return Xi(`${t}.${n}`)},e}function Yi(t){if(!t.startsWith(it))throw new Error(`Logger name must start with ${it}`);if(!Te[t]){let e=Object.entries(Te).sort(([n],[i])=>i.localeCompare(n)),[,r]=e.find(([n])=>t.startsWith(n));Te[t]=r}}function Xi(t){let e=Vi[t];return e===void 0&&(e=Zc(t),Vi[t]=e),e}function ed(t){function e(n,i){for(let o of Object.keys(Te).filter(s=>s.startsWith(n)))Te[o]=nt[i];Te[n]===void 0&&(Te[n]=nt[i])}let r=t.level;if(typeof r=="string")Te[it]=nt[r],e(it,r);else if(typeof r=="object"){let n=Object.entries(r).sort(([i],[o])=>i.localeCompare(o));for(let[i,o]of n)e(i,o)}Wt=t.appender??Wt}Kt();$();var Ae="global",ot="context",Ue=`${Ae}.errors.failure`;$();function b(t,e){return{receiver:t,body:e}}function G(t,e){return{...b({type:"cluster"},e),source:t}}function W(t,e,r){return{...b(e,r),source:t}}function id(t,e,r,n,i){let o={type:"error",request_id:e,reason_uri:n.uri,reason:n.message};return t&&(o.domain=t),r&&(o.peer_id=r),i&&(o.context=i),o}function h(t,e,r,n,i,o){return b(e,id(t,r,n,i,o))}function od(t,e,r){return{type:"success",request_id:e,domain:t,peer_id:r}}function T(t,e,r,n){return b(e,od(t,r,n))}function A(t){let e=t.type;return e&&e==="local"}function F(t){return!A(t)}function sd(t,e,r,n){return{domain:t,type:"token",request_id:e,peer_id:r,token:n}}function to(t,e,r,n,i){return b(e,sd(t,r,n,i))}function ad(t,e,r,n,i){return{domain:t,type:"peer-added",peer_id:e,new_peer_id:r,identity:n,meta:i}}function We(t,e,r,n,i,o){return b(e,ad(t,r,n,i,o))}function cd(t,e,r,n){return{domain:t,type:"peer-removed",peer_id:e,removed_id:r,reason_uri:n.uri,reason:n.message}}function Be(t,e,r,n,i){return b(e,cd(t,r,n,i))}var Ce=class extends Error{data;cause;constructor(e,r,n){super(e),this.name="ExceptionInfo",this.data=r,this.cause=n}};function B(t,e,r){return new Ce(t,e,r)}function Ke(t){if(t instanceof Ce)return t.data}function Ve(t){if(t instanceof Error)return t.message}function x(t,e){return{uri:t,message:e}}function H(t,e){let r=Ke(t);return{uri:r?.uri??e,message:r?.message??Ve(t)??""}}function k(t,e){let r={uri:t,message:e};throw new Ce(e,r)}function V(t){return{uri:t.reason_uri,message:t.reason}}var Zt=require("antlr4");var I=require("antlr4"),P=class t extends I.Parser{static OR=1;static AND=2;static EQ=3;static NEQ=4;static MATCH=5;static LPAREN=6;static RPAREN=7;static DOLLAR=8;static POUND=9;static STR=10;static WORD=11;static NUMBER=12;static WS=13;static EOF=I.Token.EOF;static RULE_parse=0;static RULE_expr=1;static RULE_andOr=2;static RULE_eqNeq=3;static RULE_term=4;static RULE_ident=5;static RULE_ownIdent=6;static RULE_str=7;static RULE_word=8;static RULE_number=9;static literalNames=[null,"'||'","'&&'","'=='","'!='","'?'","'('","')'","'$'","'#'"];static symbolicNames=[null,"OR","AND","EQ","NEQ","MATCH","LPAREN","RPAREN","DOLLAR","POUND","STR","WORD","NUMBER","WS"];static ruleNames=["parse","expr","andOr","eqNeq","term","ident","ownIdent","str","word","number"];get grammarFileName(){return"Restrictions.g4"}get literalNames(){return t.literalNames}get symbolicNames(){return t.symbolicNames}get ruleNames(){return t.ruleNames}get serializedATN(){return t._serializedATN}createFailedPredicateException(e,r){return new I.FailedPredicateException(this,e,r)}constructor(e){super(e),this._interp=new I.ParserATNSimulator(this,t._ATN,t.DecisionsToDFA,new I.PredictionContextCache)}parse(){let e=new tn(this,this._ctx,this.state);this.enterRule(e,0,t.RULE_parse);try{this.enterOuterAlt(e,1),this.state=20,this.expr(),this.state=21,this.match(t.EOF)}catch(r){if(r instanceof I.RecognitionException)e.exception=r,this._errHandler.reportError(this,r),this._errHandler.recover(this,r);else throw r}finally{this.exitRule()}return e}expr(){let e=new Vt(this,this._ctx,this.state);this.enterRule(e,2,t.RULE_expr);try{this.enterOuterAlt(e,1),this.state=23,this.andOr(0)}catch(r){if(r instanceof I.RecognitionException)e.exception=r,this._errHandler.reportError(this,r),this._errHandler.recover(this,r);else throw r}finally{this.exitRule()}return e}andOr(e){e===void 0&&(e=0);let r=this._ctx,n=this.state,i=new he(this,this._ctx,n),o=i,s=4;this.enterRecursionRule(i,4,t.RULE_andOr,e);try{let a;for(this.enterOuterAlt(i,1),i=new rn(this,i),this._ctx=i,o=i,this.state=26,this.eqNeq(0),this._ctx.stop=this._input.LT(-1),this.state=36,this._errHandler.sync(this),a=this._interp.adaptivePredict(this._input,1,this._ctx);a!==2&&a!==I.ATN.INVALID_ALT_NUMBER;){if(a===1)switch(this._parseListeners!=null&&this.triggerExitRuleEvent(),o=i,this.state=34,this._errHandler.sync(this),this._interp.adaptivePredict(this._input,0,this._ctx)){case 1:{if(i=new on(this,new he(this,r,n)),this.pushNewRecursionContext(i,s,t.RULE_andOr),this.state=28,!this.precpred(this._ctx,2))throw this.createFailedPredicateException("this.precpred(this._ctx, 2)");this.state=29,this.match(t.AND),this.state=30,this.eqNeq(0)}break;case 2:{if(i=new nn(this,new he(this,r,n)),this.pushNewRecursionContext(i,s,t.RULE_andOr),this.state=31,!this.precpred(this._ctx,1))throw this.createFailedPredicateException("this.precpred(this._ctx, 1)");this.state=32,this.match(t.OR),this.state=33,this.eqNeq(0)}break}this.state=38,this._errHandler.sync(this),a=this._interp.adaptivePredict(this._input,1,this._ctx)}}catch(a){if(a instanceof I.RecognitionException)i.exception=a,this._errHandler.reportError(this,a),this._errHandler.recover(this,a);else throw a}finally{this.unrollRecursionContexts(r)}return i}eqNeq(e){e===void 0&&(e=0);let r=this._ctx,n=this.state,i=new Q(this,this._ctx,n),o=i,s=6;this.enterRecursionRule(i,6,t.RULE_eqNeq,e);try{let a;for(this.enterOuterAlt(i,1),i=new dn(this,i),this._ctx=i,o=i,this.state=40,this.term(),this._ctx.stop=this._input.LT(-1),this.state=53,this._errHandler.sync(this),a=this._interp.adaptivePredict(this._input,3,this._ctx);a!==2&&a!==I.ATN.INVALID_ALT_NUMBER;){if(a===1)switch(this._parseListeners!=null&&this.triggerExitRuleEvent(),o=i,this.state=51,this._errHandler.sync(this),this._interp.adaptivePredict(this._input,2,this._ctx)){case 1:{if(i=new cn(this,new Q(this,r,n)),this.pushNewRecursionContext(i,s,t.RULE_eqNeq),this.state=42,!this.precpred(this._ctx,3))throw this.createFailedPredicateException("this.precpred(this._ctx, 3)");this.state=43,this.match(t.EQ),this.state=44,this.term()}break;case 2:{if(i=new an(this,new Q(this,r,n)),this.pushNewRecursionContext(i,s,t.RULE_eqNeq),this.state=45,!this.precpred(this._ctx,2))throw this.createFailedPredicateException("this.precpred(this._ctx, 2)");this.state=46,this.match(t.NEQ),this.state=47,this.term()}break;case 3:{if(i=new sn(this,new Q(this,r,n)),this.pushNewRecursionContext(i,s,t.RULE_eqNeq),this.state=48,!this.precpred(this._ctx,1))throw this.createFailedPredicateException("this.precpred(this._ctx, 1)");this.state=49,this.match(t.MATCH),this.state=50,this.term()}break}this.state=55,this._errHandler.sync(this),a=this._interp.adaptivePredict(this._input,3,this._ctx)}}catch(a){if(a instanceof I.RecognitionException)i.exception=a,this._errHandler.reportError(this,a),this._errHandler.recover(this,a);else throw a}finally{this.unrollRecursionContexts(r)}return i}term(){let e=new ze(this,this._ctx,this.state);this.enterRule(e,8,t.RULE_term);try{switch(this.enterOuterAlt(e,1),this.state=64,this._errHandler.sync(this),this._interp.adaptivePredict(this._input,4,this._ctx)){case 1:this.state=56,this.ident();break;case 2:this.state=57,this.ownIdent();break;case 3:this.state=58,this.number_();break;case 4:this.state=59,this.str();break;case 5:this.state=60,this.match(t.LPAREN),this.state=61,this.andOr(0),this.state=62,this.match(t.RPAREN);break}}catch(r){if(r instanceof I.RecognitionException)e.exception=r,this._errHandler.reportError(this,r),this._errHandler.recover(this,r);else throw r}finally{this.exitRule()}return e}ident(){let e=new zt(this,this._ctx,this.state);this.enterRule(e,10,t.RULE_ident);try{this.enterOuterAlt(e,1),this.state=66,this.match(t.DOLLAR),this.state=67,this.word()}catch(r){if(r instanceof I.RecognitionException)e.exception=r,this._errHandler.reportError(this,r),this._errHandler.recover(this,r);else throw r}finally{this.exitRule()}return e}ownIdent(){let e=new Qt(this,this._ctx,this.state);this.enterRule(e,12,t.RULE_ownIdent);try{this.enterOuterAlt(e,1),this.state=69,this.match(t.POUND),this.state=70,this.word()}catch(r){if(r instanceof I.RecognitionException)e.exception=r,this._errHandler.reportError(this,r),this._errHandler.recover(this,r);else throw r}finally{this.exitRule()}return e}str(){let e=new Yt(this,this._ctx,this.state);this.enterRule(e,14,t.RULE_str);let r;try{this.enterOuterAlt(e,1);{for(this.state=75,this._errHandler.sync(this),r=this._input.LA(1);r===13;)this.state=72,this.match(t.WS),this.state=77,this._errHandler.sync(this),r=this._input.LA(1);this.state=78,this.match(t.STR)}}catch(n){if(n instanceof I.RecognitionException)e.exception=n,this._errHandler.reportError(this,n),this._errHandler.recover(this,n);else throw n}finally{this.exitRule()}return e}word(){let e=new Ct(this,this._ctx,this.state);this.enterRule(e,16,t.RULE_word);try{this.enterOuterAlt(e,1),this.state=80,this.match(t.WORD)}catch(r){if(r instanceof I.RecognitionException)e.exception=r,this._errHandler.reportError(this,r),this._errHandler.recover(this,r);else throw r}finally{this.exitRule()}return e}number_(){let e=new Xt(this,this._ctx,this.state);this.enterRule(e,18,t.RULE_number);let r;try{this.enterOuterAlt(e,1);{for(this.state=85,this._errHandler.sync(this),r=this._input.LA(1);r===13;)this.state=82,this.match(t.WS),this.state=87,this._errHandler.sync(this),r=this._input.LA(1);this.state=88,this.match(t.NUMBER)}}catch(n){if(n instanceof I.RecognitionException)e.exception=n,this._errHandler.reportError(this,n),this._errHandler.recover(this,n);else throw n}finally{this.exitRule()}return e}sempred(e,r,n){switch(r){case 2:return this.andOr_sempred(e,n);case 3:return this.eqNeq_sempred(e,n)}return!0}andOr_sempred(e,r){switch(r){case 0:return this.precpred(this._ctx,2);case 1:return this.precpred(this._ctx,1)}return!0}eqNeq_sempred(e,r){switch(r){case 2:return this.precpred(this._ctx,3);case 3:return this.precpred(this._ctx,2);case 4:return this.precpred(this._ctx,1)}return!0}static _serializedATN=[4,1,13,91,2,0,7,0,2,1,7,1,2,2,7,2,2,3,7,3,2,4,7,4,2,5,7,5,2,6,7,6,2,7,7,7,2,8,7,8,2,9,7,9,1,0,1,0,1,0,1,1,1,1,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,1,2,5,2,35,8,2,10,2,12,2,38,9,2,1,3,1,3,1,3,1,3,1,3,1,3,1,3,1,3,1,3,1,3,1,3,1,3,5,3,52,8,3,10,3,12,3,55,9,3,1,4,1,4,1,4,1,4,1,4,1,4,1,4,1,4,3,4,65,8,4,1,5,1,5,1,5,1,6,1,6,1,6,1,7,5,7,74,8,7,10,7,12,7,77,9,7,1,7,1,7,1,8,1,8,1,9,5,9,84,8,9,10,9,12,9,87,9,9,1,9,1,9,1,9,0,2,4,6,10,0,2,4,6,8,10,12,14,16,18,0,0,91,0,20,1,0,0,0,2,23,1,0,0,0,4,25,1,0,0,0,6,39,1,0,0,0,8,64,1,0,0,0,10,66,1,0,0,0,12,69,1,0,0,0,14,75,1,0,0,0,16,80,1,0,0,0,18,85,1,0,0,0,20,21,3,2,1,0,21,22,5,0,0,1,22,1,1,0,0,0,23,24,3,4,2,0,24,3,1,0,0,0,25,26,6,2,-1,0,26,27,3,6,3,0,27,36,1,0,0,0,28,29,10,2,0,0,29,30,5,2,0,0,30,35,3,6,3,0,31,32,10,1,0,0,32,33,5,1,0,0,33,35,3,6,3,0,34,28,1,0,0,0,34,31,1,0,0,0,35,38,1,0,0,0,36,34,1,0,0,0,36,37,1,0,0,0,37,5,1,0,0,0,38,36,1,0,0,0,39,40,6,3,-1,0,40,41,3,8,4,0,41,53,1,0,0,0,42,43,10,3,0,0,43,44,5,3,0,0,44,52,3,8,4,0,45,46,10,2,0,0,46,47,5,4,0,0,47,52,3,8,4,0,48,49,10,1,0,0,49,50,5,5,0,0,50,52,3,8,4,0,51,42,1,0,0,0,51,45,1,0,0,0,51,48,1,0,0,0,52,55,1,0,0,0,53,51,1,0,0,0,53,54,1,0,0,0,54,7,1,0,0,0,55,53,1,0,0,0,56,65,3,10,5,0,57,65,3,12,6,0,58,65,3,18,9,0,59,65,3,14,7,0,60,61,5,6,0,0,61,62,3,4,2,0,62,63,5,7,0,0,63,65,1,0,0,0,64,56,1,0,0,0,64,57,1,0,0,0,64,58,1,0,0,0,64,59,1,0,0,0,64,60,1,0,0,0,65,9,1,0,0,0,66,67,5,8,0,0,67,68,3,16,8,0,68,11,1,0,0,0,69,70,5,9,0,0,70,71,3,16,8,0,71,13,1,0,0,0,72,74,5,13,0,0,73,72,1,0,0,0,74,77,1,0,0,0,75,73,1,0,0,0,75,76,1,0,0,0,76,78,1,0,0,0,77,75,1,0,0,0,78,79,5,10,0,0,79,15,1,0,0,0,80,81,5,11,0,0,81,17,1,0,0,0,82,84,5,13,0,0,83,82,1,0,0,0,84,87,1,0,0,0,85,83,1,0,0,0,85,86,1,0,0,0,86,88,1,0,0,0,87,85,1,0,0,0,88,89,5,12,0,0,89,19,1,0,0,0,7,34,36,51,53,64,75,85];static __ATN;static get _ATN(){return t.__ATN||(t.__ATN=new I.ATNDeserializer().deserialize(t._serializedATN)),t.__ATN}static DecisionsToDFA=t._ATN.decisionToState.map((e,r)=>new I.DFA(e,r))},tn=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}expr(){return this.getTypedRuleContext(Vt,0)}EOF(){return this.getToken(P.EOF,0)}get ruleIndex(){return P.RULE_parse}enterRule(e){e.enterParse&&e.enterParse(this)}exitRule(e){e.exitParse&&e.exitParse(this)}accept(e){return e.visitParse?e.visitParse(this):e.visitChildren(this)}},Vt=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}andOr(){return this.getTypedRuleContext(he,0)}get ruleIndex(){return P.RULE_expr}enterRule(e){e.enterExpr&&e.enterExpr(this)}exitRule(e){e.exitExpr&&e.exitExpr(this)}accept(e){return e.visitExpr?e.visitExpr(this):e.visitChildren(this)}},he=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}get ruleIndex(){return P.RULE_andOr}copyFrom(e){super.copyFrom(e)}},rn=class extends he{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}eqNeq(){return this.getTypedRuleContext(Q,0)}enterRule(e){e.enterAndOrEqNeq&&e.enterAndOrEqNeq(this)}exitRule(e){e.exitAndOrEqNeq&&e.exitAndOrEqNeq(this)}accept(e){return e.visitAndOrEqNeq?e.visitAndOrEqNeq(this):e.visitChildren(this)}},nn=class extends he{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}andOr(){return this.getTypedRuleContext(he,0)}OR(){return this.getToken(P.OR,0)}eqNeq(){return this.getTypedRuleContext(Q,0)}enterRule(e){e.enterOr&&e.enterOr(this)}exitRule(e){e.exitOr&&e.exitOr(this)}accept(e){return e.visitOr?e.visitOr(this):e.visitChildren(this)}},on=class extends he{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}andOr(){return this.getTypedRuleContext(he,0)}AND(){return this.getToken(P.AND,0)}eqNeq(){return this.getTypedRuleContext(Q,0)}enterRule(e){e.enterAnd&&e.enterAnd(this)}exitRule(e){e.exitAnd&&e.exitAnd(this)}accept(e){return e.visitAnd?e.visitAnd(this):e.visitChildren(this)}},Q=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}get ruleIndex(){return P.RULE_eqNeq}copyFrom(e){super.copyFrom(e)}},sn=class extends Q{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}eqNeq(){return this.getTypedRuleContext(Q,0)}MATCH(){return this.getToken(P.MATCH,0)}term(){return this.getTypedRuleContext(ze,0)}enterRule(e){e.enterMatch&&e.enterMatch(this)}exitRule(e){e.exitMatch&&e.exitMatch(this)}accept(e){return e.visitMatch?e.visitMatch(this):e.visitChildren(this)}},an=class extends Q{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}eqNeq(){return this.getTypedRuleContext(Q,0)}NEQ(){return this.getToken(P.NEQ,0)}term(){return this.getTypedRuleContext(ze,0)}enterRule(e){e.enterNeq&&e.enterNeq(this)}exitRule(e){e.exitNeq&&e.exitNeq(this)}accept(e){return e.visitNeq?e.visitNeq(this):e.visitChildren(this)}},cn=class extends Q{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}eqNeq(){return this.getTypedRuleContext(Q,0)}EQ(){return this.getToken(P.EQ,0)}term(){return this.getTypedRuleContext(ze,0)}enterRule(e){e.enterEq&&e.enterEq(this)}exitRule(e){e.exitEq&&e.exitEq(this)}accept(e){return e.visitEq?e.visitEq(this):e.visitChildren(this)}},dn=class extends Q{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}term(){return this.getTypedRuleContext(ze,0)}enterRule(e){e.enterEqNeqTerm&&e.enterEqNeqTerm(this)}exitRule(e){e.exitEqNeqTerm&&e.exitEqNeqTerm(this)}accept(e){return e.visitEqNeqTerm?e.visitEqNeqTerm(this):e.visitChildren(this)}},ze=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}ident(){return this.getTypedRuleContext(zt,0)}ownIdent(){return this.getTypedRuleContext(Qt,0)}number_(){return this.getTypedRuleContext(Xt,0)}str(){return this.getTypedRuleContext(Yt,0)}LPAREN(){return this.getToken(P.LPAREN,0)}andOr(){return this.getTypedRuleContext(he,0)}RPAREN(){return this.getToken(P.RPAREN,0)}get ruleIndex(){return P.RULE_term}enterRule(e){e.enterTerm&&e.enterTerm(this)}exitRule(e){e.exitTerm&&e.exitTerm(this)}accept(e){return e.visitTerm?e.visitTerm(this):e.visitChildren(this)}},zt=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}DOLLAR(){return this.getToken(P.DOLLAR,0)}word(){return this.getTypedRuleContext(Ct,0)}get ruleIndex(){return P.RULE_ident}enterRule(e){e.enterIdent&&e.enterIdent(this)}exitRule(e){e.exitIdent&&e.exitIdent(this)}accept(e){return e.visitIdent?e.visitIdent(this):e.visitChildren(this)}},Qt=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}POUND(){return this.getToken(P.POUND,0)}word(){return this.getTypedRuleContext(Ct,0)}get ruleIndex(){return P.RULE_ownIdent}enterRule(e){e.enterOwnIdent&&e.enterOwnIdent(this)}exitRule(e){e.exitOwnIdent&&e.exitOwnIdent(this)}accept(e){return e.visitOwnIdent?e.visitOwnIdent(this):e.visitChildren(this)}},Yt=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}STR(){return this.getToken(P.STR,0)}WS_list(){return this.getTokens(P.WS)}WS(e){return this.getToken(P.WS,e)}get ruleIndex(){return P.RULE_str}enterRule(e){e.enterStr&&e.enterStr(this)}exitRule(e){e.exitStr&&e.exitStr(this)}accept(e){return e.visitStr?e.visitStr(this):e.visitChildren(this)}},Ct=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}WORD(){return this.getToken(P.WORD,0)}get ruleIndex(){return P.RULE_word}enterRule(e){e.enterWord&&e.enterWord(this)}exitRule(e){e.exitWord&&e.exitWord(this)}accept(e){return e.visitWord?e.visitWord(this):e.visitChildren(this)}},Xt=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}NUMBER(){return this.getToken(P.NUMBER,0)}WS_list(){return this.getTokens(P.WS)}WS(e){return this.getToken(P.WS,e)}get ruleIndex(){return P.RULE_number}enterRule(e){e.enterNumber&&e.enterNumber(this)}exitRule(e){e.exitNumber&&e.exitNumber(this)}accept(e){return e.visitNumber?e.visitNumber(this):e.visitChildren(this)}};var be=require("antlr4"),Mt=class t extends be.Lexer{static OR=1;static AND=2;static EQ=3;static NEQ=4;static MATCH=5;static LPAREN=6;static RPAREN=7;static DOLLAR=8;static POUND=9;static STR=10;static WORD=11;static NUMBER=12;static WS=13;static EOF=be.Token.EOF;static channelNames=["DEFAULT_TOKEN_CHANNEL","HIDDEN"];static literalNames=[null,"'||'","'&&'","'=='","'!='","'?'","'('","')'","'$'","'#'"];static symbolicNames=[null,"OR","AND","EQ","NEQ","MATCH","LPAREN","RPAREN","DOLLAR","POUND","STR","WORD","NUMBER","WS"];static modeNames=["DEFAULT_MODE"];static ruleNames=["OR","AND","EQ","NEQ","MATCH","LPAREN","RPAREN","DOLLAR","POUND","STR","WORD","NUMBER","WS"];constructor(e){super(e),this._interp=new be.LexerATNSimulator(this,t._ATN,t.DecisionsToDFA,new be.PredictionContextCache)}get grammarFileName(){return"Restrictions.g4"}get literalNames(){return t.literalNames}get symbolicNames(){return t.symbolicNames}get ruleNames(){return t.ruleNames}get serializedATN(){return t._serializedATN}get channelNames(){return t.channelNames}get modeNames(){return t.modeNames}static _serializedATN=[4,0,13,86,6,-1,2,0,7,0,2,1,7,1,2,2,7,2,2,3,7,3,2,4,7,4,2,5,7,5,2,6,7,6,2,7,7,7,2,8,7,8,2,9,7,9,2,10,7,10,2,11,7,11,2,12,7,12,1,0,1,0,1,0,1,1,1,1,1,1,1,2,1,2,1,2,1,3,1,3,1,3,1,4,1,4,1,5,1,5,1,6,1,6,1,7,1,7,1,8,1,8,1,9,1,9,4,9,52,8,9,11,9,12,9,53,1,9,1,9,1,10,4,10,59,8,10,11,10,12,10,60,1,11,3,11,64,8,11,1,11,5,11,67,8,11,10,11,12,11,70,9,11,1,11,3,11,73,8,11,1,11,4,11,76,8,11,11,11,12,11,77,1,12,4,12,81,8,12,11,12,12,12,82,1,12,1,12,0,0,13,1,1,3,2,5,3,7,4,9,5,11,6,13,7,15,8,17,9,19,10,21,11,23,12,25,13,1,0,5,1,0,39,39,4,0,45,45,65,90,95,95,97,122,2,0,43,43,45,45,1,0,48,57,2,0,9,9,32,32,92,0,1,1,0,0,0,0,3,1,0,0,0,0,5,1,0,0,0,0,7,1,0,0,0,0,9,1,0,0,0,0,11,1,0,0,0,0,13,1,0,0,0,0,15,1,0,0,0,0,17,1,0,0,0,0,19,1,0,0,0,0,21,1,0,0,0,0,23,1,0,0,0,0,25,1,0,0,0,1,27,1,0,0,0,3,30,1,0,0,0,5,33,1,0,0,0,7,36,1,0,0,0,9,39,1,0,0,0,11,41,1,0,0,0,13,43,1,0,0,0,15,45,1,0,0,0,17,47,1,0,0,0,19,49,1,0,0,0,21,58,1,0,0,0,23,63,1,0,0,0,25,80,1,0,0,0,27,28,5,124,0,0,28,29,5,124,0,0,29,2,1,0,0,0,30,31,5,38,0,0,31,32,5,38,0,0,32,4,1,0,0,0,33,34,5,61,0,0,34,35,5,61,0,0,35,6,1,0,0,0,36,37,5,33,0,0,37,38,5,61,0,0,38,8,1,0,0,0,39,40,5,63,0,0,40,10,1,0,0,0,41,42,5,40,0,0,42,12,1,0,0,0,43,44,5,41,0,0,44,14,1,0,0,0,45,46,5,36,0,0,46,16,1,0,0,0,47,48,5,35,0,0,48,18,1,0,0,0,49,51,7,0,0,0,50,52,8,0,0,0,51,50,1,0,0,0,52,53,1,0,0,0,53,51,1,0,0,0,53,54,1,0,0,0,54,55,1,0,0,0,55,56,7,0,0,0,56,20,1,0,0,0,57,59,7,1,0,0,58,57,1,0,0,0,59,60,1,0,0,0,60,58,1,0,0,0,60,61,1,0,0,0,61,22,1,0,0,0,62,64,7,2,0,0,63,62,1,0,0,0,63,64,1,0,0,0,64,68,1,0,0,0,65,67,7,3,0,0,66,65,1,0,0,0,67,70,1,0,0,0,68,66,1,0,0,0,68,69,1,0,0,0,69,72,1,0,0,0,70,68,1,0,0,0,71,73,9,0,0,0,72,71,1,0,0,0,72,73,1,0,0,0,73,75,1,0,0,0,74,76,7,3,0,0,75,74,1,0,0,0,76,77,1,0,0,0,77,75,1,0,0,0,77,78,1,0,0,0,78,24,1,0,0,0,79,81,7,4,0,0,80,79,1,0,0,0,81,82,1,0,0,0,82,80,1,0,0,0,82,83,1,0,0,0,83,84,1,0,0,0,84,85,6,12,0,0,85,26,1,0,0,0,8,0,53,60,63,68,72,77,82,1,6,0,0];static __ATN;static get _ATN(){return t.__ATN||(t.__ATN=new be.ATNDeserializer().deserialize(t._serializedATN)),t.__ATN}static DecisionsToDFA=t._ATN.decisionToState.map((e,r)=>new be.DFA(e,r))};var no=require("antlr4"),Pt=class extends no.ParseTreeVisitor{visitParse;visitExpr;visitAndOrEqNeq;visitOr;visitAnd;visitMatch;visitNeq;visitEq;visitEqNeqTerm;visitTerm;visitIdent;visitOwnIdent;visitStr;visitWord;visitNumber};var q=new Pt,st=t=>{let e=q.visitChildren(t);return e.length==1?e[0]:e};q.visitParse=t=>t.expr().accept(q);q.visitExpr=t=>["expr",st(t)];q.visitAndOrEqNeq=st;q.visitEqNeqTerm=st;q.visitTerm=t=>t.getChildCount()===3?q.visit(t.getChild(1)):st(t);q.visitEq=t=>{let e=st(t.eqNeq()),r=t.term().accept(q);return["eq",e,r]};q.visitNeq=t=>{let e=st(t.eqNeq()),r=t.term().accept(q);return["neq",e,r]};q.visitMatch=t=>["match",q.visitChildren(t.eqNeq())[0],t.term().accept(q)];q.visitAnd=t=>{let e=q.visitChildren(t.andOr()),r=q.visitChildren(t.eqNeq());return["and",e[0],r[0]]};q.visitIdent=t=>["ident",t.word().accept(q)];q.visitOwnIdent=t=>["own-ident",t.word().accept(q)];q.visitWord=t=>["word",t.WORD().symbol.text];q.visitNumber=t=>["number",t.NUMBER().symbol.text];q.visitStr=t=>["str",t.STR().symbol.text.slice(1,-1)];var io=q;function oo(t){let e=Zt.CharStreams.fromString(t),r=new Mt(e),n=new Zt.CommonTokenStream(r);return new P(n).parse().accept(io)}function un(t,e){if(Array.isArray(e)){let[r,...n]=e,i=t[r];if(i){let s=n.map(a=>un(t,a));return i.apply(t,s)}let o=n.map(s=>un(t,s));return[r].concat(o)}return e}function so(t,e,r){return(t?.length??0)>0?un({and:(n,i)=>n&&i,or:(n,i)=>n||i,eq:(n,i)=>n===i,neq:(n,i)=>n!==i,match:(n,i)=>i&&n?new RegExp(i).test(n):n,str(n){return n},number:n=>JSON.parse(n),expr:n=>n,"own-ident":([n,i])=>e[i],ident([n,i]){return r[i]}},t):!0}function Y(t){return typeof t=="string"?t==="cluster"||t==="local"?t:oo(t):t}function X(t,e,r){let[n,i]=e,[o,s]=r;switch(t){case"local":{if(n){if(n.type==="local")return o?.type==="local";if(n.type==="peer")return o?.type==="peer"?o?.node===n?.node:!1}else return o===void 0||o.type==="local";return!0}case"cluster":return!0;default:return o?.type==="cluster"?!0:!!so(t,i,s)}}if(globalThis.crypto===void 0)throw new Error("Crypto API is not available. If Running Node 18, try --experimental-global-webcrypto.");function Oe(){return globalThis.crypto.randomUUID().replaceAll("-","")}function C(t){return t?t.nodeId:Oe()}function Ne(t){let e=t.currentId??1,r=`r-${t.nodeId}-${e}`;return[{...t,currentId:e+1},r]}function ao(t){let e=t.currentId??1,r=`i-${t.nodeId}-${e}`;return[{...t,currentId:e+1},r]}function er(t){let e=t.currentId??1,r=`c-${t.nodeId}-${e}`;return[{...t,currentId:e+1},r]}function co(t){let e=t.currentId??1,r=`a-${t.nodeId}-${e}`;return[{...t,currentId:e+1},r]}function uo(t){let e=t.currentId??1,r=`p-${t.nodeId}-${e}`;return[{...t,currentId:e+1},r]}var Qe=require("immer");(0,Qe.enableMapSet)();function tr(t,e){let r=e??Oe();return{ids:{nodeId:t,currentId:1},signatureKey:r}}function ve(t,e,r,n){return(0,Qe.produce)(t,i=>{i.peers[e][r]=n?{restrictions:n}:{},i.domains=i.domains||{},i.domains[r]=i.domains[r]||new Set,i.domains[r].add(e)})}function Z(t,e,r){return(0,Qe.produce)(t,n=>{n.peers&&delete n.peers[e][r],n.domains&&n.domains[r]&&n.domains[r].delete(e)})}function pe(t,e,r){return!!t.domains?.[r]?.has(e)}function po(t,e){return!!t[e]}function mn(t,e,r){return e?(0,Qe.produce)(t,n=>{n.gatewayRequests=n.gatewayRequests||{},n.gatewayRequests[e]=r}):t}function at(t,e){return(0,Qe.produce)({state:t},r=>{r.state.gatewayRequests&&(r.removed=r.state.gatewayRequests[e],delete r.state.gatewayRequests[e],Object.keys(r.state.gatewayRequests).length===0&&delete r.state.gatewayRequests)})}function Dt(t,e){return t.registeredDomains?.[e]?.domain}function me(t,...e){return e.reduce(([r,n],i)=>{let[o,s]=i(r);return[o,n.concat(s)]},[t,[]])}var xe=require("immer");ye();function go(t,e){switch(e.type){case"node":return e.node===t.node;case"peer":return e.node===t.node&&e.peer===t.peer;case"local":return e.receive===t.receive;default:return!1}}function Me(t,e,r){return te(t,r).filter(n=>go(n.source,e))}function ho(t,e){return ld(t).filter(r=>go(r.source,e))}function J(t,e,r){let n=y(t,e);if(n?.[r])return n}function y(t,e){return e?t.peers?.[e]:void 0}function O(t,e){if(e){let r=y(t,e);if(r)return r;throw B(`Unable to find peer ${e}`,{})}else throw B("Peer id is missing",{})}function f(t,e,r){if(e){let n=J(t,e,r);if(n)return n;throw B(`Unable to find peer ${e} in domain ${r}`,{})}else throw B("Peer id is missing",{})}function E(t){return t?.source.type==="local"}function ee(t,e,r){return X(e?.[t]?.restrictions,[e?.source,e?.identity],[{type:"cluster"},r])}function bo(t,e){let r=dt(e);return t.identities?.get(r)}function ld(t){return Object.values(t.peers||{})}function te(t,e){return Array.from(t.domains?.[e]??[],r=>J(t,r,e)).filter(le)}function ln(t,e,r,n,i,o){let s=y(t,r);if(s)return[t,s];let a=(0,xe.produce)({id:r,identity:n,source:e},c=>{o&&(c.options=o),i&&(c.creationRequest=i)});return[(0,xe.produce)(t,c=>{if(c.users=c.users||{},n.user){c.users.byName=c.users.byName||new Map;let d=c.users.byName.get(n.user);d?d.add(r):c.users.byName.set(n.user,new Set([r]))}else c.users.noUser=c.users.noUser||new Set,c.users.noUser.add(r);c.identities=c.identities||new Map,c.identities.set(dt(n),r),c.peers=c.peers||{},c.peers[r]=(0,xe.castDraft)(a),o?.service&&(c.services=c.services||new Set,c.services.add(r))}),a]}function xo(t,e){let r=e.identity,n=e.id,i=r.user;return(0,xe.produce)(t,o=>{if(o.identities&&o.identities.delete(dt(r)),o.users)if(i){let s=o.users.byName?.get(i);s&&(s.delete(n),s.size==0&&o.users.byName?.delete(i)),o.users.byName&&o.users.byName.size===0&&delete o.users.byName}else o.users.noUser?.delete(n),o.users.noUser?.size===0&&delete o.users.noUser;o.peers&&delete o.peers[n],o.services=o.services||new Set,o.services&&o.services.delete(n)})}function M(t,e,r){return(0,xe.produce)(t,n=>{n.peers=n.peers||(0,xe.castDraft)({}),n.peers[e]=(0,xe.castDraft)(r)})}function Ge(t,e,r){return(0,xe.produce)(t,n=>{n.peers[e]=(0,xe.produce)(n.peers[e],r)})}function rr(t,e){let[r,n,i,o]=t,[s,a,c,d]=e;if(!i&&!c){let u=a?.user,p=n?.user;return d||o||u===p}else return X(i,[r,n],[s,a])&&X(c,[s,a],[r,n])}function ut(t,e,r){return r.id!==e.id&&rr([e.source,e.identity,e[t]?.restrictions,e.options?.service],[r.source,r.identity,r[t]?.restrictions,r.options?.service])}function fo(t,e,r,n=!1){return te(t,e).concat(Array.from(t.services??[],i=>y(t,i)).filter(le)).filter(i=>n&&r.id===i.id||ut(e,r,i))}function re(t,e,r,n){if(r.options?.service)return fo(t,e,r,n);{let i=r.identity.user;return i?Array.from(t.users?.byName?.get(i)??[]).concat(Array.from(t.services??[])).map(o=>y(t,o)).filter(le).filter(o=>po(o,e)&&ut(e,r,o)||n===!0&&o.id===r.id):fo(t,e,r,n)}}function yd(t,e,r,n,i){let o=i.identity,s=i.id,a=n.id,c=E(n);return(0,xe.produce)(e,d=>{c&&d.push(We(t,r,a,s,o,{local:c})),E(i)&&d.push(We(t,i.source,s,a,n.identity,{local:c}))})}function nr(t,e,r,n,i){return re(r,e,i).reduce((o,s)=>yd(t,o,n,i,s),[])}function ir(t,e,r,n,i,o){let s=n.id;return[Z(r,s,e),re(r,e,n).filter(E).reduce((a,c)=>(a=a.concat(Be(t,c.source,c.id,s,i)),!o&&E(n)&&(a=a.concat(Be(t,n.source,s,c.id,i))),a),[])]}function fd(t,e){if(t===e)return!0;let r=Object.keys(t);if(r.length!==Object.keys(e).length)return!1;for(let n of r)if(t[n]!==e[n])return!1;return!0}function gd(t,e,r){let{peer_id:n}=r,i=y(t,n);if(i&&!fd(e,i.source))throw B(`The original source ${JSON.stringify(i.source)} of peer ${n} doesnt match the current source ${JSON.stringify(e)}`,{message:"Bad Source"})}var pt=g("gateway.node");function hd(t,e){let r=Object.values(e.registeredDomains).filter(n=>n.info.uri!==Ae).map(n=>n.domain);return e.registeredDomains[Ae]&&r.push(e.registeredDomains[Ae].domain),r.reduce(([n,i],o)=>{pt.enabledFor("debug")&&pt.debug(`About to remove source from domain ${JSON.stringify(o.info())}`);let s=o.handleMessage(n,t);if(s){pt.enabledFor("debug")&&pt.debug(`removed source from domain ${JSON.stringify(o.info())}`);let[a,c]=s;return[a,i.concat(c)]}else return[n,i]},[e,[]])}function Ye(t,e,r){if(e.body.type==="commands/source-removed")return hd(e,t);{let{body:n}=e,{registeredDomains:i}=t,o=n.domain??Ae,s=i[o]?.domain;if(s)return pt.enabledFor("debug")&&pt.debug(`Handling message with domain ${JSON.stringify(s.info())} message:
${JSON.stringify(e,null," ")}`),gd(t,r,n),s.handleMessage(t,e);{let a=n;return[t,[h(a.domain,r,a.request_id,a.peer_id,x(Ue,`Unable to find domain for message ${JSON.stringify(e)}`))]]}}}function or(t){return t.reduce((e,r)=>{let n=r.info(),i={};return i[n.uri]={domain:r,info:n},Object.assign(e,i)},{})}$();ye();var yn=class{constructor(e){this.handler=e}close(){}message(e){this.handler(e)}addSource(e){}removeSource(e){let r={origin:"local",source:e,body:{type:"commands/source-removed"}};return this.handler(r)}},ke=g("gateway.node.local");function bd(t,e){let{source:r,body:n,origin:i}=e;try{return n.dump?(ke.info(`state dump:
${JSON.stringify($e(t),null," ")}`),[t,[]]):i==="cluster"?[t,[]]:Ye(t,e,r)}catch(o){ke.error(`Error handling message ${JSON.stringify(e)}`,o);let s=n;return[t,[h(void 0,r,s.request_id,s.peer_id,H(o,Ue))]]}}function xd(t){return"receive"in t&&t.receive}function vd(t){switch(t.receiver.type){case"cluster":return;case"node":return;case"peer":return;case"local":{let{receiver:e,body:r}=t;ke.enabledFor("debug")&&ke.debug(`Sending message ${JSON.stringify(r,null," ")} to ${JSON.stringify(e)}`),xd(e)&&e.receive(r);break}default:{ke.error(`Unable to process response ${JSON.stringify(t)}`);break}}}function Rd(t,e){try{ke.enabledFor("trace")&&ke.debug(`domain handler processing message ${JSON.stringify(e)}`);let[r,n]=bd(t,e);if(n)for(let i of n)vd(i);return r??t}catch(r){return ke.error(`error handling message ${JSON.stringify(e)}`,r),t}}function vo(t,e){let r,n=o=>{try{r=Rd(r,o)}catch(s){throw ke.error(`Error processing internal message ${JSON.stringify(o)}`,s),s}},i=or(t);return r=t.reduce((o,s)=>s.init(o),{...tr(e?.nodeId??C(),e?.signingKey),registeredDomains:i,handler:n}),new yn(n)}var _=Ae,fn=Ue,Ro=`${_}.errors.unhandled_message`,gn=`${_}.errors.already_seen`,hn=`${_}.errors.invalid_domain`,uf=`${_}.errors.invalid_context`,bn=`${_}.errors.authentication.failure`,xn=`${_}.errors.invalid_peer`;$();function So(t,e,r,n,i,o){let s={domain:_,type:"welcome",request_id:e,peer_id:r,available_domains:n,resolved_identity:i};return o&&(s.options=o),b(t,s)}function wo(t,e,r,n,i){let o={domain:t,type:"authentication-request",request_id:r,authentication:i};return n&&(o.peer_id=n),b(e,o)}function mt(t,e,r,n,i,o){let s={domain:_,type:"join",request_id:t,peer_id:e,destination:n,identity:i};return r&&(s.restrictions=r),o&&(s.options=o),s}function Io(t){return b(t,{type:"ping"})}var vn={application:{required:!0},instance:{required:!1},region:{required:!1},environment:{required:!1},machine:{required:!1},user:{required:!1}};function wd(t){return Object.keys(vn).find(e=>vn[e]&&vn[e].required&&t[e]===void 0)}function To(t){let e=wd(t);if(e)throw new Ce(`Identity ${JSON.stringify(t)} is missing required key: ${e}`,{})}function Ao(t,e){let r=t;return r&&r.indexOf(":")!==-1&&(r=r.substring(0,r.indexOf(":"))),r&&r.indexOf("127.0.0.1")>=0?e??r:r??e}var sr=require("jsrsasign");function _t(t,e){return sr.KJUR.jws.JWS.sign(null,{alg:"HS256",typ:"JWT"},t,e)}function ar(t,e,r){let n;if(sr.KJUR.jws.JWS.verifyJWT(t,e,{alg:["HS256"],verifyAt:r?.now}))n=sr.KJUR.jws.JWS.parse(t);else throw new Error("invalid jwt token");return n.payloadObj}function Rn(t,e,r,n){let i={type:"gw-request","impersonate-peer":e,"gw-request":r};return n&&(i.exp=Math.floor(n/1e3)),_t(i,t.signatureKey)}function Co(t,e,r){let n={type:"authentication",user:e.user};return r&&(n.exp=Math.floor(r/1e3)),_t(n,t.signatureKey)}function Mo(t,e,r){r===void 0&&(r=r??Date.now());let n={};return r&&(n.now=Math.floor(r/1e3)),ar(e,t,n)}var ae=require("immer");function Do(t){return Object.values(t.contexts||{})}function cr(t,e){return(0,ae.produce)(t,r=>{r.contexts=r.contexts||{},r.contexts[e.id]=(0,ae.castDraft)(e)})}function dr(t,e){return(0,ae.produce)(t,r=>{r.contexts&&(delete r.contexts[e],Object.values(r.contexts).length===0&&delete r.contexts)})}function Xe(t,e,r){let n=r.identity.user,i=r.options?.service,o=Object.values(t.contexts||{}),s;return s=o.find(a=>e===a.name&&a.identity.user===n),s||(s=o.find(a=>e===a.name&&(i||a.options?.service))),s}function Fe(t,e){if(e)return t.contexts?.[e]}function Ot(t,e){let r=t.contexts?.[e];if(r)return r;throw B(`Unable to find context with id ${e}`,{})}function lt(t,e,r){return e&&r?e.members.has(r)?t:(0,ae.produce)(t,i=>{i.contexts=i.contexts||{},i.contexts[e.id]=(0,ae.castDraft)((0,ae.produce)(e,o=>{o.members=o.members||new Set,o.members.add(r)}))}):t}function ur(t,e,r){return(0,ae.produce)([t,e],([n,i])=>{i.members.delete(r),r===i.owner&&delete i.owner,n.contexts=n.contexts||{},n.contexts[e.id]=i})}function _o(t,e,r){if(!e)return r;if(e.length===1)t[e[0]]=r;else{let n=t[e[0]];(n===void 0||Array.isArray(n)||typeof n=="number"||typeof n=="boolean")&&(n={}),t[e[0]]=_o(n,e.slice(1),r)}return t}function Id(t,e){return{...t,...e}}function Td(t,e){let[r,n]=e;switch(r){case"removed":{n.forEach(i=>{delete t?.[i]});break}case"added":{t=Object.entries(n).reduce((i,[o,s])=>(i[o]=s,i),t??{});break}case"updated":{t=Object.entries(n).reduce((i,[o,s])=>(Array.isArray(s)&&Array.isArray(i[o])?i[o]=s:s instanceof Object&&i[o]instanceof Object?i[o]=Id(i[o],s):i[o]=s,i),t??{});break}case"reset":{n&&(t=n);break}case"commands":{t=n.reduce((i,o)=>{switch(o.type){case"set":return _o(i??{},Po(o.path),o.value);case"remove":{let s=Po(o.path);if(s){let a=i;for(let c=0;c<s.length-1;c++){let d;if(typeof a!="object")return i;d=a?.[s[c]],a=d}a&&delete a[s[s.length-1]]}else return{};return i}}},t);break}}return t}function Oo(t,e,r,n){return(0,ae.produce)(t,i=>{i.contexts[e].data=Object.entries(r).reduce((o,[s,a])=>Td(o,[s,a]),i.contexts[e].data),i.contexts[e].version=n})}function Po(t){if(t)return t.split(".")}function pr(t,e,r,n,i,o,s,a,c){let d=t.identity,u=t.options,p={id:a,data:r??{},identity:d,lifetime:n,read_permissions:i,write_permissions:o,permissions:s,members:new Set,version:c,name:e,creator:t.id};return u&&((0,ae.castDraft)(p).options=u),p.permissions===void 0&&delete(0,ae.castDraft)(p).permissions,p.read_permissions===void 0&&delete(0,ae.castDraft)(p).read_permissions,p.write_permissions===void 0&&delete(0,ae.castDraft)(p).write_permissions,p}function No(t){let e=t.version?.updates||0;e++;let r=Date.now();return{updates:e,timestamp:r}}function mr(){return{updates:0,timestamp:Date.now()}}function He(t){return X(t.permissions?.read,[{type:t.local?"local":"cluster"}