@interopio/gateway
Version:
[](https://www.npmjs.com/package/@interopio/gateway)
4 lines • 153 kB
JavaScript
"use strict";var Vc=Object.create;var Wt=Object.defineProperty;var zc=Object.getOwnPropertyDescriptor;var Qc=Object.getOwnPropertyNames;var Yc=Object.getPrototypeOf,Zc=Object.prototype.hasOwnProperty;var Se=(t,e)=>()=>(t&&(e=t(t=0)),e);var Be=(t,e)=>{for(var r in e)Wt(t,r,{get:e[r],enumerable:!0})},Ji=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Qc(e))!Zc.call(t,i)&&i!==r&&Wt(t,i,{get:()=>e[i],enumerable:!(n=zc(e,i))||n.enumerable});return t};var Wr=(t,e,r)=>(r=t!=null?Vc(Yc(t)):{},Ji(e||!t||!t.__esModule?Wt(r,"default",{value:t,enumerable:!0}):r,t)),Xc=t=>Ji(Wt({},"__esModule",{value:!0}),t);var Yr={};Be(Yr,{regexify:()=>Jt,valueMatches:()=>Ke,valuesMatch:()=>Qr});function ed(t){return typeof t=="string"}function Ke(t,e){return ed(t)?t===e:typeof e=="string"?t.test(e):!1}function Qr(t,e){for(let r of t)if(Ke(r,e))return!0;return!1}function Jt(t){if(typeof t=="string"){let e=rd.exec(t)?.groups;if(e??=td.exec(t)?.groups,e?.pattern)return new RegExp(e.pattern,e.flags??"")}return t}var td,rd,jt=Se(()=>{"use strict";td=/^#(\(\?(?<flags>[im]*)\))?(?<pattern>.*)$/,rd=/^\/(?<pattern>(?:[^/\\]|\\.)+)\/(?<flags>[gimsuyd]*)$/});function g(t){return zi.getLogger(t)}var zi,q=Se(()=>{"use strict";zi=Wr(require("@interopio/gateway/logging/core"),1)});function co(t,e){return e.reduce((r,n)=>n===t?r:r.concat(n),[])}function un(t,e){return t[e]?t:(0,ao.produce)(t,r=>{r[e]={}})}function Le(t){return t instanceof Set?Array.from(t).map(Le):t instanceof Array?t.map(Le):t instanceof Map?Le(Object.fromEntries(t)):t instanceof Object?Object.keys(t).reduce((e,r)=>(e[r]=Le(t[r]),e),{}):t}function ud(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 st(...t){return ud((e,r,n)=>t.indexOf(n)!==-1?"******":r)}function at(t){return JSON.stringify(t,Object.keys(t).sort(pd))}function ye(t){return!!t}var ao,pd,fe=Se(()=>{"use strict";ao=require("immer");pd=(t,e)=>t.localeCompare(e)});function nm(t,e){for(let[r,n]of Object.entries(t)){let i=e[r];if(!Ke(n,i))return!1}return!0}function Qa(t,e){return Qr(t,e)}function Ut(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&&Qa(a,e))return!1;{let c=s.metrics.allow??s.metrics.whitelist??[];return o||Qa(c,e)}}return o},void 0);if(n!==void 0)return n;let i=r?.non_matched??"allow";return i==="allow"||i==="whitelist"}var mi=Se(()=>{"use strict";jt()});function ym(t){if(t&&Object.keys(t).length>0)return t}function Xa(t){return typeof t=="object"?{value:Object.entries(t).reduce((r,[n,i])=>(r[n]=Xa(i),r),{})}:typeof t=="string"?{value:t}:{value:t}}function fm(t){return{timestamp:t.timestamp??Date.now(),value:Xa(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*xt(t,e){Za.enabledFor("trace")&&Za.debug(`conflating ${JSON.stringify(e)}`);let r=gm(e,i=>at(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,Ar=Se(()=>{"use strict";q();fe();Za=g("gateway.metrics.common")});var rc={};Be(rc,{NodeWorker:()=>hi});var ec,gi,tc,hi,nc=Se(()=>{"use strict";ec=require("child_process"),gi=require("events"),tc=require("url"),hi=class{events=new gi.EventEmitter;ps;constructor(e,r,n){this.events=new gi.EventEmitter;let i=(0,tc.fileURLToPath)(e);this.ps=(0,ec.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(()=>(nc(),rc)),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 ic({url:t,parameters:e,options:r}){return typeof process<"u"?hm(t,e,r):bm(t,e,r)}var oc=Se(()=>{"use strict"});async function Rm(t,e){try{let r=await import(e);if(typeof r=="function")return await r();if(typeof r.default=="function")return await r.default()}catch(r){t.error("failed to load preload",r)}}async function xm(t,e,r){t.debug(`loading publisher from ${e}`);let n=await import(e);return typeof n.default=="object"&&(n=n.default),await n.create(r,t.child(`publisher.${n.name??e}`))}var Cr,sc=Se(()=>{"use strict";Cr=class{#e;#t;#r;constructor(e){this.#e=e}async#n(e){let{publishFn:r,cfg:n}=e;if(n?.preload){let s=await Rm(this.#e,n.preload);if(typeof s=="object")for(let a in s)n[a]=s[a]}let i;typeof r=="function"?i=r:i=await xm(this.#e,r,n);let o=await i("start");this.#t=i,this.#r=o}async#i(){let e=await this.#t?.("stop");typeof e=="function"&&await e(this.#r)}async#o(e){if(!this.#t)throw new Error("worker not started");await this.#t(e)}async execute(e,r){switch(e){case"start":{await this.#n(r);break}case"stop":{await this.#i();break}case"update":{await this.#o(r);break}}}}});function bi(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 St(t,e,r){Z.info(`creating publisher with configuration
${JSON.stringify(t,st("authentication.password"))}`);try{let n=t?.worker;if(n===void 0)return await Sm(r,t??{},e);{let i=t?Object.fromEntries(Object.entries(t).filter(([o])=>o!=="worker")):{};return await vm(r,i,e,n)}}catch(n){throw Z.error("Failed to create basic publisher",n),n}}async function Sm(t,e,r){let n=new vi(e),i=o=>{for(let s of r([o]))n.next(s)};return await n.start(t),i.close=async()=>{await n.stop()},i.on=o=>{n.on(o)},i}async function vm(t,e,r,n){let i=new wi(await ic(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 vt(t,e){return new Si(t,e)}var Pr,Ri,Z,xi,Si,Mr,vi,wi,Dr=Se(()=>{"use strict";oc();Pr=require("@interopio/gateway/logging/core"),Ri=require("serialize-error");fe();mi();sc();Z=(0,Pr.getLogger)("gateway.metrics.publisher");xi=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(){Z.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=bi(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=bi(this.repoId,i,this.metadata);this.publisher(o)},this.heartbeatInterval))}stop(){Z.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||Ut(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=bi(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 xi(this.publisher,this.config?.filters,e,i,n)}async shutdown(){await this.publisher.close()}on(e){this.publisher.on(e)}};Mr=class{#e;#t;#r;#n;#i;#o;constructor(e){let{buffer_size:r}=e;this.#e=e,this.#t=r??1e3,this.#r=new Map,this.#n=new Map,this.#i=[],this.#o=0}async start(e){try{await this.enqueue("start",{cfg:this.#e,publishFn:e})[1],Z.info(`publisher [${e}] started`)}catch(r){throw Z.error(`error starting publisher [${e}]: ${r}`),r}}next(e){let[r,n]=this.enqueue("update",e);n.catch(i=>{Z.warn(`update [${r}] error`,i)}).finally(()=>{this.#n.delete(r)})}async stop(e=!1,r=1e3){Z.info(`stopping publisher worker rejectProcessing: ${e}, timeout: ${r}, promises: ${this.#n.size}`);let n=s=>{this.#r.forEach(({resolver:a})=>{a.reject(new Error(`reject on stop: ${s}`))})};e&&n("now");let i=Promise.allSettled(this.#n),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"&&Z.error(`Pending future failed with ${u.reason} on stop`);s()})}),await o,this.#n.size>0&&Z.error(`uncleared promises: ${this.#n.size}`),Z.info("publisher worker stopped")}enqueue(e,r){this.#r.size>=this.#t&&Z.warn(`processing queue is full. dropping cmd: ${JSON.stringify(e)}`);let n=++this.#o;return[n,new Promise((i,o)=>{this.#r.set(n,{resolver:{resolve:i,reject:o}}),this.processRequest(n,e,r)})]}processResult(e,r,n){let i=this.#r.get(e);if(i){let{resolver:o}=i;try{n?o.reject(n):o.resolve(r)}finally{this.#r.delete(e)}}else Z.error(`unknown message id: ${e}`)}emit(e){this.#i.forEach(r=>r(e))}on(e){this.#i.push(e)}},vi=class extends Mr{#e;constructor(e){super(e),this.#e=new Cr(Z)}processRequest(e,r,n){this.#e.execute(r,n).then(()=>{this.processResult(e,"ok")}).catch(i=>{this.processResult(e,"error",i instanceof Error?i:new Error(String(i)))})}},wi=class extends Mr{worker;constructor(e,r){super(r),this.worker=e}processRequest(e,r,n){let i={id:e,cmd:r,arg:n};this.worker.postMessage(i)}async stop(e=!1,r=1e3){try{return await super.stop(e,r)}finally{this.worker.terminate()}}async start(e){await new Promise(r=>{this.worker.onerror=n=>{Z.error(`error from worker: ${n.message}`)},this.worker.onmessageerror=n=>{Z.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;super.processResult(i,o,s==null?void 0:(0,Ri.deserializeError)(s))}else if(n.data.log){let{level:i,time:o,name:s,message:a,data:c}=n.data.log;(0,Pr.logEvent)({level:i,time:new Date(o),name:s,message:a,data:c.map(d=>(0,Ri.deserializeError)(d))})}else n.data.event&&super.emit(n.data.event)}});try{await super.start(e),Z.info(`publisher worker [${e}] started`)}catch(r){throw Z.error(`error starting publisher worker [${e}]: ${r}`),this.worker.terminate(),r}}}});var dc={};Be(dc,{restPublisher:()=>cc,restRepositoryFactory:()=>wm});async function cc(t){let e=t?.conflation?.["max-datapoints-repo"]??50;return await St(t,r=>xt(e,r),t?.publishFn??"@interopio/gateway/metrics/publisher/rest")}async function wm(t){return vt(t,await cc(t))}var uc=Se(()=>{"use strict";Dr();Ar()});var pc={};Be(pc,{fileRepositoryFactory:()=>Am});async function Tm(t){let e=t.conflation?.["max-datapoints-repo"]??50;return Im.info(`will record metrics to ${t.location}`),await St(t,r=>xt(e??1,r),t?.publishFn??"@interopio/gateway/metrics/publisher/file")}async function Am(t){return vt(t,await Tm(t))}var Im,mc=Se(()=>{"use strict";Dr();Ar();q();Im=g("gateway.metrics.file")});var cy={};Be(cy,{IOGateway:()=>Wi,default:()=>ay});module.exports=Xc(cy);var Wi={};Be(Wi,{Encoding:()=>nt,Factory:()=>Gi,Filtering:()=>Yr,Logging:()=>sy});var nt={};Be(nt,{direct:()=>zr,json:()=>Vr,transit:()=>Kr});var Ae=Wr(require("transit-js"),1),Jr=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 Ae.default.keyword(t);let n=t.substring(0,r),i=e?.get(n)??n;return Ae.default.keyword(i+t.substring(r))}function Bi(t,e){let r=t.name(),n=t.namespace();return n===null?r:(e.rev(n)??n)+"/"+r}function Vi(t,e,r,n=""){if(t instanceof Array)return t.map(i=>i);if(t instanceof Object){let i=Ae.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=Vi(c,e,r,d);i.set(a,m)}}return i}else return t}function jr(t,e){if(Ae.default.isKeyword(t))return Bi(t,e);if(Ae.default.isMap(t)){let r={};for(let[n,i]of t){let o=Ae.default.isKeyword(n)?Bi(n,e):n;r[o]=jr(i,e)}return r}else if(Ae.default.isList(t)||t instanceof Array){let r=[];for(let n of t)r.push(jr(n,e));return r}return t}function Kr(t){let e=t?.verbose?"json-verbose":"json",r=new Jr(t?.namespaces);return{encode:n=>{let i=Vi(n,r,t?.keywordize);return Ae.default.writer(e).write(i)},decode:n=>{let i;try{i=Ae.default.reader(e).read(n)}catch(o){throw new Error(`"${n}" is not valid TRANSIT`,{cause:o})}return jr(i,r)}}}function Vr(){return{encode:JSON.stringify,decode:JSON.parse}}function Ki(t){return t}function Br(t){return t instanceof Array||Array.isArray(t)?t.map(Br):t?.constructor===Object?Object.keys(t).reduce((e,r)=>(e[r]=Br(t[r]),e),{}):t===void 0?null:t}function zr(t){return{encode:Ki,decode:t?.cljs??!1?Br:Ki}}var sy=Wr(require("@interopio/gateway/logging/core"),1);jt();q();var Ce="global",ce="context",Ue=`${Ce}.errors.failure`;q();function x(t,e){return{receiver:t,body:e}}function W(t,e){return{...x({type:"cluster"},e),source:t}}function V(t,e,r){return{...x(e,r),source:t}}function nd(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 b(t,e,r,n,i,o){return x(e,nd(t,r,n,i,o))}function id(t,e,r){return{type:"success",request_id:e,domain:t,peer_id:r}}function T(t,e,r,n){return x(e,id(t,r,n))}function A(t){let e=t.type;return e&&e==="local"}function J(t){return!A(t)}function od(t,e,r,n){return{domain:t,type:"token",request_id:e,peer_id:r,token:n}}function Yi(t,e,r,n,i){return x(e,od(t,r,n,i))}function sd(t,e,r,n,i){return{domain:t,type:"peer-added",peer_id:e,new_peer_id:r,identity:n,meta:i}}function He(t,e,r,n,i,o){return x(e,sd(t,r,n,i,o))}function ad(t,e,r,n){return{domain:t,type:"peer-removed",peer_id:e,removed_id:r,reason_uri:n.uri,reason:n.message}}function Ve(t,e,r,n,i){return x(e,ad(t,r,n,i))}var Me=class extends Error{data;cause;constructor(e,r,n){super(e),this.name="ExceptionInfo",this.data=r,this.cause=n}};function z(t,e,r){return new Me(t,e,r)}function ze(t){if(t instanceof Me)return t.data}function Qe(t){if(t instanceof Error)return t.message}function S(t,e){return{uri:t,message:e}}function j(t,e){let r=ze(t);return{uri:r?.uri??e,message:r?.message??Qe(t)??""}}function N(t,e){let r={uri:t,message:e};throw new Me(e,r)}function Y(t){return{uri:t.reason_uri,message:t.reason}}var Yt=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 Zr(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 Bt(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 be(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 Xr(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 tn(this,new be(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 en(this,new be(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 X(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 sn(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 on(this,new X(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 nn(this,new X(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 rn(this,new X(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 Ye(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 Kt(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 Vt(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 zt(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 Tt(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 Qt(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))},Zr=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}expr(){return this.getTypedRuleContext(Bt,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)}},Bt=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}andOr(){return this.getTypedRuleContext(be,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)}},be=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)}},Xr=class extends be{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}eqNeq(){return this.getTypedRuleContext(X,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)}},en=class extends be{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}andOr(){return this.getTypedRuleContext(be,0)}OR(){return this.getToken(P.OR,0)}eqNeq(){return this.getTypedRuleContext(X,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)}},tn=class extends be{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}andOr(){return this.getTypedRuleContext(be,0)}AND(){return this.getToken(P.AND,0)}eqNeq(){return this.getTypedRuleContext(X,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)}},X=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)}},rn=class extends X{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}eqNeq(){return this.getTypedRuleContext(X,0)}MATCH(){return this.getToken(P.MATCH,0)}term(){return this.getTypedRuleContext(Ye,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)}},nn=class extends X{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}eqNeq(){return this.getTypedRuleContext(X,0)}NEQ(){return this.getToken(P.NEQ,0)}term(){return this.getTypedRuleContext(Ye,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)}},on=class extends X{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}eqNeq(){return this.getTypedRuleContext(X,0)}EQ(){return this.getToken(P.EQ,0)}term(){return this.getTypedRuleContext(Ye,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)}},sn=class extends X{constructor(e,r){super(e,r.parentCtx,r.invokingState),super.copyFrom(r)}term(){return this.getTypedRuleContext(Ye,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)}},Ye=class extends I.ParserRuleContext{constructor(e,r,n){super(r,n),this.parser=e}ident(){return this.getTypedRuleContext(Kt,0)}ownIdent(){return this.getTypedRuleContext(Vt,0)}number_(){return this.getTypedRuleContext(Qt,0)}str(){return this.getTypedRuleContext(zt,0)}LPAREN(){return this.getToken(P.LPAREN,0)}andOr(){return this.getTypedRuleContext(be,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)}},Kt=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(Tt,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)}},Vt=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(Tt,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)}},zt=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)}},Tt=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)}},Qt=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 Re=require("antlr4"),At=class t extends Re.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=Re.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 Re.LexerATNSimulator(this,t._ATN,t.DecisionsToDFA,new Re.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 Re.ATNDeserializer().deserialize(t._serializedATN)),t.__ATN}static DecisionsToDFA=t._ATN.decisionToState.map((e,r)=>new Re.DFA(e,r))};var Xi=require("antlr4"),Ct=class extends Xi.ParseTreeVisitor{visitParse;visitExpr;visitAndOrEqNeq;visitOr;visitAnd;visitMatch;visitNeq;visitEq;visitEqNeqTerm;visitTerm;visitIdent;visitOwnIdent;visitStr;visitWord;visitNumber};var $=new Ct,it=t=>{let e=$.visitChildren(t);return e.length==1?e[0]:e};$.visitParse=t=>t.expr().accept($);$.visitExpr=t=>["expr",it(t)];$.visitAndOrEqNeq=it;$.visitEqNeqTerm=it;$.visitTerm=t=>t.getChildCount()===3?$.visit(t.getChild(1)):it(t);$.visitEq=t=>{let e=it(t.eqNeq()),r=t.term().accept($);return["eq",e,r]};$.visitNeq=t=>{let e=it(t.eqNeq()),r=t.term().accept($);return["neq",e,r]};$.visitMatch=t=>["match",$.visitChildren(t.eqNeq())[0],t.term().accept($)];$.visitAnd=t=>{let e=$.visitChildren(t.andOr()),r=$.visitChildren(t.eqNeq());return["and",e[0],r[0]]};$.visitIdent=t=>["ident",t.word().accept($)];$.visitOwnIdent=t=>["own-ident",t.word().accept($)];$.visitWord=t=>["word",t.WORD().symbol.text];$.visitNumber=t=>["number",t.NUMBER().symbol.text];$.visitStr=t=>["str",t.STR().symbol.text.slice(1,-1)];var eo=$;function to(t){let e=Yt.CharStreams.fromString(t),r=new At(e),n=new Yt.CommonTokenStream(r);return new P(n).parse().accept(eo)}function an(t,e){if(Array.isArray(e)){let[r,...n]=e,i=t[r];if(i){let s=n.map(a=>an(t,a));return i.apply(t,s)}let o=n.map(s=>an(t,s));return[r].concat(o)}return e}function ro(t,e,r){return(t?.length??0)>0?an({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 ee(t){return typeof t=="string"?t==="cluster"||t==="local"?t:to(t):t}function te(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:!!ro(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 ke(t=globalThis.crypto){return t.randomUUID().replaceAll("-","")}function C(t){return t?t.nodeId:ke()}function Ne(t){let e=t.currentId??1,r=`r-${t.nodeId}-${e}`;return[{...t,currentId:e+1},r]}function no(t){let e=t.currentId??1,r=`i-${t.nodeId}-${e}`;return[{...t,currentId:e+1},r]}function Zt(t){let e=t.currentId??1,r=`c-${t.nodeId}-${e}`;return[{...t,currentId:e+1},r]}function io(t){let e=t.currentId??1,r=`a-${t.nodeId}-${e}`;return[{...t,currentId:e+1},r]}function oo(t){let e=t.currentId??1,r=`p-${t.nodeId}-${e}`;return[{...t,currentId:e+1},r]}var Ze=require("immer");(0,Ze.enableMapSet)();function Xt(t,e){let r=e??ke();return{ids:{nodeId:t,currentId:1},signatureKey:r}}function ve(t,e,r,n){return(0,Ze.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 re(t,e,r){return(0,Ze.produce)(t,n=>{n.peers&&delete n.peers[e][r],n.domains&&n.domains[r]&&n.domains[r].delete(e)})}function me(t,e,r){return!!t.domains?.[r]?.has(e)}function so(t,e){return!!t[e]}function dn(t,e,r){return e?(0,Ze.produce)(t,n=>{n.gatewayRequests=n.gatewayRequests||{},n.gatewayRequests[e]=r}):t}function ot(t,e){return(0,Ze.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 Mt(t,e){return t.registeredDomains?.[e]?.domain}function le(t,...e){return e.reduce(([r,n],i)=>{let[o,s]=i(r);return[o,n.concat(s)]},[t,[]])}var xe=require("immer");fe();function po(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 Pe(t,e,r){return ie(t,r).filter(n=>po(n.source,e))}function mo(t,e){return md(t).filter(r=>po(r.source,e))}function K(t,e,r){let n=h(t,e);if(n?.[r])return n}function h(t,e){return e?t.peers?.[e]:void 0}function O(t,e){if(e){let r=h(t,e);if(r)return r;throw z(`Unable to find peer ${e}`,{})}else throw z("Peer id is missing",{})}function R(t,e,r){if(e){let n=K(t,e,r);if(n)return n;throw z(`Unable to find peer ${e} in domain ${r}`,{})}else throw z("Peer id is missing",{})}function E(t){return t?.source.type==="local"}function ne(t,e,r){return te(e?.[t]?.restrictions,[e?.source,e?.identity],[{type:"cluster"},r])}function lo(t,e){let r=at(e);return t.identities?.get(r)}function md(t){return Object.values(t.peers||{})}function ie(t,e){return Array.from(t.domains?.[e]??[],r=>K(t,r,e)).filter(ye)}function pn(t,e,r,n,i,o){let s=h(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(at(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 yo(t,e){let r=e.identity,n=e.id,i=r.user;return(0,xe.produce)(t,o=>{if(o.identities&&o.identities.delete(at(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 Fe(t,e,r){return(0,xe.produce)(t,n=>{n.peers[e]=(0,xe.produce)(n.peers[e],r)})}function er(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 te(i,[r,n],[s,a])&&te(c,[s,a],[r,n])}function ct(t,e,r){return r.id!==e.id&&er([e.source,e.identity,e[t]?.restrictions,e.options?.service],[r.source,r.identity,r[t]?.restrictions,r.options?.service])}function uo(t,e,r,n=!1){return ie(t,e).concat(Array.from(t.services??[],i=>h(t,i)).filter(ye)).filter(i=>n&&r.id===i.id||ct(e,r,i))}function oe(t,e,r,n){if(r.options?.service)return uo(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=>h(t,o)).filter(ye).filter(o=>so(o,e)&&ct(e,r,o)||n===!0&&o.id===r.id):uo(t,e,r,n)}}function ld(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(He(t,r,a,s,o,{local:c})),E(i)&&d.push(He(t,i.source,s,a,n.identity,{local:c}))})}function tr(t,e,r,n,i){return oe(r,e,i).reduce((o,s)=>ld(t,o,n,i,s),[])}function rr(t,e,r,n,i,o){let s=n.id;return[re(r,s,e),oe(r,e,n).filter(E).reduce((a,c)=>(a=a.concat(Ve(t,c.source,c.id,s,i)),!o&&E(n)&&(a=a.concat(Ve(t,n.source,s,c.id,i))),a),[])]}function yd(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 fd(t,e,r){let{peer_id:n}=r,i=h(t,n);if(i&&!yd(e,i.source))throw z(`The original source ${JSON.stringify(i.source)} of peer ${n} doesnt match the current source ${JSON.stringify(e)}`,{message:"Bad Source"})}var dt=g("gateway.node");function gd(t,e){let r=Object.values(e.registeredDomains).filter(n=>n.info.uri!==Ce).map(n=>n.domain);return e.registeredDomains[Ce]&&r.push(e.registeredDomains[Ce].domain),r.reduce(([n,i],o)=>{dt.enabledFor("debug")&&dt.debug(`About to remove source from domain ${JSON.stringify(o.info())}`);let s=o.handleMessage(n,t);if(s){dt.enabledFor("debug")&&dt.debug(`removed source from domain ${JSON.stringify(o.info())}`);let[a,c]=s;return[a,i.concat(c)]}else return[n,i]},[e,[]])}function Xe(t,e,r){if(e.body.type==="commands/source-removed")return gd(e,t);{let{body:n}=e,{registeredDomains:i}=t,o=n.domain??Ce,s=i[o]?.domain;if(s)return dt.enabledFor("debug")&&dt.debug(`Handling message with domain ${JSON.stringify(s.info())} message:
${JSON.stringify(e,null," ")}`),fd(t,r,n),s.handleMessage(t,e);{let a=n;return[t,[b(a.domain,r,a.request_id,a.peer_id,S(Ue,`Unable to find domain for message ${JSON.stringify(e)}`))]]}}}function nr(t){return t.reduce((e,r)=>{let n=r.info(),i={};return i[n.uri]={domain:r,info:n},Object.assign(e,i)},{})}q();fe();var mn=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)}},qe=g("gateway.node.local");function hd(t,e){let{source:r,body:n,origin:i}=e;try{return n.dump?(qe.info(`state dump:
${JSON.stringify(Le(t),null," ")}`),[t,[]]):i==="cluster"?[t,[]]:Xe(t,e,r)}catch(o){qe.error(`Error handling message ${JSON.stringify(e)}`,o);let s=n;return[t,[b(void 0,r,s.request_id,s.peer_id,j(o,Ue))]]}}function bd(t){return"receive"in t&&t.receive}function Rd(t){switch(t.receiver.type){case"cluster":return;case"node":return;case"peer":return;case"local":{let{receiver:e,body:r}=t;qe.enabledFor("debug")&&qe.debug(`Sending message ${JSON.stringify(r,null," ")} to ${JSON.stringify(e)}`),bd(e)&&e.receive(r);break}default:{qe.error(`Unable to process response ${JSON.stringify(t)}`);break}}}function xd(t,e){try{qe.enabledFor("trace")&&qe.debug(`domain handler processing message ${JSON.stringify(e)}`);let[r,n]=hd(t,e);if(n)for(let i of n)Rd(i);return r??t}catch(r){return qe.error(`error handling message ${JSON.stringify(e)}`,r),t}}function fo(t,e){let r,n=o=>{try{r=xd(r,o)}catch(s){throw qe.error(`Error processing internal message ${JSON.stringify(o)}`,s),s}},i=nr(t);return r=t.reduce((o,s)=>s.init(o),{...Xt(e?.nodeId??C(),e?.signingKey),registeredDomains:i,handler:n}),new mn(n)}var _=Ce,ln=Ue,go=`${_}.errors.unhandled_message`,yn=`${_}.errors.already_seen`,fn=`${_}.errors.invalid_domain`,bf=`${_}.errors.invalid_context`,gn=`${_}.errors.authentication.failure`,hn=`${_}.errors.invalid_peer`;q();function ho(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),x(t,s)}function bo(t,e,r,n,i){let o={domain:t,type:"authentication-request",request_id:r,authentication:i};return n&&(o.peer_id=n),x(e,o)}function ut(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 Ro(t){return x(t,{type:"ping"})}var bn={application:{required:!0},instance:{required:!1},region:{required:!1},environment:{required:!1},machine:{required:!1},user:{required:!1}};function vd(t){return Object.keys(bn).find(e=>bn[e]&&bn[e].required&&t[e]===void 0)}function xo(t){let e=vd(t);if(e)throw new Me(`Identity ${JSON.stringify(t)} is missing required key: ${e}`,{})}function So(t,e){let r=t;if(r){let n=r.lastIndexOf(":");if(n!==-1&&(r.startsWith("[")?(r=r.substring(1),r=r.substring(0,r.indexOf("]"))):n===r.indexOf(":")&&(r=r.substring(0,n))),r.indexOf("127.0.0.1")>=0)return e??r}return r??e}var ir=require("jsrsasign");function Pt(t,e){return ir.KJUR.jws.JWS.sign(null,{alg:"HS256",typ:"JWT"},t,e)}function or(t,e,r){let n;if(ir.KJUR.jws.JWS.verifyJWT(t,e,{alg:["HS256"],verifyAt:r?.now}))n=ir.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)),Pt(i,t.signatureKey)}function vo(t,e,r){let n={type:"authentication",user:e.user};return r&&(n.exp=Math.floor(r/1e3)),Pt(n,t.signatureKey)}function wo(t,e,r){r===void 0&&(r=r??Date.now());let n={};return r&&(n.now=Math.floor(r/1e3)),or(e,t,n)}var Uo=require("immer");function w(t,e){return{type:"peer",peer:e,node:t}}function $e(t){return{type:"node",node:t}}var Io=require("immer");function xn(t){return Object.values(t.contexts||{})}q();q();var wd=g("gateway.action"),To="info";function U(t,e){let r=wd.child(t);if(r.enabledFor(To)){let n=e();r[To](n)}}fe();function Dt(t){return`${t}.errors.not_authorized`}function Ao(t){return`${t}.errors.bad_lifetime`}function Co(t){return`${t}.errors.invalid_context`}function Mo(t){return`${t}.errors.unhandled_message`}function Sn(t){return S(`${t}.destroyed`,"Context destroyed explicitly")}function Po(t){return S(`${t}.peer-left`,"Context destroyed because its owner/last peer left")}function Ge(t){return`${t}.errors.failure`}function Do(t,e,r,n,i,o){return x(e,{domain:t,type:"subscribed-context",request_id:r,peer_id:n,context_id:i,data:o})}function vn(t,e,r,n,i,o){return x(e,{domain:t,type:"context-added",peer_id:r,creator_id:n,context_id:i,name:o})}function wn(t,e,r,n,i){let o={domain:t,type:"context-destroyed",peer_id:r,context_id:n,reason_uri:i.uri,reason:i.message};return x(e,o)}function _o(t,e,r,n,i){return x(e,{domain:t,type:"context-created",request_id:r,peer_id:n,context_id:i})}function Oo(t,e,r,n,i,o){return x(e,{domain:t,type:"context-updated",peer_id:r,updater_id:n,context_id:i,delta:o})}var de=require("immer");function No(t){return Object.values(t.contexts||{})}function sr(t,e){return(0,de.produce)(t,r=>{r.contexts=r.contexts||{},r.contexts[e.id]=(0,de.castDraft)(e)})}function ar(t,e){return(0,de.produce)(t,r=>{r.contexts&&(delete r.contexts[e],Object.values(r.contexts).length===0&&delete r.contexts)})}function et(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 We(t,e){if(e)return t.contexts?.[e]}function _t(t,e,r){let n=e.contexts?.[r];if(n)return n;throw z(`Unable to find context with id ${r}`,{uri:Co(t)})}function pt(t,e,r){return e&&r?e.members.has(r)?t:(0,de.produce)(t,i=>{i.contexts=i.contexts||{},i.contexts[e.id]=(0,de.castDraft)((0,de.produce)(e,o=>{o.members=o.members||new Set,o.members.add(r)}))}):t}function cr(t,e,r){return(0,de.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 qo(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]]=qo(n,e.slice(1),r)}return t}function Td(t,e){return{...t,...e}}function Ad(t,e){let[r,n]=e;switch(r){case"removed":{n.forEach(i=>{delet